/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{position:fixed;width:100%;height:100%;overflow:hidden;}
body{background:#000;display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;font-family:'Noto Sans JP',sans-serif;overflow:hidden;user-select:none;-webkit-user-select:none;position:fixed;width:100%;height:100%;touch-action:none;overscroll-behavior:none;}
#game{width:100vw;height:100vh;height:100dvh;max-width:480px;max-height:850px;position:relative;overflow:hidden;background:#111;touch-action:none;margin:0 auto;}
canvas{width:100%;height:100%;object-fit:contain;}
.scene{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none;transition:opacity 0.5s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.scene.active{opacity:1;pointer-events:auto;}
.bg-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.bg-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.4);z-index:1;}
.content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:20px;}

/* ===== BUTTONS ===== */
.btn-gold{background:#D4A017;color:#000;font-family:'Noto Sans JP',sans-serif;font-weight:900;font-size:20px;border:none;padding:14px 40px;border-radius:50px;cursor:pointer;letter-spacing:2px;animation:pulseGlow 2s ease-in-out infinite;transition:transform 0.15s;}
.btn-gold:active{transform:scale(0.95);}
.btn-secondary{background:rgba(255,255,255,0.15);color:#fff;font-family:'Noto Sans JP',sans-serif;font-weight:700;font-size:14px;border:1px solid rgba(255,255,255,0.3);padding:10px 24px;border-radius:50px;cursor:pointer;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:transform 0.15s;}
.btn-secondary:active{transform:scale(0.95);}

/* ===== ANIMATIONS ===== */
@keyframes pulseGlow{0%,100%{box-shadow:0 0 10px rgba(212,160,23,0.4);}50%{box-shadow:0 0 30px rgba(212,160,23,0.8);}}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes shake{0%,100%{transform:translateX(0);}10%,30%,50%,70%,90%{transform:translateX(-5px);}20%,40%,60%,80%{transform:translateX(5px);}}
@keyframes dramaticGrow{0%{transform:scale(0.3);opacity:0;}50%{transform:scale(1.15);}100%{transform:scale(1);opacity:1;}}
@keyframes typewriter{from{width:0;}to{width:100%;}}
@keyframes judgmentPop{0%{transform:scale(0.5) translateY(0);opacity:1;}100%{transform:scale(1.3) translateY(-40px);opacity:0;}}
@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0deg);opacity:1;}100%{transform:translateY(700px) rotate(720deg);opacity:0;}}
@keyframes blinkHint{0%,100%{opacity:0.3;box-shadow:0 0 10px rgba(0,200,100,0.3);}50%{opacity:0.8;box-shadow:0 0 25px rgba(0,200,100,0.7);}}
@keyframes pulseBar{0%,100%{box-shadow:0 0 8px #D4A017;}50%{box-shadow:0 0 20px #D4A017,0 0 40px rgba(212,160,23,0.4);}}
@keyframes pulseBadge{0%,100%{transform:scale(1);box-shadow:0 0 10px rgba(212,160,23,0.4);}50%{transform:scale(1.06);box-shadow:0 0 25px rgba(212,160,23,0.8);}}
@keyframes borderPulseRed{0%,100%{box-shadow:inset 0 0 40px rgba(231,76,60,0);}50%{box-shadow:inset 0 0 60px rgba(231,76,60,0.65);}}
@keyframes slideInTop{from{transform:translate(-50%,-100%);opacity:0;}to{transform:translate(-50%,0);opacity:1;}}
@keyframes slideOutTop{to{transform:translate(-50%,-100%);opacity:0;}}

/* ===== FROSTED GLASS ===== */
.glass{background:rgba(0,0,0,0.5);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,0.1);border-radius:16px;}

/* ===== LANGUAGE TOGGLE ===== */
.lang-toggle{position:absolute;top:12px;right:12px;z-index:10;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,0.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2);border-radius:20px;padding:6px 12px;cursor:pointer;color:#fff;font-size:13px;font-weight:700;transition:background 0.2s;}
.lang-toggle:active{background:rgba(255,255,255,0.15);}
.lang-toggle svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:1.5;}

