/* =========================================
   Wedding Game — 幸福大富翁
   ========================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #F3E5D3;
  --bg-soft:  #FBF7F2;
  --bg-card:  #FFFFFF;
  --text:     #3B2F2A;
  --text-md:  #5B4A42;
  --text-lt:  #9A8880;
  --gold:     #C8A06A;
  --gold-lt:  #DCBC90;
  --accent:   #8C5D63;
  --border:   #E5D5C4;
  --white:    #FFFFFF;
  --green:    #7A9E87;
  --red-cell: #E8897A;

  --font-display: 'Noto Serif SC', serif;
  --font-en:      'Noto Serif SC', serif;
  --font-cn:      'Noto Serif SC', serif;
  --shadow: 0 6px 32px rgba(59,47,42,.08);
  --trans:  all .35s cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: var(--font-cn); min-height: 100vh; }

/* ── GIF 图标去白 ── */
.btn-icon-gif {
  object-fit: contain; vertical-align: middle;
  mix-blend-mode: multiply;
}

/* ── Header ── */
.page-header {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  background: rgba(243,229,211,.94);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}
.back-link, .rank-link {
  display: flex; align-items: center; gap: 6px;
  color: var(--text-lt); text-decoration: none; font-size: .82rem;
  letter-spacing: .06em; transition: var(--trans);
}
.back-link:hover, .rank-link:hover { color: var(--gold); }
.back-link svg, .rank-link svg { width: 16px; height: 16px; }
.header-title {
  font-family: var(--font-display); font-size: 1.1rem;
  color: var(--text); letter-spacing: .06em;
}

/* ── Main ── */
.game-main { max-width: 1200px; margin: 0 auto; padding: 16px 16px 60px; }

/* ── 三栏布局 ── */
.game-layout {
  display: grid;
  grid-template-columns: 2.5fr 5fr 2.5fr;
  gap: 16px;
  align-items: start;
}
@media (max-width: 900px) {
  .game-layout { grid-template-columns: 1fr; }
  .side-left, .side-right { display: none; }
}

/* ── 手机端竖屏优化（≤ 600px） ── */
@media (max-width: 600px) {
  .game-main { padding: 10px 10px 40px; }

  /* 玩家信息条：紧凑 */
  .player-bar {
    flex-direction: column; align-items: flex-start; gap: 6px;
    padding: 12px 14px; border-radius: 12px;
  }
  .player-info { flex-wrap: wrap; gap: 6px; }
  .player-name { font-size: .95rem; }
  .player-score { font-size: 1.2rem; }
  .player-plays { font-size: .72rem; }

  /* 棋盘：占满宽度 */
  .board-wrap { border-radius: 12px; margin-bottom: 14px; }
  .pawn { width: 22px; height: 22px; }

  /* 骰子区 */
  .dice-area { gap: 14px; margin-bottom: 14px; }
  .btn-roll { padding: 11px 22px; font-size: .88rem; }

  /* 积分记录 */
  .log-section { padding: 14px; border-radius: 14px; }
  .log-title { font-size: .95rem; }
  .log-item { font-size: .78rem; padding: 6px 10px; }

  /* 事件弹窗 */
  .event-modal {
    width: min(92vw, 320px);
    padding: 24px 20px 20px;
    border-radius: 22px;
  }
  .event-gif-wrap { width: 120px; height: 120px; border-radius: 14px; }
  .event-cell-name { font-size: 1.2rem; }
  .event-desc { font-size: .82rem; }
  .event-score { font-size: 1.6rem; }
  .event-close { padding: 10px 28px; font-size: .85rem; }

  /* 登录卡片 */
  .login-card { padding: 28px 20px; border-radius: 18px; margin-top: 10px; }
  .login-title { font-size: 1.7rem; }
  .login-sub { font-size: .78rem; }
  .field-input { padding: 11px 14px; font-size: .88rem; }
  .btn-start { padding: 12px; font-size: .88rem; }

  /* 页头 */
  .page-header { padding: 10px 14px; }
  .header-title { font-size: .95rem; }
}

