/**
 * MAMBEARTE - menu.css
 * Ubicación: /public_html/mambearte/css/menu.css
 * Descripción: Estilos del nuevo phaseMenu en estética "Galería Kitsch" (landing v3).
 *              Clases con prefijo .ma-* para no chocar con las existentes.
 *              Reutiliza IDs del index.php (menuKlem, menuIntro, menuPreview, klemApiBadge)
 *              para que initMenu() y aplicarIndicadorAPI() sigan funcionando sin cambios.
 */

/* ══════════════════════════════════════════════
   FUENTES Y TOKENS — prefijo --ma-* para aislar
══════════════════════════════════════════════ */
:root {
  --ma-velvet:       #1B1340;
  --ma-velvet-deep:  #0F0A28;
  --ma-night:        #0A1026;
  --ma-night-deep:   #05081A;

  --ma-gold:         #E8C964;
  --ma-gold-bright:  #FFD86B;
  --ma-gold-deep:    #9B7A1E;
  --ma-gold-shadow:  #5C4510;

  --ma-magenta:      #E94F8A;
  --ma-magenta-deep: #A81E5C;
  --ma-turquoise:    #3FCFD5;
  --ma-ruby:         #D9264A;

  --ma-parchment:    #F4E8C9;
  --ma-parch-dim:    #D4C08A;
  --ma-ivory:        #F8F1DC;
  --ma-ink:          #1A1005;

  --ma-f-display:    'Playfair Display', Georgia, serif;
  --ma-f-show:       'Bebas Neue', Impact, sans-serif;
  --ma-f-body:       'Inter', 'DM Sans', system-ui, sans-serif;
  --ma-f-hand:       'Caveat', cursive;
  --ma-f-script:     'Pinyon Script', cursive;
}

/* ══════════════════════════════════════════════
   TWEAKS GLOBALES
══════════════════════════════════════════════ */

/* Ocultar numeritos 1-6 de cartas en todas las fases del juego */
.card-num { display: none !important; }

/* Ocultar header viejo "✦ MAMBEARTE ✦ · ARTE UNIVERSAL" cuando:
   - el nuevo menú está visible (el hero nuevo ya cumple su función), o
   - está cargando cartas (phaseLoading), o
   - hay un error (phaseError).
   En #phaseGallery sigue visible porque allí no hay hero nuevo. */
.game-shell:has(#phaseMenu:not(.hidden)) .game-header-menu,
.game-shell:has(#phaseLoading:not(.hidden)) .game-header-menu,
.game-shell:has(#phaseError:not(.hidden)) .game-header-menu {
  display: none !important;
}

/* ══════════════════════════════════════════════
   PHASE MENU — reset del layout interno
══════════════════════════════════════════════ */
#phaseMenu {
  align-items: stretch;
  justify-content: flex-start;
  text-align: initial;
  gap: 18px;
  padding: 14px 14px 24px;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
  background: radial-gradient(ellipse at 50% 30%, var(--ma-velvet) 0%, var(--ma-velvet-deep) 55%, #000 100%);
}

/* Textura terciopelo */
#phaseMenu::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,216,107,0.04) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(233,79,138,0.05) 0%, transparent 40%),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.008) 0 2px, transparent 2px 5px);
  pointer-events: none;
  z-index: 0;
}

/* Elevar contenido del menú — EXCLUIR estrellas y twinkle-bursts porque son
   elementos de fondo posicionados con position:fixed (no deben ser reemplazados
   por position:relative, sino los ".ma-star" internos quedarían con height=0
   y se alinearían en una sola fila horizontal). */
#phaseMenu > *:not(.ma-stars):not(.ma-twinkle-burst) {
  position: relative;
  z-index: 2;
}

/* ══════════════════════════════════════════════
   FONDOS ANIMADOS
   - .ma-stars: 36 estrellitas fijas distribuidas en TODO el viewport
   - .ma-twinkle-burst: destellos intermitentes random en TODO el viewport
   
   Usamos position:fixed para garantizar distribución sobre el viewport completo
   sin depender del scroll ni de la altura del #phaseMenu. Se ocultan solas
   cuando el #phaseMenu está .hidden (por display:none heredado del parent).
══════════════════════════════════════════════ */
.ma-stars {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}
.ma-star {
  position: absolute;
  background: #FFE9A8;
  border-radius: 50%;
  animation: ma-twinkle 3s infinite ease-in-out;
}
@keyframes ma-twinkle {
  0%, 100% { opacity: 0.2; transform: scale(0.8); }
  50%      { opacity: 1;   transform: scale(1.2); }
}

