
:root{
  --bg:#070812;--panel:#0f1224;--panel2:#14183a;--text:#eef0ff;--muted:#a9add9;
  --accent:#ff5ac8;--accent2:#7c5cff;--danger:#ff4d4d;--ok:#47d18c;--card:#f7f7ff;
  --shadow:0 14px 40px rgba(0,0,0,.45)
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,"Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  background:
    radial-gradient(900px 600px at 30% 10%, rgba(124,92,255,.25), transparent 60%),
    radial-gradient(900px 600px at 70% 30%, rgba(255,90,200,.18), transparent 60%),
    linear-gradient(180deg, #050514, var(--bg));
  color:var(--text);
}
.wrap{max-width:1200px;margin:0 auto;padding:18px}
.header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.brand{display:flex;flex-direction:column;gap:2px}
.brand h1{margin:0;font-size:24px;letter-spacing:.02em}
.brand .sub{color:var(--muted);font-size:12px}
.pill{font-size:12px;color:var(--muted);border:1px solid rgba(255,255,255,.12);padding:6px 10px;border-radius:999px;background:rgba(0,0,0,.2)}
.grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}
@media (max-width: 980px){.grid{grid-template-columns:1fr}}
.panel{background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.panel .hd{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:10px}
.panel .bd{padding:14px}
.row{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.btns{display:flex;gap:10px;flex-wrap:wrap}
button{
  appearance:none;border:0;cursor:pointer;color:#0b0b12;background:var(--text);
  padding:10px 14px;border-radius:12px;font-weight:900;letter-spacing:.02em;
  box-shadow:0 10px 22px rgba(0,0,0,.30);
}
button.secondary{background:rgba(255,255,255,.10);color:var(--text);border:1px solid rgba(255,255,255,.15)}
button.danger{background:var(--danger);color:#13040a}
button:disabled{opacity:.5;cursor:not-allowed}
.bigTitle{font-size:44px;margin:10px 0 0;font-weight:1000;letter-spacing:-.03em}
.center{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:420px;padding:26px}
.kicker{color:var(--muted);letter-spacing:.4em;text-transform:uppercase;font-size:12px;margin-top:6px}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 720px){.duo{grid-template-columns:1fr}}
.avatarRow{display:flex;align-items:center;gap:12px}
.avatar{width:92px;height:92px;border-radius:999px;object-fit:cover;border:3px solid rgba(255,255,255,.20)}
.name{font-weight:1000;font-size:18px}
.bar{height:14px;border-radius:999px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.10);overflow:hidden;min-width:0}
.fill{height:100%;width:50%;background:linear-gradient(90deg, var(--accent2), var(--accent));transition:width .35s ease}
.small{font-size:12px;color:var(--muted)}
.cards{display:flex;gap:10px;flex-wrap:wrap}
.card{
  width:70px;height:92px;border-radius:14px;background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.85));
  color:#0d0f1a;border:2px solid rgba(0,0,0,.10);box-shadow:0 10px 22px rgba(0,0,0,.25);
  padding:8px;display:flex;flex-direction:column;justify-content:space-between;user-select:none;
  transform:translateY(0);transition:transform .12s ease, outline .12s ease, filter .12s ease
}
.card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
.card .v{font-weight:1000;font-size:13px}
.card .s{font-size:22px;line-height:1}
.card .tag{font-size:10px;color:#455;letter-spacing:.02em;text-align:center;font-weight:800}
.card.sel{outline:4px solid rgba(255,90,200,.25);transform:translateY(-8px)}
.card.joker{background:linear-gradient(180deg, rgba(255,232,252,.95), rgba(255,255,255,.85));border-color:rgba(124,92,255,.35)}
.card.lock{background:rgba(0,0,0,.30);border:2px dashed rgba(255,255,255,.18);color:rgba(255,255,255,.55);box-shadow:none}
.logs{display:flex;flex-direction:column;gap:8px}
.log{padding:10px 12px;border-radius:14px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08)}
.log.important{border-color:rgba(255,224,120,.35);background:rgba(255,224,120,.10)}
.log.player{border-color:rgba(255,90,200,.30);background:rgba(255,90,200,.10)}
.log.enemy{border-color:rgba(255,77,77,.28);background:rgba(255,77,77,.10)}
.inv{display:flex;gap:10px;flex-wrap:wrap}
.item{padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);min-width:0}
.item .t{font-weight:1000}
.item .d{font-size:12px;color:var(--muted);margin-top:4px}
.item button{margin-top:8px;padding:8px 10px;border-radius:10px;font-weight:900}
.footerNote{color:var(--muted);font-size:12px;margin-top:10px}