/* ── 移动端显示排行榜和景点（仅 ≤ 900px 显示） ── */
.mobile-section { display: none !important; }
@media (max-width: 900px) {
  .mobile-section { display: block !important; margin-top: 16px; }
  .mobile-section .panel-title {
    font-family: var(--font-display); font-size: .95rem;
    color: var(--text); margin-bottom: 10px; padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
  }
  .mobile-section .spot-list,
  .mobile-section .rank-list { max-height: 200px; overflow-y: auto; }
  .mobile-section .rank-rewards { margin-bottom: 10px; }
}

/* ── 侧边面板 ── */
.side-panel {
  background: var(--bg-card); border-radius: 16px;
  padding: 14px 12px; border: 1px solid var(--border);
  box-shadow: var(--shadow); position: sticky; top: 70px;
}
.panel-title {
  font-family: var(--font-display); font-size: .95rem;
  color: var(--text); margin-bottom: 10px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}

/* 景点加分列表 */
.spot-list { display: flex; flex-direction: column; gap: 4px; }
.spot-item {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .72rem; padding: 4px 6px; border-radius: 8px;
  background: var(--bg-soft);
}
.spot-item-name { color: var(--text-md); }
.spot-item-score { color: var(--green); font-weight: 600; font-size: .7rem; }
.spot-item-score.special { color: var(--accent); }

/* 特殊事件 */
.special-section { margin-bottom: 16px; }
.special-list { display: flex; flex-direction: column; gap: 6px; }
.special-item {
  font-size: .72rem; padding: 6px 8px; border-radius: 8px;
  background: var(--bg-soft); border-left: 3px solid var(--accent);
  line-height: 1.5;
}
.special-item-name { font-weight: 600; color: var(--text); }
.special-item-type { color: var(--accent); font-size: .68rem; }
.special-item-change { color: var(--text-md); }
.special-item-change.plus { color: var(--green); }
.special-item-change.minus { color: var(--red-cell); }

/* 排行榜 */
.rank-header { text-align: center; margin-bottom: 10px; }
.rank-title-gif { width: 100%; max-width: 100px; height: auto; object-fit: contain; }

