:root{
      --bg:#0b0f19;
      --panel:#0f1629;
      --panel2:#0c1326;
      --card:#101a33;
      --border:rgba(255,255,255,.08);
      --text:#e7ecff;
      --muted:rgba(231,236,255,.7);
      --muted2:rgba(231,236,255,.55);
      --acc:#6a00ff;
      --acc2:#2de2e6;
      --good:#37d67a;
      --warn:#ffcc66;
      --shadow: 0 14px 40px rgba(0,0,0,.45);
      --r:18px;
      --r2:14px;
      --max:1200px;
    }

    *{box-sizing:border-box}
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
      background: radial-gradient(1200px 700px at 20% -10%, rgba(124,92,255,.25), transparent 60%),
                  radial-gradient(900px 600px at 90% 10%, rgba(45,226,230,.16), transparent 55%),
                  var(--bg);
      color:var(--text);
    }

    a{color:inherit; text-decoration:none}
    .wrap{max-width:var(--max); margin:0 auto; padding:16px}

    /* Header */
    header{
      position:sticky; top:0; z-index:50;
      backdrop-filter: blur(10px);
      background: linear-gradient(to bottom, rgba(11,15,25,.92), rgba(11,15,25,.68));
      border-bottom:1px solid var(--border);
    }
    .head{
      display:flex; gap:14px; align-items:center; justify-content:space-between;
      padding:12px 16px;
      max-width:var(--max); margin:0 auto;
    }
    .brand{
      display:flex; align-items:center; gap:10px;
      font-weight:800; letter-spacing:.2px;
    }
    .logo{
      width:38px; height:38px; border-radius:12px;
      background:
        radial-gradient(12px 12px at 30% 35%, rgba(45,226,230,.9), transparent 60%),
        radial-gradient(18px 18px at 70% 70%, rgba(124,92,255,.95), transparent 60%),
        linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.06));
      border:1px solid var(--border);
      box-shadow: 0 10px 30px rgba(0,0,0,.35);
    }
    .brand small{display:block; font-weight:600; color:var(--muted); letter-spacing:0}
    .search{
      flex:1; max-width:520px;
      display:flex; align-items:center; gap:10px;
      background: rgba(255,255,255,.05);
      border:1px solid var(--border);
      border-radius:999px;
      padding:10px 14px;
    }
    .search input{
      width:100%;
      background:transparent;
      border:0; outline:none;
      color:var(--text);
      font-size:14px;
    }
    .nav{
      display:flex; gap:10px; align-items:center;
    }
    .pill{
      padding:10px 12px;
      border-radius:999px;
      border:1px solid var(--border);
      background: rgba(255,255,255,.03);
      color:var(--muted);
      font-weight:700;
      font-size:13px;
      transition:.15s;
    }
    .pill:hover{transform: translateY(-1px); background: rgba(255,255,255,.06); color:var(--text)}
    .pill.primary{
      background: linear-gradient(135deg, rgba(124,92,255,.22), rgba(45,226,230,.12));
      color:var(--text);
      border-color: rgba(124,92,255,.45);
    }

    /* Layout */
    .grid{
      display:grid;
      grid-template-columns: 200px 1fr 200px;
      gap:16px;
      align-items:start;
      margin-top:16px;
    }

    /* Ads */
    .ad{
      border:1px dashed rgba(255,255,255,.25);
      border-radius: var(--r);
      background: rgba(255,255,255,.03);
      height: 560px;
      display:flex; align-items:center; justify-content:center;
      color: rgba(255,255,255,.55);
      position:sticky; top:86px;
    }
    .ad small{display:block; text-align:center; line-height:1.3}
    .sideStack{display:flex; flex-direction:column; gap:16px}
    .miniWidget{
      border:1px solid var(--border);
      border-radius: var(--r);
      background: rgba(255,255,255,.03);
      padding:14px;
    }
    .miniWidget h4{margin:0 0 10px 0; font-size:14px}
    .miniWidget .row{
      display:flex; justify-content:space-between;
      padding:10px 0;
      border-top:1px solid rgba(255,255,255,.06);
      color:var(--muted);
      font-size:13px;
    }
    .miniWidget .row:first-of-type{border-top:0}

    /* Main panels */
    .panel{
      border:1px solid var(--border);
      border-radius: var(--r);
      background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .hero{
      padding:18px 18px 14px 18px;
      background:
        radial-gradient(700px 240px at 10% 10%, rgba(124,92,255,.25), transparent 60%),
        radial-gradient(520px 220px at 90% 40%, rgba(45,226,230,.15), transparent 60%);
      border-bottom:1px solid rgba(255,255,255,.06);
    }
    .heroTop{
      display:flex; gap:12px; justify-content:space-between; align-items:flex-start;
    }
    .hero h1{margin:0; font-size:22px; letter-spacing:.2px}
    .sub{margin:6px 0 0 0; color:var(--muted); font-size:14px}
    .badge{
      padding:8px 10px;
      border-radius:999px;
      background: rgba(55,214,122,.12);
      border:1px solid rgba(55,214,122,.35);
      color: rgba(231,236,255,.92);
      font-weight:800;
      font-size:12px;
      white-space:nowrap;
    }

    .section{
      padding:16px 18px;
      border-top:1px solid rgba(255,255,255,.06);
    }
    .sectionHead{
      display:flex; justify-content:space-between; align-items:center;
      margin-bottom:12px;
    }
    .sectionHead h2{
      margin:0; font-size:16px; letter-spacing:.2px;cursor: default;
    }
    .sectionHead a{
      font-size:13px; color:var(--muted);
      padding:8px 10px; border-radius:999px;
      border:1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.03);
    }
    .sectionHead a:hover{color:var(--text); background: rgba(255,255,255,.06)}

    /* Two rectangles */
    .duo{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap:12px;
    }
    .bigCard{
      border:1px solid rgba(255,255,255,.09);
      background: rgba(15,22,41,.55);
      border-radius: var(--r2);
      padding:14px;
      position:relative;
      overflow:hidden;
      min-height:128px;
      transition:.15s;
    }
    .bigCard:hover{transform: translateY(-2px); border-color: rgba(124,92,255,.35)}
    .bigCard::after{
      content:"";
      position:absolute; inset:-60px -60px auto auto;
      width:220px; height:220px; border-radius:50%;
      background: radial-gradient(circle at 40% 40%, rgba(124,92,255,.22), transparent 60%);
      pointer-events:none;
    }
    .bigCard.steam::after{
      background: radial-gradient(circle at 40% 40%, rgba(45,226,230,.18), transparent 60%);
    }
    .kicker{
      display:flex; align-items:center; justify-content:space-between;
      color:var(--muted);
      font-weight:800;
      letter-spacing:.3px;
      font-size:12px;
      text-transform:uppercase;
    }
    .title{
      margin:8px 0 6px 0;
      font-size:16px;
      font-weight:900;
    }
    .meta{
      color:var(--muted2);
      font-size:13px;
      line-height:1.45;
      margin:0;
    }
    .ctaRow{
      margin-top:10px;
      display:flex; gap:10px; align-items:center; flex-wrap:wrap;
    }
    .chip{
      padding:7px 10px;
      border-radius:999px;
      background: rgba(255,255,255,.04);
      border:1px solid rgba(255,255,255,.08);
      font-size:12px;
      color:var(--muted);
      font-weight:800;
    }
    .chip.good{border-color: rgba(55,214,122,.35); background: rgba(55,214,122,.10); color: rgba(231,236,255,.88)}
    .chip.warn{border-color: rgba(255,204,102,.35); background: rgba(255,204,102,.10); color: rgba(231,236,255,.88)}

    /* 5 recommended squares */
    .five{
      display:grid;
      grid-template-columns: repeat(5, 1fr);
      gap:10px;
    }
    .game{
      border:1px solid rgba(255,255,255,.09);
      background: rgba(16,26,51,.55);
      border-radius: var(--r2);
      padding:12px;
      min-height:122px;
      display:flex;
      flex-direction:column;
      gap:8px;
      transition:.15s;
    }
    .game:hover{transform: translateY(-2px); border-color: rgba(45,226,230,.32)}
    .thumb{
      width:100%;
      aspect-ratio: 1/1;
      border-radius: 12px;
      border:1px solid rgba(255,255,255,.10);
      background:
        linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
      display:flex; align-items:center; justify-content:center;
      color: rgba(255,255,255,.55);
      font-weight:900;
      font-size:12px;
      position:relative;
      overflow:hidden;
    }
    .thumb::after{
      content:"";
      position:absolute; inset:auto -40px -40px auto;
      width:120px; height:120px; border-radius:50%;
      background: radial-gradient(circle at 40% 40%, rgba(124,92,255,.22), transparent 60%);
    }
    .gname{font-weight:900; font-size:13px; margin:0}
    .gmeta{margin:0; font-size:12px; color:var(--muted); line-height:1.2}
    .score{
      margin-top:auto;
      display:flex; justify-content:space-between; align-items:center;
      font-size:12px; color:var(--muted);
    }
    .score b{color:var(--text)}
    .tag{padding:5px 8px; border-radius:999px; border:1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.03)}

    /* Guides */
    .guides{
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap:12px;
    }
    .guide{
      border:1px solid rgba(255,255,255,.09);
      background: rgba(12,19,38,.55);
      border-radius: var(--r2);
      overflow:hidden;
      display:flex;
      min-height:120px;
      transition:.15s;
    }
    .guide:hover{transform: translateY(-2px); border-color: rgba(124,92,255,.33)}
    .gthumb{
      width:140px;
      background:
        linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
      border-right:1px solid rgba(255,255,255,.08);
      display:flex; align-items:center; justify-content:center;
      color: rgba(255,255,255,.6);
      font-weight:900;
      position:relative;
    }
    .gthumb::after{
      content:"";
      position:absolute; inset: -50px auto auto -50px;
      width:140px; height:140px; border-radius:50%;
      background: radial-gradient(circle at 40% 40%, rgba(45,226,230,.18), transparent 60%);
    }
    .gbody{
      padding:12px;
      display:flex; flex-direction:column; gap:6px;
      flex:1;
    }
    .gbody h3{margin:0; font-size:14px}
    .categoriacategoria {font-size: 18px !important;}
    .line{margin:0; font-size:17px; color:var(--muted); line-height:1.3}
    @media (max-width: 880px){
      .gbody h3{font-size:13px}
      .line{font-size:10px}
      .categoria {font-size: 13px !important;}
    }
    .btn{
      margin-top:auto;
      align-self:flex-start;
      padding:8px 10px;
      border-radius: 12px;
      border:1px solid rgba(124,92,255,.45);
      background: rgba(124,92,255,.14);
      font-weight:900;
      font-size:12px;
      color:var(--text);
      transition:.15s;
    }
    .btn:hover{transform: translateY(-1px); background: rgba(124,92,255,.20)}

    /* Footer */
    footer{
      margin-top:18px;
      border-top:1px solid rgba(255,255,255,.08);
      padding:18px 16px;
      color:var(--muted);
      text-align:center;
      font-size:13px;
    }

    /* Responsive */
    @media (max-width: 1150px){
      .grid{grid-template-columns: 1fr; }
      .ad{position:relative; top:auto; height:180px}
      .sideStack{display:none}
    }
    @media (max-width: 880px){
      .duo{grid-template-columns:1fr}
      .five{grid-template-columns: repeat(2, 1fr)}
      .guides{grid-template-columns:1fr}
      .guide {max-height: 180px;}
      .search{display:none}
    }