/* ===== TICKET CARDS ===== */
.ticket-card{width:85%;padding:18px 20px;border-radius:16px;margin:8px 0;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;display:flex;justify-content:space-between;align-items:center;}
.ticket-card:active{transform:scale(0.97);}
.ticket-card.light{background:rgba(255,255,255,0.9);color:#222;}
.ticket-card.gold{background:linear-gradient(135deg,#D4A017,#F0C040);color:#222;}
.ticket-card.red{background:linear-gradient(135deg,#C0392B,#E74C3C);color:#fff;}
.ticket-card .name{font-weight:900;font-size:18px;}
.ticket-card .price{font-weight:700;font-size:16px;opacity:0.8;}

/* ===== TOPPING PILLS ===== */
.topping-row{display:flex;align-items:center;margin:6px 0;width:100%;}
.topping-label{color:#D4A017;font-weight:900;font-size:14px;width:90px;text-align:right;margin-right:8px;}
.pill-group{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;}
.pill{padding:6px 10px;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:2px solid rgba(255,255,255,0.3);color:#fff;background:rgba(255,255,255,0.1);transition:all 0.2s;white-space:nowrap;}
.pill.selected{background:#D4A017;color:#000;border-color:#D4A017;}

/* ===== RHYTHM GAME ===== */
#rhythm-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2;}
.rhythm-hud{position:absolute;z-index:3;color:#fff;font-weight:900;}
.rhythm-score{top:8px;right:12px;font-size:20px;}
.rhythm-hearts{top:8px;left:12px;font-size:18px;}
.rhythm-timer{top:8px;left:50%;transform:translateX(-50%);font-size:16px;background:rgba(0,0,0,0.5);padding:4px 12px;border-radius:20px;}
.rhythm-combo{top:50px;left:50%;transform:translateX(-50%);font-size:28px;color:#D4A017;text-shadow:0 0 10px rgba(212,160,23,0.5);}

/* ===== JUDGMENT TEXT ===== */
.judgment-text{position:absolute;z-index:4;left:50%;top:480px;transform:translateX(-50%);font-size:32px;font-weight:900;pointer-events:none;animation:judgmentPop 0.6s ease forwards;text-shadow:0px 0px 8px #000, 0px 0px 15px #000, 2px 2px 2px #000;}

/* ===== DIALOG ===== */
.dialog-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.7);z-index:10;display:flex;align-items:center;justify-content:center;}
.dialog-box{background:rgba(30,30,30,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.15);border-radius:20px;padding:30px;text-align:center;max-width:320px;}
.dialog-box p{color:#fff;font-weight:700;font-size:18px;margin-bottom:20px;}
.dialog-box .btn-row{display:flex;gap:12px;justify-content:center;}

/* ===== CONFETTI ===== */
.confetti{position:absolute;width:8px;height:8px;top:-10px;z-index:5;animation:confettiFall linear forwards;}

/* ===== MISC ===== */
.elapsed-timer{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;font-weight:700;font-size:14px;background:rgba(0,0,0,0.5);padding:4px 14px;border-radius:20px;}

/* ===== V3: DRAMA FX (Track 2) ===== */
.drama-vignette{position:absolute;inset:0;pointer-events:none;z-index:4;border-radius:0;animation:borderPulseRed 0.9s ease-in-out infinite;}
.drama-owner-line{position:absolute;top:10px;left:50%;transform:translate(-50%,-100%);z-index:12;background:rgba(12,8,4,0.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #E74C3C;border-radius:8px;padding:10px 18px;color:#E74C3C;font-size:14px;font-weight:900;white-space:nowrap;text-shadow:0 0 6px rgba(231,76,60,0.5);animation:slideInTop 0.35s cubic-bezier(0.2,1.1,0.3,1) forwards;}
.drama-owner-line.exit{animation:slideOutTop 0.3s ease forwards;}

/* ===== V3: BADGE / TOAST (Track 3) ===== */
.title-badge{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:20;background:linear-gradient(135deg,#D4A017,#F0C040);color:#1a1a1a;padding:10px 20px;border-radius:50px;font-weight:900;font-size:14px;box-shadow:0 0 25px rgba(212,160,23,0.7);animation:pulseBadge 1.2s ease-in-out infinite,dramaticGrow 0.6s ease;}

/* ===== V3: SECRET MENU POPUP (Track 4/5) ===== */
.secret-toast{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);z-index:30;background:rgba(20,10,0,0.92);border:1px solid #D4A017;border-radius:12px;padding:12px 20px;color:#D4A017;font-weight:900;font-size:13px;box-shadow:0 0 20px rgba(212,160,23,0.5);animation:dramaticGrow 0.5s ease,fadeIn 0.4s ease;}

/* ===== V3: WORST-END GLITCH (Track 2) ===== */
@keyframes gameOverGlitch{
  0%,100%{filter:none;transform:translate(0,0);}
  20%{filter:drop-shadow(2px 0 0 #00E5FF) drop-shadow(-2px 0 0 #FF0055);transform:translate(1px,0);}
  40%{filter:drop-shadow(-3px 0 0 #00E5FF) drop-shadow(3px 0 0 #FF0055);transform:translate(-1px,1px);}
  60%{filter:none;transform:translate(0,-1px);}
  80%{filter:drop-shadow(2px 1px 0 #00E5FF) drop-shadow(-2px -1px 0 #FF0055);transform:translate(0,0);}
}
@keyframes impactSpin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
