/* =====================================================================
   CLAN V4 — Estilo Obsidian Codex
   2026-05-28 · Rediseño cinematográfico de la pantalla de Clan.
   No toca V3 (queda como fallback). Todas las clases prefijadas con .gv4-
   ===================================================================== */

.gv4-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  /* Margin-top de pegar al topbar lo maneja el hero ahora (margin-top: -24px). */
  --gv4-gold: #d4af37;
  --gv4-gold-light: #f3d775;
  --gv4-gold-deep: #8a6d1c;
  --gv4-gold-grad: linear-gradient(180deg, #f3d775 0%, #d4af37 45%, #a0801b 100%);
  --gv4-arcane: #a78bfa;
  --gv4-cyan: #5cc4ff;
  --gv4-emerald: #5cf28a;
  --gv4-blood: #ff5c7c;
  --gv4-ember: #ffaa50;
  --gv4-border: rgba(212,175,55,0.18);
  --gv4-border-mid: rgba(212,175,55,0.32);
  --gv4-border-soft: rgba(212,175,55,0.10);
  --gv4-surf-1: linear-gradient(180deg, rgba(28,16,52,0.85), rgba(12,6,24,0.95));
  --gv4-surf-2: linear-gradient(135deg, rgba(40,24,72,0.78), rgba(16,8,32,0.92));
  --gv4-surf-flat: linear-gradient(180deg, rgba(18,10,36,0.82), rgba(10,4,22,0.92));
  --gv4-text: #f5edd6;
  --gv4-text-dim: rgba(245,237,214,0.72);
  --gv4-text-mute: rgba(245,237,214,0.45);
  --gv4-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ============== PAGE HEADER ============== */
.gv4-pageh {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 14px;
  box-shadow: 0 14px 30px rgba(0,0,0,0.4), inset 0 0 30px rgba(212,175,55,0.04);
  position: relative;
  overflow: hidden;
}
.gv4-pageh::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at left, rgba(212,175,55,0.16), transparent 55%);
  pointer-events: none;
}
.gv4-pageh-title {
  font-family: 'Cinzel', serif;
  font-size: 22px;
  letter-spacing: 0.06em;
  color: var(--gv4-gold-light);
  display: flex;
  align-items: center;
  gap: 10px;
  text-shadow: 0 0 18px rgba(212,175,55,0.4);
}
.gv4-pageh-title i { font-size: 26px; color: var(--gv4-gold); }
.gv4-pageh-sub {
  font-size: 13px;
  color: var(--gv4-text-dim);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.gv4-pageh-tag {
  color: var(--gv4-gold);
  font-family: 'Cinzel', serif;
  font-weight: 700;
}

/* ============== HEADER OVERLAY DENTRO DEL HERO ============== */
/* "MI CLAN" + subtítulo overlaid en la esquina superior izquierda del hero,
   sobre la imagen del cover. Con text-shadow fuerte para legibilidad. */
.gv4-hero-overhead {
  position: relative;
  z-index: 2;
  align-self: flex-start;
}
.gv4-hero-overhead-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Cinzel', serif;
  font-size: 20px;
  letter-spacing: 0.1em;
  color: var(--gv4-gold-light);
  text-transform: uppercase;
  text-shadow: 0 0 18px rgba(212,175,55,0.55), 0 2px 3px rgba(0,0,0,0.95);
}
.gv4-hero-overhead-title i { color: var(--gv4-gold); font-size: 24px; }
.gv4-hero-overhead-sub {
  font-size: 13px;
  color: var(--gv4-text-dim);
  letter-spacing: 0.04em;
  margin-top: 2px;
  padding-left: 34px;
  text-shadow: 0 1px 2px rgba(0,0,0,0.9);
}
.gv4-hero-overhead-tag {
  color: var(--gv4-gold);
  font-family: 'Cinzel', serif;
  font-weight: 700;
}

/* Legacy plain-head (no usado) — queda como fallback inerte */
.gv4-plain-head { display: none; }

/* ============== HERO (full bleed dentro del main-area) ============== */
/* Sin border, sin border-radius. Negative margins escapan al padding de
   .main-area (24px top, 28px L/R en desktop; 16px todo en mobile vía @media).
   El hero queda flush con los bordes del CONTENT AREA y SE EXTIENDE HASTA
   ARRIBA — el header "MI CLAN" vive overlay sobre la imagen, no en una franja
   separada. */
.gv4-hero {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px 32px 18px;
  border: none;
  border-radius: 0;
  background: var(--gv4-surf-2);
  box-shadow: 0 18px 32px rgba(0,0,0,0.5);
  overflow: hidden;
  isolation: isolate;
  min-height: 420px;
  --fac: var(--gv4-gold);
  margin-left: -28px;
  margin-right: -28px;
  margin-top: -24px;
}
.gv4-hero.has-cover {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
/* Overlay degradado para legibilidad — oscuro a la izquierda donde están los textos,
   claro a la derecha donde se aprecia la imagen del castillo/bandera. */
.gv4-hero.has-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg,
      rgba(8,4,18,0.92) 0%,
      rgba(8,4,18,0.78) 35%,
      rgba(8,4,18,0.42) 70%,
      rgba(8,4,18,0.25) 100%),
    linear-gradient(180deg,
      rgba(8,4,18,0.55) 0%,
      rgba(8,4,18,0.35) 50%,
      rgba(8,4,18,0.85) 100%);
  z-index: -1;
}
.gv4-hero:not(.has-cover)::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 0% 0%, rgba(212,175,55,0.22), transparent 55%),
    radial-gradient(ellipse at 100% 100%, rgba(167,139,250,0.22), transparent 55%);
  z-index: -1;
}

/* Hero head — "MI CLAN" + subtitle, esquina superior izquierda */
.gv4-hero-head {
  position: relative;
  z-index: 2;
}
.gv4-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Cinzel', serif;
  font-size: 18px;
  letter-spacing: 0.14em;
  color: var(--gv4-gold-light);
  text-shadow: 0 0 14px rgba(212,175,55,0.55), 0 1px 2px rgba(0,0,0,0.85);
  text-transform: uppercase;
}
.gv4-hero-eyebrow i { color: var(--gv4-gold); font-size: 22px; }
.gv4-hero-eyebrow-sub {
  font-size: 12px;
  color: var(--gv4-text-dim);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.gv4-hero-eyebrow-tag {
  color: var(--gv4-gold);
  font-family: 'Cinzel', serif;
  font-weight: 700;
}
.gv4-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 25% 30%, rgba(255,255,255,0.45), transparent),
    radial-gradient(1px 1px at 75% 70%, rgba(212,175,55,0.55), transparent),
    radial-gradient(1px 1px at 60% 25%, rgba(167,139,250,0.45), transparent),
    radial-gradient(1.2px 1.2px at 90% 50%, rgba(92,196,255,0.4), transparent);
  background-size: 800px 800px;
  background-repeat: repeat;
  opacity: 0.55;
  z-index: -1;
  pointer-events: none;
  animation: gv4-stars 90s linear infinite;
}
@keyframes gv4-stars { to { background-position: -800px -800px; } }

