/* Holy Meeple! — design system (coral · dark · Montserrat) */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap');

:root{
  --bg-0:#131418; --bg-1:#181A1F; --bg-2:#20232A; --bg-3:#282C34;
  --line:rgba(255,255,255,.07); --line-2:rgba(255,255,255,.14);
  --t1:#ECEDEF; --t2:#A6ABB4; --t3:#8d939c;
  --acc:#FF5A45; --acc-h:#FF6E5B; --acc-soft:rgba(255,90,69,.16);
  --green:#43AE83; --green-soft:rgba(67,174,131,.16); --violet:#8B5CF6;
  --sans:'Montserrat',system-ui,sans-serif;
  --r:14px; --r-lg:18px; --r-sm:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg-0);color:var(--t1);font-family:var(--sans);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--acc);text-decoration:none}
h1,h2,h3{letter-spacing:-.02em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--acc);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:50px;padding:0 22px;border-radius:var(--r);font-weight:600;font-size:15px;transition:background .15s,transform .1s,opacity .15s}
.btn.primary{background:var(--acc);color:#2a0c06;width:100%}
.btn.primary:hover{background:var(--acc-h)}
.btn.primary:active{transform:scale(.99)}
.btn.primary:disabled{opacity:.5;pointer-events:none}
.btn.ghost{background:var(--bg-2);color:var(--t1);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--bg-3)}

.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:500;color:var(--t2);margin-bottom:7px}
.input{width:100%;height:48px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--t1);padding:0 14px;font-size:16px;font-family:inherit}
.input:focus{border-color:var(--line-2);outline:none}
.input::placeholder{color:var(--t3)}

/* Logo en HTML (no depende de fuente embebida en SVG → no se rompe en mobile) */
.logo{display:inline-flex;align-items:center;gap:7px;line-height:1;white-space:nowrap;text-decoration:none}
.logo>img{height:25px;width:25px;border-radius:6px;flex:0 0 auto;display:block}
.logo .lw{font-size:19px;letter-spacing:-.02em;color:var(--t1);font-weight:300}
.logo .lw b{font-weight:800;color:var(--acc)}
.logo.lg>img{height:38px;width:38px}
.logo.lg .lw{font-size:27px}

.profbtn{width:40px;height:40px;border-radius:50%;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--t2);flex:0 0 auto;overflow:hidden}
.profbtn:hover{background:var(--bg-3);color:var(--t1);border-color:var(--line-2)}
.profbtn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.9}
.profbtn img{width:100%!important;height:100%!important;object-fit:cover;border-radius:50%}

/* Cluster derecho del header: globo de estado + foto, pegados */
.hend{position:relative;display:inline-flex;align-items:center;gap:9px;flex:0 0 auto}
/* Globo de diálogo: la forma misma comunica "estado", sin icono. Texto entero (hasta 2 líneas).
   El ancho lo ajusta el JS (fitMoodBubble) a la línea más larga, así no queda aire. */
.moodbub{position:relative;max-width:230px;padding:7px 12px;border-radius:13px;background:var(--bg-2);border:1px solid var(--line);color:var(--acc);font-size:12.5px;line-height:1.25;font-style:italic;font-weight:600;font-family:inherit;text-align:center;cursor:pointer;white-space:normal}
.moodbub:hover,.moodbub.open{background:var(--bg-3);border-color:var(--line-2)}
.moodbub.empty{color:var(--t3);font-style:normal;font-weight:500}
/* Puntita (tail) del globo apuntando a la foto (a la derecha) */
.moodbub::before,.moodbub::after{content:"";position:absolute;left:100%;top:50%;width:0;height:0;border:8px solid transparent;transform:translateY(-50%)}
.moodbub::before{border-left-color:var(--line)}
.moodbub::after{border-left-color:var(--bg-2);margin-left:-2px}
.moodbub:hover::after,.moodbub.open::after{border-left-color:var(--bg-3)}
/* Menú desplegable para cambiar de estado sin entrar a perfil */
.moodpop{position:absolute;top:calc(100% + 9px);right:0;width:236px;max-width:80vw;background:var(--bg-1);border:1px solid var(--line-2);border-radius:14px;box-shadow:0 16px 44px rgba(0,0,0,.55);padding:6px;z-index:60;max-height:64vh;overflow:auto}
.moodpop .mg{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--t3);padding:9px 10px 4px;font-weight:700}
.moodpop button{display:block;width:100%;text-align:left;background:none;border:0;color:var(--t1);font-size:13.5px;font-family:inherit;padding:9px 10px;border-radius:9px;cursor:pointer}
.moodpop button:hover{background:var(--bg-2)}
.moodpop button.on{color:var(--acc);background:var(--acc-soft);font-weight:600}
.moodpop button.clear{color:var(--t3)}