.rank-rewards { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; padding: 8px; background: var(--bg-soft); border-radius: 12px; }
.rank-reward-item { display: flex; align-items: center; gap: 6px; }
.reward-rank-gif  { width: 28px; height: 28px; object-fit: contain; flex-shrink: 0; }
.reward-label { font-family: var(--font-en); font-size: .68rem; letter-spacing: .03em; font-style: italic; flex: 1; }
.reward-label.supreme  { color: #B8860B; }
.reward-label.charming { color: #E8A020; }
.reward-label.lovely   { color: #B87B5A; }
.reward-label.sweet    { color: #8C5D63; }
.reward-cn { font-style: normal; font-family: var(--font-cn); font-size: .6rem; letter-spacing: .08em; opacity: .7; }
.reward-gift-gif  { width: 64px; height: 24px; object-fit: contain; flex-shrink: 0; }

.rank-list { display: flex; flex-direction: column; gap: 4px; }
.rank-item {
  display: flex; align-items: center; gap: 6px;
  font-size: .74rem; padding: 4px 6px; border-radius: 8px;
  background: var(--bg-soft);
}
.rank-pos-gif { width: 26px; height: 26px; object-fit: contain; flex-shrink: 0; }
.rank-name  { flex: 1; color: var(--text-md); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: .72rem; }
.rank-score { color: var(--text); font-weight: 600; font-size: .7rem; }
.rank-mine  { background: rgba(200,160,106,.12); border: 1px solid var(--gold-lt); }
.podium-mine { border: 2px solid var(--gold) !important; }
.rank-divider { text-align: center; color: var(--text-lt); font-size: .8rem; padding: 4px 0; letter-spacing: .2em; }

/* log-header with more btn */
.log-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.btn-more {
  font-size: .7rem; padding: 3px 10px; border-radius: 20px;
  border: 1px solid var(--border); background: var(--bg-soft);
  color: var(--text-lt); cursor: pointer; transition: var(--trans);
  font-family: var(--font-cn);
}
.btn-more:hover { border-color: var(--gold); color: var(--gold); }

/* 中间列 */
.center-col { min-width: 0; }

/* ── 登录区 ── */
.login-card {
  background: var(--bg-card); border-radius: 24px;
  padding: 40px 28px; box-shadow: var(--shadow);
  border: 1px solid var(--border); margin-top: 20px;
}
.login-hero { text-align: center; margin-bottom: 32px; }
.login-label {
  font-family: var(--font-en); font-size: .72rem;
  letter-spacing: .4em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px;
}
.login-title {
  font-family: var(--font-display); font-size: 2.2rem;
  color: var(--text); margin-bottom: 10px;
}
.login-sub { font-size: .84rem; color: var(--text-lt); line-height: 1.7; }

.field-group { margin-bottom: 14px; }
.field-input {
  width: 100%; padding: 13px 16px;
  border: 1.5px solid var(--border); border-radius: 12px;
  font-family: var(--font-cn); font-size: .92rem;
  color: var(--text); background: var(--bg-soft); outline: none;
  transition: var(--trans);
}
.field-input:focus {
  border-color: var(--gold); background: var(--white);
  box-shadow: 0 0 0 3px rgba(200,160,106,.15);
}
.field-error { display: block; font-size: .75rem; color: #c0392b; margin-top: 5px; }
.field-hint {
  font-size: .78rem; margin-top: 6px; line-height: 1.5;
  padding: 6px 10px; border-radius: 8px;
}
.field-hint.new-user  { color: #5B8C6E; background: rgba(91,140,110,.1); }
.field-hint.returning { color: #7A6B5D; background: rgba(200,160,106,.12); }

.btn-start {
  width: 100%; padding: 14px;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-lt) 100%);
  color: var(--white); border: none; border-radius: 12px;
  font-family: var(--font-cn); font-size: .95rem; letter-spacing: .1em;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  gap: 8px; transition: var(--trans);
  box-shadow: 0 4px 20px rgba(200,160,106,.35); margin-top: 8px;
}
.btn-start:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(200,160,106,.5); }
.btn-start svg { width: 16px; height: 16px; }

/* ── 玩家信息条 ── */
.player-bar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--bg-card); border-radius: 16px;
  padding: 14px 18px; margin-bottom: 16px;
  border: 1px solid var(--border); box-shadow: var(--shadow);
}
.player-info { display: flex; align-items: center; gap: 10px; }
.player-name { font-family: var(--font-display); font-size: 1.1rem; color: var(--text); }
.player-rank-text {
  font-family: var(--font-en);
  font-size: .72rem;
  color: var(--gold);
  font-weight: 500;
  padding: 2px 8px;
  background: rgba(200, 160, 106, 0.12);
  border-radius: 20px;
  white-space: nowrap;
}
.player-score-label { font-size: .72rem; color: var(--text-lt); }
.player-score { font-family: var(--font-display); font-size: 1.4rem; color: var(--gold); }
.player-plays { font-size: .75rem; color: var(--text-lt); }
.player-plays .player-rolls-sep { margin: 0 6px; opacity: .55; }
.player-free-rolls {
  font-family: var(--font-display);
  font-size: .9rem;
  color: var(--gold);
  font-weight: 500;
  padding: 0 2px;
}
.player-free-rolls.exhausted { color: #C8766A; }

/* ── 棋盘 ── */
.board-wrap {
  position: relative; margin-bottom: 20px;
  border-radius: 18px; overflow: hidden;
  box-shadow: 0 8px 40px rgba(59,47,42,.12);
}
#boardCanvas { display: block; width: 100%; height: auto; }
.pawn {
  position: absolute;
  width: 28px; height: 28px;
  object-fit: contain;
  transform: translate(-50%, -50%);
  transition: top .5s cubic-bezier(.4,0,.2,1), left .5s cubic-bezier(.4,0,.2,1);
  z-index: 10;
  border-radius: 50%;
  background: rgba(255, 248, 240, 0.92);
  box-shadow: 0 2px 8px rgba(140,93,99,.45), 0 0 0 2px #C8A06A;
  padding: 3px;
  pointer-events: none;
}

/* ── 骰子区 ── */
.dice-area {
  display: flex; align-items: center; justify-content: center;
  gap: 20px; margin-bottom: 20px;
}
.dice-display { display: flex; gap: 12px; align-items: center; }
#diceCanvas {
  width: 24px; height: 24px;
  border-radius: 5px;
  filter: drop-shadow(0 2px 4px rgba(200,160,106,.4));
}
#diceCanvas.rolling { animation: diceShake .08s ease infinite alternate; }
@keyframes diceShake {
  from { transform: rotate(-14deg) scale(1.06); }
  to   { transform: rotate(14deg)  scale(0.96); }
}

.btn-roll {
  display: flex; align-items: center; gap: 8px;
  padding: 13px 28px;
  background: linear-gradient(135deg, var(--accent) 0%, #a87080 100%);
  color: var(--white); border: none; border-radius: 50px;
  font-family: var(--font-cn); font-size: .95rem; letter-spacing: .1em;
  cursor: pointer; transition: var(--trans);
  box-shadow: 0 4px 20px rgba(140,93,99,.3);
}
.btn-roll:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(140,93,99,.45); }
.btn-roll:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.btn-roll svg { width: 18px; height: 18px; }

/* ── 事件弹窗（全屏遮罩） ── */
.event-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(59,47,42,.72);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  animation: fadeInOverlay .25s ease both;
}
.event-overlay.hidden { display: none; }
@keyframes fadeInOverlay { from{opacity:0} to{opacity:1} }

.event-modal {
  background: var(--bg-card);
  border-radius: 28px;
  padding: 32px 28px 28px;
  width: min(88vw, 340px);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  box-shadow: 0 20px 60px rgba(59,47,42,.35);
  border: 2px solid var(--gold-lt);
  animation: popIn .35s cubic-bezier(.2,1.4,.4,1) both;
}
@keyframes popIn {
  from { transform: scale(.7) translateY(30px); opacity: 0; }
  to   { transform: scale(1)  translateY(0);    opacity: 1; }
}

.event-gif-wrap {
  width: 160px; height: 160px;
  border-radius: 20px;
  overflow: hidden;
  background: #fff;
  border: 1.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
}
.event-gif-wrap canvas { width: 100%; height: 100%; }

.event-cell-name {
  font-family: var(--font-display);
  font-size: 1.5rem; color: var(--text);
  letter-spacing: .04em; text-align: center;
}
.event-desc {
  font-size: .88rem; color: var(--text-md);
  line-height: 1.6; text-align: center;
}
.event-score {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 400; text-align: center;
}
.event-score.plus  { color: var(--green); }
.event-score.minus { color: var(--red-cell); }
.event-close {
  margin-top: 4px; padding: 11px 36px;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-lt) 100%);
  color: var(--white); border: none; border-radius: 50px;
  font-family: var(--font-cn); font-size: .92rem; letter-spacing: .1em;
  cursor: pointer; transition: var(--trans);
  box-shadow: 0 4px 16px rgba(200,160,106,.4);
}
.event-close:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(200,160,106,.5); }

