@font-face {
  font-family: "Galmuri11";
  src: local("Galmuri11 Regular"), url("assets/fonts/galmuri/Galmuri11.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Galmuri11";
  src: local("Galmuri11 Bold"), url("assets/fonts/galmuri/Galmuri11-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --ink: #241a2e;
  --paper: #fff8eb;
  --paper-strong: #fffdf6;
  --muted: #73657c;
  --line: rgba(255,255,255,0.64);
  --rose: #ff6078;
  --coral: #ff8b61;
  --gold: #ffd166;
  --mint: #63d5b8;
  --sky: #5ab7f0;
  --violet: #74508f;
  --shadow: 0 24px 78px rgba(17, 10, 26, 0.36);
  --font-ui: "Pretendard", "Apple SD Gothic Neo", "Malgun Gothic", "Segoe UI", sans-serif;
  --font-game: "Galmuri11", "Pretendard", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
  overflow: hidden;
  background: #11131d;
  color: var(--ink);
  font-family: var(--font-ui);
  user-select: none;
  touch-action: none;
}

button,
input {
  font: inherit;
}

#app {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 15% 10%, rgba(255, 96, 120, 0.18), transparent 28%),
    radial-gradient(circle at 84% 80%, rgba(99, 213, 184, 0.15), transparent 26%),
    linear-gradient(145deg, #191726, #0d1220 68%);
}

#game {
  position: relative;
  width: min(100vw, calc(100vh * 1.6));
  height: min(100vh, calc(100vw / 1.6));
  overflow: hidden;
  border-radius: clamp(0px, 1vw, 20px);
  background: #101624;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.13), 0 28px 110px rgba(0,0,0,0.52);
  isolation: isolate;
}

.screen,
.gift-layer,
.album-layer {
  position: absolute;
  inset: 0;
}

.hidden {
  display: none !important;
}

.start-screen {
  z-index: 30;
  display: grid;
  align-items: end;
  padding: clamp(20px, 4vw, 56px);
}

.start-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(15, 11, 24, 0.24), transparent 52%),
    linear-gradient(0deg, rgba(15, 11, 24, 0.72), transparent 58%),
    var(--start-bg, url("assets/generated/premium_keyvisual_friend_group_v2.png")) center/cover;
  filter: saturate(1.04) contrast(1.02);
}

.start-panel {
  position: relative;
  width: min(640px, 62vw);
  padding: 0;
  color: var(--paper);
  font-family: var(--font-game);
  text-shadow: 0 3px 24px rgba(22, 12, 30, 0.45);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  padding: 9px 14px 8px;
  border-radius: 999px;
  color: #331c32;
  background: linear-gradient(135deg, rgba(255,248,235,0.96), rgba(255,214,142,0.92));
  border: 2px solid rgba(255,255,255,0.82);
  font-size: clamp(13px, 1.1vw, 16px);
  font-weight: 700;
  box-shadow: 0 14px 34px rgba(18, 12, 28, 0.22), inset 0 -3px 0 rgba(88, 47, 55, 0.12);
  text-shadow: none;
}

.eyebrow::before {
  content: "★";
  color: var(--rose);
  font-size: 14px;
}

.start-panel h1 {
  margin: 16px 0 14px;
  color: #fff9ed;
  font-family: var(--font-game);
  font-size: clamp(58px, 8.5vw, 126px);
  line-height: 0.95;
  letter-spacing: 0;
  text-shadow:
    0 5px 0 rgba(50, 29, 48, 0.62),
    0 18px 44px rgba(16, 10, 24, 0.62),
    0 0 30px rgba(255, 209, 102, 0.28);
}

.start-panel p {
  width: min(600px, 100%);
  margin: 0 0 24px;
  color: #fff8eb;
  font-family: var(--font-game);
  font-size: clamp(16px, 1.36vw, 21px);
  line-height: 1.7;
  font-weight: 700;
  word-break: keep-all;
  text-shadow: 0 4px 18px rgba(0,0,0,0.52);
}

.start-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.start-buttons .primary {
  min-height: 58px;
  padding-inline: 24px;
  border: 2px solid rgba(255,255,255,0.72);
  font-family: var(--font-game);
  font-size: 17px;
  box-shadow:
    0 18px 34px rgba(15, 10, 24, 0.32),
    inset 0 -4px 0 rgba(91, 35, 43, 0.24);
}

.start-screen.full-image-title {
  padding: 0;
  align-items: stretch;
}

.start-screen.full-image-title .start-bg {
  background: var(--start-bg) center/cover no-repeat;
  filter: none;
}

.start-screen.full-image-title .start-panel {
  position: absolute;
  inset: 0;
  width: 100%;
  pointer-events: none;
  text-shadow: none;
}

.start-screen.full-image-title .start-panel .eyebrow,
.start-screen.full-image-title .start-panel h1,
.start-screen.full-image-title .start-panel p {
  display: none;
}

.start-screen.full-image-title .start-buttons {
  position: absolute;
  left: 50%;
  bottom: clamp(64px, 6.1vw, 104px);
  width: clamp(360px, 32vw, 560px);
  height: clamp(80px, 7vw, 118px);
  pointer-events: auto;
  transform: translateX(-50%);
}

.start-screen.full-image-title .start-buttons .primary {
  width: 100%;
  height: 100%;
  min-height: 0;
  padding: 0;
  border: 0;
  opacity: 0.01;
  box-shadow: none;
}

.play-screen {
  z-index: 10;
}

.world,
.background,
.scene-grade,
.playfield-matte,
.object-layer,
.character-layer,
.hit-layer,
.particle-layer,
.cinema-bars {
  position: absolute;
  inset: 0;
}

.world {
  z-index: 1;
  overflow: hidden;
}

.background {
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  transform: scale(1.01);
  filter: saturate(0.96) contrast(1.02) brightness(0.92);
  transition: background-image 460ms ease, filter 460ms ease, transform 460ms ease;
}

.background.river-bg {
  background-size: cover;
  background-position: center;
  filter: saturate(1.06) contrast(1.03) brightness(0.88);
  transform: scale(1);
}

.scene-grade {
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(20, 12, 28, 0.32), transparent 32%, rgba(13, 20, 30, 0.1)),
    linear-gradient(0deg, rgba(20, 12, 28, 0.48), transparent 48%);
}

.scene-grade.warm {
  background:
    linear-gradient(90deg, rgba(26, 16, 32, 0.26), transparent 40%),
    linear-gradient(0deg, rgba(39, 23, 34, 0.28), transparent 56%);
}

.scene-grade.office,
.scene-grade.street {
  background:
    linear-gradient(90deg, rgba(17, 18, 30, 0.38), transparent 36%),
    linear-gradient(0deg, rgba(20, 14, 28, 0.42), transparent 52%);
}

.scene-grade.cafe {
  background:
    linear-gradient(90deg, rgba(57, 36, 28, 0.22), transparent 46%),
    linear-gradient(0deg, rgba(30, 18, 20, 0.38), transparent 56%);
}

.scene-grade.river {
  background:
    linear-gradient(0deg, rgba(7, 7, 12, 0.66) 0 34%, rgba(7, 7, 12, 0.42) 58%, rgba(10, 10, 18, 0.12)),
    linear-gradient(90deg, rgba(12, 10, 22, 0.12), transparent 42%, rgba(7, 7, 12, 0.42) 88%, rgba(7, 7, 12, 0.54));
}

.scene-grade.river + .playfield-matte {
  opacity: 0.96;
  left: 11%;
  top: 48%;
  height: 43%;
  clip-path: polygon(9% 12%, 95% 0%, 100% 82%, 5% 100%);
  background:
    radial-gradient(circle at 58% 38%, rgba(255, 209, 102, 0.26), transparent 30%),
    linear-gradient(135deg, rgba(48, 46, 62, 0.86), rgba(18, 16, 28, 0.82)),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.09) 0 4px, transparent 4px 34px);
}

.playfield-matte {
  z-index: 3;
  left: 12%;
  top: 32%;
  width: 78%;
  height: 57%;
  pointer-events: none;
  clip-path: polygon(12% 7%, 100% 0%, 91% 100%, 0 88%);
  background:
    linear-gradient(135deg, rgba(255,248,235,0.2), rgba(37,26,46,0.32)),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.075) 0 2px, transparent 2px 35px);
  border: 1px solid rgba(255,255,255,0.25);
  box-shadow:
    inset 0 0 0 1px rgba(255,209,102,0.14),
    inset 0 -88px 120px rgba(26, 18, 38, 0.2),
    0 30px 90px rgba(19, 10, 27, 0.18);
  backdrop-filter: blur(2.5px) saturate(0.86);
}

.world.presentation-mode .background {
  background-size: cover;
  background-position: center;
  filter: saturate(1.04) contrast(1.02) brightness(0.82);
  transform: scale(1);
}

.world.presentation-mode .scene-grade {
  background:
    linear-gradient(90deg, rgba(19, 11, 26, 0.22), transparent 38%, rgba(16, 12, 22, 0.18)),
    linear-gradient(0deg, rgba(18, 10, 24, 0.62), transparent 58%);
}

.world.presentation-mode .playfield-matte {
  opacity: 0;
}

.world.presentation-mode .character-layer,
.world.presentation-mode .hit-layer {
  display: none;
}

.world.visual-novel-mode .playfield-matte,
.world.visual-novel-mode .character-layer,
.world.visual-novel-mode .hit-layer {
  display: none;
}

.world.visual-novel-mode .background {
  background-size: cover;
  background-position: center;
  filter: saturate(1.06) contrast(1.02) brightness(0.84);
  transform: scale(1);
}

.presentation-art {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.presentation-illustration {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.03) contrast(1.02);
}

.presentation-art.has-illustration .presentation-prop {
  display: none;
}

.presentation-light {
  position: absolute;
  left: 7%;
  right: 7%;
  bottom: 8%;
  height: 45%;
  border-radius: 50%;
  background: radial-gradient(circle at 48% 64%, rgba(255, 209, 102, 0.24), transparent 48%);
  filter: blur(12px);
}

.presentation-prop {
  position: absolute;
  display: grid;
  place-items: end center;
  padding: 16px;
  color: #302238;
  background: rgba(255, 248, 235, 0.88);
  border: 1px solid rgba(255,255,255,0.66);
  box-shadow: 0 24px 60px rgba(18, 9, 28, 0.2);
  backdrop-filter: blur(8px);
}

.presentation-prop span {
  border-radius: 999px;
  padding: 7px 11px;
  background: rgba(255,255,255,0.76);
  font-size: 14px;
  font-weight: 1000;
}

.prop-phone {
  left: 13%;
  top: 25%;
  width: clamp(120px, 12vw, 190px);
  height: clamp(180px, 18vw, 275px);
  border-radius: 28px;
  transform: rotate(-8deg);
}

.prop-phone::before {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  top: 18%;
  height: 9px;
  border-radius: 999px;
  background: var(--rose);
  box-shadow: 0 34px 0 var(--gold), 0 68px 0 var(--mint);
}

.prop-card {
  left: 30%;
  bottom: 25%;
  width: clamp(160px, 18vw, 260px);
  height: clamp(100px, 11vw, 158px);
  border-radius: 22px;
  transform: rotate(5deg);
}

.prop-card::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 20px;
  width: 42px;
  height: 30px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--mint), var(--sky));
}

.prop-gift {
  right: 8%;
  bottom: 30%;
  width: clamp(135px, 14vw, 220px);
  height: clamp(125px, 13vw, 205px);
  border-radius: 24px;
  background:
    linear-gradient(90deg, transparent 45%, rgba(255,255,255,0.54) 45% 55%, transparent 55%),
    linear-gradient(0deg, transparent 45%, rgba(255,255,255,0.54) 45% 55%, transparent 55%),
    linear-gradient(135deg, var(--rose), var(--coral));
  transform: rotate(7deg);
}

.presentation-caption {
  position: absolute;
  left: 34px;
  top: 92px;
  color: #fff8eb;
  text-shadow: 0 4px 24px rgba(17, 8, 24, 0.42);
}

.presentation-caption strong,
.presentation-caption span {
  display: block;
}

.presentation-caption strong {
  font-size: clamp(38px, 5vw, 74px);
  line-height: 0.96;
  font-weight: 1000;
}

.presentation-caption span {
  margin-top: 8px;
  font-size: clamp(15px, 1.3vw, 20px);
  font-weight: 900;
}

.chosen-outfit-preview {
  position: absolute;
  right: 6%;
  bottom: 17%;
  width: min(260px, 22vw);
  max-height: 48%;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 18px 48px rgba(13, 10, 20, 0.38);
}

.object-layer {
  z-index: 4;
  pointer-events: none;
}

.character-layer {
  z-index: 5;
  pointer-events: none;
}

.hit-layer {
  z-index: 6;
  pointer-events: none;
}

.particle-layer {
  z-index: 12;
  pointer-events: none;
}

.cinema-bars {
  z-index: 15;
  pointer-events: none;
  opacity: 0;
  transition: opacity 360ms ease;
}

.cinema-bars.show {
  opacity: 1;
}

.cinema-bars::before,
.cinema-bars::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 8.5%;
  background: rgba(7, 7, 12, 0.86);
}

.cinema-bars::before {
  top: 0;
}

.cinema-bars::after {
  bottom: 0;
}