/* TEMPORAL STYLES */
.bigCard.frozen{
  border-color: rgba(88, 185, 249, 0.582) !important;
  background: linear-gradient(180deg, rgba(120, 201, 255, 0.261), rgba(17, 24, 45, 0.55));
  box-shadow: 0 0 0 1px rgba(120,200,255,.14), 0 14px 40px rgba(0,0,0,.45);
}
.bigCard.frozen .chip.warn{
  border-color: rgba(120, 201, 255, 0.668);
  background: rgba(120,200,255,.12);
}
/* Epic card con background */
.bigCard.epic.hasBg{
  position: relative;
  overflow: hidden;
}

/* OVERLAY OSCURO para legibilidad */
.bigCard.epic.hasBg::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      rgba(10, 14, 25, 0.56) 0%,
      rgba(10,14,25,0.75) 55%,
      rgba(10,14,25,0.85) 100%
    );
  pointer-events: none;
  z-index: 0;
}

/* Todo el contenido arriba del overlay */
.bigCard.epic > *{
  position: relative;
  z-index: 1;
}
/* =========================
   ADS (desktop + mobile)
========================= */

/* Que las imágenes de ads se adapten */
.ad img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}

/* Sticky solo en desktop */
.ad.sticky {
  position: sticky;
  top: 86px;
}

