/* ============================================================
   horse.css — Lanna Horse Racing  ·  Emerald Track Edition
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Space+Grotesk:wght@400;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050f08; --bgd:#020804;
  --track:#0d2614; --trackl:#0f3018;
  --em:#22c55e; --eml:#4ade80; --emd:#16a34a;
  --gold:#f4d03f; --goldd:#d4a017;
  --cream:#f0fff4; --red:#f87171;
  --hud-h:48px; --nav-h:54px;
  --font-px:'Press Start 2P',monospace; --font-body:'Space Grotesk',sans-serif;
}
html,body{height:100%;background:var(--bg);color:var(--cream);font-family:var(--font-body);overflow:hidden;user-select:none;-webkit-tap-highlight-color:transparent;}
.px{font-family:var(--font-px)!important}

/* ── HUD ── */
.rh{position:fixed;top:0;left:0;right:0;height:var(--hud-h);background:rgba(2,8,4,.97);border-bottom:2px solid rgba(34,197,94,.4);display:flex;align-items:center;justify-content:space-between;padding:0 14px;z-index:100;gap:8px;box-shadow:0 2px 20px rgba(34,197,94,.15);}
.rh-back{color:var(--eml);font-size:1rem;text-decoration:none;padding:6px;}
.rh-title{font-size:7px;color:var(--eml);letter-spacing:2px;text-shadow:0 0 10px rgba(74,222,128,.4);}
.rh-coins{font-size:8px;color:var(--gold);display:flex;align-items:center;gap:4px;}

/* ── Hero buff badge ── */
.rh-hero-buff{display:flex;align-items:center;gap:3px;padding:2px 7px;border-radius:6px;background:rgba(34,197,94,.15);border:1px solid rgba(74,222,128,.35);flex-shrink:0;}
#rh-hero-emoji{font-size:.9rem;line-height:1;}
.rh-hero-buff-lbl{font-size:7px;color:var(--eml);font-family:var(--font-px);white-space:nowrap;}
/* Oracle hint style */
.horse-card.oracle-hint{border-color:rgba(34,197,94,.7);box-shadow:0 0 16px rgba(34,197,94,.3);}

/* ── Layout ── */
.horse-wrap{position:fixed;top:var(--hud-h);bottom:var(--nav-h);left:0;right:0;display:flex;flex-direction:column;overflow:hidden;}

/* ── Track canvas ── */
.track-area{flex:1;max-height:42vh;position:relative;overflow:hidden;background:linear-gradient(180deg,#0a1a0c,#0d2614);}
#horse-canvas{width:100%;height:100%;display:block;image-rendering:pixelated;}

/* Speed lines overlay */
.track-area::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent 0,transparent 48px,rgba(34,197,94,.03) 48px,rgba(34,197,94,.03) 50px);
  pointer-events:none;
}

/* Race status overlay */
.race-status{position:absolute;top:8px;left:50%;transform:translateX(-50%);background:rgba(2,8,4,.88);border:1px solid rgba(34,197,94,.35);border-radius:8px;padding:5px 14px;font-size:7px;font-family:var(--font-px);color:var(--eml);white-space:nowrap;pointer-events:none;box-shadow:0 0 16px rgba(34,197,94,.12);}

/* ── Bottom panel ── */
.horse-panel{background:rgba(2,8,4,.98);border-top:2px solid rgba(34,197,94,.18);padding:10px 12px;flex-shrink:0;}

/* Horse pick grid */
.horse-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:10px;}
.horse-card{
  padding:9px 5px;border-radius:10px;
  border:1px solid rgba(34,197,94,.12);
  background:linear-gradient(180deg,rgba(13,38,20,.9),rgba(5,15,8,.9));
  text-align:center;cursor:pointer;transition:all .18s;
  position:relative;overflow:hidden;
}
.horse-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,197,94,.05),transparent);opacity:0;transition:opacity .18s;}
.horse-card:hover{border-color:rgba(34,197,94,.4);transform:translateY(-2px);box-shadow:0 4px 16px rgba(34,197,94,.1);}
.horse-card:hover::before{opacity:1;}
.horse-card.selected{background:linear-gradient(180deg,rgba(34,197,94,.18),rgba(22,163,74,.08));border:2px solid rgba(74,222,128,.7);box-shadow:0 0 24px rgba(34,197,94,.4), inset 0 0 12px rgba(34,197,94,.1);}
.horse-card.winner{background:rgba(34,197,94,.15);border-color:var(--eml);box-shadow:0 0 20px rgba(74,222,128,.25);}
.horse-card.loser{opacity:.35;}
.hc-emoji{font-size:1.5rem;}
.hc-name{font-size:.52rem;color:rgba(240,255,244,.65);margin-top:2px;}
.hc-odds{font-size:.6rem;color:var(--gold);font-weight:700;}

