/* ===== BANKSY GIRL LEVEL — LUXURY EDITION ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
button { -webkit-tap-highlight-color: transparent; touch-action: manipulation; }
input, select, textarea { -webkit-tap-highlight-color: transparent; }

:root {
  --pink:    #ff0088;
  --pink2:   #ff4db8;
  --purple:  #7700ff;
  --purple2: #aa55ff;
  --cyan:    #00eeff;
  --gold:    #ffd700;
  --gold2:   #ffb800;
  --silver:  #c8d8e8;
  --bronze:  #e8a060;
  --green:   #00ff99;
  --orange:  #ff9900;
  --text:    #ffffff;
  --text2:   #b0b0d0;
  --text3:   #555580;
  --danger:  #ff4455;
  --nav-h:   72px;
  --header-h:60px;
  --radius:  16px;
}

/* ── BACKGROUND ─────────────────────────────────── */
html, body {
  height: 100%;
  background: #050510;
  color: var(--text);
  font-family: 'Hiragino Kaku Gothic ProN','Hiragino Sans','Meiryo',sans-serif;
  overflow: hidden;
}

/* Animated gradient orbs */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 50% at 15% 20%, rgba(255,0,136,0.22) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 85% 75%, rgba(119,0,255,0.22) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 50% 50%, rgba(0,238,255,0.09) 0%, transparent 70%),
    radial-gradient(ellipse 30% 30% at 70% 10%, rgba(255,153,0,0.1) 0%, transparent 70%);
  animation: bgOrbs 10s ease-in-out infinite alternate;
}
@keyframes bgOrbs {
  0%   { opacity: 1; transform: scale(1) rotate(0deg); }
  33%  { opacity: 0.85; transform: scale(1.06) rotate(1.5deg); }
  66%  { opacity: 0.95; transform: scale(0.97) rotate(-1deg); }
  100% { opacity: 1; transform: scale(1.03) rotate(0.5deg); }
}

/* Grid + floating scanline */
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 40px 40px;
  animation: gridDrift 20s linear infinite;
}
@keyframes gridDrift {
  0%   { background-position: 0 0; }
  100% { background-position: 40px 40px; }
}

/* Floating stars background */
#stars-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
}
.star {
  position: absolute; border-radius: 50%;
  background: white; opacity: 0;
  animation: starFloat linear infinite;
}
@keyframes starFloat {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  5%   { opacity: 1; }
  90%  { opacity: 0.7; }
  100% { transform: translateY(-50px) scale(1); opacity: 0; }
}

/* iOS Safari の 100vh 問題を修正（dvhで動的ビューポート対応） */
#app {
  display: flex; flex-direction: column;
  height: 100vh;
  height: 100dvh;
  overflow: hidden; position: relative; z-index: 1;
}

/* ── HEADER ─────────────────────────────────────── */
.header {
  height: var(--header-h);
  background: rgba(5,5,20,0.8);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px;
  flex-shrink: 0;
  position: relative; z-index: 10;
}
.logo {
  display: flex; align-items: baseline; gap: 6px;
  letter-spacing: 2px; position: relative;
}
.logo-b {
  font-size: 22px; font-weight: 900; font-style: italic;
  color: var(--pink);
  text-shadow: 0 0 20px rgba(255,0,136,0.9), 0 0 40px rgba(255,0,136,0.5), 0 0 80px rgba(255,0,136,0.2);
  animation: logoPulse 3s ease-in-out infinite alternate, logoGlitch 9s ease-in-out infinite;
  position: relative;
}
.logo-l {
  font-size: 22px; font-weight: 900; font-style: italic;
  background: linear-gradient(90deg, var(--cyan), var(--purple2), var(--cyan));
  background-size: 200% 100%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 12px rgba(0,238,255,0.8));
  animation: logoFlow 3s ease-in-out infinite, logoPulse 3s ease-in-out infinite alternate 0.5s;
}
@keyframes logoPulse {
  0%   { filter: brightness(1); }
  100% { filter: brightness(1.4) drop-shadow(0 0 12px currentColor); }
}
@keyframes logoFlow {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes logoGlitch {
  0%,88%,100% { transform: none; text-shadow: 0 0 20px rgba(255,0,136,0.9), 0 0 40px rgba(255,0,136,0.5); }
  89%  { transform: translate(-2px,0) skewX(-1deg); text-shadow: 3px 0 0 rgba(0,238,255,0.8), -3px 0 0 rgba(255,0,136,0.8); }
  90%  { transform: translate(2px,0) skewX(1deg);  text-shadow: -3px 0 0 rgba(0,238,255,0.8), 3px 0 0 rgba(255,0,136,0.8); }
  91%,92%,93% { transform: none; text-shadow: 0 0 20px rgba(255,0,136,0.9), 0 0 40px rgba(255,0,136,0.5); }
}
.header-date { font-size: 11px; color: var(--text3); }

/* ── MAIN ───────────────────────────────────────── */
.main {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 16px;
  /* iPhone ホームインジケーター分を加算 */
  padding-bottom: calc(var(--nav-h) + 36px + env(safe-area-inset-bottom));
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.08) transparent;
  /* iOS スムーズスクロール */
  -webkit-overflow-scrolling: touch;
}
.main::-webkit-scrollbar { width: 3px; }
.main::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 2px; }

/* ── BOTTOM NAV (floating) ──────────────────────── */
.bottom-nav {
  position: fixed;
  /* iPhone ホームインジケーター（env）に対応 */
  bottom: calc(16px + env(safe-area-inset-bottom));
  left: 12px; right: 12px;
  height: var(--nav-h);
  background: rgba(8,8,28,0.92);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 24px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04);
  display: flex; align-items: center; justify-content: space-around;
  z-index: 100;
}
.nav-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; background: none; border: none; cursor: pointer;
  padding: 8px 4px; color: var(--text3); transition: color 0.25s; gap: 3px;
  height: 100%;
}
.nav-btn.active { color: var(--pink); }
.nav-btn.active .nav-icon {
  filter: drop-shadow(0 0 8px rgba(255,0,136,1));
  animation: navIconPop 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.nav-btn:active { transform: scale(0.88); transition: transform 0.1s; }
@keyframes navIconPop {
  0%   { transform: scale(0.7) translateY(4px); }
  100% { transform: scale(1)   translateY(0); }
}
.nav-icon { font-size: 22px; line-height: 1; transition: filter 0.25s; }
.nav-label { font-size: 10px; font-weight: 600; }

.nav-center-btn { position: relative; margin-top: -18px; }
.nav-center-inner {
  width: 58px; height: 58px; border-radius: 50%;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 24px rgba(255,0,136,0.5), 0 0 48px rgba(119,0,255,0.3);
  margin-bottom: 4px;
  animation: centerPulse 2.5s ease-in-out infinite;
}
@keyframes centerPulse {
  0%, 100% { box-shadow: 0 0 24px rgba(255,0,136,0.5), 0 0 48px rgba(119,0,255,0.3); transform: scale(1); }
  50%       { box-shadow: 0 0 42px rgba(255,0,136,0.9), 0 0 80px rgba(119,0,255,0.6); transform: scale(1.06); }
}
.nav-center-inner .nav-icon { font-size: 28px; }

/* ── GLASS CARD ─────────────────────────────────── */
.card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 18px;
  margin-bottom: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
}
.card-title {
  font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
  color: var(--text3); text-transform: uppercase; margin-bottom: 14px;
}

/* ── DASHBOARD HERO BANNER ──────────────────────── */
.dash-hero-banner {
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(135deg,rgba(255,0,136,0.12),rgba(119,0,255,0.14),rgba(0,238,255,0.10));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius); padding: 14px 16px;
  margin-bottom: 14px;
  position: relative; overflow: hidden;
  animation: heroBannerIn 0.5s cubic-bezier(0.34,1.3,0.64,1) both;
}
@keyframes heroBannerIn {
  0%   { opacity:0; transform:translateY(-10px); }
  100% { opacity:1; transform:translateY(0); }
}
.dash-hero-banner::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);
  animation: cardSheen 5s ease-in-out infinite;
}
.dash-hero-icon { font-size: 28px; flex-shrink:0; animation: heroBob 2s ease-in-out infinite; }
@keyframes heroBob { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-4px) scale(1.08)} }
.dash-hero-msg {
  font-size: 13px; font-weight: 700; color: var(--text);
  line-height: 1.5; letter-spacing: 0.3px;
}

/* ── ダッシュボード：スタッフ0人ガイド ─────────── */
.dash-empty-guide {
  text-align: center; padding: 24px 20px 20px !important;
  border: 1.5px dashed rgba(255,215,0,0.25) !important;
}
.dash-empty-icon { font-size: 44px; margin-bottom: 8px; animation: heroBob 2s ease-in-out infinite; }
.dash-empty-title { font-size: 18px; font-weight: 900; color: var(--gold); margin-bottom: 8px; }
.dash-empty-desc { font-size: 12px; color: var(--text3); line-height: 1.8; }

/* ── ショップコード共有UI ─────────────────────── */
.dash-code-share-row {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.dash-code-chip {
  display: flex; flex-direction: column; align-items: center;
  background: rgba(0,238,255,0.07); border: 1px solid rgba(0,238,255,0.2);
  border-radius: 10px; padding: 6px 14px; gap: 2px;
}
.dash-code-text {
  font-size: 20px; font-weight: 900; letter-spacing: 4px; color: var(--cyan);
}
.dash-code-copy-btn {
  background: rgba(0,238,255,0.1); border: 1px solid rgba(0,238,255,0.3);
  border-radius: 10px; color: var(--cyan); font-size: 13px; font-weight: 800;
  padding: 10px 18px; cursor: pointer; min-height: 44px;
  -webkit-tap-highlight-color: transparent; touch-action: manipulation;
}
.dash-code-copy-btn:active { background: rgba(0,238,255,0.25); transform: scale(0.95); }

/* コードバナー（ダッシュボード下部、スタッフ1人以上） */
.dash-code-banner {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(0,238,255,0.04); border: 1px solid rgba(0,238,255,0.12);
  border-radius: 14px; padding: 12px 16px; margin-top: 4px; margin-bottom: 8px;
}
.dash-code-left { display: flex; align-items: center; gap: 10px; }
.dash-code-label { font-size: 10px; color: var(--text3); letter-spacing: 1.5px; font-weight: 700; }
.dash-code-val { font-size: 16px; font-weight: 900; letter-spacing: 3px; color: var(--cyan); }
.dash-code-actions { display: flex; gap: 6px; }
.dash-code-btn {
  background: rgba(0,238,255,0.08); border: 1px solid rgba(0,238,255,0.2);
  border-radius: 8px; color: var(--cyan); font-size: 16px; cursor: pointer;
  width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
  -webkit-tap-highlight-color: transparent; touch-action: manipulation;
  transition: background 0.15s, transform 0.1s;
}
.dash-code-btn:active { background: rgba(0,238,255,0.25); transform: scale(0.9); }

/* ── ダッシュボード追加ボタン ───────────────────── */
.btn-dash-mypage {
  display: block; width: 100%; margin-top: 10px;
  padding: 11px; border-radius: 10px; border: none;
  background: linear-gradient(135deg,rgba(119,0,255,0.2),rgba(0,238,255,0.15));
  border: 1px solid rgba(119,0,255,0.3);
  color: var(--cyan); font-size: 13px; font-weight: 800;
  cursor: pointer; letter-spacing: 0.5px;
  transition: background 0.2s, transform 0.12s;
  -webkit-tap-highlight-color: transparent;
}
.btn-dash-mypage:hover { background: linear-gradient(135deg,rgba(119,0,255,0.3),rgba(0,238,255,0.2)); transform: translateY(-1px); }
.btn-dash-mypage:active { transform: scale(0.97); }

.btn-see-all-rank {
  display: block; width: 100%; margin-top: 12px;
  padding: 12px; border-radius: 12px; border: none;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
  color: var(--text2); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: background 0.15s, transform 0.12s;
  -webkit-tap-highlight-color: transparent;
}
.btn-see-all-rank:hover { background: rgba(255,255,255,0.09); color: #fff; }
.btn-see-all-rank:active { transform: scale(0.97); }

.coop-reward-hint {
  font-size: 12px; color: var(--text3); margin-bottom: 12px;
  text-align: center; padding: 6px 10px;
  background: rgba(119,0,255,0.08); border-radius: 8px;
}

/* ── STAT GRID ──────────────────────────────────── */
.stat-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px;
}
.stat-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 16px 12px; text-align: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  position: relative; overflow: hidden;
}
.stat-card::after {
  content: '';
  position: absolute; top: 0; left: -100%; width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  animation: cardSheen 4s ease-in-out infinite;
}
@keyframes cardSheen { 0%,60%{ left:-100%; } 100%{ left:200%; } }
.stat-card:hover {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 10px 30px rgba(0,0,0,0.5), 0 0 20px rgba(255,0,136,0.1);
  transition: transform 0.2s, box-shadow 0.2s;
}
.stat-value {
  animation: numPop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes numPop {
  0%   { transform: scale(0.5); opacity: 0; }
  100% { transform: scale(1);   opacity: 1; }
}
.stat-label { font-size: 10px; color: var(--text3); margin-bottom: 8px; letter-spacing: 1.5px; font-weight: 600; }
.stat-value { font-size: 32px; font-weight: 900; line-height: 1; }
.stat-sub   { font-size: 11px; color: var(--text2); margin-top: 4px; }

/* ── AVATAR ─────────────────────────────────────── */
.girl-avatar {
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; color: white; flex-shrink: 0;
  position: relative;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}

/* ── GIRL CARD ──────────────────────────────────── */
.girl-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 16px; margin-bottom: 10px;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
  position: relative; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.girl-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.1);
}
.girl-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--girl-color, var(--pink)), transparent 70%);
}
.girl-card-inner { display: flex; align-items: center; gap: 14px; }
.girl-avatar { width: 50px; height: 50px; font-size: 20px; }
.girl-avatar-glow {
  position: absolute; inset: -4px; border-radius: 50%;
  background: radial-gradient(circle, var(--girl-color, var(--pink)) 0%, transparent 70%);
  opacity: 0.2; z-index: -1;
}
.girl-info { flex: 1; min-width: 0; }
.girl-name { font-size: 18px; font-weight: 800; margin-bottom: 3px; }
.girl-rank-badge {
  display: inline-block; font-size: 9px; font-weight: 800; letter-spacing: 1.5px;
  padding: 2px 9px; border-radius: 20px;
  background: var(--girl-color, var(--pink));
  color: rgba(0,0,0,0.85); margin-bottom: 8px;
}
.girl-xp-bar {
  height: 5px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; position: relative;
}
.girl-xp-fill {
  height: 100%; border-radius: 3px;
  background: var(--girl-color, var(--pink));
  transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1);
  position: relative; overflow: hidden;
}
.girl-xp-fill::after {
  content: ''; position: absolute; top: 0; left: -100%; width: 80%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.7), transparent);
  animation: barShimmer 1.8s ease-in-out infinite;
}
@keyframes barShimmer { 0%,40%{ left:-100%; } 100%{ left:150%; } }

/* XP bar fill animation on render */
.girl-xp-fill { animation: barFill 0.8s cubic-bezier(0.34,1.56,0.64,1) both; }
@keyframes barFill { from { width: 0 !important; } }
.girl-xp-text { font-size: 10px; color: var(--text3); margin-top: 5px; }
.girl-level-wrap { text-align: right; flex-shrink: 0; }
.girl-level-num {
  font-size: 28px; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, var(--girl-color, var(--pink)), rgba(255,255,255,0.7));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.girl-level-label { font-size: 9px; color: var(--text3); text-align: right; letter-spacing: 1.5px; margin-top: 2px; }

/* ── RANK CARD ──────────────────────────────────── */
.rank-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 14px 16px; margin-bottom: 10px;
  display: flex; align-items: center; gap: 14px;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
  position: relative; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.rank-card:hover {
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 14px 40px rgba(0,0,0,0.6), 0 0 30px rgba(255,0,136,0.1);
  transition: all 0.2s cubic-bezier(0.34,1.56,0.64,1);
}

.rank-card.rank-1 {
  background: linear-gradient(135deg, rgba(255,215,0,0.07), rgba(255,180,0,0.03));
  border-color: rgba(255,215,0,0.35);
  box-shadow: 0 4px 24px rgba(0,0,0,0.3), 0 0 20px rgba(255,215,0,0.08);
}
.rank-card.rank-2 {
  background: linear-gradient(135deg, rgba(200,216,232,0.06), rgba(160,180,200,0.03));
  border-color: rgba(200,216,232,0.25);
}
.rank-card.rank-3 {
  background: linear-gradient(135deg, rgba(232,160,96,0.06), rgba(200,120,60,0.03));
  border-color: rgba(232,160,96,0.25);
}

/* Animated border for rank 1 */
.rank-card.rank-1::after {
  content: ''; position: absolute; inset: 0;
  border-radius: var(--radius);
  background: linear-gradient(90deg, transparent, rgba(255,215,0,0.08), transparent);
  animation: goldSweep 3s ease-in-out infinite;
  pointer-events: none;
}
@keyframes goldSweep {
  0%   { transform: translateX(-100%); }
  50%,100%{ transform: translateX(200%); }
}

.rank-num {
  font-size: 24px; font-weight: 900; width: 40px; text-align: center; flex-shrink: 0;
  line-height: 1;
}
.rank-1 .rank-num { color: var(--gold); text-shadow: 0 0 16px rgba(255,215,0,0.7); }
.rank-2 .rank-num { color: var(--silver); text-shadow: 0 0 12px rgba(200,216,232,0.5); }
.rank-3 .rank-num { color: var(--bronze); text-shadow: 0 0 12px rgba(232,160,96,0.5); }

