/* =========================================================
   Eedula dEendjila : レトロモダン2D RPG調スタイル
   ========================================================= */
:root{
  --bg0:#1a1228;
  --bg1:#241a3a;
  --panel:#2b2140;
  --panel2:#352a52;
  --ink:#f4eefe;
  --ink-dim:#b9addb;
  --gold:#ffcb5b;
  --gold-d:#d99a2b;
  --blue:#5bc8ff;
  --pink:#ff8fb1;
  --green:#8fe388;
  --red:#ff6b6b;
  --border:#0d0918;
  --shadow:#0c0817;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(circle at 20% 10%, #2a1f44 0%, transparent 55%),
    radial-gradient(circle at 85% 90%, #3a2150 0%, transparent 55%),
    var(--bg0);
  background-attachment:fixed;
  color:var(--ink);
  font-family:'M PLUS Rounded 1c','DotGothic16',sans-serif;
  display:flex;align-items:safe center;justify-content:center;
  min-height:100vh;padding:14px;
  overflow-y:auto;
  -webkit-font-smoothing:none;
  image-rendering:pixelated;
}

/* スキャンライン風オーバーレイ */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;
  background:repeating-linear-gradient(transparent 0 2px, rgba(0,0,0,.04) 2px 4px);
  mix-blend-mode:multiply;
}

#game{width:100%;max-width:840px;margin:auto}

/* ---------- ウィンドウ枠（RPG調） ---------- */
.window{
  background:var(--panel);
  border:4px solid var(--border);
  border-radius:6px;
  box-shadow:0 0 0 4px var(--gold-d), 0 14px 0 0 var(--shadow), 0 18px 40px rgba(0,0,0,.6);
  position:relative;
  overflow:hidden;
}
.window::before{
  content:"";position:absolute;inset:4px;border:2px solid rgba(255,203,91,.25);
  border-radius:3px;pointer-events:none;
}

.pad{padding:22px}

