/* ===== 漁夫の利ゲーム QRコード版 スタイル ===== */

.gyofu-qr-wrapper {
  --gyofu-base: #FFFFFF;
  --gyofu-base-light: #FAFAFA;
  --gyofu-base-dark: #F5F5F5;
  --gyofu-main: #1e3a5f;
  --gyofu-main-light: #2d5a8f;
  --gyofu-main-dark: #0f1e3a;
  --gyofu-accent: #d4af37;
  --gyofu-accent-light: #f4cf5f;
  --gyofu-accent-dark: #b8941f;
  --gyofu-text: #2C3E50;
  --gyofu-text-light: #7F8C8D;
  --gyofu-border: #E8E8E8;
  --gyofu-shadow: 0 18px 45px rgba(15, 30, 58, 0.16);
  all: initial;
  color: var(--gyofu-text);
  display: block;
  font-family: "Segoe UI", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif !important;
  line-height: 1.6;
}

.gyofu-qr-wrapper,
.gyofu-qr-wrapper * { box-sizing: border-box !important; }
.gyofu-qr-wrapper .hidden,
.gyofu-qr-wrapper .gyofu-qr-hidden { display: none !important; }
.gyofu-qr-wrapper h1,
.gyofu-qr-wrapper h2,
.gyofu-qr-wrapper h3,
.gyofu-qr-wrapper p,
.gyofu-qr-wrapper ol,
.gyofu-qr-wrapper ul { margin-top: 0 !important; }
.gyofu-qr-wrapper button,
.gyofu-qr-wrapper input { font-family: inherit !important; }

.gyofu-qr-wrapper button {
  border: none !important;
  border-radius: 14px !important;
  cursor: pointer !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
  min-height: 52px;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease !important;
}
.gyofu-qr-wrapper button:hover { transform: translateY(-2px) !important; }

.gyofu-qr-wrapper .gyofu-qr-btn-primary,
.gyofu-qr-wrapper .gyofu-qr-btn-submit {
  background: linear-gradient(135deg, var(--gyofu-main), var(--gyofu-main-light)) !important;
  box-shadow: 0 10px 24px rgba(30, 58, 95, 0.28) !important;
  color: var(--gyofu-base) !important;
  font-size: 1.15em !important;
  padding: 15px 34px !important;
}
.gyofu-qr-wrapper .gyofu-qr-btn-primary:hover,
.gyofu-qr-wrapper .gyofu-qr-btn-submit:hover { background: linear-gradient(135deg, var(--gyofu-main-dark), var(--gyofu-main)) !important; }

.gyofu-qr-wrapper .gyofu-qr-btn-secondary,
.gyofu-qr-wrapper .gyofu-qr-btn-back,
.gyofu-qr-wrapper .gyofu-qr-btn-toggle,
.gyofu-qr-wrapper .gyofu-qr-btn-copy-small,
.gyofu-qr-wrapper .gyofu-qr-url-box button {
  background: var(--gyofu-base) !important;
  border: 2px solid var(--gyofu-border) !important;
  color: var(--gyofu-main) !important;
  font-size: 1em !important;
  padding: 12px 22px !important;
}
.gyofu-qr-wrapper .gyofu-qr-btn-secondary:hover,
.gyofu-qr-wrapper .gyofu-qr-btn-back:hover,
.gyofu-qr-wrapper .gyofu-qr-btn-toggle:hover,
.gyofu-qr-wrapper .gyofu-qr-btn-copy-small:hover,
.gyofu-qr-wrapper .gyofu-qr-url-box button:hover { border-color: var(--gyofu-accent) !important; }

.gyofu-qr-wrapper .gyofu-qr-action-row,
.gyofu-qr-wrapper .gyofu-qr-action-stack { align-items: center; display: flex; gap: 14px; justify-content: center; }
.gyofu-qr-wrapper .gyofu-qr-action-stack { align-items: stretch; flex-direction: column; }

.gyofu-qr-wrapper .gyofu-qr-notice {
  background: #fff8df;
  border: 2px solid var(--gyofu-accent);
  border-radius: 16px;
  color: var(--gyofu-main-dark);
  font-size: 1em;
  font-weight: 800;
  margin: 20px;
  padding: 16px 20px;
  text-align: center;
}

.gyofu-qr-wrapper #gyofu-qr-setup,
.gyofu-qr-wrapper #gyofu-qr-lobby,
.gyofu-qr-wrapper #gyofu-qr-game,
.gyofu-qr-wrapper.gyofu-qr-player {
  background: radial-gradient(circle at top left, rgba(244, 207, 95, 0.22), transparent 30%), linear-gradient(135deg, var(--gyofu-main-dark), var(--gyofu-main));
  min-height: 100vh;
  padding: 28px;
}
.gyofu-qr-wrapper #gyofu-qr-setup,
.gyofu-qr-wrapper #gyofu-qr-lobby,
.gyofu-qr-wrapper.gyofu-qr-player { align-items: center; display: flex; justify-content: center; }

.gyofu-qr-wrapper .gyofu-qr-setup-card,
.gyofu-qr-wrapper .gyofu-qr-lobby-card,
.gyofu-qr-wrapper .gyofu-qr-game-card,
.gyofu-qr-wrapper .gyofu-qr-player-container,
.gyofu-qr-wrapper .gyofu-qr-popup-content {
  background: var(--gyofu-base);
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 28px;
  box-shadow: var(--gyofu-shadow);
}

