/* ============================================================
   CREATICS · Web Exposición — estilo común
   Base arcade del Comparte APP, acentos marca CREATICS
   (azul oscuro #3d4c8f + rosa #d9006c) y look más educativo.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  /* Marca CREATICS */
  --primary:#d9006c;          /* rosa marca (dosier) */
  --primary-dark:#a8004f;
  --secondary:#3d4c8f;        /* azul marca (dosier) */
  --secondary-dark:#2a3666;

  /* Acentos arcade del Comparte APP */
  --accent:#FFD93D;           /* amarillo */
  --cyan:#4ECDC4;
  --success:#06D6A0;
  --success-dark:#04A37A;
  --danger:#EF476F;

  /* Superficies */
  --bg:#FFF7E1;               /* crema */
  --bg-2:#FFEFD0;
  --card:#FFFFFE;
  --text:#1A1B2E;
  --muted:#6C6F93;
  --border:#1A1B2E;

  /* Tipografía */
  --pixel:'Press Start 2P',monospace;
  --mono:'VT323',monospace;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  /* Sombras chunky */
  --shadow:4px 4px 0 var(--border);
  --shadow-lg:6px 6px 0 var(--border);
  --shadow-sm:3px 3px 0 var(--border);
}

*{box-sizing:border-box}
html,body{
  margin:0;padding:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  min-height:100vh;
}
body{
  background-image:radial-gradient(circle, rgba(26,27,46,.06) 1px, transparent 1px);
  background-size:22px 22px;
}

a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:1180px;margin:0 auto;padding:24px 20px 80px}

/* ============================================================
   HEADER · navegación común
   ============================================================ */
.site-header{
  background:var(--text);
  color:#fff;
  border-bottom:4px solid var(--primary);
  position:sticky;top:0;z-index:50;
}
.site-header .inner{
  max-width:1180px;margin:0 auto;
  padding:8px 20px;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;
}
.site-header .brand{
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;
}
.site-header .brand a{
  display:inline-flex;align-items:center;
  text-decoration:none;color:#fff;
}
.site-header .brand a:hover{text-decoration:none}

/* Header con 2 logos (CREATICS × compu:EDU) — cada uno enlace propio */
.site-header .brand img{
  height:36px;width:auto;display:block;
  background:#fff;padding:3px 6px;
  border:2px solid var(--accent);
  box-shadow:2px 2px 0 var(--accent);
}
.site-header .brand .logo-cjp{
  padding:2px 4px;
  height:50px;width:auto;          /* compu:EDU sube de 44 → 50 */
}
.site-header .brand .logo-x{
  font-family:var(--pixel);font-size:13px;color:var(--accent);
  margin:0 -1px;
  font-weight:bold;
}
.site-header .brand-text{
  display:inline-flex;flex-direction:column;align-items:flex-start;
  line-height:1.15;
}
.site-header .brand-title{
  font-family:var(--pixel);font-size:11px;letter-spacing:1.5px;
  color:var(--accent);
}
.site-header .brand-sub{
  font-size:12.5px;color:#dfe0ee;font-weight:500;       /* +1.5px y más blanco */
  letter-spacing:.2px;display:block;margin-top:3px;
}
.site-header .brand-sub b{color:#fff;font-weight:700}    /* destaca CJP */
@media(max-width:680px){
  .site-header .brand .logo-x{display:none}
  .site-header .brand{gap:6px}
  .site-header .brand img{height:26px}                  /* CREATICS más pequeño en móvil */
  .site-header .brand .logo-cjp{height:32px;width:auto} /* compu:EDU sigue ligeramente mayor */
  .site-header .brand-sub{font-size:11px}
}
@media(max-width:420px){
  .site-header .inner{padding:6px 14px}
  .site-header .brand img{height:22px}
  .site-header .brand .logo-cjp{height:28px}
  .site-header .brand-title{font-size:9px;letter-spacing:1px}
  .site-header .brand-sub{font-size:10.5px}
}
.site-header nav{display:flex;gap:14px;flex-wrap:wrap}
.site-header nav a{
  color:#fff;text-decoration:none;
  font-weight:600;font-size:13px;
  padding:6px 12px;
  border:2px solid transparent;
  transition:all .12s;
}
.site-header nav a:hover{
  border-color:var(--accent);
  color:var(--accent);
  text-decoration:none;
}
.site-header nav a.active{
  background:var(--primary);
  border-color:var(--primary);
}

/* ============================================================
   HERO · cabecera de página
   ============================================================ */
.hero{margin:14px 0 28px;text-align:center}
.hero .tag{
  display:inline-block;
  font-family:var(--pixel);font-size:9px;letter-spacing:1.5px;
  background:var(--secondary);color:#fff;
  padding:5px 10px;
  border:2px solid var(--border);
  box-shadow:var(--shadow-sm);
  margin-bottom:14px;
}
.hero h1{
  font-family:var(--sans);font-size:42px;
  font-weight:800;letter-spacing:-1px;
  margin:6px 0 12px;
  text-shadow:3px 3px 0 var(--accent);
}
.hero .lead{
  color:var(--text);font-size:16px;font-weight:500;
  max-width:640px;margin:0 auto;
}
.hero .lead b{background:var(--accent);padding:1px 6px;font-weight:700}

/* HUD del hero · contadores tipo videojuego */
.hud{
  display:inline-flex;flex-wrap:wrap;
  gap:0;margin-top:18px;
  border:3px solid var(--border);
  background:var(--text);
  box-shadow:var(--shadow);
}
.hud .stat{
  padding:10px 16px;
  display:flex;flex-direction:column;align-items:center;
  min-width:78px;
  border-right:2px solid var(--accent);
}
.hud .stat:last-child{border-right:0}
.hud .stat .num{
  font-family:var(--pixel);font-size:16px;color:var(--accent);
  letter-spacing:.5px;line-height:1;margin-bottom:5px;
}
.hud .stat .lbl{
  font-family:var(--pixel);font-size:7px;letter-spacing:1px;
  color:#fff;line-height:1;
}

/* ============================================================
   FILTROS (galería) · compacto, label izquierda + chips derecha
   ============================================================ */
.filters{
  background:var(--card);
  border:2px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:8px 14px 10px;
  margin-bottom:22px;
}
.filters .filters-head{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;flex-wrap:wrap;
  padding:4px 0 6px;
  border-bottom:1.5px dashed rgba(26,27,46,.18);
  margin-bottom:6px;
}
.filters .filters-head h2{
  font-family:var(--pixel);font-size:9px;
  margin:0;color:var(--muted);letter-spacing:1.5px;
}
.filters .clear{
  font-size:11px;font-weight:600;
  background:transparent;border:1.5px solid var(--border);
  padding:3px 9px;cursor:pointer;
  font-family:var(--sans);color:var(--text);
  letter-spacing:.2px;
  transition:all .1s;
}
.filters .clear:hover{background:var(--accent)}

/* Cada grupo es una FILA: label-izquierda alineada + chips-derecha */
.filter-group{
  display:flex;align-items:flex-start;gap:12px;
  padding:5px 0;
}
.filter-group + .filter-group{
  border-top:1.5px dashed rgba(26,27,46,.12);
}
.filter-group .lbl{
  font-family:var(--pixel);font-size:8px;letter-spacing:.5px;
  color:var(--muted);
  flex-shrink:0;
  width:84px;
  padding-top:6px;
  text-align:right;
}

.chips{display:flex;flex-wrap:wrap;gap:5px;flex:1;min-width:0}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;
  border:1.5px solid var(--border);
  background:#FFFEF7;
  font-size:12px;font-weight:600;
  cursor:pointer;user-select:none;
  transition:all .1s;
  line-height:1.7;
}
.chip:hover{
  background:var(--accent);
  transform:translate(-1px,-1px);
  box-shadow:2px 2px 0 var(--border);
}
.chip.on{
  background:var(--primary);color:#fff;
  box-shadow:2px 2px 0 var(--border);
  transform:translate(-1px,-1px);
}
.chip .count{
  font-size:10px;color:var(--muted);
  background:rgba(0,0,0,.05);padding:0 5px;
  border-radius:99px;
}
.chip.on .count{background:rgba(255,255,255,.25);color:#fff}

/* En móvil estrecho, label arriba a ancho completo */
@media(max-width:560px){
  .filter-group{flex-direction:column;gap:4px}
  .filter-group .lbl{width:auto;text-align:left;padding-top:0}
}

/* ============================================================
   GALERÍA · grid de proyectos
   ============================================================ */
.results-info{
  font-size:14px;color:var(--muted);
  margin-bottom:14px;font-weight:500;
}
.results-info b{color:var(--text);font-weight:700}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:22px;
}

