/* ============================================================
   FIRE BAG BANDIT — styles.css  |  happystoner5420 Games!
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Oswald:wght@400;600;700&family=Roboto+Condensed:wght@400;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --fire-orange:#ff6a00;--fire-red:#ee0979;--fire-yellow:#ffe066;
  --dark-bg:#0a0a0f;--panel-bg:rgba(10,10,20,0.95);--panel-border:rgba(255,106,0,0.5);
  --text-light:#f0e8d0;--text-dim:#aaa;--hud-h:64px;
}
html,body{width:100%;height:100%;overflow:hidden;background:var(--dark-bg);
  font-family:'Roboto Condensed',sans-serif;color:var(--text-light);user-select:none}

.screen{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:10}
.screen.active{display:flex}
#game-screen{display:none;flex-direction:column}
#game-screen.active{display:flex}

/* ── MAIN MENU ── */
#main-menu{flex-direction:column;
  background:
    linear-gradient(160deg,rgba(10,0,16,0.78) 0%,rgba(13,5,0,0.7) 50%,rgba(16,0,5,0.85) 100%),
    url('bg_menu.jpg') center/cover no-repeat,
    radial-gradient(ellipse at 20% 80%,rgba(255,100,0,.35) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 20%,rgba(238,9,121,.25) 0%,transparent 55%),
    #0a0010}