.hud,
.quest-card,
.dialogue-box,
.story-actions,
.minigame-panel,
.action-dock,
.toast,
.gift-card,
.album-panel {
  background: rgba(255, 248, 235, 0.9);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px) saturate(1.12);
}

.hud {
  position: absolute;
  z-index: 20;
  left: 18px;
  right: 18px;
  top: 14px;
  min-height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 12px;
  border-radius: 20px;
}

.hud-left {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.scene-chip {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 38px;
  max-width: 280px;
  padding: 8px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: #302238;
  font-size: 15px;
  font-weight: 1000;
  white-space: nowrap;
}

.scene-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--rose), var(--gold), var(--mint));
  box-shadow: 0 0 0 4px rgba(255, 209, 102, 0.18);
}

.route-track {
  width: min(320px, 26vw);
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(35, 26, 45, 0.12);
}

.route-fill {
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--rose), var(--gold), var(--mint), var(--sky));
  transition: width 380ms ease;
}

.hud-stats {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.hud-stats span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: #31243a;
  font-size: 14px;
  font-weight: 1000;
  white-space: nowrap;
}

.quest-card {
  position: absolute;
  z-index: 20;
  right: 18px;
  top: 86px;
  width: min(330px, 28vw);
  padding: 14px 16px;
  border-radius: 20px;
  opacity: 0.92;
}

.quest-card span {
  display: block;
  margin-bottom: 7px;
  color: #d94662;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 0;
}

.quest-card strong {
  display: block;
  color: #241a2e;
  font-size: clamp(18px, 1.45vw, 24px);
  line-height: 1.18;
  font-weight: 1000;
  word-break: keep-all;
}

.quest-card p {
  margin: 7px 0 11px;
  color: #5f5067;
  font-size: clamp(13px, 1.08vw, 16px);
  line-height: 1.45;
  font-weight: 800;
  word-break: keep-all;
}

.quest-progress {
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(36, 26, 46, 0.12);
}

.quest-progress div {
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--rose), var(--gold), var(--mint));
  transition: width 280ms ease;
}

.dialogue-box {
  position: absolute;
  z-index: 50;
  left: 50%;
  bottom: clamp(18px, 4vh, 54px);
  width: min(78vw, 1120px);
  min-height: clamp(120px, 16vh, 190px);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: clamp(14px, 2vw, 28px);
  align-items: center;
  padding: clamp(18px, 2.4vw, 30px);
  padding-right: clamp(20px, 2.8vw, 38px);
  border-radius: 22px;
  transform: translateX(-50%);
  color: #fff8eb;
  background: linear-gradient(180deg, rgba(42, 30, 57, 0.94), rgba(17, 13, 28, 0.96));
  border: 2px solid rgba(226, 190, 121, 0.72);
  box-shadow:
    0 18px 45px rgba(0, 0, 0, 0.42),
    inset 0 0 0 1px rgba(255, 255, 255, 0.08),
    inset 0 0 28px rgba(255, 211, 146, 0.08);
  backdrop-filter: blur(8px) saturate(1.08);
}

.dialogue-box::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 16px;
  border: 1px solid rgba(255, 232, 180, 0.18);
  pointer-events: none;
}

.dialogue-profile-wrap {
  width: clamp(74px, 8vw, 108px);
  height: clamp(74px, 8vw, 108px);
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  background: linear-gradient(145deg, #fff3c9, #d4a85d);
  box-shadow:
    0 0 0 4px rgba(255, 245, 213, 0.18),
    0 8px 20px rgba(0, 0, 0, 0.35);
}

.dialogue-profile-wrap.is-empty::after {
  content: "♥";
  color: #2a1d2f;
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 1000;
}

.dialogue-profile {
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  object-fit: cover;
  object-position: center 24%;
  border-radius: 16px;
  background: var(--profile-bg, #f4ead8);
  display: block;
}

.dialogue-profile[hidden] {
  display: none;
}

.dialogue-content {
  min-width: 0;
  position: relative;
  z-index: 1;
}

.dialogue-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: clamp(8px, 1.3vh, 14px);
}

.dialogue-speaker {
  min-width: 78px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 18px;
  border-radius: 999px;
  color: #2a1d2f;
  background: linear-gradient(180deg, #ffe6a5, #d8a94d);
  font-family: var(--font-game);
  font-size: clamp(18px, 1.7vw, 24px);
  font-weight: 800;
  letter-spacing: 0;
}

.dialogue-role {
  color: rgba(255, 235, 190, 0.72);
  font-family: var(--font-game);
  font-size: clamp(13px, 1.1vw, 16px);
  font-weight: 600;
}

.dialogue-text {
  margin: 0;
  color: #fff8ea;
  font-family: var(--font-game);
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 1.48;
  font-weight: 750;
  letter-spacing: 0;
  word-break: keep-all;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.38);
}

.dialogue-next,
.game-button,
.close-button,
.choice-button,
.answer-button {
  min-height: 48px;
  border: 0;
  border-radius: 15px;
  padding: 11px 16px;
  color: #2e2237;
  background: rgba(255,255,255,0.9);
  font-weight: 1000;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(35,22,45,0.16), inset 0 -3px 0 rgba(45,28,55,0.12);
  transition: transform 120ms ease, filter 120ms ease, background 120ms ease;
}

.dialogue-next:active,
.game-button:active,
.close-button:active,
.choice-button:active,
.answer-button:active {
  transform: translateY(2px) scale(0.98);
}

.primary,
.choice-button.primary {
  color: #fffaf0;
  background: linear-gradient(135deg, var(--rose), var(--coral));
}

.dialogue-next {
  position: relative;
  z-index: 2;
  align-self: stretch;
  width: clamp(58px, 6vw, 82px);
  min-width: clamp(58px, 6vw, 82px);
  min-height: clamp(74px, 8vh, 104px);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 4px;
  padding: 0;
  border-radius: 18px;
  color: #2a1d2f;
  background: linear-gradient(180deg, #fff0bf, #ffb55f);
  border: 0;
  box-shadow:
    0 8px 20px rgba(0, 0, 0, 0.35),
    inset 0 0 0 2px rgba(255, 255, 255, 0.36);
}

.dialogue-next:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
}

.dialogue-next-icon {
  display: block;
  font-size: clamp(24px, 2.4vw, 36px);
  line-height: 1;
  text-indent: 3px;
}

.dialogue-next-label {
  max-width: 72px;
  overflow: hidden;
  color: rgba(42, 29, 47, 0.82);
  font-size: clamp(10px, 0.82vw, 12px);
  font-weight: 1000;
  line-height: 1.18;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.action-dock {
  position: absolute;
  z-index: 20;
  right: 16px;
  bottom: 18px;
  display: flex;
  gap: 8px;
  padding: 10px;
  border-radius: 24px;
  opacity: 0.72;
  background: rgba(255, 248, 235, 0.46);
  border: 1px solid rgba(255,255,255,0.58);
  box-shadow: 0 18px 42px rgba(20, 12, 30, 0.24), inset 0 1px 0 rgba(255,255,255,0.54);
  backdrop-filter: blur(16px) saturate(1.1);
  transition: opacity 140ms ease, transform 140ms ease;
}

.action-dock:hover,
.action-dock:focus-within {
  opacity: 0.98;
  transform: translateY(-2px);
}

.action-dock .game-button {
  min-height: 44px;
  padding: 9px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.78);
  box-shadow: 0 8px 18px rgba(35,22,45,0.14), inset 0 -3px 0 rgba(45,28,55,0.11);
}

.story-actions {
  position: absolute;
  z-index: 24;
  right: 18px;
  bottom: 100px;
  width: min(430px, 34vw);
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
}

.story-action-copy {
  min-width: 0;
}

.story-action-copy span {
  display: block;
  margin-bottom: 7px;
  color: #d94662;
  font-size: 12px;
  font-weight: 1000;
}

.story-action-copy strong {
  display: block;
  color: #241a2e;
  font-size: clamp(22px, 2.1vw, 34px);
  line-height: 1.08;
  font-weight: 1000;
  word-break: keep-all;
}

.story-action-copy p {
  margin: 9px 0 0;
  color: #65576d;
  font-size: clamp(14px, 1.15vw, 17px);
  line-height: 1.48;
  font-weight: 850;
  word-break: keep-all;
}

.story-action-button {
  min-height: 68px;
  border: 0;
  border-radius: 17px;
  padding: 14px 18px;
  color: #fffaf0;
  background: linear-gradient(135deg, var(--rose), var(--coral));
  box-shadow: 0 16px 34px rgba(35,22,45,0.18), inset 0 -4px 0 rgba(45,28,55,0.15);
  font-size: clamp(18px, 1.55vw, 24px);
  font-weight: 1000;
  cursor: pointer;
}

.story-action-button:active {
  transform: translateY(2px) scale(0.99);
}

.minigame-panel {
  position: absolute;
  z-index: 1000;
  left: 50%;
  top: 50%;
  width: min(760px, 66vw);
  transform: translate(-50%, -50%);
  padding: 24px;
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,253,246,0.98), rgba(248,236,214,0.96)),
    radial-gradient(circle at 12% 0%, rgba(255,209,102,0.35), transparent 30%);
  border: 3px solid rgba(255,255,255,0.74);
  box-shadow:
    0 30px 90px rgba(18, 10, 28, 0.42),
    inset 0 0 0 2px rgba(255,209,102,0.28),
    inset 0 -7px 0 rgba(69, 45, 71, 0.1);
  backdrop-filter: blur(18px) saturate(1.08);
}

.minigame-panel:not(.hidden-image-panel)::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 14px;
  height: 8px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--rose), var(--gold), var(--mint), var(--sky));
  box-shadow: 0 9px 18px rgba(255,96,120,0.18);
  pointer-events: none;
}

.minigame-panel.art-backed-panel {
  width: min(1360px, calc(100% - 44px));
  height: min(850px, calc(100% - 64px));
  padding: 0;
  border-radius: 32px;
  background: #120d19;
  border: 4px solid rgba(255, 255, 255, 0.72);
  box-shadow:
    0 34px 110px rgba(10, 7, 18, 0.56),
    inset 0 0 0 2px rgba(255, 209, 102, 0.2);
}

.minigame-panel.art-backed-panel::before {
  content: none;
}

.minigame-art-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.06) contrast(1.02);
}

.minigame-art-overlay {
  position: absolute;
  z-index: 2;
  border-radius: 28px;
  border: 2px solid rgba(255, 255, 255, 0.78);
  background:
    linear-gradient(180deg, rgba(255, 253, 246, 0.94), rgba(248, 237, 220, 0.9));
  box-shadow:
    0 24px 70px rgba(13, 8, 18, 0.38),
    inset 0 0 0 2px rgba(255, 209, 102, 0.2),
    inset 0 -6px 0 rgba(54, 35, 58, 0.1);
  backdrop-filter: blur(16px) saturate(1.1);
}

.quiz-art-card {
  left: clamp(24px, 4vw, 58px);
  bottom: clamp(24px, 4vw, 58px);
  width: min(560px, 45%);
  padding: clamp(18px, 2vw, 26px);
}

.questions-art-card {
  left: 50%;
  bottom: clamp(22px, 3vw, 42px);
  width: min(820px, 72%);
  padding: clamp(18px, 2vw, 26px);
  transform: translateX(-50%);
}

.art-backed-panel .minigame-title {
  margin: 0 0 14px;
}

.art-backed-panel .minigame-title strong {
  font-size: clamp(22px, 2vw, 34px);
}

.art-backed-panel .initial-card {
  min-height: clamp(104px, 14vh, 150px);
  margin: 10px 0 14px;
  font-size: clamp(46px, 5vw, 78px);
}

.art-backed-panel .choice-button {
  min-height: clamp(56px, 7vh, 72px);
}

.play-screen.hidden-game-active .dialogue-box,
.play-screen.hidden-game-active .action-dock,
.play-screen.hidden-game-active .quest-card,
.play-screen.hidden-game-active .presentation-caption {
  display: none;
}

.play-screen.hidden-game-active .hud {
  opacity: 0.88;
}

.minigame-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 8px 0 18px;
  position: relative;
  z-index: 1;
}

.minigame-title.illustrated-title {
  align-items: stretch;
}

.minigame-title.illustrated-title img {
  width: clamp(120px, 14vw, 184px);
  height: clamp(88px, 10vw, 136px);
  flex: 0 0 auto;
  object-fit: cover;
  border-radius: 18px;
  border: 3px solid rgba(255,255,255,0.9);
  transform: rotate(-1.5deg);
  box-shadow: 0 16px 34px rgba(36, 26, 46, 0.18), inset 0 0 0 2px rgba(255,209,102,0.24);
}

.minigame-title span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px 4px;
  border-radius: 999px;
  color: #fffaf0;
  background: linear-gradient(135deg, #d94662, #ff8b61);
  font-family: var(--font-game);
  font-size: 12px;
  font-weight: 700;
  box-shadow: 0 9px 20px rgba(217,70,98,0.22);
}

.minigame-title strong {
  display: block;
  margin-top: 8px;
  color: #241a2e;
  font-family: var(--font-game);
  font-size: clamp(24px, 2.2vw, 38px);
  line-height: 1.1;
  font-weight: 700;
  text-shadow: 0 2px 0 rgba(255,255,255,0.8);
}