/* Bet row */
.bet-row{display:flex;flex-direction:column;align-items:stretch;gap:6px;margin-bottom:10px;}
.bet-lbl{font-size:7px;color:var(--eml);font-family:var(--font-px);flex-shrink:0;}
.bet-btns-scroll{display:flex;gap:5px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;}
.bet-btns-scroll::-webkit-scrollbar{display:none;}
.bet-btn{padding:5px 9px;border-radius:6px;border:1px solid rgba(34,197,94,.25);background:rgba(34,197,94,.06);color:rgba(240,255,244,.65);font-size:.68rem;cursor:pointer;transition:all .15s;font-family:var(--font-body);white-space:nowrap;flex-shrink:0;}
.bet-btn:hover,.bet-btn.active{background:rgba(34,197,94,.18);border-color:rgba(74,222,128,.6);color:var(--eml);}
.bet-custom-wrap{display:flex;gap:5px;}
.bet-custom-input{flex:1;background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.25);border-radius:6px;color:rgba(240,255,244,.9);font-size:.72rem;padding:5px 9px;font-family:var(--font-body);outline:none;}
.bet-custom-input::placeholder{color:rgba(240,255,244,.3);}
.bet-custom-input:focus{border-color:rgba(74,222,128,.6);}
.bet-custom-ok{padding:5px 12px;border-radius:6px;border:1px solid rgba(74,222,128,.4);background:rgba(34,197,94,.12);color:var(--eml);font-size:.8rem;cursor:pointer;transition:all .15s;}
.bet-custom-ok:hover{background:rgba(34,197,94,.25);}

/* Race button */
.race-btn{
  width:100%;padding:13px;border-radius:12px;
  background:linear-gradient(135deg,#16a34a,#22c55e,#4ade80);
  border:none;color:#020804;font-family:var(--font-px);
  font-size:8px;letter-spacing:2px;cursor:pointer;
  transition:all .2s;box-shadow:0 4px 20px rgba(34,197,94,.35);
  font-weight:700;
}
.race-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(34,197,94,.45);}
.race-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none;}

/* Result modal */
.result-overlay{position:fixed;inset:0;background:rgba(2,8,4,.88);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;backdrop-filter:blur(6px);transition:opacity .3s,display .3s allow-discrete;}
@starting-style{.result-overlay{opacity:0;}}
.result-card{
  background:linear-gradient(180deg,rgba(13,38,20,.98),rgba(5,15,8,.98));
  border:2px solid rgba(34,197,94,.4);border-radius:22px;
  padding:30px 24px;text-align:center;max-width:300px;width:100%;
  box-shadow:0 0 60px rgba(34,197,94,.15);
}
.rc-icon{font-size:3.2rem;margin-bottom:14px;}
.rc-title{font-size:10px;font-family:var(--font-px);color:var(--eml);margin-bottom:8px;text-shadow:0 0 14px rgba(74,222,128,.4);}
.rc-desc{font-size:.8rem;color:rgba(240,255,244,.65);margin-bottom:18px;line-height:1.6;}
.rc-btn{padding:11px 26px;border-radius:10px;background:linear-gradient(135deg,#16a34a,#22c55e);border:none;color:#020804;font-family:var(--font-px);font-size:7px;cursor:pointer;font-weight:700;}

/* ── Bottom nav ── */
.game-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:rgba(2,8,4,.98);border-top:1px solid rgba(34,197,94,.14);display:flex;align-items:center;justify-content:space-around;z-index:50;}
.gbn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:rgba(240,255,244,.32);font-size:1.1rem;text-decoration:none;transition:color .15s;}
.gbn span{font-size:.62rem;font-family:var(--font-body);}
.gbn:hover,.gbn-active{color:var(--eml);}
button.gbn{background:none;border:none;cursor:pointer;}

/* ── Games hub popup ── */
.ghp-backdrop{position:fixed;inset:0;z-index:200;background:rgba(2,8,4,.7);backdrop-filter:blur(6px);}
.games-hub-popup{position:fixed;bottom:calc(var(--nav-h)+8px);left:50%;transform:translateX(-50%);width:min(340px,calc(100vw - 24px));background:rgba(5,15,8,.98);border:1px solid rgba(34,197,94,.3);border-radius:18px;padding:16px;z-index:201;box-shadow:0 -4px 40px rgba(34,197,94,.12);}
.ghp-title{font-size:8px;color:var(--eml);text-align:center;margin-bottom:14px;letter-spacing:2px;font-family:var(--font-px);}
.ghp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.ghp-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:12px 6px;border-radius:10px;background:rgba(34,197,94,.05);border:1px solid rgba(34,197,94,.1);color:rgba(240,255,244,.65);text-decoration:none;font-size:1.4rem;transition:all .15s;}
.ghp-item span{font-size:.52rem;font-family:var(--font-body);color:rgba(240,255,244,.5);}
.ghp-item:hover,.ghp-item.ghp-active{background:rgba(34,197,94,.15);border-color:rgba(74,222,128,.4);color:var(--eml);}
.ghp-close{display:block;width:100%;margin-top:12px;padding:8px;background:rgba(255,255,255,.05);border:none;border-radius:8px;color:rgba(240,255,244,.4);cursor:pointer;font-size:.75rem;font-family:var(--font-body);}

/* ── Login wall ── */
.game-login-wall{position:fixed;inset:0;background:rgba(2,8,4,.97);display:flex;align-items:center;justify-content:center;z-index:999;}
.glw-card{text-align:center;padding:32px 24px;background:rgba(5,15,8,.9);border:1px solid rgba(34,197,94,.3);border-radius:22px;max-width:280px;}
.glw-icon{font-size:3rem;margin-bottom:12px;}
.glw-title{font-size:10px;color:var(--eml);line-height:1.8;margin-bottom:10px;font-family:var(--font-px);}
.glw-sub{font-size:.8rem;color:rgba(240,255,244,.5);margin-bottom:20px;}
.glw-btn{display:inline-block;padding:12px 28px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#020804;border-radius:10px;font-weight:700;text-decoration:none;font-size:.85rem;}

.free-info{font-size:.6rem;color:rgba(240,255,244,.35);text-align:center;margin-top:6px;}
.free-info .ok{color:var(--eml);}