.rank-card .girl-avatar { width: 44px; height: 44px; font-size: 18px; }
.rank-badge-overlay {
  position: absolute; bottom: -4px; right: -4px;
  background: rgba(10,10,25,0.9); border-radius: 50%;
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; line-height: 1; border: 1.5px solid rgba(255,255,255,0.2);
  animation: badgePop 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes badgePop {
  0%   { transform: scale(0) rotate(-180deg); opacity: 0; }
  100% { transform: scale(1) rotate(0deg);    opacity: 1; }
}
.rank-info { flex: 1; min-width: 0; }
.rank-name { font-size: 16px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rank-title { font-size: 12px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rank-lv { font-size: 20px; font-weight: 900; line-height: 1; white-space: nowrap; }
.rank-xp { font-size: 11px; color: var(--text3); white-space: nowrap; flex-shrink: 0; }

/* ── TOP 3 PODIUM ───────────────────────────────── */
.top3-wrap {
  display: grid; grid-template-columns: 1fr 1.2fr 1fr;
  gap: 8px; margin-bottom: 16px; align-items: end;
}
.top3-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 14px 8px; text-align: center; cursor: pointer;
  transition: transform 0.2s;
  position: relative; overflow: hidden;
}
.top3-card:hover { transform: translateY(-3px); }
.top3-card.pos-1 {
  border-color: rgba(255,215,0,0.4);
  background: linear-gradient(180deg, rgba(255,215,0,0.1), rgba(255,215,0,0.02));
  box-shadow: 0 0 30px rgba(255,215,0,0.1);
}
.top3-card.pos-2 { border-color: rgba(200,216,232,0.25); }
.top3-card.pos-3 { border-color: rgba(232,160,96,0.25); }
.top3-crown { font-size: 26px; margin-bottom: 6px; }
.top3-avatar {
  width: 54px; height: 54px; border-radius: 50%;
  margin: 0 auto 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 900; color: white;
  position: relative;
}
.top3-card.pos-1 .top3-avatar { width: 64px; height: 64px; font-size: 28px; }
.top3-avatar-ring {
  position: absolute; inset: -3px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  animation: ringPulse 2s ease-in-out infinite;
}
.pos-1 .top3-avatar-ring {
  border-color: rgba(255,215,0,0.6);
  box-shadow: 0 0 12px rgba(255,215,0,0.4);
}
@keyframes ringPulse {
  0%,100%{ opacity: 0.6; transform: scale(1); }
  50%    { opacity: 1;   transform: scale(1.05); }
}
.top3-name { font-size: 13px; font-weight: 800; margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.top3-lv { font-size: 11px; color: var(--text3); }
.top3-lv span { font-size: 20px; font-weight: 900; color: var(--text); }

/* ── EVENT PAGE ─────────────────────────────────── */
.event-girl-list { display: flex; flex-direction: column; gap: 12px; }
.event-girl-row {
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.09);
  padding: 16px 14px;
  display: flex; align-items: flex-start; gap: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.35);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.event-girl-row:active { border-color: rgba(255,255,255,0.15); }
.event-girl-name { font-size: 15px; font-weight: 800; margin-bottom: 10px; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.event-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.event-btn {
  padding: 10px 14px; border-radius: 12px; border: none; cursor: pointer;
  font-size: 13px; font-weight: 800; min-height: 44px;
  transition: transform 0.12s, box-shadow 0.12s, filter 0.12s;
  white-space: nowrap; position: relative; overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}
.event-btn::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(255,255,255,0); transition: background 0.12s;
  border-radius: inherit;
}
.event-btn:hover { transform: translateY(-2px) scale(1.04); filter: brightness(1.15); }
.event-btn:active { transform: scale(0.95); filter: brightness(0.9); }

.evt-attend    { background: rgba(0,255,204,0.12); color: var(--cyan);    border: 1px solid rgba(0,255,204,0.3); }
.evt-visit     { background: rgba(0,255,153,0.12); color: var(--green);   border: 1px solid rgba(0,255,153,0.25); }
.evt-douhan    { background: rgba(255,0,136,0.12); color: var(--pink2);   border: 1px solid rgba(255,0,136,0.3); }
.evt-drink     { background: rgba(255,215,0,0.12); color: var(--gold);    border: 1px solid rgba(255,215,0,0.3); }
.evt-champagne { background: rgba(255,153,0,0.12); color: var(--orange);  border: 1px solid rgba(255,153,0,0.3); }
.evt-back      { background: rgba(0,238,255,0.12); color: var(--cyan);    border: 1px solid rgba(0,238,255,0.3); }
.evt-nomination{ background: rgba(170,85,255,0.12);color: var(--purple2); border: 1px solid rgba(170,85,255,0.3); }

/* Hover glow per type */
.evt-attend:hover    { box-shadow: 0 4px 16px rgba(0,255,204,0.3); }
.evt-visit:hover     { box-shadow: 0 4px 16px rgba(0,255,153,0.3); }
.evt-done { opacity: 0.45; cursor: not-allowed !important; }
.evt-done:hover { transform: none !important; filter: none !important; box-shadow: none !important; }
.evt-douhan:hover    { box-shadow: 0 4px 16px rgba(255,0,136,0.3); }
.evt-drink:hover     { box-shadow: 0 4px 16px rgba(255,215,0,0.3); }
.evt-champagne:hover { box-shadow: 0 4px 16px rgba(255,153,0,0.3); }
.evt-back:hover      { box-shadow: 0 4px 16px rgba(0,238,255,0.3); }
.evt-nomination:hover{ box-shadow: 0 4px 16px rgba(170,85,255,0.3); }

/* ── STAFF PAGE ─────────────────────────────────── */
.staff-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.btn-add-staff {
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: white; border: none; border-radius: 22px;
  padding: 10px 22px; font-size: 13px; font-weight: 800; cursor: pointer;
  box-shadow: 0 0 20px rgba(255,0,136,0.4), 0 4px 12px rgba(0,0,0,0.3);
  transition: box-shadow 0.2s, transform 0.15s;
}
.btn-add-staff:hover { box-shadow: 0 0 32px rgba(255,0,136,0.6), 0 6px 16px rgba(0,0,0,0.4); transform: translateY(-1px); }
.btn-add-staff:active { transform: scale(0.97); }

.staff-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 12px 14px; margin-bottom: 8px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}
.staff-info { flex: 1; min-width: 0; overflow: hidden; }
.staff-actions { display: flex; flex-direction: column; gap: 5px; flex-shrink: 0; }
.btn-sm {
  padding: 6px 12px; border-radius: 8px; border: none; cursor: pointer;
  font-size: 11px; font-weight: 700; transition: all 0.15s; white-space: nowrap;
  text-align: center;
}
.btn-edit {
  background: rgba(255,255,255,0.06); color: var(--text2);
  border: 1px solid rgba(255,255,255,0.1);
}
.btn-edit:hover { background: rgba(0,238,255,0.12); color: var(--cyan); border-color: rgba(0,238,255,0.3); }
.btn-del {
  background: rgba(255,68,85,0.1); color: var(--danger);
  border: 1px solid rgba(255,68,85,0.25);
}
.btn-del:hover { background: rgba(255,68,85,0.22); box-shadow: 0 0 12px rgba(255,68,85,0.2); }

/* ── SYNC ERROR BANNER ──────────────────────────── */
.sync-error-banner {
  background: rgba(255,50,50,0.08);
  border: 1.5px solid rgba(255,80,80,0.3);
  border-radius: 14px; padding: 16px; margin-bottom: 14px;
}
.sync-error-title { font-size: 15px; font-weight: 900; color: #ff6666; margin-bottom: 6px; }
.sync-error-desc { font-size: 12px; color: var(--text2); line-height: 1.7; margin-bottom: 12px; }
.sync-error-steps { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.sync-step { font-size: 12px; color: var(--text); font-weight: 600; line-height: 1.5; }
.sync-rules-box {
  background: #0a0a1a; border: 1px solid rgba(0,238,255,0.2);
  border-radius: 8px; padding: 10px 12px;
  font-family: 'Courier New', monospace; font-size: 11px;
  color: #88ffdd; line-height: 1.8; word-break: break-all;
  user-select: all; -webkit-user-select: all;
}

/* ── SETTINGS ───────────────────────────────────── */
.settings-section { margin-bottom: 22px; }

/* 注意事項セクション */
.notice-section {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); padding: 16px;
}
.notice-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.05);
}
.notice-item:last-child { border-bottom: none; padding-bottom: 0; }
.notice-icon { font-size: 14px; flex-shrink: 0; margin-top: 2px; }
.notice-body { flex: 1; }
.notice-title { font-size: 13px; font-weight: 800; color: var(--text); margin-bottom: 4px; }
.notice-desc { font-size: 12px; color: var(--text3); line-height: 1.7; }
.settings-title {
  font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
  color: var(--text3); text-transform: uppercase; margin-bottom: 10px;
}
.settings-row {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 7px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2);
}
.settings-row-label { font-size: 14px; font-weight: 700; }
.settings-row-sub { font-size: 11px; color: var(--text3); margin-top: 2px; }
.settings-input {
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; color: white; padding: 7px 12px;
  font-size: 14px; width: 90px; text-align: right; font-weight: 700;
}
.settings-input:focus { outline: none; border-color: var(--pink); box-shadow: 0 0 0 3px rgba(255,0,136,0.15); }

.btn-danger-full {
  width: 100%; padding: 13px; border-radius: var(--radius);
  background: rgba(255,68,85,0.08); color: var(--danger);
  border: 1px solid rgba(255,68,85,0.22);
  font-size: 14px; font-weight: 700; cursor: pointer;
  transition: all 0.2s;
}
.btn-danger-full:hover { background: rgba(255,68,85,0.2); box-shadow: 0 0 20px rgba(255,68,85,0.2); }

/* ── TODAY EVENTS ───────────────────────────────── */
.today-events { display: flex; flex-direction: column; gap: 7px; }
.today-event-row {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.025);
  border-radius: 12px; padding: 10px 14px;
  border: 1px solid rgba(255,255,255,0.05);
  transition: background 0.15s;
}
.today-event-row:hover { background: rgba(255,255,255,0.045); }
.today-event-icon { font-size: 20px; }
.today-event-name { font-size: 14px; font-weight: 700; }
.today-event-type { font-size: 11px; color: var(--text3); margin-top: 1px; }
.today-event-xp { font-size: 14px; font-weight: 900; color: var(--green); text-shadow: 0 0 8px rgba(0,255,153,0.4); }
.today-event-time { font-size: 10px; color: var(--text3); margin-top: 2px; }

/* ── MODALS ─────────────────────────────────────── */
.modal { position: fixed; inset: 0; z-index: 100; display: flex; align-items: flex-end; justify-content: center; }
.modal.hidden { display: none; }
.modal-bg { position: absolute; inset: 0; background: rgba(0,0,0,0.75); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.modal-box {
  position: relative; z-index: 1;
  background: rgba(12,12,28,0.92);
  backdrop-filter: blur(32px); -webkit-backdrop-filter: blur(32px);
  border-radius: 24px 24px 0 0;
  border: 1px solid rgba(255,255,255,0.08);
  border-bottom: none;
  width: 100%; max-width: 600px;
  max-height: 90vh; overflow-y: auto;
  animation: slideUp 0.28s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 -8px 40px rgba(0,0,0,0.6);
}
.modal-box-wide { max-height: 92vh; }
.modal-box-sm {
  border-radius: 20px; max-width: 340px;
  margin: auto; border-bottom: 1px solid rgba(255,255,255,0.08);
}
@keyframes slideUp {
  from { transform: translateY(60px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 22px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.modal-header h2 { font-size: 17px; font-weight: 800; }
.modal-close {
  background: rgba(255,255,255,0.07); border: none; color: var(--text2);
  width: 32px; height: 32px; border-radius: 50%;
  font-size: 15px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.modal-close:hover { background: rgba(255,255,255,0.15); color: white; }
.modal-body { padding: 18px 22px; }
.modal-footer {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 14px 22px 22px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* ── FORM ───────────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-group label {
  display: block; font-size: 12px; font-weight: 700;
  color: var(--text2); margin-bottom: 7px; letter-spacing: 0.5px;
}
.req { color: var(--pink); }
.form-input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px; color: white; padding: 12px 16px;
  font-size: 16px; /* iOS: 16px未満だとタップ時にズームされる */ transition: border-color 0.2s, box-shadow 0.2s;
}
.form-input:focus {
  outline: none;
  border-color: rgba(255,0,136,0.6);
  box-shadow: 0 0 0 3px rgba(255,0,136,0.12), 0 0 20px rgba(255,0,136,0.08);
}

.color-grid { display: flex; gap: 10px; flex-wrap: wrap; }
.color-dot {
  width: 34px; height: 34px; border-radius: 50%; cursor: pointer;
  border: 3px solid transparent; transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.color-dot:hover { transform: scale(1.2); }
.color-dot.selected {
  border-color: white; transform: scale(1.2);
  box-shadow: 0 0 12px currentColor;
}

/* ── BUTTONS ────────────────────────────────────── */
.btn-cancel {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  color: var(--text2); border-radius: 12px;
  padding: 11px 20px; font-size: 14px; font-weight: 700; cursor: pointer;
  transition: all 0.15s;
}
.btn-cancel:hover { background: rgba(255,255,255,0.12); color: white; }
.btn-save, .btn-primary {
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: white; border: none; border-radius: 12px;
  padding: 11px 24px; font-size: 14px; font-weight: 800; cursor: pointer;
  box-shadow: 0 0 20px rgba(255,0,136,0.4), 0 4px 12px rgba(0,0,0,0.3);
  transition: box-shadow 0.2s, transform 0.12s;
}
.btn-save:hover, .btn-primary:hover {
  box-shadow: 0 0 32px rgba(255,0,136,0.6), 0 6px 16px rgba(0,0,0,0.4);
}
.btn-save:active, .btn-primary:active { transform: scale(0.97); }
.btn-danger {
  background: rgba(255,68,85,0.12); color: var(--danger);
  border: 1px solid rgba(255,68,85,0.3); border-radius: 12px;
  padding: 11px 20px; font-size: 14px; font-weight: 700; cursor: pointer;
  transition: all 0.15s;
}
.btn-danger:hover { background: rgba(255,68,85,0.25); box-shadow: 0 0 16px rgba(255,68,85,0.2); }

/* ── EVENT MODAL ────────────────────────────────── */
.event-modal-girl { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.event-modal-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 900;
}
.event-confirm-box {
  background: rgba(255,255,255,0.04);
  border-radius: 16px; border: 1px solid rgba(255,255,255,0.07);
  padding: 18px; text-align: center; margin-bottom: 18px;
}
.event-note-wrap label { font-size: 12px; font-weight: 700; color: var(--text2); display: block; margin-bottom: 7px; }

/* ── DETAIL MODAL ───────────────────────────────── */
.detail-hero {
  display: flex; flex-direction: column; align-items: center;
  padding: 22px 0 18px; border-bottom: 1px solid rgba(255,255,255,0.07); margin-bottom: 18px;
}
.detail-avatar {
  width: 80px; height: 80px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; font-weight: 900; color: white; margin-bottom: 12px;
  position: relative;
}
.detail-avatar-ring {
  position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  animation: ringPulse 2s ease-in-out infinite;
}
.detail-name { font-size: 24px; font-weight: 900; margin-bottom: 4px; }
.detail-rank { font-size: 13px; font-weight: 700; margin-bottom: 14px; }
.detail-level-big {
  font-size: 56px; font-weight: 900; line-height: 1; margin-bottom: 4px;
  text-shadow: 0 0 30px currentColor;
}
.detail-level-label { font-size: 11px; color: var(--text3); letter-spacing: 2.5px; margin-bottom: 14px; }
.detail-xp-bar {
  height: 8px; background: rgba(255,255,255,0.07); border-radius: 4px; width: 100%; overflow: hidden; position: relative;
}
.detail-xp-fill {
  height: 100%; border-radius: 4px; transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1);
  position: relative; overflow: hidden;
}
.detail-xp-fill::after {
  content: ''; position: absolute; top: 0; left: -100%; width: 80%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  animation: barShimmer 2.5s ease-in-out infinite;
}
.detail-xp-label { font-size: 11px; color: var(--text3); margin-top: 6px; text-align: center; }

.detail-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 18px; }
.detail-stat {
  background: rgba(255,255,255,0.03); border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  padding: 12px 8px; text-align: center;
}
.detail-stat-v { font-size: 22px; font-weight: 900; }
.detail-stat-l { font-size: 10px; color: var(--text3); margin-top: 3px; }

.history-list {
  display: flex; flex-direction: column; gap: 7px;
  max-height: 260px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.08) transparent;
}
.history-row {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.025); border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.05);
  padding: 9px 13px;
}
.history-icon { font-size: 18px; width: 24px; text-align: center; }
.history-type { font-size: 13px; font-weight: 700; }
.history-note { font-size: 11px; color: var(--text3); }
.history-xp { font-size: 14px; font-weight: 900; color: var(--green); text-shadow: 0 0 8px rgba(0,255,153,0.3); }
.history-time { font-size: 10px; color: var(--text3); margin-top: 2px; }

/* ── REWARD OVERLAY ─────────────────────────────── */
#reward-overlay {
  position: fixed; inset: 0; z-index: 210;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.92);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  animation: fadeIn 0.3s ease;
}
#reward-overlay.hidden { display: none; }