.initial-card {
  display: grid;
  place-items: center;
  min-height: 142px;
  margin: 12px 0 16px;
  border-radius: 26px;
  position: relative;
  overflow: hidden;
  color: #fffaf0;
  background:
    radial-gradient(circle at 22% 18%, rgba(255,209,102,0.44), transparent 28%),
    radial-gradient(circle at 82% 26%, rgba(99,213,184,0.18), transparent 27%),
    linear-gradient(135deg, #342440, #d94662 64%, #ff8b61);
  border: 2px solid rgba(255,255,255,0.62);
  font-family: var(--font-game);
  font-size: clamp(48px, 5.6vw, 84px);
  font-weight: 700;
  box-shadow: 0 18px 38px rgba(45,28,55,0.18), inset 0 -6px 0 rgba(0,0,0,0.16);
}

.initial-card::before {
  content: "초성 코드";
  position: absolute;
  left: 18px;
  top: 14px;
  font-size: 12px;
  color: rgba(255,248,235,0.72);
}

.initial-card::after {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px dashed rgba(255,248,235,0.34);
  border-radius: 20px;
  pointer-events: none;
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.choice-button {
  min-height: 68px;
  border: 2px solid rgba(255,255,255,0.8);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,245,229,0.92));
  font-family: var(--font-game);
  font-size: clamp(15px, 1.4vw, 20px);
  font-weight: 700;
}

.hidden-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.hidden-badge {
  min-height: 48px;
  display: grid;
  place-items: center;
  border-radius: 13px;
  background: rgba(255,255,255,0.62);
  color: #756477;
  font-size: 12px;
  font-weight: 1000;
  text-align: center;
  word-break: keep-all;
}

.hidden-badge.done {
  color: #2e624f;
  background: rgba(99,213,184,0.28);
}

.minigame-panel.hidden-image-panel {
  top: 50%;
  display: grid;
  grid-template-columns: minmax(150px, 188px) minmax(0, auto);
  justify-content: center;
  align-items: stretch;
  gap: 12px;
  width: min(1120px, calc(100% - 24px));
  height: min(768px, calc(100% - 24px));
  padding: 10px;
  border-radius: 18px;
  font-family: var(--font-game);
  background:
    linear-gradient(180deg, rgba(255,252,244,0.96), rgba(251,239,218,0.92)),
    rgba(255, 248, 235, 0.94);
}

.hidden-game-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-content: start;
  min-height: 0;
  padding: 16px 10px;
}

.hidden-game-head span {
  color: #d94662;
  font-size: 13px;
  font-weight: 1000;
}

.hidden-game-head strong {
  display: block;
  margin-top: 3px;
  color: #241a2e;
  font-size: clamp(26px, 2.6vw, 40px);
  line-height: 1;
  font-weight: 1000;
}

.hidden-game-head p {
  width: min(360px, 100%);
  margin: 0;
  color: #66596f;
  font-size: 14px;
  line-height: 1.56;
  font-weight: 700;
  word-break: keep-all;
}

.hidden-image-stage {
  position: relative;
  height: 100%;
  max-height: 100%;
  aspect-ratio: 864 / 1821;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 20px;
  background: #231b2d;
  box-shadow: 0 18px 50px rgba(24, 14, 32, 0.28), inset 0 0 0 1px rgba(255,255,255,0.28);
}

.hidden-image-stage img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: fill;
  user-select: none;
  pointer-events: none;
}

.hidden-target {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  transform: translate(-50%, -50%);
  border: 0;
  border-radius: 45%;
  background: transparent;
  cursor: default !important;
  pointer-events: auto;
  -webkit-tap-highlight-color: transparent;
}

.hidden-target::after {
  content: "";
  position: absolute;
  inset: -10%;
  border-radius: inherit;
  opacity: 0;
  background: rgba(255,255,255,0.18);
  box-shadow: 0 0 0 4px rgba(255,209,102,0.46), 0 0 38px rgba(255,96,120,0.46);
  transition: opacity 120ms ease, transform 120ms ease;
}

.hidden-target.pressed::after {
  opacity: 1;
  transform: scale(0.94);
}

.hidden-target.found {
  pointer-events: none;
}

.target-scene-ring {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  transform: translate(-50%, -50%) rotate(-4deg) scale(0.86);
  border: clamp(3px, 0.45vw, 6px) solid #ff3b4f;
  border-radius: 46%;
  opacity: 0;
  pointer-events: none;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.7), 0 0 24px rgba(255,59,79,0.46);
  transition: opacity 160ms ease, transform 220ms cubic-bezier(.2,.8,.25,1);
}

.target-scene-ring {
  z-index: 3;
  border-width: clamp(4px, 0.62vw, 8px);
  border-color: #ed2030;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.62), 0 0 34px rgba(237,32,48,0.4);
  transform: translate(-50%, -50%) rotate(-2deg) scale(0.92);
}

.target-scene-ring.flash {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(-2deg) scale(1);
  animation: sceneRingFlash 620ms cubic-bezier(.2,.9,.25,1.2) forwards;
}

.target-card-ring {
  position: absolute;
  z-index: 4;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  transform: translate(-50%, -50%) rotate(-4deg) scale(0.88);
  border: clamp(4px, 0.6vw, 7px) solid #ed2030;
  border-radius: 28%;
  opacity: 0;
  pointer-events: none;
  box-shadow:
    0 0 0 3px rgba(255,255,255,0.7),
    0 0 24px rgba(237,32,48,0.38);
}

.target-card-ring.show {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(-4deg) scale(1);
  animation: sceneRingPop 420ms cubic-bezier(.2,.9,.25,1.2);
}

.hidden-clear {
  position: absolute;
  inset: 10px;
  z-index: 20;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  transform: scale(0.96);
  padding: 28px;
  border-radius: 16px;
  color: #fffaf0;
  background:
    radial-gradient(circle at 50% 46%, rgba(255,255,255,0.42), transparent 24%),
    radial-gradient(circle at 22% 18%, rgba(255,255,255,0.32), transparent 30%),
    radial-gradient(circle at 82% 82%, rgba(99,213,184,0.34), transparent 32%),
    linear-gradient(135deg, rgba(255,96,120,0.94), rgba(255,139,97,0.92));
  border: 2px solid rgba(255,255,255,0.82);
  box-shadow:
    0 34px 100px rgba(255,96,120,0.46),
    0 0 0 11px rgba(255,209,102,0.22),
    0 0 80px rgba(99,213,184,0.34);
  font-size: clamp(52px, 6vw, 86px);
  line-height: 1;
  font-weight: 1000;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  text-shadow: 0 4px 22px rgba(29, 18, 38, 0.42);
  transition: opacity 260ms ease, transform 360ms cubic-bezier(.2,.8,.25,1);
}

.hidden-clear.show {
  opacity: 1;
  transform: scale(1);
  animation: clearPulse 920ms ease-in-out infinite alternate;
  pointer-events: auto;
}

.hidden-clear span,
.hidden-clear small {
  position: relative;
  z-index: 2;
  display: block;
}

.hidden-clear small {
  margin-top: 8px;
  font-size: clamp(18px, 1.7vw, 26px);
  letter-spacing: 0;
}

.hidden-clear-button {
  position: relative;
  z-index: 3;
  min-height: 52px;
  margin: 18px auto 0;
  padding: 12px 22px;
  border: 0;
  border-radius: 14px;
  color: #251829;
  background: linear-gradient(135deg, #fffdf6, #ffd166);
  font-family: var(--font-game);
  font-size: 18px;
  font-weight: 700;
  box-shadow: 0 14px 34px rgba(0,0,0,0.26), inset 0 -3px 0 rgba(99,43,28,0.18);
}

.hidden-clear-button:active {
  transform: translateY(2px) scale(0.98);
}

.hidden-clear i {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 9px;
  height: 24px;
  border-radius: 99px;
  background: hsl(calc(var(--i) * 31deg), 92%, 66%);
  opacity: 0;
  transform: translate(-50%, -50%) rotate(calc(var(--i) * 25.7deg)) translateY(-24px);
}

.hidden-clear.show i {
  animation: clearSpark 980ms cubic-bezier(.1,.8,.2,1) infinite;
  animation-delay: calc(var(--i) * -72ms);
}

.hidden-clear::before,
.hidden-clear::after {
  content: "";
  position: absolute;
  inset: -24px;
  border-radius: inherit;
  pointer-events: none;
}

.hidden-clear::before {
  border: 3px solid rgba(255,255,255,0.44);
  animation: clearHalo 980ms ease-out infinite;
}

.hidden-clear::after {
  background:
    radial-gradient(circle at 18% 32%, rgba(255,255,255,0.9) 0 4px, transparent 5px),
    radial-gradient(circle at 78% 24%, rgba(255,245,160,0.95) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 74%, rgba(99,213,184,0.9) 0 5px, transparent 6px),
    radial-gradient(circle at 30% 82%, rgba(255,255,255,0.9) 0 4px, transparent 5px);
  animation: clearTwinkle 760ms ease-in-out infinite alternate;
}

@keyframes sceneRingPop {
  0% { opacity: 0; transform: translate(-50%, -50%) rotate(-2deg) scale(0.55); }
  70% { opacity: 1; transform: translate(-50%, -50%) rotate(-2deg) scale(1.08); }
  100% { opacity: 1; transform: translate(-50%, -50%) rotate(-2deg) scale(1); }
}

@keyframes sceneRingFlash {
  0% { opacity: 0; transform: translate(-50%, -50%) rotate(-2deg) scale(0.58); }
  22%, 72% { opacity: 1; transform: translate(-50%, -50%) rotate(-2deg) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -50%) rotate(-2deg) scale(1.08); }
}

@keyframes clearPulse {
  from { filter: saturate(1) brightness(1); }
  to { filter: saturate(1.18) brightness(1.08); }
}

@keyframes clearHalo {
  0% { opacity: 0.8; transform: scale(0.86); }
  100% { opacity: 0; transform: scale(1.26); }
}

@keyframes clearTwinkle {
  from { opacity: 0.65; transform: rotate(-2deg) scale(0.96); }
  to { opacity: 1; transform: rotate(2deg) scale(1.03); }
}

@keyframes clearSpark {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(calc(var(--i) * 25.7deg)) translateY(-18px) scale(0.4);
  }
  22% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(calc(var(--i) * 25.7deg)) translateY(-170px) scale(1);
  }
}

.question-stack {
  display: grid;
  gap: 13px;
  position: relative;
  z-index: 1;
}

.question-row {
  display: grid;
  gap: 8px;
  padding: 13px 14px 14px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.72), rgba(255,246,232,0.64));
  border: 1px solid rgba(83, 53, 86, 0.1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.72);
}

.question-row label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #3b2c44;
  font-family: var(--font-game);
  font-weight: 700;
  font-size: 14px;
}

.question-row label::before {
  content: "Q";
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 8px;
  color: #fffaf0;
  background: linear-gradient(135deg, var(--violet), var(--rose));
  font-size: 12px;
}

.question-row input {
  width: 100%;
  min-height: 54px;
  border: 2px solid rgba(36,26,46,0.08);
  border-radius: 16px;
  padding: 12px 14px;
  color: #241a2e;
  background: rgba(255,255,255,0.92);
  font-weight: 900;
  outline: none;
  box-shadow: inset 0 2px 8px rgba(47, 30, 55, 0.05);
}

.question-row input:focus {
  border-color: var(--rose);
  box-shadow: 0 0 0 5px rgba(255,96,120,0.14);
}

.question-row.error input {
  border-color: #d94662;
  background: rgba(255,96,120,0.08);
}

.questions-panel .answer-button {
  min-height: 62px;
  margin-top: 3px;
  border-radius: 18px;
  border: 2px solid rgba(255,255,255,0.72);
  font-family: var(--font-game);
  font-size: 17px;
  letter-spacing: 0;
  box-shadow: 0 16px 34px rgba(217,70,98,0.22), inset 0 -4px 0 rgba(105,43,50,0.16);
}

.toast {
  position: absolute;
  z-index: 40;
  left: 50%;
  top: 86px;
  min-height: 46px;
  padding: 12px 16px;
  border-radius: 999px;
  color: #302338;
  font-size: 14px;
  font-weight: 1000;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(-16px);
  transition: opacity 180ms ease, transform 180ms ease;
}

.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.character {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: calc(104px * var(--s));
  height: calc(150px * var(--s));
  transform: translate(-50%, -100%);
  filter: drop-shadow(0 20px 24px rgba(19, 10, 27, 0.3));
  transition: left 560ms cubic-bezier(.2,.8,.25,1), top 560ms cubic-bezier(.2,.8,.25,1), opacity 280ms ease, transform 220ms ease;
}

.character.wave .arm.right {
  animation: waveArm 780ms ease-in-out infinite alternate;
}

@keyframes waveArm {
  from { transform: rotate(-26deg); }
  to { transform: rotate(-72deg); }
}

.body-shadow {
  position: absolute;
  left: 50%;
  bottom: -4px;
  width: 82%;
  height: 18px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: rgba(19, 10, 27, 0.3);
  filter: blur(2px);
}

.legs {
  position: absolute;
  left: 50%;
  bottom: 12px;
  width: 58%;
  height: 44px;
  transform: translateX(-50%);
}

.legs::before,
.legs::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 18px;
  height: 46px;
  border-radius: 9px;
  background: var(--pants);
}

.legs::before { left: 12px; transform: rotate(3deg); }
.legs::after { right: 12px; transform: rotate(-3deg); }