/* Destellos intermitentes — spawned/removed por menu-setup.js */
.ma-twinkle-burst {
  position: fixed;
  background: radial-gradient(circle,
    #FFE9A8 0%,
    rgba(255,216,107,0.7) 30%,
    rgba(232,201,100,0.25) 60%,
    transparent 100%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  will-change: opacity, transform;
}
@keyframes ma-twinkle-burst {
  0%   { opacity: 0; transform: scale(0); }
  25%  { opacity: 1; transform: scale(1.4); }
  55%  { opacity: 0.9; transform: scale(1); }
  100% { opacity: 0; transform: scale(0.5); }
}

@keyframes ma-float {
  0%, 100% { transform: translateY(0) rotate(var(--ma-rot, 0deg)); }
  50%      { transform: translateY(-5px) rotate(var(--ma-rot, 0deg)); }
}

/* ══════════════════════════════════════════════
   KICKER EDITORIAL
══════════════════════════════════════════════ */
.ma-kicker {
  text-align: center;
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 11px;
  color: var(--ma-gold);
  letter-spacing: 5px;
  text-transform: uppercase;
  margin-top: 2px;
}

/* ══════════════════════════════════════════════
   HERO TITLE
══════════════════════════════════════════════ */
.ma-hero-title {
  text-align: center;
  font-family: var(--ma-f-display);
  font-weight: 900;
  font-style: italic;
  font-size: 62px;
  line-height: 0.9;
  color: var(--ma-ivory);
  text-shadow:
    0 3px 0 var(--ma-gold-shadow),
    0 8px 24px rgba(0,0,0,0.8);
  letter-spacing: -2px;
  margin: -6px 0 0 0;
}
.ma-hero-title .ma-arte { color: var(--ma-gold-bright); }

.ma-hero-sub {
  text-align: center;
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 14px;
  color: var(--ma-parch-dim);
  letter-spacing: 0.3px;
  max-width: 380px;
  margin: -4px auto 0;
  line-height: 1.3;
}

/* ══════════════════════════════════════════════
   KLEM ROW — avatar + bocadillo pergamino
══════════════════════════════════════════════ */
.ma-klem-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 2px;
}
.ma-klem-avatar-wrap {
  position: relative;
  flex-shrink: 0;
  cursor: pointer;
  display: inline-block;
}
.ma-klem-avatar {
  width: 104px; height: 104px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--ma-gold);
  box-shadow:
    0 0 30px rgba(232,201,100,0.35),
    0 0 0 6px rgba(232,201,100,0.08),
    0 10px 24px rgba(0,0,0,0.6);
  display: block;
  transition: border-color .4s, box-shadow .4s, transform .3s;
}
.ma-klem-avatar-wrap:hover .ma-klem-avatar { transform: scale(1.03); }

/* Badge estado API (reutiliza id klemApiBadge) */
.ma-klem-status {
  position: absolute;
  bottom: -6px; left: 50%;
  transform: translateX(-50%);
  background: var(--ma-night-deep);
  border: 1px solid var(--ma-gold-shadow);
  padding: 3px 10px;
  font-family: var(--ma-f-show);
  font-size: 10px;
  letter-spacing: 1.5px;
  color: var(--ma-gold);
  white-space: nowrap;
  z-index: 3;
}