.menu-bg-overlay{position:absolute;inset:0;pointer-events:none}
.title-block{text-align:center;margin-bottom:40px;position:relative}
.title-fire-effect{font-size:72px;animation:flicker 1.5s infinite alternate;margin-bottom:8px;
  filter:drop-shadow(0 0 20px #ff6a00) drop-shadow(0 0 40px #ee0979)}
@keyframes flicker{
  0%{transform:scale(1) rotate(-2deg)}
  50%{transform:scale(1.08) rotate(1deg);filter:drop-shadow(0 0 40px #ff9a00)}
  100%{transform:scale(1.03) rotate(-1deg)}}
.game-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(52px,10vw,100px);letter-spacing:6px;
  background:linear-gradient(135deg,#ffe066 0%,#ff6a00 40%,#ee0979 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;
  filter:drop-shadow(0 4px 20px rgba(255,106,0,.7))}
.game-subtitle{font-family:'Oswald',sans-serif;font-size:18px;letter-spacing:3px;color:#ff9a50;margin-top:6px}
.game-tagline{font-size:14px;color:var(--text-dim);margin-top:4px}
.game-tagline strong{color:#ff6a00}
.menu-buttons{display:flex;flex-direction:column;gap:14px;width:320px}
.menu-btn{font-family:'Oswald',sans-serif;font-size:20px;font-weight:600;letter-spacing:2px;
  padding:14px 28px;border:2px solid var(--panel-border);border-radius:6px;
  background:rgba(255,106,0,.12);color:var(--text-light);cursor:pointer;
  transition:all .2s;text-align:center;position:relative;overflow:hidden}
.menu-btn:hover{background:rgba(255,106,0,.3);border-color:#ff6a00;color:#ffe066;
  transform:translateY(-2px);box-shadow:0 6px 24px rgba(255,106,0,.4)}
.menu-btn.primary{background:linear-gradient(135deg,rgba(255,106,0,.4),rgba(238,9,121,.25));
  border-color:#ff6a00;color:#ffe066}
.menu-btn.primary:hover{background:linear-gradient(135deg,rgba(255,106,0,.6),rgba(238,9,121,.4));
  box-shadow:0 8px 32px rgba(255,106,0,.6)}
.menu-btn.danger{border-color:rgba(238,9,121,.5);background:rgba(238,9,121,.1)}
.menu-btn.danger:hover{background:rgba(238,9,121,.3);border-color:#ee0979}
.menu-disclaimer{margin-top:30px;font-size:11px;color:#555;text-align:center;max-width:420px;line-height:1.6}

/* ── MODAL BOX ── */
.modal-box{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;
  padding:36px 40px;max-width:680px;width:94%;max-height:88vh;overflow-y:auto;
  box-shadow:0 20px 80px rgba(0,0,0,.8),0 0 40px rgba(255,106,0,.15);backdrop-filter:blur(12px)}
.modal-box h2{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:4px;
  color:#ff6a00;margin-bottom:24px;text-align:center}
.modal-box h3{font-family:'Oswald',sans-serif;font-size:18px;color:#ff9a50;margin:20px 0 8px}
.modal-box p{color:var(--text-dim);line-height:1.7;margin-bottom:10px}
.modal-box ul{color:var(--text-dim);padding-left:20px;line-height:1.8}
.modal-box hr{border:none;border-top:1px solid rgba(255,106,0,.2);margin:20px 0}
.instructions{margin-bottom:24px}
.inst-row{display:flex;align-items:center;gap:16px;padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.05);font-size:15px}
.key{font-family:'Oswald',sans-serif;background:rgba(255,106,0,.2);border:1px solid rgba(255,106,0,.4);
  border-radius:4px;padding:3px 10px;font-size:13px;color:#ff9a50;
  white-space:nowrap;min-width:140px;text-align:center}
.credits-list{margin-bottom:24px}
.credit-entry{display:flex;flex-direction:column;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.credit-role{font-size:11px;letter-spacing:2px;color:#ff6a00;text-transform:uppercase}
.credit-name{font-family:'Oswald',sans-serif;font-size:18px;color:var(--text-light)}
.credits-disclaimer{font-size:11px;color:#555;line-height:1.8;text-align:center}
.credits-box{max-width:560px}

/* ── PAUSE ── */
#pause-menu{background:rgba(0,0,0,.75);backdrop-filter:blur(8px)}
#pause-menu .modal-box{max-width:380px}
.pause-subtitle{color:#888;text-align:center;margin-bottom:24px;font-size:14px}
#pause-menu .menu-btn{width:100%;margin-bottom:12px}

/* ── HUD ── */
#hud{position:relative;height:var(--hud-h);min-height:64px;
  background:linear-gradient(180deg,rgba(5,5,15,.97) 0%,rgba(5,5,15,.85) 100%);
  border-bottom:2px solid rgba(255,106,0,.3);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;z-index:100;flex-shrink:0;width:100%}
#hud-left,#hud-right{display:flex;gap:18px;align-items:center}
.hud-stat{font-family:'Oswald',sans-serif;font-size:16px;color:var(--text-light)}
.hud-stat span{color:#ff9a50;font-weight:700}
#hud-center{display:flex;flex-direction:column;align-items:center;gap:3px}
.heat-meter-label{font-size:10px;letter-spacing:2px;color:#888}
.heat-meter-bar{width:200px;height:14px;background:rgba(255,255,255,.1);
  border-radius:7px;overflow:hidden;border:1px solid rgba(255,106,0,.3)}
.heat-meter-fill{height:100%;width:0%;background:linear-gradient(90deg,#00cc44,#ffcc00,#ff4400);
  border-radius:7px;transition:width .3s;box-shadow:0 0 8px rgba(255,106,0,.6)}
.heat-meter-val{font-size:11px;color:#ff9a50;font-family:'Oswald',sans-serif}
.hud-btn{font-family:'Oswald',sans-serif;font-size:13px;letter-spacing:1px;padding:6px 14px;
  background:rgba(255,106,0,.15);border:1px solid rgba(255,106,0,.4);border-radius:4px;
  color:#ff9a50;cursor:pointer;transition:all .2s}
.hud-btn:hover{background:rgba(255,106,0,.3);border-color:#ff6a00}

/* ── CANVAS ── */
#game-canvas{flex:1;display:block;cursor:crosshair;width:100%;min-height:400px}

/* ── ITEM TOOLBAR ── */
#item-toolbar{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;background:rgba(5,5,15,.9);border:1px solid rgba(255,106,0,.35);
  border-radius:10px;padding:8px 14px;z-index:200;backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,0,0,.5)}
.tool-slot{display:flex;flex-direction:column;align-items:center;width:60px;cursor:pointer;
  border:2px solid rgba(255,255,255,.1);border-radius:8px;padding:4px;
  transition:all .2s;position:relative}
.tool-slot:hover{border-color:rgba(255,106,0,.5);background:rgba(255,106,0,.1)}
.tool-slot.active{border-color:#ff6a00;background:rgba(255,106,0,.22);box-shadow:0 0 12px rgba(255,106,0,.4)}
.slot-key{position:absolute;top:3px;left:5px;font-size:10px;color:#ff9a50;
  font-family:'Oswald',sans-serif;font-weight:700}
.tool-icon{width:36px;height:36px}
.slot-label{font-size:10px;color:var(--text-dim);margin-top:2px}

/* ── MINIMAP ── */
#minimap-canvas{position:fixed;top:calc(var(--hud-h) + 10px);right:14px;
  width:160px;height:160px;border:2px solid rgba(255,106,0,.4);
  border-radius:8px;z-index:150;background:rgba(5,5,15,.85)}

/* ── NOTIFICATIONS ── */
#notification-area{position:fixed;top:calc(var(--hud-h) + 14px);left:50%;
  transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.notification{font-family:'Oswald',sans-serif;font-size:18px;letter-spacing:1px;
  padding:10px 24px;border-radius:6px;text-align:center;
  animation:notif-in .3s ease,notif-out .4s ease 2.2s forwards}
.notification.fire{background:rgba(255,100,0,.9);color:#ffe066;border:1px solid #ff6a00}
.notification.warn{background:rgba(255,200,0,.9);color:#333;border:1px solid #ffcc00}
.notification.danger{background:rgba(200,0,50,.9);color:white;border:1px solid #ee0979}
.notification.info{background:rgba(20,80,200,.9);color:white;border:1px solid #4488ff}
.notification.score{background:rgba(0,160,70,.9);color:white;border:1px solid #00cc44}
@keyframes notif-in{from{opacity:0;transform:translateY(-16px) scale(.9)}to{opacity:1;transform:none}}
@keyframes notif-out{from{opacity:1}to{opacity:0;transform:translateY(-8px)}}

/* ── COURT / VN SCENE ── */
#court-scene{flex-direction:column;
  background:linear-gradient(180deg,#1a0800 0%,#0a0010 100%)}
.court-bg{position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 0%,rgba(255,180,50,.08) 0%,transparent 60%),
    repeating-linear-gradient(90deg,rgba(255,200,100,.025) 0px,rgba(255,200,100,.025) 1px,transparent 1px,transparent 80px),
    repeating-linear-gradient(0deg,rgba(255,200,100,.025) 0px,rgba(255,200,100,.025) 1px,transparent 1px,transparent 80px)}
.court-stage{flex:1;position:relative;display:flex;align-items:flex-end;
  justify-content:center;padding-bottom:20px;z-index:2}
.court-characters{display:flex;align-items:flex-end;justify-content:center;gap:24px;width:100%;flex-wrap:wrap;padding:0 10px}
.court-character{display:flex;flex-direction:column;align-items:center;animation:char-enter .5s ease}
@keyframes char-enter{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.court-character img{width:120px;height:120px;object-fit:cover;border-radius:50%;
  border:3px solid rgba(255,106,0,.4);
  box-shadow:0 0 24px rgba(255,106,0,.25),0 8px 32px rgba(0,0,0,.7);background:#1a0800}
.court-character img.speaking{border-color:#ff6a00;animation:speakpulse 1s ease infinite alternate}
@keyframes speakpulse{from{box-shadow:0 0 16px rgba(255,106,0,.35)}to{box-shadow:0 0 36px rgba(255,106,0,.75),0 0 60px rgba(255,106,0,.3)}}
.court-char-name{font-family:'Oswald',sans-serif;font-size:11px;color:#ff9a50;
  margin-top:7px;letter-spacing:1px;text-align:center;text-transform:uppercase}
.court-dialog-box{position:relative;z-index:5;background:rgba(4,4,14,.97);
  border:2px solid rgba(255,106,0,.4);border-radius:10px;margin:0 24px 24px;
  padding:22px 110px 22px 28px;min-height:130px;backdrop-filter:blur(12px);
  box-shadow:0 -10px 40px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,106,0,.1)}
.speaker-name{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:3px;color:#ff6a00;margin-bottom:10px}
.dialog-text{font-size:16px;line-height:1.8;color:var(--text-light);min-height:56px}
.dialog-next-btn{position:absolute;bottom:18px;right:20px;font-family:'Oswald',sans-serif;
  font-size:13px;letter-spacing:2px;padding:8px 18px;background:rgba(255,106,0,.2);
  border:1px solid rgba(255,106,0,.5);border-radius:4px;color:#ff9a50;cursor:pointer;
  transition:all .2s;animation:blink-arrow 1.2s infinite}
.dialog-next-btn:hover{background:rgba(255,106,0,.4);color:#ffe066}
@keyframes blink-arrow{0%,100%{opacity:1}50%{opacity:.35}}
.court-hud{position:fixed;top:16px;right:16px;display:flex;gap:12px;z-index:10}
.court-stat{font-family:'Oswald',sans-serif;font-size:13px;
  background:rgba(5,5,15,.88);border:1px solid rgba(255,106,0,.3);
  border-radius:6px;padding:5px 12px;color:#ff9a50}

/* ── GAME OVER ── */
.gameover-box{max-width:520px;text-align:center}
.go-verdict{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:3px;color:#ffe066;margin:16px 0}
.go-stats{color:var(--text-dim);margin-bottom:16px;line-height:2.2;font-size:16px}
.go-sentence{font-size:15px;color:#ff9a50;background:rgba(255,106,0,.1);
  border:1px solid rgba(255,106,0,.3);border-radius:6px;padding:14px 20px;margin-bottom:20px;line-height:1.7}
.gameover-box .menu-btn{width:100%;margin-bottom:10px}
.rank-badge{display:inline-block;font-family:'Bebas Neue',sans-serif;font-size:20px;
  letter-spacing:3px;padding:8px 24px;border-radius:30px;margin-bottom:12px}
.rank-legendary{background:linear-gradient(135deg,#ff6a00,#ee0979);color:#ffe066}
.rank-arsonist{background:rgba(255,106,0,.25);border:1px solid #ff6a00;color:#ff9a50}
.rank-rookie{background:rgba(255,255,255,.08);border:1px solid #666;color:#aaa}

::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}
::-webkit-scrollbar-thumb{background:rgba(255,106,0,.4);border-radius:3px}

/* ── COMBO METER ── */
#combo-meter{display:flex;align-items:center;gap:6px;margin-top:4px;
  background:linear-gradient(90deg,rgba(255,106,0,.3),rgba(238,9,121,.25));
  border:1px solid rgba(255,200,50,.55);border-radius:14px;padding:2px 10px;
  animation:combo-pulse .35s ease;box-shadow:0 0 14px rgba(255,106,0,.5)}
.combo-x{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:1px;
  color:#ffe066;text-shadow:0 0 6px rgba(255,200,50,.9)}
.combo-lbl{font-family:'Oswald',sans-serif;font-size:10px;color:#ff9a50;letter-spacing:1.5px}
@keyframes combo-pulse{0%{transform:scale(.7)}60%{transform:scale(1.15)}100%{transform:scale(1)}}

/* ── HIGH SCORE DISPLAY (main menu) ── */
#high-score-display{margin-top:18px;font-family:'Bebas Neue',sans-serif;font-size:18px;
  letter-spacing:3px;color:#ffe066;text-shadow:0 0 12px rgba(255,200,50,.6);
  padding:8px 22px;border:1px solid rgba(255,200,50,.4);border-radius:24px;
  background:rgba(0,0,0,.3);backdrop-filter:blur(6px)}

@media(max-width:600px){
  .game-title{font-size:52px}.menu-buttons{width:280px}.modal-box{padding:24px 20px}
  #minimap-canvas{width:110px;height:110px}.heat-meter-bar{width:120px}
  .court-character img{width:80px;height:80px}}