/* Ads mobile ocultos por defecto */
.ad.mobile {
  display: none;
}

/* =========================
   MOBILE BEHAVIOR
========================= */
@media (max-width: 768px) {

  /* Ocultamos stickys en mobile */
  .ad.sticky {
    display: none;
  }

  /* Mostramos ads mobile inline */
  .ad.mobile {
    display: block;
    height: auto;
    margin: 16px auto;
    border: 1px dashed rgba(255,255,255,.18);
    background: rgba(255,255,255,.03);
    text-align: center;
  }
}
/* =========================
   FIX: fondo + footer abajo
========================= */

html, body {
  height: 100%;
}

body {
  min-height: 100vh;

  /* Sticky footer layout */
  display: flex;
  flex-direction: column;

  /* Evita “cortes” raros del background al zoom */
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
}

/* Tu <main> es <main class="wrap"> */
main.wrap {
  flex: 1;
}

/* En mobile, mejor desactivar fixed para evitar glitches */
@media (max-width: 768px) {
  body {
    background-attachment: scroll;
  }
}
/* =========================
   GUIDES: tarjetas largas
========================= */

/* 1 por fila (rectángulo largo) */
.guides{
  grid-template-columns: 1fr !important;
}

/* Card larga: thumb a la izquierda, contenido a la derecha */
.guide{
  min-height: 140px;
  align-items: stretch;
}