/* Overlay frase NTQA (reutiliza .klem-frase viejo sobre wrapper nuevo) */
.ma-klem-avatar-wrap .klem-frase {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(10,8,24,0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  text-align: center;
  font-family: var(--ma-f-display);
  font-size: 10px;
  font-style: italic;
  color: var(--ma-gold);
  line-height: 1.4;
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
  z-index: 2;
}
.ma-klem-avatar-wrap .klem-frase.visible { opacity: 1; }

/* Bocadillo pergamino */
.ma-klem-bubble {
  flex: 1;
  position: relative;
  background: var(--ma-parchment);
  color: var(--ma-ink);
  padding: 12px 14px 12px 16px;
  border: 3px solid var(--ma-gold-deep);
  box-shadow: 0 8px 20px rgba(0,0,0,0.6);
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 13px;
  line-height: 1.35;
  min-height: 92px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ma-klem-bubble-label {
  font-family: var(--ma-f-show);
  font-size: 10px;
  letter-spacing: 2.5px;
  color: var(--ma-magenta-deep);
  margin-bottom: 4px;
  text-transform: uppercase;
}
/* Cola del bocadillo apuntando al avatar */
.ma-klem-bubble::before {
  content: '';
  position: absolute;
  left: -14px; top: 28px;
  width: 0; height: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-right: 14px solid var(--ma-gold-deep);
}
.ma-klem-bubble::after {
  content: '';
  position: absolute;
  left: -10px; top: 30px;
  width: 0; height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-right: 12px solid var(--ma-parchment);
}

/* ══════════════════════════════════════════════
   MARCO DORADO BARROCO — "Cómo se juega"
══════════════════════════════════════════════ */
.ma-gold-frame {
  position: relative;
  padding: 8px;
  background: linear-gradient(135deg,
    var(--ma-gold-bright) 0%,
    var(--ma-gold) 30%,
    var(--ma-gold-deep) 50%,
    var(--ma-gold) 70%,
    var(--ma-gold-bright) 100%);
  box-shadow:
    0 0 0 1px var(--ma-gold-shadow),
    0 8px 24px rgba(0,0,0,0.6),
    inset 0 0 0 1px rgba(255,248,216,0.4),
    inset 0 0 8px rgba(92,69,16,0.4);
  margin: 4px 0 16px;
}
.ma-gold-inner {
  background: var(--ma-night-deep);
  padding: 14px 16px 16px;
  position: relative;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.8), inset 0 0 16px rgba(0,0,0,0.6);
}
.ma-gold-corner {
  position: absolute;
  width: 18px; height: 18px;
  border-color: var(--ma-gold-bright);
  border-style: solid;
  opacity: 0.65;
  pointer-events: none;
  z-index: 3;
}
.ma-gold-corner.tl { top: 2px; left: 2px;    border-width: 2px 0 0 2px; }
.ma-gold-corner.tr { top: 2px; right: 2px;   border-width: 2px 2px 0 0; }
.ma-gold-corner.bl { bottom: 2px; left: 2px; border-width: 0 0 2px 2px; }
.ma-gold-corner.br { bottom: 2px; right: 2px; border-width: 0 2px 2px 0; }

.ma-gold-plaque {
  position: absolute;
  bottom: -11px; left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, #FFF8D8 0%, var(--ma-gold-bright) 15%, var(--ma-gold) 50%, var(--ma-gold-deep) 100%);
  color: var(--ma-ink);
  padding: 4px 16px;
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  border: 1px solid var(--ma-gold-shadow);
  box-shadow: 0 4px 10px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.7);
  white-space: nowrap;
  z-index: 4;
}