.topnav{display:flex;gap:4px}
.topnav a{font-size:14px;font-weight:600;color:var(--t2);padding:9px 15px;border-radius:var(--r-sm)}
.topnav a:hover{background:var(--bg-2);color:var(--t1)}
.topnav a.on{color:var(--acc);background:var(--acc-soft)}
.topnav a.nv-cta{background:var(--acc);color:#2a0c06;display:inline-flex;align-items:center;gap:6px}
.topnav a.nv-cta:hover{background:var(--acc-h);color:#2a0c06}
.topnav a.nv-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.4}
@media(max-width:699px){.topnav{display:none}}
@media(min-width:700px){.botnav{display:none!important}}

.botnav{position:fixed;left:0;right:0;bottom:0;min-height:62px;background:rgba(17,18,22,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;z-index:40;padding-bottom:env(safe-area-inset-bottom);transform:translateZ(0)}
.botnav a{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--t3);font-size:10.5px;font-weight:600;padding:9px 0}
.botnav a svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.9}
.botnav a.on{color:var(--acc)}
.botnav a.nv-add{gap:2px}
.botnav a.nv-add .plus{width:46px;height:46px;border-radius:50%;background:var(--acc);color:#2a0c06;display:grid;place-items:center;margin-top:-16px;box-shadow:0 6px 18px rgba(255,90,69,.45)}
.botnav a.nv-add .plus svg{width:25px;height:25px;stroke-width:2.6}
.botnav a.nv-add::after{content:'Jugar';color:var(--acc);font-size:10.5px;font-weight:600}
.has-botnav{padding-bottom:80px}

.livebar{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--acc-soft);border-bottom:1px solid var(--acc);color:var(--acc);font-size:13.5px;font-weight:500;padding:11px 14px}
.livebar b{font-weight:700;text-decoration:underline}
.livebar .lb-ic{width:16px;height:16px;vertical-align:-3px;margin-right:1px}

.pmodal{position:fixed;inset:0;background:rgba(8,9,11,.62);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:120;animation:fadein .2s ease}
.pmodal.open{display:flex}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.pmodal-card{width:min(540px,94vw);height:min(86vh,780px);border-radius:18px;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.65);background:var(--bg-1);border:1px solid var(--line-2)}
.pmodal-card iframe{width:100%;height:100%;border:none;display:block}

.splash{position:fixed;inset:0;background:var(--bg-0);display:grid;place-items:center;z-index:200;transition:opacity .35s ease}
.splash.hide{opacity:0;pointer-events:none}
.splash img{height:34px;animation:meeplePulse 1.2s ease-in-out infinite}
@keyframes meeplePulse{0%,100%{opacity:.5;transform:scale(.97)}50%{opacity:1;transform:scale(1.03)}}

.msg{font-size:13.5px;padding:11px 14px;border-radius:var(--r-sm);margin-bottom:14px;display:none}
.msg.err{display:block;background:rgba(216,95,95,.14);color:#F0A0A0;border:1px solid rgba(216,95,95,.4)}
.msg.ok{display:block;background:var(--green-soft);color:var(--green);border:1px solid rgba(67,174,131,.4)}

/* confeti */
.confetti-root{position:fixed;inset:0;pointer-events:none;z-index:400;overflow:hidden}
.confetti-root i{position:absolute;top:-24px;display:block;opacity:.95;animation-name:confetti-fall;animation-timing-function:cubic-bezier(.2,.6,.4,1);animation-fill-mode:forwards}
@keyframes confetti-fall{0%{transform:translate(0,-10px) rotate(0);opacity:1}100%{transform:translate(var(--xend),105vh) rotate(calc(var(--rot) * 3));opacity:.9}}
@media (prefers-reduced-motion:reduce){.confetti-root{display:none}}

/* cropper de avatar */
.cropov{position:fixed;inset:0;background:rgba(8,9,11,.85);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:300;padding:20px}
.cropcard{width:min(330px,92vw);background:var(--bg-1);border:1px solid var(--line-2);border-radius:20px;padding:22px}
.croph{font-size:16px;font-weight:700;text-align:center;margin-bottom:16px}
.cropstage{position:relative;width:264px;height:264px;margin:0 auto;border-radius:12px;overflow:hidden;background:#000;touch-action:none;cursor:grab}
.cropstage:active{cursor:grabbing}
.cropstage img{position:absolute;top:0;left:0;max-width:none;user-select:none;-webkit-user-drag:none}
.cropmask{position:absolute;inset:0;pointer-events:none;border-radius:50%;box-shadow:0 0 0 999px rgba(10,11,13,.62)}
.cropctrl{margin:18px 4px 4px}
.cropctrl input[type=range]{width:100%;accent-color:var(--acc);cursor:pointer}
.cropacts{display:flex;gap:10px;margin-top:16px}
.cropacts button{flex:1;height:46px;border-radius:var(--r);font-weight:600;font-size:15px}
.cropacts .ccancel{background:var(--bg-2);border:1px solid var(--line);color:var(--t1)} .cropacts .ccancel:hover{background:var(--bg-3)}
.cropacts .cok{background:var(--acc);color:#2a0c06} .cropacts .cok:hover{background:var(--acc-h)}