/* === Intermission / Briefing layout === */
.imGrid{
  display:grid;
  grid-template-columns: minmax(260px, 42%) 1fr;
  gap:16px;
  align-items:start;
}
.imPic img{
  width:100%;
  height:auto;
  max-height:66vh;
  object-fit:contain;
  border-radius:16px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.10);
}
.imText{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.imText .hd{
  margin-top:0;
}

/* === Battle top portraits === */
.battleTop{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.charRow{ display:flex; gap:12px; align-items:center; }
.portrait{
  width:120px;
  height:auto;
  max-height:150px;
  object-fit:contain; /* do NOT crop */
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  flex:0 0 auto;
}
.charMeta{ flex:1; min-width:0; }
.bossNote{ margin-top:6px; padding:6px 10px; border-radius:10px; background:rgba(255,84,184,.12); border:1px solid rgba(255,84,184,.25); }


.panel .hd .hdLeft{display:flex;align-items:center;gap:10px;min-width:0}
.bossNoteSide{margin-top:0;padding:4px 8px;border-radius:999px;font-size:12px;line-height:1;white-space:nowrap;max-width:340px;overflow:hidden;text-overflow:ellipsis}


/* === Hands: player/enemy panels (stacked) === */
.handGrid{
  display:grid;
  /* stack: player hand then enemy hand */
  grid-template-columns: 1fr;
  gap:12px;
}
@media (max-width: 980px){
  .imGrid{ grid-template-columns: 1fr; }
  .battleTop{ grid-template-columns: 1fr; }
  .handGrid{ grid-template-columns: 1fr; }
}

/* Player hand: up to 6x2 grid, scroll if more */
#handWrap .cards{
  display:grid;
  /* default: 6 columns grid */
  grid-template-columns: repeat(6, 86px);
  justify-content:start;
  gap:10px;
  /* keep panel height stable */
  height:130px;
  max-height:130px;
  scrollbar-gutter: stable;
  overflow-y:hidden;
  overflow-x:hidden;
  padding-right:6px;
}
/* 7枚以上は横スクロール（欄の大きさは維持） */
#handWrap .cards.scrollX{
  grid-template-columns:none;
  grid-auto-flow:column;
  grid-auto-columns:86px;
  grid-template-rows:98px;
  align-content:start;
  overflow-x:auto;
  overflow-y:hidden;
height: 130px; max-height: 130px;}
#handWrap .card{ width:86px; height:98px; }
#enemyWrap .card{ width:86px; height:98px; }

/* Enemy hand: compact grid (avoid huge cards) */
#enemyWrap .cards{
  display:grid;
  grid-template-columns: repeat(6, 86px);
  justify-content:start;
  gap:10px;
  max-height:170px;
  overflow-y:hidden;
  padding-right:6px;
}

/* === Tabs (Skill / Guide / Log) === */
.tabs{ display:flex; flex-direction:column; gap:10px; }
.tabBtns{ display:flex; gap:8px; flex-wrap:wrap; }
.tabBtn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800;
}
.tabBtn.active{
  background:rgba(153,119,255,.20);
  border-color:rgba(153,119,255,.45);
}
.tabBody{ min-height:420px; }
.tabPane{ height:100%; }

.okDock{
  margin-top:12px;
  display:flex;
  justify-content:flex-end;
}
.okDock .okBtn{
  min-width:140px;
  justify-content:center;
}

/* Battle: keep the Like(OK) button fixed to bottom-right of the viewport */
.okBtn.okFloating{
  position:fixed;
  right:24px;
  bottom:20px;
  z-index:9999;
}

