@import "https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700&family=Cinzel:wght@400;700&display=swap";:root{--bg-dark:#12102a;--bg-panel:#1e1a38d9;--bg-card:#1e1a38;--text-main:#e8e4f0;--text-dim:#8a85a0;--heading:#c8c0e8;--accent:#9b8ec4;--accent-glow:#9b8ec466;--border-gold:#9b8ec44d;--title-gold:#c8a050;--title-gold-glow:#c8a05066;--title-gold-soft:#c8a05040;--font-body:"Noto Serif JP", "Cinzel", serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased;overflow:hidden}#root{width:100vw;height:100dvh;overflow:hidden}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hub{width:100%;height:100%;color:var(--text-main);scroll-behavior:smooth;background:radial-gradient(at 10% -10%,#9b8ec438 0%,#0000 55%),radial-gradient(at 100% 10%,#9b8ec41f 0%,#0000 55%),linear-gradient(#0a0820 0%,#12102a 40%,#0a0820 100%);overflow:hidden auto}.hub-hero{justify-content:center;align-items:center;min-height:80vh;padding:6rem 1.5rem 5rem;display:flex;position:relative;overflow:hidden}.hub-hero-bg{filter:blur(1px);pointer-events:none;background:radial-gradient(circle at 50% 40%,#9b8ec42e 0%,#0000 55%),radial-gradient(circle at 50% 80%,#9b8ec42e 0%,#0000 55%);position:absolute;inset:0}.hub-hero-inner{text-align:center;z-index:1;max-width:820px;position:relative}.hub-hero-kicker{color:var(--text-dim);letter-spacing:.3em;text-transform:uppercase;margin-bottom:1.5rem;font-size:.8rem}.hub-hero-title{color:var(--title-gold);letter-spacing:.18em;text-shadow:0 0 30px var(--title-gold-glow), 0 0 80px var(--title-gold-soft);margin-bottom:2rem;font-size:clamp(3rem,10vw,6.5rem);font-weight:700}.hub-hero-lead{color:var(--text-main);opacity:.9;font-size:clamp(.95rem,1.3vw,1.1rem);line-height:2}.hub-section{max-width:1200px;margin:0 auto;padding:4rem 1.5rem}.hub-section-head{text-align:center;margin-bottom:2.5rem}.hub-section-title{color:var(--heading);letter-spacing:.15em;margin-bottom:.5rem;font-size:clamp(1.5rem,3vw,2rem)}.hub-section-sub{color:var(--text-dim);letter-spacing:.05em;font-size:.9rem}.singles-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem;display:grid}.single-card{text-align:left;border:1px solid var(--border-gold);color:var(--text-main);font-family:var(--font-body);background:#1e1a388c;flex-direction:column;align-items:stretch;padding:0;transition:transform .3s,border-color .3s,box-shadow .3s,background .3s;display:flex;overflow:hidden}.single-card.is-open{cursor:pointer}.single-card.is-open:hover{border-color:var(--accent);box-shadow:0 10px 40px #00000080, 0 0 30px var(--accent-glow);background:#2a2248b3;transform:translateY(-4px)}.single-card.is-locked{cursor:not-allowed;opacity:.85}.single-card-art{aspect-ratio:1;background:linear-gradient(160deg,#2a2148,#12102a);justify-content:center;align-items:flex-end;display:flex;position:relative;overflow:hidden}.single-card-art img{object-fit:contain;object-position:center bottom;filter:drop-shadow(0 6px 20px #00000080);width:100%;height:100%;transition:transform .5s}.single-card.is-open:hover .single-card-art img{transform:scale(1.05)}.single-card.is-locked .single-card-art img{filter:brightness(.85)}.single-card-overlay{color:var(--accent);letter-spacing:.25em;border:1px solid var(--border-gold);text-transform:uppercase;background:#0c0a1cbf;border-radius:4px;padding:8px 12px;font-size:.85rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.single-card-body{border-top:1px solid #9b8ec426;padding:1rem 1.2rem 1.3rem}.single-card-character{color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:.35rem;font-size:.75rem}.single-card-title{color:var(--heading);letter-spacing:.08em;margin-bottom:.5rem;font-size:1.15rem}.single-card-tagline{color:var(--text-main);opacity:.75;font-size:.85rem;line-height:1.6}.hub-game-cta{padding-bottom:5rem}.game-cta-card{border:1px solid var(--border-gold);text-align:center;background:linear-gradient(135deg,#2d2355b3,#12102ae6);padding:3.5rem 2rem;position:relative;overflow:hidden}.game-cta-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#9b8ec414,#0000 60%);position:absolute;inset:0}.game-cta-inner{position:relative}.coming-soon-badge{letter-spacing:.3em;color:var(--accent);border:1px solid var(--border-gold);text-transform:uppercase;margin-bottom:1.5rem;padding:.4rem 1.2rem;font-size:.85rem;display:inline-block}.game-cta-copy{color:var(--text-main);opacity:.9;font-size:1rem;line-height:2}.hub-footer{text-align:center;color:var(--text-dim);letter-spacing:.15em;padding:2rem 1rem 3rem;font-size:.8rem}.single-page{width:100%;height:100%;color:var(--text-main);background:linear-gradient(#0a0820 0%,#12102a 40%,#0a0820 100%);padding:2rem 1.5rem 5rem;overflow:hidden auto}.single-back{color:var(--text-dim);letter-spacing:.1em;background:0 0;border:1px solid #0000;margin-bottom:2.5rem;padding:.4rem .8rem;font-size:.9rem;transition:color .2s,border-color .2s}.single-back:hover{color:var(--accent);border-color:var(--border-gold)}.single-header{text-align:center;max-width:820px;margin:0 auto 3rem}.single-header-character{color:var(--text-dim);letter-spacing:.25em;text-transform:uppercase;margin-bottom:.75rem;font-size:.8rem}.single-header-title{color:var(--heading);letter-spacing:.15em;text-shadow:0 0 30px var(--accent-glow);margin-bottom:1rem;font-size:clamp(2rem,5vw,3.2rem)}.single-header-tagline{color:var(--text-main);opacity:.8;font-size:1rem;line-height:1.8}.single-media{max-width:960px;margin:0 auto 3.5rem}.youtube-frame{aspect-ratio:16/9;border:1px solid var(--border-gold);background:#000;width:100%;position:relative;overflow:hidden}.youtube-frame iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.audio-fallback{border:1px solid var(--border-gold);text-align:center;background:#1e1a38b3;padding:2rem 1.5rem}.audio-fallback-note{color:var(--text-dim);letter-spacing:.1em;margin-bottom:1rem;font-size:.85rem}.audio-fallback audio{width:100%;max-width:520px}.side-story{border:1px solid var(--border-gold);background:#1e1a388c;max-width:720px;margin:0 auto;padding:3rem clamp(1.2rem,4vw,3rem)}.side-story-head{text-align:center;border-bottom:1px solid #9b8ec433;margin-bottom:2.5rem;padding-bottom:1.5rem}.side-story-title{color:var(--heading);letter-spacing:.15em;margin-bottom:.5rem;font-size:1.6rem}.side-story-sub{color:var(--text-dim);letter-spacing:.05em;font-size:.9rem}.side-story-body{color:var(--text-main);font-size:1.02rem;line-height:2.1}.side-story-para{white-space:pre-wrap;margin-bottom:1.4rem}.side-story-end{text-align:center;color:var(--accent);letter-spacing:.5em;margin-top:2rem}.side-story-coming,.single-missing{text-align:center;color:var(--text-dim);padding:3rem 1rem}@media (width<=640px){.hub-hero{min-height:70vh;padding:4rem 1rem 3rem}.hub-section{padding:3rem 1rem}.singles-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.single-card-body{padding:.8rem .9rem 1rem}.single-card-title{font-size:1rem}.single-card-tagline{font-size:.78rem}.side-story{padding:2rem 1.2rem}.side-story-body{font-size:.95rem;line-height:2}}.title-screen{background:linear-gradient(135deg,#12102a 0%,#2a2148 50%,#12102a 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.title-bg{background:radial-gradient(circle at 20% 30%,#9b8ec426 0%,#0000 50%),radial-gradient(circle at 80% 70%,#9b8ec41a 0%,#0000 50%);position:absolute;inset:0}.title-content{text-align:center;z-index:1;position:relative}.title-text{color:var(--title-gold);text-shadow:0 0 30px var(--title-gold-glow), 0 0 60px var(--title-gold-soft);letter-spacing:.1em;margin-bottom:3rem;font-size:clamp(2rem,6vw,4rem);font-weight:700}.title-menu{flex-direction:column;align-items:center;gap:1rem;display:flex}.title-btn{background:var(--bg-panel);color:var(--text-main);border:1px solid var(--border-gold);letter-spacing:.05em;min-width:220px;padding:.8rem 2.5rem;font-size:1.1rem;transition:all .3s}.title-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-glow);background:#9b8ec426}.lang-toggle{min-width:auto;margin-top:1rem;padding:.5rem 1.5rem;font-size:.9rem}.game-screen{width:100%;height:100%;position:relative;overflow:hidden}.game-background{background-color:#2a2148;background-position:50%;background-size:cover;transition:background-image .5s;position:absolute;inset:0}.game-background:after{content:"";background:linear-gradient(#0000 40%,#12102a99 100%);position:absolute;inset:0}.characters-layer{pointer-events:none;z-index:1;position:absolute;inset:0}.character{max-height:70%;position:absolute;bottom:15%}.character img{filter:drop-shadow(0 4px 20px #00000080);width:auto;max-height:60vh}.character-left{left:5%}.character-center{left:50%;transform:translate(-50%)}.character-right{right:5%}.text-window{border-top:1px solid var(--border-gold);cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(8px);background:linear-gradient(#12102abf,#12102af2);min-height:180px;padding:1.5rem 2rem;position:absolute;bottom:0;left:0;right:0}.speaker-name{color:var(--accent);letter-spacing:.08em;margin-bottom:.5rem;font-size:.95rem;font-weight:700}.text-content{color:var(--text-main);white-space:pre-wrap;font-size:1.05rem;line-height:1.9}.cursor{color:var(--accent);margin-left:2px;animation:1s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.choices-container{z-index:20;flex-direction:column;gap:1rem;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.choice-button{color:var(--text-main);border:1px solid var(--border-gold);text-align:center;-webkit-backdrop-filter:blur(4px);background:#12102ae6;min-width:300px;padding:1rem 2.5rem;font-size:1.05rem;transition:all .3s}.choice-button:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-glow);background:#9b8ec433;transform:scale(1.02)}.menu-bar{z-index:15;gap:0;display:flex;position:absolute;top:0;right:0}.menu-btn{color:var(--text-dim);letter-spacing:.05em;background:#12102a99;border-left:1px solid #9b8ec426;padding:.5rem 1rem;font-size:.8rem;transition:all .2s}.menu-btn:hover{color:var(--text-main);background:#9b8ec41a}.menu-btn.active{color:var(--accent);background:#9b8ec426}.menu-btn:disabled{opacity:.3;cursor:not-allowed}.backlog-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.backlog-content{border:1px solid var(--border-gold);background:#1e1a38f2;flex-direction:column;width:90%;max-width:700px;max-height:80vh;display:flex}.backlog-header{border-bottom:1px solid var(--border-gold);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.backlog-header h2{color:var(--heading);font-size:1.1rem}.backlog-close{color:var(--text-dim);background:0 0;font-size:1.5rem;transition:color .2s}.backlog-close:hover{color:var(--text-main)}.backlog-list{flex:1;padding:1rem 1.5rem;overflow-y:auto}.backlog-entry{border-bottom:1px solid #9b8ec41a;margin-bottom:1rem;padding-bottom:1rem;line-height:1.7}.backlog-speaker{color:var(--accent);margin-bottom:.25rem;font-size:.85rem;display:block}.backlog-text{font-size:.95rem}.backlog-empty{text-align:center;color:var(--text-dim)}.ending-banner{text-align:center;z-index:30;animation:1s fadeIn;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ending-banner-text{color:var(--heading);text-shadow:0 0 30px var(--accent-glow);margin-bottom:.5rem;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:700}.ending-banner-sub{color:var(--text-dim);font-size:1rem}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-50%)scale(.9)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.ending-actions{z-index:20;position:absolute;top:40%;left:50%;transform:translate(-50%)}.ending-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ending-content{border:1px solid var(--border-gold);text-align:center;background:#1e1a38f2;min-width:320px;padding:2rem}.ending-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.ending-header h2{color:var(--heading);font-size:1.2rem}.ending-close{color:var(--text-dim);background:0 0;font-size:1.5rem;transition:color .2s}.ending-close:hover{color:var(--text-main)}.ending-list{flex-direction:column;gap:.8rem;margin-bottom:1.5rem;display:flex}.ending-item{border:1px solid var(--border-gold);padding:.8rem 1.2rem;font-size:.95rem}.ending-item.unlocked{color:var(--accent);background:#9b8ec41a}.ending-item.locked{color:var(--text-dim);font-style:italic}.ending-count{color:var(--text-dim);margin-bottom:1rem;font-size:.9rem}.btn-back{background:var(--bg-panel);color:var(--text-main);border:1px solid var(--border-gold);padding:.6rem 2rem;font-size:.95rem;transition:all .3s}.btn-back:hover{border-color:var(--accent);color:var(--accent)}.game-menu-overlay{z-index:50;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.game-menu{flex-direction:column;align-items:center;gap:1rem;display:flex}.effect-flash,.effect-ap,.effect-oddeye,.effect-overlay{pointer-events:none;z-index:2;position:absolute;inset:0}.effect-flash{animation:.3s ease-out forwards effect-flash-anim}@keyframes effect-flash-anim{0%{opacity:.8}to{opacity:0}}.effect-ap{background:radial-gradient(ellipse at 50% 60%, color-mix(in srgb, var(--effect-color) calc(var(--effect-intensity) * 60%), transparent) 0%, transparent 70%)}.effect-ap--pulse{animation:2.4s ease-in-out infinite effect-pulse}.effect-ap--ripple{animation:1.6s ease-out infinite effect-ripple}.effect-ap--fill{animation:1.5s forwards effect-fill-in}@keyframes effect-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes effect-ripple{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(1.4)}}@keyframes effect-fill-in{0%{opacity:0}to{opacity:1}}.effect-oddeye{background:radial-gradient(ellipse at 35% 50%, color-mix(in srgb, var(--effect-color) calc(var(--effect-intensity) * 60%), transparent) 0%, transparent 50%), radial-gradient(ellipse at 65% 50%, color-mix(in srgb, var(--effect-color2) calc(var(--effect-intensity) * 60%), transparent) 0%, transparent 50%)}.effect-oddeye--pulse{animation:3s ease-in-out infinite effect-pulse}.effect-oddeye--merge{animation:2s ease-in-out forwards effect-oddeye-merge}@keyframes effect-oddeye-merge{0%{background:radial-gradient(ellipse at 35% 50%, color-mix(in srgb, var(--effect-color) 30%, transparent) 0%, transparent 40%), radial-gradient(ellipse at 65% 50%, color-mix(in srgb, var(--effect-color2) 30%, transparent) 0%, transparent 40%);opacity:.6}50%{background:radial-gradient(ellipse at 42% 50%, color-mix(in srgb, var(--effect-color) 50%, transparent) 0%, transparent 50%), radial-gradient(ellipse at 58% 50%, color-mix(in srgb, var(--effect-color2) 50%, transparent) 0%, transparent 50%);opacity:.9}to{background:radial-gradient(ellipse at 50% 50%, color-mix(in srgb, var(--effect-color) 40%, transparent) 0%, transparent 70%), radial-gradient(ellipse at 50% 50%, color-mix(in srgb, var(--effect-color2) 40%, transparent) 10%, transparent 80%);opacity:1}}.effect-oddeye--explode{animation:1.5s ease-out forwards effect-oddeye-explode}@keyframes effect-oddeye-explode{0%{background:radial-gradient(ellipse at 50% 50%, color-mix(in srgb, var(--effect-color) 50%, transparent) 0%, transparent 30%), radial-gradient(ellipse at 50% 50%, color-mix(in srgb, var(--effect-color2) 50%, transparent) 5%, transparent 35%);opacity:.5;transform:scale(.8)}to{background:radial-gradient(ellipse at 30% 50%, color-mix(in srgb, var(--effect-color) 50%, transparent) 0%, transparent 80%), radial-gradient(ellipse at 70% 50%, color-mix(in srgb, var(--effect-color2) 50%, transparent) 0%, transparent 80%);opacity:1;transform:scale(1)}}.effect-overlay{animation:1.5s forwards effect-fill-in}@media (width<=768px){.text-window{min-height:150px;padding:1rem 1.2rem}.text-content{font-size:.95rem;line-height:1.8}.choice-button{min-width:260px;padding:.8rem 1.5rem;font-size:.95rem}.menu-btn{padding:.4rem .7rem;font-size:.75rem}.character img{max-height:40vh}}
