/* =====================================================================
   EDU TORREGROSA — ISLA 3D · interfaz (HUD + modales)
   Temas: wp (día) / dark (noche) — controlados por [data-theme] en <html>
   ===================================================================== */

@font-face{font-family:'Poppins';src:url('/assets/fonts/poppins-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Poppins';src:url('/assets/fonts/poppins-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('/assets/fonts/space-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'PressStart';src:url('/assets/fonts/press-start-2p.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'VT323';src:url('/assets/fonts/vt323.woff2') format('woff2');font-weight:400;font-display:swap}

:root{
  --isl-font: 'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;
  --isl-head: 'Space Grotesk','Poppins',sans-serif;
  --isl-arcade: 'PressStart',monospace;
  --isl-pixel: 'VT323',monospace;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;overflow:hidden;background:#0a0a0f}
body{font-family:var(--isl-font);color:#fff;-webkit-text-size-adjust:100%}

/* ---- canvas a pantalla completa ---- */
#scene{position:fixed;inset:0;width:100%;height:100%;display:block;touch-action:none;cursor:grab}
#scene:active{cursor:grabbing}
body.locked #scene{cursor:none}

/* ---- color de UI según tema ---- */
html[data-theme="wp"]{
  --ui-fg:#1c244b; --ui-fg-dim:#5c6b8a; --ui-accent:#467ff7; --ui-accent2:#d54c06;
  --panel-bg:rgba(255,255,255,.86); --panel-bd:rgba(28,36,75,.14); --panel-sh:0 18px 60px rgba(28,36,75,.28);
  --hud-bg:rgba(255,255,255,.62); --hud-bd:rgba(28,36,75,.16); --reticle:#1c244b;
}
html[data-theme="dark"]{
  --ui-fg:#eef0ff; --ui-fg-dim:#9aa0c0; --ui-accent:#8b5cf6; --ui-accent2:#06ffa5;
  --panel-bg:rgba(16,17,28,.82); --panel-bd:rgba(139,92,246,.4); --panel-sh:0 18px 60px rgba(0,0,0,.6),0 0 40px rgba(139,92,246,.25);
  --hud-bg:rgba(12,13,22,.55); --hud-bd:rgba(139,92,246,.35); --reticle:#06ffa5;
}

/* ===================== LOADER ===================== */
#loader{position:fixed;inset:0;z-index:60;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  background:radial-gradient(circle at 50% 35%,#13213a,#070910);color:#cfe6ff;transition:opacity .8s ease}
#loader.hidden{opacity:0;pointer-events:none}
#loader .l-logo{font-family:var(--isl-arcade);font-size:clamp(13px,3.4vw,22px);letter-spacing:1px;color:#00ff9c;text-shadow:0 0 18px rgba(0,255,156,.55)}
#loader .l-sub{font-size:13px;opacity:.7;letter-spacing:.18em;text-transform:uppercase}
#loader .l-bar{width:min(260px,60vw);height:6px;border-radius:6px;background:rgba(255,255,255,.12);overflow:hidden}
#loader .l-fill{height:100%;width:8%;background:linear-gradient(90deg,#00ff9c,#06b6d4);border-radius:6px;transition:width .35s ease}
#loader .l-tip{font-size:12px;opacity:.72;max-width:340px;text-align:center;line-height:1.55}
/* autor de la cita: destacado en verde para que se vea que es de una persona */
#loader .l-tip .l-by{display:block;margin-top:7px;font-weight:700;color:#00ff9c;letter-spacing:.06em;
  text-shadow:0 0 10px rgba(0,255,156,.4)}

/* ===================== HUD ===================== */
.hud{position:fixed;z-index:30;color:var(--ui-fg)}
.hud a{color:inherit;text-decoration:none}

/* top bar */
#topbar{top:0;left:0;right:0;display:flex;align-items:center;gap:14px;padding:12px 16px;
  background:linear-gradient(to bottom,var(--hud-bg),transparent);backdrop-filter:blur(2px)}
#topbar .brand{font-family:var(--isl-head);font-weight:700;letter-spacing:.04em;font-size:18px;color:var(--ui-fg)}
#topbar .brand span{color:var(--ui-accent)}
#topbar .spacer{flex:1}
.hud-btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 13px;border-radius:11px;cursor:pointer;
  background:var(--hud-bg);border:1px solid var(--hud-bd);color:var(--ui-fg);font-family:var(--isl-font);font-size:13px;font-weight:600;
  backdrop-filter:blur(8px);transition:transform .15s ease,background .2s ease}
.hud-btn:hover{transform:translateY(-1px)}
.hud-btn svg{width:18px;height:18px;fill:currentColor}
.hud-icononly{padding:0;width:38px;justify-content:center}

/* social row */
#social{display:flex;gap:8px}
/* barra de iconos centrada en la parte superior (en pantallas anchas) */
@media(min-width:901px){#social{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}}
#social a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;
  background:var(--hud-bg);border:1px solid var(--hud-bd)}
#social a svg{width:17px;height:17px;fill:var(--ui-fg)}
/* birrete: viewBox recortado + algo más grande para centrarlo y darle peso en su contenedor */
#social a.s-grad svg{width:23px;height:23px}
#social a:hover{background:var(--ui-accent);}
#social a:hover svg{fill:#fff}
@media(max-width:760px){#social{display:none}}

/* reticle + prompt */
#reticle{position:fixed;left:50%;top:50%;width:14px;height:14px;transform:translate(-50%,-50%);z-index:25;pointer-events:none;opacity:.85;
  transition:transform .12s ease,opacity .2s ease}
#reticle::before,#reticle::after{content:"";position:absolute;background:var(--reticle);box-shadow:0 0 6px rgba(0,0,0,.4)}
#reticle::before{left:50%;top:0;width:2px;height:100%;transform:translateX(-50%)}
#reticle::after{top:50%;left:0;height:2px;width:100%;transform:translateY(-50%)}
#reticle.active{transform:translate(-50%,-50%) scale(1.7);opacity:1}
#reticle.active::before,#reticle.active::after{background:var(--ui-accent2)}

#prompt{position:fixed;left:50%;top:calc(50% + 30px);transform:translateX(-50%);z-index:25;pointer-events:none;
  padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600;white-space:nowrap;opacity:0;transition:opacity .18s ease;
  background:var(--panel-bg);border:1px solid var(--panel-bd);color:var(--ui-fg);box-shadow:var(--panel-sh)}
#prompt.show{opacity:1}
#prompt kbd{font-family:var(--isl-head);background:var(--ui-accent);color:#fff;border-radius:6px;padding:1px 7px;margin:0 2px;font-size:12px}

/* hint bottom */
#hint{left:50%;bottom:16px;transform:translateX(-50%);display:flex;gap:14px;align-items:center;padding:9px 16px;border-radius:12px;
  background:var(--hud-bg);border:1px solid var(--hud-bd);backdrop-filter:blur(8px);font-size:12.5px;color:var(--ui-fg);
  box-shadow:0 6px 20px rgba(0,0,0,.18);transition:opacity .4s ease}
#hint b{font-family:var(--isl-head)}
#hint .k{display:inline-block;min-width:20px;text-align:center;background:var(--panel-bg);border:1px solid var(--panel-bd);
  border-radius:5px;padding:1px 5px;margin:0 1px;font-weight:700}