/* Imagen más grande y consistente */
.gthumb{
  width: 220px;           /* antes 140px */
  min-height: 140px;
}
@media (max-width: 880px){
  .gthumb{
    width: 130px;         /* antes 140px */
    min-height: 120px;
  }
}

.gthumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Más aire para el texto */
.gbody{
  padding: 14px;
}

/* Botón un poco más “CTA” */
.guide .btn{
  margin-top: auto;
}
.badge-new {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .5px;
  background: #00ff95;
  color: #08110c;
  box-shadow: 0 8px 22px rgba(0,0,0,.35);
  z-index: 5;
}
/* =========================
   RELATED GUIDES (2 cards)
   Pegar al final del CSS
========================= */

.guides-related{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 12px;
}

/* Card mini independiente de la .guide grande */
.guides-related .guide.mini{
  display: flex;
  gap: 12px;
  align-items: stretch;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(12,19,38,.55);
  border-radius: var(--r2);
  overflow: hidden;

  /* sacamos tus márgenes enormes */
  margin: 0 !important;
  min-height: 110px;
}

/* Thumb mini (no usa tu width 220px de gthumb grande) */
.guides-related .guide.mini .gthumb{
  width: 15rem !important;
  height: 12rem;
  min-height: 110px;
  flex-shrink: 0;
  border-right: 1px solid rgba(255,255,255,.08);
  position: relative;
  overflow: hidden;
  border-radius: 0 !important;
}