.gv4-hero-cover-edit {
  position: absolute;
  top: 14px;
  right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  background: rgba(10,5,18,0.7);
  color: var(--gv4-gold-light);
  border: 1px solid var(--gv4-border-mid);
  backdrop-filter: blur(8px);
  transition: all 0.2s var(--gv4-ease);
  z-index: 5;
}
.gv4-hero-cover-edit:hover {
  background: rgba(20,10,30,0.85);
  border-color: var(--gv4-gold);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(212,175,55,0.3);
}

.gv4-hero-row {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: 30px;
  align-items: center;
  flex: 1;
}
/* XP bar adentro del hero — al fondo, full width */
.gv4-xp-in-hero {
  position: relative;
  z-index: 2;
  background: rgba(8,4,18,0.7);
  border-color: var(--gv4-border-mid);
  backdrop-filter: blur(4px);
}

/* Avatar ring with conic gradient */
.gv4-avatar {
  position: relative;
  width: 180px;
  height: 180px;
  margin: 0 auto;
  cursor: default;
}
.gv4-avatar.is-editable { cursor: pointer; }
.gv4-avatar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  padding: 4px;
  background: conic-gradient(
    from 0deg,
    var(--gv4-gold) 0%,
    var(--gv4-gold-light) 25%,
    var(--gv4-gold-deep) 50%,
    var(--gv4-gold-light) 75%,
    var(--gv4-gold) 100%
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  box-shadow: 0 0 32px rgba(212,175,55,0.5);
  animation: gv4-rotate 24s linear infinite;
}
@keyframes gv4-rotate { to { transform: rotate(360deg); } }
.gv4-avatar::after {
  content: "";
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,55,0.45), transparent 65%);
  filter: blur(16px);
  opacity: 0.4;
  z-index: -1;
  animation: gv4-pulse 3.5s ease-in-out infinite;
}
@keyframes gv4-pulse {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(1.06); }
}
.gv4-avatar-inner {
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 30%, rgba(40,22,70,0.65), rgba(8,4,18,0.95));
  overflow: hidden;
  display: grid;
  place-items: center;
}
.gv4-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.gv4-avatar-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  font-size: 64px;
  color: var(--gv4-gold);
}
.gv4-avatar-edit {
  position: absolute;
  bottom: 4px;
  right: 4px;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  font-size: 16px;
  box-shadow: 0 4px 16px rgba(212,175,55,0.55), inset 0 -2px 4px rgba(0,0,0,0.3);
  border: 2px solid rgba(0,0,0,0.55);
  z-index: 3;
  opacity: 0;
  transform: scale(0.7);
  transition: all 0.25s var(--gv4-ease);
}
.gv4-avatar.is-editable:hover .gv4-avatar-edit {
  opacity: 1;
  transform: scale(1);
}

/* Identity block */
.gv4-identity { min-width: 0; }
.gv4-tag-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}
.gv4-tag {
  font-family: 'Cinzel', serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  padding: 4px 12px;
  background: rgba(212,175,55,0.14);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 8px;
  color: var(--gv4-gold-light);
}
.gv4-faction {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--fac);
  color: var(--fac);
  box-shadow: 0 0 12px color-mix(in srgb, var(--fac) 30%, transparent);
}
.gv4-name {
  font-family: 'Cinzel', serif;
  font-size: 38px;
  line-height: 1.1;
  margin: 4px 0 6px;
  color: var(--gv4-text);
  text-shadow: 0 0 24px rgba(212,175,55,0.5), 0 2px 0 rgba(0,0,0,0.6);
  letter-spacing: 0.04em;
}
.gv4-motto {
  font-style: italic;
  color: var(--gv4-text-dim);
  font-size: 14px;
  margin-bottom: 12px;
  padding-left: 14px;
  border-left: 2px solid var(--gv4-gold);
}
.gv4-quick-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.gv4-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(10,5,18,0.55);
  border: 1px solid var(--gv4-border);
  color: var(--gv4-text-dim);
  font-weight: 500;
}
.gv4-meta-pill i { color: var(--gv4-gold); font-size: 13px; }

/* XP bar */
.gv4-xp {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 16px;
  background: rgba(10,5,18,0.5);
  border: 1px solid var(--gv4-border);
  border-radius: 12px;
}
.gv4-xp.is-max {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: 'Cinzel', serif;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gv4-gold-light);
  padding: 14px;
}
.gv4-xp.is-max i { color: var(--gv4-gold); font-size: 18px; }
.gv4-xp-head {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--gv4-text-dim);
}
.gv4-xp-head i { color: var(--gv4-gold); }
.gv4-xp-num {
  font-family: 'Cinzel', serif;
  font-size: 13px;
  color: var(--gv4-gold-light);
}
.gv4-xp-pct { color: var(--gv4-text-mute); }
.gv4-xp-track {
  position: relative;
  height: 10px;
  background: rgba(0,0,0,0.55);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,0.16);
}
.gv4-xp-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gv4-gold-deep) 0%, var(--gv4-gold) 50%, var(--gv4-gold-light) 100%);
  border-radius: 999px;
  transition: width 0.6s var(--gv4-ease);
  box-shadow: 0 0 12px rgba(212,175,55,0.6);
}

/* ============== STATS GRID (con action buttons inline) ============== */
.gv4-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.gv4-stat {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  overflow: hidden;
  isolation: isolate;
  --sc: var(--gv4-gold);
}
/* Stat action button — Depositar / Ver mejoras / etc */
.gv4-stat-act {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  background: rgba(10,5,18,0.6);
  color: var(--gv4-text);
  border: 1px solid var(--gv4-border-mid);
  transition: all 0.22s var(--gv4-ease);
  white-space: nowrap;
}
.gv4-stat-act i { font-size: 13px; color: var(--sc); }
/* Hover SOLO para los stat-act no-primarios (Ver mejoras, Ver miembros, etc).
   Excluyo el primary explícitamente para no pisar su gradient dorado. */
.gv4-stat-act:not(.gv4-stat-act-primary):hover {
  transform: translateY(-1px);
  border-color: var(--sc);
  background: rgba(20,12,38,0.85);
  box-shadow: 0 4px 14px color-mix(in srgb, var(--sc) 30%, transparent);
}
.gv4-stat-act-primary {
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(212,175,55,0.4);
}
.gv4-stat-act-primary i { color: #1a1028; }
.gv4-stat-act-primary:hover {
  background: var(--gv4-gold-grad);
  border-color: transparent;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(212,175,55,0.6);
  filter: brightness(1.08);
}
.gv4-stat::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--sc) 18%, transparent), transparent 60%);
  z-index: -1;
}
.gv4-stat-gold    { --sc: var(--gv4-gold); }
.gv4-stat-violet  { --sc: var(--gv4-arcane); }
.gv4-stat-mint    { --sc: var(--gv4-emerald); }
.gv4-stat-cyan    { --sc: var(--gv4-cyan); }
.gv4-stat-ic {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(0,0,0,0.4);
  color: var(--sc);
  font-size: 22px;
  border: 1px solid color-mix(in srgb, var(--sc) 35%, transparent);
  box-shadow: inset 0 0 12px color-mix(in srgb, var(--sc) 18%, transparent);
}
.gv4-stat-body { min-width: 0; flex: 1; }
.gv4-stat-val {
  font-family: 'Cinzel', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--gv4-text);
  line-height: 1.1;
}
.gv4-stat-val .gv4-stat-frac {
  font-size: 14px;
  color: var(--gv4-text-mute);
}
.gv4-stat-lbl {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--gv4-text-dim);
}

