/* === HANDMAIDEN theme — emerald + lacquered gold === */
body { font-family: 'Noto Serif JP', 'Noto Serif KR', 'Noto Serif SC', serif; background: #0a0e0a; }
body[data-screen="title-screen"] { filter: saturate(1.15) contrast(1.05); }
.title-poster { background: radial-gradient(ellipse at 50% 30%, rgba(200,151,56,0.16), transparent 65%); }
.title-line1, .title-line2 { color: #c89738 !important; font-family: 'Cormorant Garamond', 'Noto Serif JP', serif !important; font-weight: 700 !important; letter-spacing: 12px !important; text-shadow: 0 0 1px #c89738, 4px 4px 0 #2a4a3a, 12px 12px 50px rgba(200,151,56,0.5) !important; }
.kanji-bg { color: #c89738 !important; opacity: 0.18 !important; font-family: 'Noto Serif JP', serif !important; font-size: 360px !important; }
.title-tag, .route-tag { color: #c89738 !important; letter-spacing: 8px !important; font-family: 'Cormorant Garamond', serif !important; font-style: italic !important; }
.title-quote { color: #a07028 !important; font-family: 'Noto Serif JP', serif !important; font-style: italic; letter-spacing: 2px !important; }
.title-foot { color: #c89738 !important; font-family: 'Cormorant Garamond', serif !important; }
.menu-btn { border: 1px solid #c89738 !important; color: #c89738 !important; font-family: 'Cormorant Garamond', serif !important; letter-spacing: 6px !important; font-style: italic !important; }
.menu-btn:hover { background: #c89738 !important; color: #1a1a14 !important; box-shadow: 0 0 30px rgba(200,151,56,0.5) !important; }
.route-card { border: 1px solid #2a4a3a !important; background: linear-gradient(135deg, rgba(42,74,58,0.22), rgba(10,14,10,0.98)) !important; }
.route-card:hover { box-shadow: 0 0 50px rgba(200,151,56,0.45) !important; border-color: #c89738 !important; }
#speaker-name { color: #c89738 !important; font-family: 'Noto Serif JP', serif !important; }
.choice-btn { border-color: #c89738 !important; color: #c89738 !important; font-family: 'Cormorant Garamond', serif !important; font-style: italic !important; letter-spacing: 2px !important; }
.choice-btn:hover { background: #c89738 !important; color: #1a1a14 !important; }
#dialogue-box { border-top: 1px solid rgba(200,151,56,0.40) !important; }
.letterbox.top, .letterbox.bottom { background: #0a0e0a !important; }


/* === AUTO-INJECTED bg/cg CSS RULES (do not edit by hand) === */
#bg-layer.bg-asylum { --bg-img: url('assets/bg/bg-asylum.png'); --bg-tint: radial-gradient(circle at 50% 30%,rgba(140,140,80,0.15) 0%,transparent 50%),linear-gradient(180deg,rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.8) 100%); }
#bg-layer.bg-basement { --bg-img: url('assets/bg/bg-basement.png'); --bg-tint: radial-gradient(circle at 50% 30%,rgba(140,140,80,0.15) 0%,transparent 50%),linear-gradient(180deg,rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.8) 100%); }
#bg-layer.bg-boat { --bg-img: url('assets/bg/bg-boat.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-cherry { --bg-img: url('assets/bg/bg-cherry.png'); --bg-tint: radial-gradient(ellipse at 50% 40%,rgba(120,180,120,0.18) 0%,transparent 55%),linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-library { --bg-img: url('assets/bg/bg-library.png'); --bg-tint: radial-gradient(ellipse at 50% 40%,rgba(220,180,100,0.15) 0%,transparent 55%),linear-gradient(180deg,rgba(20,15,5,0.18) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-mansion { --bg-img: url('assets/bg/bg-mansion.png'); --bg-tint: radial-gradient(ellipse at 50% 30%,rgba(120,160,200,0.15) 0%,transparent 55%),linear-gradient(180deg,rgba(10,15,25,0.2) 0%,rgba(0,0,0,0.55) 100%); }
#bg-layer { background: var(--bg-tint, none), var(--bg-img, none) center/cover no-repeat; }
/* === END AUTO-INJECTED === */

/* === TITLE SCREEN BG IMAGE (auto) === */
#title-screen {
  background-image: url('assets/title.png');
  background-size: cover;
  background-position: center;
  position: relative;
}
/* Darkening + vignette overlay so the title/buttons read clearly */
#title-screen::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse at 50% 55%, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.65) 60%, rgba(0,0,0,0.85) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.20) 30%, rgba(0,0,0,0.45) 75%, rgba(0,0,0,0.85) 100%);
}
/* Make sure all the actual content sits above the overlay */
#title-screen > * { position: relative; z-index: 1; }
/* === END TITLE BG === */