.guides-related .guide.mini .gthumb::after{
  display:none; /* apagamos el glow circular para mini */
}

.guides-related .guide.mini img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

/* Body mini */
.guides-related .guide.mini .gbody{
  padding: 12px;
  display:flex;
  flex-direction:column;
  gap: 6px;
}

.guides-related .guide.mini h3{
  margin: 0;
  font-size: 14px;
  line-height: 1.2;
}

.guides-related .guide.mini .line{
  margin: 0;
  font-size: 12px;
  line-height: 1.25;
  color: var(--muted);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.guides-related .guide.mini .btn{
  margin-top: auto;
  font-size: 12px;
}


/* Mobile: 1 por fila + thumb más chico */
@media (max-width: 768px){
  .guides-related{
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .vid_adj {
    height: 200px;
  }
  .vid_txt {
    font-size: 2rem !important;
  }

  .guides-related .guide.mini .gthumb{
    width: 120px !important;
    height: 96px;
    min-height: 96px;
  }

  .guides-related .guide.mini h3{
    font-size: 13px;
  }

  .guides-related .guide.mini .line{
    font-size: 11px;
  }
}
/* =========================
   FIX NAV MOBILE (header)
========================= */
@media (max-width: 600px){

  .head{
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
  }

  .logo{ width:34px; height:34px; border-radius:10px; }
  .brand{ min-width: 0; }
  .brand small{ display:none; } /* ocultar subtítulo */

  .nav{
    width: 100%;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 8px;
    padding-bottom: 2px;
  }

  .pill{
    flex: 0 0 auto;
    padding: 9px 11px;
    font-size: 12px;
    white-space: nowrap;
  }

  .nav::-webkit-scrollbar{ height: 0; }
}
.readmore{
  color: rgba(231,236,255,.92);
  font-weight: 800;
  text-decoration: underline;
  text-decoration-color: rgba(124,92,255,.55);
  text-underline-offset: 3px;
  opacity: .95;
}
/* ===== Guías: toolbar ===== */
.guides-toolbar{
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "search sort"
    "filters filters"
    "meta meta";
  gap: 12px 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  margin-bottom: 14px;
}

/* Search */
.guides-search{
  grid-area: search;
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: #fff;
  font-size: 14px;
  outline: none;
}

.guides-search::placeholder{
  color: rgba(255,255,255,.45);
}

.guides-search:focus{
  border-color: rgba(120,160,255,.55);
  box-shadow: 0 0 0 3px rgba(120,160,255,.12);
  background: rgba(0,0,0,.24);
}

/* Sort wrapper + label */
.guides-sort{
  grid-area: sort;
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: flex-end;
}

.guides-sort label{
  font-size: 12px;
  color: rgba(255,255,255,.6);
}

/* Select (no “Windows default”) */
.guides-select{
  padding: 10px 36px 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: 13px;
  cursor: pointer;
  outline: none;

  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/* Flechita fake */
.guides-sort{
  position: relative;
}
.guides-sort::after{
  content: "▾";
  position: absolute;
  right: 14px;
  pointer-events: none;
  color: rgba(255,255,255,.65);
  font-size: 12px;
  top: 50%;
  transform: translateY(-50%);
}

/* options */
.guides-select option{
  background: #0e1320;
  color: #fff;
}

/* Filters chips row */
.guides-filters{
  grid-area: filters;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Meta line */
.guides-meta{
  grid-area: meta;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 2px;
}

.guides-meta .dot{
  opacity: .35;
}

/* Mobile: todo en una columna */
@media (max-width: 640px){
  .guides-toolbar{
    grid-template-columns: 1fr;
    grid-template-areas:
      "search"
      "sort"
      "filters"
      "meta";
  }

  .guides-sort{
    justify-content: flex-start;
    width: 100%;
  }

  .guides-sort::after{
    right: 14px;
  }

  .guides-select{
    width: 100%;
  }
}
/* ===== Card (XL) ===== */
.guide-card{
  display: flex;
  flex-direction: column;
  text-decoration: none;

  border-radius: 22px;
  overflow: hidden;

  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  will-change: transform;
  margin: 1rem;
}

.guide-card:hover{
  transform: scale(1.01);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 22px 55px rgba(0,0,0,.50);
  background-color: #000000b8;
}

.guide-card:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(120,160,255,.18), 0 22px 55px rgba(0,0,0,.50);
}

/* ===== Imagen (más grande) ===== */
.guide-cover{
  height: 40rem;          /* antes 210px */
  background: rgba(0,0,0,.22);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;          /* antes 10px */
}

.guide-cover img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;    /* antes 14px */
}

/* si falla la imagen */
.guide-cover.no-img{
  background: radial-gradient(circle at 30% 20%, rgba(120,160,255,.18), rgba(0,0,0,.35));
}

/* ===== Texto (más grande) ===== */
.guide-body{
  padding: 18px 18px 20px;  /* antes 14/16 */
}

.guide-h{
  margin: 0 0 8px;
  color: #fff;
  font-size: 18px;          /* antes 15px */
  font-weight: 700;
  line-height: 1.25;
}

.guide-p{
  margin: 0 0 12px;
  color: rgba(255,255,255,.72);
  font-size: 14px;          /* antes 13px */
  line-height: 1.45;
}

/* ===== Tags (más “tocables”) ===== */
.guide-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;                 /* antes 6px */
}

.guide-tags .tag{
  font-size: 12px;          /* antes 11px */
  padding: 6px 10px;        /* antes 4px 8px */
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.90);
}