/* ============== BONUSES ============== */
.gv4-bonuses {
  padding: 16px 20px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.gv4-bonuses::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at right, rgba(167,139,250,0.12), transparent 60%);
  pointer-events: none;
}
.gv4-bonuses-head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gv4-arcane);
  margin-bottom: 12px;
}
.gv4-bonuses-head i { font-size: 16px; }
.gv4-bonuses-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.gv4-bchip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(10,5,18,0.55);
  border: 1px solid color-mix(in srgb, var(--bc) 40%, transparent);
  border-radius: 999px;
  font-size: 12px;
  color: var(--gv4-text);
  box-shadow: 0 0 12px color-mix(in srgb, var(--bc) 20%, transparent);
  transition: transform 0.2s var(--gv4-ease);
}
.gv4-bchip:hover { transform: translateY(-1px); }
.gv4-bchip i { color: var(--bc); font-size: 13px; }
.gv4-bchip-l { color: var(--gv4-text-dim); }
.gv4-bchip-v {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  color: var(--bc);
}

/* ============== MINI ACTIONS (secundarias, debajo de stats) ============== */
/* Row pequeño con management actions: Invitar, Transferir, Disolver, Salir.
   Visualmente secundario — link-style ghost buttons separados por pipes. */
.gv4-mini-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 4px;
  justify-content: flex-end;
}
.gv4-mini-act {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  letter-spacing: 0.02em;
  cursor: pointer;
  background: transparent;
  color: var(--gv4-text-dim);
  border: 1px solid var(--gv4-border-soft);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-mini-act i { color: var(--gv4-gold); font-size: 13px; }
.gv4-mini-act:hover {
  color: var(--gv4-text);
  border-color: var(--gv4-border-mid);
  background: rgba(212,175,55,0.06);
}
.gv4-mini-act-danger { color: rgba(255,92,124,0.75); }
.gv4-mini-act-danger i { color: var(--gv4-blood); }
.gv4-mini-act-danger:hover {
  color: var(--gv4-blood);
  border-color: rgba(255,92,124,0.4);
  background: rgba(255,92,124,0.06);
}

/* ============== ACTIONS (legacy — sin uso en renderMine ahora) ============== */
.gv4-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.gv4-act {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 12px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--gv4-surf-flat);
  color: var(--gv4-text);
  border: 1px solid var(--gv4-border-mid);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-act i { color: var(--gv4-gold); font-size: 16px; }
.gv4-act:hover {
  transform: translateY(-1px);
  border-color: var(--gv4-gold);
  box-shadow: 0 6px 16px rgba(212,175,55,0.25);
}
.gv4-act-primary {
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border-color: transparent;
  box-shadow: 0 6px 20px rgba(212,175,55,0.4);
}
.gv4-act-primary i { color: #1a1028; }
.gv4-act-primary:hover {
  box-shadow: 0 8px 26px rgba(212,175,55,0.55);
}
.gv4-act-danger {
  border-color: rgba(255,92,124,0.4);
}
.gv4-act-danger i { color: var(--gv4-blood); }
.gv4-act-danger:hover {
  border-color: var(--gv4-blood);
  box-shadow: 0 6px 16px rgba(255,92,124,0.3);
}

/* ============== COLLAPSE (Upgrades) ============== */
.gv4-collapse {
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  overflow: hidden;
}
.gv4-collapse[open] { border-color: var(--gv4-border-mid); }
.gv4-collapse-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.gv4-collapse-head::-webkit-details-marker { display: none; }
.gv4-collapse-ic {
  font-size: 22px;
  color: var(--gv4-gold);
  background: rgba(212,175,55,0.1);
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid var(--gv4-border-mid);
}
.gv4-collapse-title { flex: 1; }
.gv4-collapse-title > div:first-child {
  font-family: 'Cinzel', serif;
  font-size: 15px;
  letter-spacing: 0.06em;
  color: var(--gv4-text);
}
.gv4-collapse-sub {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gv4-text-dim);
}
.gv4-caret {
  color: var(--gv4-gold);
  font-size: 16px;
  transition: transform 0.3s var(--gv4-ease);
}
.gv4-collapse[open] .gv4-caret { transform: rotate(180deg); }
.gv4-collapse-body { padding: 0 20px 18px; }

/* Upgrade cards grid */
.gv4-upgrades-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.gv4-uc {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  background: var(--gv4-surf-2);
  border: 1px solid var(--gv4-border);
  border-radius: 12px;
  overflow: hidden;
  isolation: isolate;
  --cat: var(--gv4-gold);
}
.gv4-uc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top, color-mix(in srgb, var(--cat) 14%, transparent), transparent 65%);
  z-index: -1;
}
.gv4-uc.cat-combat   { --cat: var(--gv4-blood); }
.gv4-uc.cat-economy  { --cat: var(--gv4-gold); }
.gv4-uc.cat-capacity { --cat: var(--gv4-emerald); }
.gv4-uc.cat-special  { --cat: var(--gv4-arcane); }
.gv4-uc.is-max { border-color: var(--gv4-gold-light); box-shadow: 0 0 20px rgba(212,175,55,0.2); }
.gv4-uc-head { display: flex; gap: 12px; align-items: center; }
.gv4-uc-ic {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(0,0,0,0.4);
  color: var(--cat);
  font-size: 20px;
  border: 1px solid color-mix(in srgb, var(--cat) 40%, transparent);
}
.gv4-uc-title-block { flex: 1; min-width: 0; }
.gv4-uc-name {
  font-family: 'Cinzel', serif;
  font-size: 14px;
  color: var(--gv4-text);
  letter-spacing: 0.04em;
}
.gv4-uc-cat {
  font-size: 11px;
  color: var(--gv4-text-dim);
}
.gv4-uc-desc {
  font-size: 12px;
  color: var(--gv4-text-dim);
  line-height: 1.5;
}
.gv4-uc-effect {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}
.gv4-uc-effect-now {
  color: var(--gv4-text-dim);
  padding: 3px 8px;
  background: rgba(0,0,0,0.35);
  border-radius: 6px;
}
.gv4-uc-effect i { color: var(--gv4-gold); }
.gv4-uc-effect-next {
  color: var(--cat);
  padding: 3px 8px;
  background: color-mix(in srgb, var(--cat) 12%, transparent);
  border-radius: 6px;
  font-weight: 600;
}
.gv4-uc-levels {
  display: flex;
  gap: 4px;
}
.gv4-uc-lv {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.04);
}
.gv4-uc-lv.is-filled {
  background: var(--cat);
  box-shadow: 0 0 6px color-mix(in srgb, var(--cat) 60%, transparent);
}
.gv4-uc-lv.is-next {
  background: color-mix(in srgb, var(--cat) 30%, transparent);
  animation: gv4-pulse 2s ease-in-out infinite;
}
.gv4-uc-action { margin-top: 4px; }
.gv4-uc-btn {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  background: rgba(10,5,18,0.55);
  color: var(--gv4-text);
  border: 1px solid var(--gv4-border-mid);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-uc-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.gv4-uc-btn.is-active {
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(212,175,55,0.4);
}
.gv4-uc-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(212,175,55,0.4);
}
.gv4-uc-need {
  font-size: 10px;
  color: var(--gv4-blood);
  margin-left: 4px;
}
.gv4-uc-cost {
  font-size: 10px;
  color: rgba(26,16,40,0.7);
  margin-left: 4px;
}
.gv4-uc-status {
  text-align: center;
  padding: 10px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(10,5,18,0.4);
  border: 1px dashed var(--gv4-border);
  color: var(--gv4-text-dim);
}
.gv4-uc-status.is-max {
  color: var(--gv4-gold-light);
  border-color: var(--gv4-gold);
  background: rgba(212,175,55,0.08);
}
.gv4-uc-status.is-locked {
  color: var(--gv4-text-mute);
  border-color: rgba(255,255,255,0.1);
}