/* Battle: log list should scroll inside its box (not spill outside) */
.tabs #logWrap{
  max-height:62vh;
  overflow-y:hidden;
  padding-right:6px;
}

/* === Guide box === */
.handGuide .guideBox{ display:flex; flex-direction:column; gap:10px; }
.handGuide .guideHeader{ display:flex; align-items:baseline; gap:8px; }
.handGuide .guideTable{ width:100%; border-collapse:collapse; }
.handGuide .guideTable th, .handGuide .guideTable td{
  padding:6px 8px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.handGuide .guideTable .num{ text-align:right; font-variant-numeric: tabular-nums; }
.handGuide .calcBox{
  padding:10px 12px;
  border-radius:12px;
  background:rgba(0,0,0,.14);
  border:1px solid rgba(255,255,255,.10);
}
.handGuide .calcTitle{ font-weight:900; margin-bottom:6px; }


/* 1秒だけ前面に出るログ（スキル発動など） */
.frontToast{position:fixed;left:0;top:0;right:0;bottom:0;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;z-index:9999;pointer-events:none;background:rgba(0,0,0,.22);backdrop-filter:blur(2px);}
.frontToast .box{max-width:min(760px,92vw);background:rgba(20,18,28,.94);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:18px 22px;box-shadow:0 18px 70px rgba(0,0,0,.6);font-weight:800;font-size:22px;line-height:1.35;}
.frontToast.fade{opacity:0;transition:opacity .28s ease;}
.frontToast.good .box{border-color:rgba(120,255,180,.35);} 
.frontToast.bad .box{border-color:rgba(255,120,120,.35);} 
.frontToast.info .box{border-color:rgba(200,200,255,.25);} 


/* === Stream-style battle layout + Nico comments === */
.battlePanel .hd{ position: relative; }
.livePill{
  margin-left:auto;
  background:rgba(255, 0, 90, .22);
  border:1px solid rgba(255, 0, 90, .35);
  color:#fff;
  font-weight:800;
}

.battleBd{ position: relative; }

.battleLayout{
  display:grid;
  grid-template-columns: 360px 1fr;
  grid-template-rows: auto 260px auto auto;
  gap:12px;
  align-items:stretch;
}

.enemyHandMini{ grid-column:1; grid-row:1; }
.enemyHandMini .bd{ max-height:none; overflow:hidden; }
.enemyCardWrap{ grid-column:2; grid-row:1; }

.battleScene{
  grid-column:1;
  grid-row:1;
  position:relative;
  border-radius:18px;
  background:rgba(0,0,0,.20);
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
  min-height:260px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  padding:18px;
}


.playerCardLarge{
  position:absolute;
  left:16px;
  bottom:16px;
  width:min(520px, 56%);
  z-index:2;
  width:min(640px, 86%);
  min-height:200px;
}


.portraitLg{ width:150px; height:170px; object-fit:contain; border-radius:16px;  object-position:top center; }

.battleBubbles{ position:absolute; inset:0; pointer-events:none; z-index:6; display:block; }

.bubble{
  max-width:360px;
  padding:14px 18px;
  border-radius:18px;
  background:#fff;
  color:#111;
  font-weight:700;
  box-shadow:0 8px 30px rgba(0,0,0,.35);
  position:relative;
}

.bubbleAlly{
  position:absolute;
  /* Move up into the space under enemy hand */
  left: 24px;
  top: -140px;
  transform: none;
  max-width: min(520px, 72%);
}

.bubbleAlly::after{
  content:"";
  position:absolute;
  width:0;height:0;
  border:10px solid transparent;
  border-top-color:#fff;
  left:18px;
  bottom:-18px;
}
.bubbleEnemy::after{
  content:"";
  position:absolute;
  width:0;height:0;
  border:10px solid transparent;
  border-top-color:#fff;
  right:18px;
  bottom:-18px;
}

.playerHand .bd{height:auto; overflow:hidden;}
.playerHand{ grid-column:1 / span 2; grid-row:3; }
.battleControls{ grid-column:1 / span 2; grid-row:4; display:flex; flex-direction:column; gap:8px;  position:sticky; bottom:12px; z-index:80; }


.nicoLayer{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:4;
}

.nicoComment{
  position:absolute;
  right:-40px;
  white-space:nowrap;
  font-weight:900;
  font-size:18px;
  color:#fff;
  text-shadow: 0 2px 6px rgba(0,0,0,.65);
  animation-name:nicoFlow;
  animation-timing-function:linear;
  animation-fill-mode:forwards;
}

@keyframes nicoFlow{
  from { transform: translateX(0); opacity:1; }
  to   { transform: translateX(calc(-1 * var(--nicoDistance, 1400px))); opacity:1; }
}

/* responsive: keep right panel readable */
@media (max-width: 1200px){
  .battleLayout{ grid-template-columns: 320px 1fr; }
  .playerCardLarge{ width:min(520px, 70%); }
}


/* Enemy hand compact (max 5) */
.enemyHandMini .cards{ display:grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap:6px; align-items:start; }
.enemyHandMini .card{ width:58px; height:78px; border-radius:12px; padding:6px 6px; font-size:11px; }
.enemyHandMini .card .s{ font-size:20px; margin-top:4px; }
.enemyHandMini .card .tag{ font-size:10px; }
.enemyHandMini .card .top .v{ font-size:11px; }

.enemyHandMini #enemyWrap{ overflow:hidden; }

.battleLayout .bar{ width:260px; max-width:100%; }
.enemyCard .bar, .playerCardLarge .bar{ width:100%; }

.btns button{ white-space:normal; text-align:center; line-height:1.15; }
button .sub{ display:block; font-size:12px; font-weight:800; opacity:.9; margin-top:2px; }
button .main{ display:block; }

.okOverlay{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(closest-side, rgba(0,0,0,.0), rgba(0,0,0,.55));
  z-index:7;
  pointer-events:none;
}
.okOverlay .box{
  padding:22px 24px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(20,16,40,.55);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  font-weight:900;
  font-size:26px;
  letter-spacing:.02em;
}
.okBtn.pulse{ animation: okPulse 1.2s ease-in-out infinite; }
@keyframes okPulse{
  0%{ transform:translateY(0) scale(1); filter:brightness(1); }
  50%{ transform:translateY(-1px) scale(1.05); filter:brightness(1.2); }
  100%{ transform:translateY(0) scale(1); filter:brightness(1); }
}

/* === Fix: table-like battle layout (enemy hand / mid row / player hand) === */
.battleLayout.layoutTable{
  display:grid;
  grid-template-columns: 1fr 360px;
  grid-template-rows: auto auto auto auto;
  gap:12px;
  align-items:stretch;
}
.battleLayout.layoutTable .enemyHandMini{ grid-column:1 / span 2; grid-row:1; }
.battleLayout.layoutTable .midRow{ grid-column:1 / span 2; grid-row:2; display:grid; grid-template-columns: 1fr 360px; gap:12px; align-items:stretch;  position:relative; overflow:visible; }
.battleLayout.layoutTable .playerHand{ grid-column:1 / span 2; grid-row:3; }
.battleLayout.layoutTable .battleControls{ grid-column:1 / span 2; grid-row:4; }

/* Enemy hand: no scrollbars, always fit up to 5 */
#enemyWrap{ display:flex; gap:8px; align-items:flex-start; overflow:hidden !important; padding:4px 2px; }
.enemyHandMini{ overflow:hidden; }
.enemyHandMini .bd{ overflow:hidden !important; }
.enemyHandMini .cardMini{ width:58px; height:78px; }

/* Card columns: portrait on top, meta under portrait */
.charCol{ display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.charCol .under{ width:100%; }

/* Player card bigger, with portrait anchored to top */
.playerCardLarge{ position:relative; left:auto; bottom:auto; width: min(520px, 92%); margin: 16px; }
.portraitLg{ width:240px; height:240px; object-fit:contain; object-position:top center; border-radius:18px; }

/* Enemy card smaller; prevent overflow */
.enemyCardWrap{ overflow:hidden; }
.enemyPortrait{ object-position:top center;  width:200px; height:240px; object-fit:contain; border-radius:16px; }
.enemyCard .vibe{
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* HP bars: match portrait width */
.charMeta .bar{ width:100% !important; max-width:100% !important; min-width:0 !important; }

/* Speech bubbles placement */
.bubble{ pointer-events:none; }
.overlayAlly{
  position:absolute;
  left: 220px;   /* around player portrait top area */
  top: 6px;
  /* Move down so enemy hand + enemy info remain visible */
  z-index: 20;
}
.flipEnemy{
  /* Enemy bubble uses inverted coordinate system in this build */
  transform: scaleY(-1);
}
.flipEnemy .bubbleText{
  display:inline-block;
  transform: rotate(180deg) scaleY(-1);
}

/* OK button text centering */
.okBtn{ display:inline-flex; align-items:center; justify-content:center; line-height:1.1; text-align:center; }

/* Enemy hand card size override (uses .card) */
.enemyHandMini .cards{ display:flex; gap:8px; }
.enemyHandMini .card{ width:58px; height:78px; padding:6px; }
.enemyHandMini .card .s{ font-size:18px; margin-top:6px; }
.enemyHandMini .card .top .v{ font-size:12px; }
.enemyHandMini .card .tag{ font-size:11px; }


/* === Overrides: keep HP bars compact and avoid layout break === */
.battleLayout .bar{ width:100% !important; max-width:100% !important; }
.enemyCard .bar, .playerCardLarge .bar{ width:100% !important; max-width:100% !important; }

/* Theme backgrounds: unify within enemy vs player panels */
.panel.themeEnemy{ background:rgba(0,0,0,.14) !important; border:1px solid rgba(255,255,255,.08) !important; box-shadow:none !important; }
.panel.themePlayer{ background:rgba(0,0,0,.10) !important; border:1px solid rgba(255,255,255,.08) !important; box-shadow:none !important; }

/* Enemy hand: hard-disable scrollbars */
.enemyHandMini, .enemyHandMini .bd, #enemyWrap{ overflow:hidden !important; }
#enemyWrap{ flex-wrap:nowrap; }
#enemyWrap::-webkit-scrollbar{ width:0 !important; height:0 !important; }

/* OK/Like button: single label centered */
.okBtn{ display:inline-flex; align-items:center; justify-content:center; line-height:1.2; }
.btn.okBtn span{ display:inline; }


/* --- FIX10.2: ensure midRow is always 2 columns (player left, enemy right) --- */
.midRow{
  display:grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap:12px !important;
  align-items:stretch !important;
}
.battleScene{ min-width:0 !important; }

/* enemy hand on top spans full width */
.enemyHandMini{ grid-column:1 / span 2 !important; overflow:hidden !important; }
#enemyWrap{ overflow:hidden !important; }

/* --- FIX10.2: HP bars constrained to the portrait width, never stretching the panel --- */
.enemyCard .charCol{ width:200px !important; align-items:center !important; }
.enemyCard .charMeta{ width:200px !important; }
.playerCardLarge .charCol{ width:260px !important; align-items:center !important; }
.playerCardLarge .charMeta{ width:260px !important; }
.charMeta .bar{ width:100% !important; max-width:100% !important; min-width:0 !important; }

/* player card should not be absolutely positioned */
.playerCardLarge{
  position:relative !important;
  left:auto !important;
  bottom:auto !important;
  width:fit-content !important;
  margin:18px !important;
}

/* bigger player portrait; crop from bottom (top stays) */
.portraitLg{
  width:260px !important;
  height:220px !important;
  object-fit:cover !important;
  object-position:top center !important;
}

/* --- FIX10.2: enemy hand cards fit (max 5) without any scrollbars --- */
.enemyHandMini .cards{
  display:flex !important;
  gap:10px !important;
  flex-wrap:nowrap !important;
}
.enemyHandMini .card{
  width:62px !important;
  height:86px !important;
  border-radius:12px !important;
  flex:0 0 auto !important;
}
.enemyHandMini .card .s{ font-size:18px !important; }
.enemyHandMini .card .tag{ font-size:10px !important; }
.enemyHandMini .card .top{ font-size:10px !important; }

/* --- FIX10.2: unify background colors for enemy/player panels (incl inner .bd) --- */
.themeEnemy{
  background: rgba(70, 40, 90, 0.20) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
}
.themeEnemy > .bd, .themeEnemy .bd{
  background: rgba(70, 40, 90, 0.16) !important;
}
.themePlayer{
  background: rgba(40, 70, 90, 0.16) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
}
.themePlayer > .bd, .themePlayer .bd{
  background: rgba(40, 70, 90, 0.12) !important;
}

/* OK/like button text centering */
.okBtn, .likeBtn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  line-height:1.15 !important;
}



/* --- Overlay spanning whole midRow (player+enemy) --- */
.midRow{ position: relative; }
.midOverlay{
  position:absolute; inset:0;
  display:grid;
  grid-template-columns: 1fr 360px;
  column-gap: 14px;
  pointer-events: none;
  z-index: 50;
}
.midOverlay .nicoLayer{ grid-column:1 / -1; grid-row:1; position:absolute; inset:0; pointer-events:none; }
.midOverlay .okOverlay{ grid-column:1 / -1; grid-row:1; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.midOverlay .overlayLeft{ grid-column:1; grid-row:1; position:relative; }
.midOverlay .overlayRight{ grid-column:2; grid-row:1; position:relative; }

/* Ally bubble: center-left over player image area */
.midOverlay .overlayLeft .overlayAlly{
  position:absolute;
  left: 24px;
  /* Raise ally bubble into the space under enemy hand */
  /* Tuned: was too high (-110px). Lower by roughly one bubble height */
  top: -10px;
  transform: none;
  z-index: 60;
  max-width: 520px;
}


/* Enemy bubble: under enemy image, flipped */
.midOverlay .overlayRight .bubbleEnemy{
  position:absolute;
  /* Move to lower-left of enemy portrait area */
  left: -15px;
  top: 260px;
  width: 390px;
  max-width: min(460px, 70%);
  transform: rotate(180deg);
}
.midOverlay .overlayRight .bubbleEnemy .bubbleText{ display:block; transform: rotate(180deg); }


/* ==== Fix14: buttons + portraits + overflow ==== */
.btnRow{ flex-wrap:wrap; gap:10px; }
.btnRow .flexBreak{ flex-basis:100%; height:0; }
#okBtn{ display:inline-flex; align-items:center; justify-content:center; }
#okBtn:disabled{ opacity:.55; cursor:not-allowed; filter:saturate(.7); }
.portraitLg,.enemyPortrait{ background:rgba(0,0,0,.18); }
.playerCardLarge .bd, .enemyCard .bd{ overflow:hidden; }
.playerCardLarge, .enemyCard, .playerHand, .enemyHandMini{ max-width:100%; }
.playerCardLarge img, .enemyCard img{ max-width:100%; }


/* --- fix15: sticky action buttons so OK is always reachable --- */
.btns{
  position: sticky;
  bottom: 14px;
  z-index: 20;
  padding: 10px 10px;
  border-radius: 16px;
  background: rgba(10, 8, 18, .55);
  backdrop-filter: blur(8px);
}

/* --- fix15: player portrait fits frame width, crop bottom (top shown) --- */
.playerPortrait{
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: top center;
  display:block;
  border-radius: 18px;
}

/* Enemy portrait keeps current behavior; ensure doesn't stretch layout */
.enemyPortrait{
  max-width: 100%;
}

/* Meta and HP bar never overflow card */
.charCol, .charMeta, .charMeta.under{
  max-width: 100%;
}
.charMeta .bar{
  width: 100%;
  max-width: 100%;
}
.fxCard .bd{ overflow: hidden; }
.okBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1.1;
}


/* === Screen flash + Damage overlay === */
.screenFlash{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0}
.screenFlash.flash-red{animation:screenFlashRed .28s ease-out}
.screenFlash.flash-green{animation:screenFlashGreen .28s ease-out}
@keyframes screenFlashRed{0%{opacity:0}35%{opacity:.22;background:rgba(255,60,60,.55)}100%{opacity:0}}
@keyframes screenFlashGreen{0%{opacity:0}35%{opacity:.18;background:rgba(60,255,120,.45)}100%{opacity:0}}

.charMeta.under{position:relative}
.dmgFloat{position:absolute;left:0;right:0;top:22px;text-align:center;font-weight:900;font-size:22px;letter-spacing:.5px;
  text-shadow:0 2px 10px rgba(0,0,0,.65);pointer-events:none;transform:translateY(0);
  animation:dmgPop .75s ease-out forwards}
.dmgFloat.allyDmg{color:#ff3b3b}
.dmgFloat.enemyDmg{color:#62ff8a}
@keyframes dmgPop{0%{opacity:0;transform:translateY(10px) scale(.95)}15%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translateY(-14px) scale(1.05)}}


.cards .card.ghost{opacity:0; pointer-events:none;}


/* Emphasis buttons（元の色味を維持しつつ白寄りに） */
#btnBattle{
  --glow: rgba(255, 210, 70, .48);   /* was .18 */
  background: rgba(255, 232, 160, .92);
  color:#18181e;
  border: 1px solid rgba(110, 85, 20, .22);
}

#btnOk{
  --glow: rgba(90, 255, 160, .46);   /* was .18 */
  background: rgba(196, 255, 214, .90);
  color:#101016;
  border: 1px solid rgba(40, 120, 70, .22);
}

/* Cheer button glow (when cheer is available) */
#btnCheer{
  --glow: rgba(120, 200, 255, .46);
}