/* Secciones DESTACADOS / MÁS PROYECTOS */
.section-title{
  font-family:var(--pixel);font-size:13px;letter-spacing:1.5px;
  margin:14px 0 18px;
  display:flex;align-items:center;gap:14px;
  color:var(--text);
  text-transform:uppercase;
}
.section-title::before, .section-title::after{
  content:'';height:3px;background:var(--border);flex:1;
}
.section-title.muted{color:var(--muted);font-size:11px;margin-top:38px}
.section-title.muted::before, .section-title.muted::after{
  background:var(--muted);height:2px;
}
.section-title .star{color:var(--primary);font-size:16px}

/* Cards en sección DESTACADOS — sombra amarilla detrás de la negra */
.section-destacados .card-proj{
  box-shadow:5px 5px 0 var(--accent), 9px 9px 0 var(--border);
}
.section-destacados .card-proj:hover{
  transform:translate(-3px,-3px);
  box-shadow:7px 7px 0 var(--accent), 11px 11px 0 var(--border);
}

/* Recuadro de la sección "¿Has probado estos?" */
.featured-box{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:6px 6px 0 var(--border);
  padding:18px 22px 22px;
  margin:6px 0 26px;
  position:relative;
}
.featured-box::before{
  content:'';position:absolute;top:-3px;left:26px;
  width:74px;height:7px;
  background:var(--primary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}

/* 3 columnas en pantallas anchas, responsivo en móvil */
.grid.grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
@media(max-width:880px){
  .grid.grid-3{
    grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  }
}
.featured-box .grid.grid-3{margin-bottom:0}

/* Título · "★ ¿Has probado estos?" */
.section-title.featured-q{
  font-size:13px;letter-spacing:1px;
  color:var(--text);
  margin:0 0 16px;
  display:flex;align-items:center;gap:10px;
}
/* El title heredado tiene líneas decorativas; aquí las desactivamos */
.section-title.featured-q::before,
.section-title.featured-q::after{display:none}
.section-title.featured-q .ico{
  color:var(--primary);font-size:13px;font-weight:800;
  background:var(--accent);padding:4px 10px;
  border:2.5px solid var(--border);
  box-shadow:2px 2px 0 var(--border);
  letter-spacing:0;
  display:inline-block;
}

/* Línea fina separadora entre destacados y listado */
.featured-sep{
  height:0;border:none;
  border-top:2px dashed rgba(26,27,46,.35);
  margin:0 0 24px;
}
.empty{
  text-align:center;padding:60px 20px;
  background:var(--card);
  border:3px dashed var(--border);
  font-size:15px;color:var(--muted);
}
.empty .big{font-size:48px;margin-bottom:10px}

/* === Card de proyecto === */
.card-proj{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;
  overflow:hidden;
  text-decoration:none;color:var(--text);
  transition:all .15s;
  position:relative;
}
.card-proj:hover{
  transform:translate(-3px,-3px);
  box-shadow:7px 7px 0 var(--border);
  text-decoration:none;
}
.card-proj .cover{
  aspect-ratio:16/10;
  background:var(--bg-2) center/cover no-repeat;
  border-bottom:3px solid var(--border);
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.card-proj .cover.placeholder{
  background:repeating-linear-gradient(45deg,#FFEFD0 0 14px,#FFE2A8 14px 28px);
  font-size:62px;
}
.card-proj .ribbon{
  position:absolute;top:10px;left:-3px;
  background:var(--primary);color:#fff;
  font-family:var(--pixel);font-size:8px;letter-spacing:1px;
  padding:5px 10px;
  border:2px solid var(--border);border-left:none;
  box-shadow:3px 3px 0 var(--border);
  z-index:2;
}
.card-proj .ribbon.draft{background:var(--accent);color:var(--text)}
.card-proj .ribbon.featured{
  background:var(--accent);color:var(--text);
  animation:wiggle 2s ease-in-out infinite;
}
@keyframes wiggle{
  0%,100%{transform:rotate(-2deg)}
  50%{transform:rotate(2deg)}
}

/* Mini-power en la cover (tipo HP bar de videojuego) */
.card-proj .cover .mini-pwr{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;gap:1.5px;padding:4px 6px;
  background:rgba(26,27,46,.85);
  border-top:2px solid var(--border);
  height:14px;
}
.card-proj .cover .mini-pwr .seg{
  flex:1;background:rgba(255,255,255,.18);
}
.card-proj .cover .mini-pwr .seg.on{background:var(--success)}
.card-proj .cover .mini-pwr.low .seg.on{background:var(--accent)}
.card-proj .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-proj .title{
  font-size:18px;font-weight:800;line-height:1.2;
  letter-spacing:-.2px;margin:0;
}
.card-proj .author{
  font-size:13px;color:var(--muted);
  font-weight:600;
}
.card-proj .author .by{
  font-family:var(--pixel);font-size:7px;
  color:var(--secondary);letter-spacing:.5px;margin-right:4px;
}
.card-proj .tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto;padding-top:8px}
.card-proj .tag{
  font-size:11px;font-weight:600;padding:3px 7px;
  border:1.5px solid var(--border);
  background:var(--bg-2);
}
.card-proj .tag.tool{background:var(--cyan)}
.card-proj .tag.mobile{background:var(--success)}
.card-proj .tag.exito{
  background:var(--accent);color:var(--text);
  font-weight:700;
  border-color:var(--text);
  box-shadow:2px 2px 0 var(--text);
}

/* Claim en la card · frase corta debajo de las tags */
.card-proj .card-claim{
  font-size:13px;
  color:var(--text);
  margin:8px 0 0;
  font-weight:500;
  font-style:italic;
  line-height:1.4;
  /* trunca a 2 líneas para que no rompa el grid */
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  border-top:1.5px dashed rgba(26,27,46,.18);
  padding-top:8px;
}

/* ============================================================
   FICHA DE PROYECTO
   ============================================================ */

/* Cabecera de la ficha · botón volver compacto + título + autor */
.ficha-head{
  display:flex;align-items:flex-start;gap:18px;
  flex-wrap:wrap;margin-bottom:20px;
}
.ficha-head .btn-back{flex-shrink:0;align-self:flex-start;margin-top:8px}
.ficha-head .ficha-titulo{flex:1;min-width:260px}
.ficha-head h1{
  font-family:var(--sans);font-size:34px;
  font-weight:800;letter-spacing:-.5px;
  margin:0 0 6px;
  text-shadow:3px 3px 0 var(--accent);
}
.ficha-head .author-line{
  color:var(--muted);font-weight:500;font-size:14px;margin:0;
}
.ficha-head .author-line b{color:var(--text)}
.ficha-head .author-line .by{
  font-family:var(--pixel);font-size:8px;
  color:var(--secondary);letter-spacing:1px;margin-right:4px;
}

/* Botón volver compacto (cabecera) */
.btn-back{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--card);color:var(--text);
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  font-family:var(--sans);font-size:13px;font-weight:700;
  text-decoration:none;letter-spacing:.2px;
  transition:all .1s;cursor:pointer;
}
.btn-back:hover{
  background:var(--accent);
  transform:translate(-2px,-2px);
  box-shadow:5px 5px 0 var(--border);
  text-decoration:none;color:var(--text);
}
.btn-back:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--border)}
.btn-back .arrow{font-size:14px;line-height:1}