/* ============== 2-COLUMN LAYOUT (PC) ============== */
/* Después de actions: izquierda = tabs+panes, derecha = chat sticky.
   Mobile: colapsa a 1 columna y chat vuelve al flujo. */
.gv4-cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 14px;
  align-items: start;
}
.gv4-cols-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.gv4-cols-chat {
  position: sticky;
  top: 14px;
}
.gv4-cols-chat .gv4-chat {
  height: auto;
}
.gv4-cols-chat .gv4-chat-body {
  max-height: calc(100vh - 280px);
  min-height: 420px;
}

/* ============== TABS ============== */
.gv4-tabs {
  display: flex;
  gap: 4px;
  padding: 8px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.gv4-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  background: transparent;
  color: var(--gv4-text-dim);
  border: 1px solid transparent;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: all 0.22s var(--gv4-ease);
}
.gv4-tab i { font-size: 14px; }
.gv4-tab:hover { color: var(--gv4-text); background: rgba(255,255,255,0.03); }
.gv4-tab.is-active {
  background: linear-gradient(180deg, rgba(212,175,55,0.18), rgba(212,175,55,0.06));
  color: var(--gv4-gold-light);
  border-color: var(--gv4-border-mid);
  box-shadow: inset 0 0 14px rgba(212,175,55,0.08);
}
.gv4-tab.is-active i { color: var(--gv4-gold); }
.gv4-tab-count {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  padding: 2px 7px;
  background: rgba(0,0,0,0.5);
  border-radius: 999px;
  color: var(--gv4-gold-light);
  border: 1px solid var(--gv4-border-mid);
}
.gv4-tab-count.is-pulse {
  background: var(--gv4-blood);
  color: #fff;
  border-color: var(--gv4-blood);
  animation: gv4-pulse 1.6s ease-in-out infinite;
}

.gv4-pane { display: none; }
.gv4-pane.is-active { display: block; }
.gv4-pane-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 16px;
  margin-bottom: 12px;
  background: rgba(10,5,18,0.4);
  border: 1px solid var(--gv4-border);
  border-radius: 10px;
  font-size: 13px;
  color: var(--gv4-text-dim);
}
.gv4-pane-head b { color: var(--gv4-gold-light); }
.gv4-pane-head-hl { color: var(--gv4-gold-light); font-weight: 700; }
.gv4-pane-loading {
  text-align: center;
  padding: 40px;
  color: var(--gv4-text-dim);
}
.gv4-pane-loading i { font-size: 22px; color: var(--gv4-gold); }

/* ============== MEMBERS ============== */
.gv4-members {
  display: grid;
  gap: 10px;
}
.gv4-mr {
  display: grid;
  grid-template-columns: 64px 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 12px 16px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  --rc: var(--gv4-text-mute);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-mr::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--rc);
  box-shadow: 0 0 8px var(--rc);
}
.gv4-mr:hover {
  border-color: var(--gv4-border-mid);
  transform: translateX(2px);
}
.gv4-mr.role-leader  { --rc: var(--gv4-gold); }
.gv4-mr.role-officer { --rc: var(--gv4-cyan); }
.gv4-mr.role-member  { --rc: rgba(245,237,214,0.45); }

.gv4-mr-avatar {
  position: relative;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(40,22,70,0.7), rgba(8,4,18,0.95));
  border: 2px solid var(--rc);
  overflow: hidden;
  display: grid;
  place-items: center;
  font-family: 'Cinzel', serif;
  font-size: 24px;
  color: var(--gv4-gold-light);
  flex-shrink: 0;
  box-shadow: 0 0 12px color-mix(in srgb, var(--rc) 40%, transparent);
}
.gv4-mr-avatar > span { display: grid; place-items: center; }
.gv4-mr-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gv4-mr-dot {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--gv4-text-mute);
  border: 2px solid rgba(10,5,18,0.9);
}
.gv4-mr-dot.is-online {
  background: var(--gv4-emerald);
  box-shadow: 0 0 10px var(--gv4-emerald);
  animation: gv4-pulse 2s ease-in-out infinite;
}
.gv4-mr-body { min-width: 0; }
.gv4-mr-name {
  font-family: 'Cinzel', serif;
  font-size: 15px;
  color: var(--gv4-text);
  margin-bottom: 4px;
}
.gv4-mr-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.gv4-mr-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border-soft);
  color: var(--gv4-text-dim);
}
.gv4-mr-pill i { color: var(--gv4-gold); }
.gv4-mr-pill.is-online i { color: var(--gv4-emerald); }
.gv4-mr-role {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--rc) 14%, transparent);
  border: 1px solid var(--rc);
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--rc);
}
.gv4-mr-role i { font-size: 13px; }
.gv4-mr-actions { display: flex; gap: 4px; }
.gv4-mr-act {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border);
  color: var(--gv4-text);
  cursor: pointer;
  font-size: 14px;
  transition: all 0.22s var(--gv4-ease);
}
.gv4-mr-act-promote { color: var(--gv4-cyan); }
.gv4-mr-act-promote:hover { border-color: var(--gv4-cyan); box-shadow: 0 0 12px rgba(92,196,255,0.3); }
.gv4-mr-act-demote { color: var(--gv4-ember); }
.gv4-mr-act-demote:hover { border-color: var(--gv4-ember); }
.gv4-mr-act-kick { color: var(--gv4-blood); }
.gv4-mr-act-kick:hover { border-color: var(--gv4-blood); }

