/* ------------------------------------------------------------
   MIEDO — Estilos base
   ------------------------------------------------------------ */

:root {
  --miedo-bg:          #0d0d0d;
  --miedo-bg-2:        #161616;
  --miedo-bg-3:        #1e1e1e;
  --miedo-border:      #2a2a2a;
  --miedo-accent:      #c0392b;
  --miedo-accent-dark: #922b21;
  --miedo-accent-glow: rgba(192,57,43,.35);
  --miedo-text:        #e8e8e8;
  --miedo-text-muted:  #888;
  --miedo-success:     #27ae60;
  --miedo-warning:     #f39c12;
  --miedo-radius:      6px;
  --miedo-sidebar-w:   280px;
  --miedo-header-h:    56px;
  --miedo-nav-w:       52px;
  --miedo-transition:  .2s ease;
  --miedo-font:        'Segoe UI', system-ui, sans-serif;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

.miedo-app {
  font-family: var(--miedo-font);
  color: var(--miedo-text);
  background: var(--miedo-bg);
  width: 100%;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

/* -- Pantallas ----------------------------------------------- */
.miedo-screen            { display: none; width: 100%; }
.miedo-screen--active    { display: flex; flex-direction: column; }

/* ------------------------------------------------------------
   SELECTOR DE MUNDOS
   ------------------------------------------------------------ */
#miedo-world-selector {
  min-height: 100vh;
  align-items: center;
  padding: 40px 20px;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(192,57,43,.12) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(192,57,43,.08) 0%, transparent 50%),
    var(--miedo-bg);
}

.miedo-selector-header   { text-align: center; margin-bottom: 40px; }

.miedo-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 12px;
}
.miedo-logo__icon        { width: 52px; height: 52px; filter: drop-shadow(0 0 12px var(--miedo-accent-glow)); }
.miedo-logo__text        { font-size: 3rem; font-weight: 800; letter-spacing: .2em; color: var(--miedo-accent); text-shadow: 0 0 30px var(--miedo-accent-glow); }
.miedo-selector-subtitle { color: var(--miedo-text-muted); font-size: .95rem; letter-spacing: .05em; }

/* Aviso invitados */
.miedo-notice {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(192,57,43,.15);
  border: 1px solid var(--miedo-accent);
  border-radius: var(--miedo-radius);
  padding: 12px 16px;
  margin-bottom: 24px;
  max-width: 500px;
  width: 100%;
  font-size: .9rem;
  color: #e8a0a0;
  transition: opacity var(--miedo-transition);
}
.miedo-notice--hidden    { opacity: 0; pointer-events: none; }
.miedo-notice--visible   { opacity: 1; }
.miedo-notice__icon      { width: 20px; height: 20px; flex-shrink: 0; }

/* Grid de mundos */
.miedo-worlds-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
  width: 100%;
  max-width: 1100px;
}

.miedo-world-card {
  background: var(--miedo-bg-2);
  border: 1px solid var(--miedo-border);
  border-radius: 10px;
  padding: 24px;
  cursor: pointer;
  transition: border-color var(--miedo-transition), transform var(--miedo-transition), box-shadow var(--miedo-transition);
  position: relative;
  overflow: hidden;
}
.miedo-world-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--miedo-accent-glow) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--miedo-transition);
}
.miedo-world-card:hover::before  { opacity: 1; }
.miedo-world-card:hover          { border-color: var(--miedo-accent); transform: translateY(-3px); box-shadow: 0 8px 30px var(--miedo-accent-glow); }
.miedo-world-card--full          { opacity: .55; cursor: not-allowed; }
.miedo-world-card--full:hover    { transform: none; border-color: var(--miedo-border); box-shadow: none; }
.miedo-world-card--full::before  { display: none; }

.miedo-world-card__icon {
  width: 40px; height: 40px;
  margin-bottom: 14px;
  color: var(--miedo-accent);
}
.miedo-world-card__name   { font-size: 1.2rem; font-weight: 700; margin-bottom: 8px; }
.miedo-world-card__meta   { font-size: .82rem; color: var(--miedo-text-muted); display: flex; flex-direction: column; gap: 4px; }
.miedo-world-card__bar    { height: 4px; background: var(--miedo-border); border-radius: 2px; margin-top: 14px; overflow: hidden; }
.miedo-world-card__bar-fill { height: 100%; background: var(--miedo-accent); border-radius: 2px; transition: width .4s ease; }
.miedo-world-card__status {
  position: absolute; top: 14px; right: 14px;
  font-size: .72rem; font-weight: 700; letter-spacing: .05em;
  padding: 3px 8px; border-radius: 20px;
}
.miedo-world-card__status--open  { background: rgba(39,174,96,.2); color: #2ecc71; border: 1px solid rgba(39,174,96,.4); }
.miedo-world-card__status--full  { background: rgba(192,57,43,.2); color: #e74c3c; border: 1px solid rgba(192,57,43,.4); }

/* -- Utilidades ---------------------------------------------- */
.miedo-loading {
  grid-column: 1/-1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 60px;
  color: var(--miedo-text-muted);
}

.miedo-spinner {
  display: inline-block;
  width: 22px; height: 22px;
  border: 3px solid var(--miedo-border);
  border-top-color: var(--miedo-accent);
  border-radius: 50%;
  animation: miedo-spin .7s linear infinite;
}
@keyframes miedo-spin { to { transform: rotate(360deg); } }

.miedo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: none;
  cursor: pointer;
  border-radius: var(--miedo-radius);
  transition: background var(--miedo-transition), color var(--miedo-transition);
  font-family: var(--miedo-font);
  font-size: .9rem;
}
.miedo-btn--icon {
  background: transparent;
  color: var(--miedo-text-muted);
  width: 38px; height: 38px;
  border-radius: 50%;
}
.miedo-btn--icon svg   { width: 22px; height: 22px; }
.miedo-btn--icon:hover { background: var(--miedo-bg-3); color: var(--miedo-text); }

.miedo-badge {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 16px; height: 16px;
  background: var(--miedo-accent);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  border-radius: 8px;
  padding: 0 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.miedo-btn--notif { position: relative; }