.torso {
  position: absolute;
  left: 50%;
  bottom: 48px;
  width: 66%;
  height: 62px;
  transform: translateX(-50%);
  border-radius: 22px 22px 18px 18px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.18), transparent 36%),
    var(--top);
  border: 2px solid rgba(255,255,255,0.28);
}

.torso::after {
  content: "";
  position: absolute;
  left: 20%;
  top: 18px;
  width: 36%;
  height: 10px;
  border-radius: 999px;
  background: var(--accent);
  opacity: 0.82;
}

.character.hobum .torso {
  width: 84%;
  height: 72px;
  bottom: 46px;
  border-radius: 27px 27px 22px 22px;
}

.character.hobum {
  width: calc(118px * var(--s));
}

.character.haein {
  height: calc(132px * var(--s));
}

.arm {
  position: absolute;
  bottom: 66px;
  width: 16px;
  height: 49px;
  border-radius: 999px;
  background: var(--top);
  transform-origin: top;
}

.arm.left { left: 10%; transform: rotate(24deg); }
.arm.right { right: 10%; transform: rotate(-24deg); }

.head {
  position: absolute;
  left: 50%;
  bottom: 106px;
  width: 55px;
  height: 59px;
  transform: translateX(-50%);
  border-radius: 48% 48% 45% 45%;
  background: #f5c7ac;
  border: 2px solid rgba(255,255,255,0.28);
  overflow: hidden;
}

.hair {
  position: absolute;
  left: 50%;
  bottom: 143px;
  width: 67px;
  height: 38px;
  transform: translateX(-50%);
  border-radius: 45px 45px 22px 22px;
  background: #211822;
  z-index: 2;
}

.character.garam .hair,
.character.geumppi .hair {
  height: 45px;
}

.character.garam .hair::before,
.character.garam .hair::after,
.character.geumppi .hair::before,
.character.geumppi .hair::after {
  content: "";
  position: absolute;
  top: 22px;
  width: 16px;
  height: 62px;
  border-radius: 999px;
  background: #211822;
}

.character.garam .hair::before,
.character.geumppi .hair::before { left: 3px; }
.character.garam .hair::after,
.character.geumppi .hair::after { right: 3px; }

.character.haein .hair {
  height: 34px;
}

.character.haein .hair::before {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: -14px;
  height: 22px;
  border-radius: 0 0 14px 14px;
  background: repeating-linear-gradient(90deg, #211822 0 8px, #2e2231 8px 14px);
}

.face {
  position: absolute;
  left: 50%;
  bottom: 114px;
  width: 42px;
  height: 30px;
  transform: translateX(-50%);
  z-index: 3;
}

.face::before,
.face::after {
  content: "";
  position: absolute;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #2c2232;
}

.face::before { left: 9px; }
.face::after { right: 9px; }

.mouth {
  position: absolute;
  left: 50%;
  top: 20px;
  width: 15px;
  height: 7px;
  transform: translateX(-50%);
  border-bottom: 2px solid #a95a66;
  border-radius: 0 0 16px 16px;
}

.glasses {
  position: absolute;
  left: 50%;
  top: 3px;
  width: 44px;
  height: 18px;
  transform: translateX(-50%);
  display: none;
}

.character.hobum .glasses {
  display: block;
}

.glasses::before,
.glasses::after {
  content: "";
  position: absolute;
  top: 0;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  border: 3px solid #302536;
}

.glasses::before { left: 1px; }
.glasses::after { right: 1px; }

.glasses span {
  position: absolute;
  left: 19px;
  top: 7px;
  width: 6px;
  height: 3px;
  background: #302536;
}

.name-tag {
  position: absolute;
  left: 50%;
  bottom: -32px;
  min-width: 62px;
  transform: translateX(-50%);
  padding: 6px 9px;
  border-radius: 999px;
  color: #2f2339;
  background: rgba(255,248,235,0.9);
  border: 1px solid rgba(255,255,255,0.68);
  box-shadow: 0 10px 24px rgba(23,12,34,0.18);
  font-size: 13px;
  font-weight: 1000;
  text-align: center;
  white-space: nowrap;
}

.world-object {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 18px 20px rgba(19,10,27,0.25));
  transition: opacity 220ms ease, transform 180ms ease, filter 180ms ease;
}

.world-object.pressed {
  transform: translate(-50%, -50%) scale(1.12);
  filter: drop-shadow(0 22px 28px rgba(255, 209, 102, 0.44));
}

.world-object.collected,
.world-object.found {
  opacity: 0.16;
  transform: translate(-50%, -50%) scale(0.58);
}

.object-core {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.obj-phone .object-core,
.obj-card .object-core,
.obj-ticket .object-core {
  border-radius: 14px;
  background: #fffaf0;
  border: 4px solid #2f5c6f;
}

.obj-phone .object-core::after,
.obj-ticket .object-core::after {
  content: "";
  width: 56%;
  height: 10%;
  border-radius: 999px;
  background: var(--rose);
}

.obj-card .object-core::after {
  content: "";
  width: 62%;
  height: 42%;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--mint), var(--sky));
}

.obj-letter .object-core {
  border-radius: 16px;
  background: #fffaf0;
  border: 4px solid #ffd7ad;
}

.obj-letter .object-core::before {
  content: "";
  width: 60%;
  height: 42%;
  border-left: 5px solid var(--rose);
  border-bottom: 5px solid var(--rose);
  transform: rotate(-45deg);
  margin-top: -12px;
}

.obj-glasses .object-core {
  border-radius: 24px;
  background: rgba(255,248,235,0.95);
}

.obj-glasses .object-core::before,
.obj-glasses .object-core::after {
  content: "";
  width: 26px;
  height: 26px;
  border: 5px solid #241a2e;
  border-radius: 50%;
}

.obj-glasses .object-core::before {
  margin-right: -4px;
}

.obj-ribbon .object-core,
.obj-spark .object-core {
  border-radius: 50%;
  background: radial-gradient(circle, #fff 0 16%, var(--gold) 17% 46%, rgba(255,96,120,0.8) 47% 100%);
}

.obj-cake .object-core {
  border-radius: 18px 18px 24px 24px;
  background: #fff0c6;
  border-bottom: 18px solid var(--coral);
}

.obj-cake .object-core::before {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  top: -22%;
  height: 30%;
  border-radius: 999px;
  background: var(--rose);
}

.obj-gift .object-core {
  border-radius: 18px;
  background: linear-gradient(135deg, var(--rose), var(--coral));
}

.hitbox {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--hit);
  height: var(--hit);
  transform: translate(-50%, -50%);
  border: 0;
  border-radius: 50%;
  pointer-events: auto;
  cursor: pointer;
  background: radial-gradient(circle, rgba(255,255,255,0.72) 0 13%, rgba(255,209,102,0.34) 14% 40%, rgba(255,96,120,0.12) 41% 68%, transparent 69%);
  box-shadow: 0 0 34px rgba(255,209,102,0.36);
  animation: hitPulse 1.2s ease-in-out infinite;
  transition: opacity 180ms ease, transform 160ms ease;
}

.hitbox.hidden {
  opacity: 0;
  pointer-events: none;
}

.hitbox.pressed,
.hitbox:active {
  transform: translate(-50%, -50%) scale(0.92);
  background: radial-gradient(circle, #fff 0 16%, rgba(255,209,102,0.86) 17% 45%, rgba(255,96,120,0.22) 46% 78%, transparent 79%);
}

.hitbox::after {
  content: attr(data-label);
  position: absolute;
  left: 50%;
  top: 76%;
  min-width: 70px;
  padding: 7px 10px;
  transform: translateX(-50%);
  border-radius: 999px;
  color: #33243d;
  background: rgba(255,248,235,0.95);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: 0 10px 26px rgba(23,12,34,0.2);
  font-size: 12px;
  font-weight: 1000;
  white-space: nowrap;
}

@keyframes hitPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,209,102,0.46), 0 0 34px rgba(255,209,102,0.36); }
  50% { box-shadow: 0 0 0 17px rgba(255,209,102,0), 0 0 54px rgba(255,96,120,0.44); }
}

.tap-ripple,
.pop {
  position: absolute;
  left: var(--x);
  top: var(--y);
  pointer-events: none;
}

.tap-ripple {
  width: 18px;
  height: 18px;
  transform: translate(-50%, -50%);
  border: 3px solid var(--gold);
  border-radius: 50%;
  animation: ripple 560ms ease-out forwards;
}

@keyframes ripple {
  to {
    width: 124px;
    height: 124px;
    opacity: 0;
  }
}

.pop {
  transform: translate(-50%, -50%);
  color: #fffaf0;
  font-size: 18px;
  font-weight: 1000;
  text-shadow: 0 3px 16px rgba(23,12,34,0.5);
  animation: pop 820ms ease-out forwards;
}

@keyframes pop {
  to {
    opacity: 0;
    transform: translate(-50%, -90%);
  }
}

.spark {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--s);
  height: var(--s);
  border-radius: 50%;
  background: var(--c);
  transform: translate(-50%, -50%);
  animation: sparkFly var(--d) ease-out forwards;
}

@keyframes sparkFly {
  to {
    opacity: 0;
    transform: translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) scale(0.1);
  }
}

.gift-layer {
  z-index: 500;
  display: grid;
  place-items: center;
  background:
    linear-gradient(0deg, rgba(10, 10, 18, 0.62), rgba(10, 10, 18, 0.62)),
    var(--gift-layer-bg, url("assets/generated/scene_extra_haein_gift.png")) center/cover;
  backdrop-filter: blur(8px);
}

.gift-card {
  width: min(860px, 88vw);
  min-height: 410px;
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 24px;
  padding: 26px;
  border-radius: 30px;
}

.gift-layer.choosing .gift-card {
  width: min(1120px, 92vw);
  grid-template-columns: 1.45fr 0.9fr;
}

.gift-stage {
  position: relative;
  min-height: 350px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 44%, rgba(255,209,102,0.34), transparent 35%),
    linear-gradient(135deg, rgba(255,255,255,0.75), rgba(255,240,198,0.38));
  overflow: hidden;
}

.gift-box-visual,
.shirt-card {
  position: absolute;
  transition: transform 520ms cubic-bezier(.2,.8,.25,1), opacity 360ms ease;
}

.gift-box-visual {
  width: 160px;
  height: 150px;
}

.gift-body,
.gift-lid,
.gift-ribbon-v,
.gift-ribbon-h {
  position: absolute;
  background: var(--gift-color, var(--rose));
}

.gift-body {
  left: 18px;
  right: 18px;
  bottom: 0;
  height: 96px;
  border-radius: 18px;
}

.gift-lid {
  left: 5px;
  right: 5px;
  top: 26px;
  height: 38px;
  border-radius: 16px;
}

.gift-ribbon-v {
  left: 72px;
  top: 20px;
  width: 16px;
  height: 124px;
  background: var(--gift-accent, #fff0c6);
  border-radius: 999px;
}

.gift-ribbon-h {
  left: 14px;
  top: 77px;
  width: 132px;
  height: 17px;
  background: var(--gift-accent, #fff0c6);
  border-radius: 999px;
}

.shirt-card {
  width: 220px;
  height: 270px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.94), rgba(244,237,229,0.92)),
    repeating-linear-gradient(90deg, rgba(35,26,45,0.035) 0 1px, transparent 1px 5px);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: 0 20px 60px rgba(36,26,46,0.18);
  opacity: 0;
  transform: translateY(38px) rotate(-4deg) scale(0.9);
}

.shirt-photo-placeholder {
  position: relative;
  width: calc(100% - 24px);
  height: calc(100% - 24px);
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 17px;
  background:
    radial-gradient(circle at 30% 18%, rgba(255,255,255,0.86), transparent 24%),
    linear-gradient(135deg, rgba(226, 220, 214, 0.95), rgba(197, 188, 181, 0.72));
  box-shadow: inset 0 0 0 1px rgba(36,26,46,0.08);
}

.photo-sheen {
  position: absolute;
  inset: -40% 52% auto auto;
  width: 120px;
  height: 360px;
  transform: rotate(28deg);
  background: rgba(255,255,255,0.42);
  filter: blur(1px);
}

.hanger-line {
  position: absolute;
  left: 50%;
  top: 18px;
  width: 80px;
  height: 28px;
  transform: translateX(-50%);
  border-top: 4px solid rgba(36,26,46,0.28);
  border-radius: 50%;
}

.shirt-photo-placeholder small {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  min-height: 28px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #514557;
  background: rgba(255,255,255,0.72);
  font-size: 12px;
  font-weight: 1000;
  text-align: center;
}

.gift-layer.worn .shirt-card {
  opacity: 1;
  transform: translateY(0) rotate(-2deg) scale(1);
}

.gift-layer.choosing .shirt-card {
  opacity: 1;
  width: min(620px, 48vw);
  height: min(360px, 56vh);
  transform: translateY(0) rotate(0deg) scale(1);
}

.gift-layer.choosing .gift-box-visual {
  opacity: 0.18;
  transform: translateY(42px) scale(0.88);
}

.outfit-choice-grid {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  padding: 12px;
}

.outfit-card {
  min-width: 0;
  border: 0;
  border-radius: 18px;
  padding: 10px;
  background: rgba(255, 253, 246, 0.94);
  box-shadow: 0 14px 32px rgba(36, 26, 46, 0.16), inset 0 -3px 0 rgba(45, 28, 55, 0.08);
  color: #2f2339;
  cursor: pointer;
}