/* ── 积分记录 ── */
.log-section { background: var(--bg-card); border-radius: 18px; padding: 20px; border: 1px solid var(--border); }
.log-title { font-family: var(--font-display); font-size: 1.1rem; color: var(--text); margin-bottom: 14px; }
.log-list { display: flex; flex-direction: column; gap: 8px; }
.log-empty { font-size: .82rem; color: var(--text-lt); text-align: center; padding: 16px 0; }
.log-item {
  display: flex; align-items: center; justify-content: space-between;
  font-size: .84rem; padding: 8px 12px; border-radius: 10px;
  background: var(--bg-soft);
}
.log-item-name { color: var(--text-md); }
.log-item-score { font-weight: 600; }
.log-item-score.plus  { color: var(--green); }
.log-item-score.minus { color: var(--red-cell); }

/* ── 排行榜页 ── */
.rank-page { padding-top: 10px; }
.rank-hero { text-align: center; padding: 24px 0 28px; }

/* 当前玩家名次条 */
.my-rank-bar {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: rgba(200,160,106,.12); border: 1.5px solid var(--gold-lt);
  border-radius: 50px; padding: 10px 24px; margin: 0 auto 24px;
  max-width: 360px;
}
.my-rank-bar.hidden { display: none; }
.my-rank-bar img { width: 32px; height: 32px; object-fit: contain; flex-shrink: 0; }
.my-rank-name { font-family: var(--font-display); font-size: 1rem; color: var(--text); }
.my-rank-score { font-family: var(--font-en); font-size: .9rem; color: var(--gold); font-weight: 600; }

