:root{
  --bg0:#0f0820;--bg1:#1a0f2e;--bg2:#2a1a4a;
  --ink:#f4ecff;--ink-dim:#bda9e0;
  --accent:#ffd166;--accent2:#9b6bff;--accent3:#5ad7ff;
  --danger:#ff6b9b;--ok:#7fffa8;
  --card-edge:#ffd16688;
  --shadow:0 6px 24px #0008;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:radial-gradient(ellipse at top,#2a1a4a,#0f0820 70%);color:var(--ink);font-family:"Hiragino Sans","Yu Gothic UI","Segoe UI",system-ui,sans-serif;-webkit-text-size-adjust:100%;overflow-x:hidden;}
button{font-family:inherit;cursor:pointer}
.hidden{display:none !important}

#app{max-width:1100px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}

/* ── Topbar ── */
#topbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:#0009;backdrop-filter:blur(8px);position:sticky;top:0;z-index:10;border-bottom:1px solid #ffffff14}
.navbtn{background:#ffffff10;color:var(--ink);border:1px solid #ffffff22;border-radius:8px;padding:6px 10px;font-size:13px;transition:background .15s}
.navbtn:hover{background:#ffffff20}
.navbtn.active{background:var(--accent2);border-color:var(--accent2)}

#screen{flex:1;padding:16px;display:flex;flex-direction:column;gap:14px}
h1,h2,h3{margin:0 0 8px}
h1{font-size:28px;letter-spacing:2px}
h2{font-size:20px;color:var(--accent)}
h3{font-size:16px;color:var(--accent3)}
p{line-height:1.7;color:var(--ink-dim)}

/* ── Buttons ── */
.btn{background:linear-gradient(135deg,#9b6bff,#5ad7ff);color:#0a0518;border:none;border-radius:10px;padding:10px 16px;font-weight:700;letter-spacing:1px;box-shadow:var(--shadow);font-size:14px;transition:filter .15s}
.btn:hover{filter:brightness(1.12)}
.btn.ghost{background:#ffffff10;color:var(--ink);border:1px solid #ffffff33}
.btn.danger{background:linear-gradient(135deg,#ff6b9b,#9b6bff)}
.btn.small{padding:6px 10px;font-size:12px}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* ══════════════════════════════
   TITLE SCREEN
══════════════════════════════ */
.title-wrap{
  position:relative;min-height:calc(100vh - 60px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px 10px;gap:18px;overflow:hidden
}
/* Star field */
.star-field{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.star{position:absolute;border-radius:50%;background:#fff;animation:twinkle 3s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.6)}}
/* Floating card silhouettes */
.title-deco{position:absolute;pointer-events:none;z-index:0}
.title-deco-card{width:70px;height:100px;border-radius:10px;background:linear-gradient(160deg,#9b6bff22,#5ad7ff11);border:1px solid #ffffff0a;animation:floatCard 8s ease-in-out infinite}
@keyframes floatCard{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-18px) rotate(var(--r,0deg))}}
/* Logo */
.title-logo{
  position:relative;z-index:1;
  font-size:48px;font-weight:900;letter-spacing:8px;
  background:linear-gradient(90deg,#ffd166,#9b6bff,#5ad7ff,#ffd166);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:hue 10s linear infinite;
  text-shadow:0 0 0 transparent;/* prevent bleed */
  filter:drop-shadow(0 0 30px #9b6bff66)
}
@keyframes hue{to{filter:hue-rotate(360deg) drop-shadow(0 0 30px #9b6bff88)}}
.title-catch{position:relative;z-index:1;color:var(--ink-dim);max-width:500px;font-size:14px;line-height:1.9}
.title-menu{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px;width:min(300px,80vw)}
.title-save{position:relative;z-index:1;font-size:12px;opacity:.6;margin-top:4px}

/* ══════════════════════════════
   CHAPTER MAP
══════════════════════════════ */
.chap-map{display:flex;flex-direction:column;align-items:stretch;gap:0;padding:8px 0}
.chap-row{display:flex;align-items:center;gap:0;overflow-x:auto;padding:6px 10px;scrollbar-width:none}
.chap-row::-webkit-scrollbar{display:none}
.chap-row.rtl{flex-direction:row-reverse}
.chap-hline{flex:1;height:3px;min-width:14px;max-width:60px;
  background:linear-gradient(90deg,#ffd16633,#9b6bff33);border-radius:2px;flex-shrink:0}
.chap-hline.done{background:linear-gradient(90deg,#ffd166,#9b6bff)}
.chap-vwrap{display:flex;height:36px}
.chap-vwrap.right{justify-content:flex-end;padding-right:46px}
.chap-vwrap.left{justify-content:flex-start;padding-left:46px}
.chap-vline{width:3px;border-radius:2px;background:linear-gradient(180deg,#ffd16666,#9b6bff66)}
.chap-node{
  flex-shrink:0;width:92px;min-width:92px;height:92px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:radial-gradient(circle at 35% 35%,#2a1a4a,#1a0f2e);
  border:2px solid #ffd16633;cursor:pointer;
  position:relative;text-align:center;padding:6px;
  transition:transform .15s,border-color .15s,box-shadow .15s
}
.chap-node:not(.locked):hover{transform:scale(1.1);border-color:var(--accent);box-shadow:0 0 20px #ffd16644}
.chap-node.cleared{background:radial-gradient(circle at 35% 35%,#3a2a0a,#2a1a08);border-color:var(--accent);box-shadow:0 0 10px #ffd16633}
.chap-node.current{border-color:var(--accent2);box-shadow:0 0 18px #9b6bff88;animation:chapGlow .9s ease-in-out infinite alternate}
@keyframes chapGlow{from{box-shadow:0 0 8px #9b6bff66}to{box-shadow:0 0 26px #9b6bffcc}}
.chap-node.locked{opacity:.35;cursor:not-allowed;border-color:#ffffff22}
.chap-no{font-size:10px;letter-spacing:2px;color:var(--accent3);font-weight:700}
.chap-title-s{font-size:8.5px;color:var(--ink-dim);line-height:1.35;max-width:78px;word-break:keep-all}
.chap-badge{position:absolute;top:-5px;right:-3px;font-size:16px;text-shadow:0 0 8px #ffd166;line-height:1}

/* ══════════════════════════════
   CARD
══════════════════════════════ */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.acard{
  position:relative;aspect-ratio:3/4;border-radius:14px;padding:8px;
  display:flex;flex-direction:column;
  background:linear-gradient(160deg,var(--c1,#2a1a4a),var(--c2,#1a0f2e));
  border:2px solid var(--card-edge);box-shadow:var(--shadow);cursor:pointer;
  overflow:hidden;
  transition:transform .2s, box-shadow .2s
}
.acard:hover:not(.locked){
  transform:translateY(-4px) rotateY(6deg) rotateX(2deg);
  box-shadow:0 16px 40px #9b6bff44, var(--shadow);
}
.acard .ico{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;filter:drop-shadow(0 2px 8px #000a)}
.acard .nm{font-size:14px;font-weight:800;letter-spacing:1px;text-align:center}
.acard .tn{font-size:10px;color:var(--accent);text-align:center;margin-top:2px;min-height:14px}
.acard .typ{position:absolute;top:6px;left:6px;font-size:10px;background:#000a;padding:2px 6px;border-radius:6px;color:var(--accent3)}
.acard.locked{filter:grayscale(.7) brightness(.5)}
.acard.prem-locked{filter:grayscale(.3) brightness(.7);outline:1px solid var(--accent);outline-offset:2px;cursor:pointer}
.acard.prem-locked .tn{color:var(--accent);font-weight:700}
.acard.in-deck{outline:2px solid var(--ok);outline-offset:2px}
.acard.selected{outline:3px solid var(--accent);outline-offset:2px;transform:translateY(-5px)}
/* shimmer on hover */
.acard::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff00 40%,#ffffff18 50%,#ffffff00 60%);transform:translateX(-100%);transition:transform .4s}
.acard:hover::before{transform:translateX(100%)}

/* ══════════════════════════════
   CARD GET ANIMATION OVERLAY
══════════════════════════════ */
.card-get-overlay{
  position:fixed;inset:0;background:#000d;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:60;gap:16px;padding:20px;
  animation:fadeIn .3s ease
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.card-get-title{
  font-size:30px;font-weight:900;letter-spacing:6px;
  background:linear-gradient(90deg,#ffd166,#9b6bff);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 20px #ffd16688)
}
.card-get-sub{color:var(--ink-dim);font-size:13px}
.card-get-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.card-get-item{
  width:110px;padding:12px;border-radius:14px;
  background:linear-gradient(160deg,var(--c1,#2a1a4a),var(--c2,#1a0f2e));
  border:2px solid #ffd166;box-shadow:0 0 30px #9b6bff66,var(--shadow);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;transform:translateY(28px) scale(.85);
  animation:cgiIn .7s cubic-bezier(.2,.8,.4,1) forwards
}
@keyframes cgiIn{to{opacity:1;transform:translateY(0) scale(1)}}
.cgi-icon{font-size:42px;filter:drop-shadow(0 0 12px #fff8)}
.cgi-name{font-size:13px;font-weight:800;text-align:center;letter-spacing:1px}
.cgi-type{font-size:10px;color:var(--ink-dim)}

/* ══════════════════════════════
   STORY
══════════════════════════════ */
.story-stage{min-height:320px;display:flex;flex-direction:column;gap:12px}
.dialog-box{background:#0009;border:1px solid var(--accent2);border-radius:12px;padding:16px;min-height:90px;line-height:1.85;animation:dialogIn .2s ease}
@keyframes dialogIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.speaker{color:var(--accent);font-weight:700;margin-bottom:6px;font-size:13px;letter-spacing:2px}
.choices{display:flex;flex-direction:column;gap:8px}
.choice{text-align:left;padding:11px 14px;border:1px solid #ffffff33;background:#ffffff08;color:var(--ink);border-radius:10px;font-size:14px;transition:background .15s,border-color .15s}
.choice:hover{background:#ffffff18;border-color:var(--accent)}
.story-actor{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}
.actor-portrait{
  width:110px;height:150px;flex-shrink:0;border-radius:14px;
  background:linear-gradient(160deg,var(--c1,#9b6bff),var(--c2,#5ad7ff));
  display:flex;align-items:center;justify-content:center;
  font-size:36px;font-weight:900;color:#fff;
  box-shadow:var(--shadow),0 0 20px #9b6bff44;
  border:2px solid #ffffff33;letter-spacing:2px;
  animation:portraitIn .3s ease
}
@keyframes portraitIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}

/* ══════════════════════════════
   REVEAL (真名解放)
══════════════════════════════ */
.reveal-wrap{position:relative;padding:24px 10px;text-align:center;overflow:hidden;min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.reveal-aurora{position:absolute;inset:-60px;background:conic-gradient(from 0deg,#9b6bff55,#5ad7ff55,#ffd16655,#ff6b9b55,#9b6bff55);filter:blur(70px);animation:spin 16s linear infinite;z-index:0;pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}
.reveal-title{position:relative;z-index:1;font-size:36px;font-weight:900;letter-spacing:10px;background:linear-gradient(90deg,#ffd166,#9b6bff,#5ad7ff);-webkit-background-clip:text;background-clip:text;color:transparent;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.5)}}
.reveal-sub{position:relative;z-index:1;color:var(--ink-dim);font-size:13px}
.reveal-grid{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.reveal-card{width:160px;padding:14px;border-radius:14px;background:linear-gradient(160deg,var(--c1),var(--c2));border:2px solid #ffd166;box-shadow:0 0 30px #9b6bff66,var(--shadow);opacity:0;transform:translateY(20px) scale(.9);animation:revealIn .8s cubic-bezier(.2,.8,.4,1) forwards}
@keyframes revealIn{to{opacity:1;transform:translateY(0) scale(1)}}
.reveal-ico{font-size:48px;margin-bottom:6px}
.reveal-nm{font-weight:800;letter-spacing:2px;font-size:14px}
.reveal-arrow{margin:6px 0;opacity:.7}
.reveal-tn{font-size:19px;font-weight:900;color:#fff;letter-spacing:3px;text-shadow:0 0 8px #ffd166}
.reveal-role{font-size:11px;color:#ffffffcc;margin-top:6px;line-height:1.5}

/* ══════════════════════════════
   PANEL, MISC
══════════════════════════════ */
.panel{background:linear-gradient(180deg,#ffffff0e,#ffffff05);border:1px solid #ffffff18;border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.spacer{flex:1}
.tag{display:inline-block;padding:2px 8px;border-radius:6px;background:#ffffff14;font-size:11px;color:var(--ink-dim);margin-right:4px}
.mission-req{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.req-chip{padding:4px 8px;border-radius:6px;background:#ffffff10;font-size:12px;border:1px solid #ffffff22}
.req-chip.ok{background:#7fffa844;border-color:var(--ok);color:var(--ok)}
.codex-entry{border-left:3px solid var(--accent2);padding:10px 14px;margin-bottom:10px;background:#ffffff06;border-radius:0 12px 12px 0}
.codex-entry h3{margin:0 0 4px}
.codex-entry .true-name{color:var(--accent);font-size:13px;letter-spacing:2px;font-weight:700}
.codex-entry .true-name.locked{color:var(--ink-dim);filter:blur(5px);user-select:none}
.bp-section{margin-bottom:14px}
.bp-line{font-family:ui-monospace,Consolas,Menlo,monospace;font-size:13px;padding:4px 10px;background:#0008;border-radius:6px;margin:2px 0;color:var(--accent3)}
pre.tf-code{background:#000b;color:#7fffa8;padding:14px;border-radius:10px;font-size:12px;overflow-x:auto;border:1px solid #ffffff22;font-family:ui-monospace,Consolas,monospace;line-height:1.7}

/* Deck */
.deck-area{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:760px){.deck-area{grid-template-columns:1fr 320px}}
.deck-slots{display:flex;flex-wrap:wrap;gap:6px;min-height:80px;padding:8px;border:2px dashed #ffd16655;border-radius:10px;background:#0006}
.deck-slot{min-width:60px;padding:6px;border-radius:8px;background:#ffffff10;font-size:12px;text-align:center;border:1px solid #ffffff22}
.deck-slot button{display:block;width:100%;background:none;border:none;color:#ff6b9b;font-size:10px;margin-top:4px;cursor:pointer}

/* Battle */
.battle-stage{display:flex;flex-direction:column;gap:12px}
.enemy{padding:14px;border:2px solid var(--danger);border-radius:14px;background:linear-gradient(160deg,#3a1238,#1a0f2e);display:flex;gap:14px;align-items:center}
.enemy-icon{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,#ff6b9b,#3a1238);display:flex;align-items:center;justify-content:center;font-size:42px;flex-shrink:0;border:2px solid #ffffff44;animation:enemyPulse 1.4s ease-in-out infinite}
@keyframes enemyPulse{0%,100%{box-shadow:0 0 8px #ff6b9b44}50%{box-shadow:0 0 24px #ff6b9baa}}
.enemy-info{flex:1;min-width:0}
.enemy-name{font-size:18px;color:var(--danger);font-weight:800}
.enemy-desc{font-size:13px;color:var(--ink-dim);margin-top:4px}
.hp-bar{width:100%;height:10px;background:#0009;border-radius:6px;overflow:hidden;margin-top:10px}
.hp-fill{height:100%;background:linear-gradient(90deg,#7fffa8,#ffd166,#ff6b9b);transition:width .5s ease}

/* Toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);background:#000d;color:var(--ink);padding:10px 20px;border-radius:10px;border:1px solid var(--accent);z-index:50;transition:transform .25s;pointer-events:none;font-size:14px;white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Modal */
.modal{position:fixed;inset:0;background:#000a;display:flex;align-items:center;justify-content:center;z-index:40;padding:14px}
.modal-inner{background:linear-gradient(160deg,#2a1a4a,#1a0f2e);border:1px solid var(--accent2);border-radius:14px;padding:18px;max-width:520px;width:100%;max-height:80vh;overflow:auto;box-shadow:var(--shadow)}

/* ══════════════════════════════
   OPENING (intro cinematics)
══════════════════════════════ */
.opening-wrap{
  position:relative;min-height:calc(100vh - 30px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:20px;overflow:hidden;
  background:radial-gradient(ellipse at center,#1a0f2e,#000 80%);
  transition:background 1.2s ease;
}
.opening-wrap.phase-intro{background:#000}
.opening-wrap.phase-silhouettes{background:radial-gradient(ellipse at center,#1a0a2a,#000 80%)}
.opening-wrap.phase-icons{background:radial-gradient(ellipse at center,#2a1a4a,#0a0518 80%)}
.opening-wrap.phase-glow{background:radial-gradient(ellipse at center,#3a2a6a,#0a0518 80%)}
.opening-wrap.phase-alka{background:radial-gradient(ellipse at center,#5a3a8a,#0a0518 70%)}
.opening-wrap.phase-fadeout{background:radial-gradient(ellipse at center,#ffd16622,#000 80%)}
.opening-wrap.phase-logo{background:radial-gradient(ellipse at center,#2a1a4a,#0f0820 80%)}

.opening-skip{
  position:absolute;top:14px;right:14px;z-index:10;
  background:linear-gradient(135deg,#9b6bff,#5ad7ff);
  color:#0a0518;border:none;border-radius:24px;
  padding:10px 18px;font-weight:800;letter-spacing:1px;font-size:13px;
  box-shadow:0 4px 18px #5ad7ff66,0 0 0 2px #ffd16633;
  cursor:pointer;animation:skipPulse 1.8s ease-in-out infinite;
}
@keyframes skipPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.opening-skip:hover{filter:brightness(1.15)}

.opening-particles{position:absolute;inset:0;pointer-events:none;z-index:1}
.opening-particle{
  position:absolute;border-radius:50%;background:#fff;
  opacity:.35;animation:opParticle 4s ease-in-out infinite;
}
@keyframes opParticle{
  0%,100%{opacity:.1;transform:translateY(0) scale(.8)}
  50%{opacity:.7;transform:translateY(-12px) scale(1.2)}
}

.opening-sils{
  position:relative;z-index:2;
  display:flex;justify-content:center;align-items:flex-end;
  gap:6px;flex-wrap:wrap;max-width:90vw;margin-bottom:20px;
  opacity:0;transform:translateY(20px);
  transition:opacity 1.4s ease, transform 1.4s ease;
}
.phase-silhouettes .opening-sils,
.phase-icons .opening-sils,
.phase-glow .opening-sils,
.phase-alka .opening-sils{opacity:1;transform:none}
.phase-fadeout .opening-sils{opacity:.2}
.phase-logo .opening-sils{opacity:0;transform:scale(.95)}

.opening-sil{
  position:relative;width:42px;height:96px;
  display:flex;flex-direction:column;align-items:center;
  opacity:0;animation:silIn .6s ease-out forwards;
}
@keyframes silIn{to{opacity:1}}
.opening-sil-body{
  width:32px;height:78px;border-radius:16px 16px 8px 8px;
  background:linear-gradient(180deg,#3a2a6a,#1a0a3a);
  border:1px solid #ffffff14;
  transition:background 1s ease,box-shadow 1s ease;
}
.phase-glow .opening-sil-body{
  background:linear-gradient(180deg,#9b6bff88,#3a1a5a);
  box-shadow:0 0 16px #9b6bff66;
}
.phase-alka .opening-sil.alka .opening-sil-body{
  background:linear-gradient(180deg,#ffd166,#9b6bff);
  box-shadow:0 0 36px #ffd166cc,0 0 0 2px #fff8;
  animation:alkaPulse 2s ease-in-out infinite;
}
@keyframes alkaPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.5)}}
.opening-sil-icon{
  position:absolute;top:-22px;font-size:18px;opacity:0;
  filter:drop-shadow(0 0 6px #ffd16688);
  transition:opacity 1s ease, transform 1s ease;
}
.phase-icons .opening-sil-icon,
.phase-glow .opening-sil-icon,
.phase-alka .opening-sil-icon{opacity:1;transform:translateY(-4px)}
.phase-fadeout .opening-sil-icon{opacity:.4}
.phase-logo .opening-sil-icon{opacity:0}

.opening-narration{
  position:relative;z-index:3;
  max-width:90vw;min-height:80px;
  color:#fff;text-align:center;
  padding:14px 18px;border-radius:10px;
  background:rgba(0,0,0,0.45);backdrop-filter:blur(2px);
  border:1px solid #ffffff14;
  margin-top:10px;
  animation:dialogIn .4s ease;
}
.opening-speaker{
  font-size:12px;color:var(--accent);letter-spacing:3px;
  margin-bottom:6px;font-weight:700;
}
.opening-line{font-size:16px;line-height:1.85;letter-spacing:1px}

.opening-logo-wrap{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;padding:20px;text-align:center;
  opacity:0;pointer-events:none;
  transition:opacity 1s ease;
}
.opening-wrap.opening-finished .opening-logo-wrap,
.opening-wrap.phase-logo .opening-logo-wrap{opacity:1;pointer-events:auto}
.opening-logo{
  font-size:clamp(36px,8vw,64px);font-weight:900;letter-spacing:8px;
  background:linear-gradient(90deg,#ffd166,#9b6bff,#5ad7ff,#ffd166);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 30px #9b6bff88);
  animation:hue 8s linear infinite;
}
.opening-catch{
  color:var(--accent);font-size:16px;letter-spacing:4px;
  text-shadow:0 0 12px #ffd16666;
}
.opening-start{font-size:18px;padding:14px 32px;letter-spacing:2px}

@media(max-width:600px){
  .opening-sil{width:32px;height:78px}
  .opening-sil-body{width:24px;height:62px}
  .opening-sil-icon{font-size:14px;top:-20px}
  .opening-line{font-size:14px}
  .opening-skip{padding:8px 14px;font-size:12px}
}

/* ══════════════════════════════
   ENTRY CHOICE (入口分岐)
══════════════════════════════ */
.entry-wrap{padding:24px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.entry-title{font-size:22px;color:var(--accent);letter-spacing:3px;margin:0}
.entry-sub{color:var(--ink-dim);font-size:13px;margin:0}
.entry-options{
  display:grid;gap:14px;width:100%;max-width:800px;
  grid-template-columns:1fr;
}
@media(min-width:760px){.entry-options{grid-template-columns:1fr 1fr}}
.entry-card{
  background:linear-gradient(160deg,#2a1a4a,#1a0f2e);
  border:2px solid var(--accent2);border-radius:16px;
  padding:20px 16px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.entry-card:hover{
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 12px 30px #9b6bff44;
}
.entry-card-icon{font-size:48px;filter:drop-shadow(0 0 12px #ffd16666)}
.entry-card-name{font-size:18px;font-weight:900;letter-spacing:2px;color:var(--accent)}
.entry-card-desc{font-size:13px;line-height:1.85;color:var(--ink-dim);margin:0;text-align:left}

/* ══════════════════════════════
   DIGEST (5分顔見せ)
══════════════════════════════ */
.digest-scene{
  display:flex;gap:16px;align-items:center;flex-wrap:wrap;
  padding:18px;border-radius:14px;
  background:linear-gradient(160deg,#1a0f2e,#0a0518);
  border:1px solid var(--accent2);box-shadow:var(--shadow);
}
.digest-scene .actor-portrait{
  width:140px;height:190px;
  animation:dgIn .35s ease;
}
@keyframes dgIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
.digest-info{flex:1;min-width:200px;display:flex;flex-direction:column;gap:6px}
.digest-role{font-size:12px;color:var(--accent3);letter-spacing:3px}
.digest-name{font-size:24px;color:var(--accent);font-weight:900;letter-spacing:3px}
.digest-line{font-size:15px;line-height:1.95;color:var(--ink);margin-top:4px}
.digest-finish{text-align:center;padding:40px 16px;display:flex;flex-direction:column;gap:12px;align-items:center}

/* ══════════════════════════════
   AUDIO SETTINGS
══════════════════════════════ */
.audio-row{display:flex;align-items:center;gap:10px;margin:8px 0}
.audio-row label{flex:0 0 80px;font-size:13px;color:var(--ink-dim)}
.audio-row input[type=range]{flex:1;accent-color:var(--accent)}
.audio-val{flex:0 0 50px;text-align:right;font-size:12px;color:var(--accent3);font-family:ui-monospace,Consolas,monospace}

/* ══════════════════════════════
   FOOTER (商標免責)
══════════════════════════════ */
#footer{
  padding:18px 12px;text-align:center;
  border-top:1px solid #ffffff14;
  background:#0006;
}
#footer p{
  font-size:10px;color:var(--ink-dim);
  line-height:1.75;letter-spacing:.5px;
  max-width:760px;margin:0 auto;opacity:.7;
}

/* Mobile */
@media(max-width:600px){
  h1{font-size:22px}
  .title-logo{font-size:32px;letter-spacing:4px}
  #screen{padding:10px}
  .navbtn{font-size:11px;padding:5px 7px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .chap-node{width:78px;min-width:78px;height:78px}
  .chap-title-s{font-size:7.5px}
}
