/* === ENCANTO theme — vibrant Colombian palette === */
:root {
  --enc-yellow: #ffd24a;
  --enc-orange: #f08a3a;
  --enc-red:    #d8344e;
  --enc-pink:   #f06daf;
  --enc-purple: #6c3aa6;
  --enc-green:  #3aa66c;
  --enc-cream:  #fff3d6;
}

body {
  font-family: 'Bebas Neue', 'Noto Sans SC', 'Noto Serif SC', sans-serif;
  background: linear-gradient(135deg, #2a0a1a 0%, #4a1a2a 40%, #2a1a3a 100%);
}

/* Title screen — vibrant warm Colombian feel */
#title-screen { background: linear-gradient(135deg, var(--enc-purple) 0%, var(--enc-red) 50%, var(--enc-orange) 100%) !important; }
#title-screen::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(circle at 18% 26%, rgba(255,210,74,0.30) 0%, transparent 22%),
    radial-gradient(circle at 78% 78%, rgba(240,109,175,0.30) 0%, transparent 26%),
    radial-gradient(circle at 90% 14%, rgba(58,166,108,0.22) 0%, transparent 22%);
  z-index: 0;
}

.title-line1, .title-line2 {
  color: var(--enc-yellow) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 14px !important;
  text-shadow:
    0 0 1px var(--enc-yellow),
    4px 4px 0 var(--enc-red),
    8px 8px 0 var(--enc-purple),
    12px 12px 30px rgba(255,210,74,0.5) !important;
}
.kanji-bg { color: var(--enc-yellow) !important; opacity: 0.18 !important; font-size: 380px !important; transform: translate(-50%,-50%) rotate(-12deg) !important; }
.title-tag, .title-foot { color: var(--enc-yellow) !important; font-family: 'Bebas Neue', sans-serif !important; letter-spacing: 6px !important; }
.title-quote { color: var(--enc-cream) !important; font-style: italic !important; }
.title-starring-label { font-family: 'Bebas Neue', sans-serif !important; letter-spacing: 6px !important; color: var(--enc-cream) !important; }

.menu-btn {
  border: 2px solid var(--enc-yellow) !important;
  color: var(--enc-yellow) !important;
  background: rgba(45,15,35,0.6) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 4px !important;
  font-size: 1.1em !important;
}
.menu-btn:hover {
  background: var(--enc-yellow) !important;
  color: var(--enc-purple) !important;
  box-shadow: 0 0 28px rgba(255,210,74,0.6) !important;
}