/* header 右侧当前玩家排名 */
.header-my-rank {
  display: flex; align-items: center; gap: 4px;
  font-size: .78rem; color: var(--text-md);
}
.header-my-rank img { width: 22px; height: 22px; object-fit: contain; }
.header-my-rank span { max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.podium {
  display: flex; align-items: flex-end; justify-content: center;
  gap: 12px; margin-bottom: 24px;
}
.podium-item {
  display: flex; flex-direction: column; align-items: center;
  background: var(--bg-card); border-radius: 16px;
  padding: 16px 12px; border: 1px solid var(--border);
  box-shadow: var(--shadow); min-width: 90px;
}
.podium-item.rank-1 { order: 2; padding-top: 24px; border-color: var(--gold); }
.podium-item.rank-2 { order: 1; }
.podium-item.rank-3 { order: 3; }
.podium-mine { border: 2px solid var(--gold) !important; }
.podium-medal { font-size: 1.8rem; margin-bottom: 6px; }
.podium-name { font-family: var(--font-display); font-size: .95rem; color: var(--text); text-align: center; margin-bottom: 4px; }
.podium-score { font-family: var(--font-en); font-size: 1rem; color: var(--gold); font-weight: 600; }

.rank-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.rank-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--bg-card); border-radius: 14px;
  padding: 14px 18px; border: 1px solid var(--border);
}
.rank-no { font-family: var(--font-en); font-size: 1.1rem; font-weight: 700; color: var(--text-lt); width: 24px; }
.rank-name { flex: 1; font-size: .92rem; color: var(--text); }
.rank-score { font-family: var(--font-display); font-size: 1.1rem; color: var(--gold); }
.rank-divider { text-align: center; color: var(--text-lt); font-size: .8rem; padding: 4px 0; letter-spacing: .2em; }

.reward-card {
  background: var(--bg-card); border-radius: 20px;
  padding: 24px; border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.reward-title { font-family: var(--font-display); font-size: 1.2rem; color: var(--text); margin-bottom: 16px; }
.reward-items { display: flex; flex-direction: column; gap: 10px; }
.reward-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; border-radius: 10px;
}
.reward-item.gold   { background: rgba(200,160,106,.12); }
.reward-item.silver { background: rgba(180,180,190,.1); }
.reward-item.bronze { background: rgba(180,120,80,.08); }
.reward-item.part   { background: rgba(140,93,99,.07); }
.reward-rank { font-size: .88rem; font-weight: 500; color: var(--text); }
.reward-desc { font-size: .82rem; color: var(--text-lt); }

/* ── hidden ── */
.hidden { display: none !important; }
