:root {
  --primary: #6062ca;
  --female: #d55490;
  --line: #e6e8ef;
  --bg: #f3f4f6;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  font-family: -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Segoe UI', Roboto, 'Microsoft YaHei', sans-serif;
}
.app-shell {
  width: 100%;
  min-height: 100vh;
  background: #fff;
}
.topbar {
  display: none;
}
.topbar h1 { margin: 0; font-size: 17px; font-weight: 600; text-align: center; }
.topbar p { margin: 2px 0 0; font-size: 12px; color: #666; text-align: center; }
.ghost-btn {
  position: absolute;
  right: 14px;
  bottom: 8px;
  border: none;
  background: none;
  color: #000;
  font-size: 17px;
  font-weight: 600;
}
.view { min-height: calc(100vh - 84px); padding-bottom: 96px; }
.view-no-topbar { min-height: calc(100vh - 84px); padding-top: 0; }

.hero { background: var(--primary); color: #fff; padding: 10px 20px 11px; position: relative; min-height: 70px; }
.hero .name { font-size: 20px; line-height: 1.15; font-weight: 600; letter-spacing: .2px; }
.hero .addr { font-size: 14px; line-height: 1.25; margin-top: 4px; opacity: .95; }
.hero-actions { position: absolute; right: 20px; top: 10px; display: flex; gap: 10px; }
.court-current { margin-top: 4px; color: rgba(255,255,255,.88); font-size: 12px; line-height: 1.2; }
.court-matchday-hint { margin: 8px 10px; padding: 10px 12px; border-radius: 10px; background: #f7f8ff; border: 1px solid #e1e5ff; font-size: 12px; color: #5c6289; }
.round-btn { width: 40px; height: 40px; border-radius: 999px; border: 1px solid rgba(255,255,255,.95); background: transparent; color: #fff; font-size: 12px; line-height: 1; padding: 0; }
.date-bar { display: flex; gap: 8px; padding: 10px 10px; border-bottom: 1px solid var(--line); overflow-x: auto; background: #fff; align-items: center; }
.date-item { min-width: 44px; height: 44px; border: 1px solid #d1d6e6; border-radius: 7px; text-align: center; padding-top: 3px; background: #fff; flex: 0 0 auto; }
.date-item.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.date-item.closed { opacity: .55; }
.date-item .d1 { font-size: 13px; }
.date-item .d2 { font-size: 12px; margin-top: 1px; }
.date-split { width: 16px; height: 44px; display: flex; align-items: center; justify-content: center; margin: 0 2px; position: relative; flex: 0 0 auto; }
.date-split::before { content: ''; position: absolute; left: 7px; top: 4px; bottom: 4px; width: 1px; background: #cfd5eb; }
.date-split-pill { width: 1px; height: 32px; background: #7e85d7; z-index: 1; }
.date-split-label { position: absolute; top: -7px; font-size: 8px; line-height: 1; color: #7e85d7; white-space: nowrap; font-weight: 600; }
.date-split-label.left { right: 11px; }
.date-split-label.right { left: 11px; color: #8e94ad; }
.slot-row { display: grid; grid-template-columns: 42px 1fr 26px 1fr 40px; gap: 8px; align-items: center; padding: 10px 12px; border-bottom: 1px solid #f2f4f9; background: #fff; }
.time-col { font-size: 12px; line-height: 1.1; color: #555; text-align: center; }
.time-col .line { width: 1px; height: 6px; background: #999; margin: 4px auto; }
.team-card { min-height: 50px; border: 1px solid #6062ca; border-radius: 5px; padding: 7px 10px 6px; overflow: hidden; background: #fff; }
.team-name { font-size: 14px; font-weight: 600; line-height: 1.2; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.team-name.female { color: var(--female); }
.team-sub { font-size: 12px; margin-top: 2px; white-space: nowrap; color: #666; text-overflow: ellipsis; overflow: hidden; display: flex; align-items: center; gap: 4px; }
.jersey-wrap { width: 14px; height: 14px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.jersey-icon { width: 14px; height: 14px; object-fit: contain; display: block; }
.vs { display: flex; align-items: center; justify-content: center; }
.vs-icon { width: 24px; height: 14px; object-fit: contain; display: block; }
.op-btn { border: none; border-radius: 5px; height: 20px; width: 40px; font-size: 12px; font-weight: 400; color: #fff; background: var(--primary); padding: 0; }
.op-btn.gray { background: #a0a0a0; }

.panel { padding: 12px; }
.section-title { font-size: 20px; font-weight: 600; margin: 6px 0 10px; }
.card { border: 1px solid #e6e8ef; border-radius: 10px; padding: 10px; margin-bottom: 10px; background: #fff; }
.primary-btn { border: none; border-radius: 7px; background: var(--primary); color: #fff; font-size: 12px; padding: 7px 10px; }
.input { width: 100%; border: 1px solid #d8dbe6; border-radius: 8px; height: 38px; padding: 0 10px; margin-top: 6px; }
.row { display: flex; gap: 8px; align-items: center; justify-content: space-between; }
.muted { font-size: 12px; color: #666; }
.tabbar { position: fixed; left: 0; right: 0; bottom: 0; height: 84px; border-top: 1px solid var(--line); display: grid; grid-template-columns: repeat(4, 1fr); background: #fff; z-index: 30; padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 2px); }
.tab { border: none; background: none; color: #000; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 8px 0 6px; }
.tab-icon { width: 30px; height: 30px; object-fit: contain; }
.tab-label { font-size: 10px; font-weight: 600; line-height: 1; }
.tab.active .tab-label { color: var(--primary); }

.modal { position: fixed; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; padding: 10vh 8px; z-index: 50; }
.hidden { display: none; }
.modal-panel { width: calc(100vw - 16px); max-width: 360px; max-height: 80vh; background: #fff; border-radius: 12px; padding: 16px; display: flex; flex-direction: column; overflow: hidden; position: relative; }
.modal-panel h3 { margin: 0 0 8px; font-size: 16px; }
.modal-x { position: absolute; top: 10px; right: 10px; width: 24px; height: 24px; border: 1px solid rgba(0,0,0,.2); border-radius: 999px; background: #fff; color: #111; font-size: 18px; line-height: 1; display: none; align-items: center; justify-content: center; padding: 0; }
.modal-body { flex: 1 1 auto; min-height: 0; font-size: 14px; color: #4b5563; line-height: 1.5; overflow: auto; -webkit-overflow-scrolling: touch; }
.modal-actions { margin-top: 12px; text-align: right; flex: 0 0 auto; }
.modal-panel.rules-theme { background: #4a5666; color: #fff; border-radius: 5px; padding: 14px 12px 12px; }
.modal-panel.rules-theme h3 { color: #fff; text-align: center; font-size: 20px; line-height: 1.15; font-weight: 600; margin: 8px 0 12px; padding-bottom: 10px; border-bottom: 1px solid #748496; }
.modal-panel.rules-theme .modal-body { color: #fff; font-size: 12px; line-height: 1.42; }
.modal-panel.rules-theme .modal-body p { margin: 0; white-space: pre-line; }
.modal-panel.rules-theme .modal-body hr { border: 0; border-top: 1px solid #748496; margin: 10px 0; }
.modal-panel.rules-theme .modal-actions { display: none; }
.modal-panel.rules-theme .modal-x { display: inline-flex; border-color: rgba(255,255,255,.45); background: transparent; color: #fff; }

.detail-matchup { display: grid; grid-template-columns: 1fr 28px 1fr; align-items: center; gap: 8px; margin-bottom: 8px; }
.detail-team { padding: 6px; background: #f5f7ff; border-radius: 6px; text-align: center; }
.detail-team-name { font-size: 14px; font-weight: 600; line-height: 1.2; }
.detail-team-jersey { margin-top: 4px; font-size: 12px; color: #666; line-height: 1.2; }
.detail-team.female { color: #d55490; }
.detail-vs { font-size: 12px; text-align: center; color: #666; }
.badge { display: inline-block; padding: 2px 8px; font-size: 11px; border-radius: 999px; background: #ecefff; color: #6062ca; }

.checkin-search { width: 100%; border: 1px solid #d8dbe6; border-radius: 8px; height: 36px; padding: 0 10px; margin: 8px 0 10px; }
.list-scroll-box { max-height: calc(100vh - 280px); overflow-y: auto; -webkit-overflow-scrolling: touch; }
.list-footer { text-align: center; font-size: 11px; padding: 8px 0 2px; }
.matches-list .card, .orders-list .card { margin-bottom: 8px; }
.matches-list .card, .orders-list .card, .matches-list .card *, .orders-list .card * { font-size: 12px; }
.matches-list .card strong, .orders-list .card strong { font-size: 13px; }
.matches-list .badge, .orders-list .badge { font-size: 10px; }
.checkin-player { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid #f2f4f9; font-size: 14px; }
.checkin-player:last-child { border-bottom: none; }
.checkin-player button { border: none; border-radius: 6px; padding: 4px 8px; font-size: 12px; background: #e9edff; color: #6062ca; }
.checkin-player button.done { background: #6062ca; color: #fff; }

.auth-lite { padding: 8px 4px 0; }
.auth-logo { width: 106px; height: auto; display: block; margin: 0 0 14px; }
.auth-title { margin: 0 0 14px; font-size: 26px; font-weight: 700; color: #111; }
.auth-input-wrap { position: relative; }
.auth-input { width: 100%; border: 1px solid #d7d9e2; border-radius: 10px; height: 44px; padding: 0 14px; margin-bottom: 10px; font-size: 15px; background: #fff; }
.auth-input::placeholder { color: #c5c7ce; font-size: 15px; }
.auth-code-btn { position: absolute; right: 10px; top: 8px; border: none; background: none; color: #6062ca; font-size: 14px; padding: 0 6px; }
.auth-code-btn[disabled] { color: #b5b9d8; }
.auth-submit-btn { width: 100%; border: none; border-radius: 999px; height: 46px; font-size: 18px; font-weight: 600; color: #fff; background: #6062ca; margin-top: 12px; }
.auth-submit-btn[disabled] { background: #b6b8c6; }
.auth-agree { margin-top: 16px; display: flex; align-items: center; flex-wrap: wrap; gap: 4px; font-size: 14px; color: #222; }
.auth-agree input { width: 22px; height: 22px; margin: 0 4px 0 0; }
.auth-link { border: none; background: none; padding: 0; color: #6062ca; font-size: 14px; font-weight: 600; }
.policy-text { font-size: 13px; line-height: 1.65; color: #333; white-space: normal; }

.profile-complete-page { padding: 6px 10px 0; }
.profile-logo { width: 104px; height: auto; display: block; margin: 8px 0 44px; }
.profile-title { margin: 0 0 20px; font-size: 18px; line-height: 1.2; font-weight: 700; color: #111; }
.profile-input-wrap { position: relative; margin-bottom: 16px; }
.profile-input { width: 100%; height: 44px; border: 1px solid #bfc1c8; border-radius: 8px; padding: 0 50px 0 12px; font-size: 13px; color: #222; background: #fff; }
.profile-input::placeholder { color: #c6c8cf; }
.profile-count { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 12px; line-height: 1; color: #666ab8; }
.profile-gender-label { font-size: 13px; color: #111; margin-bottom: 8px; }
.profile-gender-row { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.profile-gender-option { display: inline-flex; align-items: center; gap: 4px; font-size: 14px; line-height: 1; font-weight: 500; }
.profile-gender-option input { width: 16px; height: 16px; accent-color: #6062ca; }
.profile-gender-option.male span { color: #1f1f1f; }
.profile-gender-option.female span { color: #e3a2c6; }
.profile-submit { width: 100%; height: 44px; border: none; border-radius: 999px; background: #6062ca; color: #fff; font-size: 16px; font-weight: 500; }

.create-team-page { padding: 0 2px 4px; }
.create-team-topbar { display: flex; align-items: center; justify-content: flex-start; margin: 2px 0 12px; }
.create-team-nickname { font-size: 20px; font-weight: 700; letter-spacing: .3px; }
.create-team-nickname.male { color: #1f1f1f; }
.create-team-nickname.female { color: #d97baa; }
.create-team-block { padding: 0 2px; }
.create-team-title { font-size: 18px; line-height: 1.2; margin: 0 0 10px; color: #111; font-weight: 700; }
.create-team-field { margin-bottom: 12px; }
.create-team-field > label { display: block; font-size: 13px; font-weight: 600; color: #1d1d1d; margin-bottom: 6px; }
.create-team-name-wrap { position: relative; }
.create-team-input { width: 100%; height: 44px; border: 1px solid #bfc1c8; border-radius: 8px; background: #fff; padding: 0 50px 0 12px; font-size: 13px; }
.create-team-input::placeholder { color: #c4c7cf; }
.create-team-count { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 12px; color: #7073bf; }
.create-team-radio-row, .create-team-check-row { display: flex; align-items: center; gap: 14px; font-size: 14px; color: #171717; }
.create-team-radio-row label, .create-team-check-row label { display: inline-flex; align-items: center; gap: 4px; }
.create-team-radio-row input, .create-team-check-row input { width: 16px; height: 16px; accent-color: #6062ca; }
.create-team-radio-row .female { color: #d696b9; }
.tiny-rule-btn { border: none; border-radius: 8px; background: #6062ca; color: #fff; font-size: 12px; line-height: 1; padding: 6px 8px; }
.create-team-submit { width: 100%; height: 46px; border: none; border-radius: 999px; background: #6062ca; color: #fff; font-size: 18px; font-weight: 500; margin: 12px 0 20px; }
.create-team-current-title { font-size: 18px; line-height: 1.2; margin-bottom: 10px; color: #111; font-weight: 700; }
.create-team-venue-box { height: 52px; border: 1px solid #bfc1c8; border-radius: 10px; background: #fff; display: flex; align-items: center; justify-content: space-between; padding: 0 12px; font-size: 13px; color: #111; cursor: pointer; }
.create-team-venue-box .venue-name { max-width: calc(100% - 96px); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.venue-switch-link { border: none; background: none; color: #6f72c2; font-size: 12px; padding: 0; cursor: pointer; }

.captain-intensity-row { margin-top: 6px; }
.logout-pill { border: none; background: none; color: #000; font-size: 12px; font-weight: 600; padding: 0; cursor: pointer; }
.team-readonly-row { display: flex; align-items: center; justify-content: flex-start; gap: 4px; font-size: 14px; margin: 10px 0 6px; }
.team-readonly-label { color: #111; }
.team-name-text { font-size: 16px; font-weight: 600; text-align: left; }
.team-type-row { margin-top: 2px; }
.team-type-row .team-readonly-value { font-size: 14px; }
.team-readonly-value.male { color: #1f1f1f; }
.team-readonly-value.female { color: #d97baa; }
.team-readonly-note { font-size: 11px; color: #7d839a; margin-top: 4px; }
.captain-submit { margin-top: 14px; }

.modal-panel.venue-picker-theme { background: #4f5c72; border-radius: 8px; color: #fff; width: calc(100vw - 26px); max-width: 420px; max-height: 80vh; padding: 14px 10px 12px; }
.modal-panel.venue-picker-theme h3 { text-align: center; color: #fff; font-size: 18px; font-weight: 600; margin: 8px 0 10px; }
.modal-panel.venue-picker-theme .modal-actions { display: none; }
.modal-panel.venue-picker-theme .modal-x { display: inline-flex; border-color: rgba(255,255,255,.45); background: transparent; color: #fff; }
.modal-panel.venue-picker-theme .modal-body { color: #fff; padding: 2px 2px 0; }
.venue-picker-list { max-height: 52vh; overflow: auto; border-top: 1px solid #748496; }
.venue-picker-item { width: 100%; border: none; border-bottom: 1px solid #748496; background: transparent; color: #fff; height: 54px; padding: 0 2px; font-size: 14px; display: flex; align-items: center; justify-content: space-between; }
.venue-picker-item .tick { width: 20px; text-align: center; font-size: 18px; }
.venue-picker-confirm { width: 100%; height: 52px; border: none; border-radius: 8px; margin-top: 16px; background: #6062ca; color: #fff; font-size: 18px; font-weight: 500; }

.payment-page { padding: 10px 10px 18px; }
.payment-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.payment-back { border: none; background: none; font-size: 24px; line-height: 1; padding: 0; color: #111; }
.payment-head-center { text-align: center; flex: 1; }
.payment-head-title { font-size: 18px; font-weight: 700; color: #111; }
.payment-head-subtitle { font-size: 12px; color: #666; margin-top: 2px; }
.payment-rule-link { border: none; background: none; font-size: 17px; font-weight: 600; color: #111; }
.payment-match { padding: 12px 12px 10px; }
.payment-row { display: flex; align-items: flex-start; gap: 10px; }
.payment-team-row + .payment-team-row { margin-top: 12px; }
.payment-side-label { width: 44px; font-size: 18px; font-weight: 700; color: #4d4d8f; }
.payment-side-content { flex: 1; }
.payment-team-line { display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; min-width: 0; }
.payment-team-name { font-size: 18px; font-weight: 700; color: #111; line-height: 1; white-space: nowrap; }
.payment-team-name.female { color: #d97baa; }
.payment-female-tag { font-size: 11px; color: #d97baa; white-space: nowrap; }
.payment-support-row { display: flex; align-items: center; gap: 8px; margin-top: 4px; font-size: 12px; color: #666; }
.payment-support-bar { flex: 1; height: 18px; border: 1px solid #8d8fd9; border-radius: 10px; position: relative; overflow: hidden; }
.payment-support-bar i { position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: #8d8fd9; }
.payment-vs { margin: 6px 0 2px 48px; }
.payment-vs-icon { width: 42px; height: 22px; object-fit: contain; }
.payment-time-block { margin-top: 18px; }
.payment-time { font-size: 18px; font-weight: 700; color: #111; }
.payment-venue-name { margin-top: 6px; font-size: 18px; font-weight: 700; color: #111; }
.payment-venue-address { margin-top: 6px; font-size: 14px; color: #555; }
.payment-desc { margin-top: 18px; font-size: 14px; line-height: 1.55; color: #222; font-weight: 600; }
.payment-desc-note { display: block; margin-top: 4px; color: #8a8fd6; }
.payment-team-summary { margin-top: 18px; display: flex; justify-content: space-between; gap: 12px; }
.payment-summary-label { font-size: 18px; font-weight: 700; color: #111; }
.payment-summary-team { font-size: 18px; font-weight: 700; margin-top: 6px; }
.payment-summary-team.female { color: #d97baa; }
.payment-summary-team.male { color: #111; }
.payment-summary-amount { font-size: 18px; font-weight: 700; color: #6d68cf; margin-top: 6px; }
.payment-summary-jersey { font-size: 12px; color: #666; margin-top: 4px; }
.payment-jersey-title { margin-top: 18px; font-size: 18px; font-weight: 700; color: #111; }
.payment-jersey-grid { margin-top: 12px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px 8px; }
.payment-jersey-option { display: flex; align-items: center; gap: 6px; position: relative; }
.payment-jersey-option input { position: absolute; opacity: 0; pointer-events: none; }
.payment-jersey-circle { width: 20px; height: 20px; border: 1px solid #9a9a9a; border-radius: 50%; display: inline-block; flex: 0 0 auto; position: relative; }
.payment-jersey-option input:checked + .payment-jersey-circle::after { content: ''; position: absolute; left: 50%; top: 50%; width: 10px; height: 10px; transform: translate(-50%, -50%); border-radius: 50%; background: #6668d0; }
.payment-jersey-img,
.payment-jersey-icon { width: 18px; height: 18px; object-fit: contain; flex: 0 0 auto; }
.payment-pay-btn { width: 100%; border: none; border-radius: 999px; height: 54px; margin-top: 22px; background: #6668d0; color: #fff; font-size: 20px; font-weight: 600; }
.payment-back-btn { margin-top: 10px; border: none; background: none; color: #6668d0; font-size: 14px; font-weight: 600; }
.hidden-fee { display: none; }
.payment-confirm-box { font-size: 14px; line-height: 1.7; color: #fff; }
.payment-confirm-box * { color: #fff; }
.payment-confirm-line { margin: 2px 0; }
.payment-confirm-actions { margin-top: 14px; text-align: center; }
.modal-panel.venue-picker-theme .payment-confirm-box,
.modal-panel.venue-picker-theme .payment-confirm-box * { color: #fff; }
.modal-panel.venue-picker-theme .payment-confirm-actions .primary-btn { background: #6062ca; color: #fff; }

.detail-page {
  padding: 14px 16px 24px;
  background: #fff;
  min-height: 100vh;
}
.detail-top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.detail-back {
  border: none;
  background: none;
  font-size: 28px;
  line-height: 1;
  padding: 0;
  color: #111;
}
.detail-status-pill {
  min-width: 72px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #ecefff;
  color: #6062ca;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
}
.detail-match-header {
  display: grid;
  grid-template-columns: 42px 1fr 54px;
  gap: 8px 10px;
  align-items: center;
}
.detail-side-label {
  font-size: 18px;
  font-weight: 700;
  color: #4d4d8f;
  align-self: start;
  padding-top: 18px;
}
.detail-side-block {
  padding-top: 8px;
}
.detail-team-line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}
.detail-jersey-img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}
.detail-team-name {
  font-size: 20px;
  font-weight: 700;
  color: #111;
  line-height: 1.15;
}
.detail-team-name.female { color: var(--female); }
.detail-female-tag {
  font-size: 11px;
  color: var(--female);
  align-self: flex-end;
  margin-bottom: 1px;
}
.detail-support-line {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  font-size: 12px;
  color: #555;
}
.detail-support-line.male .detail-support-bar i { background: #6062ca; }
.detail-support-line.female .detail-support-bar i { background: #d55490; }
.detail-support-bar {
  flex: 1;
  height: 18px;
  border: 1px solid #8d8fd9;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  background: #f4f6ff;
}
.detail-support-bar i {
  position: absolute;
  inset: 0 auto 0 0;
  background: #8d8fd9;
}
.detail-support-line.male .detail-support-bar { border-color: #6062ca; }
.detail-support-line.female .detail-support-bar { border-color: #d55490; }
.detail-support-line.male .detail-support-bar i { background: #6062ca; }
.detail-support-line.female .detail-support-bar i { background: #d55490; }
.detail-support-btn {
  width: 64px;
  height: 30px;
  border-radius: 8px;
  align-self: center;
  justify-self: end;
  font-size: 12px;
  padding: 0;
  box-shadow: none;
}
.detail-support-btn.active { background: #6668d0; }
.detail-support-btn.gray { background: #a0a0a0; box-shadow: none; }
.detail-vs-wrap {
  grid-column: 1 / span 3;
  display: flex;
  justify-content: flex-start;
  padding-left: 28px;
  margin: 2px 0 0;
}
.detail-vs-icon { width: 34px; height: 20px; object-fit: contain; }
.detail-time { margin-top: 18px; font-size: 18px; font-weight: 700; color: #111; }
.detail-venue-name { margin-top: 8px; font-size: 18px; font-weight: 700; color: #111; }
.detail-venue-address { margin-top: 8px; font-size: 14px; color: #555; }
.detail-live { margin-top: 22px; }
.detail-section-title { font-size: 18px; font-weight: 700; color: #111; margin-bottom: 12px; }
.detail-live-img { width: 220px; max-width: 100%; height: auto; aspect-ratio: auto; border: 1px solid #bbb; border-radius: 12px; display: block; margin: 0 auto; object-fit: contain; background: #f6f6f9; }
.detail-action-hint, .detail-cancel-hint { text-align: center; margin-top: 22px; font-size: 14px; font-weight: 600; color: #111; }
.detail-select-block { margin-top: 18px; padding: 14px; border: 1px solid #e6e8ef; border-radius: 14px; background: #fafbff; }
.selection-countdown { font-weight: 700; color: #6062ca; }
.detail-select-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.detail-count-pill {
  min-width: 56px;
  height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: #ecefff;
  color: #6062ca;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
}
.detail-select-subtitle { margin-top: 6px; font-size: 12px; color: #666; }
.detail-confirm-wrap, .detail-cancel-wrap, .detail-vote-row { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.detail-confirm-wrap { grid-template-columns: 1fr; }
.detail-challenger-item {
  width: 100%;
  border: 1px solid #c9cdea;
  border-radius: 12px;
  background: #fff;
  padding: 12px 14px;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.detail-challenger-item.female .detail-challenger-name { color: var(--female); }
.detail-challenger-left { display: flex; align-items: center; gap: 10px; min-width: 0; }
.detail-challenger-jersey { width: 28px; height: 28px; object-fit: contain; flex: 0 0 auto; }
.detail-challenger-name { font-size: 16px; font-weight: 700; color: #111; }
.detail-challenger-meta { margin-top: 4px; font-size: 12px; color: #666; }
.detail-challenger-chevron { color: #8b8fb8; font-size: 24px; line-height: 1; }
.detail-confirm-dialog { font-size: 14px; line-height: 1.7; color: #fff; }
.detail-confirm-line { margin: 2px 0; }
.detail-confirm-actions { margin-top: 14px; text-align: center; }
.detail-empty-state { padding: 10px 0; text-align: center; color: #666; font-size: 13px; }
.detail-note { margin-top: 12px; }
.detail-admin-entry { margin-top: 14px; padding: 10px; border: 1px solid #e6e8ef; border-radius: 10px; }
.detail-action-btn { width: 100%; height: 46px; border-radius: 999px; }
