@charset "UTF-8";
/* CSS Document */

.page-memoria main,
.page-sopa main,
.page-sudokus main{
  background:#fff;
  max-width:var(--content-w);
  margin:0 auto;
  padding-top: calc(var(--header-h) + 32px);
}

.page-memoria .home-hero h1,
.page-sopa .home-hero h1,
.page-sudokus .home-hero h1{
  font-size:26px;
  color:var(--brand);
  margin:0 0 12px;
}

.page-memoria .nivel-badge,
.page-sopa .nivel-badge,
.page-sudokus .nivel-badge{
  display:block;
  margin:0 0 8px;
  font-family:var(--font-display);
  font-size:18px;
  font-weight:600;
}
/* ====================================================================================================
   MEMORIA
==================================================================================================== */

/* GRID PRINCIPAL */
.page-memoria .columns{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:32px;
  padding:0 var(--pad);
}

/* GRID DE JUEGOS */
.page-memoria .grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}

/* DESK GRANDE */
@media (min-width: 1100px){
  .page-memoria .grid{
    grid-template-columns:repeat(3,1fr);
  }
}
/* COLUMNAS */
.page-memoria .col{min-width:0}

.page-memoria .col--faciles{
  --accent:var(--a2);
  --accent-text:#9d4a00;
}
.page-memoria .col--intermedios{
  --accent:var(--a1);
  --accent-text:#9d4a00;
}
.page-memoria .col--dificiles{
  --accent:var(--a3);
  --accent-text:#a44a00;
}

/* CARD CUADRADA */
.page-memoria .card{
  aspect-ratio:1 / 1;
}

/* VER MÁS */
.page-memoria .ver-mas{
  margin-top:16px;
}



/* ====================================================================================================
   SOPA
==================================================================================================== */

/* ---------- GRID DE NIVELES ---------- */
.page-sopa .levels{
  display:grid;
    grid-template-columns:repeat(3,180px);
  gap:48px;
    justify-content:center;
    margin:0 auto 30px;
  padding:0 var(--pad);
  justify-items:stretch;
    align-items:start;
}
.page-sopa .level-item{
  display:flex;
  flex-direction:column;
}
/* ---------- CARDS ---------- */
.page-sopa .level-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
}
.page-sopa .level-card .card{
  width:100%;
}

.page-sopa .level-card .thumb{
  width:100%;
    height:auto;  
  aspect-ratio:1 / 1;
  object-fit:cover;
  display:block;
  border:3px solid var(--brand);
}

@media (hover:hover) and (pointer:fine){
  .page-sopa .card:hover .thumb{
    filter:none;
  }
}



.page-sopa .level-temas{
  list-style:none;
  margin:6px 0 18px;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px 14px;
    font-size:14px;
}

.page-sopa .level-temas a{
    color:var(--brand);
     font-weight:600; 
  text-decoration:none;
  white-space:nowrap;
      cursor:pointer;
}

.page-sopa .level-temas,
.page-sopa .level-temas a{
    font-family:var(--font-display);
}

.page-sopa .level-temas::before{
  content:"•";
  color:var(--a3);   /* naranja del sitio */
  font-size:22px;       /* más grande */
  line-height:1;
  margin-right:0px;
  transform:translateY(0px);
}


/* ====================================================================================================
   SUDOKUS
==================================================================================================== */


/* ---------- GRID DE NIVELES ---------- */
.page-sudokus .levels{
  display:grid;
  grid-template-columns:repeat(6,110px);
  gap:20px;
  justify-content:center;
  margin:0 auto 32px;
  padding:0;
}

/* ---------- CARD ---------- */
.page-sudokus .level-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
}

.page-sudokus .level-card,
.page-sudokus .level-card .thumb{
  overflow: visible;
}

/* imagen */
.page-sudokus .level-card .thumb{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  display:block;

  border:3px solid var(--brand);
  box-shadow:0 0 0 1px rgba(0,0,0,.12);
}

/* ---------- HOVER GLOBAL ---------- */
@media (hover:hover) and (pointer:fine){

  /* SOPAS */
  .page-sopa .level-card{
    transition:transform .2s ease;
  }

  .page-sopa .level-card:hover{
    transform:translateY(-2px);
  }

  .page-sopa .level-card .thumb{
    transition:transform .25s ease;
  }

  .page-sopa .level-card:hover .thumb{
    transform:scale(1.03);
  }

  .page-sopa .level-temas a{
    display:inline-block;
    transition:transform .15s ease, color .15s ease;
  }

  .page-sopa .level-temas a:hover{
    transform:scale(1.3);
    color:var(--brand);
  }
    
    /* SUDOKUS */
.page-sudokus .level-card{
  transition:transform .2s ease;
}

.page-sudokus .level-card:hover{
  transform:translateY(-2px);
}

.page-sudokus .level-card .thumb{
  transition:transform .25s ease, box-shadow .25s ease, border .25s ease;
}

.page-sudokus .level-card:hover .thumb{
  transform:scale(1.06);
  border:4px solid var(--brand);
  box-shadow:none;
}
    
}

/* ====================================================================================================
   SUBMENUS — EXCEPCIONES
==================================================================================================== */

