/* Devoramundos Battles — estilo mobile-first, dark + neón */
:root{
  --bg:#0c0e1a; --bg2:#12152a; --panel:#171b33; --panel2:#1e2342;
  --green:#9FE870; --green2:#6FCF4E; --gold:#F4C14E; --gold2:#C98A1B;
  --red:#FF4D5E; --blue:#4DA3FF;
  --txt:#ECEEF7; --muted:#9aa0c0; --line:#2a2f54;
  --shadow:0 8px 24px rgba(0,0,0,.45);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,Segoe UI,Roboto,system-ui,sans-serif;
  background:radial-gradient(1200px 600px at 50% -10%,#1b2147 0,var(--bg) 60%);
  color:var(--txt); min-height:100vh; overscroll-behavior:none;
}
b{color:#fff}

/* ===== Onboarding ===== */
.onboard{max-width:480px;margin:0 auto;padding:64px 24px;text-align:center;display:flex;flex-direction:column;gap:16px;align-items:center}
.onboard .coin{font-size:72px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.5));animation:spin 6s linear infinite}
@keyframes spin{to{transform:rotateY(360deg)}}
.onboard h1{font-size:28px;margin:4px 0;line-height:1.12;word-break:break-word}
.onboard h1 span{color:var(--green)}
.onboard p{color:var(--muted);margin:0 0 8px}
.onboard input{width:100%;padding:16px;border-radius:14px;border:1px solid var(--line);background:var(--panel);color:#fff;font-size:18px;text-align:center}
.onboard input:focus{outline:none;border-color:var(--green)}
.onboard small{color:var(--muted);font-size:12px;max-width:320px}
.onboard .age{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}
.onboard .age input{width:auto;accent-color:var(--green)}
.auth-tabs{display:flex;gap:8px;width:100%;margin-bottom:2px}
.auth-tab{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--muted);padding:11px;border-radius:10px;font-weight:700;cursor:pointer;font-family:inherit;font-size:14px}
.auth-tab.active{border-color:var(--green);color:var(--green);background:rgba(159,232,112,.08)}
.onboard .devcode{color:var(--gold);font-size:13px;background:rgba(244,193,78,.1);padding:6px 12px;border-radius:8px}
.onboard a{color:var(--green);cursor:pointer;text-decoration:underline}
.onboard #code{text-align:center;letter-spacing:8px;font-size:22px;font-weight:800}

/* ===== Topbar ===== */
.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;background:rgba(12,14,26,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{font-size:18px;display:flex;align-items:center;gap:6px}
.brand b{color:var(--gold);letter-spacing:1px}
.brand span{color:var(--muted);font-size:13px;margin-left:2px}
.balance{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#231a05;font-weight:800;font-size:15px;font-family:inherit;padding:8px 14px;border:none;border-radius:999px;box-shadow:var(--shadow);cursor:pointer}
.warn{margin-top:8px}
.warn:empty{display:none}

/* ===== Layout ===== */
main{max-width:560px;margin:0 auto;padding:16px 14px 96px;min-height:60vh}
.section{font-size:20px;margin:6px 4px 14px}
.subsec{font-size:15px;color:var(--muted);margin:22px 4px 10px;text-transform:uppercase;letter-spacing:1px}
.hint{color:var(--muted);font-size:14px;margin:0 4px 14px;line-height:1.4}
.hint.small{font-size:12px;margin-top:16px}
.loading{color:var(--muted);text-align:center;padding:40px}
.cards{display:flex;flex-direction:column;gap:14px}

/* ===== Battle card ===== */
.battle-card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow)}
.bc-top{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:13px}
.bc-title{color:var(--muted)}
.badge{font-size:11px;font-weight:800;padding:4px 9px;border-radius:999px;letter-spacing:.5px}
.badge.live{background:rgba(255,77,94,.16);color:var(--red)}
.badge.soon{background:rgba(77,163,255,.16);color:var(--blue)}
.badge.done{background:rgba(255,255,255,.08);color:var(--muted)}
.vs{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin:6px 0 12px}
.fighter{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:14px 8px;text-align:center}
.fighter.b{border-color:#3a2a55}
.fighter .fav{font-weight:800;font-size:16px}
.fighter .odd{margin-top:4px;color:var(--green);font-weight:800}
.fighter.b .odd{color:var(--gold)}
.fighter.win{outline:2px solid var(--green);box-shadow:0 0 16px rgba(159,232,112,.3)}
.vs-mid{font-weight:900;color:var(--muted);font-size:13px}
.scorebar{height:8px;background:linear-gradient(90deg,var(--gold) 0,var(--gold2) 100%);border-radius:999px;overflow:hidden;position:relative;margin-bottom:12px}
.scorebar .fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--green),var(--green2));border-right:3px solid #fff;transition:width .8s ease;border-radius:999px}
.result{text-align:center;color:var(--muted);font-size:14px;padding:6px}