.reward-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  gap: 12px; padding: 40px 32px; text-align: center;
  animation: rewardPop 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes rewardPop {
  0%   { transform: scale(0.5) translateY(30px); opacity: 0; }
  100% { transform: scale(1)   translateY(0);    opacity: 1; }
}
.reward-label {
  font-size: 13px; font-weight: 900; letter-spacing: 4px;
  text-transform: uppercase;
  animation: rewardLabelPulse 1s ease-in-out infinite alternate;
}
@keyframes rewardLabelPulse {
  from { opacity: 0.7; } to { opacity: 1; filter: brightness(1.3); }
}
.reward-icon-wrap {
  position: relative; display: flex; align-items: center; justify-content: center;
  width: 140px; height: 140px; margin: 8px 0;
}
.reward-icon-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 3px solid; animation: rewardRingSpin 3s linear infinite;
}
@keyframes rewardRingSpin {
  from { transform: rotate(0deg); } to { transform: rotate(360deg); }
}
.reward-icon-inner {
  font-size: 72px; line-height: 1;
  animation: rewardIconFloat 2s ease-in-out infinite alternate,
             rewardIconGlow  1.5s ease-in-out infinite alternate;
  position: relative; z-index: 2;
}
@keyframes rewardIconFloat {
  from { transform: translateY(0);    }
  to   { transform: translateY(-8px); }
}
@keyframes rewardIconGlow {
  from { filter: drop-shadow(0 0 10px currentColor); }
  to   { filter: drop-shadow(0 0 30px currentColor) brightness(1.2); }
}
.reward-title {
  font-size: 24px; font-weight: 900; color: #fff;
  letter-spacing: 2px;
}
.reward-desc {
  font-size: 13px; color: rgba(255,255,255,0.5);
  letter-spacing: 1px;
}
.reward-lv {
  font-size: 11px; font-weight: 800; letter-spacing: 2px;
  background: rgba(255,255,255,0.08);
  border-radius: 8px; padding: 4px 12px;
}
.btn-reward-ok {
  margin-top: 8px; padding: 16px 48px;
  border: none; border-radius: 16px;
  color: #fff; font-size: 18px; font-weight: 900;
  letter-spacing: 2px; cursor: pointer;
  box-shadow: 0 4px 24px rgba(0,0,0,0.4);
  animation: rewardBtnPulse 1s ease-in-out infinite alternate;
  transition: transform 0.1s;
}
.btn-reward-ok:active { transform: scale(0.96); }
@keyframes rewardBtnPulse {
  from { box-shadow: 0 4px 24px rgba(0,0,0,0.4); }
  to   { box-shadow: 0 4px 40px currentColor; }
}

/* 放射光 */
.reward-rays {
  position: absolute; inset: 0; display: flex;
  align-items: center; justify-content: center;
  pointer-events: none; z-index: 1;
}
.reward-ray {
  position: absolute; width: 3px; height: 50vh;
  transform-origin: bottom center; bottom: 50%;
  opacity: 0.3; animation: rewardRayFade 2s ease-in-out infinite alternate;
}
@keyframes rewardRayFade {
  from { opacity: 0.1; } to { opacity: 0.4; }
}

/* パーティクル */
.reward-particles {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1;
}
.reward-particle {
  position: absolute;
  animation: rewardParticleFall linear forwards;
}
@keyframes rewardParticleFall {
  0%   { transform: translateY(0) rotate(0deg);   opacity: 1; }
  100% { transform: translateY(110vh) rotate(540deg); opacity: 0; }
}

/* ══════════════════════════════════════════════════
   GOHAN SPECIAL MODE (代表・オーナーとご飯券)
   ══════════════════════════════════════════════════ */

/* 背景 */
#reward-overlay.gohan-mode {
  background: radial-gradient(ellipse at 50% 40%, rgba(120,70,0,0.97) 0%, rgba(10,5,0,0.98) 70%);
  animation: gohanOverlayIn 0.5s ease;
}
#reward-overlay.owner-mode {
  background: radial-gradient(ellipse at 50% 40%, rgba(60,10,100,0.97) 0%, rgba(5,0,15,0.98) 70%);
}
@keyframes gohanOverlayIn {
  0%   { opacity: 0; }
  30%  { opacity: 1; background: rgba(255,220,100,0.15); }
  100% { opacity: 1; }
}

/* スクリーンフラッシュ */
#reward-overlay.gohan-mode::before,
#reward-overlay.owner-mode::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  animation: gohanFlash 0.6s ease forwards;
  pointer-events: none;
}
#reward-overlay.gohan-mode::before {
  background: radial-gradient(ellipse at center, rgba(255,220,100,0.6), transparent 70%);
}
#reward-overlay.owner-mode::before {
  background: radial-gradient(ellipse at center, rgba(200,140,255,0.6), transparent 70%);
}
@keyframes gohanFlash {
  0%   { opacity: 1; }
  100% { opacity: 0; }
}