#hint.fade{opacity:0;pointer-events:none}
@media(max-width:760px){#hint{display:none}}

/* compass / progress of discovery */
/* barra de progreso de descubrimientos (sin texto): se llena, fluye y cambia de color */
#discover{position:fixed;bottom:18px;right:16px;z-index:24;display:flex;align-items:center;
  background:var(--hud-bg);border:1px solid var(--hud-bd);border-radius:12px;padding:7px 10px;backdrop-filter:blur(8px);
  box-shadow:0 6px 20px rgba(0,0,0,.18)}
#discover .dc-track{position:relative;width:172px;height:13px;border-radius:7px;overflow:hidden;
  background:rgba(0,0,0,.34);border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 3px rgba(0,0,0,.45)}
#discover .dc-fill{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:inherit;
  background:linear-gradient(90deg,var(--dc-c1,#ff5f57),var(--dc-c2,#ffd24a));background-size:220% 100%;
  animation:dcFlow 2.6s linear infinite;box-shadow:0 0 10px -1px var(--dc-c2,#ffd24a);
  transition:width .65s cubic-bezier(.2,.85,.2,1)}
@keyframes dcFlow{from{background-position:0 0}to{background-position:220% 0}}
#discover .dc-fill::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.6) 50%,transparent 65%);
  transform:translateX(-130%);animation:dcShine 2.8s ease-in-out infinite}
@keyframes dcShine{0%{transform:translateX(-130%)}55%,100%{transform:translateX(240%)}}
#discover .dc-ticks{position:absolute;inset:0;pointer-events:none;border-radius:inherit}
#discover.dc-bump{animation:dcBump .5s ease}
@keyframes dcBump{0%{transform:scale(1)}35%{transform:scale(1.09)}100%{transform:scale(1)}}
#discover.dc-done .dc-fill{background:linear-gradient(90deg,#ffd24a,#7CFFB0,#30c0ff,#b46bff,#ff5f8a,#ffd24a);
  background-size:300% 100%;animation:dcRainbow 2.4s linear infinite;box-shadow:0 0 14px -1px #ffd24a}
@keyframes dcRainbow{from{background-position:0 0}to{background-position:300% 0}}
/* en táctil, los controles ocupan abajo-derecha: subimos la barra para no solaparlos */
@media(pointer:coarse){#discover{bottom:auto;top:64px}}

/* hint de control PC (abajo-izquierda): clic para controlar / Esc para soltar */
#pcHint{position:fixed;left:16px;bottom:16px;z-index:24;font-size:12.5px;font-weight:600;color:var(--ui-fg);
  background:var(--hud-bg);border:1px solid var(--hud-bd);border-radius:10px;padding:7px 12px;backdrop-filter:blur(8px);
  display:flex;align-items:center;gap:7px;box-shadow:0 6px 20px rgba(0,0,0,.18)}
#pcHint b{color:var(--ui-accent2)}
#pcHint kbd{font-family:var(--isl-head);background:var(--panel-bg);border:1px solid var(--panel-bd);border-radius:5px;padding:1px 6px;font-weight:700}
body.touch #pcHint,body.ingame #pcHint{display:none}
@media(pointer:coarse){#pcHint{display:none}}

/* ===================== MENU (puntos de interés) ===================== */
#menu{position:fixed;inset:0;z-index:45;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,6,14,.5);backdrop-filter:blur(7px)}
#menu.open{display:flex}
/* tarjeta con fondo transparente y barra de scroll oculta (sigue desplazándose) */
#menu .menu-card{width:min(1120px,96vw);max-height:90vh;overflow:auto;border-radius:18px;padding:10px 10px 18px;
  background:transparent;border:0;box-shadow:none;color:#fff;
  scrollbar-width:none;-ms-overflow-style:none}
#menu .menu-card::-webkit-scrollbar{width:0;height:0;display:none}
#menu h2{font-family:var(--isl-head);margin:0 0 6px;font-size:26px;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.65)}
#menu p.menu-sub{margin:0 0 18px;color:rgba(255,255,255,.82);font-size:15px;text-shadow:0 1px 8px rgba(0,0,0,.65)}
/* cajas translúcidas y más grandes, aprovechando el ancho disponible */
#menu .menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
#menu .menu-item{text-align:left;cursor:pointer;border-radius:14px;padding:20px;font-family:var(--isl-font);
  background:rgba(10,14,26,.38);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.16);color:#fff;
  box-shadow:0 8px 28px rgba(0,0,0,.28);transition:transform .14s ease,border-color .2s,background .2s}