.outfit-card:active {
  transform: translateY(2px) scale(0.98);
}

.outfit-card img,
.selected-outfit-card img {
  width: 100%;
  height: calc(100% - 58px);
  min-height: 0;
  object-fit: cover;
  border-radius: 14px;
  background: #eee4d8;
}

.outfit-card strong,
.outfit-card span,
.selected-outfit-card strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.outfit-card strong {
  margin-top: 8px;
  font-size: 15px;
  font-weight: 1000;
}

.outfit-card span {
  margin-top: 3px;
  color: #8a5d65;
  font-size: 12px;
  font-weight: 1000;
}

.selected-outfit-card {
  width: calc(100% - 22px);
  height: calc(100% - 22px);
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 10px;
  padding: 10px;
}

.selected-outfit-card img {
  height: 100%;
}

.selected-outfit-card strong {
  color: #34263e;
  font-size: 16px;
  font-weight: 1000;
  text-align: center;
}

.gift-layer.worn .gift-box-visual {
  opacity: 0.26;
  transform: translateY(32px) scale(0.82);
}

.shirt-icon {
  position: relative;
  width: 112px;
  height: 128px;
  border-radius: 27px 27px 19px 19px;
  background: var(--gift-color, var(--rose));
}

.shirt-icon::before,
.shirt-icon::after {
  content: "";
  position: absolute;
  top: 24px;
  width: 34px;
  height: 68px;
  border-radius: 999px;
  background: var(--gift-color, var(--rose));
}

.shirt-icon::before {
  left: -24px;
  transform: rotate(22deg);
}

.shirt-icon::after {
  right: -24px;
  transform: rotate(-22deg);
}

.shirt-icon span {
  position: absolute;
  left: 50%;
  top: 58px;
  width: 42px;
  height: 14px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: var(--gift-accent, #fff0c6);
}

.gift-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.gift-copy span {
  color: #d94662;
  font-size: 15px;
  font-weight: 1000;
}

.gift-copy h2 {
  margin: 8px 0 12px;
  color: #241a2e;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.03;
  font-weight: 1000;
  word-break: keep-all;
}

.gift-copy p {
  margin: 0 0 20px;
  color: #675a70;
  font-size: clamp(16px, 1.35vw, 20px);
  line-height: 1.5;
  font-weight: 800;
  word-break: keep-all;
}

.gift-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.album-layer {
  z-index: 1100;
  display: grid;
  place-items: center;
  background: rgba(10, 10, 18, 0.58);
  backdrop-filter: blur(8px);
}

.album-panel {
  width: min(1000px, 90vw);
  max-height: 84vh;
  display: flex;
  flex-direction: column;
  padding: 22px;
  border-radius: 28px;
}

.album-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}

.album-head span {
  color: #241a2e;
  font-size: 28px;
  font-weight: 1000;
}

.photo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  overflow: auto;
  padding: 2px 2px 8px;
}

.photo-card {
  min-height: 178px;
  padding: 10px;
  border-radius: 18px;
  background: #fffdf7;
  box-shadow: 0 12px 30px rgba(36,26,46,0.14);
  transform: rotate(var(--tilt, 0deg));
}

.photo-card img,
.photo-fallback {
  width: 100%;
  height: 112px;
  object-fit: cover;
  border-radius: 12px;
  background: #eee4d8;
}

.photo-card strong {
  display: block;
  margin-top: 9px;
  color: #3a2a43;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 1000;
  word-break: keep-all;
}

.photo-fallback {
  display: grid;
  place-items: center;
  padding: 12px;
  color: #7e7185;
  text-align: center;
  font-size: 12px;
  font-weight: 900;
}

.ending-credit-slides {
  position: absolute;
  z-index: 1200;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.ending-credit-card {
  position: absolute;
  left: 50%;
  top: 53%;
  width: min(620px, 52vw);
  height: min(430px, 55vh);
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto auto;
  gap: 8px;
  padding: clamp(10px, 1vw, 16px);
  border-radius: 18px;
  color: #2f2038;
  background: rgba(255, 248, 235, 0.94);
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: 0 24px 70px rgba(0,0,0,0.38);
  opacity: 0;
  transform: translate(-50%, -50%) translateY(38px) rotate(calc(var(--tilt) - 2deg)) scale(0.9);
  animation: creditCardShow 4.8s cubic-bezier(.2,.8,.22,1) forwards;
  animation-delay: calc(7.4s + var(--i) * 3.15s);
}

.ending-credit-card img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: contain;
  border-radius: 12px;
  background: #17131d;
  box-shadow: inset 0 0 0 1px rgba(36,26,46,0.08);
}

.ending-credit-card strong,
.ending-credit-card span {
  display: block;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ending-credit-card strong {
  font-size: clamp(14px, 1.35vw, 20px);
  font-weight: 1000;
}

.ending-credit-card span {
  color: #8a5d65;
  font-size: 12px;
  font-weight: 900;
}

@keyframes creditCardShow {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(42px) rotate(calc(var(--tilt) - 3deg)) scale(0.9);
  }
  16%, 76% {
    opacity: 1;
    transform: translate(-50%, -50%) translateY(0) rotate(var(--tilt)) scale(1);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(-36px) rotate(calc(var(--tilt) + 2deg)) scale(0.96);
  }
}

.ending-title {
  position: absolute;
  z-index: 1210;
  left: 50%;
  top: 17%;
  width: min(900px, 82vw);
  transform: translateX(-50%);
  color: #fff8eb;
  text-align: center;
  font-family: var(--font-game);
  text-shadow:
    0 5px 0 rgba(45, 25, 53, 0.56),
    0 22px 46px rgba(0,0,0,0.55),
    0 0 30px rgba(255,209,102,0.28);
  pointer-events: none;
  opacity: 0;
  animation: endingTitle 7s ease 39s forwards;
}

.ending-title::before {
  content: "BIRTHDAY ROUTE CLEAR";
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  margin-bottom: 16px;
  padding: 7px 14px 6px;
  border-radius: 999px;
  color: #321c34;
  background: linear-gradient(135deg, #fff8eb, #ffd166);
  border: 2px solid rgba(255,255,255,0.82);
  box-shadow: 0 14px 34px rgba(0,0,0,0.24);
  font-size: clamp(12px, 1vw, 15px);
  font-weight: 700;
  text-shadow: none;
}

.ending-title strong {
  display: block;
  font-size: clamp(48px, 6.4vw, 92px);
  line-height: 1.04;
  font-weight: 700;
  letter-spacing: 0;
}

.ending-title span {
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 16px auto 0;
  padding: 10px 18px;
  border-radius: 999px;
  color: #fff8eb;
  background: rgba(31, 22, 45, 0.56);
  border: 1px solid rgba(255,255,255,0.24);
  backdrop-filter: blur(12px);
  font-size: clamp(16px, 1.4vw, 22px);
  font-weight: 700;
  text-shadow: 0 3px 16px rgba(0,0,0,0.44);
}

@keyframes endingTitle {
  0% { opacity: 0; transform: translateX(-50%) translateY(16px); }
  18%, 78% { opacity: 1; transform: translateX(-50%) translateY(0); }
  100% { opacity: 0; transform: translateX(-50%) translateY(-18px); }
}

.cake-stage {
  position: absolute;
  z-index: 4;
  left: 51%;
  top: 74%;
  width: 132px;
  height: 92px;
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 16px 24px rgba(10,10,18,0.38));
}

.cake-stage.has-cake-image {
  width: min(220px, 17vw);
  height: min(170px, 22vh);
  top: 73%;
}

.cake-stage.has-cake-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.ending-album-frame {
  position: absolute;
  z-index: 16;
  right: 2.5%;
  top: 56%;
  width: min(190px, 16vw);
  max-height: 28vh;
  object-fit: cover;
  border-radius: 16px;
  transform: rotate(2deg);
  box-shadow: 0 16px 44px rgba(0,0,0,0.32);
  opacity: 0.58;
}

.cake-stage::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 0;
  height: 48px;
  border-radius: 18px 18px 22px 22px;
  background: #fff0c6;
  border-bottom: 18px solid #ff8b61;
}

.cake-stage.has-cake-image::before,
.cake-stage.has-cake-image::after {
  display: none;
}

.cake-stage::after {
  content: "";
  position: absolute;
  left: 24px;
  right: 24px;
  top: 12px;
  height: 28px;
  border-radius: 999px;
  background: #ff6078;
  box-shadow:
    18px -16px 0 -8px #ffd166,
    42px -16px 0 -8px #ffd166,
    66px -16px 0 -8px #ffd166;
}

.orientation {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
  place-items: center;
  padding: 24px;
  color: var(--paper);
  text-align: center;
  background: #11131d;
}

.orientation strong {
  display: block;
  font-size: 28px;
}

.orientation p {
  margin: 10px auto 0;
  max-width: 320px;
  line-height: 1.5;
  font-weight: 800;
}

@media (orientation: portrait) {
  .orientation {
    display: grid;
  }
}

@media (max-width: 920px) {
  .quest-card {
    width: min(340px, 40vw);
  }

  .dialogue-box {
    width: calc(100% - 36px);
    grid-template-columns: auto 1fr;
    min-height: 112px;
    padding-right: 18px;
  }

  .dialogue-profile-wrap {
    width: 52px;
    height: 52px;
  }

  .dialogue-next {
    position: absolute;
    right: 14px;
    bottom: 14px;
    width: 54px;
    min-width: 54px;
    min-height: 54px;
    height: 54px;
    border-radius: 16px;
  }

  .dialogue-next-label {
    display: none;
  }

  .dialogue-text {
    padding-right: 58px;
    font-size: clamp(18px, 4.4vw, 24px);
  }

  .dialogue-role {
    display: none;
  }

  .minigame-panel {
    width: calc(100% - 36px);
  }

  .story-actions {
    right: 18px;
    bottom: 92px;
    width: min(390px, 43vw);
  }

  .presentation-caption {
    top: 82px;
  }

  .prop-phone {
    left: 10%;
    top: 29%;
  }

  .prop-card {
    left: 25%;
    bottom: 27%;
  }

  .choice-grid,
  .hidden-list,
  .photo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Dialogue UI v2 final override. Keep this at the end so cached or legacy rules cannot win. */
#playScreen > #dialogueBox.dialogue-box,
#dialogueBox.dialogue-box-v2 {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  bottom: max(24px, env(safe-area-inset-bottom)) !important;
  top: auto !important;
  transform: translateX(-50%) !important;
  z-index: 50 !important;
  width: min(1120px, calc(100vw - 96px)) !important;
  min-height: 174px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 22px 28px !important;
  overflow: visible !important;
  color: #fff8ea !important;
  background:
    radial-gradient(circle at 13% 10%, rgba(255, 209, 102, 0.18), transparent 32%),
    linear-gradient(180deg, rgba(45, 31, 62, 0.96), rgba(14, 11, 25, 0.98)) !important;
  border: 2px solid rgba(236, 201, 132, 0.86) !important;
  border-radius: 24px !important;
  box-shadow:
    0 26px 70px rgba(0, 0, 0, 0.52),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset,
    0 0 34px rgba(255, 209, 102, 0.13) inset !important;
  backdrop-filter: blur(12px) saturate(1.12) !important;
  font-family: var(--font-game), system-ui, sans-serif !important;
  letter-spacing: 0 !important;
}

#dialogueBox.dialogue-box-v2[hidden],
#dialogueBox.dialogue-box-v2.hidden,
.legacy-dialogue-hidden {
  display: none !important;
}

#dialogueBox.dialogue-box-v2::before {
  content: "" !important;
  position: absolute !important;
  inset: 9px !important;
  border: 1px solid rgba(255, 239, 197, 0.24) !important;
  border-radius: 18px !important;
  pointer-events: none !important;
}