/* ===== Buttons ===== */
.btn{width:100%;padding:14px;border:none;border-radius:14px;font-size:15px;font-weight:800;letter-spacing:.5px;
  background:linear-gradient(135deg,var(--green),var(--green2));color:#0a2008;cursor:pointer;transition:transform .1s}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.big{padding:16px;font-size:16px;margin-top:14px}
.btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.btn.debo{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#231a05}
.btn.debo small{background:#0a2008;color:var(--green);padding:2px 6px;border-radius:6px;font-size:10px;margin-left:4px}

/* ===== Modal ===== */
.modal-bg{position:fixed;inset:0;background:rgba(5,6,14,.7);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:50}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:22px 22px 0 0;width:100%;max-width:560px;padding:20px 18px calc(20px + env(safe-area-inset-bottom));box-shadow:var(--shadow);animation:up .25s ease}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.modal-title{font-weight:800;font-size:17px;margin-bottom:14px;text-align:center}
.pick-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pick{background:var(--panel2);border:2px solid var(--line);border-radius:14px;padding:16px 8px;color:var(--txt);cursor:pointer;text-align:center}
.pick b{display:block;font-size:15px}
.pick span{color:var(--muted);font-size:13px}
.pick.sel{border-color:var(--green);background:rgba(159,232,112,.12)}
.stake-label{margin:16px 0 8px;color:var(--muted);text-align:center}
.chips{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.chip{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px 0;color:var(--txt);font-weight:700;cursor:pointer}
.chip.sel{border-color:var(--gold);background:rgba(244,193,78,.14);color:var(--gold)}
.payout{text-align:center;margin:16px 0 6px;color:var(--muted)}
.payout b{color:var(--green);font-size:18px}
.modal-actions{display:grid;grid-template-columns:1fr 1.4fr;gap:10px;margin-top:8px}

/* ===== Quiniela ===== */
.q-row{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px}
.q-title{font-size:13px;color:var(--muted);margin-bottom:8px}
.q-picks{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.q-pick{background:var(--panel2);border:2px solid var(--line);border-radius:10px;padding:12px 6px;color:var(--txt);font-weight:700;cursor:pointer}
.q-pick small{color:var(--muted);font-weight:600}
.q-pick.sel{border-color:var(--green);background:rgba(159,232,112,.12)}
.q-foot{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:16px;padding:16px;margin-top:16px;text-align:center}
.q-foot>div{margin-bottom:8px}
.q-foot b{color:var(--gold);font-size:17px}

/* ===== Tienda ===== */
.pkg{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.pkg-amt{font-size:22px;font-weight:900;text-align:center;margin-bottom:12px}
.pkg-buy{display:grid;grid-template-columns:1fr 1.3fr;gap:10px}
.pkg-soon{text-align:center;color:var(--gold);font-weight:800;font-size:14px;padding:8px;background:rgba(244,193,78,.08);border-radius:10px}
.store-soon{background:linear-gradient(135deg,#2a2150,#1a2340);border:1px solid var(--gold2);border-radius:14px;padding:14px 16px;margin-bottom:14px;font-size:14px;color:#e9e4ff;line-height:1.35}

/* ===== Ranking ===== */
.raffle{background:linear-gradient(135deg,#2a2150,#1a2340);border:1px solid var(--gold2);border-radius:16px;padding:16px;margin-bottom:16px;text-align:center;box-shadow:var(--shadow)}
.raffle-t{font-size:18px;font-weight:800;margin-bottom:4px}
.raffle p{color:var(--muted);font-size:13px;margin:6px 0}
.raffle-status{color:var(--gold);font-weight:700;margin:10px 0}
.leaders{display:flex;flex-direction:column;gap:8px}
.leader{display:grid;grid-template-columns:48px 1fr auto;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.leader.me{border-color:var(--green);background:rgba(159,232,112,.08)}
.leader .rank{font-weight:900;color:var(--muted)}
.leader .lname{font-weight:700}
.leader .ldia{color:var(--gold);font-weight:800}

/* ===== Perfil ===== */
.profile-bal{font-size:30px;font-weight:900;color:var(--gold);text-align:center;margin:6px 0 8px}
.hist{display:flex;flex-direction:column;gap:8px}
.h-row{display:flex;justify-content:space-between;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:14px}
.h-row.won{border-color:rgba(159,232,112,.5)}
.h-row.lost{opacity:.6}
.h-st{font-weight:800;white-space:nowrap}
.h-row.won .h-st{color:var(--green)}
.empty{color:var(--muted);text-align:center;padding:20px}
#logout{margin-top:24px}

/* ===== Tabbar ===== */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;display:grid;grid-template-columns:repeat(6,1fr);
  background:rgba(12,14,26,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tab{background:none;border:none;color:var(--muted);font-size:10px;font-weight:600;padding:9px 0 11px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px}
.tab span{font-size:18px;filter:grayscale(.4);opacity:.7}
.tab.active{color:var(--green)}
.tab.active span{filter:none;opacity:1}

/* ===== Toast ===== */
.toast{position:fixed;left:50%;bottom:88px;transform:translate(-50%,20px);background:var(--panel2);color:#fff;border:1px solid var(--line);
  padding:12px 18px;border-radius:999px;font-weight:600;font-size:14px;z-index:100;opacity:0;transition:.3s;box-shadow:var(--shadow);max-width:92%;text-align:center}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.err{border-color:var(--red);color:#ffd9dd}
.toast.ok{border-color:var(--green)}

/* ===== Mundo Devora (rancho tycoon) ===== */
.muted{color:var(--muted);font-weight:400;font-size:13px}
.btn.mini{width:auto;padding:8px 12px;font-size:13px}
.ranch-bar{display:flex;justify-content:space-between;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 14px;margin-bottom:12px;font-size:14px}
.btn.collect{background:linear-gradient(135deg,#6f748f,#565b78);color:#fff;margin-bottom:16px}
.btn.collect.ready{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#231a05;animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.03);box-shadow:0 0 26px rgba(244,193,78,.5)}}
.ranch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.ranch-cell{background:linear-gradient(180deg,#23401f,#16241a);border:1px solid #345a33;border-radius:16px;padding:14px 6px;text-align:center;cursor:pointer;position:relative;min-height:98px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:transform .1s}
.ranch-cell:active{transform:scale(.95)}
.ranch-cell.empty{background:var(--panel);border:2px dashed var(--line);color:var(--muted);font-size:26px}
.ranch-cell.empty small{font-size:10px;font-weight:600}
.ranch-cell.ready{border-color:var(--gold);box-shadow:0 0 16px rgba(244,193,78,.4)}
.rc-emoji{font-size:40px;line-height:1;filter:drop-shadow(0 3px 4px rgba(0,0,0,.4))}
.rc-name{font-size:11px;color:#d4eccd;font-weight:700}
.rc-ready{position:absolute;top:-9px;right:-5px;background:var(--gold);color:#231a05;font-weight:800;font-size:11px;padding:2px 7px;border-radius:999px;box-shadow:var(--shadow);animation:pulse 1.3s infinite}
.rc-idle{font-size:13px;opacity:.45}
.ranch-cell.listed{border-color:var(--blue);opacity:.85}
.rc-sale{position:absolute;top:-9px;right:-5px;background:var(--blue);color:#04182e;font-weight:800;font-size:10px;padding:2px 7px;border-radius:999px}
.inv-box{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:16px}
.inv-head{font-weight:700;margin-bottom:10px;font-size:14px}
.inv-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.inv-item{background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px}
.inv-actions{display:flex;flex-direction:column;gap:8px}
.chips.wrap{display:flex;flex-wrap:wrap;gap:8px;grid-template-columns:none}
.chips.wrap .chip{flex:0 0 auto}
.ranch-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ranch-actions .btn{padding:12px 4px;font-size:13px}
.recipe{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px}
.recipe.locked{opacity:.65}
.rec-top{display:flex;align-items:center;gap:8px;font-size:14px;margin-bottom:8px}
.rec-top .si-emoji{font-size:24px}
.rec-top .si-price{margin-left:auto;color:var(--gold);font-weight:800;white-space:nowrap}
.rec-ing{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.ing{font-size:12px;padding:3px 9px;border-radius:999px;background:var(--panel);border:1px solid var(--line)}
.ing.ok{color:var(--green);border-color:rgba(159,232,112,.4)}
.ing.no{color:var(--red);border-color:rgba(255,77,94,.4)}
.rec-btn{width:100%;padding:10px;font-size:13px}
.shop-list{display:flex;flex-direction:column;gap:8px;max-height:56vh;overflow-y:auto;margin:4px 0}
.shop-item{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px 12px;color:var(--txt);cursor:pointer;text-align:left;width:100%}
.shop-item:active{transform:scale(.98)}
.shop-item:disabled{opacity:.5}
.si-emoji{font-size:30px}
.si-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.si-info b{font-size:14px}
.si-info small{color:var(--muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.si-prod{color:var(--green)!important}
.si-price{color:var(--gold);font-weight:800;white-space:nowrap}
.coinfx{position:fixed;bottom:30%;font-size:28px;z-index:200;pointer-events:none;animation:coinup 1.3s ease-out forwards}
@keyframes coinup{0%{transform:translateY(0) scale(.6);opacity:0}20%{opacity:1}100%{transform:translateY(-230px) scale(1.2);opacity:0}}

/* ===== Pulido AAA ===== */
.confetti{position:fixed;top:-12px;width:9px;height:14px;border-radius:2px;z-index:200;pointer-events:none;animation:confall 2.1s cubic-bezier(.3,.6,.5,1) forwards}
@keyframes confall{0%{transform:translateY(0) rotate(0)}100%{transform:translateY(110vh) rotate(720deg);opacity:.15}}
.scorebar::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:translateX(-100%);animation:sweep 2.6s ease-in-out infinite}
@keyframes sweep{0%{transform:translateX(-100%)}60%,100%{transform:translateX(120%)}}
.battle-card{transition:transform .12s}
.battle-card:active{transform:scale(.99)}

/* ===== Mundo 3D caminable (Viejo Oeste) ===== */
.btn.big.enter-world{background:linear-gradient(135deg,#7a5cff,#4da3ff);color:#fff;margin-bottom:14px;letter-spacing:.5px;box-shadow:0 6px 22px rgba(122,92,255,.4)}
.btn.big.enter-world:active{transform:scale(.98)}
#world3d{position:fixed;inset:0;z-index:3000;background:#9ec7e6;overflow:hidden;touch-action:none;user-select:none}
#world3d canvas{display:block;width:100%;height:100%}
.w3d-exit{position:absolute;top:calc(10px + env(safe-area-inset-top));right:12px;z-index:12;background:rgba(10,14,26,.82);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:9px 16px;font-weight:800;font-family:inherit;font-size:14px;cursor:pointer}
.w3d-banner{position:absolute;top:calc(12px + env(safe-area-inset-top));left:50%;transform:translateX(-50%);z-index:10;background:rgba(10,14,26,.8);color:#fff;border:1px solid var(--gold2);border-radius:12px;padding:9px 18px;font-weight:800;font-size:16px;text-align:center;max-width:70%;opacity:0;transition:opacity .2s;pointer-events:none}
.w3d-banner.show{opacity:1}
.w3d-hint{position:absolute;bottom:calc(18px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:8;color:#fff;background:rgba(10,14,26,.55);padding:7px 14px;border-radius:10px;font-size:12px;text-align:center;transition:opacity .4s;max-width:80%}
.w3d-action{position:absolute;bottom:calc(92px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:12;background:linear-gradient(135deg,var(--green),var(--green2));color:#0a2008;border:none;border-radius:999px;padding:15px 30px;font-weight:800;font-family:inherit;font-size:16px;cursor:pointer;box-shadow:var(--shadow);display:none}
.w3d-action.show{display:block;animation:pulse 1.4s ease-in-out infinite}
.w3d-joy{position:absolute;bottom:calc(34px + env(safe-area-inset-bottom));left:30px;width:120px;height:120px;z-index:9;border-radius:50%;background:rgba(255,255,255,.14);border:2px solid rgba(255,255,255,.3);touch-action:none}
.w3d-knob{position:absolute;top:35px;left:35px;width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.6);border:2px solid rgba(255,255,255,.8);transition:transform .03s}

/* ===== Modo construcción ===== */
.w3d-build-toggle{position:absolute;top:calc(10px + env(safe-area-inset-top));left:12px;z-index:12;background:rgba(10,14,26,.82);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:9px 14px;font-weight:800;font-family:inherit;font-size:14px;cursor:pointer}
.w3d-build-toggle.on{background:linear-gradient(135deg,var(--green),var(--green2));color:#0a2008;border-color:var(--green)}
.w3d-voice{position:absolute;top:calc(54px + env(safe-area-inset-top));left:12px;z-index:12;background:rgba(10,14,26,.82);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:9px 14px;font-weight:800;font-family:inherit;font-size:14px;cursor:pointer}
.w3d-voice.on{background:linear-gradient(135deg,#e23b3b,#ff7a45);color:#fff;border-color:#ff7a45}
.w3d-flash{position:absolute;top:calc(12px + env(safe-area-inset-top));left:50%;transform:translateX(-50%);z-index:13;background:rgba(10,14,26,.88);color:#fff;border:1px solid var(--gold2);border-radius:10px;padding:7px 14px;font-weight:700;font-size:13px;text-align:center;max-width:64%;opacity:0;transition:opacity .2s;pointer-events:none}
.w3d-flash.show{opacity:1}
/* Barra de construcción: VERTICAL a la derecha (no tapa el joystick de abajo-izquierda) */
.w3d-buildbar{position:absolute;right:8px;top:calc(58px + env(safe-area-inset-top));bottom:calc(16px + env(safe-area-inset-bottom));z-index:11;width:130px;
  background:rgba(12,14,26,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:14px;padding:8px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.bb-earn{color:var(--gold);font-weight:800;font-size:12px;text-align:center}
.bb-palette{display:flex;flex-direction:column;gap:5px}
.bb-swatch{display:flex;align-items:center;gap:7px;background:var(--panel2);border:2px solid var(--line);border-radius:9px;padding:5px 7px;cursor:pointer;color:#fff;font-family:inherit;text-align:left}
.bb-swatch .sw{width:20px;height:20px;border-radius:5px;flex:0 0 auto;border:1px solid rgba(255,255,255,.3)}
.bb-swatch small{font-size:11px;font-weight:700}
.bb-swatch.sel{border-color:#fff;box-shadow:0 0 8px rgba(255,255,255,.45)}
.bb-tools{display:flex;flex-direction:column;gap:5px;margin-top:2px;border-top:1px solid var(--line);padding-top:6px}
.bb-tool,.bb-missions{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:9px 8px;font-weight:700;font-family:inherit;font-size:13px;cursor:pointer;text-align:center}
.bb-tool.active{background:var(--green);color:#0a2008;border-color:var(--green)}
.bb-missions{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#231a05;border:none}
.w3d-modal{position:fixed;inset:0;z-index:3200;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:16px}
.w3d-modal-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;max-width:420px;width:100%;max-height:80vh;overflow-y:auto}
.w3d-modal-h{font-weight:800;font-size:17px;margin-bottom:6px}
.w3d-earn-big{color:var(--gold);font-weight:800;margin-bottom:12px}
.w3d-mlist{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.w3d-mission{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.w3d-mission.done{opacity:.55}
.wm-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.wm-info small{color:var(--muted);font-size:11px}
.wm-daily{display:inline-block;background:var(--blue);color:#04182e;font-size:9px;font-weight:800;padding:1px 6px;border-radius:999px;vertical-align:middle}
.wm-claim{flex:0 0 auto;background:var(--green);color:#0a2008;border:none;border-radius:999px;padding:9px 14px;font-weight:800;font-family:inherit;font-size:13px;cursor:pointer;white-space:nowrap}
.wm-claim:disabled{background:var(--panel);color:var(--muted);cursor:default}
.w3d-modal-close{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:12px;padding:11px;font-weight:700;font-family:inherit;cursor:pointer}

/* ===== Creador de avatar ===== */
.btn.ghost.custom-avatar{margin-bottom:16px}
#avatarcreator{position:fixed;inset:0;z-index:3100;background:linear-gradient(180deg,#171a3a,#0c0e1a);overflow:hidden;touch-action:none;user-select:none}
.ac-canvas{position:absolute;inset:0;width:100%;height:100%}
.ac-exit{position:absolute;top:calc(10px + env(safe-area-inset-top));right:12px;z-index:13;background:rgba(10,14,26,.82);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;width:40px;height:40px;font-weight:800;font-size:16px;font-family:inherit;cursor:pointer}
.ac-title{position:absolute;top:calc(15px + env(safe-area-inset-top));left:0;right:0;text-align:center;z-index:11;font-weight:800;font-size:18px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6);pointer-events:none}
.ac-panel{position:absolute;left:0;right:0;bottom:calc(74px + env(safe-area-inset-bottom));z-index:11;background:rgba(12,14,26,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line);border-radius:18px 18px 0 0;padding:10px;max-height:44vh;display:flex;flex-direction:column;gap:8px}
.ac-cats{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.ac-cat{flex:0 0 auto;background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:7px 13px;font-weight:700;font-size:13px;font-family:inherit;cursor:pointer;white-space:nowrap}
.ac-cat.active{background:var(--green);color:#0a2008;border-color:var(--green)}
.ac-opts{display:flex;flex-wrap:wrap;gap:8px;overflow-y:auto;align-content:flex-start;padding:2px}
.ac-opt{position:relative;background:var(--panel2);border:2px solid var(--line);border-radius:12px;padding:8px;min-width:62px;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--txt);font-family:inherit;cursor:pointer}
.ac-opt small{font-size:10px;color:var(--muted);font-weight:600}
.ac-opt.sel{border-color:var(--green);background:rgba(159,232,112,.12)}
.ac-opt.sel small{color:#d4eccd}
.ac-sw{width:30px;height:30px;border-radius:50%;border:2px solid rgba(255,255,255,.25)}
.ac-emoji{font-size:26px;line-height:1}
.ac-pro{position:absolute;top:-7px;right:-6px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#231a05;font-weight:800;font-size:10px;padding:1px 6px;border-radius:999px;box-shadow:var(--shadow)}
.ac-opt.shake{animation:acshake .4s}
@keyframes acshake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.ac-go{position:absolute;bottom:calc(14px + env(safe-area-inset-bottom));left:16px;right:16px;width:auto;z-index:12}

/* ===== Barra flotante "Instalar app" (PWA Android) ===== */
#install-bar{position:fixed;left:10px;right:10px;bottom:calc(72px + env(safe-area-inset-bottom));z-index:120;display:flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,#7a5cff,#4da3ff);color:#fff;border-radius:14px;padding:10px 12px;box-shadow:0 8px 24px rgba(0,0,0,.4);font-weight:700;font-size:14px;animation:slideup .3s ease}
@keyframes slideup{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
#install-bar span{flex:1;line-height:1.2}
#install-bar #ib-go{flex:0 0 auto;background:#fff;color:#241a05;font-weight:800;padding:9px 18px;border:none;border-radius:999px;cursor:pointer;font-family:inherit;font-size:14px}
#install-bar #ib-x{flex:0 0 auto;background:transparent;border:none;color:#fff;font-size:16px;cursor:pointer;padding:4px 6px;line-height:1}