#menu .menu-item:hover{transform:translateY(-3px);border-color:var(--ui-accent);background:rgba(20,26,46,.5)}
#menu .menu-item .mi-ico{font-size:26px}
#menu .menu-item .mi-t{display:block;font-weight:600;margin-top:8px;font-size:18px;color:#fff}
#menu .menu-item .mi-d{display:block;font-size:13px;color:rgba(255,255,255,.72);margin-top:4px}
#menu .menu-item.found .mi-t::after{content:" ✓";color:var(--ui-accent2)}
#menu .menu-item--game{border-color:#ffd24a66}
#menu .menu-item--game:hover{border-color:#ffd24a}
#menu .menu-item--game .mi-d{color:#ffd24a}
/* secciones del menú (Edu Torregrosa / Mini-juegos) */
#menu .menu-section+.menu-section{margin-top:24px}
#menu .menu-h{font-family:var(--isl-head);font-size:19px;color:#fff;margin:0 0 14px;padding-bottom:9px;
  display:flex;align-items:center;gap:9px;letter-spacing:.5px;
  border-bottom:1px solid rgba(255,255,255,.18);text-shadow:0 1px 8px rgba(0,0,0,.6)}
#menu .menu-h .mh-ico{font-size:21px}
#menu .menu-h .menu-h-tag{font-family:var(--isl-font);font-size:12.5px;font-weight:600;letter-spacing:0;color:#ffd24a;opacity:.92}
#menu .menu-section--games .menu-h{color:#ffe08a;border-bottom-color:#ffd24a3d}
/* los 5 mini-juegos en UNA sola fila (tarjetas compactas, centradas) */
#menu .menu-section--games .menu-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
#menu .menu-section--games .menu-item{padding:14px 8px;text-align:center}
#menu .menu-section--games .menu-item .mi-ico{font-size:28px}
#menu .menu-section--games .menu-item .mi-t{font-size:14px;margin-top:6px}
#menu .menu-section--games .menu-item .mi-d{font-size:10.5px;margin-top:2px}
/* en móvil: los mini-juegos a UNA columna (legibles, como las tarjetas de arriba) */
@media(max-width:760px){
  #menu .menu-section--games .menu-grid{grid-template-columns:1fr;gap:14px}
  #menu .menu-section--games .menu-item{padding:18px;text-align:left}
  #menu .menu-section--games .menu-item .mi-t{font-size:17px;margin-top:8px}
  #menu .menu-section--games .menu-item .mi-d{font-size:12.5px;margin-top:4px}
}

/* ===================== MODAL DE CONTENIDO ===================== */
#modal{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,6,14,.5);backdrop-filter:blur(7px)}
#modal.open{display:flex;animation:mfade .25s ease}
@keyframes mfade{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;width:min(680px,96vw);max-height:88vh;overflow:hidden;border-radius:20px;
  display:flex;flex-direction:column;
  background:var(--panel-bg);border:1px solid var(--panel-bd);box-shadow:var(--panel-sh);color:var(--ui-fg);
  animation:mrise .3s cubic-bezier(.2,.8,.2,1)}
@keyframes mrise{from{transform:translateY(22px) scale(.98);opacity:.6}to{transform:none;opacity:1}}
.modal-scroll{overflow-y:auto;overflow-x:hidden}
.modal-scroll::-webkit-scrollbar{width:10px}
.modal-scroll::-webkit-scrollbar-thumb{background:var(--panel-bd);border-radius:10px}

.modal-head{position:relative;padding:22px 26px 14px;border-bottom:1px solid var(--panel-bd)}
.modal-tag{font-family:var(--isl-arcade);font-size:10px;letter-spacing:1px;color:var(--ui-accent2);text-transform:uppercase}
.modal-card h2{font-family:var(--isl-head);font-size:clamp(20px,3.4vw,28px);margin:8px 0 0;color:var(--ui-fg)}
.modal-body{padding:18px 26px 26px;line-height:1.7;font-size:15.5px;color:var(--ui-fg)}
.modal-body p{margin:0 0 12px}
.modal-body h3{font-family:var(--isl-head);margin:18px 0 6px;font-size:18px;color:var(--ui-fg)}
.modal-body strong{color:var(--ui-fg);font-weight:700}
.modal-body blockquote{margin:14px 0;padding:10px 16px;border-left:3px solid var(--ui-accent);
  background:rgba(127,127,170,.08);border-radius:0 10px 10px 0;font-style:italic;color:var(--ui-fg-dim)}
.modal-body ul{margin:0 0 12px;padding-left:18px}
.modal-body li{margin:4px 0}
.modal-body a:not(.m-btn){color:var(--ui-accent);font-weight:600}

.m-close{position:absolute;top:14px;right:14px;z-index:4;width:38px;height:38px;border-radius:10px;cursor:pointer;border:1px solid var(--panel-bd);
  background:var(--hud-bg);color:var(--ui-fg);font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center}
.m-close:hover{background:var(--ui-accent);color:#fff}

/* botones del modal */
.m-btns{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0}
.m-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:11px;font-family:var(--isl-head);font-weight:700;
  font-size:14px;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:transform .14s ease,box-shadow .2s}
.m-btn.primary{background:var(--ui-accent);color:#fff}
.m-btn.alt{background:var(--ui-accent2);color:#04140d}
html[data-theme="wp"] .m-btn.alt{color:#fff}
.m-btn.ghost{background:transparent;border-color:var(--panel-bd);color:var(--ui-fg)}
.m-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.22)}

/* contadores */
.m-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin:8px 0 4px}
.m-stat{text-align:center;padding:14px 8px;border-radius:13px;background:var(--hud-bg);border:1px solid var(--panel-bd)}
.m-stat .mi{font-size:20px;line-height:1;margin-bottom:3px}
.m-stat .n{font-family:var(--isl-head);font-size:24px;font-weight:700;color:var(--ui-accent)}
.m-stat .l{font-size:11.5px;color:var(--ui-fg-dim);margin-top:3px}