/* コンテンツ入場 */
.gohan-mode .reward-content,
.owner-mode .reward-content {
  animation: gohanPop 0.75s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes gohanPop {
  0%   { transform: scale(0.1) rotate(-15deg) translateY(60px); opacity: 0; }
  50%  { transform: scale(1.18) rotate(3deg)  translateY(-10px); opacity: 1; }
  75%  { transform: scale(0.95) rotate(-1deg) translateY(0); }
  100% { transform: scale(1)    rotate(0deg)  translateY(0); opacity: 1; }
}

/* アイコンエリア拡大 */
.gohan-mode .reward-icon-wrap,
.owner-mode .reward-icon-wrap {
  width: 190px; height: 190px;
}

/* アイコン本体 */
.gohan-mode .reward-icon-inner {
  font-size: 100px;
  animation: gohanIconFloat 1.6s ease-in-out infinite alternate,
             gohanIconGlow  1s   ease-in-out infinite alternate;
}
.owner-mode .reward-icon-inner {
  font-size: 100px;
  animation: gohanIconFloat 1.6s ease-in-out infinite alternate,
             ownerIconGlow  0.9s ease-in-out infinite alternate;
}
@keyframes gohanIconFloat {
  from { transform: translateY(0) scale(1)    rotate(-3deg); }
  to   { transform: translateY(-14px) scale(1.08) rotate(3deg); }
}
@keyframes gohanIconGlow {
  from { filter: drop-shadow(0 0 16px #ffd700) drop-shadow(0 0 32px #ff8800); }
  to   { filter: drop-shadow(0 0 40px #ffd700) drop-shadow(0 0 80px #ffbb00) brightness(1.4); }
}
@keyframes ownerIconGlow {
  from { filter: drop-shadow(0 0 16px #cc88ff) drop-shadow(0 0 40px #aa44ff); }
  to   { filter: drop-shadow(0 0 50px #ffffff) drop-shadow(0 0 100px #cc88ff) brightness(1.5); }
}

/* リング（メイン） */
.gohan-mode .reward-icon-ring {
  border-width: 5px;
  animation: rewardRingSpin 1.2s linear infinite;
  box-shadow: 0 0 20px #ffd70088, 0 0 40px #ff880044;
}
.owner-mode .reward-icon-ring {
  border-width: 5px;
  animation: rewardRingSpin 1.2s linear infinite;
  box-shadow: 0 0 20px #cc88ff88, 0 0 50px #aa44ff44;
}

/* 追加リング（JS動的生成） */
.gohan-ring-extra {
  position: absolute; border-radius: 50%;
  border: 2px solid; pointer-events: none;
}
.gohan-ring-extra.ring-out1 {
  inset: -20px;
  animation: gohanRingPulse 1.8s ease-in-out infinite;
}
.gohan-ring-extra.ring-out2 {
  inset: -40px;
  animation: gohanRingPulse 1.8s ease-in-out 0.6s infinite;
}
.gohan-ring-extra.ring-out3 {
  inset: -60px;
  animation: gohanRingPulse 1.8s ease-in-out 1.2s infinite;
}
@keyframes gohanRingPulse {
  0%   { transform: scale(1);   opacity: 0.9; }
  100% { transform: scale(1.5); opacity: 0;   }
}

/* ラベル */
.gohan-mode .reward-label {
  font-size: 15px; letter-spacing: 6px;
  animation: gohanLabelPulse 0.8s ease-in-out infinite alternate;
}
.owner-mode .reward-label {
  font-size: 15px; letter-spacing: 6px;
  animation: ownerLabelPulse 0.8s ease-in-out infinite alternate;
}
@keyframes gohanLabelPulse {
  from { opacity: 0.7; text-shadow: 0 0 8px #ffd700; }
  to   { opacity: 1;   text-shadow: 0 0 24px #ffd700, 0 0 40px #ff8800; }
}
@keyframes ownerLabelPulse {
  from { opacity: 0.7; text-shadow: 0 0 8px #cc88ff; }
  to   { opacity: 1;   text-shadow: 0 0 24px #ffffff, 0 0 40px #cc88ff; }
}

/* タイトル（シャイニングテキスト） */
.gohan-mode .reward-title {
  font-size: 28px;
  background: linear-gradient(90deg, #aa6600, #ffd700, #fff8dc, #ffa500, #ffd700, #aa6600);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-size: 300% 100%;
  animation: gohanTitleShine 1.8s linear infinite;
  text-shadow: none;
}
.owner-mode .reward-title {
  font-size: 28px;
  background: linear-gradient(90deg, #6600cc, #cc88ff, #ffffff, #ff88cc, #cc88ff, #6600cc);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-size: 300% 100%;
  animation: ownerTitleShine 1.4s linear infinite;
  text-shadow: none;
}
@keyframes gohanTitleShine {
  0%   { background-position: 150% 0; }
  100% { background-position: -150% 0; }
}
@keyframes ownerTitleShine {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* 説明文 */
.gohan-mode .reward-desc,
.owner-mode .reward-desc {
  font-size: 15px; color: rgba(255,255,255,0.8);
  letter-spacing: 1.5px;
}

/* ボタン */
.gohan-mode .btn-reward-ok {
  background: linear-gradient(135deg, #ffd700, #ff8800) !important;
  font-size: 20px; padding: 18px 56px;
  animation: gohanBtnPulse 1s ease-in-out infinite alternate;
}
.owner-mode .btn-reward-ok {
  background: linear-gradient(135deg, #aa44ff, #ff44cc) !important;
  font-size: 20px; padding: 18px 56px;
  animation: ownerBtnPulse 1s ease-in-out infinite alternate;
}
@keyframes gohanBtnPulse {
  from { box-shadow: 0 4px 20px #ffd70066; transform: scale(1); }
  to   { box-shadow: 0 4px 50px #ffd700cc, 0 0 80px #ff880044; transform: scale(1.04); }
}
@keyframes ownerBtnPulse {
  from { box-shadow: 0 4px 20px #aa44ff66; transform: scale(1); }
  to   { box-shadow: 0 4px 50px #cc88ffcc, 0 0 80px #aa44ff44; transform: scale(1.04); }
}

/* スパークル（JS生成要素）*/
.gohan-sparkle {
  position: absolute; pointer-events: none; font-size: 20px;
  animation: gohanSparkle var(--dur,1.2s) ease-in-out var(--delay,0s) infinite;
}
@keyframes gohanSparkle {
  0%   { transform: scale(0) rotate(0deg);   opacity: 0; }
  40%  { opacity: 1; }
  100% { transform: scale(1.6) rotate(200deg); opacity: 0; }
}

/* 花火（JS生成要素）*/
.gohan-firework {
  position: absolute; width: 8px; height: 8px;
  border-radius: 50%; pointer-events: none;
  animation: gohanFirework var(--dur,1s) ease-out var(--delay,0s) infinite;
}
@keyframes gohanFirework {
  0%   { transform: translate(0,0) scale(1.2); opacity: 1; }
  100% { transform: translate(var(--tx,50px), var(--ty,-80px)) scale(0); opacity: 0; }
}

/* 放射光（ゴハン強化） */
.gohan-mode .reward-ray,
.owner-mode .reward-ray {
  width: 5px; height: 60vh; opacity: 0.5;
  animation: gohanRayFade 1.2s ease-in-out infinite alternate;
}
@keyframes gohanRayFade {
  from { opacity: 0.15; }
  to   { opacity: 0.55; }
}

/* ── LEVEL UP OVERLAY ───────────────────────────── */
#levelup-overlay {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.88);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  animation: fadeIn 0.3s ease;
}
#levelup-overlay.hidden { display: none; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.levelup-content {
  position: relative; z-index: 1; text-align: center;
  padding: 36px 44px;
  background: rgba(12,12,32,0.95);
  backdrop-filter: blur(32px); -webkit-backdrop-filter: blur(32px);
  border-radius: 28px;
  border: 1px solid rgba(255,0,136,0.4);
  box-shadow:
    0 0 60px rgba(255,0,136,0.3),
    0 0 120px rgba(119,0,255,0.2),
    0 0 200px rgba(0,238,255,0.1),
    inset 0 1px 0 rgba(255,255,255,0.08);
  animation: scaleInBounce 0.55s cubic-bezier(0.34,1.56,0.64,1);
  max-width: 330px; width: 90%;
}
@keyframes scaleIn {
  from { transform: scale(0.4) rotate(-5deg); opacity: 0; }
  to   { transform: scale(1)   rotate(0deg);  opacity: 1; }
}

.levelup-badge {
  font-size: 30px; font-weight: 900; letter-spacing: 5px;
  background: linear-gradient(135deg, var(--pink), var(--gold), var(--cyan));
  background-size: 200% 200%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: gradientShift 1.5s ease infinite alternate;
  margin-bottom: 10px;
}
@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}
.levelup-name { font-size: 26px; font-weight: 900; margin-bottom: 8px; }
.levelup-arrow { font-size: 16px; color: var(--text3); margin-bottom: 8px; animation: bounce 0.6s ease infinite alternate; }
@keyframes bounce { from { transform: translateY(0); } to { transform: translateY(4px); } }
.levelup-num {
  font-size: 80px; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, var(--gold), var(--orange), var(--gold));
  background-size: 200% 200%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: gradientShift 2s ease infinite alternate;
  margin-bottom: 6px;
  filter: drop-shadow(0 0 20px rgba(255,215,0,0.4));
}
.levelup-rank { font-size: 20px; font-weight: 800; margin-bottom: 28px; }
.btn-levelup-ok {
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: white; border: none; border-radius: 30px;
  padding: 14px 40px; font-size: 17px; font-weight: 800; cursor: pointer;
  box-shadow: 0 0 28px rgba(255,0,136,0.5), 0 6px 20px rgba(0,0,0,0.4);
  transition: transform 0.12s, box-shadow 0.2s;
  animation: btnPop 0.5s cubic-bezier(0.34,1.56,0.64,1) 0.4s both;
}
@keyframes btnPop { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.btn-levelup-ok:hover { transform: scale(1.06); box-shadow: 0 0 40px rgba(255,0,136,0.7); }
.btn-levelup-ok:active { transform: scale(0.96); }

/* 記念カードボタン */
.btn-levelup-card {
  display: block; margin: 10px auto 0;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 20px; color: rgba(255,255,255,0.7);
  font-size: 13px; font-weight: 700; padding: 9px 24px;
  cursor: pointer; letter-spacing: 1px;
  transition: background 0.2s, color 0.2s;
}
.btn-levelup-card:hover { background: rgba(255,255,255,0.14); color: #fff; }
.btn-levelup-card:active { transform: scale(0.97); }

/* ══════════════════════════════════════════════════
   MVP OVERLAY
   ══════════════════════════════════════════════════ */
#mvp-overlay {
  position: fixed; inset: 0; z-index: 220;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(ellipse at 50% 35%, rgba(80,50,0,0.97) 0%, rgba(4,2,0,0.98) 70%);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  animation: mvpIn 0.5s ease;
}
#mvp-overlay.hidden { display: none; }
@keyframes mvpIn { from { opacity:0; } to { opacity:1; } }

.mvp-content {
  position: relative; z-index: 2; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 44px 36px;
  background: rgba(10,6,0,0.7);
  border-radius: 32px;
  border: 1px solid rgba(255,215,0,0.5);
  box-shadow: 0 0 60px rgba(255,215,0,0.25), 0 0 120px rgba(255,140,0,0.15);
  max-width: 340px; width: 90%;
  animation: mvpPop 0.7s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes mvpPop {
  0%   { transform: scale(0.2) rotate(-8deg); opacity:0; }
  60%  { transform: scale(1.12) rotate(2deg); opacity:1; }
  100% { transform: scale(1) rotate(0); opacity:1; }
}

.mvp-crown-wrap { position: relative; display: flex; justify-content: center; align-items: center; width: 100px; height: 100px; }
.mvp-crown { font-size: 64px; animation: mvpCrownFloat 1.4s ease-in-out infinite alternate, mvpCrownGlow 1s ease-in-out infinite alternate; }
@keyframes mvpCrownFloat { from { transform: translateY(0) rotate(-5deg) scale(1); } to { transform: translateY(-10px) rotate(5deg) scale(1.08); } }
@keyframes mvpCrownGlow { from { filter: drop-shadow(0 0 12px #ffd700); } to { filter: drop-shadow(0 0 30px #ffd700) drop-shadow(0 0 60px #ff8800) brightness(1.3); } }
.mvp-crown-ring {
  position: absolute; inset: -8px; border-radius: 50%;
  border: 3px solid #ffd700; opacity: 0.7;
  animation: mvpRingPulse 1.6s ease-in-out infinite;
}
.mvp-crown-ring.r2 { inset: -24px; animation-delay: 0.8s; border-color: #ff8800; }
@keyframes mvpRingPulse { 0%{transform:scale(1);opacity:0.7;} 100%{transform:scale(1.4);opacity:0;} }

.mvp-label {
  font-size: 14px; font-weight: 900; letter-spacing: 4px; color: #ffd700;
  text-shadow: 0 0 20px #ffd700, 0 0 40px #ff8800;
  animation: mvpLabelPulse 1s ease-in-out infinite alternate;
}
@keyframes mvpLabelPulse {
  from { opacity: 0.8; letter-spacing: 4px; }
  to   { opacity: 1; letter-spacing: 5px; text-shadow: 0 0 30px #ffd700, 0 0 60px #ff8800; }
}

.mvp-avatar-wrap { position: relative; }
.mvp-avatar {
  width: 90px; height: 90px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; font-weight: 900; color: #fff;
  border: 4px solid #ffd700;
  box-shadow: 0 0 0 6px rgba(255,215,0,0.25), 0 0 40px rgba(255,215,0,0.4);
  animation: mvpAvatarGlow 1.5s ease-in-out infinite alternate;
  overflow: hidden;
}
@keyframes mvpAvatarGlow {
  from { box-shadow: 0 0 0 4px rgba(255,215,0,0.3), 0 0 30px rgba(255,215,0,0.3); }
  to   { box-shadow: 0 0 0 8px rgba(255,215,0,0.5), 0 0 60px rgba(255,215,0,0.6); }
}

.mvp-name {
  font-size: 30px; font-weight: 900; letter-spacing: 2px;
  background: linear-gradient(90deg, #aa6600, #ffd700, #fff8dc, #ffa500, #ffd700);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-size: 300% 100%;
  animation: gohanTitleShine 1.8s linear infinite;
}
.mvp-xp {
  font-size: 22px; font-weight: 900; color: #ffd700;
  text-shadow: 0 0 20px #ffd70088;
  letter-spacing: 1px;
}
.mvp-sub { font-size: 13px; color: rgba(255,255,255,0.6); letter-spacing: 1px; }

.btn-mvp-ok {
  margin-top: 4px; padding: 16px 52px;
  border: none; border-radius: 28px;
  background: linear-gradient(135deg, #ffd700, #ff8800);
  color: #fff; font-size: 19px; font-weight: 900; letter-spacing: 2px; cursor: pointer;
  animation: gohanBtnPulse 1s ease-in-out infinite alternate;
}
.btn-mvp-ok:active { transform: scale(0.96); }

/* MVP 放射光 / パーティクル */
.mvp-rays { position: absolute; inset: 0; pointer-events: none; z-index: 1; display: flex; align-items: center; justify-content: center; }
.mvp-ray { position: absolute; width: 4px; height: 55vh; transform-origin: bottom center; bottom: 50%; opacity: 0.4; animation: gohanRayFade 1.4s ease-in-out infinite alternate; }
.mvp-particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }

/* ══════════════════════════════════════════════════
   TITLES (称号) SECTION
   ══════════════════════════════════════════════════ */
.titles-card { }
.titles-wrap { display: flex; flex-wrap: wrap; gap: 8px; }
.title-chip {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 20px; padding: 6px 12px;
  font-size: 12px; color: rgba(255,255,255,0.8); font-weight: 700;
  cursor: pointer; transition: all 0.15s;
}
.title-chip:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.25); }
.title-chip.title-active {
  background: rgba(255,215,0,0.12);
  border-color: rgba(255,215,0,0.5);
  color: #ffd700;
  box-shadow: 0 0 14px rgba(255,215,0,0.2);
}
.title-chip-icon { font-size: 16px; }
.title-chip-name { letter-spacing: 0.5px; }
.title-chip-new {
  font-size: 9px; background: #ff0088; color: #fff;
  border-radius: 6px; padding: 1px 5px; font-weight: 900; letter-spacing: 0.5px;
}
.titles-count { font-size: 11px; color: var(--text3); margin-bottom: 10px; }

/* ストリーク表示 */
.streak-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(255,100,0,0.15);
  border: 1px solid rgba(255,100,0,0.4);
  border-radius: 12px; padding: 3px 10px;
  font-size: 12px; font-weight: 800; color: #ff6600;
  animation: streakGlow 1.5s ease-in-out infinite alternate;
}
@keyframes streakGlow {
  from { box-shadow: none; }
  to   { box-shadow: 0 0 12px rgba(255,100,0,0.4); }
}

/* タイトル称号表示（プロフィール上部） */
.active-title-display {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 800;
  background: rgba(255,215,0,0.1);
  border: 1px solid rgba(255,215,0,0.35);
  border-radius: 16px; padding: 4px 14px;
  color: #ffd700; letter-spacing: 0.5px;
  animation: titleGlow 2s ease-in-out infinite alternate;
}
@keyframes titleGlow {
  from { box-shadow: none; }
  to   { box-shadow: 0 0 16px rgba(255,215,0,0.3); }
}

/* ── PARTICLES ──────────────────────────────────── */
.particles { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.particle {
  position: absolute; border-radius: 50%;
  animation: fall linear infinite;
}
@keyframes fall {
  0%   { transform: translateY(-10px) rotate(0deg) scale(1); opacity: 1; }
  80%  { opacity: 0.8; }
  100% { transform: translateY(105vh) rotate(720deg) scale(0.5); opacity: 0; }
}

/* ── TOAST ──────────────────────────────────────── */
#toast-container {
  position: fixed; bottom: calc(var(--nav-h) + 44px); left: 50%;
  transform: translateX(-50%); z-index: 150;
  display: flex; flex-direction: column; gap: 8px; align-items: center;
  pointer-events: none; width: 92%; max-width: 380px;
}
.toast {
  background: rgba(12,12,28,0.95);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  padding: 12px 16px;
  display: flex; align-items: center; gap: 12px;
  pointer-events: auto; width: 100%;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04);
  animation: toastIn 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes toastIn {
  from { transform: translateY(30px) scale(0.9); opacity: 0; }
  to   { transform: translateY(0)    scale(1);   opacity: 1; }
}
.toast-icon { font-size: 22px; }
.toast-title { font-size: 14px; font-weight: 700; }
.toast-sub { font-size: 11px; color: var(--text3); margin-top: 1px; }
.toast.toast-success { border-color: rgba(0,255,153,0.25); box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 20px rgba(0,255,153,0.08); }
.toast.toast-info    { border-color: rgba(0,238,255,0.2); }
.toast.toast-warn    { border-color: rgba(255,215,0,0.25); }

/* ── EMPTY / NO STAFF ───────────────────────────── */
.empty-state {
  text-align: center; padding: 32px 16px;
  color: var(--text3); font-size: 13px;
}
.empty-icon { font-size: 44px; margin-bottom: 10px; opacity: 0.6; }

.no-staff {
  text-align: center; padding: 48px 20px;
  color: var(--text3);
}
.no-staff-icon { font-size: 52px; margin-bottom: 14px; opacity: 0.5; }
.no-staff-text { font-size: 15px; margin-bottom: 24px; }

/* ── SECTION HEADER ─────────────────────────────── */
.section-hd { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.section-hd-title { font-size: 14px; font-weight: 800; color: var(--text2); letter-spacing: 0.5px; flex: 1; }
.section-hd-badge {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px; padding: 3px 12px; font-size: 12px; color: var(--text3); font-weight: 600;
}

/* ── ANIMATIONS ON LOAD ─────────────────────────── */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(22px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.anim-in {
  animation: fadeSlideUp 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}

/* ── SPARKLE EFFECT ─────────────────────────────── */
@keyframes sparkle {
  0%,100% { transform: scale(0) rotate(0deg);   opacity: 0; }
  50%      { transform: scale(1) rotate(180deg); opacity: 1; }
}
.sparkle {
  position: absolute; pointer-events: none;
  animation: sparkle 0.7s ease both;
  font-size: 14px;
}

/* ── NEON FLICKER ───────────────────────────────── */
@keyframes neonFlicker {
  0%,19%,21%,23%,25%,54%,56%,100% { opacity: 1; }
  20%,24%,55% { opacity: 0.4; }
}

/* ── FLOAT ──────────────────────────────────────── */
@keyframes floatY {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* ── LEVEL UP enhanced ──────────────────────────── */
@keyframes scaleInBounce {
  0%   { transform: scale(0.2) rotate(-8deg); opacity: 0; }
  60%  { transform: scale(1.08) rotate(1deg); opacity: 1; }
  80%  { transform: scale(0.96) rotate(-0.5deg); }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}

/* ── SYNC STATUS ────────────────────────────────── */
.header-right { display:flex; align-items:center; gap:8px; }
.sync-status {
  font-size: 10px; font-weight: 900; letter-spacing: 1px;
  transition: color 0.4s, text-shadow 0.4s;
}
.sync-online      { color:#00ff99; text-shadow:0 0 8px rgba(0,255,153,0.8); animation:syncPulse 2s ease-in-out infinite; }
.sync-offline     { color:#ff9900; text-shadow:0 0 8px rgba(255,153,0,0.7); }
.sync-connecting  { color:#00eeff; text-shadow:0 0 8px rgba(0,238,255,0.7); animation:syncPulse 0.8s ease-in-out infinite; }
.sync-local       { color:#ffd700; text-shadow:0 0 8px rgba(255,215,0,0.6); }
.sync-error       { color:#ff4455; text-shadow:0 0 8px rgba(255,68,85,0.7); }
@keyframes syncPulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

/* ── SETUP SCREEN ───────────────────────────────── */
#setup-screen {
  position: fixed; inset: 0; z-index: 300;
  background: #050510;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  overflow-y: auto;
}
#setup-screen.hidden { display: none; }
.setup-wrap {
  width: 100%; max-width: 420px;
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.setup-logo {
  display: flex; align-items: baseline; gap: 8px;
  letter-spacing: 3px; margin-bottom: 6px;
}
.setup-tagline {
  font-size: 11px; color: var(--text3); letter-spacing: 2px;
  margin-bottom: 4px; text-align: center; text-transform: uppercase;
}
.setup-subtitle {
  font-size: 12px; color: var(--text3); letter-spacing: 1px;
  margin-bottom: 32px; text-align: center;
}
.setup-hero-emoji {
  font-size: 52px; margin-bottom: 12px;
  animation: setupHeroBob 2.5s ease-in-out infinite;
}
@keyframes setupHeroBob {
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-8px) scale(1.06)}
}
.setup-card {
  width: 100%;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.10);
  padding: 26px 22px;
  margin-bottom: 14px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.06);
}
.setup-card-title {
  font-size: 16px; font-weight: 800; margin-bottom: 10px; text-align: center;
  background: linear-gradient(135deg,var(--cyan),var(--purple2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.setup-card-desc {
  font-size: 12px; color: var(--text3); line-height: 1.8;
  text-align: center; margin-bottom: 16px;
}
.setup-code-input {
  text-align: center; font-size: 22px; font-weight: 900;
  letter-spacing: 4px; margin-bottom: 14px;
}
.btn-setup-join {
  width: 100%;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: white; border: none; border-radius: 14px;
  padding: 14px; font-size: 16px; font-weight: 800; cursor: pointer;
  box-shadow: 0 0 24px rgba(255,0,136,0.4);
  transition: box-shadow 0.2s, transform 0.12s;
}
.btn-setup-join:hover { box-shadow: 0 0 36px rgba(255,0,136,0.6); }
.btn-setup-join:active { transform: scale(0.97); }

.setup-divider {
  display: flex; align-items: center; gap: 12px;
  width: 100%; color: var(--text3); font-size: 12px;
  margin: 4px 0 16px;
}
.setup-divider::before, .setup-divider::after {
  content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.08);
}

.btn-setup-new {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text2); border-radius: 14px;
  padding: 13px; font-size: 14px; font-weight: 700; cursor: pointer;
  transition: all 0.15s; margin-bottom: 20px;
}
.btn-setup-new:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); color: white; }

.setup-firebase-warn {
  width: 100%;
  background: rgba(255,153,0,0.08);
  border: 1px solid rgba(255,153,0,0.25);
  border-radius: 14px; padding: 14px;
  font-size: 12px; color: var(--orange); line-height: 1.7;
  text-align: center;
}
.setup-firebase-warn.hidden { display: none; }

/* ── MY PAGE ────────────────────────────────────── */
.girl-name-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.girl-name-btn {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-radius: var(--radius);
  border: 2px solid rgba(255,255,255,0.07);
  padding: 18px 12px; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
  position: relative; overflow: hidden;
}
.girl-name-btn::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--girl-color, var(--pink)) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.2s;
}
.girl-name-btn:hover {
  transform: translateY(-3px) scale(1.02);
  border-color: var(--girl-color, var(--pink));
  box-shadow: 0 8px 28px rgba(0,0,0,0.4), 0 0 20px color-mix(in srgb, var(--girl-color, var(--pink)) 30%, transparent);
}
.girl-name-btn:hover::before { opacity: 0.07; }
.girl-name-btn:active { transform: scale(0.97); }
.girl-name-btn-avatar {
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 900; color: white;
  position: relative; z-index: 1;
}
.girl-name-btn-name {
  font-size: 17px; font-weight: 800; position: relative; z-index: 1;
}
.girl-name-btn-lv {
  font-size: 13px; font-weight: 700; position: relative; z-index: 1;
}

/* My Page Profile Hero */
.mypage-hero {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.07);
  padding: 28px 20px;
  display: flex; flex-direction: column; align-items: center;
  margin-bottom: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  position: relative; overflow: hidden;
}
.mypage-hero::before {
  content: ''; position: absolute; top: -40px; left: 50%; transform: translateX(-50%);
  width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle, var(--girl-color, rgba(255,0,136,0.15)) 0%, transparent 70%);
  pointer-events: none;
}
.mypage-avatar {
  width: 86px; height: 86px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; font-weight: 900; color: white;
  margin-bottom: 14px; position: relative;
}
.mypage-name { font-size: 26px; font-weight: 900; margin-bottom: 6px; }
.mypage-motivation {
  font-size: 13px; color: var(--text2);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px; padding: 4px 14px; margin: 8px 0 16px;
}
.mypage-level-num {
  font-size: 72px; font-weight: 900; line-height: 1;
  margin-bottom: 4px;
  filter: drop-shadow(0 0 20px currentColor);
}
.mypage-total-xp {
  font-size: 36px; font-weight: 900; line-height: 1;
  margin-top: 18px; margin-bottom: 2px;
  filter: drop-shadow(0 0 14px currentColor);
  letter-spacing: -1px;
}
.mypage-mini-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  width: 100%; margin-top: 18px;
}
.mypage-mini-stat {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px; padding: 12px 8px; text-align: center;
}
.mypage-mini-v { font-size: 18px; font-weight: 900; margin-bottom: 4px; }
.mypage-mini-l { font-size: 10px; color: var(--text3); }

/* Shake animation for wrong password */
@keyframes shake {
  0%,100% { transform: translateX(0); }
  20%      { transform: translateX(-10px); }
  40%      { transform: translateX(10px); }
  60%      { transform: translateX(-8px); }
  80%      { transform: translateX(8px); }
}

/* ── DAILY MISSIONS ─────────────────────────────── */
.mission-card { border-color: rgba(255,215,0,0.18) !important; }
.mission-date {
  font-size: 11px; font-weight: 600; color: var(--text3);
  margin-left: 6px; letter-spacing: 0.5px;
}
.mission-item {
  display: flex; flex-direction: column; gap: 8px;
  padding: 11px 12px; border-radius: 12px; margin-bottom: 8px;
  background: rgba(255,215,0,0.04);
  border: 1px solid rgba(255,215,0,0.12);
  transition: background 0.2s;
}
.mission-item.mission-done {
  background: rgba(0,255,153,0.04);
  border-color: rgba(0,255,153,0.15);
  opacity: 0.75;
}
.mission-num {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  font-size: 11px; font-weight: 800;
  color: rgba(255,255,255,0.6);
  display: flex; align-items: center; justify-content: center;
}
.mission-top {
  display: flex; align-items: center; gap: 8px;
}
.mission-icon { font-size: 18px; flex-shrink: 0; }
.mission-text {
  flex: 1; min-width: 0; font-size: 13px; font-weight: 600;
  color: var(--text1); line-height: 1.45;
  word-break: break-word;
}
.mission-bottom {
  display: flex; align-items: center; justify-content: flex-end; gap: 8px;
}
.mission-xp {
  font-size: 15px; font-weight: 900; color: var(--gold);
  flex-shrink: 0; white-space: nowrap;
}
.mission-done-badge {
  font-size: 12px; font-weight: 800; color: var(--green);
  text-align: center; line-height: 1.5;
}
.btn-mission-complete {
  padding: 8px 14px;
  background: linear-gradient(135deg, #ff0088, #7700ff);
  border: none; border-radius: 10px;
  color: #fff; font-size: 13px; font-weight: 900;
  cursor: pointer; white-space: nowrap;
  box-shadow: 0 3px 14px rgba(255,0,136,0.4);
  transition: all 0.15s; display: block;
  letter-spacing: 0.5px;
}
.btn-mission-complete:active { transform: scale(0.93); box-shadow: none; }
.btn-mission-complete:hover { box-shadow: 0 4px 20px rgba(255,0,136,0.6); }

/* ── COOP MISSIONS ──────────────────────────────── */
.coop-card {
  border-color: rgba(170,85,255,0.25) !important;
  animation: coopGlow 3s ease-in-out infinite alternate;
}
@keyframes coopGlow {
  0%   { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 0 rgba(170,85,255,0); }
  100% { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 28px rgba(170,85,255,0.15); }
}
.coop-item {
  display: flex; flex-direction: column; gap: 8px;
  padding: 11px 12px; border-radius: 12px; margin-bottom: 7px;
  background: rgba(170,85,255,0.05);
  border: 1px solid rgba(170,85,255,0.15);
  transition: background 0.2s, border-color 0.2s;
}
.coop-item:hover { background: rgba(170,85,255,0.09); border-color: rgba(170,85,255,0.3); }
.coop-item.coop-done {
  background: rgba(0,255,153,0.04);
  border-color: rgba(0,255,153,0.15);
  opacity: 0.72;
}
.coop-top { display: flex; align-items: center; gap: 10px; }
.coop-bottom { display: flex; align-items: center; justify-content: flex-end; gap: 8px; }
.coop-icon { font-size: 22px; flex-shrink: 0; }
.coop-text {
  flex: 1; min-width: 0; font-size: 13px; font-weight: 600;
  color: var(--text1); line-height: 1.4;
  word-break: break-word;
}
.coop-xp {
  font-size: 14px; font-weight: 900; color: var(--purple2);
  white-space: nowrap; margin-bottom: 4px;
  text-shadow: 0 0 10px rgba(170,85,255,0.6);
}
.coop-done-badge {
  font-size: 12px; font-weight: 800; color: var(--green);
  text-align: center; line-height: 1.5;
}
.btn-coop {
  padding: 7px 12px;
  background: linear-gradient(135deg, #7700ff, #aa55ff);
  border: none; border-radius: 10px;
  color: #fff; font-size: 12px; font-weight: 900;
  cursor: pointer; white-space: nowrap; display: block;
  box-shadow: 0 3px 14px rgba(119,0,255,0.5);
  transition: all 0.15s; letter-spacing: 0.5px;
  animation: coopBtnPulse 2.5s ease-in-out infinite alternate;
}
.btn-coop:hover  { box-shadow: 0 4px 20px rgba(119,0,255,0.7); transform: scale(1.05); }
.btn-coop:active { transform: scale(0.93); box-shadow: none; }
@keyframes coopBtnPulse {
  0%   { box-shadow: 0 3px 14px rgba(119,0,255,0.4); }
  100% { box-shadow: 0 3px 20px rgba(170,85,255,0.7), 0 0 30px rgba(119,0,255,0.2); }
}

/* ── PARAM STATUS BARS ──────────────────────────── */
.param-section {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.param-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2px;
}
.param-section-title {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.5);
}
.param-section-ceil {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.28);
  background: rgba(255,255,255,0.06);
  padding: 2px 8px;
  border-radius: 20px;
}
.param-row {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.04);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.06);
}
.param-row-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.param-row-icon {
  font-size: 20px;
  line-height: 1;
  flex-shrink: 0;
  width: 28px;
  text-align: center;
}
.param-row-info { flex: 1; min-width: 0; }
.param-row-name {
  font-size: 13px;
  font-weight: 800;
  color: var(--text1);
  line-height: 1.2;
}
.param-row-desc {
  font-size: 10px;
  color: rgba(255,255,255,0.32);
  margin-top: 2px;
}
.param-row-right {
  text-align: right;
  flex-shrink: 0;
}
.param-row-val {
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.param-row-max {
  font-size: 10px;
  color: rgba(255,255,255,0.28);
  font-weight: 600;
  margin-top: 1px;
}
.param-tier-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 900;
  border-radius: 4px;
  padding: 1px 5px;
  margin-left: 5px;
  vertical-align: middle;
  letter-spacing: 0.5px;
}
.param-row-track {
  height: 7px;
  background: rgba(255,255,255,0.07);
  border-radius: 4px;
  overflow: hidden;
}
.param-row-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.7s cubic-bezier(0.22,1,0.36,1);
  min-width: 3px;
}

/* ── EVENT RECORD CARD (new) ────────────────────── */
.ev-btn-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}
@media (max-width: 360px) {
  .ev-btn-grid { grid-template-columns: repeat(3, 1fr); }
}
.ev-btn {
  display: flex; flex-direction: column; align-items: center;
  gap: 3px; padding: 12px 4px 10px;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(255,255,255,0.09);
  border-radius: 18px;
  cursor: pointer; transition: all 0.15s;
  position: relative; overflow: hidden;
}
.ev-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 100%, var(--ev-color, #fff) 0%, transparent 70%);
  opacity: 0.06;
  pointer-events: none;
}
.ev-btn:not([disabled]):hover  { transform: translateY(-3px); border-color: var(--ev-color, #fff); box-shadow: 0 6px 20px color-mix(in srgb, var(--ev-color, #fff) 30%, transparent); }
.ev-btn:not([disabled]):active { transform: scale(0.92); }
.ev-btn-done { opacity: 0.45; cursor: not-allowed !important; }
.ev-btn-icon  { font-size: 30px; }
.ev-btn-name  { font-size: 10px; font-weight: 800; color: var(--text1); }
.ev-btn-total { font-size: 20px; font-weight: 900; line-height: 1.1; }
.ev-btn-unit  { font-size: 10px; font-weight: 700; margin-left: 1px; }
.ev-btn-today { font-size: 9px; font-weight: 600; }

/* ── EXP マイナス修正セクション ── */
.ev-minus-section {
  margin: 14px 0 4px;
  border: 1px solid rgba(255,100,100,0.2);
  border-radius: 12px;
  background: rgba(255,60,60,0.04);
  overflow: hidden;
}
.ev-minus-title {
  font-size: 11px; font-weight: 700; color: rgba(255,180,180,0.7);
  letter-spacing: 1px; padding: 10px 14px 8px;
  border-bottom: 1px solid rgba(255,100,100,0.1);
}
.ev-minus-list { padding: 6px 8px 8px; display: flex; flex-direction: column; gap: 6px; }
.ev-minus-row {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,0.03); border-radius: 10px;
  padding: 8px 10px;
}
.ev-minus-info { display: flex; align-items: center; gap: 7px; }
.ev-minus-icon { font-size: 18px; line-height: 1; }
.ev-minus-name { font-size: 13px; font-weight: 700; color: var(--text); }
.ev-minus-count { font-size: 12px; font-weight: 800; margin-left: 4px; }
.ev-minus-btn {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: rgba(255,60,60,0.15); border: 1.5px solid rgba(255,80,80,0.35);
  border-radius: 10px; color: #ff8888; font-weight: 900; cursor: pointer;
  padding: 6px 12px; min-height: 44px; min-width: 64px;
  transition: background 0.15s, transform 0.12s;
  -webkit-tap-highlight-color: transparent; touch-action: manipulation;
}
.ev-minus-btn:active { background: rgba(255,60,60,0.35); transform: scale(0.94); }
.ev-minus-btn > span:first-child { font-size: 16px; line-height: 1.1; }
.ev-minus-xp { font-size: 9px; color: rgba(255,120,120,0.7); font-weight: 700; letter-spacing: 0.5px; margin-top: 1px; }

/* ── カレンダー ── */
.cal-card {}
.cal-nav {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.cal-nav-btn {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px; color: #fff;
  font-size: 20px; font-weight: 900;
  padding: 4px 16px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s;
}
.cal-nav-btn:active { background: rgba(255,255,255,0.18); }
.cal-month-label {
  font-size: 15px; font-weight: 900; color: #fff; letter-spacing: 1px;
}
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 3px; margin-bottom: 16px;
}
.cal-dow {
  text-align: center; font-size: 10px; font-weight: 800;
  color: var(--text3); padding: 4px 0;
}
.cal-cell {
  display: flex; flex-direction: column; align-items: center;
  justify-content: flex-start; padding: 5px 2px 4px;
  border-radius: 8px; cursor: pointer; min-height: 44px;
  border: 1px solid transparent;
  transition: background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.cal-cell:active { background: rgba(255,255,255,0.1); }
.cal-num {
  font-size: 12px; color: var(--text2); font-weight: 600; line-height: 1.2;
}
.cal-today {
  background: rgba(0,238,255,0.08);
  border-color: rgba(0,238,255,0.3);
}
.cal-today .cal-num { color: var(--cyan); font-weight: 900; }
.cal-sel {
  background: rgba(255,0,136,0.15);
  border-color: rgba(255,0,136,0.5);
}
.cal-sel .cal-num { color: var(--pink); font-weight: 900; }
.cal-dot {
  font-size: 8px; color: #fff; border-radius: 4px;
  padding: 1px 3px; margin-top: 3px; font-weight: 900;
  white-space: nowrap; max-width: 100%; overflow: hidden;
  text-overflow: clip;
}
.cal-sel-label {
  font-size: 13px; font-weight: 700; color: var(--text2);
  margin-bottom: 10px; display: flex; align-items: center; gap: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 14px;
}
.cal-sel-xp {
  font-size: 11px; font-weight: 800; color: var(--cyan);
  background: rgba(0,238,255,0.1); border: 1px solid rgba(0,238,255,0.25);
  border-radius: 6px; padding: 2px 8px;
}

/* パラメーターバー */
.ev-param-section { border-top: 1px solid rgba(255,255,255,0.07); padding-top: 16px; }
.ev-param-title { font-size: 10px; color: rgba(255,255,255,0.4); letter-spacing: 2px; font-weight: 700; margin-bottom: 12px; text-align: center; }
.ev-param-row { display: flex; align-items: center; gap: 8px; margin-bottom: 9px; }
.ev-param-label { display: flex; align-items: center; gap: 4px; font-size: 11px; min-width: 64px; flex-shrink: 0; }
.ev-param-bar-wrap { flex: 1; height: 8px; background: rgba(255,255,255,0.07); border-radius: 99px; overflow: hidden; }
.ev-param-bar { height: 100%; border-radius: 99px; transition: width 0.5s cubic-bezier(0.34,1.56,0.64,1); min-width: 4px; }
.ev-param-val { font-size: 11px; font-weight: 800; min-width: 32px; text-align: right; flex-shrink: 0; }

/* ── SELF RECORD CARD (旧・後方互換) ────────────── */
.self-record-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.self-rec-done { opacity:0.45; cursor:not-allowed!important; }
.self-rec-btn { display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:16px;cursor:pointer;transition:all 0.15s; }
.self-rec-btn:hover { background:rgba(255,255,255,0.09);transform:translateY(-2px); }
.self-rec-btn:active { transform:scale(0.95); }
.self-rec-icon { font-size:28px; }
.self-rec-name { font-size:11px;font-weight:800;color:var(--text1); }
.self-rec-xp   { font-size:11px;font-weight:700; }
.self-rec-count { font-size:10px;color:var(--green);font-weight:700;background:rgba(0,255,153,0.1);border-radius:6px;padding:1px 6px; }

/* ── LIKE CARD ───────────────────────────────────── */
.like-card { }
.like-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.like-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 12px 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  transition: border-color 0.2s;
}
.like-item-done {
  opacity: 0.55;
}
.like-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 900; color: #fff;
  position: relative;
}
.like-name {
  font-size: 12px; font-weight: 800;
  color: var(--text1);
  text-align: center;
  max-width: 64px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.like-done-badge {
  font-size: 11px; color: var(--green); font-weight: 700;
}
.btn-like {
  padding: 6px 10px;
  background: linear-gradient(135deg, rgba(255,136,0,0.15), rgba(255,0,136,0.15));
  border: 1px solid rgba(255,100,100,0.3);
  border-radius: 10px;
  color: var(--pink);
  font-size: 11px; font-weight: 800;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.btn-like:hover {
  background: linear-gradient(135deg, rgba(255,136,0,0.3), rgba(255,0,136,0.3));
  transform: scale(1.05);
  box-shadow: 0 3px 12px rgba(255,0,136,0.3);
}
.btn-like:active { transform: scale(0.95); }

.mypage-param-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  margin: 20px 0 16px;
}
.param-chart-card { overflow: hidden; }
.param-chart-wrap {
  width: 100%;
  padding: 8px 0 4px;
  display: flex;
  justify-content: center;
}
.param-desc-row {
  display: flex;
  justify-content: space-around;
  gap: 4px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.param-desc-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  flex: 1;
  min-width: 48px;
}
.param-desc-icon { font-size: 18px; }
.param-desc-label {
  font-size: 13px;
  font-weight: 900;
  color: var(--text1);
  letter-spacing: 0.5px;
}
.param-desc-sub {
  font-size: 9px;
  color: var(--text3);
  text-align: center;
  line-height: 1.3;
}

/* ── RANK BADGES ────────────────────────────────── */
/* Diamond rainbow effect */
.rank-diamond {
  background: linear-gradient(135deg, #ffffff, #88eeff, #cc88ff, #ffd700, #ffffff);
  background-size: 300% 300%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: rainbowShift 3s ease infinite;
}
@keyframes rainbowShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
/* Platinum glow */
.rank-platinum { text-shadow: 0 0 16px #88eeff, 0 0 32px #44ccff; }
/* Gold glow */
.rank-gold { text-shadow: 0 0 14px #ffd700aa; }

/* ── MY PAGE LOGIN ──────────────────────────────── */
.mypage-login-wrap {
  display: flex; flex-direction: column; align-items: center;
  padding: 28px 20px 24px;
  animation: fadeIn 0.4s cubic-bezier(0.34,1.3,0.64,1);
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.mypage-login-hero { font-size: 56px; margin-bottom: 12px; animation: setupHeroBob 2.5s ease-in-out infinite; }
.mypage-login-title {
  font-size: 26px; font-weight: 900; text-align: center;
  line-height: 1.3; margin-bottom: 6px;
  background: linear-gradient(135deg, var(--pink2), var(--purple2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.mypage-login-sub {
  font-size: 13px; color: var(--text2); text-align: center; margin-bottom: 8px;
}
.mypage-login-hint {
  font-size: 11px; color: var(--text3); text-align: center;
  margin-bottom: 22px; padding: 8px 16px;
  background: rgba(255,255,255,0.04); border-radius: 20px;
}
.mypage-name-input {
  width: 100%; max-width: 320px; font-size: 18px; text-align: center;
  padding: 14px 18px; border-radius: 14px; margin-bottom: 10px;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: #fff; letter-spacing: 1px;
}
.mypage-name-input:focus {
  outline: none; border-color: var(--pink2);
  box-shadow: 0 0 0 3px rgba(255,77,184,0.15);
}
.mypage-error {
  min-height: 18px; color: var(--danger); font-size: 13px;
  text-align: center; margin-bottom: 10px; font-weight: 600;
}
.mypage-divider {
  width: 100%; max-width: 320px; display: flex; align-items: center; gap: 10px;
  margin: 18px 0 12px;
}
.mypage-divider::before,.mypage-divider::after {
  content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.1);
}
.mypage-divider span { font-size: 11px; color: var(--text3); white-space: nowrap; }
.mypage-bday-avatar {
  width: 78px; height: 78px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; font-weight: 900; color: #fff;
  margin-bottom: 14px; position: relative;
  animation: ringPulse 2s ease-in-out infinite;
}
.btn-mp-login {
  width: 100%; max-width: 320px;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: #fff; font-size: 16px; font-weight: 900;
  border: none; border-radius: 14px; padding: 15px;
  cursor: pointer; margin-top: 8px; margin-bottom: 6px;
  box-shadow: 0 4px 20px rgba(255,0,136,0.4);
  transition: transform 0.15s, box-shadow 0.15s;
  letter-spacing: 1px;
}
.btn-mp-login:active { transform: scale(0.97); }
.btn-mp-back {
  background: none; border: none; color: var(--text3);
  font-size: 13px; cursor: pointer; padding: 8px;
  text-decoration: underline; transition: color 0.15s;
}
.btn-mp-back:hover { color: var(--text2); }
.btn-mp-register {
  width: 100%; max-width: 320px;
  background: rgba(255,255,255,0.05);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: var(--text2); font-size: 14px; font-weight: 700;
  border-radius: 14px; padding: 13px;
  cursor: pointer; transition: all 0.15s;
}
.btn-mp-register:hover {
  background: rgba(255,255,255,0.09);
  border-color: var(--pink2); color: var(--pink2);
}
/* Birthday picker base */
.bday-picker {
  display: flex; flex-direction: row; align-items: center;
  gap: 6px; flex-wrap: nowrap; margin-bottom: 4px;
}
.bday-sep {
  font-size: 14px; color: var(--text3); flex-shrink: 0;
}
.bday-select {
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: #fff; border-radius: 10px;
  padding: 10px 8px; font-size: 16px; font-weight: 700; /* iOS zoom防止 */
  cursor: pointer; -webkit-appearance: none; appearance: none;
  min-width: 70px; text-align: center;
}
.bday-select:focus { outline: none; border-color: var(--pink2); }
.bday-picker-lg { gap: 10px; margin-bottom: 6px; }
.bday-select-lg {
  font-size: 17px !important; padding: 12px 10px !important;
  min-width: 90px !important; border-radius: 12px !important;
}

/* ── RIPPLE ─────────────────────────────────────── */
.ripple {
  position: absolute; border-radius: 50%; pointer-events: none;
  background: rgba(255,255,255,0.18);
  transform: scale(0);
  animation: rippleOut 0.55s ease-out forwards;
}
@keyframes rippleOut {
  to { transform: scale(1); opacity: 0; }
}

/* ── TOP3 AVATAR FLOAT ──────────────────────────── */
.top3-card.pos-1 .top3-avatar {
  animation: floatY 2.8s ease-in-out infinite;
}
.top3-card.pos-2 .top3-avatar {
  animation: floatY 3.2s ease-in-out infinite 0.4s;
}
.top3-card.pos-3 .top3-avatar {
  animation: floatY 3s ease-in-out infinite 0.8s;
}

/* ── MYPAGE HERO FLOAT ──────────────────────────── */
.mypage-avatar { animation: floatY 3.5s ease-in-out infinite; }

/* ── MISSION CARD PULSE ─────────────────────────── */
.mission-card {
  animation: missionGlow 3s ease-in-out infinite alternate;
}
@keyframes missionGlow {
  0%   { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 0 rgba(255,215,0,0); }
  100% { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 24px rgba(255,215,0,0.12); }
}

/* ── RANK 1 BADGE GLOW ──────────────────────────── */
.rank-card.rank-1 .rank-badge-overlay {
  animation: badgePop 0.5s cubic-bezier(0.34,1.56,0.64,1) both, goldGlow 2s ease-in-out infinite alternate;
}
@keyframes goldGlow {
  0%   { box-shadow: 0 0 0 rgba(255,215,0,0); }
  100% { box-shadow: 0 0 14px rgba(255,215,0,0.7); }
}

/* ── TOAST ENHANCED ─────────────────────────────── */
.toast { animation: toastIn 0.35s cubic-bezier(0.34,1.56,0.64,1); }

/* ── LEVEL NUMBER PULSE ─────────────────────────── */
.mypage-level-num {
  animation: lvPulse 2s ease-in-out infinite alternate;
}
@keyframes lvPulse {
  0%   { filter: drop-shadow(0 0 12px currentColor); }
  100% { filter: drop-shadow(0 0 28px currentColor) brightness(1.2); }
}

/* ── SETUP LOGO ENTRANCE ────────────────────────── */
.setup-logo {
  animation: fadeSlideUp 0.6s cubic-bezier(0.34,1.56,0.64,1) both;
}
.setup-card {
  animation: fadeSlideUp 0.5s cubic-bezier(0.34,1.56,0.64,1) 0.1s both;
}

/* ── BADGES (MyPage) ────────────────────────────── */
/* ── AVATAR BADGE SLOT ──────────────────────────── */
.avatar-badge-slot {
  position: absolute;
  bottom: -4px; right: -4px;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: #0a0a1a;
  border: 2.5px solid;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  z-index: 3;
  animation: badgeFloat 3s ease-in-out infinite alternate;
}
@keyframes badgeFloat {
  0%   { transform: scale(1) rotate(-5deg); }
  100% { transform: scale(1.08) rotate(5deg); }
}

.mypage-badges-wrap {
  width: 100%; text-align: center; margin: 6px 0;
}
.mypage-badges-label {
  font-size: 10px; color: rgba(255,255,255,0.4);
  letter-spacing: 2px; margin-bottom: 8px;
}
.mypage-badges {
  display: flex; gap: 8px; justify-content: center; flex-wrap: wrap;
  margin: 0 0 4px;
}
.mypage-badge {
  font-size: 26px;
  filter: drop-shadow(0 0 7px currentColor);
  transition: transform 0.2s;
  cursor: pointer;
  position: relative;
}
.mypage-badge:hover { transform: scale(1.22); }
.mypage-badge:active { transform: scale(0.9); }
.badge-equipped {
  transform: scale(1.2);
  filter: drop-shadow(0 0 12px currentColor);
}
.badge-equipped-dot {
  position: absolute;
  bottom: -4px; right: -2px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ff0088;
  border: 1.5px solid #0a0a1a;
  box-shadow: 0 0 6px rgba(255,0,136,0.8);
}
.mypage-badges-more {
  font-size: 11px; color: rgba(255,255,255,0.35);
  letter-spacing: 1px; margin-top: 4px;
}

/* ── AVATAR CAMERA OVERLAY ───────────────────────── */
.avatar-camera-overlay {
  position: absolute; inset: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; background: rgba(0,0,0,0);
  opacity: 0; transition: opacity 0.2s;
  pointer-events: none;
}
.mypage-avatar:hover .avatar-camera-overlay,
.mypage-avatar:active .avatar-camera-overlay {
  opacity: 1; background: rgba(0,0,0,0.45);
}

/* ── FORTUNE CARD ────────────────────────────────── */
.fortune-card {}
.fortune-message {
  font-size: 13px; color: rgba(255,255,255,0.8);
  background: rgba(255,255,255,0.04);
  border-radius: 12px; padding: 12px 14px;
  margin-bottom: 14px; line-height: 1.7;
  border-left: 3px solid var(--gold);
}
.fortune-birthday-badge {
  display: inline-block; background: rgba(255,200,0,0.2);
  color: var(--gold); font-size: 10px; font-weight: 800;
  border-radius: 8px; padding: 2px 8px; margin-left: 6px;
  border: 1px solid rgba(255,200,0,0.4);
}
.fortune-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 8px; margin-bottom: 12px;
}
.fortune-item {
  background: rgba(255,255,255,0.04);
  border-radius: 12px; padding: 10px 6px;
  text-align: center;
}
.fortune-label {
  font-size: 10px; color: rgba(255,255,255,0.4);
  margin-bottom: 4px; font-weight: 600;
}
.fortune-stars {
  font-size: 11px; letter-spacing: 1px;
}
.fortune-lucky-row {
  display: flex; flex-direction: column; gap: 6px;
}
.fortune-lucky-item {
  display: flex; justify-content: space-between;
  align-items: center;
  font-size: 12px; color: rgba(255,255,255,0.45);
  background: rgba(255,255,255,0.03);
  border-radius: 10px; padding: 8px 12px;
}
.fortune-lucky-item span {
  color: rgba(255,255,255,0.8); font-weight: 700;
}

/* ── RANK TABS ───────────────────────────────────── */
.rank-tab-bar {
  display: flex; gap: 8px; margin-bottom: 14px;
}
.rank-tab-btn {
  flex: 1; padding: 12px 0; border-radius: 12px;
  font-size: 13px; font-weight: 800; letter-spacing: 0.5px;
  background: rgba(255,255,255,0.05);
  border: 1.5px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.45); cursor: pointer;
  transition: all 0.2s; min-height: 46px;
  -webkit-tap-highlight-color: transparent;
}
.rank-tab-btn:active { transform: scale(0.96); }
.rank-tab-btn.active {
  background: rgba(255,0,136,0.15);
  border-color: var(--pink);
  color: var(--pink);
  box-shadow: 0 0 20px rgba(255,0,136,0.25);
}

/* ── MESSAGE BOARD ───────────────────────────────── */
.msg-card { padding-bottom: 10px; }
.msg-input-row {
  display: flex; gap: 8px; margin-bottom: 12px;
}
.msg-input {
  flex: 1; background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.1);
  border-radius: 12px; padding: 10px 14px;
  color: #fff; font-size: 13px; outline: none;
  transition: border-color 0.2s;
}
.msg-input:focus { border-color: var(--pink); }
.btn-msg-send {
  padding: 10px 16px; border-radius: 12px;
  background: var(--pink); color: #fff;
  font-size: 13px; font-weight: 800; cursor: pointer;
  border: none; white-space: nowrap;
  transition: opacity 0.2s;
}
.btn-msg-send:active { opacity: 0.7; }
.msg-list { display: flex; flex-direction: column; gap: 8px; }
.msg-row {
  display: flex; align-items: flex-start; gap: 8px;
}
.msg-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 900; flex-shrink: 0;
  color: #fff;
}
.msg-bubble {
  flex: 1; background: rgba(255,255,255,0.05);
  border-radius: 0 12px 12px 12px;
  padding: 6px 10px; min-width: 0;
}
.msg-name { font-size: 10px; font-weight: 800; margin-bottom: 2px; }
.msg-text { font-size: 13px; color: rgba(255,255,255,0.85); word-break: break-all; }
.msg-time {
  font-size: 10px; color: rgba(255,255,255,0.28);
  flex-shrink: 0; padding-top: 6px;
}

/* ── ROULETTE CARD ───────────────────────────────── */
.roulette-card { text-align: center; }
.roulette-wrap {
  display: flex; align-items: center; justify-content: center;
  gap: 10px; margin: 12px 0;
}
.roulette-ptr {
  font-size: 20px; color: var(--pink);
  text-shadow: 0 0 10px rgba(255,0,136,0.6);
}
.roulette-window {
  width: 180px; height: 44px;
  overflow: hidden; border-radius: 10px;
  border: 2px solid rgba(255,0,136,0.4);
  background: rgba(0,0,0,0.5);
  box-shadow: 0 0 20px rgba(255,0,136,0.2), inset 0 0 10px rgba(0,0,0,0.5);
  position: relative;
}
.roulette-strip {
  display: flex; flex-direction: column;
  will-change: transform;
}
.roulette-item {
  height: 44px; display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 900; letter-spacing: 1px;
  flex-shrink: 0;
}
.roulette-done {
  font-size: 12px; color: rgba(255,255,255,0.35);
  padding: 8px 0; letter-spacing: 1px;
}
.btn-roulette-spin {
  width: 100%; padding: 14px;
  background: linear-gradient(135deg, #ff0088, #ff6600);
  border: none; border-radius: 14px;
  color: #fff; font-size: 16px; font-weight: 900;
  letter-spacing: 2px; cursor: pointer;
  box-shadow: 0 4px 20px rgba(255,0,136,0.4);
  transition: transform 0.1s, opacity 0.2s;
}
.btn-roulette-spin:active { transform: scale(0.97); }
.btn-roulette-spin:disabled { opacity: 0.5; cursor: default; }

/* ── RIVAL CARD ──────────────────────────────────── */
.rival-card { text-align: center; }
.rival-wrap {
  display: flex; align-items: center; justify-content: space-around;
  padding: 10px 0;
}
.rival-side { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.rival-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 900; color: #fff;
}
.rival-name { font-size: 13px; font-weight: 800; color: rgba(255,255,255,0.85); }
.rival-lv { font-size: 11px; font-weight: 700; }
.rival-xp { font-size: 10px; color: rgba(255,255,255,0.35); }
.rival-vs {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.rival-vs-text {
  font-size: 20px; font-weight: 900;
  color: rgba(255,255,255,0.5); letter-spacing: 2px;
}
.rival-gap { font-size: 12px; font-weight: 900; }
.rival-msg {
  font-size: 12px; color: rgba(255,255,255,0.6);
  background: rgba(255,255,255,0.04);
  border-radius: 10px; padding: 8px 12px;
  margin-top: 10px; line-height: 1.6;
}

/* ── GROWTH GRAPH CARD ───────────────────────────── */
.graph-card svg { border-radius: 8px; background: rgba(255,255,255,0.02); }

/* ── EXP GUIDE CARD ─────────────────────────────── */
.xp-guide-card { padding-bottom: 8px; }
.xp-guide-list { display: flex; flex-direction: column; gap: 2px; }
.xp-guide-row {
  display: grid;
  grid-template-columns: 28px 1fr auto auto;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  transition: background 0.15s;
}
.xp-guide-row:hover { background: rgba(255,255,255,0.06); }
.xp-guide-icon { font-size: 18px; text-align: center; }
.xp-guide-name { font-size: 13px; font-weight: 700; color: rgba(255,255,255,0.85); }
.xp-guide-note {
  font-size: 10px; color: rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.06);
  border-radius: 6px; padding: 2px 6px;
  white-space: nowrap;
}
.xp-guide-val {
  font-size: 12px; font-weight: 900;
  letter-spacing: 0.5px; white-space: nowrap;
  text-align: right; min-width: 80px;
}

/* ── ITEM BOX CARD ──────────────────────────────── */
.item-box-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.item-box-item {
  background: rgba(255,215,0,0.06);
  border: 1.5px solid rgba(255,215,0,0.22);
  border-radius: 16px;
  padding: 14px 8px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  transition: all 0.2s;
}
.item-box-item:hover { background: rgba(255,215,0,0.12); transform: translateY(-2px); }
.item-box-claimed {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.08);
  opacity: 0.5;
}
.item-box-icon { font-size: 36px; }
.item-box-name { font-size: 12px; font-weight: 800; color: var(--gold); letter-spacing: 0.5px; }
.item-box-desc { font-size: 10px; color: var(--text3); line-height: 1.4; }
.item-box-badge { font-size: 11px; color: var(--text3); margin-top: 2px; }

/* ── THEME SETTINGS CARD ────────────────────────── */
.theme-row-list { display: flex; flex-direction: column; gap: 8px; }
.theme-row-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  padding: 12px 14px;
  cursor: pointer; transition: all 0.2s;
  text-align: left;
}
.theme-row-btn:hover { background: rgba(255,255,255,0.08); transform: translateX(3px); }
.theme-row-active {
  border-color: var(--pink) !important;
  background: rgba(255,0,136,0.1) !important;
  box-shadow: 0 0 18px rgba(255,0,136,0.2);
}
.theme-row-locked { opacity: 0.4; cursor: default !important; }
.theme-row-locked:hover { background: rgba(255,255,255,0.04) !important; transform: none !important; }
.theme-row-left { display: flex; align-items: center; gap: 12px; }
.theme-row-icon { font-size: 26px; }
.theme-row-info { display: flex; flex-direction: column; gap: 2px; }
.theme-row-name { font-size: 15px; font-weight: 800; color: var(--text1); letter-spacing: 1px; }
.theme-row-badge {
  font-size: 10px; font-weight: 700;
  background: var(--pink); color: #fff;
  border-radius: 6px; padding: 1px 7px; display: inline-block;
}
.theme-row-lock-label { font-size: 10px; color: var(--text3); }
.theme-row-swatch {
  width: 44px; height: 44px; border-radius: 12px;
  border: 2px solid;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}

/* ── THEME SELECTOR ─────────────────────────────── */
.theme-selector { margin: 14px 0 6px; width: 100%; text-align: center; }
.theme-grid { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 8px; }
.theme-btn {
  width: 44px; height: 44px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06);
  font-size: 20px; cursor: pointer;
  transition: all 0.2s;
  display: flex; align-items: center; justify-content: center;
}
.theme-btn:hover { transform: scale(1.12); border-color: rgba(255,255,255,0.4); }
.theme-btn-active {
  border-color: var(--pink) !important;
  box-shadow: 0 0 16px rgba(255,0,136,0.55);
  transform: scale(1.15);
}
.theme-btn-locked {
  opacity: 0.35;
  cursor: default !important;
  position: relative;
}
.theme-btn-locked:hover { transform: none !important; border-color: rgba(255,255,255,0.15) !important; }
.theme-lock-overlay {
  position: absolute;
  bottom: -4px; right: -4px;
  font-size: 10px;
  line-height: 1;
}

/* ── UNLOCK LOCK OVERLAY ────────────────────────── */
.unlock-lock {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 28px 16px; gap: 8px;
}
.unlock-lock-icon { font-size: 36px; opacity: 0.45; }
.unlock-lock-title { font-size: 16px; font-weight: 900; color: rgba(255,255,255,0.38); letter-spacing: 1px; }
.unlock-lock-desc { font-size: 12px; color: rgba(255,255,255,0.22); text-align: center; line-height: 1.7; }

/* ── REWARDS CARD ───────────────────────────────── */
.rewards-card {}
.rewards-list { display: flex; flex-direction: column; gap: 7px; }
.reward-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 12px;
  transition: opacity 0.2s;
}
.reward-earned {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.09);
}
.reward-locked {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
  opacity: 0.55;
}
.reward-level { font-size: 11px; font-weight: 800; min-width: 38px; flex-shrink: 0; }
.reward-icon { font-size: 20px; flex-shrink: 0; }
.reward-info { flex: 1; min-width: 0; }
.reward-title { font-size: 13px; font-weight: 800; }
.reward-desc { font-size: 11px; color: var(--text3); margin-top: 2px; }
.reward-check { font-size: 15px; flex-shrink: 0; }
.reward-lock { font-size: 15px; flex-shrink: 0; opacity: 0.35; }
.btn-claim {
  padding: 6px 12px; border-radius: 8px;
  background: linear-gradient(135deg, var(--pink), var(--purple2));
  border: none; color: white;
  font-size: 11px; font-weight: 800;
  cursor: pointer; flex-shrink: 0;
  transition: all 0.15s;
  white-space: nowrap;
}
.btn-claim:hover { transform: scale(1.07); box-shadow: 0 0 12px rgba(255,0,136,0.5); }
.btn-claimed {
  background: rgba(255,255,255,0.07) !important;
  color: rgba(255,255,255,0.28) !important;
  cursor: default !important;
  transform: none !important;
  box-shadow: none !important;
}

/* ── MINIGAME CARD ──────────────────────────────── */
.minigame-card {}
.minigame-locked {
  text-align: center; padding: 24px 16px;
  color: var(--text3);
}
.janken-btns {
  display: flex; gap: 12px; justify-content: center;
  padding: 8px 0 4px;
}
.btn-janken {
  flex: 1; max-width: 90px;
  padding: 16px 8px; border-radius: 18px;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.1);
  color: white; cursor: pointer;
  transition: all 0.2s;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.btn-janken:hover {
  background: rgba(255,0,136,0.18);
  border-color: var(--pink);
  transform: scale(1.08) translateY(-3px);
  box-shadow: 0 8px 24px rgba(255,0,136,0.3);
}
.btn-janken:active { transform: scale(0.96); }
.janken-icon { font-size: 38px; }
.janken-label { font-size: 12px; font-weight: 800; letter-spacing: 1px; }

/* ── MINIGAME CARD GLOW ─────────────────────────── */
.minigame-card {
  animation: minigameGlow 3s ease-in-out infinite alternate;
}
@keyframes minigameGlow {
  0%   { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 0 rgba(0,238,255,0); }
  100% { box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 24px rgba(0,238,255,0.1); }
}

/* ═══════════════════════════════════════════════════
   THEME HERO DESIGNS
   ═══════════════════════════════════════════════════ */

/* ── THEME 0: デフォルト（宇宙）─────────────────── */
.hero-0 { position:relative; overflow:hidden; }
.hero-0::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(180,60,255,0.18) 0%, transparent 70%),
    radial-gradient(ellipse 50% 40% at 80% 80%, rgba(255,0,136,0.12) 0%, transparent 60%);
  animation: heroCosmicDrift 8s ease-in-out infinite alternate;
}
@keyframes heroCosmicDrift {
  0%   { opacity:0.7; transform:scale(1) rotate(0deg); }
  100% { opacity:1;   transform:scale(1.08) rotate(3deg); }
}

/* ── THEME 1: 夜桜 ─────────────────────────────── */
.hero-1 { position:relative; overflow:hidden; }
.hero-1::before {
  content:'🌸';
  position:absolute; top:-10px; left:0; right:0;
  text-align:center; font-size:14px;
  letter-spacing:32px; pointer-events:none; z-index:0; opacity:0;
  animation: sakuraPetal 6s ease-in-out infinite;
}
.hero-1::after {
  content:'🌸';
  position:absolute; top:-10px; left:-30px; right:0;
  text-align:center; font-size:11px;
  letter-spacing:48px; pointer-events:none; z-index:0; opacity:0;
  animation: sakuraPetal 6s ease-in-out 2s infinite;
}
@keyframes sakuraPetal {
  0%   { opacity:0;    transform:translateY(-20px) rotate(0deg); }
  15%  { opacity:0.5; }
  70%  { opacity:0.3;  transform:translateY(340px) rotate(180deg); }
  100% { opacity:0;    transform:translateY(400px) rotate(240deg); }
}

/* ── THEME 2: ネオン（サイバー）─────────────────── */
.hero-2 { position:relative; overflow:hidden; }
.hero-2::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:repeating-linear-gradient(
    0deg,
    transparent 0px, transparent 3px,
    rgba(0,238,255,0.025) 3px, rgba(0,238,255,0.025) 4px
  );
}
.hero-2::after {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:linear-gradient(90deg, transparent 0%, rgba(0,238,255,0.06) 50%, transparent 100%);
  animation: neonSweep 3s ease-in-out infinite;
}
@keyframes neonSweep {
  0%   { transform:translateX(-100%); }
  100% { transform:translateX(100%); }
}

/* ── THEME 3: ゴールド ─────────────────────────── */
.hero-3 { position:relative; overflow:hidden; }
.hero-3::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:radial-gradient(ellipse 70% 50% at 50% 30%, rgba(255,215,0,0.1) 0%, transparent 70%);
  animation: goldPulse 3s ease-in-out infinite alternate;
}
.hero-3::after {
  content:'';
  position:absolute; top:0; left:-60%;
  width:40%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,215,0,0.12), transparent);
  pointer-events:none; z-index:0;
  animation: goldShimmer 4s ease-in-out infinite;
}
@keyframes goldPulse {
  0%   { opacity:0.6; }
  100% { opacity:1; }
}
@keyframes goldShimmer {
  0%   { left:-60%; }
  100% { left:120%; }
}

/* ── THEME 4: ムーン ────────────────────────────── */
.hero-4 { position:relative; overflow:hidden; }
.hero-4::before {
  content:'✦ ✧ ✦ ✧ ✦ ✧ ✦';
  position:absolute; top:14px; left:0; right:0;
  text-align:center; font-size:9px; letter-spacing:14px;
  color:rgba(200,210,255,0.4); pointer-events:none; z-index:0;
  animation: moonStars 4s ease-in-out infinite alternate;
}
.hero-4::after {
  content:'✧ ✦ ✧ ✦ ✧ ✦ ✧';
  position:absolute; bottom:40px; left:0; right:0;
  text-align:center; font-size:8px; letter-spacing:18px;
  color:rgba(180,190,255,0.3); pointer-events:none; z-index:0;
  animation: moonStars 4s ease-in-out 1s infinite alternate;
}
@keyframes moonStars {
  0%   { opacity:0.3; transform:scale(0.95); }
  100% { opacity:1;   transform:scale(1.05); }
}

/* ── THEME 5: フレイム ─────────────────────────── */
.hero-5 { position:relative; overflow:hidden; }
.hero-5::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 90% 70% at 50% 115%, rgba(255,80,0,0.32) 0%, transparent 60%),
    radial-gradient(ellipse 40% 25% at 20% 75%, rgba(255,150,0,0.18) 0%, transparent 50%);
  animation: flameGlow 1.8s ease-in-out infinite alternate;
}
.hero-5::after {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:linear-gradient(0deg,rgba(255,60,0,0.2) 0%,rgba(255,110,0,0.08) 35%,transparent 65%);
  animation: flameFlicker 1.2s ease-in-out infinite alternate;
}
@keyframes flameGlow {
  0%   { opacity:0.65; transform:scaleY(1); }
  100% { opacity:1;    transform:scaleY(1.06); }
}
@keyframes flameFlicker {
  0%   { opacity:0.55; }
  100% { opacity:1; }
}
.hero-5 { animation: flameBorderPulse 1.4s ease-in-out infinite alternate; }
@keyframes flameBorderPulse {
  0%   { border-color:rgba(255,80,0,0.55);  box-shadow:0 0 70px rgba(255,60,0,0.35),0 20px 60px rgba(0,0,0,0.7); }
  100% { border-color:rgba(255,170,0,0.95); box-shadow:0 0 95px rgba(255,110,0,0.6),0 20px 60px rgba(0,0,0,0.7); }
}

/* ── THEME 6: ノワール ─────────────────────────── */
.hero-6 { position:relative; overflow:hidden; }
.hero-6::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.045) 0%,transparent 55%);
}
.hero-6::after {
  content:'';
  position:absolute; top:0; left:-100%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.08),transparent);
  pointer-events:none; z-index:0;
  animation: silverSweep 7s ease-in-out infinite;
}
@keyframes silverSweep {
  0%   { left:-100%; }
  45%  { left:160%; }
  100% { left:160%; }
}
.hero-6 { animation: noirBorderPulse 4s ease-in-out infinite alternate; }
@keyframes noirBorderPulse {
  0%   { border-color:rgba(140,140,140,0.22); }
  100% { border-color:rgba(255,255,255,0.6); box-shadow:0 0 75px rgba(255,255,255,0.09),0 20px 60px rgba(0,0,0,0.95); }
}

/* ── THEME 7: オーロラ ─────────────────────────── */
.hero-7 { position:relative; overflow:hidden; }
.hero-7::before {
  content:'';
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:linear-gradient(180deg,
    rgba(0,255,150,0.11) 0%,
    rgba(0,150,255,0.11) 50%,
    rgba(120,0,255,0.11) 100%
  );
  animation: auroraShift 6s ease-in-out infinite alternate;
}
.hero-7::after {
  content:'✦ ✧ ✦';
  position:absolute; top:14px; left:0; right:0;
  text-align:center; font-size:11px; letter-spacing:22px;
  pointer-events:none; z-index:0;
  animation: auroraStars 3.5s ease-in-out infinite alternate;
}
@keyframes auroraShift {
  0%   { opacity:0.55; transform:skewY(0.8deg); }
  100% { opacity:1;    transform:skewY(-0.8deg); }
}
@keyframes auroraStars {
  0%   { opacity:0.25; color:rgba(0,255,180,0.4); }
  50%  { color:rgba(0,200,255,0.55); }
  100% { opacity:0.8;  color:rgba(160,80,255,0.55); }
}
.hero-7 { animation: auroraBorderPulse 4s ease-in-out infinite; }
@keyframes auroraBorderPulse {
  0%   { border-color:rgba(0,255,150,0.5);  box-shadow:0 0 70px rgba(0,200,150,0.28),0 20px 60px rgba(0,0,0,0.7); }
  33%  { border-color:rgba(0,160,255,0.6);  box-shadow:0 0 80px rgba(0,150,255,0.3), 0 20px 60px rgba(0,0,0,0.7); }
  66%  { border-color:rgba(140,0,255,0.55); box-shadow:0 0 72px rgba(110,0,255,0.26),0 20px 60px rgba(0,0,0,0.7); }
  100% { border-color:rgba(0,255,150,0.5);  box-shadow:0 0 70px rgba(0,200,150,0.28),0 20px 60px rgba(0,0,0,0.7); }
}

/* ── 共通: テーマ内コンテンツ前面化 ──────────────── */
.hero-0>*,.hero-1>*,.hero-2>*,.hero-3>*,.hero-4>*,.hero-5>*,.hero-6>*,.hero-7>* { position:relative; z-index:1; }

/* ── グラデーションテキスト ────────────────────── */
.name-grad {
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ── ネオンテーマ: ボーダーアニメーション ─────── */
.hero-2 {
  animation: neonBorderPulse 2s ease-in-out infinite alternate;
}
@keyframes neonBorderPulse {
  0%   { border-color:rgba(0,238,255,0.55); box-shadow:0 0 70px rgba(0,200,255,0.35),0 20px 60px rgba(0,0,0,0.7); }
  100% { border-color:rgba(0,238,255,0.9);  box-shadow:0 0 90px rgba(0,220,255,0.55),0 20px 60px rgba(0,0,0,0.7),0 0 0 2px rgba(0,238,255,0.1); }
}

/* ── 夜桜テーマ: ボーダーアニメーション ─────── */
.hero-1 {
  animation: sakuraBorderPulse 3s ease-in-out infinite alternate;
}
@keyframes sakuraBorderPulse {
  0%   { border-color:rgba(255,110,175,0.5); }
  100% { border-color:rgba(255,140,195,0.85); box-shadow:0 0 80px rgba(255,70,150,0.38),0 20px 60px rgba(0,0,0,0.7); }
}

/* ── ゴールドテーマ: ボーダーアニメーション ───── */
.hero-3 {
  animation: goldBorderPulse 3s ease-in-out infinite alternate;
}
@keyframes goldBorderPulse {
  0%   { border-color:rgba(255,215,0,0.5); }
  100% { border-color:rgba(255,225,80,0.9); box-shadow:0 0 80px rgba(255,190,0,0.38),0 20px 60px rgba(0,0,0,0.7); }
}

/* ── RESPONSIVE ─────────────────────────────────── */
@media (min-width: 600px) {
  .stat-grid { grid-template-columns: repeat(4, 1fr); }
  .modal { align-items: center; }
  .modal-box { border-radius: 24px; }
}

/* ══════════════════════════════════════════════════
   ── LEGEND テーマ（Lv100+）───────────────────────
   ══════════════════════════════════════════════════ */

/* ヒーローカード本体 */
.hero-legend {
  position: relative; overflow: hidden;
  background: radial-gradient(ellipse 80% 60% at 50% 0%,   rgba(255,180,0,0.18) 0%, transparent 60%),
              radial-gradient(ellipse 60% 40% at 20% 100%, rgba(255,80,180,0.12) 0%, transparent 60%),
              radial-gradient(ellipse 60% 40% at 80% 100%, rgba(80,150,255,0.1) 0%, transparent 60%),
              linear-gradient(180deg, #0a0508 0%, #070310 100%) !important;
  border: 2px solid rgba(255,215,0,0.7) !important;
  box-shadow:
    0 0 0 1px rgba(255,180,0,0.25),
    0 0 40px rgba(255,180,0,0.35),
    0 0 90px rgba(255,120,0,0.2),
    0 0 160px rgba(200,80,255,0.1),
    0 30px 80px rgba(0,0,0,0.8) !important;
  animation: legendBorderPulse 2.5s ease-in-out infinite !important;
}
@keyframes legendBorderPulse {
  0%   { border-color: rgba(255,215,0,0.6); box-shadow: 0 0 40px rgba(255,180,0,0.3), 0 0 90px rgba(255,120,0,0.15), 0 30px 80px rgba(0,0,0,0.8); }
  50%  { border-color: rgba(255,240,100,1); box-shadow: 0 0 60px rgba(255,215,0,0.6), 0 0 120px rgba(255,150,0,0.3), 0 0 8px rgba(255,215,0,0.2) inset, 0 30px 80px rgba(0,0,0,0.8); }
  100% { border-color: rgba(255,215,0,0.6); box-shadow: 0 0 40px rgba(255,180,0,0.3), 0 0 90px rgba(255,120,0,0.15), 0 30px 80px rgba(0,0,0,0.8); }
}

/* 星シャワーキャンバス */
.legend-stars-canvas {
  position: absolute; inset: 0;
  pointer-events: none; z-index: 0; overflow: hidden;
}
.legend-star {
  position: absolute;
  top: -24px;
  display: flex; align-items: center; justify-content: center;
  animation: legendStarFall linear infinite;
}
@keyframes legendStarFall {
  0%   { transform: translateY(0) translateX(0) rotate(0deg) scale(0.3); opacity: 0; }
  8%   { opacity: 1; transform: translateY(40px) translateX(calc(var(--drift)*0.2)) scale(1); }
  90%  { opacity: 0.8; }
  100% { transform: translateY(680px) translateX(var(--drift)) rotate(540deg) scale(0.6); opacity: 0; }
}

/* 浮かぶ王冠 */
.legend-crown-float {
  position: absolute; top: 12px; left: 50%;
  transform: translateX(-50%);
  font-size: 28px; z-index: 2; pointer-events: none;
  animation: legendCrownFloat 2.5s ease-in-out infinite alternate,
             legendCrownGlow 2.5s ease-in-out infinite;
  filter: drop-shadow(0 0 12px rgba(255,215,0,0.9));
}
@keyframes legendCrownFloat {
  0%   { transform: translateX(-50%) translateY(0) rotate(-4deg) scale(1); }
  100% { transform: translateX(-50%) translateY(-8px) rotate(4deg) scale(1.1); }
}
@keyframes legendCrownGlow {
  0%, 100% { filter: drop-shadow(0 0 10px rgba(255,200,0,0.8)); }
  50%       { filter: drop-shadow(0 0 22px rgba(255,220,80,1)) drop-shadow(0 0 40px rgba(255,160,0,0.5)); }
}

/* LEGEND タイトルバッジ */
.legend-title-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 22px; font-weight: 900; letter-spacing: 4px;
  padding: 5px 20px;
  background: linear-gradient(135deg, rgba(255,180,0,0.2), rgba(255,215,0,0.1), rgba(255,180,0,0.2));
  border: 1.5px solid rgba(255,215,0,0.6);
  border-radius: 999px;
  margin-bottom: 4px;
  position: relative; z-index: 1;
  animation: legendTitleShine 3s ease-in-out infinite;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-image: linear-gradient(90deg, #ffd700, #fffaaa, #ffaa00, #ffd700, #fffaaa, #ffaa00);
  background-size: 200%;
}
@keyframes legendTitleShine {
  0%   { background-position: 0%;   }
  50%  { background-position: 100%; }
  100% { background-position: 0%;   }
}
.legend-title-badge {
  /* override text clip for wrapper */
  -webkit-text-fill-color: unset;
  color: #ffd700;
  text-shadow: 0 0 20px rgba(255,215,0,0.8), 0 0 40px rgba(255,150,0,0.4);
  background-image: none;
}
.legend-title-crown { font-size: 20px; }

/* LEGEND レベル数字 */
.legend-level-num {
  font-size: 72px; font-weight: 900; line-height: 1;
  background: linear-gradient(180deg, #fff8a0 0%, #ffd700 40%, #ffaa00 70%, #ff8800 100%);
  background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 16px rgba(255,215,0,0.7));
  animation: legendNumPulse 2s ease-in-out infinite alternate;
  position: relative; z-index: 1;
}
@keyframes legendNumPulse {
  0%   { filter: drop-shadow(0 0 12px rgba(255,215,0,0.6)); transform: scale(1); }
  100% { filter: drop-shadow(0 0 28px rgba(255,215,0,1)) drop-shadow(0 0 50px rgba(255,150,0,0.5)); transform: scale(1.04); }
}
.legend-level-label {
  font-size: 11px; letter-spacing: 3px; color: rgba(255,215,0,0.7);
  margin-bottom: 16px; position: relative; z-index: 1;
}
.legend-actual-lv {
  font-size: 13px; color: rgba(255,215,0,0.55);
  letter-spacing: 2px; margin-bottom: 4px;
  position: relative; z-index: 1;
}

/* LEGEND アバターリング */
@keyframes legendRingPulse {
  0%   { opacity: 0.5; transform: scale(1); }
  50%  { opacity: 1;   transform: scale(1.04); box-shadow: 0 0 12px rgba(255,215,0,0.6); }
  100% { opacity: 0.5; transform: scale(1); }
}

/* ランキング: LEGEND カード */
.rank-legend {
  border-color: rgba(255,215,0,0.45) !important;
  background: linear-gradient(135deg, rgba(255,180,0,0.09) 0%, rgba(255,100,0,0.04) 100%) !important;
  box-shadow: 0 0 24px rgba(255,180,0,0.15), 0 4px 20px rgba(0,0,0,0.5) !important;
}
.rank-legend-badge {
  display: none; /* 名前横バッジは rank-lv に移動済み */
}

/* ランキング: LEGEND レベル表示 */
.rank-lv { font-size: 13px; font-weight: 800; }

/* イベントページ: LEGEND バッジ */
.event-legend-badge {
  display: inline-block;
  font-size: 11px; font-weight: 800;
  padding: 1px 7px; border-radius: 999px;
  background: rgba(255,215,0,0.15);
  border: 1px solid rgba(255,215,0,0.45);
  color: #ffd700;
  letter-spacing: 0.5px;
  animation: legendBadgePulse 2s ease-in-out infinite alternate;
  margin-left: 4px;
}
@keyframes legendBadgePulse {
  0%   { box-shadow: none; }
  100% { box-shadow: 0 0 8px rgba(255,215,0,0.4); }
}

/* ══════════════════════════════════════════════════
   ── タイムイベントバナー ──────────────────────────
   ══════════════════════════════════════════════════ */
.te-banner {
  position: relative; overflow: hidden;
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(135deg, rgba(255,80,0,0.18) 0%, rgba(255,160,0,0.14) 100%);
  border: 1.5px solid rgba(255,130,0,0.55);
  border-radius: 16px; padding: 14px 16px;
  margin-bottom: 14px;
  box-shadow: 0 0 28px rgba(255,100,0,0.22);
  animation: teBannerGlow 2s ease-in-out infinite alternate;
}
@keyframes teBannerGlow {
  0%   { box-shadow: 0 0 22px rgba(255,100,0,0.2);  border-color: rgba(255,130,0,0.45); }
  100% { box-shadow: 0 0 42px rgba(255,170,0,0.45); border-color: rgba(255,200,0,0.85); }
}
.te-banner-icon {
  font-size: 28px; flex-shrink: 0;
  animation: teBannerIconBounce 1s ease-in-out infinite alternate;
}
@keyframes teBannerIconBounce {
  0%   { transform: scale(1) rotate(-5deg); }
  100% { transform: scale(1.15) rotate(5deg); }
}
.te-banner-body { flex: 1; min-width: 0; }
.te-banner-title {
  font-size: 15px; font-weight: 900; color: #ffd700;
  letter-spacing: 0.5px; text-shadow: 0 0 10px rgba(255,200,0,0.6);
}
.te-banner-sub {
  font-size: 12px; color: rgba(255,200,130,0.9); margin-top: 2px;
}
.te-banner-pulse {
  position: absolute; top: 0; left: -60%; width: 35%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,200,0,0.12), transparent);
  animation: teBannerSweep 2.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes teBannerSweep {
  0%   { left: -60%; }
  100% { left: 120%; }
}

/* ══════════════════════════════════════════════════
   ── 全員チャレンジカード ──────────────────────────
   ══════════════════════════════════════════════════ */
.gc-card {
  background: rgba(0,255,150,0.06);
  border: 1.5px solid rgba(0,255,150,0.3);
  border-radius: 16px; padding: 14px 16px;
  margin-bottom: 14px;
  box-shadow: 0 0 20px rgba(0,200,120,0.12);
}
.gc-card-done {
  text-align: center; font-size: 15px; font-weight: 800;
  color: var(--green); padding: 16px;
  background: rgba(0,255,120,0.08);
  border-color: rgba(0,255,120,0.4);
  letter-spacing: 1px;
}
.gc-card-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
}
.gc-card-icon { font-size: 22px; flex-shrink: 0; }
.gc-card-title {
  font-size: 14px; font-weight: 900; color: var(--text); letter-spacing: 0.3px;
}
.gc-card-sub {
  font-size: 11px; color: var(--text2); margin-top: 2px;
}
.gc-card-reward {
  font-size: 16px; font-weight: 900; color: var(--gold);
  text-shadow: 0 0 8px rgba(255,215,0,0.5);
  flex-shrink: 0; text-align: right;
}
.gc-progress-wrap {
  width: 100%; height: 10px;
  background: rgba(255,255,255,0.08);
  border-radius: 999px; overflow: hidden;
  margin-bottom: 6px;
}
.gc-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, #00ff99, #00eeff);
  border-radius: 999px;
  transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 0 8px rgba(0,255,150,0.5);
}
.gc-progress-label {
  font-size: 12px; color: var(--text2); line-height: 1.4;
}

/* ══════════════════════════════════════════════════
   ── チームバトルカード ────────────────────────────
   ══════════════════════════════════════════════════ */
.bt-card {
  background: rgba(120,0,255,0.07);
  border: 1.5px solid rgba(150,50,255,0.35);
  border-radius: 16px; padding: 14px 16px;
  margin-bottom: 14px;
  box-shadow: 0 0 20px rgba(100,0,255,0.12);
}
.bt-card-title {
  font-size: 14px; font-weight: 900; color: var(--text);
  letter-spacing: 0.5px; margin-bottom: 12px;
}
.bt-teams { display: flex; flex-direction: column; gap: 10px; }
.bt-team {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px; padding: 10px 12px;
  transition: border-color 0.2s;
}
.bt-team-lead {
  border-color: rgba(255,215,0,0.45);
  background: rgba(255,215,0,0.06);
  box-shadow: 0 0 14px rgba(255,215,0,0.1);
}
.bt-team-head {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.bt-team-icon { font-size: 18px; flex-shrink: 0; }
.bt-team-name {
  flex: 1; font-size: 14px; font-weight: 800; letter-spacing: 0.5px;
}
.bt-lead-badge {
  font-size: 10px; font-weight: 700; padding: 2px 7px;
  background: rgba(255,215,0,0.2); border: 1px solid rgba(255,215,0,0.5);
  border-radius: 999px; color: var(--gold); letter-spacing: 0.5px;
  animation: btLeadPulse 1.5s ease-in-out infinite alternate;
}
@keyframes btLeadPulse {
  0%   { opacity: 0.75; }
  100% { opacity: 1; box-shadow: 0 0 8px rgba(255,215,0,0.35); }
}
.bt-team-xp {
  font-size: 14px; font-weight: 900;
  flex-shrink: 0; text-align: right;
}
.bt-bar-wrap {
  width: 100%; height: 8px;
  background: rgba(255,255,255,0.07);
  border-radius: 999px; overflow: hidden;
  margin-bottom: 8px;
}
.bt-bar {
  height: 100%; border-radius: 999px;
  transition: width 0.7s cubic-bezier(0.34,1.56,0.64,1);
}
.bt-members { display: flex; flex-wrap: wrap; gap: 5px; }
.bt-member-chip {
  font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: 999px;
  border: 1px solid transparent;
  letter-spacing: 0.3px;
}

/* ── 女の子カード: チームバッジ ─────────────────── */
.girl-team-badge {
  display: inline-block; font-size: 10px; font-weight: 700;
  padding: 1px 7px; border-radius: 999px;
  border: 1px solid transparent;
  margin-left: 6px; vertical-align: middle;
  letter-spacing: 0.3px;
}

/* ── 設定画面: アクティブ表示バッジ ─────────────── */
.te-active-badge {
  display: inline-block; font-size: 13px; font-weight: 800;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(255,130,0,0.18);
  border: 1.5px solid rgba(255,160,0,0.6);
  color: #ffd700; letter-spacing: 1px;
  animation: teBannerGlow 2s ease-in-out infinite alternate;
  margin-bottom: 10px;
}

/* ── ランキング チームタブ ───────────────────────── */
.bt-rank-team {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px; padding: 14px 16px;
  margin-bottom: 10px;
}
.bt-rank-lead {
  border-color: rgba(255,215,0,0.4);
  background: rgba(255,215,0,0.06);
}
.bt-rank-head {
  font-size: 18px; flex-shrink: 0;
}

/* ══════════════════════════════════════════════════
   ── イベント取り消し（undo）チップ ───────────────
   ══════════════════════════════════════════════════ */
.evt-undo-row {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin-top: 6px;
}
.evt-undo-chip {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; font-weight: 700;
  padding: 3px 9px 3px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.15);
  color: var(--text2);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
  -webkit-tap-highlight-color: transparent;
  white-space: nowrap;
}
.evt-undo-chip:hover {
  background: rgba(255,60,80,0.15);
  border-color: rgba(255,80,80,0.45);
  color: #ff8899;
}
.evt-undo-chip:active { transform: scale(0.93); }
.evt-undo-minus {
  font-size: 14px; font-weight: 900;
  color: var(--danger); line-height: 1;
  margin-left: 1px;
}

/* ══════════════════════════════════════════════════
   ── 要望ボックス ──────────────────────────────────
   ══════════════════════════════════════════════════ */
.feedback-card { border-color: rgba(100,200,255,0.25) !important; }

.feedback-note {
  font-size: 12px; color: var(--text3); margin-bottom: 12px; line-height: 1.6;
}
.feedback-form { display: flex; flex-direction: column; gap: 10px; }

.feedback-cats {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.feedback-cat-label {
  display: flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 700; color: var(--text2);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 999px; padding: 5px 12px;
  cursor: pointer; transition: all 0.15s;
}
.feedback-cat-label:has(input:checked) {
  background: rgba(0,200,255,0.15);
  border-color: rgba(0,200,255,0.5);
  color: var(--cyan);
}
.feedback-cat-label input { display: none; }

.feedback-textarea {
  resize: none; min-height: 72px; font-size: 14px; line-height: 1.6;
}
.feedback-sent {
  text-align: center; padding: 16px;
  font-size: 15px; font-weight: 800; color: var(--green);
  line-height: 1.8;
}

/* 管理者側一覧 */
.feedback-unread-badge {
  display: inline-block; font-size: 11px; font-weight: 800;
  padding: 2px 8px; border-radius: 999px;
  background: rgba(255,60,80,0.2); border: 1px solid rgba(255,60,80,0.5);
  color: var(--danger); margin-left: 8px; vertical-align: middle;
}
.feedback-list { display: flex; flex-direction: column; gap: 10px; }
.feedback-item {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px; padding: 12px 14px;
  transition: border-color 0.2s;
}
.feedback-item-unread {
  border-color: rgba(0,200,255,0.35);
  background: rgba(0,200,255,0.05);
}
.feedback-item-head {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.feedback-item-cat {
  font-size: 12px; font-weight: 800; color: var(--cyan);
}
.feedback-item-date {
  font-size: 11px; color: var(--text3); margin-left: auto;
}
.feedback-new-dot {
  font-size: 10px; font-weight: 800; padding: 1px 6px;
  border-radius: 999px; background: rgba(255,60,80,0.2);
  border: 1px solid rgba(255,60,80,0.5); color: var(--danger);
}
.feedback-item-text {
  font-size: 13px; color: var(--text); line-height: 1.6;
  white-space: pre-wrap;
}

/* ナビバッジ */
.feedback-nav-badge {
  position: absolute; top: 4px; right: 8px;
  min-width: 16px; height: 16px; border-radius: 999px;
  background: var(--danger); color: #fff;
  font-size: 9px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  padding: 0 4px; pointer-events: none;
  animation: feedbackBadgePop 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.feedback-nav-badge.hidden { display: none; }
@keyframes feedbackBadgePop {
  0%   { transform: scale(0); }
  100% { transform: scale(1); }
}

/* ── 称号コレクション: ロック中表示 ─────────────── */
.title-chip-locked {
  opacity: 0.45; cursor: default;
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.1) !important;
}
.title-chip-locked:hover {
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.1) !important;
  transform: none !important;
}
.title-chip-lock-icon { font-size: 13px; }
.titles-count { font-size:12px; color:var(--text3); margin-bottom:10px; letter-spacing:0.5px; }

/* ── 個人成長グラフ (Lv4解放) ────────────────────── */
.growth-card {
  background: linear-gradient(135deg,rgba(0,238,255,0.07),rgba(119,0,255,0.09));
  border: 1px solid rgba(0,238,255,0.18);
  border-radius: var(--radius); padding: 18px 16px 14px;
  margin-bottom: 16px;
}
.growth-card-locked {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); padding: 28px 16px;
  margin-bottom: 16px;
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; text-align: center;
}
.growth-lock-icon { font-size: 32px; margin-bottom: 4px; }
.growth-lock-text { font-size: 15px; font-weight: 700; color: var(--cyan); }
.growth-lock-sub  { font-size: 12px; color: var(--text3); }

.growth-stats-row {
  display: flex; gap: 12px; margin-bottom: 14px;
}
.growth-stat {
  flex: 1; background: rgba(255,255,255,0.06);
  border-radius: 10px; padding: 10px 8px; text-align: center;
}
.growth-stat-v {
  font-size: 18px; font-weight: 900;
  background: linear-gradient(135deg,var(--cyan),var(--purple2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.growth-stat-l {
  font-size: 10px; color: var(--text3); margin-top: 2px; letter-spacing: 0.5px;
}

/* bar chart */
.growth-chart {
  display: flex; align-items: flex-end; gap: 4px;
  height: 90px; padding-bottom: 22px; position: relative;
}
.growth-bar-col {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end; height: 100%;
}
.growth-bar-wrap {
  width: 100%; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end;
  flex: 1; position: relative;
}
.growth-bar {
  width: 100%; border-radius: 4px 4px 0 0;
  background: linear-gradient(180deg,var(--cyan) 0%,var(--purple2) 100%);
  min-height: 3px;
  transform-origin: bottom;
  animation: growthBarRise 0.6s cubic-bezier(0.34,1.3,0.64,1) both;
}
.growth-bar-today .growth-bar {
  background: linear-gradient(180deg,var(--gold) 0%,var(--pink) 100%);
  box-shadow: 0 0 8px rgba(255,215,0,0.5);
}
.growth-bar-val {
  font-size: 8px; color: var(--text3); position: absolute;
  top: -14px; left: 50%; transform: translateX(-50%);
  white-space: nowrap;
}
.growth-bar-today .growth-bar-val { color: var(--gold); font-weight: 700; }
.growth-bar-label {
  position: absolute; bottom: -20px;
  font-size: 8px; color: var(--text3);
  white-space: nowrap; left: 50%; transform: translateX(-50%);
}
.growth-bar-label-today { color: var(--gold); font-weight: 700; }

@keyframes growthBarRise {
  0%   { transform: scaleY(0); }
  100% { transform: scaleY(1); }
}

/* ── 月間アワード オーバーレイ ──────────────────── */
#awards-overlay {
  position: fixed; inset: 0; z-index: 9800;
  display: flex; align-items: center; justify-content: center;
}
#awards-overlay.hidden { display: none; }

.awards-bg {
  position: absolute; inset: 0;
  background: linear-gradient(160deg,#0a0018 0%,#050510 50%,#001a0a 100%);
  opacity: 0.96;
}
.awards-particles {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden;
}
.awards-particle {
  position: absolute; top: -16px; border-radius: 50%;
  animation: awardParticleFall linear infinite;
  opacity: 0.7;
}
@keyframes awardParticleFall {
  0%   { transform: translateY(-20px) rotate(0deg); opacity: 0.8; }
  100% { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

.awards-content {
  position: relative; z-index: 1;
  width: min(92vw, 420px);
  background: linear-gradient(160deg,rgba(20,5,50,0.97),rgba(5,5,20,0.97));
  border: 1px solid rgba(255,215,0,0.3);
  border-radius: 24px; padding: 28px 20px 22px;
  box-shadow:
    0 0 60px rgba(255,215,0,0.15),
    0 0 120px rgba(119,0,255,0.2),
    inset 0 1px 0 rgba(255,255,255,0.1);
  animation: awardsContentIn 0.5s cubic-bezier(0.34,1.4,0.64,1) both;
}
@keyframes awardsContentIn {
  0%   { opacity: 0; transform: scale(0.85) translateY(20px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}

.awards-header-row {
  display: flex; align-items: center; justify-content: center;
  gap: 10px; margin-bottom: 18px;
}
.awards-trophy  { font-size: 28px; animation: trophyBob 1.6s ease-in-out infinite; }
.awards-trophy:last-child { animation-delay: 0.8s; }
@keyframes trophyBob {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-6px); }
}
.awards-header-title {
  font-size: 18px; font-weight: 900; letter-spacing: 2px;
  background: linear-gradient(90deg,var(--gold),var(--gold2),var(--gold));
  background-size: 200%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: awardsGoldShimmer 2s linear infinite;
}
@keyframes awardsGoldShimmer {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* slide */
.awards-slide {
  min-height: 200px; display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: 8px;
  animation: awardsSlideIn 0.4s cubic-bezier(0.34,1.3,0.64,1) both;
}
@keyframes awardsSlideIn {
  0%   { opacity: 0; transform: translateX(40px) scale(0.95); }
  100% { opacity: 1; transform: translateX(0) scale(1); }
}
.awards-month-label {
  font-size: 11px; color: var(--text3); letter-spacing: 1px;
  margin-bottom: 2px;
}
.awards-category {
  font-size: 22px; font-weight: 900; color: var(--gold);
  letter-spacing: 1px; margin-bottom: 8px;
}
.awards-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  background: linear-gradient(135deg,var(--pink),var(--purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; margin: 0 auto;
  box-shadow: 0 0 24px rgba(255,0,136,0.5);
  animation: awardsAvatarPop 0.5s cubic-bezier(0.34,1.56,0.64,1) 0.15s both;
}
@keyframes awardsAvatarPop {
  0%   { transform: scale(0); }
  100% { transform: scale(1); }
}
.awards-name {
  font-size: 20px; font-weight: 900; color: #fff;
  margin-top: 4px;
}
.awards-score {
  font-size: 28px; font-weight: 900;
  background: linear-gradient(90deg,var(--cyan),var(--purple2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.awards-unit { font-size: 12px; color: var(--text3); margin-top: -4px; }
.awards-congrats {
  font-size: 13px; color: rgba(255,215,0,0.8);
  letter-spacing: 1px; margin-top: 6px;
  animation: awardsCongratsFade 0.6s ease 0.4s both;
}
@keyframes awardsCongratsFade {
  0%   { opacity: 0; transform: translateY(8px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* dots */
.awards-dots {
  display: flex; justify-content: center; gap: 7px;
  margin: 16px 0 12px;
}
.awards-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.2);
  transition: all 0.3s;
}
.awards-dot-active {
  background: var(--gold);
  box-shadow: 0 0 8px rgba(255,215,0,0.6);
  transform: scale(1.3);
}

/* buttons */
.btn-awards-next {
  display: block; width: 100%;
  padding: 13px 0; border-radius: 12px; border: none;
  background: linear-gradient(135deg,var(--gold),var(--gold2));
  color: #1a0a00; font-size: 15px; font-weight: 900;
  cursor: pointer; letter-spacing: 1px;
  box-shadow: 0 4px 20px rgba(255,215,0,0.35);
  transition: transform 0.15s, box-shadow 0.15s;
}
.btn-awards-next:hover { transform: translateY(-2px); box-shadow: 0 6px 28px rgba(255,215,0,0.5); }
.btn-awards-next:active { transform: translateY(0); }

.btn-awards-skip {
  display: block; width: 100%; margin-top: 8px;
  padding: 8px 0; border-radius: 10px; border: none;
  background: transparent; color: var(--text3);
  font-size: 13px; cursor: pointer;
  transition: color 0.2s;
}
.btn-awards-skip:hover { color: var(--text); }