/* ===== Skeleton (XL) ===== */
.guide-card.is-skeleton{
  border-color: rgba(255,255,255,.06);
  background: rgba(255,255,255,.03);
  pointer-events: none;
}

.guide-card.is-skeleton .guide-cover{
  height: 320px;           /* match */
  background: rgba(255,255,255,.06);
}

.guide-card.is-skeleton .guide-cover,
.guide-card.is-skeleton .guide-title,
.guide-card.is-skeleton .guide-sub,
.guide-card.is-skeleton .guide-tags{
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}

.guide-card.is-skeleton .guide-title{
  height: 16px;
  margin: 18px 18px 12px;
  background: rgba(255,255,255,.06);
}

.guide-card.is-skeleton .guide-sub{
  height: 12px;
  margin: 0 18px 16px;
  background: rgba(255,255,255,.05);
}

.guide-card.is-skeleton .guide-tags{
  height: 12px;
  margin: 0 18px 18px;
  background: rgba(255,255,255,.04);
}

/* shimmer */
.guide-card.is-skeleton *::after{
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-120%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  animation: shimmer 1.2s infinite;
}
@keyframes shimmer{
  100% { transform: translateX(120%); }
}

/* ===== Empty state ===== */
.empty{
  padding: 22px;
  border-radius: 18px;
  border: 1px dashed rgba(255,255,255,.16);
  background: rgba(255,255,255,.03);
  text-align: center;
}
.empty h2{
  margin: 0 0 8px;
  font-size: 20px;
  color: #fff;
}
.empty .line{
  margin: 0 0 12px;
  color: rgba(255,255,255,.7);
  font-size: 14px;
}

/* ===== Responsive tweaks ===== */
@media (max-width: 520px){
  .guides-grid{
    grid-template-columns: 1fr;
  }
  .guide-cover{
    height: 240px;          /* antes 190px */
  }
}
/* Overlay que oscurece la página */
#videoDim {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);  /* Aumenta la opacidad aquí */
  opacity: 0;
  pointer-events: none;
  transition: opacity 400ms ease;
  z-index: 80;
  filter: blur(5px); /* Desenfoque suave en el fondo */
}