/* pilares apps */
.m-pillars{list-style:none;padding:0;margin:10px 0}
.m-pillars li{display:flex;gap:10px;align-items:baseline;margin:6px 0}
.m-pillars .num{font-family:var(--isl-arcade);font-size:11px;color:var(--ui-accent2)}

/* skill bars */
.m-skill{margin:7px 0}
.m-skill .sh{display:flex;justify-content:space-between;font-size:13px;margin-bottom:3px}
.m-skill .sb{height:8px;border-radius:8px;background:var(--hud-bg);overflow:hidden;border:1px solid var(--panel-bd)}
.m-skill .sf{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--ui-accent),var(--ui-accent2));width:0;transition:width 1s ease}
.m-skillcols{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:8px 18px}
.m-skillcols h3{margin:10px 0 2px}

/* hobbies grid */
.m-hobbies{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-top:8px}
.m-hobby{padding:12px;border-radius:13px;background:var(--hud-bg);border:1px solid var(--panel-bd)}
.m-hobby .hi{font-size:24px}
.m-hobby h4{font-family:var(--isl-head);margin:6px 0 4px;font-size:15px}
.m-hobby p{font-size:13px;color:var(--ui-fg-dim);margin:0}

/* testimonios */
.m-quote{padding:14px 16px;border-radius:13px;background:var(--hud-bg);border:1px solid var(--panel-bd);margin:10px 0}
.m-quote .who{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-weight:700}
.m-quote .who img{width:38px;height:38px;border-radius:50%;object-fit:cover}
.m-quote .txt{font-size:14px;color:var(--ui-fg-dim);font-style:italic;line-height:1.6}

/* testimonios en carrusel (como la web original) */
.m-carousel{position:relative;margin:8px 0 4px;outline:none}
.m-carousel .m-slide{display:none}
.m-carousel .m-slide.active{display:block;animation:mSlideIn .4s ease}
@keyframes mSlideIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.m-carousel .who{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-weight:700;color:var(--ui-fg)}
.m-carousel .who img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--ui-accent2);flex:none}
.m-carousel .txt{font-size:14px;color:var(--ui-fg-dim);font-style:italic;line-height:1.62;background:var(--hud-bg);border:1px solid var(--panel-bd);border-radius:13px;padding:14px 16px}
.m-cnav{display:flex;justify-content:center;gap:10px;margin-top:12px}
.m-cnav button{font-family:var(--isl-arcade);font-size:11px;letter-spacing:1px;padding:7px 13px;border-radius:9px;cursor:pointer;
  background:var(--hud-bg);border:1px solid var(--panel-bd);color:var(--ui-fg)}
.m-cnav button:hover{border-color:var(--ui-accent2);color:var(--ui-accent2)}
.m-dots{display:flex;justify-content:center;gap:7px;margin-top:10px;flex-wrap:wrap}
.m-dots button{width:9px;height:9px;border-radius:50%;border:0;cursor:pointer;background:var(--panel-bd);padding:0}
.m-dots button.active{background:var(--ui-accent2)}