/* Botón grande retro (al final de la ficha) */
.btn-big{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:16px 30px;
  background:var(--text);color:var(--accent);
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--primary);
  font-family:var(--pixel);font-size:12px;letter-spacing:1.5px;
  font-weight:800;
  text-decoration:none;text-transform:uppercase;
  transition:all .12s;cursor:pointer;
}
.btn-big:hover{
  transform:translate(-2px,-2px);
  box-shadow:7px 7px 0 var(--primary);
  text-decoration:none;color:var(--accent);
}
.btn-big:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--primary)}
.btn-big .arrow{font-size:16px}

/* Visor (player) · ancho completo, alto generoso */
.ficha-player{margin-bottom:24px}
.player{
  background:var(--text);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.player .player-bar{
  background:var(--text);color:var(--accent);
  font-family:var(--pixel);font-size:9px;letter-spacing:1px;
  padding:10px 14px;
  border-bottom:2px solid var(--accent);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  flex-wrap:wrap;
}
.player .player-bar .title-mini{
  color:#fff;font-family:var(--pixel);font-size:9px;
}
.player iframe{
  display:block;width:100%;background:#fff;
  border:0;
}
/* Selectores correctos: misma clase, no descendiente */
.player.player-html iframe{height:78vh;min-height:560px;max-height:900px}
.player.player-scratch iframe{height:72vh;min-height:520px;max-height:780px}
.player .open-ext{
  background:var(--accent);color:var(--text);
  padding:6px 12px;font-size:10px;font-weight:700;
  border:2px solid var(--text);text-decoration:none;
  font-family:var(--pixel);letter-spacing:.5px;
  transition:all .1s;
}
.player .open-ext:hover{background:#fff;text-decoration:none}

/* Grid debajo del visor: textos + sidebar */
.ficha-grid{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(280px,1fr);
  gap:24px;
  align-items:start;
}
@media(max-width:880px){
  .ficha-grid{grid-template-columns:1fr}
}

/* Navegación al final de la ficha */
.ficha-bottom-nav{
  margin:36px 0 20px;
  display:flex;justify-content:center;gap:16px;
  flex-wrap:wrap;
}

/* Estado: solo descarga / solo enlace */
.player-cta{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:36px 24px;
  text-align:center;margin-bottom:22px;
}
.player-cta .icon{font-size:64px;margin-bottom:10px;display:block;line-height:1}
.player-cta h3{margin:0 0 6px;font-size:20px;font-weight:800}
.player-cta p{color:var(--muted);margin:0 0 18px;font-size:14px;font-weight:500}
.player-cta .btn-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* Claim destacado en la ficha · justo encima de "Cómo se juega" */
.proj-claim{
  background:var(--accent);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:18px 24px;
  margin-bottom:20px;
  font-size:19px;
  font-weight:700;
  color:var(--text);
  text-align:center;
  font-family:var(--sans);
  letter-spacing:.2px;
  line-height:1.4;
  position:relative;
}
.proj-claim::before{
  content:'';position:absolute;top:-3px;left:24px;
  width:80px;height:6px;background:var(--primary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}

/* Bloques de texto del proyecto */
.proj-section{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:20px 22px;
  margin-bottom:18px;
  position:relative;
}
.proj-section::before{
  content:'';position:absolute;top:-3px;left:22px;
  width:60px;height:6px;background:var(--accent);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}
.proj-section h2{
  margin:0 0 10px;font-size:17px;font-weight:800;
  display:flex;align-items:center;gap:10px;
}
.proj-section h2 .ico{font-size:22px;line-height:1}
.proj-section p{margin:0;line-height:1.6;font-size:15px}

/* Sidebar (datos del autor + ficha técnica) */
.side-card{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:18px 20px;
  margin-bottom:18px;
}
.side-card h3{
  margin:0 0 12px;font-size:13px;
  font-family:var(--pixel);letter-spacing:1px;
  color:var(--secondary);
}
.kv{display:flex;justify-content:space-between;gap:12px;padding:7px 0;font-size:14px;border-bottom:1.5px dashed rgba(0,0,0,.1)}
.kv:last-child{border:none}
.kv .k{color:var(--muted);font-weight:600;font-size:13px}
.kv .v{font-weight:700;text-align:right;word-break:break-word}
.tag-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.tag-list .tag{
  font-size:11px;font-weight:600;padding:3px 8px;
  border:1.5px solid var(--border);background:var(--bg-2);
}
.tag-list .tag.tool{background:var(--cyan)}
.tag-list .tag.mobile{background:var(--success)}
.tag-list .tag.exito{
  background:var(--accent);color:var(--text);
  font-weight:700;
  border-color:var(--text);
}

/* === Rúbrica · barras segmentadas estilo pixel === */
.rubric-mini{display:flex;flex-direction:column;gap:11px}
.rubric-row{
  display:grid;
  grid-template-columns:74px 1fr 42px;
  align-items:center;gap:10px;
}
.rubric-row .lbl{
  font-size:13px;font-weight:700;color:var(--text);
  letter-spacing:.1px;
}
.rubric-row .pct{
  font-family:var(--pixel);font-size:9px;
  text-align:right;font-weight:700;color:var(--text);
  letter-spacing:.5px;
}
.rubric-row .segs{
  display:flex;gap:2px;
  border:2px solid var(--border);
  background:var(--bg-2);
  padding:2px;
  height:20px;
  image-rendering:pixelated;
}
.rubric-row .seg{
  flex:1;
  background:transparent;
  transition:background .12s;
}
/* Por defecto verde — la mayoría debería estar ≥80% (objetivo CREATICS) */
.rubric-row .seg.on{background:var(--success)}
/* Si la fila está por debajo del 80%, los segmentos llenos van en rosa marca */
.rubric-row.low .seg.on{background:var(--primary)}
/* Si está al 0% le ponemos un sutil "no contestado" */
.rubric-row.zero .pct{color:var(--muted);font-weight:600}

/* === Power level · barra de importancia === */
.power-level{
  margin-top:4px;
  border:2px solid var(--border);
  background:var(--bg-2);
  padding:2px;
  display:flex;gap:2px;
  height:18px;
  image-rendering:pixelated;
}
.power-level .pwr{
  flex:1;background:transparent;
}
.power-level .pwr.on{background:var(--accent)}
.power-level.full .pwr.on{background:var(--success)}
.power-label{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:6px;
  font-family:var(--pixel);font-size:8px;letter-spacing:.5px;
  color:var(--muted);
}
.power-label .num{color:var(--text);font-size:10px}

/* ============================================================
   BOTONES
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;
  background:var(--primary);color:#fff;
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  font-family:var(--pixel);font-size:11px;letter-spacing:1px;
  font-weight:800;
  cursor:pointer;text-decoration:none;
  transition:all .1s;text-transform:uppercase;
}
.btn:hover:not(:disabled){
  transform:translate(-2px,-2px);
  box-shadow:6px 6px 0 var(--border);
  text-decoration:none;color:#fff;
}
.btn:active:not(:disabled){
  transform:translate(2px,2px);
  box-shadow:0 0 0 var(--border);
}
.btn.btn-secondary{background:var(--card);color:var(--text)}
.btn.btn-secondary:hover{color:var(--text)}
.btn.btn-cyan{background:var(--cyan);color:var(--text)}
.btn.btn-cyan:hover{color:var(--text)}
.btn.btn-blue{background:var(--secondary);color:#fff}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  border-top:3px dashed var(--border);
  margin-top:50px;padding:24px 20px;
  text-align:center;font-size:13px;color:var(--muted);
}
.site-footer .pixel{
  font-family:var(--pixel);font-size:8px;letter-spacing:1px;
  color:var(--secondary);margin-bottom:6px;display:block;
}

/* Util */
.creatics-quote{
  text-align:center;margin:18px 0 8px;padding:12px;
  font-family:var(--mono);color:var(--text);font-size:20px;
  letter-spacing:.5px;
  border-top:2.5px dashed var(--border);
  border-bottom:2.5px dashed var(--border);
}
.creatics-quote::before{content:'< ';color:var(--primary);font-weight:700}
.creatics-quote::after{content:' />';color:var(--primary);font-weight:700}

/* ============================================================
   CAPTURAS · galería de imágenes en la ficha
   ============================================================ */
.capturas-section{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:18px 22px 22px;
  margin-bottom:22px;
  position:relative;
}
.capturas-section::before{
  content:'';position:absolute;top:-3px;left:22px;
  width:60px;height:6px;background:var(--accent);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}
.capturas-section h2{
  margin:0 0 14px;font-size:17px;font-weight:800;
  display:flex;align-items:center;gap:10px;
}
.capturas-section h2 .ico{font-size:22px;line-height:1}
.capturas-section h2 .count{
  margin-left:auto;
  font-family:var(--pixel);font-size:9px;letter-spacing:.5px;
  background:var(--text);color:var(--accent);
  padding:4px 9px;
  border:2px solid var(--border);
}
.capturas-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:10px;
}
.captura-thumb{
  aspect-ratio:16/10;
  border:2.5px solid var(--border);
  background:var(--bg-2) center/cover no-repeat;
  cursor:zoom-in;
  transition:all .15s;
  position:relative;
  overflow:hidden;
  padding:0;
  font-family:inherit;
  display:block;
}
.captura-thumb:hover{
  transform:translate(-2px,-2px);
  box-shadow:4px 4px 0 var(--border);
  border-color:var(--primary);
}
.captura-thumb:focus-visible{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--accent),4px 4px 0 var(--border);
}
.captura-thumb .num{
  position:absolute;top:6px;left:6px;
  background:var(--text);color:var(--accent);
  font-family:var(--pixel);font-size:8px;letter-spacing:.5px;
  padding:3px 7px;
  border:2px solid var(--accent);
  z-index:2;
}
.captura-thumb .zoom-hint{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;
  color:#fff;
  background:rgba(26,27,46,.55);
  opacity:0;transition:opacity .12s;
  pointer-events:none;
}
.captura-thumb:hover .zoom-hint,
.captura-thumb:focus-visible .zoom-hint{opacity:1}

/* ============================================================
   LIGHTBOX · modal de imagen ampliada
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  padding:60px 70px;
  animation:lb-fade .15s ease-out;
}
.lightbox[hidden]{display:none}
@keyframes lb-fade{from{opacity:0}to{opacity:1}}
.lightbox .lb-img{
  max-width:100%;max-height:100%;
  border:3px solid var(--accent);
  box-shadow:0 0 0 2px var(--border), 8px 8px 0 var(--border);
  background:var(--text);
  display:block;
  object-fit:contain;
}
.lightbox .lb-btn{
  position:absolute;
  background:var(--text);color:var(--accent);
  border:3px solid var(--accent);
  width:48px;height:48px;
  font-family:var(--pixel);font-size:14px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;
  z-index:2;
  padding:0;
  line-height:1;
}
.lightbox .lb-btn:hover{
  background:var(--primary);color:#fff;border-color:#fff;
}
.lightbox .lb-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px var(--accent);
}
.lightbox .lb-close{top:18px;right:18px}
.lightbox .lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lightbox .lb-next{right:18px;top:50%;transform:translateY(-50%)}
.lightbox .lb-counter{
  position:absolute;bottom:18px;left:50%;
  transform:translateX(-50%);
  font-family:var(--pixel);font-size:10px;letter-spacing:1.5px;
  color:var(--accent);
  background:var(--text);
  padding:7px 14px;
  border:2px solid var(--accent);
  pointer-events:none;
}
.lightbox .lb-hint{
  position:absolute;top:18px;left:18px;
  font-family:var(--pixel);font-size:8px;letter-spacing:.8px;
  color:var(--accent);
  background:rgba(0,0,0,.6);
  padding:5px 10px;
  border:2px solid var(--accent);
  pointer-events:none;
  opacity:.85;
}
@media(max-width:600px){
  .lightbox{padding:60px 14px}
  .lightbox .lb-prev, .lightbox .lb-next{
    width:38px;height:38px;font-size:12px;
  }
  .lightbox .lb-prev{left:6px}
  .lightbox .lb-next{right:6px}
  .lightbox .lb-hint{display:none}
}

/* ============================================================
   MODO ADMIN · edición in-place
   ============================================================ */

/* Barra superior fija (solo en admin) */
.is-admin{padding-top:38px}
.admin-bar{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:var(--primary);color:#fff;
  padding:9px 16px;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  border-bottom:3px solid var(--border);
  box-shadow:0 4px 0 var(--border);
}
.admin-bar .lbl{
  font-family:var(--pixel);font-size:10px;letter-spacing:1.5px;
  display:flex;align-items:center;gap:8px;
}
.admin-bar .lbl::before{content:'⚙'}
.admin-bar .actions{display:flex;gap:8px;flex-wrap:wrap}
.admin-bar a, .admin-bar button{
  font-family:var(--pixel);font-size:9px;letter-spacing:1px;
  background:var(--text);color:var(--accent);
  border:2px solid var(--accent);
  padding:5px 10px;
  cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:5px;
  transition:all .1s;
}
.admin-bar a:hover, .admin-bar button:hover{
  background:var(--accent);color:var(--text);text-decoration:none;
}

/* Indicador flotante de guardado */
.save-status{
  position:fixed;top:52px;right:14px;z-index:201;
  background:var(--text);color:var(--accent);
  border:2.5px solid var(--accent);
  padding:8px 14px;
  font-family:var(--pixel);font-size:9px;letter-spacing:1px;
  box-shadow:3px 3px 0 var(--border);
  opacity:0;pointer-events:none;
  transition:opacity .15s, transform .15s;
  transform:translateY(-6px);
}
.save-status.show{opacity:1;transform:translateY(0)}
.save-status.ok{background:var(--success);color:var(--text);border-color:var(--success-dark)}
.save-status.err{background:var(--danger);color:#fff;border-color:var(--border)}

/* Elementos editables */
.is-admin [data-edit]{
  outline:2px dashed transparent;
  outline-offset:3px;
  transition:outline-color .12s, background .12s;
  cursor:text;
  position:relative;
}
.is-admin [data-edit]:hover{
  outline-color:var(--primary);
  background:rgba(217,0,108,.05);
}
.is-admin [data-edit]:focus, .is-admin [data-edit].editing{
  outline:2px solid var(--primary);
  background:rgba(217,0,108,.08);
}
.is-admin [data-edit]:not(:focus):hover::after{
  content:'✏️';
  position:absolute;top:-14px;right:-6px;
  font-size:13px;
  background:#fff;
  padding:0 4px;
  border:2px solid var(--border);
  pointer-events:none;
  line-height:1.3;
  z-index:5;
}

/* Selects admin (look retro) */
.admin-select{
  font-family:var(--sans);font-weight:700;font-size:13px;
  border:2.5px solid var(--border);
  background:#FFFEF7;color:var(--text);
  padding:5px 10px;border-radius:0;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--border);
}
.admin-select:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--border)}

