Files
justice/www/html/Game/public/play.html
T

2721 lines
93 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!DOCTYPE html>
<html lang="th">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="Cache-Control" content="no-store, max-age=0">
<title>เล่น — Game</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Orbitron:wght@500;700;800&family=Share+Tech+Mono&display=swap" rel="stylesheet">
<link rel="stylesheet" href="css/style.css?v=20260427-canvas-pixel">
<style>
html, body { height: 100%; margin: 0; }
body { min-height: 100dvh; }
.sr-only {
position: absolute !important;
width: 1px !important;
height: 1px !important;
padding: 0 !important;
margin: -1px !important;
overflow: hidden !important;
clip: rect(0, 0, 0, 0) !important;
white-space: nowrap !important;
border: 0 !important;
}
.play-canvas-stack {
position: relative;
flex: 1 1 auto;
min-height: 0;
min-width: 0;
display: flex;
flex-direction: column;
}
.play-canvas-stack #game-canvas {
flex: 1 1 auto;
min-height: 0;
width: 100%;
display: block;
touch-action: none;
image-rendering: pixelated;
image-rendering: crisp-edges;
}
/* หลังกดรับหลักฐานในหน้าสรุป — BG ดำ alpha ทั้งจอ + timeup ติดโซนโต๊ะเหมือน #quiz-map-question-panel */
#quiz-carry-timeup-desk-layer {
position: absolute;
inset: 0;
z-index: 65;
pointer-events: none;
box-sizing: border-box;
}
#quiz-carry-timeup-desk-layer.is-hidden {
display: none !important;
}
.qc-timeup-dim {
position: absolute;
inset: 0;
z-index: 0;
background: rgba(0, 0, 0, 0.58);
pointer-events: none;
}
.qc-timeup-desk-anchor {
position: absolute;
z-index: 1;
box-sizing: border-box;
padding: clamp(6px, 1.5vw, 14px);
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-align: center;
overflow: visible;
pointer-events: none;
}
.qc-timeup-txt-img {
width: min(94%, 520px);
max-width: 100%;
height: auto;
object-fit: contain;
display: block;
filter: drop-shadow(0 10px 36px rgba(0, 0, 0, 0.65)) drop-shadow(0 0 20px rgba(255, 60, 80, 0.15));
}
/* หลัง timeup 5s — mock จบ: result-complete / result-gameover เต็มพื้นที่แคนวาส */
#quiz-carry-result-end-layer {
position: absolute;
inset: 0;
z-index: 66;
pointer-events: none;
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
#quiz-carry-result-end-layer.is-hidden {
display: none !important;
}
.qc-result-end-dim {
position: absolute;
inset: 0;
z-index: 0;
background: rgba(0, 0, 0, 0.62);
pointer-events: none;
}
.qc-result-end-img {
position: relative;
z-index: 1;
width: min(96vw, 920px);
max-height: min(88vh, 640px);
height: auto;
object-fit: contain;
display: block;
pointer-events: none;
filter: drop-shadow(0 12px 40px rgba(0, 0, 0, 0.7));
}
/* Quiz carry — ปุ่ม GRAB มุมขวาล่าง (เทียบ F) · mockup ≈ 10–12% ความสูงจอ */
#quiz-carry-grab-btn {
position: absolute;
right: max(10px, env(safe-area-inset-right, 0px));
bottom: max(10px, env(safe-area-inset-bottom, 0px));
z-index: 60;
width: min(12vh, 13vw, 168px);
height: min(12vh, 13vw, 168px);
padding: 0;
margin: 0;
border: none;
border-radius: 50%;
background: transparent;
cursor: default;
opacity: 0.38;
transition: opacity 0.2s ease, transform 0.15s ease;
touch-action: manipulation;
-webkit-tap-highlight-color: transparent;
box-shadow: none;
}
#quiz-carry-grab-btn.is-hidden {
display: none !important;
}
#quiz-carry-grab-btn.quiz-carry-grab-btn--active {
opacity: 1;
cursor: pointer;
}
#quiz-carry-grab-btn.quiz-carry-grab-btn--active:active {
transform: scale(0.96);
}
#quiz-carry-grab-btn.quiz-carry-grab-btn--place.quiz-carry-grab-btn--active {
filter: drop-shadow(0 0 10px rgba(94, 234, 255, 0.45));
}
#quiz-carry-grab-btn img {
width: 100%;
height: 100%;
object-fit: contain;
display: block;
pointer-events: none;
user-select: none;
}
/* Last Light (mno9kb07) — ปุ่มกระโดดมุมขวาล่าง · เทียบ Space / W / ↑ */
#gauntlet-crown-jump-btn {
position: absolute;
right: max(10px, env(safe-area-inset-right, 0px));
bottom: max(10px, env(safe-area-inset-bottom, 0px));
z-index: 59;
width: min(14vh, 16vw, 200px);
height: min(14vh, 16vw, 200px);
padding: 0;
margin: 0;
border: none;
border-radius: 50%;
background: transparent;
cursor: pointer;
opacity: 1;
transition: transform 0.15s ease, filter 0.15s ease;
touch-action: manipulation;
-webkit-tap-highlight-color: transparent;
box-shadow: none;
filter: drop-shadow(0 0 12px rgba(94, 234, 255, 0.35));
}
#gauntlet-crown-jump-btn.is-hidden {
display: none !important;
}
#gauntlet-crown-jump-btn:active {
transform: scale(0.96);
}
#gauntlet-crown-jump-btn img {
width: 100%;
height: 100%;
object-fit: contain;
display: block;
pointer-events: none;
user-select: none;
}
#quiz-game-overlay {
position: fixed;
left: 50%;
transform: translateX(-50%);
bottom: max(12px, env(safe-area-inset-bottom));
z-index: 650;
max-width: min(96vw, 520px);
width: 100%;
pointer-events: none;
}
#quiz-game-overlay.is-hidden { display: none !important; }
.quiz-game-inner {
background: rgba(12, 14, 28, 0.92);
border: 1px solid rgba(122, 162, 247, 0.45);
border-radius: 14px;
padding: 0.65rem 1rem 0.75rem;
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
backdrop-filter: blur(10px);
}
.quiz-game-phase {
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
color: #7aa2f7;
margin-bottom: 0.35rem;
}
.quiz-game-q {
margin: 0 0 0.45rem;
font-size: clamp(0.95rem, 3vw, 1.1rem);
line-height: 1.45;
color: #e2e8f0;
font-weight: 600;
white-space: pre-line;
}
.quiz-game-timer {
font-variant-numeric: tabular-nums;
font-size: 1.35rem;
font-weight: 800;
color: #9ece6a;
text-shadow: 0 0 12px rgba(158, 206, 106, 0.35);
}
.quiz-play-legend {
margin: 0;
font-size: 0.72rem;
line-height: 1.4;
color: #a9b1d6;
}
#quiz-map-question-panel {
position: absolute;
z-index: 2;
pointer-events: none;
box-sizing: border-box;
padding: clamp(6px, 1.5vw, 14px);
display: flex;
flex-direction: column;
align-items: stretch;
justify-content: flex-start;
text-align: center;
overflow: visible;
scrollbar-width: none;
-ms-overflow-style: none;
--qmap-bg: rgba(12, 14, 28, 0.88);
--qmap-border: rgba(255, 214, 102, 0.7);
--qmap-border-w: 2px;
--qmap-shadow: 0 8px 28px rgba(0, 0, 0, 0.5);
background: var(--qmap-bg);
border: var(--qmap-border-w) solid var(--qmap-border);
border-radius: 12px;
box-shadow: var(--qmap-shadow);
}
/* เกมถูก/ผิด: จัดข้อความกึ่งกลางแนวตั้งในโซนทอง (quiz_carry ไม่ใส่คลาสนี้ — ยังใช้ไอคอน/คะแนนด้านล่าง) */
#quiz-map-question-panel.quiz-map-question-panel--true-false {
justify-content: center;
}
/* แมปภารกิจคำถาม (mng8a80o) ช่วงเล่น — กรอบแบบ mock โดยไม่ต้องมี hud-question-plaque.png */
#quiz-map-question-panel.quiz-map-question-panel--question-mission-live {
background:
linear-gradient(180deg, rgba(14, 24, 44, 0.5), rgba(8, 12, 26, 0.82)),
linear-gradient(90deg, rgba(0, 255, 230, 0.07), transparent 38%, transparent 62%, rgba(255, 100, 70, 0.06)),
var(--qmap-bg, rgba(12, 14, 28, 0.92));
border-color: rgba(255, 224, 130, 0.5);
box-shadow:
var(--qmap-shadow, 0 8px 28px rgba(0, 0, 0, 0.55)),
inset 0 0 0 1px rgba(0, 255, 240, 0.14),
0 0 32px rgba(0, 200, 255, 0.1);
}
/* บรรทัดเล็กเหนือข้อความคำถาม — หมายเลขข้อ (เทียบ mock - Quiz 3) */
#quiz-map-question-panel .quiz-map-question-kicker {
position: relative;
z-index: 1;
flex: 0 0 auto;
width: 100%;
box-sizing: border-box;
margin: 0 0 0.28rem;
padding: 0 2px;
font-family: 'Orbitron', 'Share Tech Mono', ui-monospace, sans-serif;
font-size: clamp(0.52rem, 1.35vw, 0.66rem);
font-weight: 600;
letter-spacing: 0.16em;
text-transform: uppercase;
line-height: 1.25;
text-align: center;
color: rgba(236, 252, 255, 0.95);
text-shadow:
0 0 10px rgba(0, 240, 255, 0.42),
0 1px 8px rgba(0, 0, 0, 0.88);
}
#quiz-map-question-panel .quiz-map-question-kicker.is-hidden {
display: none !important;
}
#quiz-map-question-panel.is-hidden { display: none !important; }
#quiz-map-question-panel::-webkit-scrollbar {
display: none;
width: 0;
height: 0;
}
/* ขนาดตั้งต้น — โหมด quiz_carry ถูกทับด้วย play.js ตามสัดส่วนกล่อง + ธีม */
#quiz-map-question-text {
margin: 0;
font-size: 22px;
font-weight: 600;
line-height: 1.45;
--qmap-text: #f1f5f9;
--qmap-text-shadow: 0 1px 10px rgba(0, 0, 0, 0.55);
color: var(--qmap-text);
text-shadow: var(--qmap-text-shadow);
width: 100%;
box-sizing: border-box;
flex: 0 1 auto;
min-height: 0;
max-height: 100%;
align-self: center;
text-align: center;
overflow: hidden;
overflow-wrap: anywhere;
word-break: break-word;
white-space: pre-line;
scrollbar-width: none;
-ms-overflow-style: none;
}
#quiz-map-question-text::-webkit-scrollbar {
display: none;
width: 0;
height: 0;
}
/* quiz_carry: ไอคอนถูก/ผิดโผล่ครึ่งบนกรอบแผง — ข้อความยัง clip ใน p */
#quiz-map-q-feedback-icon {
position: absolute;
left: 50%;
top: 0;
transform: translate(-50%, -44%);
width: clamp(28px, min(24%, 5vmin), 76px);
height: auto;
z-index: 4;
pointer-events: none;
object-fit: contain;
filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.55));
}
#quiz-map-q-feedback-icon.is-hidden {
display: none !important;
}
#quiz-map-q-feedback-score-wrap {
flex: 1 1 auto;
min-height: 0;
display: flex;
align-items: center;
justify-content: center;
pointer-events: none;
padding: 0.12em 0 0.2em;
}
#quiz-map-q-feedback-score-wrap.is-hidden {
display: none !important;
}
#quiz-map-q-feedback-score {
width: clamp(44px, min(58%, 12vmin), 160px);
height: auto;
object-fit: contain;
filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.45));
}
#quiz-map-q-feedback-score.quiz-map-q-feedback-score--pop {
animation: quizMapQScorePop 0.58s ease-out both;
}
@keyframes quizMapQScorePop {
0% { transform: scale(0.55); opacity: 0; }
58% { transform: scale(1.06); opacity: 1; }
100% { transform: scale(1); opacity: 1; }
}
#quiz-carry-embed-countdown {
position: fixed;
inset: 0;
z-index: 10080;
display: flex;
align-items: center;
justify-content: center;
pointer-events: none;
background: var(--carry-ecd-overlay, rgba(8, 10, 20, 0.42));
}
#quiz-carry-embed-countdown.quiz-carry-embed-countdown--map-anchor {
align-items: flex-start;
justify-content: flex-start;
background: var(--carry-ecd-overlay, rgba(8, 10, 20, 0.32));
}
#quiz-carry-embed-countdown.is-hidden { display: none !important; }
#quiz-carry-embed-countdown-inner {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.55rem;
max-width: min(94vw, 760px);
padding: 0;
text-align: center;
box-sizing: border-box;
border-radius: 0;
background: transparent;
border: none;
box-shadow: none;
}
#quiz-carry-embed-countdown-inner.quiz-carry-embed-countdown-inner--map-rect {
max-width: none;
padding: 0;
box-sizing: border-box;
border-radius: 0;
background: transparent;
border: none;
box-shadow: none;
}
#quiz-carry-embed-countdown-kicker {
display: none;
margin: 0;
font: 800 0.68rem / 1.2 system-ui, "Kanit", sans-serif;
letter-spacing: 0.12em;
text-transform: uppercase;
color: #7aa2f7;
text-shadow: 0 1px 12px rgba(0, 0, 0, 0.55);
}
#quiz-carry-embed-countdown-kicker.quiz-carry-embed-countdown-kicker--mission {
font-weight: 600;
font-size: clamp(0.72rem, 2vmin, 0.9rem);
letter-spacing: 0.04em;
text-transform: none;
color: #f8fafc;
text-shadow: 0 1px 14px rgba(0, 0, 0, 0.65);
}
#quiz-carry-embed-countdown-q {
display: none;
margin: 0;
font: 600 clamp(14px, 3.2vmin, 20px) / 1.45 system-ui, "Kanit", sans-serif;
color: #f8fafc;
text-shadow: 0 2px 20px rgba(0, 0, 0, 0.75);
max-height: min(32vh, 220px);
overflow: hidden;
overflow-wrap: anywhere;
word-break: break-word;
white-space: pre-line;
scrollbar-width: none;
-ms-overflow-style: none;
}
#quiz-carry-embed-countdown-q::-webkit-scrollbar {
display: none;
width: 0;
height: 0;
}
#quiz-carry-embed-countdown-num {
display: block;
width: min(var(--carry-ecd-screen-vw, 32vw), var(--carry-ecd-screen-max, 200px));
max-width: min(78vw, 420px);
height: auto;
object-fit: contain;
filter: drop-shadow(0 4px 18px rgba(0, 0, 0, 0.55));
}
/* ยึดกล่องบนแมป (ทอง / กลาง / กริด 321): ตัวเลขตามขนาดกล่องช่อง — ไม่ใช้ vw เต็มจอ */
#quiz-carry-embed-countdown.quiz-carry-embed-countdown--map-anchor #quiz-carry-embed-countdown-inner.quiz-carry-embed-countdown-inner--map-rect {
container-type: size;
}
#quiz-carry-embed-countdown.quiz-carry-embed-countdown--map-anchor #quiz-carry-embed-countdown-inner.quiz-carry-embed-countdown-inner--map-rect #quiz-carry-embed-countdown-num {
width: auto;
height: min(72cqh, 88cqmin);
max-height: 78%;
max-width: 92%;
object-fit: contain;
filter: drop-shadow(0 3px 14px rgba(0, 0, 0, 0.55));
}
/* ด้านบน: ไม่ชน HUD ล่างบนแคนวาส + เห็นชัดกว่าแถบล่าง */
#quiz-carry-embed-q-strip {
position: fixed;
left: 50%;
top: max(52px, calc(env(safe-area-inset-top) + 46px));
bottom: auto;
transform: translateX(-50%);
z-index: 10100;
max-width: min(92vw, min(640px, calc(100vw - 200px)));
padding: 0.4rem 0.75rem 0.48rem;
border-radius: 12px;
background: rgba(12, 14, 28, 0.96);
border: 1px solid rgba(122, 162, 247, 0.55);
box-shadow: 0 10px 32px rgba(0, 0, 0, 0.55);
pointer-events: none;
}
#quiz-carry-embed-q-strip.is-hidden { display: none !important; }
.quiz-carry-embed-q-strip-kicker {
display: block;
font: 800 0.58rem / 1.2 system-ui, "Kanit", sans-serif;
letter-spacing: 0.12em;
text-transform: uppercase;
color: #7aa2f7;
margin: 0 0 0.2rem;
text-align: center;
}
#quiz-carry-embed-q-strip-text {
margin: 0;
font: 600 clamp(0.82rem, 2.4vmin, 1.12rem) / 1.45 system-ui, "Kanit", sans-serif;
color: #f8fafc;
text-align: center;
text-shadow: 0 1px 10px rgba(0, 0, 0, 0.65);
max-height: min(28vh, 200px);
overflow: auto;
}
/* ระหว่าง 3–2–1 อยู่เหนือ overlay นับถอยหลัง (10080) */
#quiz-carry-embed-q-strip.quiz-carry-embed-q-strip--countdown {
z-index: 10120;
top: max(52px, calc(env(safe-area-inset-top) + 46px));
}
/* พรีวิว embed quiz_carry: How to play + Ready / START ก่อน 321 */
#quiz-carry-pregame-overlay {
position: fixed;
inset: 0;
z-index: 10078;
display: flex;
align-items: center;
justify-content: center;
padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
box-sizing: border-box;
}
#quiz-carry-pregame-overlay.is-hidden { display: none !important; }
.quiz-carry-pregame-backdrop {
position: absolute;
inset: 0;
background: rgba(4, 6, 14, 0.78);
backdrop-filter: blur(10px);
}
.quiz-carry-pregame-sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
.quiz-carry-pregame-card {
position: relative;
z-index: 1;
display: flex;
flex-direction: column;
align-items: stretch;
max-width: min(94vw, 900px);
width: 100%;
max-height: min(94vh, 900px);
overflow: hidden;
background: rgba(10, 12, 26, 0.55);
border: none;
border-radius: 4px;
box-shadow: none;
pointer-events: auto;
}
.quiz-carry-pregame-art {
flex: 1 1 auto;
min-height: 0;
margin: 0;
padding: 0;
overflow: auto;
background: transparent;
display: flex;
align-items: flex-start;
justify-content: center;
}
.quiz-carry-pregame-howto-img {
display: block;
width: 100%;
height: auto;
max-height: min(62vh, 560px);
object-fit: contain;
object-position: top center;
border: none;
outline: none;
box-shadow: none;
}
.quiz-carry-pregame-footer {
flex: 0 0 auto;
padding: 0.85rem 1rem 1rem;
background: linear-gradient(180deg, rgba(8, 10, 22, 0.2), rgba(8, 10, 22, 0.96));
border-top: none;
display: flex;
flex-direction: column;
align-items: center;
gap: 0.65rem;
}
.quiz-carry-pregame-status {
margin: 0;
text-align: center;
font: 700 clamp(0.8rem, 2.4vw, 0.95rem) / 1.35 system-ui, "Kanit", sans-serif;
color: #fbcfe8;
text-shadow: 0 0 16px rgba(244, 114, 182, 0.5);
letter-spacing: 0.02em;
}
.quiz-carry-pregame-actions {
display: flex;
flex-wrap: wrap;
gap: 0.85rem 1.25rem;
justify-content: center;
align-items: center;
}
.quiz-carry-pregame-primary-btn {
background: transparent;
border: none;
padding: 0;
cursor: pointer;
line-height: 0;
border-radius: 6px;
transition: transform 0.12s ease, filter 0.12s ease, opacity 0.15s ease;
}
.quiz-carry-pregame-primary-btn:hover:not(:disabled):not(.is-read-only) {
transform: scale(1.03);
filter: brightness(1.08);
}
.quiz-carry-pregame-primary-btn.is-pressed:not(.is-start-phase) {
filter: brightness(1.12) drop-shadow(0 0 12px rgba(94, 234, 212, 0.55));
}
.quiz-carry-pregame-primary-btn.is-read-only,
.quiz-carry-pregame-primary-btn:disabled {
opacity: 0.38;
pointer-events: none;
cursor: default;
filter: grayscale(0.2);
}
.quiz-carry-pregame-primary-btn img {
display: block;
width: min(220px, 42vw);
height: auto;
}
#play-quiz-scoreboard {
position: fixed;
top: max(56px, env(safe-area-inset-top));
right: max(10px, env(safe-area-inset-right));
z-index: 10070;
min-width: 150px;
max-width: min(42vw, 220px);
background: rgba(12, 14, 28, 0.92);
border: 1px solid rgba(122, 162, 247, 0.4);
border-radius: 12px;
padding: 0.45rem 0.55rem 0.55rem;
box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45);
pointer-events: none;
}
#play-quiz-scoreboard.is-hidden { display: none !important; }
.play-quiz-scoreboard-title {
font-size: 0.65rem;
font-weight: 800;
letter-spacing: 0.08em;
text-transform: uppercase;
color: #7aa2f7;
margin-bottom: 0.3rem;
border-bottom: 1px solid rgba(122, 162, 247, 0.25);
padding-bottom: 0.2rem;
}
.play-quiz-scoreboard-list {
list-style: none;
margin: 0;
padding: 0;
max-height: 38vh;
overflow: auto;
}
.play-quiz-scoreboard-list li {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(2.25rem, auto);
align-items: baseline;
column-gap: 0.5rem;
font-size: 0.74rem;
color: #c0caf5;
padding: 0.15rem 0;
}
.play-quiz-scoreboard-me { color: #9ece6a !important; font-weight: 700; }
.play-quiz-scoreboard-val {
font-variant-numeric: tabular-nums;
font-weight: 800;
text-align: right;
justify-self: end;
}
.play-quiz-scoreboard-me .play-quiz-scoreboard-val { color: #9ece6a; }
/* แจ้งผลรอบคำถามแบบ toast — ปิดการแสดง (กรอบกลางบนรบกวน HUD) โค้ดยังอัปเดตข้อความได้สำหรับ a11y/ดีบัก */
#play-quiz-feedback {
display: none !important;
position: fixed;
top: max(10px, env(safe-area-inset-top));
left: 50%;
transform: translateX(-50%);
z-index: 10072;
max-width: min(92vw, 440px);
padding: 0.55rem 1rem;
border-radius: 12px;
font-size: clamp(0.88rem, 3vw, 1.05rem);
font-weight: 800;
text-align: center;
box-shadow: 0 12px 40px rgba(0, 0, 0, 0.55);
pointer-events: none;
line-height: 1.35;
}
#play-quiz-feedback.is-hidden { display: none !important; }
.play-quiz-feedback-ok {
background: rgba(22, 40, 28, 0.95);
border: 2px solid rgba(158, 206, 106, 0.85);
color: #c3e6a8;
}
.play-quiz-feedback-bad {
background: rgba(40, 22, 30, 0.95);
border: 2px solid rgba(247, 118, 140, 0.85);
color: #fecdd3;
}
/* quiz_carry — สรุปผลภารกิจ (mock) · พื้นหลังแยกจากเนื้อหา กันลาย PNG [4th]/[5th] ทับ + หัวซ้ำกับ artwork */
#quiz-carry-mission-overlay {
position: fixed;
inset: 0;
z-index: 10090;
display: flex;
align-items: center;
justify-content: center;
padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
box-sizing: border-box;
font-family: 'Orbitron', 'Segoe UI', sans-serif;
}
#quiz-carry-mission-overlay.is-hidden { display: none !important; }
.qc-mission-backdrop {
position: absolute;
inset: 0;
background: rgba(4, 6, 14, 0.78);
backdrop-filter: blur(8px);
}
.qc-mission-panel {
position: relative;
width: min(96vw, 720px);
max-width: 100%;
max-height: min(92vh, 860px);
border-radius: 12px;
overflow: hidden;
filter: drop-shadow(0 0 22px rgba(0, 255, 240, 0.18));
box-sizing: border-box;
display: flex;
flex-direction: column;
}
.qc-mission-panel-bg {
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
height: auto;
min-height: 100%;
background-image: url('/Game/img/quiz-carry/popup-result.png');
background-repeat: no-repeat;
background-position: center top;
background-size: 100% auto;
pointer-events: none;
z-index: 0;
}
.qc-mission-panel-inner {
position: relative;
z-index: 1;
flex: 1 1 auto;
min-height: 0;
display: flex;
flex-direction: column;
align-items: stretch;
overflow-x: hidden;
overflow-y: auto;
/* เว้นตำแหน่งหัวข้อใน artwork — ไม่ซ้ำกับ <h2> sr-only */
padding: clamp(72px, 16vw, 112px) clamp(14px, 3.2vw, 26px) clamp(14px, 2.8vw, 22px);
gap: clamp(8px, 1.6vw, 14px);
}
.qc-mission-rank-row {
display: flex;
flex-wrap: nowrap;
justify-content: center;
align-items: stretch;
gap: clamp(6px, 1.5vw, 14px);
flex: 0 0 auto;
overflow-x: auto;
-webkit-overflow-scrolling: touch;
scrollbar-width: thin;
padding: 2px 0;
}
.qc-mission-rank-cell {
flex: 0 0 auto;
width: clamp(68px, 16vw, 104px);
display: flex;
flex-direction: column;
align-items: stretch;
gap: 4px;
text-align: center;
color: #e2e8f0;
min-width: 0;
}
/* แท็กอันดับ mock: [1st] … [5th] สีทอง — อยู่เหนือกรอบ ไม่ทับอวาตาร์ */
.qc-mission-rank-tag {
flex: 0 0 auto;
font-size: clamp(0.5rem, 1.35vw, 0.65rem);
font-weight: 800;
letter-spacing: 0.04em;
color: #f6e08a;
text-shadow: 0 0 10px rgba(246, 224, 138, 0.45);
line-height: 1.1;
white-space: nowrap;
}
.qc-mission-rank-frame {
position: relative;
width: 100%;
max-width: 88px;
aspect-ratio: 1;
margin: 0 auto;
overflow: hidden;
border-radius: 8px;
border: 1px solid rgba(0, 255, 240, 0.45);
box-shadow:
0 0 0 1px rgba(255, 79, 180, 0.2),
0 0 14px rgba(0, 255, 240, 0.18);
background: rgba(10, 12, 24, 0.95);
flex-shrink: 0;
}
.qc-mission-rank-avatar {
position: absolute;
left: 50%;
top: 40%;
transform: translate(-50%, -50%) scale(1.28);
transform-origin: 50% 30%;
width: 88%;
height: 88%;
object-fit: cover;
object-position: center 18%;
image-rendering: pixelated;
display: block;
pointer-events: none;
}
.qc-mission-rank-nick {
flex: 1 1 auto;
min-height: 2.5em;
display: flex;
align-items: flex-end;
justify-content: center;
font-size: clamp(0.52rem, 1.45vw, 0.68rem);
font-weight: 700;
color: #e2e8f0;
line-height: 1.15;
width: 100%;
max-width: 100%;
overflow: hidden;
word-break: break-word;
hyphens: auto;
text-align: center;
}
.qc-mission-rank-score {
flex: 0 0 auto;
margin-top: auto;
font-variant-numeric: tabular-nums;
font-size: clamp(0.62rem, 1.85vw, 0.78rem);
font-weight: 800;
color: #f6e08a;
text-shadow: 0 0 10px rgba(246, 224, 138, 0.35);
}
.qc-mission-total {
margin: 0;
text-align: center;
font-size: clamp(0.65rem, 1.85vw, 0.8rem);
font-weight: 700;
line-height: 1.4;
flex: 0 0 auto;
color: #f1f5f9;
}
.qc-mission-total-nums {
color: #f6e08a;
font-weight: 800;
text-shadow: 0 0 8px rgba(246, 224, 138, 0.25);
}
.qc-mission-bottom {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(0, 1.25fr);
gap: clamp(10px, 2.2vw, 20px);
align-items: start;
flex: 0 0 auto;
isolation: isolate;
}
@media (max-width: 520px) {
.qc-mission-bottom { grid-template-columns: 1fr; }
}
.qc-mission-section-h {
margin: 0 0 8px;
font-size: clamp(0.68rem, 1.9vw, 0.82rem);
font-weight: 700;
letter-spacing: 0.06em;
color: #f1f5f9;
text-align: center;
}
.qc-mission-grade-block,
.qc-mission-bonus-block {
text-align: center;
min-width: 0;
}
.qc-mission-grade {
font-size: clamp(2.4rem, 11vw, 4rem);
font-weight: 900;
line-height: 1;
letter-spacing: 0.02em;
color: #f8fafc;
text-shadow: 0 0 28px rgba(255, 255, 255, 0.35);
}
.qc-mission-grade--a { color: #9ece6a; text-shadow: 0 0 24px rgba(158, 206, 106, 0.55); }
.qc-mission-grade--b { color: #7aa2f7; text-shadow: 0 0 24px rgba(122, 162, 247, 0.5); }
.qc-mission-grade--c { color: #e0af68; text-shadow: 0 0 22px rgba(224, 175, 104, 0.45); }
.qc-mission-grade--d { color: #bb9af7; text-shadow: 0 0 20px rgba(187, 154, 247, 0.4); }
.qc-mission-grade--e { color: #7dcfff; text-shadow: 0 0 20px rgba(125, 207, 255, 0.35); }
.qc-mission-grade--f { color: #f7768e; text-shadow: 0 0 22px rgba(247, 118, 140, 0.45); }
.qc-mission-bonus-row {
display: flex;
flex-direction: row;
flex-wrap: wrap;
align-items: center;
justify-content: center;
gap: clamp(10px, 2.5vw, 18px);
min-height: 0;
}
.qc-mission-bonus-inline {
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
flex-wrap: nowrap;
flex: 0 0 auto;
}
.qc-mission-reward-plaque {
flex: 0 1 auto;
min-width: 100px;
max-width: 160px;
padding: 8px 10px 10px;
border-radius: 10px;
border: 1px solid rgba(0, 255, 240, 0.55);
box-shadow: 0 0 14px rgba(0, 255, 240, 0.15), inset 0 0 20px rgba(0, 40, 48, 0.35);
background: linear-gradient(165deg, rgba(14, 18, 36, 0.98), rgba(8, 10, 22, 0.99));
text-align: center;
}
.qc-mission-reward-plaque--muted {
border-color: rgba(148, 153, 168, 0.4);
box-shadow: none;
opacity: 0.92;
}
.qc-mission-reward-plaque-title {
font-size: clamp(0.68rem, 1.8vw, 0.8rem);
font-weight: 800;
color: #f1f5f9;
line-height: 1.25;
}
.qc-mission-reward-plaque-sub {
margin-top: 4px;
font-size: clamp(0.58rem, 1.45vw, 0.68rem);
font-weight: 600;
color: #7af8ff;
opacity: 0.9;
}
.qc-mission-check {
width: clamp(22px, 6vw, 32px);
height: auto;
flex-shrink: 0;
}
.qc-mission-success-txt {
font-size: clamp(0.72rem, 2.1vw, 0.88rem);
font-weight: 700;
color: #9ece6a;
}
.qc-mission-card-text {
flex: 0 1 auto;
text-align: center;
font-size: clamp(0.68rem, 1.9vw, 0.82rem);
color: #c0caf5;
line-height: 1.45;
min-width: 0;
max-width: min(200px, 42vw);
}
.qc-mission-reward-sub {
font-size: 0.78em;
opacity: 0.85;
font-weight: 600;
}
.qc-mission-panel-inner #btn-quiz-carry-mission-done {
flex: 0 0 auto;
align-self: center;
}
#btn-quiz-carry-mission-done {
margin: clamp(10px, 2.5vw, 16px) auto 0;
display: block;
width: min(92%, 320px);
height: clamp(44px, 11vw, 56px);
border: none;
padding: 0;
cursor: pointer;
background: url('/Game/img/quiz-carry/btn-done.png') center / contain no-repeat;
background-color: transparent;
}
#btn-quiz-carry-mission-done:focus-visible {
outline: 2px solid rgba(0, 255, 240, 0.7);
outline-offset: 3px;
}
.qc-mission-sr {
position: absolute !important;
width: 1px !important;
height: 1px !important;
padding: 0 !important;
margin: -1px !important;
overflow: hidden !important;
clip: rect(0, 0, 0, 0) !important;
clip-path: inset(50%) !important;
border: 0 !important;
white-space: nowrap !important;
}
/* —— Gauntlet crown heist (mno9kb07) — mock overlays — assets /Game/img/gauntlet-assets —— */
/* สูงกว่า #quiz-carry-pregame-overlay (10078) และ embed strip — กัน mock ถูกบังใน editor preview */
#gauntlet-crown-howto-overlay,
#gauntlet-crown-mission-overlay {
position: fixed;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
box-sizing: border-box;
z-index: 10140;
}
#gauntlet-crown-countdown {
position: fixed;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
box-sizing: border-box;
z-index: 10142;
pointer-events: auto;
background: rgba(6, 8, 18, 0.55);
backdrop-filter: blur(3px);
}
#gauntlet-crown-mission-overlay { z-index: 10150; }
#gauntlet-crown-howto-overlay.is-hidden,
#gauntlet-crown-mission-overlay.is-hidden,
#gauntlet-crown-countdown.is-hidden { display: none !important; }
.gcc-panel {
text-align: center;
padding: 0;
border-radius: 0;
border: none;
box-shadow: none;
background: transparent;
}
.gcc-num {
display: block;
width: min(42vw, 280px);
max-width: min(88vw, 360px);
height: auto;
margin: 0 auto;
object-fit: contain;
filter: drop-shadow(0 4px 22px rgba(0, 0, 0, 0.6)) drop-shadow(0 0 14px rgba(0, 255, 240, 0.35));
}
.gch-backdrop,
.gcm-backdrop {
position: absolute;
inset: 0;
background: rgba(6, 8, 18, 0.78);
backdrop-filter: blur(5px);
}
.gch-shell,
.gcm-shell {
position: relative;
width: min(96vw, 920px);
max-height: min(92vh, 640px);
display: flex;
align-items: center;
justify-content: center;
padding: clamp(4px, 1.2vw, 10px);
border-radius: 14px;
/* border: 2px solid rgba(0, 255, 240, 0.75); */
/* box-shadow: 0 0 0 1px rgba(255, 0, 200, 0.55), 0 0 28px rgba(0, 255, 240, 0.22), 0 0 40px rgba(255, 0, 200, 0.12); */
/* background: rgba(6, 8, 18, 0.35); */
pointer-events: auto;
}
.gch-bg,
.gcm-bg {
width: 100%;
height: auto;
max-height: min(88vh, 600px);
object-fit: contain;
display: block;
pointer-events: none;
filter: drop-shadow(0 0 18px rgba(0, 255, 240, 0.25)) drop-shadow(0 0 22px rgba(255, 0, 200, 0.2));
}
.gch-inner,
.gcm-inner {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
width: min(88%, 780px);
max-height: 82%;
overflow: auto;
padding: clamp(10px, 2.2vw, 18px);
box-sizing: border-box;
color: #e2e8f0;
font-family: ui-sans-serif, system-ui, 'Segoe UI', 'Kanit', sans-serif;
/* background: rgba(8, 10, 22, 0.72); */
border-radius: 12px;
/* border: 1px solid rgba(0, 255, 240, 0.35); */
/* box-shadow: inset 0 0 24px rgba(0, 0, 0, 0.35); */
}
.gch-inner.gch-inner--art {
left: 0;
top: 0;
right: 0;
bottom: 0;
transform: none;
width: 100%;
max-height: none;
overflow: visible;
padding: 0;
background: transparent;
border: none;
box-shadow: none;
display: block;
pointer-events: none;
}
/* Ready สถานะ + ปุ่ม — ยึดชายล่างการ์ด ไม่ทับภาพ/ข้อความกลาง */
.gch-inner.gch-inner--art .gch-art-footer {
position: absolute;
left: 50%;
bottom: clamp(6px, 1.6vmin, 14px);
transform: translateX(-50%);
width: min(92%, 280px);
display: flex;
flex-direction: column;
align-items: center;
gap: 4px;
pointer-events: none;
}
.gch-inner.gch-inner--art .gch-status {
pointer-events: none;
margin: 0;
max-width: 100%;
text-align: center;
font-weight: 800;
color: #f8fafc;
font-size: clamp(0.75rem, 2vw, 0.9rem);
text-shadow: 0 1px 4px rgba(0, 0, 0, 0.85), 0 0 14px rgba(0, 0, 0, 0.55);
}
.gch-inner.gch-inner--art .btn-gch-ready {
pointer-events: auto;
flex-shrink: 0;
margin: 0;
}
#stack-tower-howto-rules.stack-tower-howto-rules {
pointer-events: none;
max-height: none;
overflow: visible;
width: min(98%, 440px);
margin: 0 auto 6px;
padding: 8px 10px;
text-align: left;
font-size: clamp(0.62rem, 1.45vw, 0.74rem);
line-height: 1.42;
color: #d5e6ff;
text-shadow: 0 1px 4px rgba(0, 0, 0, 0.92);
background: rgba(6, 10, 24, 0.88);
border: 1px solid rgba(0, 234, 255, 0.38);
border-radius: 8px;
box-sizing: border-box;
display: none;
visibility: hidden;
}
.stack-tower-howto-rules h4 {
margin: 8px 0 4px;
font-size: 0.92em;
color: #7af8ff;
font-weight: 800;
letter-spacing: 0.04em;
}
.stack-tower-howto-rules h4:first-child { margin-top: 0; }
.stack-tower-howto-rules ul { margin: 0; padding-left: 1.15em; }
.stack-tower-howto-rules li { margin-bottom: 3px; }
.stack-tower-howto-rules .warn { color: #f6e08a; font-weight: 700; }
.stack-tower-howto-rules.is-hidden { display: none !important; }
.gch-title {
margin: 0 0 4px;
font-size: clamp(1rem, 3.2vw, 1.35rem);
font-weight: 900;
letter-spacing: 0.06em;
color: #fff;
text-align: center;
text-shadow: 0 0 12px rgba(0, 255, 240, 0.45);
}
.gch-sub {
margin: 0 0 10px;
text-align: center;
font-size: clamp(0.78rem, 2.1vw, 0.95rem);
color: #7af8ff;
font-weight: 700;
}
.gch-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: clamp(6px, 1.5vw, 12px);
margin-bottom: 10px;
}
@media (max-width: 640px) {
.gch-grid { grid-template-columns: 1fr; }
}
.gch-col {
background: rgba(10, 14, 28, 0.72);
border: 1px solid rgba(0, 255, 240, 0.35);
border-radius: 10px;
padding: 8px 10px;
font-size: clamp(0.65rem, 1.65vw, 0.78rem);
line-height: 1.45;
}
.gch-col h3 {
margin: 0 0 6px;
font-size: clamp(0.72rem, 1.9vw, 0.85rem);
color: #f6e08a;
}
.gch-col p { margin: 0 0 6px; color: #c0caf5; }
.gch-col .warn { color: #f6e08a; font-weight: 600; }
.gch-foot {
text-align: center;
font-size: clamp(0.68rem, 1.8vw, 0.8rem);
color: #f7768e;
margin: 0 0 10px;
}
.btn-gch-ready {
display: block;
margin: 0 auto;
width: min(240px, 70%);
height: clamp(44px, 12vw, 56px);
border: none;
cursor: pointer;
background: url('/Game/img/gauntlet-assets/btn-ready.png') center / contain no-repeat;
background-color: transparent;
}
.btn-gch-ready.is-start-phase {
background-image: url('/Game/img/quiz-carry/btn-start.png');
}
.btn-gch-ready:disabled {
opacity: 0.55;
cursor: not-allowed;
}
.btn-gch-ready:focus-visible { outline: 2px solid #7af8ff; outline-offset: 3px; }
.gch-status {
margin: 0;
text-align: center;
font-size: clamp(0.72rem, 1.9vw, 0.88rem);
font-weight: 700;
color: #c0caf5;
}
.gch-status.is-hidden { display: none !important; }
.gcm-header-tab {
text-align: center;
font-weight: 800;
font-size: clamp(0.85rem, 2.4vw, 1rem);
color: #7af8ff;
margin-bottom: 8px;
letter-spacing: 0.04em;
}
.gcm-rank-row {
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items: stretch;
gap: clamp(6px, 1.5vw, 10px);
margin-bottom: 8px;
}
.gcm-cell {
flex: 0 0 auto;
width: clamp(72px, 18vw, 100px);
text-align: center;
display: flex;
flex-direction: column;
align-items: stretch;
}
.gcm-rank-tag {
flex: 0 0 auto;
min-height: 1.15em;
display: flex;
align-items: center;
justify-content: center;
font-size: clamp(0.55rem, 1.4vw, 0.65rem);
font-weight: 800;
color: #f6e08a;
margin-bottom: 4px;
}
.gcm-frame {
position: relative;
flex: 0 0 auto;
width: 100%;
aspect-ratio: 1;
border-radius: 8px;
border: 2px solid rgba(0, 255, 240, 0.5);
box-shadow: 0 0 12px rgba(0, 255, 240, 0.2);
overflow: hidden;
background: rgba(8, 10, 20, 0.9);
}
.gcm-frame img.gcm-av {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center 22%;
transform: scale(1.32);
transform-origin: 50% 26%;
image-rendering: pixelated;
}
.gcm-frame img.gcm-stamp {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: contain;
pointer-events: none;
}
.gcm-nick {
flex: 1 1 auto;
min-height: 2.55em;
display: flex;
align-items: flex-end;
justify-content: center;
font-size: clamp(0.52rem, 1.35vw, 0.65rem);
font-weight: 700;
color: #e2e8f0;
margin-top: 4px;
word-break: break-word;
line-height: 1.15;
}
.gcm-sc {
flex: 0 0 auto;
width: 100%;
text-align: center;
font-variant-numeric: tabular-nums;
font-size: clamp(0.58rem, 1.5vw, 0.72rem);
font-weight: 800;
color: #f6e08a;
margin-top: auto;
padding-top: 3px;
}
.gcm-total {
text-align: center;
font-size: clamp(0.65rem, 1.8vw, 0.8rem);
font-weight: 700;
color: #f1f5f9;
margin: 0 0 8px;
}
.gcm-total-nums { color: #f6e08a; }
.gcm-bottom {
display: grid;
grid-template-columns: 1fr 1.2fr;
gap: 10px;
align-items: start;
margin-bottom: 8px;
}
@media (max-width: 520px) { .gcm-bottom { grid-template-columns: 1fr; } }
.gcm-h {
font-size: clamp(0.62rem, 1.7vw, 0.75rem);
font-weight: 700;
color: #cbd5e1;
text-align: center;
margin-bottom: 4px;
}
.gcm-grade {
text-align: center;
font-size: clamp(2rem, 9vw, 3.2rem);
font-weight: 900;
line-height: 1;
color: #f8fafc;
text-shadow: 0 0 20px rgba(255, 255, 255, 0.35);
}
.gcm-grade--a { color: #9ece6a; text-shadow: 0 0 20px rgba(158, 206, 106, 0.5); }
.gcm-grade--b { color: #7aa2f7; }
.gcm-grade--c { color: #e0af68; }
.gcm-grade--d { color: #bb9af7; text-shadow: 0 0 16px rgba(187, 154, 247, 0.4); }
.gcm-grade--e { color: #7dcfff; text-shadow: 0 0 16px rgba(125, 207, 255, 0.35); }
.gcm-grade--f { color: #f7768e; text-shadow: 0 0 18px rgba(247, 118, 140, 0.45); }
.gcm-bonus {
display: flex;
flex-direction: column;
align-items: center;
gap: 6px;
font-size: clamp(0.65rem, 1.7vw, 0.78rem);
color: #c0caf5;
}
.gcm-plaque {
border: 1px solid rgba(0, 255, 240, 0.55);
border-radius: 10px;
padding: 8px 10px;
background: linear-gradient(165deg, rgba(14, 18, 36, 0.96), rgba(8, 10, 22, 0.98));
text-align: center;
max-width: 200px;
}
.gcm-plaque strong { color: #f1f5f9; display: block; }
.gcm-plaque span { color: #7af8ff; font-size: 0.92em; }
.btn-gcm-done {
display: block;
margin: 4px auto 0;
width: min(92%, 300px);
height: clamp(44px, 11vw, 54px);
border: none;
cursor: pointer;
background: url('/Game/img/gauntlet-assets/btn-done.png') center / contain no-repeat;
background-color: transparent;
}
#gauntlet-ended-overlay {
position: fixed;
inset: 0;
z-index: 10080;
display: flex;
align-items: center;
justify-content: center;
padding: max(12px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
box-sizing: border-box;
}
#gauntlet-ended-overlay.is-hidden { display: none !important; }
.gauntlet-ended-backdrop {
position: absolute;
inset: 0;
background: rgba(8, 10, 18, 0.82);
backdrop-filter: blur(6px);
}
.gauntlet-ended-card {
position: relative;
max-width: min(92vw, 400px);
width: 100%;
background: rgba(18, 20, 32, 0.96);
border: 1px solid rgba(247, 118, 140, 0.45);
border-radius: 16px;
padding: 1.25rem 1.35rem 1.1rem;
box-shadow: 0 16px 48px rgba(0, 0, 0, 0.55);
}
.gauntlet-ended-card h2 {
margin: 0 0 0.5rem;
font-size: 1.15rem;
color: #f7768e;
font-weight: 800;
}
#gauntlet-ended-message {
margin: 0 0 0.75rem;
font-size: 0.95rem;
color: #c0caf5;
line-height: 1.45;
}
#gauntlet-ended-rankings {
margin: 0 0 1rem;
padding-left: 1.2rem;
color: #a9b1d6;
font-size: 0.88rem;
line-height: 1.5;
}
#gauntlet-ended-rankings .gauntlet-ended-me {
color: #9ece6a;
font-weight: 700;
}
#btn-gauntlet-ended-lobby {
width: 100%;
padding: 0.55rem 1rem;
border-radius: 10px;
border: none;
font-weight: 700;
cursor: pointer;
background: linear-gradient(180deg, #7aa2f7, #5a7fd4);
color: #1a1b26;
}
/* —— Cyber / server-room play HUD (Jump survive · Gauntlet) —— */
.play-cyber-hud {
position: fixed;
inset: 0;
z-index: 55;
pointer-events: none;
font-family: 'Share Tech Mono', ui-monospace, monospace;
}
.play-cyber-hud.is-hidden { display: none !important; }
/* mng8a80o — แผง SCORE: มุมคม, หัว SCORE ใหญ่, แถวแนวนอน = [อวาตาร์เล็ก + ชื่อไทย] ซ้าย | คะแนนใหญ่ขวา */
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-scoreboard {
width: min(252px, 64vw);
max-width: min(252px, 64vw);
box-sizing: border-box;
padding: 0.48rem 0.62rem 0.52rem;
background: linear-gradient(
165deg,
rgba(10, 26, 48, 0.92) 0%,
rgba(5, 14, 32, 0.94) 42%,
rgba(8, 20, 40, 0.9) 100%
);
border: 1px solid rgba(0, 255, 240, 0.38);
border-radius: 2px;
box-shadow:
0 0 0 1px rgba(0, 0, 0, 0.45),
0 0 24px rgba(0, 200, 255, 0.16),
inset 0 1px 0 rgba(255, 255, 255, 0.08);
overflow: visible;
min-height: unset;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-list {
box-sizing: border-box;
width: 100%;
max-width: 100%;
max-height: 48vh;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-panel-title {
display: block;
font-family: 'Orbitron', sans-serif;
font-weight: 800;
font-size: clamp(0.82rem, 2.4vmin, 0.95rem);
letter-spacing: 0.22em;
text-transform: uppercase;
color: #8afeff;
text-shadow:
0 0 16px rgba(0, 240, 255, 0.62),
0 0 32px rgba(0, 160, 255, 0.32);
margin: 0 0 0.34rem;
padding: 0 0 0.38rem;
border-bottom: 1px solid rgba(0, 255, 240, 0.48);
text-align: left;
line-height: 1.15;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-row {
border-bottom: none;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-row--qm-mock {
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
gap: 0.42rem;
width: 100%;
min-width: 0;
box-sizing: border-box;
padding: 0.3rem 0;
border-bottom: 1px solid rgba(0, 255, 240, 0.32);
grid-template-columns: unset;
grid-template: none;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-row--qm-mock:last-child {
border-bottom: none;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-qm-left {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
align-items: center;
justify-content: flex-start;
gap: 0.4rem;
flex: 1 1 auto;
min-width: 0;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-qm-name {
font-family: 'Share Tech Mono', ui-monospace, monospace;
font-size: 0.58rem;
font-weight: 600;
letter-spacing: 0.04em;
text-transform: none;
color: rgba(248, 252, 255, 0.95);
text-shadow: 0 1px 5px rgba(0, 0, 0, 0.92);
flex: 1 1 auto;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-row--qm-mock.is-me .play-cyber-qm-name {
color: #e8fcff;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-qm-score {
flex: 0 0 auto;
align-self: center;
font-family: 'Orbitron', sans-serif;
font-size: clamp(1.02rem, 3.5vmin, 1.38rem);
font-weight: 800;
color: #7af8ff;
text-align: right;
line-height: 1;
text-shadow:
0 0 14px rgba(0, 255, 240, 0.48),
0 0 26px rgba(0, 160, 255, 0.22);
min-width: 2.1rem;
justify-self: unset;
white-space: nowrap;
}
/* อวาตาร์แถบ SCORE: คอขึ้นไป (crop) — wrap ตัดขอบหลัง scale */
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-qm-av-wrap {
display: block;
width: 34px;
height: 34px;
flex-shrink: 0;
overflow: hidden;
border-radius: 2px;
border: 1px solid rgba(0, 255, 240, 0.4);
background: rgba(0, 16, 28, 0.95);
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-score-row--qm-mock .play-cyber-score-av--qm {
display: block;
width: 34px;
height: 34px;
border: none;
object-fit: cover;
object-position: center 4%;
transform: scale(1.38);
transform-origin: center 8%;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-self-frame {
overflow: hidden;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-self-frame img {
object-fit: cover;
object-position: center 6%;
transform: scale(1.36);
transform-origin: center 10%;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-sub {
margin-top: 0.32rem;
opacity: 0.52;
font-size: 0.52rem;
max-width: min(88vw, 420px);
}
/* โหมดคำถาม: ไม่แสดงกล่องคำแนะ (ให้พื้นที่ซ้ายกับแถบ SCORE) */
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-hint {
display: none !important;
}
/* โหมดคำถาม: ซ่อนแถบ glitch แดง (RAM ERROR…) และบรรทัด SIM พรีวิวด้านล่าง */
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-corruption {
display: none !important;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-preview-line {
display: none !important;
}
/* Last Light (mno9kb07): แถบคะแนนแนวนอน — score.png แล้วตามด้วยสูงสุด 6 ช่อง (อวาตาร์ | ชื่อบน / คะแนนล่าง) */
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-hint {
display: none !important;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-corruption,
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-preview-line {
display: none !important;
}
/* Last Light: แถวบน = SCORE ยืดซ้าย | OPERATOR ขวา — แถวล่าง = TIME ใต้ SCORE */
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
grid-template-rows: auto auto;
grid-template-areas:
'crownScore crownOp'
'crownTime crownOp';
align-items: start;
column-gap: clamp(10px, 2vw, 20px);
row-gap: 0.35rem;
box-sizing: border-box;
padding-top: max(50px, calc(env(safe-area-inset-top) + 38px));
padding-left: max(6px, env(safe-area-inset-left));
padding-right: max(8px, env(safe-area-inset-right));
padding-bottom: max(6px, env(safe-area-inset-bottom));
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-center-stack {
grid-area: crownTime;
position: static;
left: auto;
top: auto;
transform: none;
width: 100%;
min-width: 0;
max-width: none;
padding: 0;
align-items: flex-start;
justify-self: stretch;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-time-block {
min-width: 0;
text-align: left;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-time-head {
align-items: flex-start;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-time-sub {
max-width: min(100%, 320px);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
text-align: left;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self {
grid-area: crownOp;
grid-row: 1 / -1;
justify-self: end;
align-self: start;
position: static;
top: auto;
right: auto;
margin-left: 0;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.32rem;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-scoreboard.play-cyber-scoreboard--crown-strip {
grid-area: crownScore;
width: 100%;
min-width: 0;
max-width: none;
position: static;
left: auto;
right: auto;
top: auto;
padding: 0.28rem 0.2rem 0.32rem 0;
display: flex;
flex-direction: row;
flex-wrap: nowrap;
align-items: center;
gap: 0.55rem;
box-sizing: border-box;
background: transparent;
border: none;
box-shadow: none;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-panel-title {
flex: 0 0 auto;
align-self: center;
margin: 0 0.15rem 0 0;
padding: 0;
border-bottom: none;
font-family: 'Orbitron', sans-serif;
font-weight: 800;
font-size: clamp(0.68rem, 1.9vmin, 0.86rem);
letter-spacing: 0.14em;
text-transform: uppercase;
color: #8afeff;
text-shadow:
0 0 14px rgba(0, 240, 255, 0.55),
0 0 28px rgba(0, 160, 255, 0.28),
0 1px 10px rgba(0, 0, 0, 0.75);
white-space: nowrap;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-score-head {
flex: 0 0 auto;
align-self: center;
margin: 0;
line-height: 0;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-score-head img {
display: block;
height: clamp(16px, 3.2vmin, 26px);
width: auto;
max-width: min(42vw, 200px);
object-fit: contain;
object-position: left center;
image-rendering: auto;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-score-head.is-hidden {
display: none !important;
margin: 0;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-list.play-cyber-score-list--crown-strip {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
align-items: stretch;
gap: clamp(6px, 1vw, 12px);
flex: 1 1 auto;
min-width: 0;
max-height: none;
overflow-x: auto;
overflow-y: hidden;
width: 100%;
scrollbar-width: thin;
scrollbar-color: rgba(0, 210, 255, 0.5) rgba(0, 0, 0, 0.28);
padding: 0 0.2rem 0.2rem 0;
box-sizing: border-box;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-list.play-cyber-score-list--crown-strip::-webkit-scrollbar {
height: 5px;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-list.play-cyber-score-list--crown-strip::-webkit-scrollbar-thumb {
background: linear-gradient(90deg, rgba(0, 200, 255, 0.55), rgba(0, 255, 220, 0.4));
border-radius: 4px;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-list.play-cyber-score-list--crown-strip::-webkit-scrollbar-track {
background: rgba(0, 0, 0, 0.22);
border-radius: 4px;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-row--crown-strip {
display: flex;
flex: 0 0 auto;
flex-shrink: 0;
min-width: 7.1rem;
padding: 0.12rem 0.12rem 0.12rem 0;
box-sizing: border-box;
margin: 0;
border-bottom: none;
grid-template-columns: unset;
grid-template: none;
border-right: none;
background: transparent;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-strip-cell {
display: flex;
flex-direction: row;
align-items: center;
gap: 0.36rem;
width: auto;
min-width: 0;
max-width: none;
flex-shrink: 0;
box-sizing: border-box;
background: transparent;
}
/* คอขึ้นไป — โฟกัสใบหน้า+ไหล่ (ไม่ซูมจนเหลือแต่หน้าผาก) */
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-strip-av-wrap {
flex: 0 0 auto;
width: 36px;
height: 36px;
overflow: hidden;
position: relative;
display: flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
border-radius: 8px;
border: 1px solid rgba(0, 255, 240, 0.42);
background: rgba(0, 6, 12, 0.92);
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-av--crown-strip {
display: block;
position: relative;
left: auto;
top: auto;
width: 40px;
height: 40px;
max-width: none;
margin: 0;
border: none;
flex-shrink: 0;
object-fit: cover;
object-position: 50% 28%;
transform: scale(1.12);
transform-origin: 50% 42%;
image-rendering: pixelated;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-strip-meta {
display: flex;
flex-direction: column;
align-items: flex-start;
justify-content: center;
gap: 0.12rem;
flex: 0 1 auto;
min-width: 3.75rem;
max-width: 9.5rem;
background: transparent;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-strip-name {
font-family: 'Share Tech Mono', ui-monospace, monospace;
font-size: 0.46rem;
font-weight: 600;
letter-spacing: 0.06em;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.9);
text-shadow: 0 1px 5px rgba(0, 0, 0, 0.75);
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-score-row--crown-strip.is-me .play-cyber-crown-strip-name {
color: #f2ffff;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-crown-strip-val {
font-family: 'Orbitron', sans-serif;
font-size: clamp(0.72rem, 2.2vmin, 0.9rem);
font-weight: 800;
color: #7af8ff;
text-shadow:
0 0 14px rgba(122, 248, 255, 0.55),
0 0 26px rgba(0, 200, 255, 0.28),
0 1px 8px rgba(0, 0, 0, 0.88);
line-height: 1;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-time-val {
color: #7fffab;
text-shadow:
0 0 20px rgba(100, 255, 180, 0.55),
0 0 40px rgba(0, 255, 140, 0.25),
0 2px 12px rgba(0, 0, 0, 0.88);
}
/* Last Light: OPERATOR + ไมค์ / สถานะ */
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-frame {
padding: 3px;
border-radius: 12px;
background: rgba(0, 12, 22, 0.55);
border: 1px solid rgba(0, 255, 240, 0.55);
box-shadow:
0 0 0 1px rgba(0, 0, 0, 0.45),
0 0 22px rgba(0, 230, 255, 0.42),
inset 0 0 18px rgba(0, 255, 240, 0.07);
overflow: hidden;
width: 58px;
height: 58px;
box-sizing: border-box;
display: flex;
align-items: flex-start;
justify-content: center;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-frame img {
width: 64px;
height: 64px;
max-width: none;
margin: 0;
border-radius: 9px;
object-fit: cover;
object-position: 50% 0%;
transform: scale(1.38);
transform-origin: 50% 14%;
background: rgba(0, 6, 14, 0.75);
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-status {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.1rem;
max-width: min(200px, 42vw);
width: max-content;
font-size: 0;
letter-spacing: 0.08em;
line-height: 1.22;
text-align: left;
}
/* โทนเดียวกับแผง user embed คำถาม (editor mng8a80o): QUIZ LINK · + ประลองความรู้ */
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-tagline {
font-family: 'Orbitron', sans-serif;
font-size: clamp(0.44rem, 1.35vmin, 0.56rem);
font-weight: 700;
letter-spacing: 0.14em;
text-transform: uppercase;
color: #7af8ff;
text-shadow:
0 0 12px rgba(122, 248, 255, 0.55),
0 0 22px rgba(0, 200, 255, 0.28),
0 1px 8px rgba(0, 0, 0, 0.85);
white-space: nowrap;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-subtag {
font-family: 'Sarabun', 'Noto Sans Thai', system-ui, sans-serif;
font-size: clamp(0.48rem, 1.5vmin, 0.62rem);
font-weight: 600;
letter-spacing: 0.04em;
color: rgba(122, 248, 255, 0.92);
text-shadow:
0 0 10px rgba(0, 240, 255, 0.35),
0 1px 6px rgba(0, 0, 0, 0.82);
white-space: nowrap;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-self-nick-line {
font-family: 'Sarabun', 'Noto Sans Thai', 'Share Tech Mono', ui-monospace, monospace;
font-size: clamp(0.42rem, 1.35vmin, 0.52rem);
font-weight: 600;
letter-spacing: 0.06em;
text-transform: none;
color: rgba(232, 250, 255, 0.9);
text-shadow: 0 1px 6px rgba(0, 0, 0, 0.82);
margin-top: 0.06rem;
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.play-cyber-op-widgets {
display: none;
flex-direction: column;
align-items: center;
justify-content: flex-start;
gap: 0.25rem;
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-op-widgets {
display: flex;
align-self: center;
margin-top: 0.06rem;
}
.play-cyber-link-status {
display: flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
border-radius: 8px;
box-sizing: border-box;
border: 1px solid rgba(0, 255, 240, 0.48);
background: linear-gradient(180deg, rgba(0, 48, 58, 0.75), rgba(0, 12, 22, 0.92));
box-shadow:
0 0 14px rgba(0, 220, 255, 0.28),
inset 0 1px 0 rgba(255, 255, 255, 0.06);
font-family: 'Orbitron', sans-serif;
font-size: 0.58rem;
font-weight: 800;
letter-spacing: 0.04em;
color: rgba(255, 255, 255, 0.92);
line-height: 1;
}
.play-cyber-voice-chip {
display: none;
width: 30px;
height: 30px;
border-radius: 8px;
box-sizing: border-box;
align-items: center;
justify-content: center;
border: 1px solid rgba(0, 255, 240, 0.48);
background: linear-gradient(180deg, rgba(0, 48, 58, 0.75), rgba(0, 12, 22, 0.92));
box-shadow:
0 0 14px rgba(0, 220, 255, 0.32),
inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
#play-cyber-hud.play-cyber-hud--gauntlet-crown-strip .play-cyber-voice-chip {
display: flex;
}
.play-cyber-voice-chip::after {
content: '';
display: block;
width: 9px;
height: 12px;
border: 2px solid rgba(255, 255, 255, 0.88);
border-radius: 4px 4px 5px 5px;
box-shadow: 0 4px 0 -2px rgba(255, 255, 255, 0.35);
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-head {
display: flex;
flex-direction: row;
flex-wrap: wrap;
align-items: baseline;
justify-content: center;
column-gap: 0.08rem;
row-gap: 0.12rem;
}
/* time.png = กราฟิกคำว่า TIME : ด้านซ้ายของตัวเลข */
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-head--qm-plaque .play-cyber-time-plaque-img {
display: block;
height: clamp(1rem, 3.4vmin, 1.55rem);
width: auto;
max-width: min(48vw, 200px);
object-fit: contain;
object-position: left center;
flex-shrink: 0;
margin-right: 0.12rem;
align-self: center;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-head--qm-plaque {
align-items: center;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-head--qm-plaque .play-cyber-time-label,
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-head--qm-plaque .play-cyber-time-colon {
display: none !important;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-colon {
display: inline;
font-family: 'Orbitron', sans-serif;
font-size: clamp(0.88rem, 2.6vw, 1.15rem);
font-weight: 700;
color: rgba(232, 248, 255, 0.96);
text-shadow: 0 0 14px rgba(0, 255, 220, 0.42), 0 1px 10px rgba(0, 0, 0, 0.88);
margin: 0 0.1rem 0 0.06rem;
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-label {
margin-bottom: 0;
font-size: clamp(0.88rem, 2.6vw, 1.12rem);
letter-spacing: 0.12em;
color: rgba(232, 248, 255, 0.96);
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-val {
filter: drop-shadow(0 2px 10px rgba(0, 0, 0, 0.85));
color: #7af8ff;
text-shadow:
0 0 18px rgba(122, 248, 255, 0.55),
0 0 36px rgba(0, 200, 255, 0.28),
0 2px 12px rgba(0, 0, 0, 0.9);
}
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-label,
#play-cyber-hud.play-cyber-hud--question-mission .play-cyber-time-sub {
text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9), 0 0 12px rgba(0, 0, 0, 0.65);
}
.game-wrap.play-cyber-active .game-header {
background: linear-gradient(180deg, rgba(6, 10, 22, 0.94), rgba(12, 18, 36, 0.88));
border-bottom: 1px solid rgba(0, 255, 240, 0.22);
box-shadow: 0 0 24px rgba(0, 240, 255, 0.08);
}
.game-wrap.play-cyber-active .game-header span {
color: #7af8ff;
text-shadow: 0 0 12px rgba(0, 255, 240, 0.35);
font-family: 'Orbitron', sans-serif;
font-weight: 600;
font-size: 0.82rem;
letter-spacing: 0.04em;
}
.game-wrap.play-cyber-active #btn-leave {
background: rgba(0, 40, 48, 0.85);
color: #7af8ff;
border: 1px solid rgba(0, 255, 240, 0.35);
font-family: 'Share Tech Mono', monospace;
font-size: 0.72rem;
letter-spacing: 0.06em;
}
.play-cyber-scoreboard {
position: absolute;
top: max(52px, calc(env(safe-area-inset-top) + 42px));
left: max(10px, env(safe-area-inset-left));
width: min(240px, 42vw);
padding: 0.5rem 0.55rem 0.6rem;
background: rgba(4, 8, 18, 0.08);
border: 1px solid rgba(0, 255, 240, 0.28);
border-radius: 4px;
box-shadow:
0 0 0 1px rgba(0, 0, 0, 0.5),
0 0 28px rgba(0, 200, 255, 0.12),
inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
.play-cyber-panel-title {
font-family: 'Orbitron', sans-serif;
font-weight: 800;
font-size: 0.72rem;
letter-spacing: 0.2em;
color: #5cf0ff;
text-shadow: 0 0 14px rgba(92, 240, 255, 0.45);
margin-bottom: 0.35rem;
padding-bottom: 0.25rem;
border-bottom: 1px solid rgba(0, 255, 240, 0.2);
}
.play-cyber-panel-title.is-hidden {
display: none !important;
}
/* กล่องหัว score.png (Last Light) — บนแมปอื่นมี is-hidden แต่เดิมไม่มี display:none จึงเห็นกรอบว่างเหนือ SCORE */
#play-cyber-crown-score-head.is-hidden {
display: none !important;
margin: 0 !important;
padding: 0 !important;
height: 0 !important;
min-height: 0 !important;
overflow: hidden !important;
border: none !important;
}
.play-cyber-score-list {
list-style: none;
margin: 0;
padding: 0;
max-height: 42vh;
overflow: auto;
}
.play-cyber-score-row {
display: grid;
grid-template-columns: 36px minmax(0, 1fr) minmax(2.75rem, auto);
align-items: center;
gap: 0.35rem;
padding: 0.28rem 0;
border-bottom: 1px solid rgba(0, 255, 240, 0.08);
}
.play-cyber-score-row:last-child { border-bottom: none; }
.play-cyber-score-row.is-me .play-cyber-score-name { color: #9efcff; }
.play-cyber-score-row.is-out { opacity: 0.45; }
.play-cyber-score-av {
width: 34px;
height: 34px;
object-fit: contain;
image-rendering: pixelated;
border: 1px solid rgba(0, 255, 240, 0.35);
border-radius: 2px;
background: rgba(0, 20, 30, 0.9);
}
.play-cyber-score-mid {
display: flex;
flex-direction: column;
gap: 0.1rem;
min-width: 0;
}
.play-cyber-score-name {
font-size: 0.68rem;
font-weight: 700;
color: #c8f4ff;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.play-cyber-score-state {
font-size: 0.58rem;
letter-spacing: 0.08em;
color: rgba(0, 255, 200, 0.55);
}
.play-cyber-score-row.is-out .play-cyber-score-state { color: #f7768e; }
.play-cyber-score-val {
font-family: 'Orbitron', sans-serif;
font-weight: 800;
font-size: 0.78rem;
color: #7af8ff;
text-shadow: 0 0 10px rgba(0, 255, 240, 0.35);
font-variant-numeric: tabular-nums;
text-align: right;
justify-self: end;
min-width: 2.5rem;
}
.play-cyber-lead-crown {
display: inline-block;
margin-right: 0.15rem;
filter: drop-shadow(0 0 6px rgba(255, 220, 120, 0.7));
}
/* กลางบน: TIME + (เฉพาะแมป quiz mng8a80o) แถบคำถาม */
.play-cyber-center-stack {
position: absolute;
top: max(52px, calc(env(safe-area-inset-top) + 38px));
left: 50%;
transform: translateX(-50%);
display: flex;
flex-direction: column;
align-items: center;
gap: clamp(4px, 1vmin, 12px);
z-index: 4;
max-width: min(94vw, 760px);
pointer-events: none;
}
.play-cyber-time-block {
position: relative;
left: auto;
top: auto;
transform: none;
text-align: center;
min-width: 120px;
}
.play-cyber-time-head {
display: flex;
flex-direction: column;
align-items: center;
}
.play-cyber-time-plaque-img {
display: none;
}
.play-cyber-time-colon {
display: none;
line-height: 1;
}
.play-cyber-quiz-mission-q-band {
position: relative;
width: min(92vw, 680px);
max-width: 100%;
padding: clamp(10px, 2vmin, 18px) clamp(12px, 2.5vmin, 22px);
box-sizing: border-box;
text-align: center;
}
/* is-hidden ใช้ทั่วโปรเจกต์แต่หลายจุดไม่มีกฎ display:none — แถบนี้ซ่อนแล้วต้องไม่กินที่และไม่เห็นกรอบว่าง */
#play-cyber-quiz-mission-q-band.is-hidden {
display: none !important;
}
.play-cyber-quiz-mission-q-plaque {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: fill;
object-position: center;
z-index: 0;
pointer-events: none;
opacity: 0.95;
}
.play-cyber-quiz-mission-q-text {
position: relative;
z-index: 1;
margin: 0;
font-family: 'Sarabun', 'Noto Sans Thai', system-ui, sans-serif;
font-size: clamp(0.78rem, 2.1vw, 1.05rem);
font-weight: 700;
line-height: 1.45;
color: #ffe066;
text-shadow:
0 0 12px rgba(255, 200, 80, 0.55),
0 2px 14px rgba(0, 0, 0, 0.85);
white-space: pre-line;
overflow-wrap: anywhere;
word-break: break-word;
}
.play-cyber-time-label {
font-family: 'Orbitron', sans-serif;
font-size: 0.62rem;
font-weight: 700;
letter-spacing: 0.28em;
color: rgba(0, 255, 200, 0.55);
margin-bottom: 0.15rem;
}
.play-cyber-time-val {
font-family: 'Orbitron', sans-serif;
font-weight: 800;
font-size: clamp(1.5rem, 4.5vw, 2rem);
line-height: 1;
color: #7fffab;
text-shadow:
0 0 20px rgba(100, 255, 180, 0.55),
0 0 40px rgba(0, 255, 140, 0.25);
}
.play-cyber-time-sub {
margin-top: 0.25rem;
font-size: 0.58rem;
letter-spacing: 0.12em;
color: rgba(122, 248, 255, 0.5);
max-width: 70vw;
}
.play-cyber-self {
position: absolute;
top: max(52px, calc(env(safe-area-inset-top) + 38px));
right: max(10px, env(safe-area-inset-right));
display: flex;
flex-direction: column;
align-items: center;
gap: 0.35rem;
}
.play-cyber-self-frame {
padding: 4px;
background: linear-gradient(145deg, rgba(0, 60, 70, 0.9), rgba(0, 20, 35, 0.95));
border: 1px solid rgba(0, 255, 240, 0.45);
border-radius: 6px;
box-shadow:
0 0 24px rgba(0, 200, 255, 0.2),
inset 0 0 20px rgba(0, 255, 240, 0.06);
}
.play-cyber-self-frame img {
display: block;
width: 72px;
height: 72px;
object-fit: contain;
image-rendering: pixelated;
background: rgba(0, 8, 16, 0.9);
}
.play-cyber-self-status {
font-size: 0.58rem;
letter-spacing: 0.14em;
color: #5cf0ff;
text-shadow: 0 0 8px rgba(92, 240, 255, 0.4);
max-width: 100px;
text-align: center;
line-height: 1.3;
}
.play-cyber-hint {
position: absolute;
top: max(200px, calc(env(safe-area-inset-top) + 168px));
left: max(10px, env(safe-area-inset-left));
width: min(280px, 48vw);
font-size: 0.62rem;
line-height: 1.45;
color: rgba(180, 230, 255, 0.72);
text-shadow: 0 1px 8px rgba(0, 0, 0, 0.8);
}
.play-cyber-preview-line {
position: absolute;
bottom: max(88px, calc(env(safe-area-inset-bottom) + 72px));
left: max(10px, env(safe-area-inset-left));
right: max(56px, env(safe-area-inset-right));
font-size: 0.6rem;
letter-spacing: 0.06em;
color: rgba(255, 200, 120, 0.85);
text-shadow: 0 0 10px rgba(255, 180, 80, 0.35);
}
.play-cyber-preview-line.is-hidden { display: none !important; }
.play-cyber-corruption {
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: clamp(56px, 14vh, 100px);
background: linear-gradient(0deg, rgba(120, 0, 20, 0.55), rgba(180, 20, 40, 0.22) 40%, transparent);
overflow: hidden;
pointer-events: none;
}
.play-cyber-corruption-scanlines {
position: absolute;
inset: 0;
background: repeating-linear-gradient(
0deg,
transparent,
transparent 2px,
rgba(0, 0, 0, 0.12) 2px,
rgba(0, 0, 0, 0.12) 3px
);
opacity: 0.85;
animation: play-cyber-scan 6s linear infinite;
}
@keyframes play-cyber-scan {
from { transform: translateY(0); }
to { transform: translateY(6px); }
}
.play-cyber-corruption-text {
position: absolute;
bottom: 0.45rem;
left: 0.75rem;
right: 0.75rem;
font-size: 0.58rem;
letter-spacing: 0.1em;
color: rgba(255, 160, 170, 0.9);
text-shadow: 0 0 12px rgba(255, 80, 100, 0.5);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
animation: play-cyber-glitch 4.5s steps(2) infinite;
}
@keyframes play-cyber-glitch {
0%, 100% { opacity: 1; }
50% { opacity: 0.82; }
}
.play-canvas-stack.play-cyber-vignette::after {
content: '';
position: absolute;
inset: 0;
pointer-events: none;
box-shadow: inset 0 0 80px rgba(0, 0, 0, 0.35);
border-radius: inherit;
}
/* Quiz Battle — MCQ โดม (กด E) */
#quiz-battle-mcq-overlay {
position: fixed;
inset: 0;
z-index: 10076;
display: flex;
align-items: center;
justify-content: center;
padding: max(12px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
box-sizing: border-box;
}
#quiz-battle-mcq-overlay.is-hidden { display: none !important; }
.quiz-battle-mcq-backdrop {
position: absolute;
inset: 0;
background: rgba(6, 8, 20, 0.82);
backdrop-filter: blur(8px);
}
.quiz-battle-mcq-card {
position: relative;
max-width: min(92vw, 440px);
width: 100%;
background: linear-gradient(165deg, rgba(14, 18, 36, 0.97), rgba(8, 12, 28, 0.98));
border: 1px solid rgba(0, 255, 240, 0.28);
border-radius: 14px;
padding: 1.1rem 1.15rem 1rem;
box-shadow:
0 0 0 1px rgba(0, 0, 0, 0.5),
0 0 40px rgba(0, 200, 255, 0.12);
font-family: 'Share Tech Mono', ui-monospace, monospace;
}
.quiz-battle-mcq-title {
margin: 0 0 0.6rem;
font-family: 'Orbitron', sans-serif;
font-size: 0.78rem;
font-weight: 800;
letter-spacing: 0.16em;
color: #5cf0ff;
text-shadow: 0 0 12px rgba(92, 240, 255, 0.4);
}
.quiz-battle-mcq-text {
margin: 0 0 1rem;
font-size: clamp(0.9rem, 2.8vw, 1.05rem);
line-height: 1.5;
color: #e2e8f0;
font-weight: 600;
}
.quiz-battle-mcq-actions {
display: flex;
flex-direction: column;
gap: 0.45rem;
margin-bottom: 0.65rem;
}
.quiz-battle-choice {
width: 100%;
text-align: left;
padding: 0.55rem 0.75rem;
border-radius: 8px;
border: 1px solid rgba(122, 162, 247, 0.45);
background: rgba(20, 28, 48, 0.95);
color: #c0caf5;
font-size: 0.82rem;
font-weight: 600;
cursor: pointer;
transition: border-color 0.15s, box-shadow 0.15s;
}
.quiz-battle-choice:hover {
border-color: rgba(0, 255, 240, 0.55);
box-shadow: 0 0 16px rgba(0, 200, 255, 0.15);
}
#quiz-battle-mcq-close {
width: 100%;
margin-top: 0.15rem;
padding: 0.45rem;
border: none;
border-radius: 8px;
background: rgba(60, 70, 100, 0.6);
color: #a9b1d6;
font-weight: 700;
cursor: pointer;
font-size: 0.78rem;
}
</style>
</head>
<body>
<div class="game-wrap">
<div class="game-header">
<span id="room-id"></span>
<button id="btn-leave">ออกจากห้อง</button>
</div>
<div class="play-canvas-stack" id="play-canvas-stack">
<canvas id="game-canvas"></canvas>
<button type="button" id="quiz-carry-grab-btn" class="is-hidden" aria-label="หยิบหรือส่งคำตอบ (Grab)" title="หยิบ / ส่งคำตอบ — เหมือนกด F">
<img src="/Game/img/quiz-carry/btn-grab.png" alt="" width="256" height="256" decoding="async" />
</button>
<button type="button" id="gauntlet-crown-jump-btn" class="is-hidden" aria-label="กระโดด (Jump)" title="กระโดด — เหมือน Space / W / ↑" aria-hidden="true">
<img src="/Game/img/gauntlet-assets/btn-jump.png" alt="" width="256" height="256" decoding="async" />
</button>
<div id="quiz-map-question-panel" class="is-hidden" aria-hidden="true">
<img id="quiz-map-q-feedback-icon" class="quiz-map-q-feedback-icon is-hidden" alt="" width="64" height="64" decoding="async" />
<div id="quiz-map-question-kicker" class="quiz-map-question-kicker is-hidden" aria-hidden="true"></div>
<p id="quiz-map-question-text"></p>
<div id="quiz-map-q-feedback-score-wrap" class="is-hidden" aria-hidden="true">
<img id="quiz-map-q-feedback-score" alt="" width="120" height="48" decoding="async" />
</div>
</div>
<div id="quiz-carry-timeup-desk-layer" class="is-hidden" aria-hidden="true">
<div class="qc-timeup-dim" aria-hidden="true"></div>
<div class="qc-timeup-desk-anchor">
<img id="quiz-carry-timeup-txt-img" class="qc-timeup-txt-img" src="/Game/img/quiz-carry/timeup-txt.png" alt="" width="480" height="120" decoding="async" />
</div>
</div>
<div id="quiz-carry-result-end-layer" class="is-hidden" aria-hidden="true" role="img" aria-label="ผลจบภารกิจ">
<div class="qc-result-end-dim" aria-hidden="true"></div>
<img id="quiz-carry-result-end-img" class="qc-result-end-img" src="" alt="" width="900" height="520" decoding="async" />
</div>
</div>
</div>
<div id="play-quiz-scoreboard" class="is-hidden" aria-live="polite">
<div class="play-quiz-scoreboard-title">คะแนน</div>
<ul id="play-quiz-scoreboard-list" class="play-quiz-scoreboard-list"></ul>
</div>
<div id="play-quiz-feedback" class="is-hidden play-quiz-feedback" role="status" aria-atomic="true"></div>
<div id="quiz-carry-pregame-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-labelledby="quiz-carry-pregame-sr-title" aria-hidden="true">
<div class="quiz-carry-pregame-backdrop" aria-hidden="true"></div>
<div class="quiz-carry-pregame-card">
<h2 id="quiz-carry-pregame-sr-title" class="quiz-carry-pregame-sr-only">ประลองความรู้ คำศัพท์ในกระบวนการยุติธรรม — How to play</h2>
<div class="quiz-carry-pregame-art">
<img id="quiz-carry-pregame-howto-img" class="quiz-carry-pregame-howto-img" src="/Game/img/quiz-carry/howto.png" width="900" height="520" alt="HOW TO PLAY — ประลองความรู้ คำศัพท์ในกระบวนการยุติธรรม" loading="lazy" decoding="async" />
</div>
<div class="quiz-carry-pregame-footer">
<p id="quiz-carry-pregame-status" class="quiz-carry-pregame-status" aria-live="polite"></p>
<div class="quiz-carry-pregame-actions">
<button type="button" id="quiz-carry-pregame-primary" class="quiz-carry-pregame-primary-btn" aria-pressed="false" title="READY">
<img id="quiz-carry-pregame-primary-img" src="/Game/img/quiz-carry/btn-ready.png" width="220" height="56" alt="READY" decoding="async" />
</button>
</div>
</div>
</div>
</div>
<div id="quiz-carry-embed-countdown" class="is-hidden" role="alert" aria-live="assertive" aria-atomic="true" aria-hidden="true">
<div id="quiz-carry-embed-countdown-inner">
<p id="quiz-carry-embed-countdown-kicker" class="quiz-carry-embed-countdown-kicker">คำถาม · Question</p>
<p id="quiz-carry-embed-countdown-q" class="quiz-carry-embed-countdown-q"></p>
<img id="quiz-carry-embed-countdown-num" src="/Game/img/QUESTION/3.png" width="200" height="200" alt="3" decoding="async" />
</div>
</div>
<div id="quiz-carry-embed-q-strip" class="is-hidden" role="status" aria-live="polite" aria-atomic="true" aria-hidden="true">
<span class="quiz-carry-embed-q-strip-kicker">คำถาม · Question</span>
<p id="quiz-carry-embed-q-strip-text"></p>
</div>
<div id="quiz-game-overlay" class="is-hidden" role="status" aria-live="polite" aria-atomic="true">
<div class="quiz-game-inner">
<div class="quiz-game-phase" id="quiz-game-phase-label"></div>
<p class="quiz-game-q" id="quiz-game-question"></p>
<div class="quiz-game-timer" id="quiz-game-timer" aria-hidden="true"></div>
<p class="quiz-play-legend" id="quiz-play-legend"></p>
</div>
</div>
<div id="play-cyber-hud" class="play-cyber-hud is-hidden" aria-hidden="true">
<aside class="play-cyber-scoreboard" aria-label="SCORE">
<div id="play-cyber-crown-score-head" class="play-cyber-crown-score-head is-hidden" aria-hidden="true">
<img id="play-cyber-crown-score-img" alt="" width="120" height="32" decoding="async" />
</div>
<div class="play-cyber-panel-title">SCORE</div>
<ul id="play-cyber-score-list" class="play-cyber-score-list"></ul>
</aside>
<div class="play-cyber-center-stack">
<div class="play-cyber-time-block">
<div class="play-cyber-time-head">
<img id="play-cyber-time-plaque-img" class="play-cyber-time-plaque-img is-hidden" alt="TIME" decoding="async" aria-hidden="true" />
<div class="play-cyber-time-label">TIME</div>
<span class="play-cyber-time-colon" aria-hidden="true">:</span>
<div id="play-cyber-time-val" class="play-cyber-time-val">0</div>
</div>
<div id="play-cyber-time-sub" class="play-cyber-time-sub"></div>
</div>
<div id="play-cyber-quiz-mission-q-band" class="play-cyber-quiz-mission-q-band is-hidden" aria-hidden="true">
<img id="play-cyber-quiz-mission-q-plaque" class="play-cyber-quiz-mission-q-plaque is-hidden" alt="" decoding="async" />
<p id="play-cyber-quiz-mission-q-text" class="play-cyber-quiz-mission-q-text"></p>
</div>
</div>
<div class="play-cyber-self">
<div class="play-cyber-self-frame">
<img id="play-cyber-portrait-img" alt="" width="72" height="72" />
</div>
<div id="play-cyber-self-status" class="play-cyber-self-status"></div>
<div id="play-cyber-op-widgets" class="play-cyber-op-widgets" aria-hidden="true">
<div id="play-cyber-voice-chip" class="play-cyber-voice-chip"></div>
<div class="play-cyber-link-status" title="LINK">O</div>
</div>
</div>
<p id="play-cyber-hint" class="play-cyber-hint"></p>
<p id="play-cyber-preview-line" class="play-cyber-preview-line is-hidden"></p>
<div class="play-cyber-corruption" aria-hidden="true">
<div class="play-cyber-corruption-scanlines"></div>
<div class="play-cyber-corruption-text">RAM ERROR · CORRUPTING · DELETE INITIATED · 01001101 01110011 01100101 01100011</div>
</div>
</div>
<div id="quiz-battle-mcq-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-labelledby="quiz-battle-mcq-title">
<div class="quiz-battle-mcq-backdrop" aria-hidden="true"></div>
<div class="quiz-battle-mcq-card">
<h2 id="quiz-battle-mcq-title" class="quiz-battle-mcq-title">QUIZ BATTLE</h2>
<p id="quiz-battle-mcq-text" class="quiz-battle-mcq-text"></p>
<div class="quiz-battle-mcq-actions">
<button type="button" class="quiz-battle-choice" data-idx="0">A</button>
<button type="button" class="quiz-battle-choice" data-idx="1">B</button>
<button type="button" class="quiz-battle-choice" data-idx="2">C</button>
</div>
<button type="button" id="quiz-battle-mcq-close">ปิด · Close</button>
</div>
</div>
<div id="gauntlet-crown-howto-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-label="HOW TO PLAY — Last Light">
<div class="gch-backdrop" aria-hidden="true"></div>
<div class="gch-shell">
<img class="gch-bg" src="/Game/img/gauntlet-assets/popup-Howto.png" alt="" width="920" height="520" decoding="async" />
<div class="gch-inner gch-inner--art">
<div class="gch-art-footer">
<div id="stack-tower-howto-rules" class="stack-tower-howto-rules is-hidden" aria-hidden="true">
<h4>กติกา / How to</h4>
<ul>
<li>วางชิ้นส่วนให้ตรงตำแหน่งมากที่สุด</li>
<li>แตะ / ปล่อย — <strong>Space · Enter · คลิก</strong> เพื่อวางชิ้นส่วนลงบนฐาน</li>
<li>วางตรง = ได้คะแนน + ไปต่อ · วางแม่นต่อเนื่อง = <strong>คอมโบ ×2</strong> (คะแนน + Progress)</li>
</ul>
<h4>เวลา &amp; โอกาส</h4>
<ul>
<li class="warn">พลาดครบหรือหมดเวลา = เกมจบ</li>
</ul>
</div>
<p id="gauntlet-crown-howto-status" class="gch-status is-hidden" aria-live="polite"></p>
<button type="button" class="btn-gch-ready" id="btn-gch-ready" title="READY"><span class="sr-only">READY</span></button>
</div>
</div>
</div>
</div>
<div id="gauntlet-crown-countdown" class="is-hidden" role="alert" aria-live="assertive" aria-atomic="true">
<div class="gcc-panel">
<img id="gauntlet-crown-countdown-num" class="gcc-num" src="/Game/img/QUESTION/3.png" width="240" height="240" alt="" decoding="async" />
</div>
</div>
<div id="gauntlet-crown-mission-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-labelledby="gcm-heading">
<div class="gcm-backdrop" aria-hidden="true"></div>
<div class="gcm-shell">
<img class="gcm-bg" src="/Game/img/gauntlet-assets/popup-result.png" alt="" width="920" height="560" decoding="async" />
<div class="gcm-inner">
<div id="gcm-heading" class="gcm-header-tab">สรุปผลภารกิจ · Mission summary</div>
<div id="gcm-rank-row" class="gcm-rank-row"></div>
<p id="gcm-total" class="gcm-total"></p>
<div class="gcm-bottom">
<div>
<div class="gcm-h">ระดับความสำเร็จ</div>
<div id="gcm-grade" class="gcm-grade" aria-live="polite">A</div>
</div>
<div>
<div class="gcm-h">โบนัสพิเศษ</div>
<div id="gcm-bonus" class="gcm-bonus"></div>
</div>
</div>
<button type="button" class="btn-gcm-done" id="btn-gcm-done" title="รับหลักฐาน"><span class="sr-only">รับหลักฐาน · Receive evidence</span></button>
</div>
</div>
</div>
<div id="gauntlet-ended-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-labelledby="gauntlet-ended-title">
<div class="gauntlet-ended-backdrop" aria-hidden="true"></div>
<div class="gauntlet-ended-card">
<h2 id="gauntlet-ended-title">เกมจบ</h2>
<p id="gauntlet-ended-message"></p>
<ol id="gauntlet-ended-rankings"></ol>
<button type="button" id="btn-gauntlet-ended-lobby">กลับห้อง (ล็อบบี้) · Back to room lobby</button>
</div>
</div>
<div id="quiz-carry-mission-overlay" class="is-hidden" role="dialog" aria-modal="true" aria-labelledby="qc-mission-title">
<div class="qc-mission-backdrop" aria-hidden="true"></div>
<div class="qc-mission-panel">
<div class="qc-mission-panel-bg" aria-hidden="true"></div>
<div class="qc-mission-panel-inner">
<h2 id="qc-mission-title" class="qc-mission-sr">สรุปผลภารกิจ</h2>
<div id="qc-mission-rank-row" class="qc-mission-rank-row"></div>
<p id="qc-mission-total-line" class="qc-mission-total"></p>
<div class="qc-mission-bottom">
<div class="qc-mission-grade-block">
<div class="qc-mission-section-h">ระดับความสำเร็จ</div>
<div id="qc-mission-grade" class="qc-mission-grade" aria-live="polite">A</div>
</div>
<div class="qc-mission-bonus-block">
<div class="qc-mission-section-h">โบนัสพิเศษ</div>
<div id="qc-mission-bonus-row" class="qc-mission-bonus-row">
<div class="qc-mission-bonus-inline">
<img id="qc-mission-check" class="qc-mission-check" src="/Game/img/quiz-carry/result-check.png" alt="" width="28" height="28" loading="lazy" decoding="async" />
<span id="qc-mission-success-txt" class="qc-mission-success-txt">ภารกิจสำเร็จ</span>
</div>
<div id="qc-mission-card-text" class="qc-mission-card-text"></div>
</div>
</div>
</div>
<button type="button" id="btn-quiz-carry-mission-done"><span class="qc-mission-sr">รับหลักฐาน · Done</span></button>
</div>
</div>
</div>
<script src="/Game/socket.io/socket.io.js"></script>
<script src="js/version.js?v=0.0249"></script>
<script src="js/play.js?v=0.0249"></script>
<div class="version-tag">v —</div>
</body>
</html>