/* ============== REQUESTS ============== */
.gv4-requests { display: grid; gap: 10px; }
.gv4-rr {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 12px;
}
.gv4-rr-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(40,22,70,0.7), rgba(8,4,18,0.95));
  border: 2px solid var(--gv4-cyan);
  overflow: hidden;
  display: grid;
  place-items: center;
  font-family: 'Cinzel', serif;
  font-size: 20px;
  color: var(--gv4-gold-light);
  box-shadow: 0 0 10px rgba(92,196,255,0.3);
}
.gv4-rr-img { width: 100%; height: 100%; object-fit: cover; }
.gv4-rr-body { min-width: 0; }
.gv4-rr-name { font-family: 'Cinzel', serif; font-size: 14px; color: var(--gv4-text); }
.gv4-rr-meta { display: flex; flex-wrap: wrap; gap: 6px; margin: 4px 0; }
.gv4-rr-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border-soft);
  color: var(--gv4-text-dim);
}
.gv4-rr-pill i { color: var(--gv4-gold); }
.gv4-rr-msg {
  font-style: italic;
  font-size: 12px;
  color: var(--gv4-text-dim);
  padding-left: 10px;
  border-left: 2px solid var(--gv4-cyan);
}
.gv4-rr-actions { display: flex; gap: 6px; }
.gv4-rr-act {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  border: 1px solid;
  cursor: pointer;
  font-size: 16px;
  transition: all 0.22s var(--gv4-ease);
}
.gv4-rr-act-accept {
  background: rgba(92,242,138,0.12);
  border-color: var(--gv4-emerald);
  color: var(--gv4-emerald);
}
.gv4-rr-act-accept:hover { background: var(--gv4-emerald); color: #0a1a0a; }
.gv4-rr-act-reject {
  background: rgba(255,92,124,0.12);
  border-color: var(--gv4-blood);
  color: var(--gv4-blood);
}
.gv4-rr-act-reject:hover { background: var(--gv4-blood); color: #fff; }

/* ============== DONORS ============== */
.gv4-donors-list { display: grid; gap: 8px; }
.gv4-dn-row {
  display: grid;
  grid-template-columns: 50px 1fr 90px 130px;
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 10px;
}
.gv4-dn-row.is-podium {
  background: linear-gradient(135deg, rgba(212,175,55,0.16), rgba(20,12,32,0.6));
  border-color: var(--gv4-border-mid);
}
.gv4-dn-row.is-former { opacity: 0.65; }
.gv4-dn-rank {
  font-family: 'Cinzel', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--gv4-gold-light);
  text-align: center;
}
.gv4-dn-info { min-width: 0; }
.gv4-dn-name {
  font-family: 'Cinzel', serif;
  font-size: 14px;
  color: var(--gv4-text);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.gv4-dn-meta {
  font-size: 11px;
  color: var(--gv4-text-mute);
  font-family: 'Inter', sans-serif;
}
.gv4-dn-vip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  font-family: 'Cinzel', serif;
  font-weight: 700;
}
.gv4-dn-former-tag {
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border-soft);
  color: var(--gv4-text-mute);
  font-family: 'Inter', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.gv4-dn-bar {
  height: 5px;
  background: rgba(0,0,0,0.5);
  border-radius: 999px;
  margin-top: 6px;
  overflow: hidden;
}
.gv4-dn-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gv4-gold-deep), var(--gv4-gold));
  border-radius: 999px;
}
.gv4-dn-today { text-align: center; }
.gv4-dn-today-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gv4-text-mute);
}
.gv4-dn-today-amt {
  font-family: 'Cinzel', serif;
  font-size: 14px;
  color: var(--gv4-cyan);
}
.gv4-dn-today.no .gv4-dn-today-amt { color: var(--gv4-text-mute); }
.gv4-dn-total { text-align: right; }
.gv4-dn-total-amt {
  font-family: 'Cinzel', serif;
  font-size: 15px;
  color: var(--gv4-gold-light);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
}
.gv4-dn-total-amt i { color: var(--gv4-gold); }
.gv4-dn-total-cnt {
  font-size: 11px;
  color: var(--gv4-text-mute);
}
.gv4-dn-former-section { margin-top: 12px; }
.gv4-dn-former-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(10,5,18,0.5);
  border: 1px dashed var(--gv4-border);
  border-radius: 10px;
  cursor: pointer;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gv4-text-dim);
  list-style: none;
}
.gv4-dn-former-head::-webkit-details-marker { display: none; }
.gv4-dn-former-cnt {
  margin-left: auto;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(212,175,55,0.1);
  color: var(--gv4-gold-light);
  border: 1px solid var(--gv4-border);
  font-size: 11px;
}

/* ============== HISTORY ============== */
.gv4-history {
  display: grid;
  gap: 6px;
  padding: 4px 0;
}
.gv4-h-row {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 10px;
  --ev: var(--gv4-gold);
  position: relative;
}
.gv4-h-row::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--ev);
}
.gv4-h-ic {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(0,0,0,0.5);
  color: var(--ev);
  font-size: 18px;
  border: 1px solid color-mix(in srgb, var(--ev) 40%, transparent);
}
.gv4-h-body { min-width: 0; }
.gv4-h-text {
  font-size: 13px;
  color: var(--gv4-text);
  line-height: 1.45;
}
.gv4-h-text b { color: var(--gv4-gold-light); font-weight: 600; }
.gv4-h-time {
  font-size: 11px;
  color: var(--gv4-text-mute);
  font-family: 'Inter', sans-serif;
  white-space: nowrap;
}

/* ============== SETTINGS ============== */
.gv4-settings { display: grid; gap: 14px; }
.gv4-set-card {
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  overflow: hidden;
}
.gv4-set-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(10,5,18,0.5);
  border-bottom: 1px solid var(--gv4-border);
}
.gv4-set-card-head > i {
  font-size: 22px;
  color: var(--gv4-gold);
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(212,175,55,0.1);
  border: 1px solid var(--gv4-border-mid);
}
.gv4-set-card-title {
  font-family: 'Cinzel', serif;
  font-size: 14px;
  color: var(--gv4-text);
  letter-spacing: 0.06em;
}
.gv4-set-card-sub {
  font-size: 11px;
  color: var(--gv4-text-dim);
}
.gv4-set-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 16px 18px;
}
.gv4-set-field { display: flex; flex-direction: column; gap: 6px; }
.gv4-set-field label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gv4-text-dim);
  display: flex;
  align-items: center;
  gap: 6px;
}
.gv4-set-field label i { color: var(--gv4-gold); }
.gv4-set-field input,
.gv4-set-field textarea,
.gv4-set-field select {
  padding: 10px 12px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 10px;
  color: var(--gv4-text);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  outline: none;
  transition: border-color 0.2s var(--gv4-ease);
}
.gv4-set-field input:focus,
.gv4-set-field textarea:focus { border-color: var(--gv4-gold); }
.gv4-set-field textarea { resize: vertical; min-height: 64px; }
.gv4-set-hint {
  font-size: 10px;
  color: var(--gv4-text-mute);
  font-weight: normal;
  letter-spacing: 0.04em;
  text-transform: none;
}
.gv4-set-full { grid-column: 1 / -1; }
.gv4-set-section-title {
  grid-column: 1 / -1;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gv4-arcane);
  padding-top: 10px;
  border-top: 1px solid var(--gv4-border);
}

.gv4-set-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 12px;
  background: rgba(10,5,18,0.4);
  border-radius: 10px;
  border: 1px solid var(--gv4-border);
}
.gv4-set-toggle-title {
  font-family: 'Cinzel', serif;
  font-size: 13px;
  color: var(--gv4-text);
}
.gv4-set-toggle-sub {
  font-size: 11px;
  color: var(--gv4-text-dim);
}
.gv4-set-switch {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 24px;
  flex-shrink: 0;
}
.gv4-set-switch input { display: none; }
.gv4-set-slider {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 999px;
  cursor: pointer;
  transition: 0.25s var(--gv4-ease);
}
.gv4-set-slider::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 1px;
  width: 18px;
  height: 18px;
  background: var(--gv4-text-mute);
  border-radius: 50%;
  transition: 0.25s var(--gv4-ease);
}
.gv4-set-switch input:checked + .gv4-set-slider {
  background: var(--gv4-gold-grad);
  border-color: var(--gv4-gold);
}
.gv4-set-switch input:checked + .gv4-set-slider::before {
  transform: translateX(22px);
  background: #1a1028;
}