/* Switch retro */
.admin-switch{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  user-select:none;font-weight:600;font-size:13px;
}
.admin-switch input{display:none}
.admin-switch .track{
  width:36px;height:20px;
  background:#ccc;
  border:2px solid var(--border);
  position:relative;
  transition:background .12s;
  flex-shrink:0;
}
.admin-switch .track::after{
  content:'';position:absolute;top:0;left:0;
  width:14px;height:14px;
  background:#fff;
  border:2px solid var(--border);
  transition:left .12s;
}
.admin-switch input:checked + .track{background:var(--success)}
.admin-switch input:checked + .track::after{left:18px}

/* Toggle estado (publicado/borrador) */
.admin-state-toggle{
  display:flex;
  border:2.5px solid var(--border);
  font-family:var(--pixel);font-size:9px;
  margin-bottom:8px;
}
.admin-state-toggle button{
  flex:1;padding:8px 0;border:0;background:#FFFEF7;
  cursor:pointer;font-family:inherit;font-size:inherit;
  letter-spacing:.5px;transition:all .1s;
}
.admin-state-toggle button + button{border-left:2px solid var(--border)}
.admin-state-toggle button.on{background:var(--accent);color:var(--text);font-weight:bold}
.admin-state-toggle button.on.publicado-on{background:var(--success);color:var(--text)}

