/* assets/base.css - TIPITY BOUNCE UI */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;width:100%;background:#08080d;color:#fff;font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;}

/* --- GAME CONTAINER --- */
#game-container{display:flex;flex-direction:column;height:100dvh;}
canvas{flex:1;display:block;border-radius:12px;margin:4px 6px;touch-action:none;}

/* --- HUD --- */
#hud{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;gap:8px;}
.hud-item{background:rgba(255,255,255,0.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:8px 14px;border-radius:12px;font-weight:700;font-size:15px;border:1px solid rgba(255,255,255,0.06);transition:all 0.3s;}
#hud-brand{font-size:13px;letter-spacing:1px;color:rgba(255,255,255,0.5);text-transform:uppercase;}
#hud-time.urgent{color:#ff3b30;background:rgba(255,59,48,0.12);border-color:rgba(255,59,48,0.3);animation:urgentPulse 0.5s ease infinite alternate;}
@keyframes urgentPulse{from{transform:scale(1);}to{transform:scale(1.06);}}

/* --- TAP GUARD --- */
.tap-guard{height:10px;pointer-events:auto;touch-action:none;background:linear-gradient(180deg,rgba(255,140,0,0.05),transparent);}

/* --- AD DOCK (fixed bottom, never covers content) --- */
#ad-dock{position:fixed;bottom:0;left:0;right:0;width:min(100%,360px);min-height:50px;margin:0 auto;background:#0d0d12;display:flex;justify-content:center;align-items:center;overflow:hidden;border-top:1px solid rgba(255,140,0,0.15);z-index:100;}
.safe-bottom-spacer{height:max(env(safe-area-inset-bottom,0px),74px);flex:0 0 auto;}

/* --- START MENU --- */
#start-menu{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#08080d;z-index:200;padding:20px;}
.start-inner{text-align:center;width:min(400px,92vw);animation:fadeUp 0.5s ease;}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* Logo */
.logo-wrap{margin-bottom:28px;}
.logo-ball{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#ff8c00,#ff3b30);margin:0 auto 16px;box-shadow:0 0 40px rgba(255,140,0,0.5),0 0 80px rgba(255,140,0,0.2);animation:logoPulse 2s ease infinite alternate;}
@keyframes logoPulse{from{box-shadow:0 0 40px rgba(255,140,0,0.5),0 0 80px rgba(255,140,0,0.2);}to{box-shadow:0 0 60px rgba(255,140,0,0.7),0 0 120px rgba(255,140,0,0.3);transform:scale(1.05);}}
.logo-text{font-size:42px;font-weight:900;letter-spacing:2px;line-height:1.1;background:linear-gradient(135deg,#ff8c00,#ffcc00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.logo-sub{color:rgba(255,255,255,0.4);font-size:14px;margin-top:6px;letter-spacing:0.5px;}

/* Stats row */
.stats-row{display:flex;gap:10px;justify-content:center;margin-bottom:20px;}
.stat-card{flex:1;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:14px 8px;}
.stat-val{font-size:28px;font-weight:800;color:#ff8c00;}
.stat-lbl{font-size:11px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:1px;margin-top:2px;}

/* Badges */
.badges-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px;}
.badge-item{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:6px 10px;font-size:12px;opacity:0.3;transition:all 0.3s;display:flex;align-items:center;gap:4px;}
.badge-item.earned{opacity:1;border-color:rgba(255,140,0,0.3);background:rgba(255,140,0,0.08);}
.badge-icon{font-size:16px;}
.badge-name{color:rgba(255,255,255,0.7);}

/* Buttons */
.btn-glow{display:inline-block;background:linear-gradient(135deg,#ff8c00,#ff6600);color:#000;border:0;border-radius:14px;padding:16px 48px;font-size:18px;font-weight:800;letter-spacing:1px;cursor:pointer;box-shadow:0 4px 20px rgba(255,140,0,0.4);transition:all 0.2s;text-transform:uppercase;}
.btn-glow:hover,.btn-glow:active{transform:scale(1.04);box-shadow:0 6px 30px rgba(255,140,0,0.6);}
.btn-secondary{background:rgba(255,255,255,0.06);color:#fff;border:1px solid rgba(255,255,255,0.1);border-radius:14px;padding:14px 28px;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.2s;}
.btn-secondary:hover{background:rgba(255,255,255,0.1);}
.start-links{margin-top:20px;font-size:13px;color:rgba(255,255,255,0.3);}
.start-links a{color:rgba(255,255,255,0.4);text-decoration:none;}
.start-links a:hover{color:#ff8c00;}

/* --- MODAL --- */
#modal{position:fixed;inset:0;display:none;background:rgba(0,0,0,0.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:20px;z-index:300;}
.modal-card{background:linear-gradient(180deg,#111318,#0c0d11);border:1px solid rgba(255,255,255,0.08);border-radius:20px;padding:24px 20px;width:min(420px,92vw);box-shadow:0 20px 60px rgba(0,0,0,0.6);animation:modalIn 0.4s ease;}
@keyframes modalIn{from{opacity:0;transform:scale(0.9) translateY(20px);}to{opacity:1;transform:scale(1) translateY(0);}}
.modal-title{font-size:24px;font-weight:800;margin-bottom:8px;}
.score-display{margin:16px 0;}
.score-number{font-size:64px;font-weight:900;background:linear-gradient(135deg,#ff8c00,#ffcc00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;line-height:1;}
.score-label{font-size:14px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:2px;}
.combo-badge{display:inline-block;background:rgba(255,51,102,0.15);border:1px solid rgba(255,51,102,0.3);color:#ff3366;border-radius:20px;padding:4px 14px;font-size:13px;font-weight:700;margin-bottom:12px;}
.new-badges{margin:12px 0;padding:12px;background:rgba(255,140,0,0.06);border-radius:12px;border:1px solid rgba(255,140,0,0.15);}
.nb-title{font-size:13px;color:#ff8c00;font-weight:700;margin-bottom:6px;}
.nb-item{font-size:14px;padding:2px 0;}
.buttons{display:flex;gap:10px;justify-content:center;margin:16px 0;flex-wrap:wrap;}

/* Share section */
.share-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.06);}
.share-label{font-size:12px;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;}
.share-icons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.share-btn{width:42px;height:42px;border-radius:12px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.6);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;}
.share-btn:hover,.share-btn:active{background:rgba(255,140,0,0.15);border-color:rgba(255,140,0,0.3);color:#ff8c00;transform:scale(1.1);}
.share-toast{position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);background:#ff8c00;color:#000;padding:6px 16px;border-radius:8px;font-size:13px;font-weight:700;opacity:0;transition:all 0.3s;pointer-events:none;}
.share-toast.visible{opacity:1;bottom:-40px;}
.modal-footer{margin-top:14px;font-size:12px;color:rgba(255,255,255,0.25);}
.modal-footer a{color:rgba(255,255,255,0.35);text-decoration:none;}
.modal-footer a:hover{color:#ff8c00;}
.brand-sub{display:block;margin-top:4px;font-size:11px;}

/* --- RESPONSIVE --- */
@media(max-width:360px){
  .hud-item{padding:6px 10px;font-size:13px;}
  .logo-text{font-size:34px;}
  .score-number{font-size:48px;}
  .btn-glow{padding:14px 36px;font-size:16px;}
}

/* --- INSTALL BANNER --- */
#install-banner{
  position:fixed;bottom:60px;left:0;right:0;z-index:250;
  display:none;justify-content:center;padding:0 12px;
  animation:slideUp 0.4s ease;
}
@keyframes slideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.install-inner{
  display:flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,rgba(255,140,0,0.12),rgba(255,100,0,0.08));
  border:1px solid rgba(255,140,0,0.25);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:16px;padding:12px 16px;
  width:min(420px,96vw);
  box-shadow:0 8px 32px rgba(0,0,0,0.5);
}
.install-text{flex:1;text-align:left;}
.install-text strong{display:block;font-size:14px;color:#fff;margin-bottom:2px;}
.install-text span{font-size:12px;color:rgba(255,255,255,0.5);}
.install-action{padding:10px 20px;font-size:14px;white-space:nowrap;}
.install-close{
  background:none;border:none;color:rgba(255,255,255,0.4);font-size:22px;
  cursor:pointer;padding:4px 8px;line-height:1;
}
.install-close:hover{color:#fff;}