.gv4-set-footer {
  display: flex;
  justify-content: flex-end;
  padding: 12px 18px;
  background: rgba(10,5,18,0.4);
  border-top: 1px solid var(--gv4-border);
}
.gv4-set-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border: none;
  box-shadow: 0 4px 14px rgba(212,175,55,0.4);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-set-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(212,175,55,0.55); }

/* ============== CHAT ============== */
.gv4-chat {
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.gv4-chat-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(10,5,18,0.55);
  border-bottom: 1px solid var(--gv4-border);
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--gv4-gold-light);
}
.gv4-chat-head i { color: var(--gv4-gold); font-size: 16px; }
.gv4-chat-meta {
  margin-left: auto;
  font-size: 11px;
  font-family: 'Inter', sans-serif;
  text-transform: none;
  letter-spacing: 0.04em;
  color: var(--gv4-text-mute);
  font-weight: normal;
}
.gv4-chat-body {
  padding: 14px 16px;
  max-height: 320px;
  min-height: 180px;
  overflow-y: auto;
  scrollbar-width: thin;
}
.gv4-chat-loading,
.gv4-chat-empty {
  text-align: center;
  padding: 30px 12px;
  color: var(--gv4-text-mute);
  font-style: italic;
}
.gv4-chat-msg {
  display: flex;
  gap: 6px;
  align-items: baseline;
  padding: 5px 0;
  font-size: 13px;
  line-height: 1.55;
}
.gv4-chat-msg.is-own { color: var(--gv4-gold-light); }
.gv4-chat-time {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  color: var(--gv4-text-mute);
  min-width: 38px;
}
.gv4-chat-role {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 9px;
  padding: 1px 6px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.gv4-chat-role.is-admin { background: var(--gv4-blood); color: #fff; }
.gv4-chat-role.is-mod   { background: var(--gv4-cyan);  color: #001a30; }
.gv4-chat-sender {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  color: var(--gv4-cyan);
}
.gv4-chat-body-txt {
  color: var(--gv4-text);
  word-break: break-word;
  flex: 1;
}
.gv4-chat-input-row {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(10,5,18,0.6);
  border-top: 1px solid var(--gv4-border);
}
.gv4-chat-input-row input {
  flex: 1;
  padding: 10px 14px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 10px;
  color: var(--gv4-text);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  outline: none;
}
.gv4-chat-input-row input:focus { border-color: var(--gv4-gold); }
.gv4-chat-input-row button {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border: none;
  cursor: pointer;
  font-size: 18px;
  box-shadow: 0 4px 14px rgba(212,175,55,0.4);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-chat-input-row button:hover { transform: translateY(-1px); }

/* ============== BANNER ============== */
.gv4-banner {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(167,139,250,0.08);
  border: 1px solid rgba(167,139,250,0.3);
  border-radius: 12px;
  font-size: 12px;
  color: var(--gv4-text-dim);
}
.gv4-banner i {
  color: var(--gv4-arcane);
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 2px;
}
.gv4-banner-info { background: rgba(92,196,255,0.07); border-color: rgba(92,196,255,0.3); }
.gv4-banner-info i { color: var(--gv4-cyan); }

.gv4-empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--gv4-text-mute);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.gv4-empty i { font-size: 38px; color: var(--gv4-text-mute); opacity: 0.6; }

/* ============== LIST VIEW (no clan) ============== */
.gv4-list-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.gv4-ls-cell {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
.gv4-ls-cell::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at left, rgba(167,139,250,0.1), transparent 60%);
  pointer-events: none;
}
.gv4-ls-cell.is-hl { border-color: var(--gv4-cyan); box-shadow: 0 0 16px rgba(92,196,255,0.15); }
.gv4-ls-cell.is-gold { border-color: var(--gv4-gold); }
.gv4-ls-cell > i {
  font-size: 28px;
  color: var(--gv4-gold);
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  background: rgba(212,175,55,0.1);
  border-radius: 12px;
  border: 1px solid var(--gv4-border-mid);
}
.gv4-ls-val {
  font-family: 'Cinzel', serif;
  font-size: 22px;
  color: var(--gv4-text);
  line-height: 1.1;
}
.gv4-ls-lbl {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gv4-text-dim);
}

.gv4-create-card {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 20px 24px;
  background: var(--gv4-surf-2);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.gv4-create-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at left, rgba(212,175,55,0.18), transparent 55%),
    radial-gradient(ellipse at right, rgba(167,139,250,0.18), transparent 55%);
  z-index: -1;
}
.gv4-cc-icon {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  font-size: 30px;
  box-shadow: 0 8px 24px rgba(212,175,55,0.5);
  border: 2px solid rgba(0,0,0,0.45);
}
.gv4-cc-title {
  font-family: 'Cinzel', serif;
  font-size: 18px;
  color: var(--gv4-gold-light);
  letter-spacing: 0.04em;
}
.gv4-cc-desc {
  font-size: 12px;
  color: var(--gv4-text-dim);
  margin: 4px 0 8px;
}
.gv4-cc-costs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.gv4-cc-cost {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid var(--gv4-border-mid);
  background: rgba(0,0,0,0.4);
}
.gv4-cc-cost.is-ok { color: var(--gv4-emerald); border-color: var(--gv4-emerald); }
.gv4-cc-cost.is-bad { color: var(--gv4-blood); border-color: rgba(255,92,124,0.4); }
.gv4-cc-or {
  font-size: 11px;
  color: var(--gv4-text-mute);
  font-style: italic;
}
.gv4-cc-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 12px;
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border: none;
  box-shadow: 0 6px 20px rgba(212,175,55,0.45);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-cc-btn:disabled { opacity: 0.55; cursor: not-allowed; filter: grayscale(0.4); }
.gv4-cc-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(212,175,55,0.6); }

.gv4-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Cinzel', serif;
  font-size: 16px;
  letter-spacing: 0.08em;
  color: var(--gv4-gold-light);
  padding: 16px 4px 8px;
  border-bottom: 1px solid var(--gv4-border);
  margin-bottom: 12px;
}
.gv4-section-title > i { color: var(--gv4-gold); }
.gv4-section-count {
  margin-left: auto;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--gv4-text-mute);
  padding: 3px 10px;
  background: rgba(212,175,55,0.1);
  border-radius: 999px;
  border: 1px solid var(--gv4-border);
}