/* Route screen — 12 colourful doors */
.route-card {
  border: 3px solid var(--enc-yellow) !important;
  background: linear-gradient(135deg, var(--c1, var(--enc-purple)) 0%, var(--c2, var(--enc-red)) 100%) !important;
  border-radius: 18px !important;
}
.route-card:hover { box-shadow: 0 0 50px rgba(255,210,74,0.5) !important; transform: translateY(-6px) !important; }
.route-card[data-route="mirabel"] { --c1: #6c3aa6; --c2: #d8344e; }
.route-card[data-route="pepa"]    { --c1: #4a90c4; --c2: #f0d050; }
.route-card[data-route="julieta"] { --c1: #d8344e; --c2: #f08a3a; }
.route-card[data-route="antonio"] { --c1: #3aa66c; --c2: #6cba80; }
.route-card[data-route="isabela"] { --c1: #f06daf; --c2: #ec70d4; }
.route-card[data-route="luisa"]   { --c1: #5c44b8; --c2: #b94c98; }
.route-card[data-route="camilo"]  { --c1: #f08a3a; --c2: #ffd24a; }
.route-card[data-route="dolores"] { --c1: #c44264; --c2: #f06daf; }
.route-card[data-route="agustin"] { --c1: #6c5494; --c2: #4c8870; }
.route-card[data-route="abuela"]  { --c1: #884a4a; --c2: #c46a4a; }
.route-card[data-route="bruno"]   { --c1: #2a4a6c; --c2: #4ca6c4; }
.route-card[data-route="casita"]  { --c1: #c44a3a; --c2: #f0d050; }
.route-card[data-route="reunion"] { --c1: #ffd24a; --c2: #f06daf; }
.route-num { color: white !important; font-size: 28px !important; }
.route-title { color: white !important; font-family: 'Bebas Neue', sans-serif !important; font-size: 22px !important; letter-spacing: 3px !important; }
.route-subtitle { color: rgba(255,255,255,0.85) !important; font-size: 12px !important; letter-spacing: 1.5px !important; }

/* Dialogue */
#dialogue-box { border-top: 3px solid var(--enc-yellow) !important; background: linear-gradient(180deg, rgba(45,15,35,0.95), rgba(15,5,15,0.99)) !important; }
#speaker-name { color: var(--enc-yellow) !important; font-family: 'Bebas Neue', sans-serif !important; }
#dialogue-text { font-size: 1.05em !important; }
#dialogue-text-sub { font-family: 'Comic Sans MS', 'Bebas Neue', sans-serif !important; color: rgba(255,242,200,0.85) !important; font-size: 0.95em !important; }

/* Vocab tag (clickable inline word) */
.vocab {
  display: inline-block; padding: 0 6px; margin: 0 2px;
  background: linear-gradient(180deg, var(--enc-yellow), var(--enc-orange));
  color: #2a0a1a; border-radius: 6px;
  cursor: pointer; font-weight: 700;
  border-bottom: 2px solid var(--enc-red);
  transition: transform .15s, box-shadow .15s;
}
.vocab:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(255,210,74,0.5); }
.vocab:active { transform: translateY(0); }

/* Vocab popup */
.vocab-popup {
  position: fixed; z-index: 9999; min-width: 220px; max-width: 340px;
  background: linear-gradient(135deg, var(--enc-purple), var(--enc-red));
  border: 2px solid var(--enc-yellow);
  border-radius: 14px; padding: 16px 18px;
  color: white; box-shadow: 0 14px 40px rgba(0,0,0,0.5);
  animation: vp-pop .2s ease-out;
}
@keyframes vp-pop { from { transform: scale(.85); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.vocab-popup .vocab-en { font-size: 26px; font-weight: 700; font-family: 'Bebas Neue', sans-serif; letter-spacing: 2px; color: var(--enc-yellow); }
.vocab-popup .vocab-zh { font-size: 20px; margin-top: 6px; font-family: 'Noto Serif SC', serif; }
.vocab-popup .vocab-tts { display: block; margin-top: 12px; padding: 8px 14px; background: var(--enc-yellow); color: var(--enc-purple); border: none; border-radius: 8px; cursor: pointer; font-weight: 700; letter-spacing: 2px; width: 100%; }
.vocab-popup .vocab-tts:hover { background: white; }
.vocab-popup .vocab-close { position: absolute; top: 4px; right: 8px; background: transparent; color: white; border: none; cursor: pointer; font-size: 20px; }

/* Per-line TTS button */
.line-tts {
  margin-left: 8px; padding: 2px 8px; font-size: 14px;
  background: rgba(255,210,74,0.2); color: var(--enc-yellow);
  border: 1px solid var(--enc-yellow); border-radius: 4px; cursor: pointer;
  vertical-align: middle;
}
.line-tts:hover { background: var(--enc-yellow); color: var(--enc-purple); }

/* Progress HUD */
#edu-progress {
  position: fixed; top: 20px; left: 20px; z-index: 100;
  display: flex; align-items: center; gap: 10px;
  background: rgba(45,15,35,0.88); color: white; padding: 8px 16px;
  border: 2px solid var(--enc-yellow); border-radius: 999px;
  font-family: 'Bebas Neue', sans-serif; font-size: 14px; letter-spacing: 1.5px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.3);
}
#edu-progress .p-icon { font-size: 16px; }
#edu-progress .p-words { color: var(--enc-yellow); font-weight: 700; margin: 0 4px; }
#edu-progress .p-stars { color: var(--enc-yellow); font-weight: 700; margin: 0 4px; }
#edu-progress .p-divider { color: rgba(255,210,74,0.4); }
#edu-progress .hud-btn {
  background: transparent; color: white; border: none; padding: 4px 8px;
  font-family: inherit; font-size: 14px; letter-spacing: 1.5px; cursor: pointer; border-radius: 6px;
  transition: background .15s;
}
#edu-progress .hud-btn:hover { background: rgba(255,210,74,0.25); }
#edu-progress .hud-toggle { background: rgba(255,210,74,0.15); border: 1px solid var(--enc-yellow); }
#edu-progress .hud-toggle:hover { background: var(--enc-yellow); color: var(--enc-purple); }

/* Subtitle/Translation toggle modes */
body[data-edu-mode="en-only"] #dialogue-text       { display: none; }
body[data-edu-mode="zh-only"] #dialogue-text-sub   { display: none; }
body[data-edu-mode="en-only"] #dialogue-text-sub   { font-size: 1.4em !important; color: var(--enc-cream) !important; }
body[data-edu-mode="zh-only"] #dialogue-text       { font-size: 1.4em !important; }

/* Quiz / Match / Spell overlays */
.edu-overlay {
  position: fixed; inset: 0; z-index: 5000;
  background: radial-gradient(circle at center, rgba(108,58,166,0.85), rgba(15,5,15,0.92));
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s ease-out;
}
.edu-overlay.show { opacity: 1; }
.edu-card {
  background: linear-gradient(135deg, white 0%, var(--enc-cream) 100%);
  color: var(--enc-purple);
  border: 4px solid var(--enc-yellow);
  border-radius: 24px;
  padding: 40px 50px; max-width: 720px; width: 90%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  animation: card-bounce .35s ease-out;
}
@keyframes card-bounce { from { transform: scale(.7); } to { transform: scale(1); } }
.edu-stars { font-size: 28px; color: var(--enc-yellow); text-align: center; letter-spacing: 6px; }
.edu-q { font-family: 'Bebas Neue', sans-serif; font-size: 32px; letter-spacing: 2px; text-align: center; margin: 20px 0 10px; color: var(--enc-purple); }
.edu-hint { font-size: 16px; color: var(--enc-orange); text-align: center; margin-bottom: 18px; }
.edu-opts { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 24px; }
.edu-opt {
  padding: 16px; font-size: 22px; font-family: 'Bebas Neue', sans-serif; letter-spacing: 2px;
  background: white; color: var(--enc-purple); border: 3px solid var(--enc-purple); border-radius: 14px;
  cursor: pointer; transition: all .2s;
}
.edu-opt:hover { background: var(--enc-yellow); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(108,58,166,0.3); }
.edu-opt.right { background: var(--enc-green); color: white; border-color: var(--enc-green); }
.edu-opt.wrong { background: var(--enc-red); color: white; border-color: var(--enc-red); opacity: 0.5; }

/* Match grid */
.edu-match-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px; }
.m-en, .m-zh {
  padding: 14px; font-size: 20px; font-family: 'Bebas Neue', 'Noto Serif SC', sans-serif;
  background: white; color: var(--enc-purple); border: 3px solid var(--enc-purple); border-radius: 14px;
  cursor: pointer; transition: all .2s;
}
.m-en:hover, .m-zh:hover { background: var(--enc-yellow); }
.m-en.picked { background: var(--enc-orange); color: white; border-color: var(--enc-orange); }
.m-en.matched, .m-zh.matched { background: var(--enc-green); color: white; border-color: var(--enc-green); pointer-events: none; }
.m-zh.wrong { animation: shake .4s; }
@keyframes shake { 0%,100%{transform:translateX(0);} 25%{transform:translateX(-8px);} 75%{transform:translateX(8px);} }
.edu-progress { text-align: center; margin-top: 18px; font-size: 22px; color: var(--enc-purple); font-family: 'Bebas Neue', sans-serif; letter-spacing: 4px; }

/* Spell overlay */
.edu-img { display: block; margin: 0 auto 20px; max-height: 200px; max-width: 60%; border-radius: 12px; }
.edu-blanks { font-size: 36px; letter-spacing: 12px; text-align: center; font-family: 'Courier Prime', monospace; color: var(--enc-purple); margin: 18px 0; min-height: 50px; }
.edu-blanks .ok  { color: var(--enc-green); }
.edu-blanks .bad { color: var(--enc-red); }
.edu-input { display: block; margin: 0 auto; padding: 12px 18px; width: 80%; font-size: 22px; font-family: 'Courier Prime', monospace; border: 3px solid var(--enc-purple); border-radius: 12px; text-align: center; letter-spacing: 8px; }
.edu-input.wrong { animation: shake .4s; }
.edu-btn-tts, .edu-btn-check { display: inline-block; margin: 16px 8px 0; padding: 10px 20px; font-family: 'Bebas Neue', sans-serif; letter-spacing: 2px; font-size: 18px; background: var(--enc-yellow); color: var(--enc-purple); border: none; border-radius: 10px; cursor: pointer; }
.edu-btn-check { background: var(--enc-green); color: white; }
.edu-btn-tts:hover, .edu-btn-check:hover { transform: translateY(-2px); }
.edu-overlay.correct .edu-card { animation: pulse-correct .6s; }
@keyframes pulse-correct { 0%,100%{transform:scale(1);} 50%{transform:scale(1.05);} }

/* === AUTO-INJECTED bg/cg CSS RULES (do not edit by hand) === */
#bg-layer.bg-bedroom { --bg-img: url('assets/bg/bg-bedroom.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-casita { --bg-img: url('assets/bg/bg-casita.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-garden { --bg-img: url('assets/bg/bg-garden.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-kitchen { --bg-img: url('assets/bg/bg-kitchen.png'); --bg-tint: radial-gradient(ellipse at 50% 50%,rgba(220,160,80,0.15) 0%,transparent 55%),linear-gradient(180deg,rgba(20,15,5,0.2) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-river { --bg-img: url('assets/bg/bg-river.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer.bg-tower { --bg-img: url('assets/bg/bg-tower.png'); --bg-tint: linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.5) 100%); }
#bg-layer { background: var(--bg-tint, none), var(--bg-img, none) center/cover no-repeat; }
/* === END AUTO-INJECTED === */