/* Activo cuando el video está en play */
body.is-video-playing #videoDim {
  opacity: 1;
  pointer-events: auto;
  filter: blur(10px); /* Aumenta el desenfoque cuando está activo */
}

/* El contenedor del video queda arriba */
body.is-video-playing .video-focus {
  position: relative;
  z-index: 90; /* Asegúrate de que esté arriba del overlay */
  transform: scale(1.03); /* Aumenta ligeramente el tamaño del video */
  transition: transform 500ms ease; /* Transición suave cuando se escala */
}

/* Brillo y resaltar el video */
body.is-video-playing .video-focus::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 14px; /* Bordes redondeados si tienes borde en el video */
  z-index: -1;  /* Asegura que el brillo esté detrás del video */
  transition: box-shadow 500ms ease; /* Transición suave del resplandor */
}

/* Si no se está reproduciendo, vuelve a su estado normal */
body:not(.is-video-playing) .video-focus {
  transform: scale(1);  /* Vuelve al tamaño original */
  transition: transform 350ms ease;
}

/* Ajuste de brillo y escala cuando se pausa */
body:not(.is-video-playing) .video-focus::after {
  box-shadow: none; /* Elimina el resplandor */
}
/* Contenedor del video */
.video-focus {
  position: relative;
  width: 100%;  /* Asegura que ocupe todo el ancho disponible */
  max-width: 100%;
  height: auto; /* Permite que el contenedor se ajuste automáticamente */
  overflow: hidden; /* Evita el desbordamiento */
  margin-bottom: 20px; /* Espacio debajo del video */
}
.guide_rsm {
  font-size: 0.8rem;
}

/* Bottom ad: oculto por defecto */
#ad-bottom.ad-bottom{
  display: none;
  margin: 18px auto 0;
  padding: 12px;
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.18);
  background: rgba(255,255,255,.03);
  text-align: center;

  /* para que quede “abajo del todo” pero dentro del layout */
  width: 100%;
  max-width: 720px;
}

/* En mobile + tablet-like lo mostramos */
@media (max-width: 1150px){
  #ad-bottom.ad-bottom{
    display: block;
  }
}

/* Que el contenido no se estire raro */
#ad-bottom img,
#ad-bottom ins{
  width: 100% !important;
  height: auto !important;
  max-width: 720px;
  display: block;
  margin: 0 auto;
  border-radius: 12px;
}


body::before{ content:"desktop"; display:none; }
@media (max-width: 1150px){ body::before{ content:"compact"; } }
@media (max-width: 768px){ body::before{ content:"mobile"; } }


/* =========================
   CHRISTMAS SNOW (PRO)
========================= */

#snow-container {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  overflow: hidden;
}

.snowflake {
  position: absolute;
  top: -8%;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 0 8px rgba(255,255,255,.25);
  user-select: none;
  animation-name: snow-fall;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

@keyframes snow-fall {
  from {
    transform: translateY(-10vh) translateX(0);
  }
  to {
    transform: translateY(110vh) translateX(var(--drift));
  }
}

/* Mobile: más sutil */
@media (max-width: 768px) {
  .snowflake {
    opacity: 0.6;
    text-shadow: none;
  }
}
/* =========================
   WINTER FROST OVERLAY
========================= */

#winter-frost {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 140px;
  pointer-events: none;
  z-index: 40;

  background:
    radial-gradient(
      120% 80% at 50% -20%,
      rgba(255,255,255,0.12),
      rgba(255,255,255,0.05) 35%,
      rgba(255,255,255,0.02) 55%,
      transparent 70%
    );

  mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
  opacity: 0.75;
}

/* Mobile: desactivar (queda solo la nieve) */
@media (max-width: 768px){
  #winter-frost {
    display: none;
  }
}
/* Ofertas de Xbox Game Pass */
#gamepass-offers {
  margin-top: 32px;
  padding: 16px;
  background-color: #1a202c;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