#dialogueBox.dialogue-box-v2::after {
  content: "" !important;
  position: absolute !important;
  left: 28px !important;
  right: 28px !important;
  top: -2px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 231, 178, 0.9), transparent) !important;
  pointer-events: none !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-profile-wrap {
  position: relative !important;
  z-index: 1 !important;
  width: 112px !important;
  height: 112px !important;
  display: grid !important;
  place-items: center !important;
  flex: none !important;
  overflow: visible !important;
  border-radius: 24px !important;
  background: var(--profile-bg, linear-gradient(135deg, #ffe6a5, #d8a94d)) !important;
  box-shadow:
    0 0 0 5px rgba(255, 245, 213, 0.2),
    0 12px 28px rgba(0, 0, 0, 0.42) !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-profile {
  display: block !important;
  width: calc(100% - 12px) !important;
  height: calc(100% - 12px) !important;
  object-fit: cover !important;
  border-radius: 18px !important;
  background: #f6ead8 !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-profile[hidden] {
  display: none !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-content {
  position: relative !important;
  z-index: 1 !important;
  min-width: 0 !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-header {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 12px !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-speaker {
  min-width: 86px !important;
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 20px !important;
  color: #2b1d31 !important;
  background: linear-gradient(180deg, #fff0bb, #e5b558) !important;
  border: 1px solid rgba(255, 255, 255, 0.64) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28), inset 0 -2px 0 rgba(113, 70, 34, 0.18) !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-role {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 32px !important;
  color: rgba(255, 238, 201, 0.78) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-text {
  margin: 0 !important;
  padding: 0 !important;
  color: #fff8ea !important;
  font-size: 30px !important;
  font-weight: 850 !important;
  line-height: 1.42 !important;
  letter-spacing: 0 !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
  text-shadow: 0 3px 12px rgba(0, 0, 0, 0.46) !important;
}

#dialogueBox.dialogue-box-v2 #nextButton.dialogue-next {
  position: relative !important;
  z-index: 2 !important;
  width: 82px !important;
  min-width: 82px !important;
  height: 112px !important;
  min-height: 112px !important;
  display: grid !important;
  place-items: center !important;
  gap: 5px !important;
  align-self: center !important;
  padding: 0 !important;
  color: #2b1d31 !important;
  background: linear-gradient(180deg, #fff0bf, #ffb760) !important;
  border: 0 !important;
  border-radius: 20px !important;
  box-shadow:
    0 14px 30px rgba(0, 0, 0, 0.42),
    inset 0 0 0 2px rgba(255, 255, 255, 0.38) !important;
  cursor: pointer !important;
  letter-spacing: 0 !important;
}

#dialogueBox.dialogue-box-v2 #nextButton.dialogue-next:hover {
  transform: translateY(-1px) !important;
  filter: brightness(1.05) !important;
}

#dialogueBox.dialogue-box-v2 #nextButton.dialogue-next:active {
  transform: translateY(1px) !important;
}

#dialogueBox.dialogue-box-v2 #nextButton.dialogue-next.hidden {
  display: none !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-next-icon {
  display: block !important;
  color: #2b1d31 !important;
  font-size: 36px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-indent: 3px !important;
}

#dialogueBox.dialogue-box-v2 .dialogue-next-label {
  display: block !important;
  max-width: 70px !important;
  overflow: hidden !important;
  color: rgba(43, 29, 49, 0.82) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  text-align: center !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
}

.gift-layer:not(.hidden) ~ #dialogueBox.dialogue-box-v2,
.album-layer:not(.hidden) ~ #dialogueBox.dialogue-box-v2,
.ending-credit-slides ~ #dialogueBox.dialogue-box-v2 {
  display: none !important;
}

@media (max-width: 920px) {
  #playScreen > #dialogueBox.dialogue-box,
  #dialogueBox.dialogue-box-v2 {
    width: calc(100vw - 28px) !important;
    min-height: 132px !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 14px !important;
    padding: 16px 18px !important;
    padding-right: 78px !important;
    border-radius: 20px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-profile-wrap {
    width: 64px !important;
    height: 64px !important;
    border-radius: 18px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-profile {
    border-radius: 14px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-role {
    display: none !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-speaker {
    min-width: 70px !important;
    min-height: 34px !important;
    padding: 6px 14px !important;
    font-size: 18px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-text {
    padding-right: 0 !important;
    font-size: 20px !important;
    line-height: 1.38 !important;
  }

  #dialogueBox.dialogue-box-v2 #nextButton.dialogue-next {
    position: absolute !important;
    right: 14px !important;
    bottom: 14px !important;
    width: 54px !important;
    min-width: 54px !important;
    height: 54px !important;
    min-height: 54px !important;
    border-radius: 16px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-next-icon {
    font-size: 25px !important;
  }

  #dialogueBox.dialogue-box-v2 .dialogue-next-label {
    display: none !important;
  }
}

#playScreen > #dialogueBox.dialogue-box-v2[hidden],
#playScreen > #dialogueBox.dialogue-box-v2.hidden,
#playScreen > #dialogueBox.dialogue-box[hidden],
#playScreen > #dialogueBox.dialogue-box.hidden {
  display: none !important;
}

/* Dialogue VN box final override: reference-style wide translucent black dialogue. */
#playScreen > #dialogueBox.dialogue-box.dialogue-vn-box,
#dialogueBox.dialogue-vn-box {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: clamp(28px, 5vh, 64px) !important;
  transform: translateX(-50%) !important;
  z-index: 80 !important;
  width: min(82vw, 1180px) !important;
  min-height: clamp(150px, 19vh, 220px) !important;
  display: block !important;
  box-sizing: border-box !important;
  padding: clamp(24px, 2.5vw, 34px) clamp(32px, 3vw, 46px) !important;
  overflow: visible !important;
  color: rgba(255, 255, 255, 0.94) !important;
  background:
    linear-gradient(180deg, rgba(10, 10, 12, 0.78), rgba(3, 3, 5, 0.88)) !important;
  border: 1.5px solid rgba(214, 174, 94, 0.72) !important;
  border-radius: 8px !important;
  box-shadow:
    0 20px 48px rgba(0, 0, 0, 0.48),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05) !important;
  backdrop-filter: blur(3px) !important;
  font-family: var(--font-game), system-ui, sans-serif !important;
  letter-spacing: 0 !important;
}

#playScreen > #dialogueBox.dialogue-vn-box[hidden],
#playScreen > #dialogueBox.dialogue-vn-box.hidden,
#dialogueBox.dialogue-vn-box[hidden],
#dialogueBox.dialogue-vn-box.hidden {
  display: none !important;
}

#dialogueBox.dialogue-vn-box::before,
#dialogueBox.dialogue-vn-box::after {
  content: none !important;
}

#dialogueBox.dialogue-vn-box .dialogue-profile-wrap,
#dialogueBox.dialogue-vn-box .dialogue-profile,
#dialogueBox.dialogue-vn-box #dialogueProfile,
#dialogueBox.dialogue-vn-box .dialogue-role,
#dialogueBox.dialogue-vn-box #dialogueRole,
#dialogueBox.dialogue-vn-box .dialogue-header,
#dialogueBox.dialogue-vn-box .dialogue-next-icon,
#dialogueBox.dialogue-vn-box .dialogue-next-label,
#dialogueBox.dialogue-vn-box #nextButtonLabel {
  display: none !important;
}

#dialogueBox.dialogue-vn-box .dialogue-name,
#dialogueBox.dialogue-vn-box #dialogueSpeaker {
  display: block !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 0 clamp(10px, 1.2vh, 14px) !important;
  padding: 0 !important;
  color: #f2c46f !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-size: clamp(24px, 2.1vw, 34px) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
}

#dialogueBox.dialogue-vn-box .dialogue-divider {
  display: block !important;
  width: 100% !important;
  height: 1px !important;
  margin: 0 0 clamp(16px, 1.6vh, 22px) !important;
  padding: 0 !important;
  background:
    linear-gradient(90deg, rgba(242, 196, 111, 0.42), rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)) !important;
}

#dialogueBox.dialogue-vn-box .dialogue-content {
  display: contents !important;
}

#dialogueBox.dialogue-vn-box .dialogue-text,
#dialogueBox.dialogue-vn-box #dialogueText {
  display: block !important;
  margin: 0 !important;
  padding: 0 52px 0 0 !important;
  color: rgba(255, 255, 255, 0.94) !important;
  background: transparent !important;
  border: 0 !important;
  font-size: clamp(25px, 2.15vw, 34px) !important;
  line-height: 1.55 !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
  text-align: left !important;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45) !important;
}

#dialogueBox.dialogue-vn-box #nextButton.dialogue-next,
#dialogueBox.dialogue-vn-box .dialogue-next {
  position: absolute !important;
  right: clamp(22px, 2.4vw, 34px) !important;
  bottom: clamp(18px, 2vh, 28px) !important;
  left: auto !important;
  top: auto !important;
  width: 34px !important;
  min-width: 34px !important;
  max-width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  max-height: 34px !important;
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
  color: #f3c374 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-size: clamp(22px, 1.8vw, 30px) !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-indent: 0 !important;
  cursor: pointer !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.55)) !important;
  animation: dialogueNextBlink 1.15s ease-in-out infinite !important;
}

#dialogueBox.dialogue-vn-box #nextButton.dialogue-next:hover {
  transform: none !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.55)) brightness(1.08) !important;
}

#dialogueBox.dialogue-vn-box #nextButton.dialogue-next.hidden {
  display: none !important;
}

@keyframes dialogueNextBlink {
  0%, 100% {
    opacity: 0.45;
    transform: translateY(0);
  }
  50% {
    opacity: 1;
    transform: translateY(4px);
  }
}

@media (max-width: 900px) {
  #playScreen > #dialogueBox.dialogue-box.dialogue-vn-box,
  #dialogueBox.dialogue-vn-box {
    width: calc(100vw - 32px) !important;
    bottom: 18px !important;
    min-height: 132px !important;
    padding: 20px 24px !important;
  }

  #dialogueBox.dialogue-vn-box .dialogue-name,
  #dialogueBox.dialogue-vn-box #dialogueSpeaker {
    font-size: 22px !important;
  }

  #dialogueBox.dialogue-vn-box .dialogue-text,
  #dialogueBox.dialogue-vn-box #dialogueText {
    padding-right: 46px !important;
    font-size: 22px !important;
    line-height: 1.45 !important;
  }

  #dialogueBox.dialogue-vn-box #nextButton.dialogue-next,
  #dialogueBox.dialogue-vn-box .dialogue-next {
    right: 18px !important;
    bottom: 16px !important;
  }
}

/* Merged final build: calendar, profile VN dialogue, full-screen minigames, final hold. */
.calendar-button {
  position: absolute;
  top: clamp(18px, 3vw, 34px);
  right: clamp(18px, 3vw, 34px);
  z-index: 8;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 18px;
  color: #fffdf4;
  background: rgba(45, 28, 22, 0.44);
  border: 1.5px solid rgba(255, 246, 218, 0.7);
  border-radius: 999px;
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(8px);
  font-weight: 800;
  letter-spacing: 0;
  cursor: pointer;
}

.calendar-button-icon {
  width: 22px;
  height: 22px;
  display: inline-block;
  border: 2px solid currentColor;
  border-radius: 5px;
  position: relative;
}

.calendar-button-icon::before,
.calendar-button-icon::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  height: 2px;
  background: currentColor;
}

.calendar-button-icon::before {
  top: 5px;
}

.calendar-button-icon::after {
  bottom: 5px;
}

.calendar-modal[hidden] {
  display: none !important;
}

.calendar-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: clamp(18px, 4vw, 42px);
}

.calendar-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(19, 13, 10, 0.56);
  backdrop-filter: blur(5px);
}

.calendar-popup {
  position: relative;
  z-index: 1;
  width: min(92vw, 680px);
  padding: clamp(24px, 3vw, 34px);
  color: #3b251e;
  background: linear-gradient(180deg, rgba(255, 250, 235, 0.98), rgba(255, 239, 210, 0.98));
  border: 2px solid rgba(160, 92, 62, 0.25);
  border-radius: 24px;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
}

.calendar-close-button {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 50%;
  color: #7a342e;
  background: rgba(255, 255, 255, 0.72);
  font-size: 26px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
}

.calendar-popup-head span {
  display: block;
  color: #b45a44;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0;
}

.calendar-popup-head h2 {
  margin: 4px 0 20px;
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.1;
  letter-spacing: 0;
}

.calendar-weekdays,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.calendar-weekdays span {
  text-align: center;
  color: #8f5c46;
  font-size: 15px;
  font-weight: 900;
}

.calendar-grid {
  margin-top: 10px;
}

.calendar-grid button,
.calendar-grid > span {
  min-height: clamp(50px, 8vw, 68px);
  border: 0;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.52);
  color: #4a2d22;
  font: inherit;
  font-size: clamp(18px, 2.3vw, 24px);
  font-weight: 800;
  letter-spacing: 0;
}

.calendar-grid button {
  position: relative;
  cursor: default;
}

.calendar-grid .birthday-day {
  color: #c4312f;
  background: rgba(255, 240, 228, 0.9);
}

.calendar-grid .birthday-day::before {
  content: "";
  position: absolute;
  inset: 7px 6px 9px;
  border: 4px solid rgba(217, 34, 36, 0.84);
  border-radius: 50%;
  transform: rotate(-7deg);
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.5));
}

.calendar-grid .birthday-day strong {
  display: block;
  position: relative;
  z-index: 1;
  margin-top: 1px;
  font-size: clamp(8px, 0.9vw, 11px);
  font-weight: 900;
  color: #9f242a;
  letter-spacing: 0;
  line-height: 1.05;
  white-space: nowrap;
}

.calendar-grid .birthday-day span {
  position: relative;
  z-index: 1;
}

#playScreen > #dialogueBox.dialogue-box.dialogue-vn-box.vn-dialogue-box,
#dialogueBox.dialogue-vn-box.vn-dialogue-box {
  width: min(88vw, 1260px) !important;
  min-height: clamp(158px, 20vh, 228px) !important;
  padding: clamp(18px, 2.2vw, 28px) clamp(26px, 3vw, 42px) !important;
}

#dialogueBox.dialogue-vn-box .vn-dialogue-inner {
  display: grid !important;
  grid-template-columns: clamp(82px, 8vw, 116px) minmax(0, 1fr);
  gap: clamp(18px, 2.1vw, 28px);
  align-items: center;
  min-height: 100%;
}

#dialogueBox.dialogue-vn-box .vn-speaker-portrait-wrap,
#dialogueBox.dialogue-vn-box #dialogueProfileWrap.vn-speaker-portrait-wrap {
  display: block !important;
  width: clamp(82px, 8vw, 116px) !important;
  height: clamp(82px, 8vw, 116px) !important;
  padding: 4px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(242, 196, 111, 0.96), rgba(255, 255, 255, 0.38));
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
}