#btnBattle:hover,#btnOk:hover{
  filter: brightness(1.03);
}

#btnBattle:disabled,#btnOk:disabled{
  filter: grayscale(.2) brightness(.85);
}

/* Pulse highlight for the next recommended action */
.btnGlow{
  animation: btnGlow 1.05s ease-in-out infinite;
}

@keyframes btnGlow{
  0%{
    box-shadow: 0 0 0 0 var(--glow);
    filter: brightness(1) saturate(1);
  }
  50%{
    box-shadow:
      0 0 0 3px rgba(255,255,255,.30),  /* 白い輪郭ちょい強め */
      0 0 18px 6px var(--glow),         /* 色の光を強く */
      0 0 34px 12px var(--glow);        /* 外側にもう一段 */
    filter: brightness(1.08) saturate(1.18); /* ほんのり鮮やか */
  }
  100%{
    box-shadow: 0 0 0 0 var(--glow);
    filter: brightness(1) saturate(1);
  }
}

/* clickable links in title/howto (dark background) */
#howBox a, #howBox a:visited{
  color: #BFE6FF;                 /* 明るめシアン系（高コントラスト） */
  font-weight: 700;               /* 文字の存在感 */
  text-decoration: underline;
  text-decoration-thickness: 2px; /* 下線を太く */
  text-underline-offset: 3px;
  text-decoration-color: rgba(191,230,255,.9);
  text-shadow: 0 0 10px rgba(0,180,255,.35); /* ほんのり発光 */
}

#howBox a:hover, #howBox a:focus{
  color: #FFFFFF;                 /* ホバーは白 */
  text-decoration-color: rgba(255,255,255,.95);
  text-shadow: 0 0 14px rgba(0,180,255,.55);
  outline: none;
}


/* Music room modal */
.modal{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(0,0,0,.62);
  z-index: 50;
}
.modalCard{
  width: min(720px, 94vw);
  background: rgba(18,18,24,.96);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  padding: 16px 16px 14px;
  box-shadow: 0 16px 48px rgba(0,0,0,.55);
}
.modalHd{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.modalTitle{
  font-size: 20px;
  font-weight: 800;
}
.musicGrid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
button.tiny{
  padding: 6px 10px;
  font-size: 12px;
}

/* === Reward layout (fit illustration to viewport) === */
.rewardGrid{
  display:grid;
  grid-template-columns: minmax(260px, 42%) 1fr;
  gap:16px;
  align-items:start;
}
.rewardIllust img{
  width:100%;
  height:auto;
  max-height:66vh;
  object-fit:contain;
  border-radius:16px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.10);
}