/* Slider de importancia */
.admin-importance{
  display:flex;align-items:center;gap:10px;
  margin-top:6px;
}
.admin-importance input[type=range]{flex:1;accent-color:var(--primary)}
.admin-importance .val{
  font-family:var(--pixel);font-size:11px;
  background:var(--text);color:var(--accent);
  padding:4px 8px;border:2px solid var(--border);
  min-width:38px;text-align:center;
}

/* Editar herramientas (chips toggle) */
.tool-edit-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.tool-edit-chips .chip-tool{
  font-size:11px;font-weight:600;padding:4px 9px;
  border:2px solid var(--border);
  background:#FFFEF7;
  cursor:pointer;user-select:none;transition:all .1s;
}
.tool-edit-chips .chip-tool:hover{background:var(--accent)}
.tool-edit-chips .chip-tool.on{background:var(--cyan);font-weight:700}

/* Rúbrica editable: los segmentos son clicables */
.is-admin .rubric-row .seg{cursor:pointer;transition:transform .08s}
.is-admin .rubric-row .seg:hover{transform:scale(1.15)}

/* Card de galería: controles admin */
.is-admin .card-proj{position:relative}
.is-admin .card-proj .admin-card-controls{
  position:absolute;top:8px;right:8px;
  display:flex;gap:5px;
  z-index:4;
}
.is-admin .card-proj .admin-card-controls button{
  background:var(--text);color:var(--accent);
  border:2px solid var(--accent);
  font-family:var(--pixel);font-size:8px;
  padding:5px 8px;cursor:pointer;
  letter-spacing:.5px;
}
.is-admin .card-proj .admin-card-controls button:hover{
  background:var(--primary);color:#fff;border-color:#fff;
}
.is-admin .card-proj .admin-card-controls button.btn-del{
  border-color:var(--danger);color:var(--danger);background:#fff;
}
.is-admin .card-proj .admin-card-controls button.btn-del:hover{
  background:var(--danger);color:#fff;border-color:var(--border);
}
.is-admin .card-proj .admin-card-state{
  position:absolute;top:8px;left:8px;z-index:4;
}
.is-admin .card-proj .admin-card-state button{
  font-family:var(--pixel);font-size:8px;letter-spacing:.5px;
  padding:5px 8px;cursor:pointer;
  border:2px solid var(--border);
}
.is-admin .card-proj .admin-card-state .pub{background:var(--success);color:var(--text)}
.is-admin .card-proj .admin-card-state .bor{background:var(--accent);color:var(--text)}

/* En admin, las cards no navegan al hacer click en los controles internos */