/* ---------- タイトル画面 ---------- */
.title-screen{text-align:center;padding:40px 26px}
.pixel-title{
  font-family:'Press Start 2P',monospace;
  font-size:clamp(16px,4.4vw,30px);
  color:var(--gold);
  line-height:1.6;
  text-shadow:3px 3px 0 var(--gold-d), 6px 6px 0 var(--border);
  letter-spacing:1px;
  margin-bottom:8px;
}
.subtitle-jp{
  font-size:clamp(18px,4vw,26px);font-weight:800;color:var(--ink);
  margin:14px 0 4px;letter-spacing:2px;
}
.subtitle-en{color:var(--ink-dim);font-size:13px;letter-spacing:1px;margin-bottom:24px}
.flag-bar{height:8px;border-radius:4px;margin:18px auto;max-width:320px;
  background:linear-gradient(90deg,#003580 0 20%,#ffffff 20% 26%,#d21034 26% 46%,#009543 46% 66%,#ffffff 66% 72%,#003580 72% 100%);
  border:2px solid var(--border)}
.title-blurb{color:var(--ink-dim);font-size:13px;line-height:1.9;max-width:540px;margin:0 auto 26px}
.title-blurb b{color:var(--gold)}

/* ---------- ボタン ---------- */
.btn{
  font-family:'M PLUS Rounded 1c',sans-serif;font-weight:800;
  cursor:pointer;border:3px solid var(--border);border-radius:5px;
  padding:13px 26px;font-size:15px;letter-spacing:1px;
  background:var(--gold);color:#3a280a;
  box-shadow:0 5px 0 0 var(--gold-d), 0 8px 14px rgba(0,0,0,.4);
  transition:transform .07s, box-shadow .07s;
}
.btn:hover{transform:translateY(2px);box-shadow:0 3px 0 0 var(--gold-d),0 5px 10px rgba(0,0,0,.4)}
.btn:active{transform:translateY(5px);box-shadow:0 0 0 0 var(--gold-d)}
.btn.secondary{background:var(--panel2);color:var(--ink);box-shadow:0 5px 0 0 #1d1730,0 8px 14px rgba(0,0,0,.4)}
.btn.secondary:hover{box-shadow:0 3px 0 0 #1d1730,0 5px 10px rgba(0,0,0,.4)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}

/* ---------- HUD（進行バー） ---------- */
.hud{display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--bg1);border-bottom:4px solid var(--border);flex-wrap:wrap}
.hud .year-badge{
  font-family:'Press Start 2P',monospace;font-size:13px;color:var(--border);
  background:var(--gold);padding:7px 10px;border-radius:4px;border:2px solid var(--border)}
.hud .place{font-weight:800;font-size:14px}
.hud .place small{display:block;color:var(--ink-dim);font-weight:400;font-size:11px}
.hud .spacer{flex:1}
.progress-dots{display:flex;gap:5px}
.dot{width:11px;height:11px;border-radius:2px;background:var(--panel2);border:2px solid var(--border)}
.dot.done{background:var(--green)}
.dot.cur{background:var(--gold);box-shadow:0 0 8px var(--gold)}

/* ---------- シーン背景（ピクセルアート風グラデ） ---------- */
.stage{height:200px;position:relative;overflow:hidden;border-bottom:4px solid var(--border)}
.stage .scene-label{position:absolute;left:14px;bottom:10px;z-index:3;
  background:rgba(13,9,24,.78);padding:6px 12px;border-radius:4px;border:2px solid var(--gold-d);
  font-weight:800;font-size:14px}
.stage .scene-label small{color:var(--gold);display:block;font-size:11px;font-weight:400}
.sun{position:absolute;width:60px;height:60px;border-radius:50%;right:50px;top:30px;z-index:1}
.ground{position:absolute;left:0;right:0;bottom:0;height:60px;z-index:2}

/* キャラクタースプライト */
.sprite{position:absolute;bottom:42px;z-index:3;width:46px;height:70px;
  image-rendering:pixelated;animation:bob 1.6s ease-in-out infinite;transition:filter .2s,opacity .2s,transform .2s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.sprite .head{width:24px;height:24px;border-radius:6px;margin:0 auto;border:2px solid var(--border)}
.sprite .body{width:34px;height:38px;border-radius:8px 8px 4px 4px;margin:2px auto 0;border:2px solid var(--border)}
.sprite .nameplate{position:absolute;left:50%;transform:translateX(-50%);top:-16px;white-space:nowrap;
  font-size:10px;font-weight:800;color:#fff;background:rgba(13,9,24,.7);padding:1px 6px;border-radius:3px;
  border:1px solid var(--gold-d);opacity:0;transition:opacity .2s}
.sprite.active .nameplate{opacity:1}
.sprite.active{filter:drop-shadow(0 0 6px var(--gold));animation:bob 1.1s ease-in-out infinite}
.sprite.dim{opacity:.45;filter:grayscale(.5) brightness(.8);animation:none}
/* 場面の小見出し */
.beat-label{position:absolute;right:14px;top:10px;z-index:3;
  background:rgba(13,9,24,.72);color:var(--gold);padding:5px 11px;border-radius:4px;
  border:2px solid var(--gold-d);font-weight:800;font-size:12px}
.tap-hint .prog{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--gold);margin-right:8px}

/* ---------- 会話ボックス ---------- */
.dialogue-box{padding:18px 20px;min-height:140px}
.speaker{display:inline-block;font-weight:800;font-size:14px;padding:4px 12px;border-radius:4px 4px 0 0;
  border:2px solid var(--border);border-bottom:none;margin-bottom:-2px;position:relative;z-index:2}
.speaker small{font-weight:400;opacity:.8;font-size:11px;margin-left:6px}
.line-text{background:var(--bg1);border:2px solid var(--border);border-radius:0 6px 6px 6px;
  padding:16px 18px;font-size:16px;line-height:1.9;min-height:80px}
.line-text .cursor{color:var(--gold);animation:blink .8s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.tap-hint{text-align:right;color:var(--ink-dim);font-size:12px;margin-top:10px}
.tap-hint .key{display:inline-block;border:2px solid var(--ink-dim);border-radius:3px;padding:1px 7px;animation:nudge 1s ease-in-out infinite}
@keyframes nudge{50%{transform:translateX(4px)}}

/* ---------- 史実パネル ---------- */
.history-card{background:var(--panel2);border:3px solid var(--border);border-radius:6px;
  padding:18px;margin:0 0 4px}
.history-card .tag{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--blue);margin-bottom:10px;display:block}
.history-card h3{font-size:18px;color:var(--gold);margin-bottom:10px}
.history-card p{font-size:14px;line-height:1.95;color:var(--ink)}

/* ---------- レッスン（単語帳） ---------- */
.lesson{padding:20px}
.lesson h3{font-size:17px;color:var(--green);margin-bottom:6px}
.lesson .intro{color:var(--ink-dim);font-size:13px;line-height:1.8;margin-bottom:16px}
.vocab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.vocab{background:var(--bg1);border:3px solid var(--border);border-radius:6px;padding:12px 14px;
  cursor:pointer;transition:transform .08s,border-color .08s;position:relative}
.vocab:hover{transform:translateY(-3px);border-color:var(--gold-d)}
.vocab .o{font-weight:800;font-size:16px;color:var(--gold);margin-bottom:4px}
.vocab .j{font-size:13px;color:var(--ink-dim)}
.vocab .speak{position:absolute;right:8px;top:8px;font-size:14px;opacity:.5}
.vocab:hover .speak{opacity:1}

/* ---------- クイズ ---------- */
.quiz{padding:20px}
.quiz .q-label{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--pink);margin-bottom:10px;display:block}
.quiz h3{font-size:17px;margin-bottom:16px;line-height:1.7}
.choices{display:flex;flex-direction:column;gap:10px}
.choice{text-align:left;background:var(--panel2);border:3px solid var(--border);border-radius:6px;
  padding:13px 16px;font-size:15px;font-weight:700;cursor:pointer;color:var(--ink);
  box-shadow:0 4px 0 0 #1d1730;transition:transform .07s,box-shadow .07s}
.choice:hover{transform:translateY(2px);box-shadow:0 2px 0 0 #1d1730}
.choice.correct{background:var(--green);color:#10330d;border-color:#10330d;box-shadow:0 4px 0 0 #2e6b29}
.choice.wrong{background:var(--red);color:#3a0d0d;border-color:#3a0d0d;box-shadow:0 4px 0 0 #8a2e2e}
.choice:disabled{cursor:default}
.explain{margin-top:16px;background:var(--bg1);border:3px dashed var(--gold-d);border-radius:6px;
  padding:14px 16px;font-size:14px;line-height:1.85;display:none}
.explain.show{display:block;animation:pop .25s}
@keyframes pop{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}

/* ---------- 章タイトルカード ---------- */
.chapter-title{text-align:center;padding:46px 24px}
.chapter-title .yr{font-family:'Press Start 2P',monospace;font-size:34px;color:var(--gold);
  text-shadow:3px 3px 0 var(--gold-d),6px 6px 0 var(--border);margin-bottom:16px}
.chapter-title h2{font-size:24px;margin-bottom:8px}
.chapter-title .pl{color:var(--ink-dim);font-size:14px}

/* ---------- エンディング ---------- */
.ending{text-align:center;padding:40px 26px}
.ending .yomi{font-size:22px;color:var(--gold);font-weight:800;line-height:1.7;margin:18px 0}
.summary{text-align:left;background:var(--bg1);border:3px solid var(--border);border-radius:6px;
  padding:16px 18px;margin:18px 0;font-size:13px;line-height:2;color:var(--ink-dim)}
.summary b{color:var(--green)}

.section-title{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:1px;margin:0 0 4px;padding:14px 20px 0}

/* ---------- HUDボタン（コンコード表） ---------- */
.hud-btn{font-family:'M PLUS Rounded 1c',sans-serif;font-weight:800;font-size:12px;cursor:pointer;
  border:2px solid var(--border);border-radius:4px;padding:5px 10px;margin-right:8px;
  background:var(--blue);color:#0a2233;box-shadow:0 3px 0 0 #2a6a8a}
.hud-btn:hover{transform:translateY(1px);box-shadow:0 2px 0 0 #2a6a8a}
.hud-btn:active{transform:translateY(3px);box-shadow:none}

/* ---------- 文法解説 ---------- */
.grammar{padding:20px}
.grammar h3{font-size:17px;color:var(--gold);margin-bottom:14px;line-height:1.6}
.g-points{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.g-points li{background:var(--bg1);border:2px solid var(--border);border-left:5px solid var(--green);
  border-radius:5px;padding:11px 14px;font-size:14px;line-height:1.85}
.g-points li b{color:var(--gold);font-family:'DotGothic16',monospace;letter-spacing:.5px}
.g-example{background:var(--panel2);border:3px dashed var(--blue);border-radius:6px;padding:14px 16px;margin-bottom:12px}
.g-example .ex-o{font-weight:800;font-size:18px;color:var(--blue);margin-bottom:6px;font-family:'DotGothic16',monospace}
.g-example .ex-j{font-size:13px;color:var(--ink-dim);line-height:1.7}
.g-hint{color:var(--ink-dim);font-size:12px;margin-bottom:6px}

/* ---------- コンコード表 ---------- */
.concord-table{width:100%;border-collapse:collapse;font-size:13px;
  border:3px solid var(--border);border-radius:6px;overflow:hidden}
.concord-table th{background:var(--gold);color:#3a280a;font-weight:800;padding:9px 8px;
  border:1px solid var(--border);font-size:12px}
.concord-table td{background:var(--bg1);color:var(--ink);padding:9px 8px;
  border:1px solid var(--border);text-align:center;font-family:'DotGothic16',monospace}
.concord-table td.rowhead{background:var(--panel2);font-weight:800;color:var(--gold);text-align:left;
  font-family:'M PLUS Rounded 1c',sans-serif}
.tbl-note{color:var(--ink-dim);font-size:12px;margin:8px 0 4px;line-height:1.7}
.tbl-note b{color:var(--green)}

/* ---------- スコアボックス ---------- */
.score-box{background:var(--bg1);border:3px solid var(--gold-d);border-radius:6px;
  padding:14px 16px;margin:16px auto;max-width:420px;font-size:15px;font-weight:700;line-height:2}
.score-box b{color:var(--green);font-size:20px}

.fade-in{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

@media(max-width:560px){
  .pad{padding:16px}
  .stage{height:160px}
  .vocab-grid{grid-template-columns:1fr 1fr}
  .chapter-title .yr{font-size:26px}
}

/* =========================================================
   隠しエンド（満点解放）：兵士ヤンの物語
   ========================================================= */
/* 解放ボタン（エンディング画面） */
.btn.hidden-unlock{
  background:linear-gradient(180deg,#7a2d2d,#4a1414);
  color:#ffd9c0;
  box-shadow:0 5px 0 0 #2a0c0c, 0 8px 16px rgba(0,0,0,.5);
  border:1px solid #b8674f;
  animation:hidden-pulse 1.8s ease-in-out infinite;
}
.btn.hidden-unlock:hover{transform:translateY(2px);box-shadow:0 3px 0 0 #2a0c0c,0 5px 10px rgba(0,0,0,.5)}
.btn.hidden-unlock:active{transform:translateY(5px);box-shadow:0 0 0 0 #2a0c0c}
@keyframes hidden-pulse{0%,100%{box-shadow:0 5px 0 0 #2a0c0c,0 8px 16px rgba(0,0,0,.5),0 0 0 0 rgba(217,110,79,.0)}
  50%{box-shadow:0 5px 0 0 #2a0c0c,0 8px 16px rgba(0,0,0,.5),0 0 22px 4px rgba(217,110,79,.45)}}

.perfect-note{margin:14px auto;max-width:420px;padding:10px 14px;border-radius:6px;
  background:rgba(122,45,45,.18);border:1px solid #b8674f;color:var(--gold);
  font-weight:800;font-family:'DotGothic16',monospace;letter-spacing:1px;line-height:1.8}
.perfect-note span{display:block;color:#ffd9c0;font-size:12px;font-weight:600;letter-spacing:0;margin-top:4px}

/* イントロ画面 */
.hidden-intro{text-align:center;padding:34px 18px;
  background:radial-gradient(120% 90% at 50% 0%, #2a1414 0%, #160a14 70%);
  border-radius:6px}
.hidden-eyebrow{color:#d98a6a;font-family:'DotGothic16',monospace;font-size:12px;letter-spacing:3px;margin-bottom:10px}
.hidden-title{color:#f4eefe;font-size:clamp(20px,5vw,30px);font-weight:800;margin:0 0 8px;
  text-shadow:2px 2px 0 #3a1010}
.hidden-sub{color:var(--gold);font-style:italic;font-size:15px;margin-bottom:18px;letter-spacing:1px}
.hidden-lead{color:var(--ink-dim);line-height:2;font-size:13px;max-width:460px;margin:0 auto 24px}

/* 本編ステージ（暗いシネマティック） */
.hidden-stage{position:relative;overflow:hidden}
.hidden-stage{background:linear-gradient(180deg,#150a16 0%,#1d0f1a 100%)!important}
.hidden-bar{height:6px;background:linear-gradient(90deg,#7a2d2d,#d99a2b,#7a2d2d);
  border-radius:4px;margin-bottom:14px;opacity:.7}
.hidden-beatlabel{color:#d98a6a;font-family:'DotGothic16',monospace;font-size:12px;
  letter-spacing:1px;text-align:right;margin-bottom:10px;opacity:.85}
.hidden-screen{min-height:200px;display:flex;align-items:center;justify-content:center;
  padding:24px 18px;background:rgba(0,0,0,.28);border:1px solid #5a2e2e;border-radius:8px}
.hidden-line{max-width:640px;width:100%}
.hidden-line.narr .hidden-text{color:#cfc6ff;font-style:italic;text-align:center;line-height:2.1}
.hidden-line.talk .hidden-text{color:#f4eefe;line-height:2.1}
.hidden-name{font-family:'DotGothic16',monospace;font-weight:800;font-size:14px;margin-bottom:8px;
  letter-spacing:1px}
.hidden-text{font-size:15px;min-height:1.6em;margin:0}
.hidden-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;
  color:var(--ink-dim);font-size:12px}
.hidden-prog{font-family:'Press Start 2P','DotGothic16',monospace;font-size:10px;color:var(--gold)}
.hidden-hint{opacity:.6;animation:hint-blink 1.4s ease-in-out infinite}
@keyframes hint-blink{0%,100%{opacity:.25}50%{opacity:.8}}

/* 炎のフラッシュ演出（カッシンガの場面） */
.hidden-flash::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(80% 60% at 50% 110%, rgba(255,120,40,.28), rgba(180,40,20,.0) 60%);
  animation:flame-flicker 2.6s ease-in-out infinite;z-index:0}
.hidden-flash>*{position:relative;z-index:1}
@keyframes flame-flicker{0%,100%{opacity:.5}25%{opacity:.85}50%{opacity:.35}75%{opacity:.7}}

/* 真エンド画面 */
.hidden-final{background:radial-gradient(120% 90% at 50% 0%, #1f1322 0%, #130a14 75%)}

@media(max-width:560px){
  .hidden-screen{min-height:180px;padding:18px 12px}
  .hidden-text{font-size:14px}
}

/* =========================================================
   セーブ / ロード UI
   ========================================================= */
/* タイトルの「つづきから」ボタン（金色で強調） */
.btn.continue-btn{
  background:linear-gradient(#ffd86b,#e0a430);
  color:#3a2400;
  box-shadow:0 4px 0 0 #a8761a;
}
.btn.continue-btn:hover{transform:translateY(1px);box-shadow:0 3px 0 0 #a8761a}
.btn.continue-btn:active{transform:translateY(4px);box-shadow:none}

/* タイトルのセーブ情報表示 */
.save-info{
  margin:18px auto 0;
  max-width:420px;
  padding:10px 14px;
  background:rgba(255,203,91,.10);
  border:1px solid rgba(255,203,91,.35);
  border-radius:10px;
  color:var(--ink-dim);
  font-size:12px;
  line-height:1.8;
}
.save-info b{color:var(--gold)}
.save-info span{font-size:11px;opacity:.85}

/* トースト通知（セーブしました 等） */
.toast{
  position:fixed;
  left:50%;
  bottom:28px;
  transform:translateX(-50%) translateY(20px);
  background:#2b2140;
  color:var(--ink);
  border:2px solid var(--gold-d);
  border-radius:12px;
  padding:10px 20px;
  font-family:'M PLUS Rounded 1c',sans-serif;
  font-weight:800;
  font-size:13px;
  box-shadow:0 6px 18px rgba(0,0,0,.45);
  opacity:0;
  pointer-events:none;
  z-index:9999;
  transition:opacity .25s ease, transform .25s ease;
}
.toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* =========================================================
   セーブスロット（3スロット選択UI）
   ========================================================= */
.slot-board{
  margin:20px auto 4px;
  max-width:480px;
  text-align:left;
}
.slot-board-title{
  color:var(--gold);
  font-size:13px;
  font-weight:800;
  margin-bottom:10px;
  text-align:center;
}
.slot-card{
  background:var(--panel2);
  border:2px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  margin-bottom:12px;
  box-shadow:0 3px 0 0 var(--shadow);
}
.slot-card.filled{ border-color:var(--gold-d); }
.slot-card.empty{ opacity:.92; }
.slot-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
}
.slot-no{
  font-family:'Press Start 2P', 'M PLUS Rounded 1c', monospace, sans-serif;
  font-size:11px;
  color:var(--blue);
  letter-spacing:1px;
  background:rgba(91,200,255,.12);
  border:1px solid rgba(91,200,255,.3);
  border-radius:6px;
  padding:3px 8px;
  white-space:nowrap;
}
.slot-loc{
  font-size:13px;
  font-weight:800;
  color:var(--ink);
}
.slot-loc.empty-label{ color:var(--ink-dim); font-weight:600; }
.slot-meta{
  font-size:11px;
  color:var(--ink-dim);
  margin-bottom:10px;
}
.slot-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.slot-actions .btn{
  font-size:12px;
  padding:8px 14px;
  margin-top:0;
}
.btn.slot-continue{
  background:linear-gradient(#ffd86b,#e0a430);
  color:#3a2400;
  box-shadow:0 4px 0 0 #a8761a;
}
.btn.slot-continue:hover{transform:translateY(1px);box-shadow:0 3px 0 0 #a8761a}
.btn.slot-continue:active{transform:translateY(4px);box-shadow:none}
.btn.ghost{
  background:transparent;
  color:var(--red);
  border:1px solid rgba(255,107,107,.4);
  box-shadow:none;
  padding:8px 12px;
}
.btn.ghost:hover{ background:rgba(255,107,107,.12); }

@media(max-width:560px){
  .slot-board{max-width:100%}
  .slot-actions .btn{flex:1 1 auto; text-align:center}
  .btn.ghost{flex:0 0 auto}
}

/* =========================================================
   保存先スロット選択モーダル
   ========================================================= */
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(10,7,20,.72);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10000;
  padding:18px;
  animation:modalFade .18s ease;
}
@keyframes modalFade{ from{opacity:0} to{opacity:1} }
.modal-card{
  background:var(--panel);
  border:2px solid var(--gold-d);
  border-radius:16px;
  box-shadow:0 12px 36px rgba(0,0,0,.55);
  padding:20px 18px;
  width:100%;
  max-width:440px;
  max-height:90vh;
  overflow:auto;
}
.modal-title{
  color:var(--gold);
  font-size:16px;
  font-weight:800;
  text-align:center;
  margin-bottom:6px;
}
.modal-sub{
  color:var(--ink-dim);
  font-size:11px;
  text-align:center;
  margin-bottom:14px;
}
.ssm-list{ display:flex; flex-direction:column; gap:10px; }
.ssm-slot{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  text-align:left;
  background:var(--panel2);
  border:2px solid var(--border);
  border-radius:12px;
  padding:12px 12px;
  cursor:pointer;
  font-family:'M PLUS Rounded 1c',sans-serif;
  color:var(--ink);
  box-shadow:0 3px 0 0 var(--shadow);
  transition:transform .08s ease, border-color .12s ease;
}
.ssm-slot:hover{ border-color:var(--gold); transform:translateY(-1px); }
.ssm-slot:active{ transform:translateY(2px); box-shadow:none; }
.ssm-slot.is-active{ border-color:var(--gold-d); background:rgba(255,203,91,.08); }
.ssm-no{
  font-family:'Press Start 2P','M PLUS Rounded 1c',monospace,sans-serif;
  font-size:10px;
  color:var(--blue);
  letter-spacing:1px;
  background:rgba(91,200,255,.12);
  border:1px solid rgba(91,200,255,.3);
  border-radius:6px;
  padding:6px 8px;
  white-space:nowrap;
  flex:0 0 auto;
}
.ssm-body{ display:flex; flex-direction:column; gap:2px; flex:1 1 auto; min-width:0; }
.ssm-loc{ font-size:13px; font-weight:800; color:var(--ink); }
.ssm-loc.empty-label{ color:var(--ink-dim); font-weight:600; }
.ssm-meta{ font-size:11px; color:var(--ink-dim); }
.ssm-act{
  flex:0 0 auto;
  font-size:11px;
  font-weight:800;
  color:#3a2400;
  background:linear-gradient(#ffd86b,#e0a430);
  border-radius:8px;
  padding:7px 10px;
  white-space:nowrap;
}

@media(max-width:560px){
  .ssm-slot{ flex-wrap:wrap; }
  .ssm-act{ width:100%; text-align:center; }
}