/* MEMORIA — H1 no va centrado al borde */
.page-memoria h1{
  padding-left:var(--pad);
}


/* ====================================================================================================
   FIN SUBMENUS — EXCEPCIONES
==================================================================================================== */


/* ====================================================================================================
   SUBMENUS — TABLETS
==================================================================================================== */

@media (min-width:641px) and (max-width:1099px){

  /* =========================
     MEMORIA
  ========================= */

  /* columnas: siguen siendo 3, menos aire */
  .page-memoria .columns{
    gap:24px;
    padding:0 var(--pad);
  }

  /* grid interno: 2 thumbs por columna */
  .page-memoria .grid{
    grid-template-columns:repeat(2,1fr);
    gap:14px;
  }

  /* cards */
  .page-memoria .card{
    aspect-ratio:1 / 1;
  }

  /* =========================
     SOPA
  ========================= */

  .page-sopa .levels{
    grid-template-columns:repeat(3,160px);
    gap:32px;
    margin:0 auto 28px;
    padding:0 var(--pad);
  }

  .page-sopa .level-temas{
    font-size:15px;
  }

  /* =========================
     SUDOKUS
  ========================= */


  .page-sudokus .levels{
    grid-template-columns:repeat(6, minmax(0, 1fr));
    max-width:100%;
    padding:0 var(--pad);
    box-sizing:border-box;
  }

  .page-sudokus .level-card .thumb{
    width:100%;
  }

}



/* ====================================================================================================
   SUBMENUS MOBILE
==================================================================================================== */


@media (max-width:640px){

  .page-memoria main{
    padding:
      calc(var(--header-h) + 50px)
      16px
      0;
    overflow-x:hidden;
  }

     
  .page-sopa main{
    padding:
      calc(var(--header-h) + 70px)
      16px
      0;
    overflow-x:hidden;
  }

  .page-sudokus main{
    padding:
      calc(var(--header-h) + 70px)
      16px
      0;
    overflow-x:hidden;
  }
    
  .page-memoria .home-hero h1,
  .page-sopa .home-hero h1,
  .page-sudokus .home-hero h1{
    text-align:center;
    font-weight:700;
    margin-bottom:2px;
  }

  .page-memoria .nivel-badge,
  .page-sopa .nivel-badge,
  .page-sudokus .nivel-badge{
    width:100%;
    text-align:center;
  }

    
   /* ===================================
   SUBMENU MEMORIA MOBILE
======================================== */ 
    
     /* HERO */
  .page-memoria .home-hero{
    padding: 16px var(--pad) 12px;
    margin-bottom: 8px;
  }

  /* AFTER HERO (igual Sudokus) */
  .page-memoria .section-after-hero{
    margin-top: 32px;
    padding: 0 var(--pad);
  }

  /* HERO */
  .page-memoria .home-hero{
    padding-bottom:12px;
  }

  /* BLOQUE: 3 COLUMNAS FIJAS (Fácil / Medio / Difícil) */
  .page-memoria .columns{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:16px;
    padding:0 var(--pad);
          padding-left:0;
    padding-right:0;
  }

  /* CADA COLUMNA */
  .page-memoria .col{
    min-width:0;
    display:flex;
    flex-direction:column;
  }

  /* GRID INTERNO: UNA SOLA COLUMNA DE THUMBS */
  .page-memoria .col .grid{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
          margin-left:0;
    margin-right:0;
  }


  /* CARD */
  .page-memoria .card{
    aspect-ratio:1 / 1;
  }

  .page-memoria .thumb{
    width:100%;
    height:auto;
    display:block;
  }
    
    
   /* ===================================
   SUBMENU SOPAS MOBILE
======================================== */     
    
  /* HERO */
  .page-sopa .home-hero{
    padding-bottom:0;
  }

  /* GRID DE NIVELES */
  .page-sopa .levels{
    grid-template-columns:repeat(3,1fr);
    gap:14px;
    margin:16px 0 24px;
    padding:0;
    align-items:start;
  }

  /* CARD */
  .page-sopa .level-card{
    display:block;
  }



  /* THUMB */
  .page-sopa .level-card .thumb{
    border-width:2px;
  }

  /* TEMAS */
  .page-sopa .level-temas{
    font-size:18px;
    gap:6px 14px;
    margin:6px 0 14px;
  }
    
    /* ===================================
   SUBMENU SUDOKUS MOBILE
======================================== */      
    
   .page-sudokus .home-hero{
  padding-bottom:12px;
}

.page-sudokus .levels{
    grid-template-columns:repeat(3,1fr);
    gap:14px;
    margin:16px 0 24px;
        margin-top:0;
  }


  /* CONTENEDOR DE NIVELES */
  .page-sudokus .levels-wrap{
    margin-top:0;
  } 
    

  /* SUBMENÚS: el header debe crecer para alojar breadcrumbs */
  .page-memoria .header,
  .page-sopa .header,
  .page-sudokus .header{
    padding-bottom: 0px;
  }

  /* breadcrumbs debajo del logo, como en juegos */
  .page-memoria .breadcrumbs--header,
  .page-sopa .breadcrumbs--header,
  .page-sudokus .breadcrumbs--header{
    margin-top: 0px;
    font-size:15px;
   
  }
    
    
}