#dialogueBox.dialogue-vn-box .vn-speaker-portrait-wrap.hidden,
#dialogueBox.dialogue-vn-box #dialogueProfileWrap.vn-speaker-portrait-wrap.hidden {
  display: none !important;
}

#dialogueBox.dialogue-vn-box .vn-speaker-portrait,
#dialogueBox.dialogue-vn-box #dialogueProfile.vn-speaker-portrait {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 14px !important;
}

#dialogueBox.dialogue-vn-box .vn-dialogue-content {
  min-width: 0;
  display: block !important;
}

#dialogueBox.dialogue-vn-box .vn-speaker-name,
#dialogueBox.dialogue-vn-box #dialogueSpeaker.vn-speaker-name {
  margin-bottom: clamp(8px, 1vh, 12px) !important;
}

#dialogueBox.dialogue-vn-box .vn-dialogue-text,
#dialogueBox.dialogue-vn-box #dialogueText.vn-dialogue-text {
  padding-right: 56px !important;
}

#dialogueBox.dialogue-vn-box .vn-dialogue-next,
#dialogueBox.dialogue-vn-box #nextButton.vn-dialogue-next {
  right: clamp(22px, 2.4vw, 36px) !important;
  bottom: clamp(16px, 1.9vh, 26px) !important;
}

.play-screen.hidden-game-active #dialogueBox {
  display: none !important;
}

.play-screen:not(.hidden-game-active):not(.final-hold-screen) .action-dock {
  bottom: clamp(258px, 30vh, 340px) !important;
  z-index: 70 !important;
}

.minigame-overlay.minigame-panel {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1000 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0 !important;
  padding: clamp(14px, 2vw, 30px) !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  background: rgba(0, 0, 0, 0.48) !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

.minigame-overlay.minigame-panel.hidden {
  display: none !important;
}

.minigame-content {
  position: relative;
  width: min(96vw, 1720px);
  height: min(92vh, 1040px);
  box-sizing: border-box;
  overflow: hidden;
  border-radius: clamp(18px, 2vw, 34px);
  border: 3px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 248, 235, 0.96);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
}

.minigame-frame-image {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.minigame-profile {
  position: absolute;
  z-index: 2;
  object-fit: cover;
  border-radius: 50%;
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.28);
}

.quiz-frame-profile {
  left: 8.2%;
  top: 11.2%;
  width: clamp(82px, 9vw, 150px);
  height: clamp(82px, 9vw, 150px);
}

.garam-frame-profile {
  left: 8%;
  top: 22%;
  width: clamp(120px, 16vw, 260px);
  height: clamp(120px, 16vw, 260px);
}

.quiz-content .quiz-art-card,
.questions-content .questions-art-card {
  position: absolute !important;
  z-index: 1;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  gap: clamp(18px, 2vw, 32px);
  padding: clamp(24px, 3vw, 52px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #3e2a20;
}

.quiz-content .quiz-art-card {
  left: 25%;
  right: 8%;
  top: 14%;
  bottom: 10%;
}

.questions-content .questions-art-card {
  left: 42%;
  right: 10%;
  top: 15%;
  bottom: 11%;
  width: auto !important;
  transform: none !important;
  justify-content: flex-start;
  padding: clamp(16px, 1.8vw, 28px) !important;
}

.minigame-frame-hint {
  margin: 0;
  color: #6e4a38;
  font-size: clamp(18px, 1.5vw, 24px);
  font-weight: 800;
  text-align: center;
  letter-spacing: 0;
}

.quiz-content .initial-card {
  min-height: clamp(110px, 14vh, 180px);
  display: grid;
  place-items: center;
  font-size: clamp(54px, 7vw, 120px);
  border-radius: 22px;
}

.quiz-content .choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(12px, 1.5vw, 24px);
}

.quiz-content .choice-button,
.questions-content .answer-button {
  min-height: clamp(58px, 6vh, 82px);
  font-size: clamp(20px, 2vw, 32px);
}

.questions-content .question-stack {
  gap: clamp(12px, 1.25vw, 20px);
}

.questions-content .illustrated-title {
  margin-bottom: clamp(4px, 0.8vw, 10px);
}

.questions-content .question-row {
  padding: clamp(10px, 1.2vw, 16px);
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(157, 109, 70, 0.18);
  border-radius: 16px;
}

.questions-content .question-row label {
  font-size: clamp(16px, 1.25vw, 22px);
}

.questions-content .question-row input {
  min-height: clamp(42px, 4.4vh, 58px);
  font-size: clamp(17px, 1.35vw, 23px);
}

.hidden-picture-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: clamp(10px, 1.5vw, 20px);
  padding: clamp(14px, 2vw, 28px);
}

.hidden-picture-panel .hidden-game-head {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
}

.hidden-picture-panel .hidden-image-stage {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.72);
}

.hidden-picture-panel .hidden-image-stage > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.hidden-picture-panel .hidden-clear {
  position: absolute;
  inset: 0;
  z-index: 5;
}

.play-screen.final-hold-screen .hud,
.play-screen.final-hold-screen .quest-card,
.play-screen.final-hold-screen .dialogue-box,
.play-screen.final-hold-screen .action-dock,
.play-screen.final-hold-screen .presentation-caption {
  display: none !important;
}

.play-screen.final-hold-screen .presentation-art {
  inset: 0 !important;
}

.play-screen.final-hold-screen .presentation-illustration {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

@media (max-width: 900px) {
  .calendar-button {
    top: 12px;
    right: 12px;
    min-height: 42px;
    padding: 0 14px;
  }

  #playScreen > #dialogueBox.dialogue-box.dialogue-vn-box.vn-dialogue-box,
  #dialogueBox.dialogue-vn-box.vn-dialogue-box {
    width: calc(100vw - 24px) !important;
    min-height: 132px !important;
    padding: 16px 18px !important;
  }

  #dialogueBox.dialogue-vn-box .vn-dialogue-inner {
    grid-template-columns: 68px minmax(0, 1fr);
    gap: 14px;
  }

  #dialogueBox.dialogue-vn-box .vn-speaker-portrait-wrap,
  #dialogueBox.dialogue-vn-box #dialogueProfileWrap.vn-speaker-portrait-wrap {
    width: 68px !important;
    height: 68px !important;
    border-radius: 15px;
  }

  #dialogueBox.dialogue-vn-box .vn-speaker-portrait,
  #dialogueBox.dialogue-vn-box #dialogueProfile.vn-speaker-portrait {
    border-radius: 11px !important;
  }

  .minigame-overlay.minigame-panel {
    padding: 10px !important;
  }

  .minigame-content {
    width: calc(100vw - 20px);
    height: calc(100vh - 20px);
    border-radius: 18px;
  }

  .quiz-content .quiz-art-card,
  .questions-content .questions-art-card {
    left: 8%;
    right: 8%;
    top: 18%;
    bottom: 8%;
    padding: 18px !important;
  }

  .quiz-frame-profile,
  .garam-frame-profile {
    left: 50%;
    top: 7%;
    width: 86px;
    height: 86px;
    transform: translateX(-50%);
  }

  .quiz-content .choice-grid {
    grid-template-columns: 1fr;
  }

  .hidden-picture-panel {
    padding: 10px;
  }
}

/* Browser review fixes: image-hotspot calendar, dock placement, and frame-native Haein quiz. */
.start-screen.full-image-title .calendar-button {
  top: 2.2% !important;
  right: 17.65% !important;
  z-index: 12 !important;
  width: clamp(38px, 4.1vw, 52px) !important;
  height: clamp(38px, 4.1vw, 52px) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
  color: transparent !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 50% !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
}

.start-screen.full-image-title .calendar-button > * {
  opacity: 0 !important;
}

.start-screen.full-image-title .calendar-button:hover,
.start-screen.full-image-title .calendar-button:focus-visible {
  outline: 2px solid rgba(255, 245, 215, 0.86);
  outline-offset: 3px;
}

.calendar-grid .birthday-day {
  overflow: visible !important;
  background:
    radial-gradient(circle at 50% 38%, rgba(255, 231, 235, 0.98), rgba(255, 240, 228, 0.92)) !important;
  box-shadow:
    0 8px 18px rgba(184, 48, 54, 0.16),
    inset 0 0 0 2px rgba(255, 255, 255, 0.46) !important;
}

.calendar-grid .birthday-day::before {
  inset: 8px 13px 20px !important;
  border-width: 5px !important;
  border-color: rgba(224, 38, 48, 0.9) !important;
  transform: rotate(-9deg) scaleX(1.16) !important;
}

.calendar-grid .birthday-day span {
  display: block !important;
  transform: translateY(-8px);
  color: #c4312f;
  font-size: clamp(20px, 2.45vw, 28px);
  font-weight: 1000;
}

.calendar-grid .birthday-day strong {
  position: absolute !important;
  left: 50%;
  bottom: 5px;
  width: max-content;
  margin: 0 !important;
  padding: 2px 8px;
  transform: translateX(-50%);
  color: #a91f28 !important;
  background: rgba(255, 250, 238, 0.96);
  border: 1px solid rgba(222, 78, 78, 0.22);
  border-radius: 999px;
  font-size: clamp(11px, 1.22vw, 15px) !important;
  line-height: 1.05 !important;
  box-shadow: 0 3px 10px rgba(121, 48, 40, 0.12);
}

.play-screen:not(.hidden-game-active):not(.final-hold-screen) .action-dock {
  right: clamp(18px, 2.2vw, 30px) !important;
  bottom: clamp(78px, 8vh, 112px) !important;
  z-index: 72 !important;
}

.minigame-frame-mode .minigame-content.frame-backed {
  width: min(96vw, 1720px, calc(92vh * 1.599)) !important;
  height: auto !important;
  aspect-ratio: 1586 / 992;
}

.minigame-frame-mode .minigame-content.frame-backed .minigame-frame-image {
  object-fit: cover !important;
}

.quiz-content .quiz-art-card {
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  display: block !important;
  padding: 0 !important;
  color: #2d2336;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
  pointer-events: none;
}

.quiz-content .quiz-art-card .minigame-title {
  position: absolute;
  left: 31.5%;
  top: 8.2%;
  width: 42.5%;
  min-height: 12%;
  margin: 0 !important;
  display: grid !important;
  place-items: center;
  text-align: center;
  pointer-events: none;
}

.quiz-content .quiz-art-card .minigame-title > div {
  display: grid;
  gap: clamp(6px, 0.7vw, 11px);
  justify-items: center;
}

.quiz-content .quiz-art-card .minigame-title span {
  min-height: 0;
  padding: clamp(5px, 0.55vw, 8px) clamp(12px, 1.1vw, 18px);
  color: #fffaf0;
  background: linear-gradient(135deg, #c85f72, #ef8770);
  border: 1px solid rgba(255, 242, 221, 0.68);
  border-radius: 999px;
  font-size: clamp(13px, 1.05vw, 18px);
  line-height: 1;
  box-shadow: 0 8px 18px rgba(150, 62, 73, 0.22);
}

.quiz-content .quiz-art-card .minigame-title strong {
  margin: 0;
  color: #2c2342;
  font-size: clamp(25px, 2.15vw, 40px);
  line-height: 1.14;
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.72);
}

.quiz-content .initial-card {
  position: absolute;
  left: 30.6%;
  top: 26.6%;
  width: 44.4%;
  height: 14.4%;
  min-height: 0 !important;
  margin: 0 !important;
  display: grid;
  place-items: center;
  color: #d45567;
  background: rgba(255, 252, 241, 0.58) !important;
  border: 0 !important;
  border-radius: 26px !important;
  box-shadow: none !important;
  font-size: clamp(64px, 8vw, 132px) !important;
  line-height: 1;
  text-shadow:
    0 4px 0 rgba(255, 255, 255, 0.72),
    0 12px 28px rgba(142, 61, 70, 0.24);
  pointer-events: auto;
}

.quiz-content .initial-card::before,
.quiz-content .initial-card::after {
  content: none !important;
}

.quiz-content .choice-grid {
  position: absolute;
  left: 15%;
  top: 48.3%;
  width: 62.5%;
  height: 20.6%;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2.8%;
  pointer-events: auto;
}

.quiz-content .choice-button {
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  padding: 0;
  color: #35233d;
  background: transparent !important;
  border: 0 !important;
  border-radius: 24px !important;
  box-shadow: none !important;
  font-size: clamp(22px, 2.6vw, 46px) !important;
  line-height: 1.05;
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.76);
}

.quiz-content .choice-button:hover,
.quiz-content .choice-button:focus-visible {
  background: rgba(255, 255, 255, 0.22) !important;
  box-shadow: inset 0 0 0 3px rgba(215, 154, 83, 0.55) !important;
}

.quiz-content .minigame-frame-hint {
  position: absolute;
  left: 19.5%;
  bottom: 8.1%;
  width: 67.5%;
  margin: 0 !important;
  color: #7a5541;
  font-size: clamp(20px, 1.8vw, 32px);
  line-height: 1.28;
  font-weight: 900;
  text-align: center;
  pointer-events: none;
}

.quiz-frame-profile {
  left: 6.15% !important;
  top: 74.2% !important;
  width: 10.8% !important;
  height: 17.25% !important;
  transform: none !important;
  border: 3px solid rgba(255, 232, 183, 0.82);
  box-shadow: 0 12px 28px rgba(57, 26, 40, 0.28);
}