#gamepass-offers h2 {
  font-size: 24px;
  color: #fff;
  margin-bottom: 16px;
}

.gamepass-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.gamepass-item {
  background-color: #101a33;
  padding: 14px;
  border-radius: 12px;
  text-align: center;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.gamepass-item img {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.gamepass-item h3 {
  font-size: 18px;
  margin-top: 10px;
}

.gamepass-item .price {
  font-size: 16px;
  color: #6a00ff;
  margin-top: 8px;
}

.gamepass-item .cta-btn {
  margin-top: 12px;
  padding: 8px 16px;
  background-color: #37d67a;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
}

.gamepass-item .cta-btn:hover {
  background-color: #2d9b59;
}

/* Los Más Jugados */
#most-played {
  margin-top: 32px;
  padding: 16px;
  background-color: #1a202c;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

#most-played h2 {
  font-size: 24px;
  color: #fff;
  margin-bottom: 16px;
}

.most-played-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.most-played-item {
  background-color: #101a33;
  padding: 14px;
  border-radius: 12px;
  text-align: center;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.most-played-item img {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.most-played-item h3 {
  font-size: 18px;
  margin-top: 10px;
}

.most-played-item .price {
  font-size: 16px;
  color: #ffcc66;
  margin-top: 8px;
}

.most-played-item .cta-btn {
  margin-top: 12px;
  padding: 8px 16px;
  background-color: #37d67a;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
}

.most-played-item .cta-btn:hover {
  background-color: #2d9b59;
}

/* Adaptación móvil */
@media (max-width: 768px) {
  .gamepass-list, .most-played-list {
    grid-template-columns: 1fr;
  }
}
#gamepass-list, #most-played-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}

.gamepass-item, .most-played-item {
  flex: 1;
  max-width: calc(20% - 20px); /* 5 items por fila */
  box-sizing: border-box;
}

img {
  max-width: 100%;
  height: auto;
}

/* Estilo de la sección "Lanzamientos Futuros" */
#lanzamientos-futuros {
  background: var(--bg); /* Mismo fondo que el resto de la página */
  padding: 20px;
  border-radius: var(--r);
  box-shadow: var(--shadow);
  margin-top: 30px;
  text-align: center;  /* Centrado del texto */
}

/* Título centrado */
#lanzamientos-futuros h2 {
  font-size: 24px;  /* Tamaño del título */
  color: var(--text);
  font-weight: 800;
  margin-bottom: 20px;
}

/* Contenedor del timer */
.timer-container {
  margin-top: 20px;
  display: inline-block; /* Aseguramos que el contenido se centre */
}

/* Ajustar el estilo del contador para móviles y desktop */
.timer {
  font-size: 60px;  /* Hacer el timer gigante */
  font-weight: 900;
  color: var(--text); /* Color del contador */
  padding: 0px 40px 30px 40px;
  border-radius: 12px;
  display: inline-block;
  background: transparent; /* Eliminar fondo gris */
  transition: transform 0.5s ease; /* Efecto de movimiento */
}

/* Hacer que el contador se mueva ligeramente */
.timer:hover {
  transform: translateY(-5px);  /* Hace que el contador se mueva hacia arriba cuando el cursor está encima */
}

.countdown-label {
  font-size: 18px;
  color: var(--muted);
  margin-top: 10px;
  font-weight: 700;
}

/* Estilos para dispositivos móviles */
@media (max-width: 768px) {
  /* Ajustes para que el contador sea más pequeño en dispositivos móviles */
  .timer {
    font-size: 40px; /* Reducir el tamaño del contador */
    padding: 20px 40px;
  }

  .countdown-label {
    font-size: 16px; /* Ajustar el tamaño de la etiqueta en móviles */
  }

  /* El tamaño del botón también se ajusta en móviles */
  .btn {
    font-size: 16px; /* Ajustar el tamaño del botón */
    padding: 10px 20px;
  }
}