/* Captura con botón eliminar */
.is-admin .captura-thumb .del{
  position:absolute;top:4px;right:4px;z-index:3;
  background:var(--danger);color:#fff;
  border:2px solid var(--border);
  width:24px;height:24px;
  font-family:var(--sans);font-size:13px;font-weight:700;
  cursor:pointer;line-height:1;
  display:none;align-items:center;justify-content:center;
}
.is-admin .captura-thumb:hover .del{display:flex}
.is-admin .captura-thumb .del:hover{background:#000}

/* Botón añadir captura */
.add-captura{
  aspect-ratio:16/10;
  border:2.5px dashed var(--primary);
  background:rgba(217,0,108,.05);
  color:var(--primary);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  gap:6px;cursor:pointer;font-family:var(--sans);font-weight:700;font-size:13px;
  transition:all .12s;
  padding:0;letter-spacing:.3px;
}
.add-captura:hover{
  background:rgba(217,0,108,.12);
  transform:translate(-2px,-2px);
  box-shadow:4px 4px 0 var(--primary);
}
.add-captura .ico{font-size:28px;line-height:1}

/* Cambiar portada (botón en player-bar) */
.player-bar .change-portada{
  background:transparent;color:var(--accent);
  border:2px solid var(--accent);
  font-family:var(--pixel);font-size:8px;
  padding:4px 8px;cursor:pointer;letter-spacing:.5px;
}
.player-bar .change-portada:hover{background:var(--accent);color:var(--text)}

/* Zona de peligro */
.danger-zone{
  margin-top:30px;
  padding:18px 22px;
  border:3px dashed var(--danger);
  background:rgba(239,71,111,.06);
}
.danger-zone h3{
  margin:0 0 8px;color:var(--danger);
  font-family:var(--pixel);font-size:11px;letter-spacing:1.5px;
}
.danger-zone p{margin:0 0 14px;font-size:13px;color:var(--text);font-weight:500}
.danger-zone .btn-delete{
  background:var(--danger);color:#fff;
  border:3px solid var(--border);
  padding:11px 22px;
  font-family:var(--pixel);font-size:10px;letter-spacing:1.5px;
  cursor:pointer;font-weight:800;
  box-shadow:3px 3px 0 var(--border);
  transition:all .12s;
}
.danger-zone .btn-delete:hover{
  transform:translate(-2px,-2px);
  box-shadow:5px 5px 0 var(--border);
}

/* Inputs de texto editables (alias autor, etc.) */
.admin-input{
  font-family:var(--sans);font-weight:700;font-size:14px;
  border:2px solid var(--border);
  background:#FFFEF7;color:var(--text);
  padding:5px 9px;border-radius:0;
  box-shadow:2px 2px 0 var(--border);
  min-width:90px;
}
.admin-input:focus{
  outline:none;
  background:#fff;
  box-shadow:3px 3px 0 var(--primary);
}

/* Mensaje de no-acceso al modo admin (cuando falla auth) */
.admin-error{
  background:var(--card);
  border:3px solid var(--danger);
  box-shadow:5px 5px 0 var(--border);
  padding:24px;margin:30px auto;max-width:480px;
  text-align:center;
}
.admin-error h2{margin:0 0 8px;color:var(--danger);font-size:18px}
.admin-error p{margin:0 0 14px;font-size:14px;color:var(--text)}

/* ============================================================
   MODO SIN DISTRACCIÓN · pantalla completa + ESC 5s para salir
   ============================================================ */

/* Botón ⛶ inyectado en el nav del header */
.site-header nav .df-toggle{
  background:transparent;color:#fff;
  border:2px solid transparent;
  font-family:var(--sans);font-size:16px;font-weight:700;
  padding:6px 10px;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;
  transition:all .12s;
  line-height:1;
}
.site-header nav .df-toggle .ico{font-size:18px;line-height:1}
.site-header nav .df-toggle:hover{
  border-color:var(--accent);
  color:var(--accent);
}

/* Modo activo: ocultar todo lo que distrae */
body.distraction-free .site-header,
body.distraction-free .site-footer,
body.distraction-free .admin-bar,
body.distraction-free .save-status,
body.distraction-free .creatics-quote,
body.distraction-free .filters,
body.distraction-free .results-info,
body.distraction-free .hud,
body.distraction-free .featured-sep,
body.distraction-free .ficha-bottom-nav,
body.distraction-free .danger-zone{
  display:none !important;
}

/* Hero más compacto en modo expo */
body.distraction-free .hero{margin:14px 0 18px}
body.distraction-free .hero .tag,
body.distraction-free .hero .lead{display:none}

/* Quitar el padding-top del modo admin si estaba activo */
body.distraction-free{padding-top:0 !important}

/* Ficha del proyecto: cabecera oculta, visor más alto */
body.distraction-free .ficha-head{display:none}
body.distraction-free .player.player-html iframe{height:88vh;max-height:none}
body.distraction-free .player.player-scratch iframe{height:82vh;max-height:none}

/* Container ocupa más ancho en modo expo */
body.distraction-free .container{
  max-width:1400px;
  padding:14px 20px 30px;
}

/* === Hint inicial: aviso pixel arriba a la derecha === */
.df-hint{
  position:fixed;top:16px;right:16px;z-index:9999;
  background:rgba(0,0,0,.88);
  color:var(--accent);
  border:2.5px solid var(--accent);
  padding:8px 14px;
  font-family:var(--pixel);font-size:9px;letter-spacing:1px;
  pointer-events:none;
  box-shadow:3px 3px 0 var(--border);
  animation:df-hint-anim 5s ease-out forwards;
}
.df-hint b{color:#fff;background:var(--primary);padding:1px 5px;letter-spacing:.5px}
@keyframes df-hint-anim{
  0%   {opacity:0; transform:translateY(-6px)}
  10%  {opacity:1; transform:translateY(0)}
  80%  {opacity:1; transform:translateY(0)}
  100% {opacity:0; transform:translateY(-6px)}
}

/* === Indicador de progreso al mantener ESC === */
.df-esc-progress{
  position:fixed;top:16px;right:16px;z-index:10000;
  background:rgba(0,0,0,.92);
  color:var(--accent);
  border:3px solid var(--accent);
  padding:12px 18px;
  font-family:var(--pixel);font-size:10px;letter-spacing:1.2px;
  box-shadow:4px 4px 0 var(--border);
  min-width:240px;
  display:none;
  pointer-events:none;
}
.df-esc-progress.show{display:block}
.df-esc-progress .lbl{margin-bottom:8px;color:#fff}
.df-esc-progress .lbl b{color:var(--accent)}
.df-esc-progress .bar{
  height:8px;
  background:rgba(255,255,255,.15);
  border:1.5px solid var(--accent);
  position:relative;overflow:hidden;
}
.df-esc-progress .bar-fill{
  height:100%;
  background:repeating-linear-gradient(90deg,
    var(--accent) 0 8px,
    #b89d2f 8px 10px);
  width:0%;
}

/* ============================================================
   CTAs · "Aprende a programar" (banner arriba + ficha al final)
   ============================================================ */

/* === Banner superior · entre el hero y los filtros === */
.cta-banner{
  background:repeating-linear-gradient(45deg,
    var(--accent) 0 28px,
    #FFE680 28px 56px);
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--border);
  padding:18px 24px;
  margin:8px 0 24px;
  display:flex;align-items:center;gap:20px;
  position:relative;
  text-decoration:none;
  color:var(--text);
  transition:all .15s;
}
.cta-banner::before{
  content:'';position:absolute;top:-3px;left:24px;
  width:84px;height:6px;background:var(--primary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}
.cta-banner:hover{
  transform:translate(-2px,-2px);
  box-shadow:7px 7px 0 var(--border);
  text-decoration:none;
}
.cta-banner .icon{
  font-size:54px;line-height:1;flex-shrink:0;
  filter:drop-shadow(2px 2px 0 var(--border));
}
.cta-banner .cta-img{
  width:120px;height:120px;
  object-fit:cover;
  border:3px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  flex-shrink:0;
  background:#fff;
}

/* Stack de 2 imágenes apiladas + badge campamento */
.cta-banner .cta-stack{
  position:relative;
  width:230px;height:175px;
  flex-shrink:0;
  margin:8px 14px 8px 6px;
}
.cta-banner .cta-stack img{
  position:absolute;
  width:185px;height:135px;
  object-fit:cover;
  border:3px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  background:#fff;
}
.cta-banner .cta-stack .cta-stack-back{
  top:0;left:0;
  transform:rotate(-5deg);
  z-index:1;
}
.cta-banner .cta-stack .cta-stack-front{
  top:24px;left:30px;
  transform:rotate(4deg);
  z-index:2;
}
.cta-banner .cta-stack .cta-stack-badge{
  position:absolute;
  bottom:-6px;right:-14px;
  z-index:3;
  background:var(--primary);color:#fff;
  font-family:var(--pixel);font-size:9px;letter-spacing:.8px;
  padding:7px 10px;line-height:1.25;
  border:2.5px solid var(--border);
  box-shadow:2px 2px 0 var(--border);
  transform:rotate(8deg);
  text-align:center;
  white-space:nowrap;
}
.cta-banner:hover .cta-stack .cta-stack-back{transform:rotate(-7deg) translate(-3px,-2px)}
.cta-banner:hover .cta-stack .cta-stack-front{transform:rotate(6deg) translate(2px,-2px)}
.cta-banner:hover .cta-stack .cta-stack-badge{transform:rotate(11deg) scale(1.05)}
.cta-banner .cta-stack img,
.cta-banner .cta-stack .cta-stack-badge{transition:transform .25s}

@media(max-width:680px){
  .cta-banner .cta-stack{
    width:100%;max-width:280px;height:200px;
    margin:0 auto;
  }
  .cta-banner .cta-stack img{
    width:200px;height:150px;
  }
}
.cta-banner .cta-eyebrow{
  display:inline-block;
  font-family:var(--pixel);font-size:8px;letter-spacing:1px;
  background:var(--text);color:var(--accent);
  padding:3px 8px;
  margin-bottom:8px;
}
@media(max-width:680px){
  .cta-banner .cta-img{width:100%;max-width:240px;height:160px}
}
.cta-banner .text{flex:1;min-width:0}
.cta-banner .text h3{
  margin:0 0 4px;font-size:22px;font-weight:800;
  letter-spacing:-.3px;line-height:1.15;
}
.cta-banner .text p{
  margin:0;font-size:14px;font-weight:500;color:var(--text);
}
.cta-banner .text p b{
  background:var(--primary);color:#fff;
  padding:1px 7px;font-weight:700;
}
.cta-banner .btn-cta{
  flex-shrink:0;
  background:var(--primary);color:#fff;
  border:3px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:13px 20px;
  font-family:var(--pixel);font-size:10px;letter-spacing:1.5px;
  font-weight:800;
  text-decoration:none;text-transform:uppercase;
  transition:all .12s;
  display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.cta-banner:hover .btn-cta{background:var(--primary-dark)}

@media(max-width:680px){
  .cta-banner{flex-direction:column;text-align:center;padding:18px}
  .cta-banner::before{left:50%;transform:translateX(-50%)}
}

/* === Bloque ficha grande · al final de la galería y de la ficha === */
.creatics-card{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:6px 6px 0 var(--border);
  margin:36px 0 20px;
  display:grid;
  grid-template-columns:260px 1fr;
  overflow:hidden;
  position:relative;
}
.creatics-card::before{
  content:'';position:absolute;top:-3px;left:24px;
  width:84px;height:6px;background:var(--primary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
  z-index:2;
}
@media(max-width:760px){
  .creatics-card{grid-template-columns:1fr}
}

.creatics-card .left{
  background:var(--text);
  color:var(--accent);
  padding:30px 24px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;
  text-align:center;
  border-right:3px solid var(--border);
  position:relative;
  background-image:radial-gradient(circle, rgba(255,217,61,.08) 1px, transparent 1px);
  background-size:18px 18px;
}
@media(max-width:760px){
  .creatics-card .left{border-right:0;border-bottom:3px solid var(--border)}
}
.creatics-card .left img{
  width:100%;max-width:180px;
  background:#fff;padding:12px;
  border:3px solid var(--accent);
  box-shadow:4px 4px 0 var(--accent);
}

/* Variante con foto: foto a tamaño completo + overlay con logo encima */
.creatics-card .left.has-photo{
  padding:0;position:relative;overflow:hidden;
  background:var(--text);
}
.creatics-card .left.has-photo .photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  background:none;padding:0;border:0;box-shadow:none;
  max-width:none;
  filter:saturate(.92);
}
.creatics-card .left.has-photo .left-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,
    rgba(26,27,46,.05) 0%,
    rgba(26,27,46,.45) 55%,
    rgba(26,27,46,.92) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;align-items:center;
  padding:18px;gap:10px;
  text-align:center;
}
.creatics-card .left.has-photo .logo{
  width:65%;max-width:140px;
  background:#fff;padding:8px;
  border:2.5px solid var(--accent);
  box-shadow:3px 3px 0 var(--accent);
  position:relative;
  max-height:none;
}
.creatics-card .left.has-photo .pixel-tag{
  font-family:var(--pixel);font-size:8px;letter-spacing:.8px;
  color:var(--accent);
  background:rgba(0,0,0,.55);
  padding:4px 9px;
  border:1.5px solid var(--accent);
  position:relative;
}
@media(max-width:760px){
  .creatics-card .left.has-photo{min-height:240px}
}
.creatics-card .left .pixel-label{
  font-family:var(--pixel);font-size:9px;letter-spacing:1.2px;
  color:var(--accent);
  background:rgba(255,255,255,.06);
  padding:5px 10px;
  border:1.5px solid var(--accent);
}
.creatics-card .left .pixel-tag{
  font-family:var(--pixel);font-size:8px;letter-spacing:.8px;
  color:#fff;opacity:.75;
}

.creatics-card .right{
  padding:26px 30px 24px;
}
.creatics-card .right h3{
  margin:0 0 8px;font-size:22px;font-weight:800;
  letter-spacing:-.3px;line-height:1.2;
  text-shadow:2px 2px 0 var(--accent);
}
.creatics-card .right .lead-copy{
  font-size:15px;color:var(--text);margin:0 0 16px;font-weight:500;
  line-height:1.5;
}
.creatics-card .right .lead-copy b{background:var(--accent);padding:1px 5px}
.creatics-card .right ul.points{
  list-style:none;padding:0;margin:0 0 18px;
  display:grid;gap:7px;
}
.creatics-card .right ul.points li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13.5px;font-weight:500;
}
.creatics-card .right ul.points li .ico{
  font-size:18px;flex-shrink:0;line-height:1.2;
  width:22px;text-align:center;
}
.creatics-card .right .contact{
  display:flex;flex-wrap:wrap;gap:14px;
  font-size:13px;color:var(--muted);
  border-top:2px dashed rgba(26,27,46,.18);
  padding-top:12px;
  font-weight:500;
}
.creatics-card .right .contact .item{
  display:inline-flex;align-items:center;gap:5px;
}
.creatics-card .right .contact .item a{color:var(--text);font-weight:600}
.creatics-card .right .actions{
  margin-top:14px;display:flex;gap:10px;flex-wrap:wrap;
}

/* === Footer CTA === */
.site-footer .footer-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--text);color:var(--accent);
  border:3px solid var(--border);
  box-shadow:3px 3px 0 var(--primary);
  padding:10px 18px;
  font-family:var(--pixel);font-size:10px;letter-spacing:1px;
  text-decoration:none;
  transition:all .12s;
  margin:14px auto 16px;
}
.site-footer .footer-cta:hover{
  transform:translate(-2px,-2px);
  box-shadow:5px 5px 0 var(--primary);
  background:var(--primary);color:#fff;
  text-decoration:none;
}
.site-footer .footer-cta .ico{font-size:14px;line-height:1}

/* En modo sin distracción, ocultar también los CTA */
body.distraction-free .cta-banner,
body.distraction-free .creatics-card,
body.distraction-free .probar{display:none !important}

/* ============================================================
   "¿CÓMO LO QUIERES PROBAR?" · 3 botones de modo principal
   ============================================================ */
.probar{
  margin:6px 0 22px;
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--secondary);
  padding:18px 20px;
  position:relative;
}
.probar::before{
  content:'';position:absolute;top:-3px;left:24px;
  width:84px;height:6px;background:var(--secondary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}
.probar .probar-title{
  font-family:var(--pixel);font-size:11px;letter-spacing:1.5px;
  color:var(--text);
  margin:0 0 14px;
  display:flex;align-items:center;gap:10px;
}
.probar .probar-title .badge{
  background:var(--secondary);color:#fff;
  padding:4px 8px;
  border:2px solid var(--border);
  font-size:9px;letter-spacing:1px;
  box-shadow:2px 2px 0 var(--border);
}

.probar-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
@media(max-width:680px){.probar-grid{grid-template-columns:1fr}}

.probar-btn{
  background:#FFFEF7;color:var(--text);
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:18px 16px 16px;
  cursor:pointer;
  display:flex;flex-direction:column;align-items:flex-start;gap:5px;
  transition:all .12s;
  text-align:left;
  font-family:var(--sans);
  position:relative;
  overflow:hidden;
}
.probar-btn:hover{
  transform:translate(-2px,-2px);
  box-shadow:5px 5px 0 var(--border);
  background:var(--accent);
}
.probar-btn:active{
  transform:translate(2px,2px);
  box-shadow:1px 1px 0 var(--border);
}
.probar-btn .ico{
  font-size:42px;line-height:1;
  filter:drop-shadow(2px 2px 0 var(--border));
}
.probar-btn .lbl{
  font-family:var(--pixel);font-size:11px;letter-spacing:1px;
  color:var(--text);font-weight:bold;
  margin-top:4px;
}
.probar-btn .sub{
  font-size:13px;color:var(--muted);font-weight:600;
  letter-spacing:.1px;
}
.probar-btn[data-mode="movil"]:hover{background:var(--success);color:var(--text)}
.probar-btn[data-mode="ordenador"]:hover{background:var(--cyan)}
.probar-btn[data-mode="microbit"]:hover{background:#FFD7E5}

.probar-btn .arrow{
  position:absolute;top:14px;right:14px;
  font-family:var(--pixel);font-size:14px;
  color:var(--secondary);opacity:.6;
  transition:transform .12s, opacity .12s;
}
.probar-btn:hover .arrow{
  transform:translate(2px,-2px);
  opacity:1;
}

/* Estado activo · cuando un modo está aplicado */
.probar-btn.active{
  background:var(--primary);color:#fff;
  box-shadow:5px 5px 0 var(--border);
  transform:translate(-2px,-2px);
}
.probar-btn.active .lbl{color:#fff}
.probar-btn.active .sub{color:rgba(255,255,255,.85)}
.probar-btn.active .arrow{color:var(--accent);opacity:1}
.probar-btn.active:hover{background:var(--primary-dark)}

/* Aviso de Scratch Link en fichas micro:bit */
.microbit-warning{
  background:var(--accent);
  border:3px solid var(--border);
  box-shadow:var(--shadow);
  padding:14px 18px;
  margin:0 0 18px;
  display:flex;align-items:flex-start;gap:14px;
  position:relative;
}
.microbit-warning::before{
  content:'';position:absolute;top:-3px;left:18px;
  width:60px;height:6px;background:var(--primary);
  border-left:3px solid var(--border);
  border-right:3px solid var(--border);
}
.microbit-warning .ico{font-size:32px;line-height:1;flex-shrink:0}
.microbit-warning .text{flex:1;min-width:0}
.microbit-warning h4{margin:0 0 4px;font-size:15px;font-weight:800}
.microbit-warning p{margin:0;font-size:13.5px;font-weight:500;line-height:1.5}
.microbit-warning a{color:var(--primary);font-weight:700;text-decoration:underline}
.microbit-warning a:hover{color:var(--primary-dark)}

/* ============================================================
   PÁGINA ACTIVIDADES · estilos específicos
   ============================================================ */

/* Hero con composición visual */
.act-hero{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:30px;
  align-items:center;
  margin:14px 0 36px;
}
@media(max-width:760px){.act-hero{grid-template-columns:1fr;gap:20px}}

.act-hero-text .tag{
  display:inline-block;
  font-family:var(--pixel);font-size:9px;letter-spacing:1.5px;
  background:var(--secondary);color:#fff;
  padding:5px 10px;
  border:2px solid var(--border);
  box-shadow:var(--shadow-sm);
  margin-bottom:14px;
}
.act-hero-text h1{
  font-family:var(--sans);font-size:40px;
  font-weight:800;letter-spacing:-1px;
  margin:0 0 12px;line-height:1.1;
  text-shadow:3px 3px 0 var(--accent);
}
.act-hero-text h1 b{
  background:var(--primary);color:#fff;
  padding:0 10px;font-weight:800;
  text-shadow:none;
}
.act-hero-text .lead{
  font-size:16px;color:var(--text);font-weight:500;
  line-height:1.55;margin:0 0 20px;
}
.act-hero-text .lead b{background:var(--accent);padding:1px 6px;font-weight:700}
.act-hero-text .lead a{color:var(--secondary);font-weight:700;text-decoration:underline}
.act-hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Composición visual: tiles + logo central */
.act-hero-visual{
  position:relative;
  aspect-ratio:1/1;
  max-width:360px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(3,1fr);
  gap:8px;
}
.act-hero-visual .visual-tile{
  background:var(--card);
  border:3px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:46px;line-height:1;
  transition:transform .25s;
}
.act-hero-visual .visual-tile:hover{transform:translate(-2px,-2px) rotate(-3deg)}
.act-hero-visual .tile-1{background:var(--accent)}
.act-hero-visual .tile-2{background:var(--cyan)}
.act-hero-visual .tile-3{background:var(--success)}
.act-hero-visual .tile-4{background:#FFD7E5}
.act-hero-visual .tile-5{background:var(--accent)}
.act-hero-visual .tile-6{background:var(--cyan)}

/* Posiciones de las 6 tiles · dejamos hueco central para el logo */
.act-hero-visual .tile-1{grid-area:1/1}
.act-hero-visual .tile-2{grid-area:1/2}
.act-hero-visual .tile-3{grid-area:1/3}
.act-hero-visual .tile-4{grid-area:3/1}
.act-hero-visual .tile-5{grid-area:3/2}
.act-hero-visual .tile-6{grid-area:3/3}

.act-hero-visual .visual-logo{
  grid-area:2/1/3/4;
  width:100%;height:100%;
  background:var(--text);
  padding:18px;
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--primary);
  object-fit:contain;
}

/* Variante con foto real (lleva enlace externo) */
.act-hero-visual:has(.hero-photo-link){
  display:block;
  aspect-ratio:auto;
  max-width:380px;
}
.hero-photo-link{
  display:block;position:relative;
  text-decoration:none;
  overflow:hidden;
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--primary);
  transition:all .15s;
}
.hero-photo-link:hover{
  transform:translate(-3px,-3px);
  box-shadow:7px 7px 0 var(--primary);
  text-decoration:none;
}
.hero-photo{
  display:block;width:100%;height:auto;
}
.hero-photo-cta{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(26,27,46,.92);
  color:var(--accent);
  font-family:var(--pixel);font-size:10px;letter-spacing:1.2px;
  padding:10px 14px;
  text-align:center;
}

/* Big external CTA en actividades.html */
.big-external-cta{
  display:flex;align-items:stretch;gap:0;
  background:var(--text);color:#fff;
  border:3px solid var(--border);
  box-shadow:5px 5px 0 var(--primary);
  margin:8px 0 22px;
  text-decoration:none;
  overflow:hidden;
  transition:all .15s;
}
.big-external-cta:hover{
  transform:translate(-2px,-2px);
  box-shadow:7px 7px 0 var(--primary);
  text-decoration:none;
}
.big-external-cta img{
  width:180px;height:auto;min-height:160px;
  object-fit:cover;
  flex-shrink:0;
  border-right:3px solid var(--border);
  filter:saturate(.95);
}
.big-external-cta .big-cta-text{
  flex:1;min-width:0;
  padding:16px 20px;
  display:flex;flex-direction:column;gap:5px;justify-content:center;
}
.big-external-cta .big-cta-eyebrow{
  font-family:var(--pixel);font-size:8px;letter-spacing:1.2px;
  color:var(--accent);
}
.big-external-cta .big-cta-url{
  font-size:21px;font-weight:800;letter-spacing:-.3px;
  color:#fff;
  word-break:break-word;line-height:1.15;
}
.big-external-cta .big-cta-sub{
  font-size:13px;color:var(--accent);opacity:.85;
}
.big-external-cta .big-cta-arrow{
  font-family:var(--pixel);font-size:32px;color:var(--accent);
  padding:0 22px;flex-shrink:0;
  display:flex;align-items:center;
}
@media(max-width:600px){
  .big-external-cta{flex-direction:column;text-align:center}
  .big-external-cta img{width:100%;height:200px;border-right:0;border-bottom:3px solid var(--border)}
  .big-external-cta .big-cta-arrow{padding:14px 0;justify-content:center}
}

/* Grid de herramientas (Qué aprendes) */
.act-tools-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
}
.act-tool{
  background:var(--bg-2);
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:18px 18px 16px;
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  transition:transform .12s, box-shadow .12s;
}
.act-tool:hover{
  transform:translate(-2px,-2px);
  box-shadow:5px 5px 0 var(--border);
}
.act-tool .tool-emoji{
  font-size:38px;line-height:1;margin-bottom:4px;
  background:var(--accent);
  padding:6px 10px;
  border:2px solid var(--border);
}
.act-tool h4{
  margin:0;font-size:18px;font-weight:800;letter-spacing:-.2px;
}
.act-tool p{
  margin:4px 0 0;font-size:13.5px;color:var(--text);
  font-weight:500;line-height:1.45;
}

/* Etapas (Para quién) */
.act-stages{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:14px;
}
.act-stage{
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:16px 18px;
  background:var(--card);
}
.act-stage .stage-pixel{
  display:inline-block;
  font-family:var(--pixel);font-size:9px;letter-spacing:1.2px;
  background:var(--secondary);color:#fff;
  padding:5px 9px;
  border:2px solid var(--border);
  box-shadow:2px 2px 0 var(--border);
  margin-bottom:10px;
}
.act-stage p{
  margin:0;font-size:14px;color:var(--text);font-weight:500;line-height:1.5;
}
.act-stage p b{color:var(--text)}

/* Cuándo y dónde */
.act-when{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:14px;
}
.act-when .when-item{
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  padding:16px 18px;
  background:var(--card);
}
.act-when .when-item.highlight{
  background:var(--accent);
  box-shadow:4px 4px 0 var(--border);
}
.act-when .when-item h4{
  margin:0 0 6px;font-size:17px;font-weight:800;
}
.act-when .when-item p{
  margin:0;font-size:14px;color:var(--text);font-weight:500;line-height:1.5;
}

/* Apúntate · 3 cards */
.act-apuntate .lead-copy{
  font-size:15px;color:var(--text);margin:0 0 16px;
  font-weight:500;line-height:1.5;
}
.act-apuntate .lead-copy b{background:var(--accent);padding:1px 5px}
.apuntate-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:14px;
}
.apuntate-card{
  background:var(--text);
  color:var(--accent);
  border:3px solid var(--border);
  box-shadow:4px 4px 0 var(--primary);
  padding:20px 18px;
  text-align:center;
  text-decoration:none;
  transition:all .12s;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.apuntate-card:hover{
  transform:translate(-2px,-2px);
  box-shadow:6px 6px 0 var(--primary);
  background:var(--primary);color:#fff;
  text-decoration:none;
}
.apuntate-card .ico{font-size:34px;line-height:1;margin-bottom:4px}
.apuntate-card .lbl{
  font-family:var(--pixel);font-size:9px;letter-spacing:1px;
  opacity:.8;
}
.apuntate-card .val{
  font-family:var(--sans);font-size:15px;font-weight:700;
  color:#fff;line-height:1.3;
}
.apuntate-card:hover .lbl{color:#fff;opacity:1}