@media (max-width: 900px) {
  .start-screen.full-image-title .calendar-button {
    top: 2.2% !important;
    right: 17.65% !important;
    width: clamp(32px, 4.1vw, 44px) !important;
    height: clamp(32px, 4.1vw, 44px) !important;
  }

  .play-screen:not(.hidden-game-active):not(.final-hold-screen) .action-dock {
    right: 12px !important;
    bottom: clamp(70px, 11vh, 104px) !important;
  }

  .minigame-frame-mode .minigame-content.frame-backed {
    width: min(calc(100vw - 20px), calc((100vh - 20px) * 1.599)) !important;
  }

  .quiz-content .quiz-art-card .minigame-title strong {
    font-size: clamp(19px, 3.8vw, 30px);
  }

  .quiz-content .initial-card {
    font-size: clamp(46px, 11vw, 86px) !important;
  }

  .quiz-content .choice-button {
    font-size: clamp(16px, 4.2vw, 28px) !important;
  }

  .quiz-content .minigame-frame-hint {
    font-size: clamp(14px, 3.6vw, 22px);
  }
}

/* Hidden-picture rollback: keep Hobum's game in the earlier centered card layout. */
.minigame-panel.hidden-image-panel {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: min(760px, calc(100% - 48px)) !important;
  height: min(700px, calc(100% - 88px)) !important;
  transform: translate(-50%, -50%) !important;
  display: grid !important;
  grid-template-columns: minmax(150px, 188px) minmax(0, auto) !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 12px !important;
  padding: 10px !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  border: 3px solid rgba(255, 255, 255, 0.74) !important;
  background:
    linear-gradient(180deg, rgba(255, 252, 244, 0.96), rgba(251, 239, 218, 0.92)),
    rgba(255, 248, 235, 0.94) !important;
  box-shadow:
    0 30px 90px rgba(18, 10, 28, 0.42),
    inset 0 0 0 2px rgba(255, 209, 102, 0.28),
    inset 0 -7px 0 rgba(69, 45, 71, 0.1) !important;
}

.minigame-panel.hidden-image-panel .hidden-image-stage {
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: auto !important;
  height: 100% !important;
  aspect-ratio: 864 / 1821 !important;
  margin: 0 auto !important;
  display: block !important;
  align-self: stretch !important;
}

.minigame-panel.hidden-image-panel .hidden-image-stage > img {
  width: 100% !important;
  height: 100% !important;
  object-fit: fill !important;
}

.minigame-panel.hidden-image-panel .hidden-game-head {
  position: absolute !important;
  z-index: 2 !important;
  left: clamp(34px, 5.2vw, 64px) !important;
  top: clamp(28px, 4.2vh, 44px) !important;
  width: min(248px, calc(100% - 400px)) !important;
  padding: 0 !important;
  gap: 12px !important;
}

.minigame-panel.hidden-image-panel .hidden-game-head strong {
  white-space: nowrap !important;
}

.minigame-panel.hidden-image-panel .hidden-game-head p {
  width: 100% !important;
  max-width: none !important;
}

@media (max-width: 900px) {
  .minigame-panel.hidden-image-panel {
    width: calc(100% - 24px) !important;
    height: min(680px, calc(100% - 40px)) !important;
    grid-template-columns: minmax(112px, 150px) minmax(0, auto) !important;
  }

.minigame-panel.hidden-image-panel .hidden-game-head {
    left: 18px !important;
    top: 24px !important;
    width: min(190px, 34vw) !important;
  }
}

/* Start screen uses the baked-in title image only; keep only invisible click hotspots. */
.start-screen .start-panel .eyebrow,
.start-screen .start-panel h1,
.start-screen .start-panel p,
.start-screen .calendar-button > * {
  display: none !important;
}

.start-screen .calendar-button,
.start-screen.full-image-title .calendar-button,
.start-screen .calendar-button:hover,
.start-screen .calendar-button:focus-visible,
.start-screen.full-image-title .calendar-button:hover,
.start-screen.full-image-title .calendar-button:focus-visible {
  color: transparent !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.start-screen .start-buttons .primary,
.start-screen.full-image-title .start-buttons .primary {
  color: transparent !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  opacity: 0 !important;
  text-shadow: none !important;
}

/* 2026-05-05 final spec: frame-native quiz/question layouts and automatic ending message. */
.quiz-content .quiz-art-card .minigame-title {
  left: 31.4% !important;
  top: 22.4% !important;
  width: 45.4% !important;
  min-height: 7.4% !important;
  align-items: center !important;
}

.quiz-content .quiz-art-card .minigame-title > div {
  gap: 5px !important;
}

.quiz-content .quiz-art-card .minigame-title span {
  padding: 4px 13px !important;
  font-size: clamp(12px, 0.92vw, 16px) !important;
}

.quiz-content .quiz-art-card .minigame-title strong {
  max-width: 100%;
  font-size: clamp(24px, 2vw, 36px) !important;
  line-height: 1.06 !important;
}

.quiz-content .initial-card {
  left: 31.6% !important;
  top: 30.7% !important;
  width: 44.6% !important;
  height: 11.2% !important;
  background: transparent !important;
  color: #d05263 !important;
  font-size: clamp(58px, 7.2vw, 118px) !important;
}

.quiz-content .choice-grid {
  left: 15.4% !important;
  top: 51.2% !important;
  width: 62.7% !important;
  height: 18.6% !important;
  gap: 3.3% !important;
}

.quiz-content .choice-button {
  display: grid !important;
  place-items: center !important;
  border-radius: 30px !important;
}

.quiz-content .choice-button span {
  display: grid;
  place-items: center;
  width: 72%;
  min-width: 0;
  max-width: 100%;
  color: #3a2b3f;
  overflow-wrap: anywhere;
}

.quiz-content .minigame-frame-hint {
  display: none !important;
}

.questions-content .garam-frame-profile {
  display: none !important;
}

.questions-content .questions-art-card {
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  display: block !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
  pointer-events: none;
}

.questions-content .illustrated-title {
  display: none !important;
}

.questions-content .illustrated-title span {
  color: #9e4454;
  font-size: clamp(13px, 1vw, 17px);
  font-weight: 900;
}

.questions-content .illustrated-title strong {
  color: #3a2a31;
  font-size: clamp(21px, 1.7vw, 32px) !important;
  line-height: 1.1;
}

.questions-content .question-stack {
  position: absolute !important;
  left: 42.4% !important;
  top: 14.2% !important;
  width: 39.3% !important;
  height: 63.2% !important;
  display: grid !important;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 4.9% !important;
  pointer-events: auto;
}

.questions-content .question-row {
  min-height: 0 !important;
  padding: 0 5.5% 0 14.2% !important;
  display: grid !important;
  grid-template-rows: auto minmax(34px, 42%);
  align-content: center;
  gap: clamp(5px, 0.58vw, 9px);
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.questions-content .question-row label {
  display: block !important;
  color: #5a372f !important;
  font-size: clamp(13px, 1.05vw, 18px) !important;
  font-weight: 900;
  line-height: 1.18;
}

.questions-content .question-row label::before {
  content: none !important;
}

.questions-content .question-row input {
  min-height: 0 !important;
  height: 100%;
  padding: 0 clamp(11px, 1vw, 16px);
  color: #3f2b34;
  background: rgba(255, 255, 255, 0.62) !important;
  border: 2px solid rgba(196, 146, 83, 0.32) !important;
  border-radius: 14px !important;
  font-size: clamp(15px, 1.14vw, 20px) !important;
}

.questions-content .answer-button {
  position: absolute !important;
  left: 28.6% !important;
  bottom: 7.7% !important;
  width: 33.8% !important;
  min-height: 0 !important;
  height: 7.1% !important;
  padding: 0 !important;
  border-radius: 18px !important;
  pointer-events: auto;
}

.questions-content .minigame-frame-hint {
  position: absolute !important;
  left: 18.8% !important;
  bottom: 16.4% !important;
  width: 53% !important;
  color: #6d4938 !important;
  font-size: clamp(15px, 1.18vw, 22px) !important;
  line-height: 1.18;
}

@media (max-width: 900px) {
  .questions-content .question-row label {
    font-size: clamp(11px, 2.4vw, 15px) !important;
  }

  .questions-content .question-row input {
    font-size: clamp(12px, 2.7vw, 16px) !important;
  }

  .questions-content .answer-button {
    font-size: clamp(15px, 3.4vw, 22px) !important;
  }
}

/* Final V2 override must stay last: Haein/Garam frame text alignment. */
.minigame-frame-mode .minigame-content.frame-backed {
  container-type: size;
}

.quiz-content .haein-quiz-initial {
  left: 29.45% !important;
  top: 28.85% !important;
  width: 45.4% !important;
  height: 12.1% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  color: #d35265 !important;
  background: transparent !important;
  font-size: clamp(54px, 6.6cqw, 104px) !important;
  line-height: 1 !important;
  font-weight: 1000 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  transform: translateY(-1%) !important;
}

.quiz-content .haein-quiz-initial.is-medium {
  font-size: clamp(48px, 5.8cqw, 92px) !important;
}

.quiz-content .haein-quiz-initial.is-long {
  font-size: clamp(40px, 4.9cqw, 78px) !important;
}

.quiz-content .haein-quiz-options {
  left: 15.2% !important;
  top: 45.6% !important;
  width: 62.2% !important;
  height: 22.7% !important;
  gap: 3.25% !important;
}

.quiz-content .haein-quiz-option {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.quiz-content .haein-quiz-option-label {
  position: absolute !important;
  left: 50% !important;
  top: 48.7% !important;
  width: 52% !important;
  height: 58% !important;
  transform: translate(-50%, -50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  color: #30263d !important;
  font-size: clamp(22px, 2.38cqw, 38px) !important;
  line-height: 1 !important;
  font-weight: 1000 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  pointer-events: none;
}

.quiz-content .haein-quiz-option.is-medium .haein-quiz-option-label {
  width: 58% !important;
  font-size: clamp(17px, 1.82cqw, 29px) !important;
}

.quiz-content .haein-quiz-option.is-long .haein-quiz-option-label {
  width: 66% !important;
  font-size: clamp(13px, 1.42cqw, 23px) !important;
}

.questions-content .garam-frame-profile,
.questions-content .minigame-circular-profile,
.questions-content .circular-profile,
.questions-content .speaker-floating-profile {
  display: none !important;
}

.questions-content .garam-question-list {
  left: 42.7% !important;
  top: 15.2% !important;
  width: 39.5% !important;
  height: 58.8% !important;
  display: grid !important;
  grid-template-rows: repeat(3, minmax(0, 1fr)) !important;
  gap: 5.1% !important;
  pointer-events: auto;
}

.questions-content .garam-question-item {
  min-height: 0 !important;
  padding: 1.5% 6.1% 1.8% 14.4% !important;
  display: grid !important;
  grid-template-rows: minmax(0, auto) minmax(34px, 39%) !important;
  align-content: center !important;
  gap: clamp(9px, 0.82cqw, 13px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.questions-content .garam-question-label {
  display: block !important;
  margin: 0 !important;
  color: #54362f !important;
  font-family: var(--font-ui) !important;
  font-size: clamp(16px, 1.42cqw, 24px) !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  word-break: keep-all !important;
}

.questions-content .garam-question-label.is-long {
  font-size: clamp(15px, 1.24cqw, 21px) !important;
  line-height: 1.13 !important;
}

.questions-content .garam-question-input {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  box-sizing: border-box !important;
  padding: 0 18px !important;
  color: #3f2d35 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  font-family: var(--font-ui) !important;
  font-size: clamp(15px, 1.28cqw, 22px) !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

.questions-content .garam-question-input.is-long-placeholder {
  font-size: clamp(14px, 1.12cqw, 19px) !important;
}

.questions-content .garam-question-input::placeholder {
  color: rgba(98, 82, 78, 0.72) !important;
  opacity: 1 !important;
}

.questions-content .question-row input.garam-question-input {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
}

.questions-content .garam-question-guide {
  left: 27.5% !important;
  bottom: 15.4% !important;
  width: 43.2% !important;
  margin: 0 !important;
  color: #6b4b3a !important;
  font-family: var(--font-ui) !important;
  font-size: clamp(15px, 1.38cqw, 24px) !important;
  line-height: 1.24 !important;
  font-weight: 800 !important;
  text-align: center !important;
  letter-spacing: 0 !important;
  pointer-events: none;
}

.questions-content .garam-question-submit {
  left: 33.6% !important;
  bottom: 7.2% !important;
  width: 31.8% !important;
  height: 7.4% !important;
  min-height: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 18px !important;
  font-family: var(--font-ui) !important;
  font-size: clamp(22px, 2.08cqw, 36px) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  pointer-events: auto;
}

/* Restart is removed globally; keep the old dock unavailable on every screen. */
.action-dock {
  display: none !important;
}

/* Keep the river ending quiet: no dimming pass or cinematic bars before the final hold. */
.world.presentation-mode .background.river-bg,
.background.river-bg {
  filter: saturate(1.06) contrast(1.03) brightness(1) !important;
}

.world.presentation-mode .scene-grade.river,
.world.visual-novel-mode .scene-grade.river,
.scene-grade.river {
  background: transparent !important;
}

.cinema-bars.show {
  opacity: 0 !important;
}