.gyofu-qr-wrapper .gyofu-qr-setup-card { max-width: 680px; padding: 44px; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-setup-card h1 { color: var(--gyofu-main) !important; font-size: clamp(2.1rem, 4vw, 3.2rem) !important; line-height: 1.15 !important; margin: 0 0 8px !important; text-align: center !important; }
.gyofu-qr-wrapper .gyofu-qr-subtitle { color: var(--gyofu-accent-dark); font-size: 1.15em; font-weight: 800; margin: 0 0 32px !important; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-setup-group { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 22px; margin: 18px 0; padding: 22px; }
.gyofu-qr-wrapper .gyofu-qr-setup-group label { color: var(--gyofu-text) !important; display: block; font-size: 1.25em !important; font-weight: 800 !important; margin-bottom: 14px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-number-control { align-items: center; display: flex; gap: 22px; justify-content: center; }
.gyofu-qr-wrapper .gyofu-qr-number-control button { background: var(--gyofu-main) !important; border-radius: 50% !important; color: var(--gyofu-base) !important; font-size: 2em !important; height: 58px !important; padding: 0 !important; width: 58px !important; }
.gyofu-qr-wrapper .gyofu-qr-value { color: var(--gyofu-main); font-size: 3em; font-weight: 900; min-width: 90px; text-align: center; }

.gyofu-qr-wrapper .gyofu-qr-lobby-card,
.gyofu-qr-wrapper .gyofu-qr-game-card { max-width: 1280px; padding: 34px; width: min(100%, 1280px); }
.gyofu-qr-wrapper .gyofu-qr-section-heading { margin-bottom: 24px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-step-label,
.gyofu-qr-wrapper .gyofu-qr-player-label { background: rgba(212, 175, 55, 0.16); border: 1px solid rgba(212, 175, 55, 0.35); border-radius: 999px; color: var(--gyofu-accent-dark); display: inline-flex; font-size: 0.88em; font-weight: 900; letter-spacing: 0.08em; margin-bottom: 8px; padding: 5px 14px; }
.gyofu-qr-wrapper .gyofu-qr-section-heading h2,
.gyofu-qr-wrapper .gyofu-qr-game-header h2,
.gyofu-qr-wrapper .gyofu-qr-result-title { color: var(--gyofu-main) !important; font-size: clamp(1.9rem, 3vw, 2.8rem) !important; line-height: 1.2 !important; margin: 0 !important; text-align: center !important; }
.gyofu-qr-wrapper .gyofu-qr-section-heading p { color: var(--gyofu-text-light); font-size: 1.05em; margin: 8px 0 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-lobby-content { display: grid; gap: 22px; grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr) minmax(280px, 0.9fr); }
.gyofu-qr-wrapper .gyofu-qr-panel { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 22px; padding: 22px; }
.gyofu-qr-wrapper .gyofu-qr-panel h3,
.gyofu-qr-wrapper .gyofu-qr-status-box h3,
.gyofu-qr-wrapper .gyofu-qr-game-status h3,
.gyofu-qr-wrapper .gyofu-qr-progress-guide h3 { color: var(--gyofu-main) !important; font-size: 1.35em !important; margin: 0 0 16px !important; text-align: center !important; }

.gyofu-qr-wrapper .gyofu-qr-code-container { background: var(--gyofu-base); border: 3px solid var(--gyofu-accent); border-radius: 22px; display: flex; justify-content: center; margin: 0 auto; padding: 18px; width: fit-content; }
.gyofu-qr-wrapper #gyofu-qr-code { display: inline-block; }
.gyofu-qr-wrapper .gyofu-qr-url-container { margin: 18px 0 0; text-align: center; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-url-container p { color: var(--gyofu-text-light); font-weight: 800; margin-bottom: 8px !important; }
.gyofu-qr-wrapper .gyofu-qr-url-box { display: flex; flex-direction: column; gap: 10px; }
.gyofu-qr-wrapper .gyofu-qr-url-box input { background: var(--gyofu-base); border: 2px solid var(--gyofu-border) !important; border-radius: 12px !important; color: var(--gyofu-text) !important; font-family: monospace !important; font-size: 0.88em !important; padding: 12px !important; text-align: center !important; text-overflow: ellipsis !important; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-join-code { background: var(--gyofu-main); border-radius: 16px; color: var(--gyofu-base); font-size: 1em; font-weight: 800; margin-top: 16px; padding: 12px; text-align: center; word-break: break-all; }

.gyofu-qr-wrapper .gyofu-qr-setting-summary { display: grid; gap: 10px; grid-template-columns: 1fr 1fr; margin-bottom: 16px; }
.gyofu-qr-wrapper .gyofu-qr-setting-summary div { background: var(--gyofu-base); border: 1px solid var(--gyofu-border); border-radius: 16px; padding: 12px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-setting-summary span { color: var(--gyofu-text-light); display: block; font-size: 0.9em; font-weight: 800; }
.gyofu-qr-wrapper .gyofu-qr-setting-summary strong { color: var(--gyofu-main); display: block; font-size: 2em; line-height: 1.1; }
.gyofu-qr-wrapper .gyofu-qr-host-key-box { background: #fff8df; border: 2px solid var(--gyofu-accent); border-radius: 18px; margin-bottom: 18px; padding: 16px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-host-key-label,
.gyofu-qr-wrapper .gyofu-qr-host-key-note,
.gyofu-qr-wrapper .gyofu-qr-host-key-desc { color: var(--gyofu-main-dark); font-weight: 800; }
.gyofu-qr-wrapper .gyofu-qr-host-key-value { background: var(--gyofu-base); border: 2px solid var(--gyofu-accent-dark); border-radius: 12px; color: var(--gyofu-main); font-family: monospace !important; font-size: 1.35em; font-weight: 900; letter-spacing: 0.06em; margin: 12px 0; padding: 12px; word-break: break-all; }
.gyofu-qr-wrapper .gyofu-qr-host-key-note,
.gyofu-qr-wrapper .gyofu-qr-host-key-desc { font-size: 0.9em; margin: 12px 0 0 !important; }

.gyofu-qr-wrapper .gyofu-qr-status-list { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-status-item,
.gyofu-qr-wrapper .gyofu-qr-input-item { align-items: center; background: var(--gyofu-base); border: 2px solid var(--gyofu-border); border-left: 8px solid var(--gyofu-text-light); border-radius: 16px; display: flex; gap: 12px; justify-content: space-between; margin-bottom: 10px !important; padding: 14px 16px !important; }
.gyofu-qr-wrapper .gyofu-qr-status-item.submitted,
.gyofu-qr-wrapper .gyofu-qr-input-item.completed,
.gyofu-qr-wrapper .gyofu-qr-input-item.submitted { background: #fbfff5; border-color: rgba(212, 175, 55, 0.45); border-left-color: var(--gyofu-accent); }
.gyofu-qr-wrapper .gyofu-qr-input-item.timeout { background: #fff8df; border-left-color: var(--gyofu-accent-dark); }
.gyofu-qr-wrapper .gyofu-qr-status-group,
.gyofu-qr-wrapper .gyofu-qr-group-name { color: var(--gyofu-text); flex: 1; font-size: 1.08em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-status-badge { border-radius: 999px; flex-shrink: 0; font-size: 0.9em; font-weight: 900; padding: 6px 12px; }
.gyofu-qr-wrapper .gyofu-qr-status-badge.waiting { background: var(--gyofu-base-dark); color: var(--gyofu-text-light); }
.gyofu-qr-wrapper .gyofu-qr-status-badge.submitted,
.gyofu-qr-wrapper .gyofu-qr-status-badge.completed { background: var(--gyofu-accent); color: var(--gyofu-main-dark); }
.gyofu-qr-wrapper .gyofu-qr-status-badge.timeout { background: #fff8df; color: var(--gyofu-accent-dark); }

.gyofu-qr-wrapper .gyofu-qr-game-header { align-items: center; border-bottom: 2px solid var(--gyofu-border); display: flex; gap: 18px; justify-content: space-between; margin-bottom: 24px; padding-bottom: 20px; }
.gyofu-qr-wrapper .gyofu-qr-game-header h2 { text-align: left !important; }
.gyofu-qr-wrapper .gyofu-qr-game-controls { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; }
.gyofu-qr-wrapper .gyofu-qr-game-layout { display: grid; gap: 22px; grid-template-columns: minmax(0, 1fr) 320px; }
.gyofu-qr-wrapper .gyofu-qr-progress-guide ol { color: var(--gyofu-text); font-size: 1.05em; font-weight: 800; margin: 0 !important; padding-left: 1.4em !important; }
.gyofu-qr-wrapper .gyofu-qr-progress-guide li { margin: 10px 0; }

.gyofu-qr-wrapper .gyofu-qr-player-container { max-width: 560px; padding: 28px; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-warning { background: #fff8df; border: 2px solid var(--gyofu-accent); border-radius: 16px; color: var(--gyofu-main-dark); font-size: 1.05em; font-weight: 900; margin-bottom: 18px; padding: 12px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-loading,
.gyofu-qr-wrapper .gyofu-qr-player-info,
.gyofu-qr-wrapper .gyofu-qr-waiting,
.gyofu-qr-wrapper .gyofu-qr-player-result { text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-loading { color: var(--gyofu-main); font-size: 1.25em; font-weight: 800; padding: 36px; }
.gyofu-qr-wrapper .gyofu-qr-player-info h2 { color: var(--gyofu-main) !important; font-size: clamp(2.3rem, 10vw, 3.6rem) !important; line-height: 1 !important; margin: 6px 0 12px !important; }
.gyofu-qr-wrapper .gyofu-qr-round-info,
.gyofu-qr-wrapper .gyofu-qr-select-title { color: var(--gyofu-text-light); font-size: 1.1em; font-weight: 900; margin: 8px 0; }
.gyofu-qr-wrapper .gyofu-qr-numbers { display: grid; gap: 12px; grid-template-columns: repeat(5, minmax(0, 1fr)); margin: 20px 0; }
.gyofu-qr-wrapper .gyofu-qr-number-btn { aspect-ratio: 1; background: var(--gyofu-base) !important; border: 3px solid var(--gyofu-main) !important; border-radius: 20px !important; color: var(--gyofu-main) !important; font-size: clamp(1.6rem, 7vw, 2.4rem) !important; font-weight: 900 !important; min-height: 64px; padding: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-number-btn:hover,
.gyofu-qr-wrapper .gyofu-qr-number-btn.selected { background: var(--gyofu-main) !important; color: var(--gyofu-base) !important; }
.gyofu-qr-wrapper .gyofu-qr-confirm { text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-selected-display,
.gyofu-qr-wrapper .gyofu-qr-confirm-question { color: var(--gyofu-text-light); font-size: 1.1em; font-weight: 800; }
.gyofu-qr-wrapper .gyofu-qr-selected-number { color: var(--gyofu-main); font-size: 5em; font-weight: 900; line-height: 1; margin: 14px 0; }
.gyofu-qr-wrapper .gyofu-qr-confirm-buttons { display: flex; gap: 12px; justify-content: center; margin-top: 20px; }
.gyofu-qr-wrapper .gyofu-qr-waiting { padding: 38px 18px; }
.gyofu-qr-wrapper .gyofu-qr-waiting h3,
.gyofu-qr-wrapper .gyofu-qr-player-result h3 { color: var(--gyofu-main) !important; font-size: 2em !important; margin-bottom: 12px !important; }
.gyofu-qr-wrapper .gyofu-qr-waiting p,
.gyofu-qr-wrapper .gyofu-qr-player-result p { color: var(--gyofu-text-light); font-size: 1.1em; font-weight: 800; }
.gyofu-qr-wrapper .gyofu-qr-spinner { animation: gyofu-spin 1s linear infinite; border: 6px solid var(--gyofu-base-dark); border-radius: 50%; border-top-color: var(--gyofu-accent); height: 58px; margin: 22px auto; width: 58px; }
@keyframes gyofu-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
.gyofu-qr-wrapper .gyofu-qr-player-result { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 22px; padding: 28px; }
.gyofu-qr-wrapper .gyofu-qr-result-number { color: var(--gyofu-text); font-size: 1.2em; font-weight: 900; margin: 18px 0 8px; }
.gyofu-qr-wrapper .gyofu-qr-result-number strong { color: var(--gyofu-main); font-size: 2.4em; margin-left: 8px; }
.gyofu-qr-wrapper .gyofu-qr-result-score { color: var(--gyofu-accent-dark); font-size: 3em; font-weight: 900; line-height: 1.1; margin: 10px 0; }
.gyofu-qr-wrapper .gyofu-qr-result-score.zero { color: var(--gyofu-text-light); }

.gyofu-qr-wrapper #gyofu-qr-result-popup { align-items: center; background: rgba(15, 30, 58, 0.86); display: flex; height: 100%; justify-content: center; left: 0; padding: 20px; position: fixed; top: 0; width: 100%; z-index: 9999; }
.gyofu-qr-wrapper .gyofu-qr-popup-content { animation: gyofu-popup-appear 0.24s ease-out; max-height: 90vh; max-width: 980px; overflow-y: auto; padding: 34px; width: 100%; }
@keyframes gyofu-popup-appear { from { opacity: 0; transform: scale(0.96); } to { opacity: 1; transform: scale(1); } }
.gyofu-qr-wrapper .gyofu-qr-reveal-steps { display: grid; gap: 12px; grid-template-columns: repeat(4, 1fr); margin: 22px 0; }
.gyofu-qr-wrapper .gyofu-qr-reveal-steps section { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 18px; padding: 14px; }
.gyofu-qr-wrapper .gyofu-qr-reveal-steps span { align-items: center; background: var(--gyofu-accent); border-radius: 50%; color: var(--gyofu-main-dark); display: inline-flex; font-weight: 900; height: 30px; justify-content: center; margin-bottom: 8px; width: 30px; }
.gyofu-qr-wrapper .gyofu-qr-reveal-steps strong { color: var(--gyofu-main); display: block; font-size: 1.05em; }
.gyofu-qr-wrapper .gyofu-qr-reveal-steps p { color: var(--gyofu-text-light); font-size: 0.9em; margin: 4px 0 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-confirm-table { border-collapse: separate; border-spacing: 0; margin: 20px 0; overflow: hidden; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-confirm-table th,
.gyofu-qr-wrapper .gyofu-qr-confirm-table td { border-bottom: 2px solid var(--gyofu-border); font-size: 1.12em; padding: 15px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-confirm-table th { background: var(--gyofu-main); color: var(--gyofu-base) !important; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-confirm-table .duplicate { background: #fff2f2; color: #b23b3b; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-confirm-table .unique { background: #fbfff5; color: var(--gyofu-accent-dark); font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-ranking-list { list-style: none !important; margin: 22px 0 !important; padding: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-ranking-item { align-items: center; animation: gyofu-slide-in 0.28s ease-out; background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-left: 10px solid var(--gyofu-main); border-radius: 20px; display: flex; justify-content: space-between; margin: 12px 0 !important; padding: 18px; }
@keyframes gyofu-slide-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.gyofu-qr-wrapper .gyofu-qr-ranking-item.gyofu-qr-rank-1,
.gyofu-qr-wrapper .gyofu-qr-ranking-item.rank-1 { background: #fff8df; border-color: var(--gyofu-accent); border-left-color: var(--gyofu-accent); }
.gyofu-qr-wrapper .gyofu-qr-ranking-item.gyofu-qr-rank-2,
.gyofu-qr-wrapper .gyofu-qr-ranking-item.rank-2 { border-left-color: var(--gyofu-text-light); }
.gyofu-qr-wrapper .gyofu-qr-ranking-item.gyofu-qr-rank-3,
.gyofu-qr-wrapper .gyofu-qr-ranking-item.rank-3 { border-left-color: var(--gyofu-accent-dark); }
.gyofu-qr-wrapper .gyofu-qr-rank-left,
.gyofu-qr-wrapper .gyofu-qr-score-display { align-items: center; display: flex; gap: 16px; }
.gyofu-qr-wrapper .gyofu-qr-rank-num { color: var(--gyofu-main); font-size: 2.2em; font-weight: 900; min-width: 72px; }
.gyofu-qr-wrapper .gyofu-qr-group-label { color: var(--gyofu-text); font-size: 1.45em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-total-score { color: var(--gyofu-main); font-size: 2.2em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-add-score { color: var(--gyofu-accent-dark); font-size: 1.35em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-add-score.zero { color: var(--gyofu-text-light); }

@media (max-width: 1100px) {
  .gyofu-qr-wrapper .gyofu-qr-lobby-content,
  .gyofu-qr-wrapper .gyofu-qr-game-layout,
  .gyofu-qr-wrapper .gyofu-qr-reveal-steps { grid-template-columns: 1fr; }
  .gyofu-qr-wrapper .gyofu-qr-game-header { align-items: stretch; flex-direction: column; }
  .gyofu-qr-wrapper .gyofu-qr-game-controls { justify-content: stretch; }
  .gyofu-qr-wrapper .gyofu-qr-game-controls button { flex: 1; }
}

@media (max-width: 768px) {
  .gyofu-qr-wrapper #gyofu-qr-setup,
  .gyofu-qr-wrapper #gyofu-qr-lobby,
  .gyofu-qr-wrapper #gyofu-qr-game,
  .gyofu-qr-wrapper.gyofu-qr-player { padding: 14px; }
  .gyofu-qr-wrapper .gyofu-qr-setup-card,
  .gyofu-qr-wrapper .gyofu-qr-lobby-card,
  .gyofu-qr-wrapper .gyofu-qr-game-card,
  .gyofu-qr-wrapper .gyofu-qr-player-container,
  .gyofu-qr-wrapper .gyofu-qr-popup-content { border-radius: 22px; padding: 20px; }
  .gyofu-qr-wrapper .gyofu-qr-confirm-buttons,
  .gyofu-qr-wrapper .gyofu-qr-action-row,
  .gyofu-qr-wrapper .gyofu-qr-game-controls,
  .gyofu-qr-wrapper .gyofu-qr-ranking-item { flex-direction: column; }
  .gyofu-qr-wrapper .gyofu-qr-confirm-buttons button,
  .gyofu-qr-wrapper .gyofu-qr-action-row button,
  .gyofu-qr-wrapper .gyofu-qr-game-controls button { width: 100%; }
  .gyofu-qr-wrapper .gyofu-qr-numbers { gap: 9px; grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .gyofu-qr-wrapper .gyofu-qr-number-btn { border-radius: 16px !important; min-height: 56px; }
  .gyofu-qr-wrapper .gyofu-qr-confirm-table { display: block; overflow-x: auto; white-space: nowrap; }
  .gyofu-qr-wrapper .gyofu-qr-rank-left,
  .gyofu-qr-wrapper .gyofu-qr-score-display { justify-content: center; width: 100%; }
}

/* ===== 代表端末制限 / 結果発表POPUP ===== */
body.gyofu-qr-modal-open { overflow: hidden; }
.gyofu-qr-wrapper .gyofu-qr-lobby-actions { align-items: center; display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.gyofu-qr-wrapper .gyofu-qr-btn-release { background: #fff2f2 !important; border: 2px solid #f0b5b5 !important; color: #b23b3b !important; font-size: 0.9em !important; min-height: 38px; padding: 7px 12px !important; }
.gyofu-qr-wrapper .gyofu-qr-btn-release:disabled { background: var(--gyofu-base-dark) !important; border-color: var(--gyofu-border) !important; color: var(--gyofu-text-light) !important; cursor: not-allowed !important; opacity: 0.55; transform: none !important; }
.gyofu-qr-wrapper .gyofu-qr-group-select-note { color: var(--gyofu-text-light); font-size: 1.05em; font-weight: 800; margin: 10px 0 18px !important; }
.gyofu-qr-wrapper .gyofu-qr-group-select-grid { display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn { background: var(--gyofu-base) !important; border: 3px solid var(--gyofu-main) !important; color: var(--gyofu-main) !important; font-size: 1.2em !important; padding: 18px 10px !important; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn:hover { background: var(--gyofu-main) !important; color: var(--gyofu-base) !important; }

.gyofu-qr-wrapper .gyofu-qr-result-modal { background: var(--gyofu-base); border-radius: 28px; overflow: hidden; }
.gyofu-qr-wrapper .gyofu-qr-result-modal-header { background: linear-gradient(135deg, var(--gyofu-main-dark), var(--gyofu-main)); padding: 24px 28px; }
.gyofu-qr-wrapper .gyofu-qr-result-modal-header h2 { color: var(--gyofu-base) !important; font-size: clamp(2rem, 4vw, 3rem) !important; line-height: 1.15 !important; margin: 0 !important; text-align: center !important; }
.gyofu-qr-wrapper .gyofu-qr-result-modal-body { padding: 26px 28px; }
.gyofu-qr-wrapper .gyofu-qr-result-summary { display: grid; gap: 14px; grid-template-columns: repeat(3, 1fr); margin-bottom: 22px; }
.gyofu-qr-wrapper .gyofu-qr-result-summary div { background: #fff8df; border: 2px solid var(--gyofu-accent); border-radius: 18px; padding: 16px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-result-summary span { color: var(--gyofu-main-dark); display: block; font-size: 1em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-result-summary strong { color: var(--gyofu-accent-dark); display: block; font-size: 2.1em; font-weight: 900; line-height: 1.1; margin-top: 4px; }
.gyofu-qr-wrapper .gyofu-qr-result-table-wrap { overflow-x: auto; }
.gyofu-qr-wrapper .gyofu-qr-result-table th,
.gyofu-qr-wrapper .gyofu-qr-result-table td { font-size: 1.18em; }
.gyofu-qr-wrapper .gyofu-qr-result-table tr.duplicate-row td { background: #fff2f2; color: #9f2f2f; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-result-table tr.unique-row td { background: #f3fff0; color: #2f7d3b; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-ranking-block h3 { color: var(--gyofu-main) !important; font-size: 1.6em !important; margin: 22px 0 8px !important; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-result-modal-footer { background: var(--gyofu-base-light); border-top: 2px solid var(--gyofu-border); display: flex; gap: 14px; justify-content: center; padding: 22px 28px; }

@media (max-width: 768px) {
  .gyofu-qr-wrapper .gyofu-qr-lobby-actions,
  .gyofu-qr-wrapper .gyofu-qr-result-modal-footer { align-items: stretch; flex-direction: column; width: 100%; }
  .gyofu-qr-wrapper .gyofu-qr-result-summary,
  .gyofu-qr-wrapper .gyofu-qr-group-select-grid { grid-template-columns: 1fr; }
  .gyofu-qr-wrapper .gyofu-qr-result-modal-body,
  .gyofu-qr-wrapper .gyofu-qr-result-modal-header,
  .gyofu-qr-wrapper .gyofu-qr-result-modal-footer { padding: 18px; }
}

/* ===== 授業運用改善 ===== */
.gyofu-qr-wrapper .gyofu-qr-btn-danger {
  background: linear-gradient(135deg, #b23b3b, #d95b5b) !important;
  box-shadow: 0 10px 24px rgba(178, 59, 59, 0.26) !important;
  color: var(--gyofu-base) !important;
  font-size: 1.08em !important;
  padding: 14px 28px !important;
}
.gyofu-qr-wrapper .gyofu-qr-btn-danger:hover { background: linear-gradient(135deg, #8f2727, #b23b3b) !important; }
.gyofu-qr-wrapper .gyofu-qr-session-id { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 16px; color: var(--gyofu-text-light); font-size: 0.92em; font-weight: 800; margin-top: 16px; padding: 10px; text-align: center; word-break: break-all; }
.gyofu-qr-wrapper .gyofu-qr-session-id strong { color: var(--gyofu-main); }
.gyofu-qr-wrapper .gyofu-qr-lobby-summary { background: linear-gradient(135deg, #fff8df, #ffffff); border: 3px solid var(--gyofu-accent); border-radius: 22px; margin-bottom: 18px; padding: 18px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-lobby-count strong { color: var(--gyofu-main); display: block; font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 900; line-height: 1; }
.gyofu-qr-wrapper .gyofu-qr-lobby-count span { color: var(--gyofu-text-light); display: block; font-weight: 900; margin-top: 4px; }
.gyofu-qr-wrapper .gyofu-qr-lobby-ready-message { color: var(--gyofu-accent-dark); font-size: 1.55em; font-weight: 900; margin-top: 10px; }
.gyofu-qr-wrapper .gyofu-qr-lobby-count.ready + .gyofu-qr-lobby-ready-message { color: #2f7d3b; }
.gyofu-qr-wrapper .gyofu-qr-lobby-missing { color: var(--gyofu-main-dark); font-size: 0.98em; font-weight: 800; margin-top: 8px; }
.gyofu-qr-wrapper .gyofu-qr-status-item:not(.submitted) { opacity: 0.9; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn { align-items: center; display: flex !important; flex-direction: column; gap: 6px; justify-content: center; min-height: 92px; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn span { font-size: 1.2em; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn strong { border-radius: 999px; font-size: 0.86em; padding: 4px 10px; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn.available strong { background: #f3fff0; color: #2f7d3b; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn.occupied { background: var(--gyofu-base-dark) !important; border-color: var(--gyofu-border) !important; color: var(--gyofu-text-light) !important; opacity: 0.58; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn.occupied strong { background: #fff2f2; color: #b23b3b; }
.gyofu-qr-wrapper .gyofu-qr-group-select-btn:disabled { cursor: not-allowed !important; transform: none !important; }
.gyofu-qr-wrapper .gyofu-qr-player-error,
.gyofu-qr-wrapper .gyofu-qr-player-notice { background: #fff8df; border: 2px solid var(--gyofu-accent); border-radius: 18px; color: var(--gyofu-main-dark); font-size: 1.08em; font-weight: 900; margin: 16px 0; padding: 18px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-player-error { background: #fff2f2; border-color: #f0b5b5; color: #b23b3b; }
.gyofu-qr-toast { background: #1e3a5f; border-radius: 10px; color: #fff; font-family: "Segoe UI", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif; font-weight: 800; left: 50%; padding: 15px 30px; position: fixed; top: 20px; transform: translateX(-50%); z-index: 10000; }
.gyofu-qr-wrapper .gyofu-qr-strategy-box { border-top: 2px solid var(--gyofu-border); margin-top: 18px; padding-top: 18px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-strategy-timer,
.gyofu-qr-wrapper .gyofu-qr-strategy-player-note { background: var(--gyofu-main); border: 3px solid var(--gyofu-accent); border-radius: 18px; color: var(--gyofu-base); font-size: 1.5em; font-weight: 900; margin-top: 14px; padding: 14px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-strategy-player-note { background: #fff8df; color: var(--gyofu-main-dark); font-size: 1.1em; margin: 12px auto 0; max-width: 360px; }
.gyofu-qr-wrapper .gyofu-qr-round-history-panel { grid-column: 1 / -1; }
.gyofu-qr-wrapper .gyofu-qr-round-history { color: var(--gyofu-text); font-size: 1.05em; font-weight: 800; }
.gyofu-qr-wrapper .gyofu-qr-round-history ul { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-round-history li { background: var(--gyofu-base); border: 2px solid var(--gyofu-border); border-left: 8px solid var(--gyofu-accent); border-radius: 14px; margin: 8px 0 !important; padding: 12px 14px; }
.gyofu-qr-wrapper .gyofu-qr-reset-modal { align-items: center; background: rgba(15, 30, 58, 0.86); display: flex; height: 100%; justify-content: center; left: 0; padding: 20px; position: fixed; top: 0; width: 100%; z-index: 10000; }
.gyofu-qr-wrapper .gyofu-qr-reset-modal-content { background: var(--gyofu-base); border: 4px solid #d95b5b; border-radius: 26px; box-shadow: var(--gyofu-shadow); max-width: 560px; padding: 34px; text-align: center; width: 100%; }
.gyofu-qr-wrapper .gyofu-qr-reset-modal-content h2 { color: #b23b3b !important; font-size: 2em !important; margin-bottom: 14px !important; }
.gyofu-qr-wrapper .gyofu-qr-reset-modal-content p { color: var(--gyofu-main-dark); font-size: 1.18em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-reset-modal-actions { display: flex; gap: 14px; justify-content: center; margin-top: 24px; }
.gyofu-qr-wrapper .gyofu-qr-result-highlights { display: grid; gap: 14px; grid-template-columns: repeat(3, 1fr); margin-bottom: 22px; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card { border-radius: 20px; border: 3px solid var(--gyofu-border); padding: 18px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card span { color: var(--gyofu-main-dark); display: block; font-size: 1em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card strong { display: block; font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 900; line-height: 1.1; margin-top: 6px; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.duplicate { background: #fff2f2; border-color: #f0b5b5; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.duplicate strong { color: #b23b3b; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.safe { background: #f3fff0; border-color: #bde6b8; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.safe strong { color: #2f7d3b; }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.missing { background: #fff8df; border-color: var(--gyofu-accent); }
.gyofu-qr-wrapper .gyofu-qr-highlight-card.missing strong { color: var(--gyofu-accent-dark); font-size: clamp(1.2rem, 2.2vw, 1.8rem); }
.gyofu-qr-wrapper .gyofu-qr-reveal-current { color: var(--gyofu-accent-light); font-size: 1.2em; font-weight: 900; margin-top: 10px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-reveal-step-tabs { display: grid; gap: 10px; grid-template-columns: repeat(4, 1fr); margin: 16px 0 22px; }
.gyofu-qr-wrapper .gyofu-qr-reveal-step-tabs span { background: var(--gyofu-base-dark); border: 2px solid var(--gyofu-border); border-radius: 999px; color: var(--gyofu-text-light); font-size: 0.92em; font-weight: 900; padding: 8px 10px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-reveal-step-tabs span.active { background: var(--gyofu-accent); border-color: var(--gyofu-accent-dark); color: var(--gyofu-main-dark); }
.gyofu-qr-wrapper .gyofu-qr-reveal-number-grid,
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-grid,
.gyofu-qr-wrapper .gyofu-qr-podium-grid { display: grid; gap: 16px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.gyofu-qr-wrapper .gyofu-qr-reveal-number-card,
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card,
.gyofu-qr-wrapper .gyofu-qr-podium-card { background: var(--gyofu-base-light); border: 3px solid var(--gyofu-border); border-radius: 22px; padding: 20px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-reveal-number-card span,
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card span { color: var(--gyofu-main); display: block; font-size: 1.15em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-reveal-number-card strong { color: var(--gyofu-accent-dark); display: block; font-size: clamp(3rem, 8vw, 5rem); font-weight: 900; line-height: 1; }
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card strong { display: block; font-size: clamp(1.8rem, 4vw, 2.7rem); font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card.duplicate { background: #fff2f2; border-color: #f0b5b5; color: #b23b3b; }
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card.safe { background: #f3fff0; border-color: #bde6b8; color: #2f7d3b; }
.gyofu-qr-wrapper .gyofu-qr-reveal-judge-card.missing { background: #fff8df; border-color: var(--gyofu-accent); color: var(--gyofu-accent-dark); }
.gyofu-qr-wrapper .gyofu-qr-podium-card.rank-1 { background: #fff8df; border-color: var(--gyofu-accent); }
.gyofu-qr-wrapper .gyofu-qr-podium-card.rank-2 { background: #f4f5f7; border-color: #aeb6bf; }
.gyofu-qr-wrapper .gyofu-qr-podium-card.rank-3 { background: #fff1e6; border-color: #b87333; }
.gyofu-qr-wrapper .gyofu-qr-podium-rank { color: var(--gyofu-main); font-size: 2em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-podium-group { color: var(--gyofu-text); font-size: 1.45em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-podium-score { color: var(--gyofu-accent-dark); font-size: 2.5em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-next-round-strong { background: linear-gradient(135deg, var(--gyofu-accent), var(--gyofu-accent-light)) !important; color: var(--gyofu-main-dark) !important; font-size: 1.25em !important; }

@media (max-width: 900px) {
  .gyofu-qr-wrapper .gyofu-qr-result-highlights,
  .gyofu-qr-wrapper .gyofu-qr-reveal-step-tabs,
  .gyofu-qr-wrapper .gyofu-qr-reveal-number-grid,
  .gyofu-qr-wrapper .gyofu-qr-reveal-judge-grid,
  .gyofu-qr-wrapper .gyofu-qr-podium-grid { grid-template-columns: 1fr; }
  .gyofu-qr-wrapper .gyofu-qr-reset-modal-actions { flex-direction: column; }
}

/* ===== 結果発表後導線 / 最終結果 ===== */
.gyofu-qr-wrapper #gyofu-qr-final {
  background: radial-gradient(circle at top left, rgba(244, 207, 95, 0.22), transparent 30%), linear-gradient(135deg, var(--gyofu-main-dark), var(--gyofu-main));
  min-height: 100vh;
  padding: 28px;
}
.gyofu-qr-wrapper #gyofu-qr-final { align-items: center; display: flex; justify-content: center; }
.gyofu-qr-wrapper .gyofu-qr-post-result-actions { margin: 0 0 22px; }
.gyofu-qr-wrapper .gyofu-qr-post-result-card { align-items: center; background: #fff8df; border: 3px solid var(--gyofu-accent); border-radius: 22px; display: flex; gap: 18px; justify-content: space-between; padding: 20px 22px; }
.gyofu-qr-wrapper .gyofu-qr-post-result-card h3 { color: var(--gyofu-main) !important; font-size: 1.35em !important; margin: 10px 0 4px !important; }
.gyofu-qr-wrapper .gyofu-qr-post-result-card p { color: var(--gyofu-main-dark); font-weight: 800; margin: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-post-result-buttons,
.gyofu-qr-wrapper .gyofu-qr-final-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.gyofu-qr-wrapper .gyofu-qr-game-controls button:disabled { cursor: not-allowed !important; opacity: 0.5; transform: none !important; }
.gyofu-qr-wrapper .gyofu-qr-lobby-missing { background: var(--gyofu-base); border: 2px solid var(--gyofu-border); border-radius: 16px; margin-top: 12px; padding: 12px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-lobby-missing span { color: var(--gyofu-text-light); display: block; font-size: 0.9em; font-weight: 900; }
.gyofu-qr-wrapper .gyofu-qr-lobby-missing strong { color: var(--gyofu-main); display: block; font-size: 1.15em; font-weight: 900; margin-top: 4px; }
.gyofu-qr-wrapper .gyofu-qr-final-card { max-width: 1120px; }
.gyofu-qr-wrapper .gyofu-qr-final-hero { background: linear-gradient(135deg, var(--gyofu-main-dark), var(--gyofu-main)); border-radius: 24px; margin-bottom: 24px; padding: 34px; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-final-hero h2 { color: var(--gyofu-base) !important; font-size: clamp(2.3rem, 5vw, 4rem) !important; line-height: 1.1 !important; margin: 12px 0 8px !important; }
.gyofu-qr-wrapper .gyofu-qr-final-hero p { color: var(--gyofu-accent-light); font-size: 1.2em; font-weight: 900; margin: 0 !important; }
.gyofu-qr-wrapper .gyofu-qr-final-top3,
.gyofu-qr-wrapper .gyofu-qr-final-full-ranking,
.gyofu-qr-wrapper .gyofu-qr-final-history { background: var(--gyofu-base-light); border: 2px solid var(--gyofu-border); border-radius: 22px; margin: 18px 0; padding: 22px; }
.gyofu-qr-wrapper .gyofu-qr-final-top3 h3,
.gyofu-qr-wrapper .gyofu-qr-final-full-ranking h3,
.gyofu-qr-wrapper .gyofu-qr-final-history h3 { color: var(--gyofu-main) !important; font-size: 1.55em !important; margin: 0 0 16px !important; text-align: center; }
.gyofu-qr-wrapper .gyofu-qr-final-actions { border-top: 2px solid var(--gyofu-border); margin-top: 24px; padding-top: 22px; }
.gyofu-qr-wrapper .gyofu-qr-waiting-before-result strong { color: var(--gyofu-main); font-size: 1.6em; }
.gyofu-qr-wrapper .gyofu-qr-player-result-after { border-color: var(--gyofu-accent); }

@media (max-width: 768px) {
  .gyofu-qr-wrapper #gyofu-qr-final { padding: 14px; }
  .gyofu-qr-wrapper .gyofu-qr-post-result-card { align-items: stretch; flex-direction: column; }
  .gyofu-qr-wrapper .gyofu-qr-post-result-buttons,
  .gyofu-qr-wrapper .gyofu-qr-final-actions { flex-direction: column; }
}