.ma-howto-title {
  font-family: var(--ma-f-display);
  font-style: italic;
  font-weight: 900;
  font-size: 15px;
  color: var(--ma-gold);
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.ma-howto-line {
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 13px;
  color: var(--ma-parchment);
  line-height: 1.75;
}
.ma-howto-line b {
  color: var(--ma-ivory);
  font-weight: 700;
  font-style: normal;
}

/* ══════════════════════════════════════════════
   DIFICULTAD — pills doradas
══════════════════════════════════════════════ */
.ma-diff-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
}
.ma-diff-label {
  font-family: var(--ma-f-show);
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--ma-gold);
  text-transform: uppercase;
}
.ma-diff-row {
  display: flex;
  gap: 8px;
}
.ma-diff-pill {
  all: unset;
  cursor: pointer;
  padding: 8px 18px;
  font-family: var(--ma-f-show);
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ma-gold);
  border: 1.5px solid var(--ma-gold-shadow);
  background: transparent;
  transition: all 0.2s;
  border-radius: 20px;
}
.ma-diff-pill:hover:not(.active) {
  border-color: var(--ma-gold);
  color: var(--ma-gold-bright);
}
.ma-diff-pill.active {
  background: linear-gradient(180deg, #FFF8D8 0%, var(--ma-gold-bright) 20%, var(--ma-gold) 55%, var(--ma-gold-deep) 100%);
  color: var(--ma-ink);
  border-color: var(--ma-gold-bright);
  box-shadow:
    0 0 20px rgba(232,201,100,0.5),
    inset 0 1px 0 rgba(255,255,255,0.8),
    inset 0 -2px 0 rgba(92,69,16,0.3);
}

/* ══════════════════════════════════════════════
   PREVIEW CARDS — mini cuadros con marco dorado
══════════════════════════════════════════════ */
.ma-preview-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.ma-preview-kicker {
  font-family: var(--ma-f-display);
  font-style: italic;
  font-size: 11px;
  color: var(--ma-gold);
  letter-spacing: 2.5px;
  text-transform: uppercase;
  text-align: center;
}
.ma-preview-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 4px 0;
}
.ma-preview-card {
  width: 48px;
  padding: 3px;
  background: linear-gradient(135deg, #FFF8D8 0%, var(--ma-gold-bright) 25%, var(--ma-gold) 50%, var(--ma-gold-deep) 75%, var(--ma-gold-shadow) 100%);
  box-shadow: 0 6px 16px rgba(0,0,0,0.6), inset 0 0 0 1px rgba(255,248,216,0.4);
  cursor: pointer;
  animation: ma-float 5s ease-in-out infinite;
  transition: transform .15s;
}
.ma-preview-card:hover {
  transform: translateY(-4px) rotate(0deg) scale(1.15) !important;
  z-index: 10;
}
.ma-preview-card-inner {
  border: 1.5px solid var(--ma-gold-shadow);
  background: #000;
  aspect-ratio: 5 / 7;
  overflow: hidden;
  position: relative;
}
.ma-preview-card-inner img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.ma-preview-card-fallback {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; opacity: 0.35;
  background: var(--ma-velvet);
}

/* ══════════════════════════════════════════════
   CTA BUTTONS — ambos dorados, mismo tamaño, una línea
   Tamaños más contenidos para verse proporcionados al resto del menú.
══════════════════════════════════════════════ */
.ma-cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  padding-bottom: 6px;
}
.ma-cta-btn {
  all: unset;
  box-sizing: border-box;
  cursor: pointer;
  padding: 11px 20px;
  width: 280px;
  max-width: calc(100vw - 32px);
  height: 46px;
  font-family: var(--ma-f-show);
  font-size: 16px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ma-ink);
  background: linear-gradient(180deg, #FFF8D8 0%, var(--ma-gold-bright) 20%, var(--ma-gold) 50%, var(--ma-gold-deep) 100%);
  border: 2px solid var(--ma-gold-shadow);
  box-shadow:
    0 5px 16px rgba(0,0,0,0.55),
    0 0 14px rgba(232,201,100,0.35),
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -2px 0 rgba(92,69,16,0.5);
  transition: all 0.15s;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ma-cta-btn:hover {
  transform: translateY(2px);
  box-shadow:
    0 3px 12px rgba(0,0,0,0.6),
    0 0 28px rgba(232,201,100,0.55),
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -2px 0 rgba(92,69,16,0.5);
}

/* ══════════════════════════════════════════════
   RESPONSIVE DESKTOP
══════════════════════════════════════════════ */
@media (min-width: 640px) {
  #phaseMenu { padding: 24px 40px 30px; gap: 22px; }
  .ma-hero-title { font-size: 90px; }
  .ma-hero-sub { font-size: 16px; max-width: 480px; }
  .ma-klem-avatar { width: 130px; height: 130px; }
  .ma-klem-bubble { font-size: 15px; padding: 14px 18px; min-height: 108px; }
  .ma-howto-title { font-size: 17px; }
  .ma-howto-line { font-size: 14px; }
  .ma-cta-btn { font-size: 18px; padding: 13px 24px; width: 320px; height: 52px; }
  .ma-preview-card { width: 56px; }
}