/* video facade */
.m-video{position:relative;aspect-ratio:16/9;border-radius:13px;overflow:hidden;margin:10px 0;background:#000;cursor:pointer;border:1px solid var(--panel-bd)}
.m-video img{width:100%;height:100%;object-fit:cover;opacity:.78}
.m-video .pv{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.m-video .pv::after{content:"";width:0;height:0;border-style:solid;border-width:16px 0 16px 28px;border-color:transparent transparent transparent #fff;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.6));margin-left:6px}
.m-video .pv-ring{position:absolute;width:72px;height:72px;border-radius:50%;background:rgba(213,76,6,.92)}
html[data-theme="dark"] .m-video .pv-ring{background:rgba(139,92,246,.92)}
.m-video iframe{width:100%;height:100%;border:0}
.m-portrait{width:100%;max-width:340px;border-radius:14px;margin:6px auto 12px;display:block;border:1px solid var(--panel-bd)}

/* ===================== MODAL · efectos tipo web normal ===================== */
/* enlaces en línea dentro del texto (no botones) */
.modal-body p a,.modal-body blockquote a{color:var(--ui-accent2);text-decoration:underline;text-underline-offset:2px}

/* aparición de bloques/figuras (reveal) — el JS añade .in al abrir */
.modal-body .reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.modal-body .reveal.reveal--scale{transform:scale(.94)}
.modal-body .reveal.in{opacity:1;transform:none}

/* figura de imagen enmarcada (proyectos) */
.modal-body .m-fig{margin:4px 0 16px;text-align:center}
.modal-body .m-fig img{width:100%;max-width:420px;border-radius:14px;border:1px solid var(--panel-bd);box-shadow:0 12px 30px -18px rgba(0,0,0,.5);background:var(--hud-bg);display:inline-block}
.modal-body .m-fig figcaption{margin-top:8px;font-family:var(--isl-arcade);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--ui-accent2)}

/* rotador "Soy …" con efecto typing (caret parpadeante) */
.modal-body .hero-rotator{font-family:var(--isl-head);font-size:clamp(18px,3.2vw,24px);margin:2px 0 14px;min-height:1.6em;text-align:center}
.modal-body .hero-rotator .soy{color:var(--ui-fg)}
.modal-body .hero-rotator .rot{color:var(--ui-accent2);display:inline-block;border-right:3px solid var(--ui-accent2);padding-right:5px;font-weight:700;vertical-align:bottom}
.modal-body .hero-rotator .rot.typing{animation:islCaret .7s step-end infinite}
@keyframes islCaret{50%{border-color:transparent}}

/* fotos de Edu con barrido diagonal (@property anima la máscara) */
@property --fe-p{syntax:'<percentage>';inherits:true;initial-value:-8%}
.fotos-edu{--fe-p:-8%;position:relative;width:clamp(180px,56%,280px);aspect-ratio:1/1;margin:2px auto 16px;border-radius:18px;overflow:hidden;isolation:isolate;background:var(--hud-bg);box-shadow:0 14px 34px -16px rgba(0,0,0,.5)}
.fotos-edu .fe-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none}
.fotos-edu .fe-front{-webkit-mask-image:linear-gradient(135deg,#000 0%,#000 calc(var(--fe-p) - 4%),transparent calc(var(--fe-p) + 4%),transparent 100%);mask-image:linear-gradient(135deg,#000 0%,#000 calc(var(--fe-p) - 4%),transparent calc(var(--fe-p) + 4%),transparent 100%)}
.fotos-edu .fe-band{position:absolute;inset:-2%;pointer-events:none;opacity:0;z-index:2;background:linear-gradient(135deg,transparent 0%,transparent calc(var(--fe-p) - 6%),rgba(255,255,255,.55) calc(var(--fe-p) - 2%),rgba(255,255,255,.95) calc(var(--fe-p)),rgba(255,255,255,.55) calc(var(--fe-p) + 2%),transparent calc(var(--fe-p) + 6%),transparent 100%);mix-blend-mode:screen;transition:opacity .25s ease}
.fotos-edu::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;border:2px solid var(--ui-accent);opacity:.55;z-index:3}
.fotos-edu.swiping{animation:feSwipe 1.4s cubic-bezier(.7,0,.3,1) forwards}
.fotos-edu.swiping .fe-band{opacity:1}
@keyframes feSwipe{from{--fe-p:-8%}to{--fe-p:108%}}

/* ventana de terminal (modal IA) con autotyping */
.modal-body .terminal{margin:4px 0 14px;border-radius:12px;overflow:hidden;border:1px solid var(--panel-bd);background:#0e1118;
  font-family:'JetBrains Mono','Fira Code',Menlo,Consolas,monospace;box-shadow:0 12px 30px -16px rgba(0,0,0,.6)}
.modal-body .terminal-bar{display:flex;align-items:center;gap:7px;padding:9px 12px;background:#171b26;border-bottom:1px solid #232838}
.modal-body .t-dot{width:11px;height:11px;border-radius:50%;background:#3a4150}
.modal-body .t-dot--r{background:#ff5f57}.modal-body .t-dot--y{background:#febc2e}.modal-body .t-dot--g{background:#28c840}
.modal-body .terminal-name{margin-left:8px;font-size:11px;color:#8b93a7;letter-spacing:.3px;font-family:'JetBrains Mono',Menlo,Consolas,monospace}
.modal-body .terminal-body{padding:14px 16px;font-size:13.5px;line-height:1.65;color:#cbd5e1}
.modal-body .t-row{margin:2px 0;word-break:break-word}
.modal-body .t-prompt{color:#34d399;font-weight:700}
.modal-body .t-arrow{color:#60a5fa}
.modal-body .t-cmd{color:#f8fafc}
.modal-body .t-out{padding:8px 0 6px;transition:opacity .35s ease}
.modal-body .t-out p{margin:0 0 8px;color:#cbd5e1}
.modal-body .t-out strong{color:#fff}
.modal-body [data-terminal] .t-out.t-hide{opacity:0;pointer-events:none}
.modal-body .t-caret{color:#34d399;animation:islBlink .7s step-end infinite;padding-left:2px}
@keyframes islBlink{50%{opacity:0}}

/* fallback accesible: sin animación, todo visible */
@media(prefers-reduced-motion:reduce){.modal-body .reveal{opacity:1;transform:none}}

/* ===================== CONTROLES TÁCTILES (dos joysticks) ===================== */
#touch{position:fixed;inset:0;z-index:20;display:none}
body.touch #touch{display:block}
/* joystick de MOVER (izq) y de MIRAR (der) — sin etiquetas */
#joy,#joyLook{position:absolute;bottom:22px;width:116px;height:116px;border-radius:50%;
  background:var(--hud-bg);border:1px solid var(--hud-bd);touch-action:none}
#joy{left:22px}
#joyLook{right:22px}
#joy .nub,#joyLook .nub{position:absolute;left:50%;top:50%;width:52px;height:52px;border-radius:50%;transform:translate(-50%,-50%);
  box-shadow:0 4px 14px rgba(0,0,0,.3);opacity:.85}
#joy .nub{background:var(--ui-accent)}
#joyLook .nub{background:var(--ui-accent2)}
/* botones de ACCIÓN y SALTO — mismo tamaño y posición relativa sobre su joystick */
#touch .tap-act{position:absolute;width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:var(--hud-bg);border:1px solid var(--hud-bd);backdrop-filter:blur(8px);
  opacity:0;transition:opacity .2s,transform .1s;pointer-events:none;box-shadow:0 6px 18px rgba(0,0,0,.32)}
#touch .tap-act.show{opacity:.96;pointer-events:auto}
#touch .tap-act:active{transform:scale(.9)}
#touch .tap-act svg{width:62%;height:62%;display:block;shape-rendering:crispEdges;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.45))}
#touch .tap-act.act-game{background:var(--ui-accent);border-color:transparent}
/* ACCIÓN: centrada sobre el joystick izquierdo (joy: left:22px, ancho 116 → centro a 80; botón 64 → 48) */
#touch #tapAct{left:48px;right:auto;bottom:150px}
/* SALTO: centrada sobre el joystick de mirar, mismo tamaño y mismo offset */
#touch #jumpBtn{right:48px;left:auto;bottom:150px}
/* el slime bota suavemente para sugerir "salto" sin texto */
#touch #jumpBtn .jslime{animation:jumpBob 2.4s ease-in-out infinite}
@keyframes jumpBob{0%,70%,100%{transform:translateY(0)}80%{transform:translateY(-3px)}90%{transform:translateY(1px)}}
@media(prefers-reduced-motion:reduce){#touch #jumpBtn .jslime{animation:none}}

/* toast */
#toast{position:fixed;left:50%;top:74px;transform:translateX(-50%) translateY(-12px);z-index:35;opacity:0;
  padding:9px 18px;border-radius:12px;font-weight:600;font-size:14px;pointer-events:none;transition:opacity .3s ease,transform .3s ease;
  background:var(--panel-bg);border:1px solid var(--panel-bd);color:var(--ui-fg);box-shadow:var(--panel-sh)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast b{color:var(--ui-accent2)}

/* ===================== MINI-JUEGOS ===================== */
/* reglas del reto */
.g-rules{list-style:none;padding:0;margin:10px 0}
.g-rules li{position:relative;padding:6px 0 6px 24px;font-size:14.5px;border-bottom:1px dashed var(--panel-bd)}
.g-rules li:last-child{border-bottom:0}
.g-rules li::before{content:"▸";position:absolute;left:4px;color:var(--ui-accent2);font-weight:700}

/* ranking */
.lb{list-style:none;counter-reset:none;padding:0;margin:8px 0 0}
.lb li{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:10px;margin-bottom:5px;
  background:var(--hud-bg);border:1px solid var(--panel-bd)}
.lb-pos{width:24px;height:24px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:7px;
  font-family:var(--isl-head);font-weight:700;font-size:13px;background:var(--ui-accent);color:#fff}
.lb li:nth-child(1) .lb-pos{background:#ffd24a;color:#3a2a00}
.lb li:nth-child(2) .lb-pos{background:#cdd3df;color:#2a2f3a}
.lb li:nth-child(3) .lb-pos{background:#e0a062;color:#3a2300}
.lb-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-score{font-family:var(--isl-head);font-weight:700;color:var(--ui-accent2)}
.lb-empty{font-size:14px;color:var(--ui-fg-dim);text-align:center;padding:10px}

/* resultado */
.g-result{text-align:center;margin:6px 0 16px}
.g-result-score{font-family:var(--isl-head);font-weight:700;font-size:64px;line-height:1;color:var(--ui-accent2);
  text-shadow:0 0 24px color-mix(in srgb,var(--ui-accent2) 50%,transparent)}
.g-result-label{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ui-fg-dim)}
.g-save{display:flex;gap:8px;margin:6px 0 14px}
.g-save input{flex:1;min-width:0;padding:11px 14px;border-radius:11px;font-family:var(--isl-font);font-size:15px;
  background:var(--hud-bg);border:1px solid var(--panel-bd);color:var(--ui-fg)}
.g-save input:focus{outline:none;border-color:var(--ui-accent)}
.g-save .m-btn{white-space:nowrap}

/* HUD durante la partida */
#gameHud{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:34;display:none;align-items:center;gap:8px;
  padding:8px 10px;border-radius:14px;background:var(--hud-bg);border:1px solid var(--hud-bd);backdrop-filter:blur(8px);
  box-shadow:0 8px 24px rgba(0,0,0,.25);max-width:96vw;flex-wrap:wrap;justify-content:center}
#gameHud.show{display:flex}
.gh-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:9px;font-size:13.5px;color:var(--ui-fg);
  background:var(--panel-bg);border:1px solid var(--panel-bd)}
.gh-pill b{font-family:var(--isl-head)}
.gh-score{color:var(--ui-fg)}
.gh-score b{color:var(--ui-accent2)}
.gh-exit{margin-left:4px;padding:6px 13px;border-radius:9px;cursor:pointer;font-family:var(--isl-head);font-weight:700;font-size:13px;
  background:var(--ui-accent2);color:#04140d;border:0}
html[data-theme="wp"] .gh-exit{background:var(--ui-accent2);color:#fff}
.gh-exit:hover{filter:brightness(1.08)}

/* modo en-juego: oculta HUD que estorba */
body.ingame #discover,body.ingame #hint,body.ingame #prompt,body.ingame #menuBtn{display:none !important}

/* popups de puntuación */
#popups{position:fixed;inset:0;z-index:33;pointer-events:none}
.popup{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);font-family:var(--isl-head);font-weight:700;
  font-size:26px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.6);animation:pop 0.9s ease-out forwards;white-space:nowrap}
@keyframes pop{0%{opacity:0;transform:translate(-50%,-30%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}
  100%{opacity:0;transform:translate(-50%,-150%) scale(1)}}

/* cuenta atrás */
#countdown{position:fixed;inset:0;z-index:36;display:none;align-items:center;justify-content:center;pointer-events:none}
#countdown.show{display:flex}
#countdown .cd{font-family:var(--isl-arcade);font-size:clamp(48px,14vw,120px);color:#fff;
  text-shadow:0 0 30px var(--ui-accent2),0 6px 20px rgba(0,0,0,.6);animation:cdpop .6s ease-out}
@keyframes cdpop{0%{opacity:0;transform:scale(2)}30%{opacity:1;transform:scale(1)}100%{opacity:.85;transform:scale(.9)}}

/* récord + medallas en tarjetas */
.g-best{display:flex;align-items:center;justify-content:center;gap:10px;margin:4px 0 12px;flex-wrap:wrap;
  font-size:14px;color:var(--ui-fg-dim)}
.g-best b{color:var(--ui-fg)}
.medal{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:700;
  background:var(--hud-bg);border:1px solid var(--panel-bd)}
.medal.bronze{color:#c87b3a} .medal.silver{color:#9aa7bd} .medal.gold{color:#e0a800}
html[data-theme="dark"] .medal.silver{color:#cdd3df}
.medal-row{display:flex;gap:8px;justify-content:center;margin:8px 0 2px;flex-wrap:wrap}
.medal.locked{opacity:.4}
.g-newrecord{text-align:center;font-family:var(--isl-arcade);font-size:13px;color:var(--ui-accent2);
  letter-spacing:1px;margin:8px 0;animation:rec 1s ease infinite alternate}
@keyframes rec{from{opacity:.6}to{opacity:1;text-shadow:0 0 14px var(--ui-accent2)}}
.g-xp{text-align:center;font-size:12.5px;color:var(--ui-fg-dim);margin-top:6px}
.g-xp b{color:var(--ui-accent)}

/* flecha hacia el siguiente aro (contrarreloj) */
/* flecha-guía del contrarreloj: flecha REAL (asta + cabeza) para que la dirección
   se entienda al instante; el JS la rota hacia el siguiente aro. */
#ringArrow{position:fixed;left:50%;top:39%;z-index:32;width:52px;height:52px;margin-left:-26px;margin-top:-26px;
  transform-origin:50% 50%;display:none;pointer-events:none}
#ringArrow svg{display:block;width:100%;height:100%;fill:var(--ui-accent2);
  filter:drop-shadow(0 0 7px var(--ui-accent2)) drop-shadow(0 2px 3px rgba(0,0,0,.65));animation:raPulse 1.1s ease-in-out infinite}
@keyframes raPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.14)}}
body.ingame #ringArrow.show{display:block}

/* ===================================================================
   Tipografía PIXEL estilo Minecraft para todo el HUD / interfaz del juego.
   VT323 tiene poca altura-x, así que se suben un poco los tamaños para que
   se lea bien. El cuerpo de los modales (texto largo) se deja en Poppins.
   =================================================================== */
#topbar .brand, .hud-btn, #prompt, #prompt b, #prompt kbd, #hint, #hint b, #discover,
#gameHud .gh-pill, #gameHud .gh-pill b, .gh-exit,
#menu h2, #menu .menu-h, .menu-sub, #menu .menu-item, .mi-t, .mi-d,
.modal-tag, .modal-card h2, .modal-body h3, .m-btn,
#toast, .popup, .g-result-label, .lb-name, .lb-score, .g-best, .g-xp {
  font-family: var(--isl-pixel) !important; letter-spacing:.4px;
}
#topbar .brand{font-size:23px}
.hud-btn{font-size:16px}
#prompt{font-size:20px;font-weight:400}
#prompt kbd{font-size:16px;padding:0 7px}
#hint{font-size:16px;gap:16px}
#discover{font-size:19px}
#gameHud .gh-pill{font-size:18px}
.gh-exit{font-size:16px}
#menu h2{font-size:26px}
.mi-t{font-size:18px}
.modal-card h2{letter-spacing:.5px}
#toast{font-size:18px}
.popup{font-size:22px}

@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms !important}}

/* =================== Editor de SKIN (vestidor) ===================
   Paleta PROPIA (no depende del tema claro/oscuro de la página): el editor
   es siempre oscuro y profesional. */
.sk-modal{--sk-fg:#e9eef7;--sk-dim:#9aa6bb;--sk-bd:rgba(255,255,255,.12);--sk-bd2:rgba(255,255,255,.22);
  --sk-card1:#1a2030;--sk-card2:#10141f;--sk-soft:rgba(255,255,255,.05);--sk-soft2:rgba(255,255,255,.09);
  --sk-acc:#28e0b0;--sk-acc2:#7c5cff;--sk-ink:#04201a;
  position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 50% 0%,rgba(124,92,255,.16),rgba(4,7,14,.74) 60%);backdrop-filter:blur(8px);
  padding:18px;color:var(--sk-fg);font-family:var(--isl-body,'Poppins',system-ui,sans-serif);animation:skFade .25s ease}
@keyframes skFade{from{opacity:0}to{opacity:1}}
.sk-card{position:relative;width:min(1000px,96vw);height:min(660px,93vh);display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(180deg,var(--sk-card1),var(--sk-card2));border:1px solid var(--sk-bd2);border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(124,92,255,.12),inset 0 1px 0 rgba(255,255,255,.06);
  animation:skPop .42s cubic-bezier(.2,.9,.25,1.12)}
@keyframes skPop{from{opacity:0;transform:translateY(20px) scale(.965)}to{opacity:1;transform:none}}
.sk-x{position:absolute;top:13px;right:15px;z-index:4;width:34px;height:34px;border-radius:10px;border:1px solid var(--sk-bd);
  background:var(--sk-soft);color:var(--sk-fg);font-size:20px;line-height:1;cursor:pointer;transition:background .15s,transform .15s}
.sk-x:hover{background:#ff5f6e;color:#fff;transform:rotate(90deg)}
.sk-title{display:flex;align-items:center;font-family:var(--isl-head);font-size:18px;letter-spacing:.3px;padding:15px 18px;flex:0 0 auto;
  border-bottom:1px solid var(--sk-bd);background:linear-gradient(90deg,rgba(124,92,255,.18),rgba(40,224,176,.1) 70%,transparent)}
.sk-dot{width:11px;height:11px;border-radius:50%;background:var(--sk-acc);margin-right:9px;animation:skDot 2.2s ease-out infinite}
@keyframes skDot{0%{box-shadow:0 0 0 0 rgba(40,224,176,.55)}70%{box-shadow:0 0 0 11px rgba(40,224,176,0)}100%{box-shadow:0 0 0 0 rgba(40,224,176,0)}}
.sk-main{flex:1 1 auto;display:flex;min-height:0}
.sk-preview{position:relative;flex:1 1 auto;min-width:280px;background:radial-gradient(circle at 50% 36%,#2b3a58,#0d1018 72%)}
.sk-preview::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 90px 10px rgba(0,0,0,.5)}
.sk-preview canvas{display:block;width:100%;height:100%;touch-action:none;cursor:grab}
.sk-preview canvas:active{cursor:grabbing}
.sk-pvhint{position:absolute;left:0;right:0;bottom:10px;text-align:center;font-size:11px;color:var(--sk-dim);pointer-events:none;animation:skFloat 3.2s ease-in-out infinite}
@keyframes skFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.sk-panel{flex:0 0 372px;max-width:46%;display:flex;flex-direction:column;border-left:1px solid var(--sk-bd);min-height:0;background:rgba(0,0,0,.12)}
.sk-tabs{display:flex;gap:8px;padding:12px 12px 0}
.sk-tab{flex:1;padding:9px 6px;border-radius:11px 11px 0 0;border:1px solid var(--sk-bd);border-bottom:0;background:var(--sk-soft);
  color:var(--sk-dim);cursor:pointer;font-weight:600;font-size:13px;transition:color .15s,background .2s,box-shadow .2s}
.sk-tab:hover{color:var(--sk-fg)}
.sk-tab.on{color:var(--sk-fg);background:linear-gradient(180deg,rgba(40,224,176,.22),transparent);box-shadow:inset 0 -2px 0 var(--sk-acc)}
.sk-gallery{flex:1;overflow:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}
.sk-skin{display:flex;flex-direction:column;align-items:center;gap:6px;padding:9px;border-radius:13px;border:1px solid var(--sk-bd);
  background:var(--sk-soft);color:var(--sk-fg);cursor:pointer;font-size:11.5px;text-align:center;
  transition:transform .16s,box-shadow .22s,border-color .2s;animation:skItem .36s ease backwards}
@keyframes skItem{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.sk-skin img{width:52px;height:64px;object-fit:contain;image-rendering:pixelated;border-radius:9px;background:#0d1018;box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.sk-skin span{line-height:1.2;color:var(--sk-dim)}
.sk-skin:hover{transform:translateY(-3px);border-color:var(--sk-acc);box-shadow:0 10px 22px -6px rgba(0,0,0,.6)}
.sk-skin.on{border-color:var(--sk-acc);box-shadow:0 0 0 2px var(--sk-acc) inset,0 0 22px -6px var(--sk-acc)}
.sk-skin.on span{color:var(--sk-fg)}
.sk-comm{flex:1;display:flex;flex-direction:column;min-height:0}
.sk-commbar{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 4px;font-size:12.5px;color:var(--sk-dim)}
.sk-mini{padding:6px 11px;border-radius:9px;border:1px solid var(--sk-bd);background:var(--sk-soft);color:var(--sk-fg);cursor:pointer;font-size:12px;transition:background .15s}
.sk-mini:hover{background:var(--sk-soft2)}
.sk-msg{padding:6px 14px;font-size:12.5px;color:var(--sk-dim)}
.sk-comm .sk-gallery{padding-top:6px}
.sk-edit{flex:1;overflow:auto;display:flex;flex-direction:column;gap:11px;padding:12px}
.sk-faces{display:flex;flex-wrap:wrap;gap:5px}
.sk-face{padding:5px 9px;border-radius:9px;border:1px solid var(--sk-bd);background:var(--sk-soft);color:var(--sk-dim);cursor:pointer;font-size:12px;transition:color .15s,background .15s}
.sk-face:hover{color:var(--sk-fg)}
.sk-face.on{background:linear-gradient(90deg,var(--sk-acc),#46e0c0);color:var(--sk-ink);border-color:transparent;font-weight:600}
.sk-canvas{align-self:center;image-rendering:pixelated;border-radius:8px;border:1px solid var(--sk-bd2);background:#0d1018;touch-action:none;cursor:crosshair;max-width:100%;box-shadow:0 8px 24px -10px rgba(0,0,0,.7)}
.sk-tools{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.sk-colorinp{width:40px;height:34px;border:1px solid var(--sk-bd2);border-radius:9px;background:none;cursor:pointer;padding:2px}
.sk-tool{width:38px;height:34px;border-radius:9px;border:1px solid var(--sk-bd);background:var(--sk-soft);color:var(--sk-fg);cursor:pointer;font-size:16px;transition:background .15s,transform .1s}
.sk-tool:hover{background:var(--sk-soft2)}
.sk-tool:active{transform:scale(.92)}
.sk-tool.on{background:linear-gradient(180deg,var(--sk-acc),#46e0c0);color:var(--sk-ink);border-color:transparent}
.sk-tool:disabled{opacity:.4;cursor:default}
.sk-sep{flex:1}
.sk-tlbl{font-size:12px;color:var(--sk-dim)}
.sk-sizes{display:flex;gap:4px}
.sk-size{padding:6px 9px;border-radius:8px;border:1px solid var(--sk-bd);background:var(--sk-soft);color:var(--sk-dim);cursor:pointer;font-size:12px}
.sk-size.on{background:var(--sk-acc2);color:#fff;border-color:transparent}
.sk-swatches{display:flex;flex-wrap:wrap;gap:5px}
.sk-sw{width:21px;height:21px;border-radius:6px;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:transform .1s}
.sk-sw:hover{transform:scale(1.15)}
.sk-sw.on{outline:2px solid var(--sk-fg);outline-offset:1px}
.sk-foot{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--sk-bd);background:rgba(0,0,0,.18)}
.sk-name{flex:0 0 150px;max-width:150px;padding:9px 11px;border-radius:9px;border:1px solid var(--sk-bd2);background:var(--sk-soft);color:var(--sk-fg);font-size:13px}
.sk-name::placeholder{color:var(--sk-dim)}
.sk-status{flex:1;font-size:12px;color:var(--sk-acc);min-height:1em;transition:color .2s}
.sk-status.err{color:#ff8a8a}
.sk-btn{padding:10px 15px;border-radius:11px;border:1px solid var(--sk-bd);cursor:pointer;font-weight:700;font-family:var(--isl-head);font-size:13px;transition:filter .15s,box-shadow .2s,transform .1s}
.sk-btn:active{transform:translateY(1px)}
.sk-btn.primary{background:linear-gradient(90deg,var(--sk-acc),#46e0c0);color:var(--sk-ink);border-color:transparent}
.sk-btn.primary:hover{filter:brightness(1.07);box-shadow:0 8px 22px -6px var(--sk-acc)}
.sk-btn.ghost{background:var(--sk-soft);color:var(--sk-fg)}
.sk-btn.ghost:hover{background:var(--sk-soft2)}
@media(max-width:760px){.sk-main{flex-direction:column}.sk-panel{flex:1 1 auto;max-width:none;border-left:0;border-top:1px solid var(--sk-bd)}.sk-preview{min-height:190px;flex:0 0 36%}.sk-foot{flex-wrap:wrap}.sk-name{flex:1 1 auto;max-width:none}}
@media(prefers-reduced-motion:reduce){.sk-card,.sk-skin,.sk-dot,.sk-pvhint{animation:none}}