.gv4-invites { display: grid; gap: 10px; margin-bottom: 18px; }
.gv4-invite-card {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-cyan);
  border-radius: 12px;
  box-shadow: 0 0 18px rgba(92,196,255,0.18);
}
.gv4-ic-tag {
  font-family: 'Cinzel', serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--gv4-cyan);
  text-align: center;
  padding: 8px 0;
  background: rgba(92,196,255,0.1);
  border: 1px solid rgba(92,196,255,0.3);
  border-radius: 10px;
}
.gv4-ic-name {
  font-family: 'Cinzel', serif;
  font-size: 16px;
  color: var(--gv4-text);
}
.gv4-ic-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
  font-size: 12px;
  color: var(--gv4-text-dim);
}
.gv4-ic-meta i { color: var(--gv4-gold); }
.gv4-ic-actions { display: flex; gap: 6px; }
.gv4-ic-accept,
.gv4-ic-reject {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.22s var(--gv4-ease);
}
.gv4-ic-accept {
  background: var(--gv4-emerald);
  color: #001a0a;
  border: none;
  box-shadow: 0 4px 14px rgba(92,242,138,0.4);
}
.gv4-ic-reject {
  background: rgba(0,0,0,0.4);
  color: var(--gv4-blood);
  border: 1px solid var(--gv4-blood);
  padding: 10px;
}
.gv4-ic-accept:hover, .gv4-ic-reject:hover { transform: translateY(-1px); }

.gv4-guild-list { display: grid; gap: 10px; }
.gv4-guild-card {
  display: grid;
  grid-template-columns: 70px 70px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  background: var(--gv4-surf-flat);
  border: 1px solid var(--gv4-border);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  --fac: var(--gv4-gold);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-guild-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--fac);
  box-shadow: 0 0 12px var(--fac);
}
.gv4-guild-card:hover {
  border-color: var(--fac);
  transform: translateX(2px);
}
.gv4-gc-avatar {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(40,22,70,0.7), rgba(8,4,18,0.95));
  border: 2px solid var(--fac);
  overflow: hidden;
  display: grid;
  place-items: center;
  color: var(--fac);
  font-size: 28px;
  box-shadow: 0 0 14px color-mix(in srgb, var(--fac) 40%, transparent);
}
.gv4-gc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.gv4-gc-tag {
  font-family: 'Cinzel', serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--fac);
  text-align: center;
  padding: 8px 4px;
  background: color-mix(in srgb, var(--fac) 12%, transparent);
  border: 1px solid var(--fac);
  border-radius: 10px;
}
.gv4-gc-name-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.gv4-gc-name {
  font-family: 'Cinzel', serif;
  font-size: 16px;
  color: var(--gv4-text);
}
.gv4-gc-faction {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--fac);
  color: var(--fac);
}
.gv4-gc-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 6px 0;
}
.gv4-gc-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border-soft);
  color: var(--gv4-text-dim);
}
.gv4-gc-pill i { color: var(--gv4-gold); }
.gv4-gc-req { color: var(--gv4-ember); border-color: rgba(255,170,80,0.3); }
.gv4-gc-req i { color: var(--gv4-ember); }
.gv4-gc-motto {
  font-style: italic;
  font-size: 12px;
  color: var(--gv4-text-dim);
  padding-left: 10px;
  border-left: 2px solid var(--fac);
  margin: 4px 0;
}
.gv4-gc-progress {
  display: flex;
  align-items: center;
  gap: 10px;
}
.gv4-gc-bar {
  flex: 1;
  height: 6px;
  background: rgba(0,0,0,0.5);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid var(--gv4-border-soft);
}
.gv4-gc-bar-fill {
  height: 100%;
  border-radius: 999px;
  box-shadow: 0 0 8px currentColor;
}
.gv4-gc-bar-text {
  font-size: 11px;
  color: var(--gv4-text-dim);
  font-family: 'Inter', sans-serif;
}
.gv4-gc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border: none;
  box-shadow: 0 4px 14px rgba(212,175,55,0.35);
  transition: all 0.22s var(--gv4-ease);
}
.gv4-gc-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.gv4-gc-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(212,175,55,0.5); }

/* ============== INVITE / AVATAR / COVER MODALES ============== */
/* CRÍTICO: los modales se renderizan en #modal-host que vive FUERA de
   .gv4-stage. Las CSS vars --gv4-* están scopeadas al stage, así que aquí
   las re-declaramos para que estén disponibles dentro del modal. */
.gv4-invite-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.78);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  z-index: 1000;
  /* Re-scope de los tokens Obsidian Codex */
  --gv4-gold: #d4af37;
  --gv4-gold-light: #f3d775;
  --gv4-gold-deep: #8a6d1c;
  --gv4-gold-grad: linear-gradient(180deg, #f3d775 0%, #d4af37 45%, #a0801b 100%);
  --gv4-arcane: #a78bfa;
  --gv4-cyan: #5cc4ff;
  --gv4-emerald: #5cf28a;
  --gv4-blood: #ff5c7c;
  --gv4-ember: #ffaa50;
  --gv4-border: rgba(212,175,55,0.22);
  --gv4-border-mid: rgba(212,175,55,0.38);
  --gv4-border-soft: rgba(212,175,55,0.14);
  --gv4-text: #f5edd6;
  --gv4-text-dim: rgba(245,237,214,0.78);
  --gv4-text-mute: rgba(245,237,214,0.5);
  --gv4-ease: cubic-bezier(0.16, 1, 0.3, 1);
}
.gv4-invite-modal {
  width: min(560px, 92vw);
  max-height: 88vh;
  /* Background SOLIDO (no semi-transparente) para que sea opaco sobre el blur */
  background:
    linear-gradient(135deg, rgba(40,24,72,0.98), rgba(16,8,32,1)),
    #120a24;
  border: 1px solid var(--gv4-border-mid);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 26px 60px rgba(0,0,0,0.7), inset 0 0 60px rgba(212,175,55,0.06);
  color: var(--gv4-text);
}
.gv4-im-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--gv4-border);
  color: var(--gv4-text);
  cursor: pointer;
  z-index: 10;
}
.gv4-im-head {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 22px;
  border-bottom: 1px solid var(--gv4-border);
}
.gv4-im-icon {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  font-size: 24px;
}
.gv4-im-title {
  font-family: 'Cinzel', serif;
  font-size: 18px;
  color: var(--gv4-gold-light);
}
.gv4-im-sub {
  font-size: 12px;
  color: var(--gv4-text-dim);
}
.gv4-im-body {
  padding: 18px 22px;
  overflow-y: auto;
}
.gv4-im-search-wrap {
  position: relative;
  margin-bottom: 14px;
}
.gv4-im-search-ic {
  position: absolute;
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  color: var(--gv4-text-mute);
}
.gv4-im-search {
  width: 100%;
  padding: 12px 14px 12px 40px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--gv4-border-mid);
  border-radius: 10px;
  color: var(--gv4-text);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  outline: none;
}
.gv4-im-search:focus { border-color: var(--gv4-gold); }
.gv4-im-results { display: grid; gap: 8px; }
.gv4-im-empty,
.gv4-im-loading {
  text-align: center;
  padding: 30px 12px;
  color: var(--gv4-text-mute);
}
.gv4-im-empty i { font-size: 32px; opacity: 0.5; }
.gv4-im-row {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  background: rgba(10,5,18,0.5);
  border: 1px solid var(--gv4-border);
  border-radius: 10px;
}
.gv4-im-row.is-busy { opacity: 0.55; }
.gv4-im-row-av {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(40,22,70,0.7), rgba(8,4,18,0.95));
  border: 2px solid var(--gv4-gold);
  font-family: 'Cinzel', serif;
  color: var(--gv4-gold-light);
}
.gv4-im-row-name {
  font-family: 'Cinzel', serif;
  font-size: 14px;
  color: var(--gv4-text);
}
.gv4-im-row-meta {
  display: flex;
  gap: 10px;
  font-size: 11px;
  color: var(--gv4-text-dim);
  margin-top: 2px;
}
.gv4-im-row-meta i { color: var(--gv4-gold); }
.gv4-im-row-busy {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--gv4-border);
  color: var(--gv4-text-mute);
}
.gv4-im-row-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  border-radius: 10px;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--gv4-gold-grad);
  color: #1a1028;
  border: none;
  box-shadow: 0 3px 10px rgba(212,175,55,0.35);
}

/* ============== AVATAR / COVER MODAL ============== */
.gv4-avatar-modal, .gv4-cover-modal {
  width: min(440px, 92vw);
}
.gv4-av-preview-wrap, .gv4-cv-preview-wrap {
  display: grid;
  place-items: center;
  padding: 14px 0;
}
.gv4-av-preview {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  border: 2px dashed var(--gv4-border-mid);
  background: rgba(0,0,0,0.4);
  display: grid;
  place-items: center;
  overflow: hidden;
  font-size: 60px;
  color: var(--gv4-text-mute);
}
.gv4-av-preview.has-img { border-style: solid; border-color: var(--gv4-gold); box-shadow: 0 0 20px rgba(212,175,55,0.3); }
.gv4-av-preview img { width: 100%; height: 100%; object-fit: cover; }
.gv4-cv-preview {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 14px;
  border: 2px dashed var(--gv4-border-mid);
  background: rgba(0,0,0,0.4);
  background-size: cover;
  background-position: center;
  display: grid;
  place-items: center;
  font-size: 60px;
  color: var(--gv4-text-mute);
}
.gv4-cv-preview.has-img { border-style: solid; border-color: var(--gv4-gold); }
.gv4-av-info {
  display: flex;
  justify-content: space-between;
  padding: 0 18px;
  margin: 6px 0 12px;
  font-size: 12px;
}
.gv4-av-cost { color: var(--gv4-gold-light); }
.gv4-av-cost i { color: var(--gv4-gold); }
.gv4-av-bank { color: var(--gv4-text-dim); }
.gv4-av-pick {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: calc(100% - 36px);
  margin: 0 18px;
  padding: 10px;
  justify-content: center;
  border-radius: 10px;
  background: rgba(212,175,55,0.1);
  border: 1px dashed var(--gv4-border-mid);
  color: var(--gv4-gold-light);
  cursor: pointer;
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.08em;
}
.gv4-av-warn {
  display: flex;
  gap: 8px;
  padding: 10px 18px;
  font-size: 11px;
  color: var(--gv4-text-dim);
  align-items: flex-start;
}
.gv4-av-warn i { color: var(--gv4-ember); font-size: 14px; margin-top: 1px; }

/* ============== RESPONSIVE ============== */
@media (max-width: 1400px) {
  /* En pantallas medianas las stats pasan a 2x2 para que el botón quepa cómodo */
  .gv4-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1100px) {
  /* En tablet/mobile el chat vuelve abajo y todo es 1 columna */
  .gv4-cols {
    grid-template-columns: 1fr;
  }
  .gv4-cols-chat {
    position: static;
  }
  .gv4-cols-chat .gv4-chat-body {
    max-height: 320px;
    min-height: 180px;
  }
  /* main-area pasa a padding 16px → ajustar el bleed del hero */
  .gv4-hero {
    margin-left: -16px;
    margin-right: -16px;
    margin-top: -16px;
  }
}

@media (max-width: 900px) {
  .gv4-stats { grid-template-columns: repeat(2, 1fr); }
  .gv4-list-summary { grid-template-columns: 1fr; }
  .gv4-set-body { grid-template-columns: 1fr; }
  .gv4-hero-row { grid-template-columns: 1fr; gap: 18px; }
  .gv4-avatar { width: 140px; height: 140px; }
  .gv4-name { font-size: 28px; }
  .gv4-hero { padding: 22px 18px; }
  .gv4-create-card { grid-template-columns: 1fr; text-align: center; }
  .gv4-cc-icon { margin: 0 auto; }
  .gv4-cc-costs { justify-content: center; }
  .gv4-guild-card {
    grid-template-columns: 56px 56px 1fr;
    grid-template-areas:
      "av tag body"
      "btn btn btn";
  }
  .gv4-gc-avatar { grid-area: av; }
  .gv4-gc-tag { grid-area: tag; }
  .gv4-gc-body { grid-area: body; min-width: 0; }
  .gv4-gc-action { grid-area: btn; }
  .gv4-gc-btn { width: 100%; justify-content: center; }
  .gv4-mr {
    grid-template-columns: 48px 1fr;
    grid-template-areas:
      "av body"
      "av meta-row"
      "actions actions";
  }
  .gv4-mr-avatar { grid-area: av; width: 48px; height: 48px; font-size: 20px; }
  .gv4-mr-body { grid-area: body; }
  .gv4-mr-role { grid-area: meta-row; justify-self: start; }
  .gv4-mr-actions { grid-area: actions; justify-self: end; }
  .gv4-dn-row { grid-template-columns: 40px 1fr 90px; }
  .gv4-dn-total { display: none; }
  .gv4-rr { grid-template-columns: 48px 1fr; grid-auto-rows: auto; }
  .gv4-rr-actions { grid-column: 1 / -1; justify-content: flex-end; }
}

@media (max-width: 720px) {
  /* Mobile: stats vuelven a 2 columnas, hero más compacto, mini-actions wrap */
  .gv4-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gv4-stat { grid-template-columns: auto 1fr; grid-template-rows: auto auto; }
  .gv4-stat-act { grid-column: 1 / -1; justify-content: center; }
  .gv4-hero { min-height: 320px; }
  .gv4-hero-eyebrow { font-size: 14px; }
  .gv4-mini-actions { justify-content: center; }
  .gv4-mini-act span { font-size: 11px; }
}

@media (max-width: 560px) {
  .gv4-pageh { padding: 12px 14px; }
  .gv4-pageh-title { font-size: 18px; }
  .gv4-hero { padding: 14px 14px; min-height: 280px; }
  .gv4-hero-eyebrow { font-size: 13px; }
  .gv4-hero-eyebrow i { font-size: 16px; }
  .gv4-name { font-size: 22px; }
  .gv4-stats { gap: 8px; grid-template-columns: 1fr; }
  .gv4-stat { padding: 10px 12px; gap: 8px; grid-template-columns: auto 1fr auto; grid-template-rows: auto; }
  .gv4-stat-act { grid-column: auto; }
  .gv4-stat-act span { display: none; }
  .gv4-stat-act { padding: 8px; }
  .gv4-stat-ic { width: 38px; height: 38px; font-size: 18px; }
  .gv4-stat-val { font-size: 18px; }
  .gv4-upgrades-grid { grid-template-columns: 1fr; }
  .gv4-tabs { gap: 2px; padding: 6px; }
  .gv4-tab { padding: 8px 12px; font-size: 11px; }
  .gv4-tab span:not(.gv4-tab-count) { display: none; }
  .gv4-actions .gv4-act span { display: none; }
  .gv4-mini-actions { gap: 4px; }
  .gv4-mini-act { padding: 5px 8px; font-size: 11px; }
}
