:root{--ink-bg:#0a0d18;--ink-veil:#0a0d18eb;--indigo-deep:#0d1428;--indigo-mid:#16203a;--gold-rule:#c8a36a;--gold-deep:#5c4220;--porcelain:#ece4d0;--henri-warm:#f1c187;--henri-amber:#d99656;--henri-deep:#6a4220;--henri-rule:#d996568c;--hanae-cool:#b4cdf5;--hanae-moon:#7ea0d6;--hanae-deep:#1f3458;--hanae-rule:#b4cdf58c;--fused-gold:#ffe9b0;--fused-amber:#ffba65;--accent-warm:var(--henri-warm);--accent-deep:var(--henri-deep);--accent-rule:var(--henri-rule);--accent-glow:#f1c18759;--font-serif:"Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", "Georgia", serif;--font-mono-jp:"Noto Serif JP", "Yu Mincho", serif;--font-fr:"EB Garamond", "Georgia", "Yu Mincho", serif}body.narrator-henri{--accent-warm:var(--henri-warm);--accent-deep:var(--henri-deep);--accent-rule:var(--henri-rule);--accent-glow:#f1c18759}body.narrator-hanae{--accent-warm:var(--hanae-cool);--accent-deep:var(--hanae-deep);--accent-rule:var(--hanae-rule);--accent-glow:#b4cdf559}*{box-sizing:border-box}html,body{background:var(--ink-bg);color:var(--porcelain);font-family:var(--font-serif);font-feature-settings:"palt" 1;letter-spacing:.02em;-webkit-tap-highlight-color:transparent;width:100vw;height:100vh;margin:0;padding:0;transition:background 1.4s;overflow:hidden}body.narrator-henri{background:#110d08}body.narrator-hanae{background:#0a0e1c}body.ending-mode{background:#1a1206}#app{-webkit-user-select:none;user-select:none;touch-action:none;background:radial-gradient(#0d1020 0%,#02030a 80%);position:fixed;inset:0}#pixi-canvas{display:block;position:absolute;inset:0}#title-screen{z-index:200;cursor:pointer;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}#title-veil{z-index:1;background:linear-gradient(#0a0d18f5 0%,#0a0d18d9 40%,#0a0d18f5 100%);position:absolute;inset:0}#title-stack{z-index:2;text-align:center;padding:0 env(safe-area-inset-right,1rem) calc(env(safe-area-inset-bottom,0px) + 3rem) env(safe-area-inset-left,1rem);max-width:920px;position:relative}#title-main{font-family:var(--font-mono-jp);color:var(--porcelain);text-shadow:0 0 24px #f1c18740;letter-spacing:.16em;margin:0 0 .5rem;font-size:clamp(2rem,7.5vw,4rem);font-weight:400}#title-subtitle{font-family:var(--font-fr);color:#f6eed88c;letter-spacing:.25em;margin-bottom:1.6rem;font-size:clamp(.78rem,1.4vw,1.05rem);font-style:italic}#title-hint{color:#f1c187bf;letter-spacing:.3em;font-size:clamp(.75rem,1.2vw,.95rem)}#clue-log{top:calc(env(safe-area-inset-top,0px) + .6rem);right:calc(env(safe-area-inset-right,0px) + .6rem);z-index:50;border:1px solid var(--accent-rule);-webkit-backdrop-filter:blur(4px);background:linear-gradient(145deg,#16203ac7,#0a0d18db);border-radius:6px;min-width:140px;max-width:32vw;padding:.45rem .6rem;transition:border-color 1.2s;position:fixed;box-shadow:0 4px 18px #00000080}.clue-log-title{letter-spacing:.4em;color:var(--gold-rule);text-align:left;border-bottom:1px solid #c8a36a40;margin-bottom:.4rem;padding-bottom:.25rem;font-size:.66rem}.clue-log-items{flex-direction:column;gap:.25rem;max-height:30vh;display:flex;overflow-y:auto}.clue-item{color:var(--porcelain);align-items:center;gap:.4rem;padding:.18rem 0;font-size:.7rem;display:flex}.clue-icon{font-size:.9rem}.clue-label{letter-spacing:.06em}#narrator-toggle{z-index:60;top:calc(env(safe-area-inset-top,0px) + .6rem);left:calc(env(safe-area-inset-left,0px) + .6rem);border:1px solid var(--accent-rule);cursor:pointer;font-family:var(--font-mono-jp);background:linear-gradient(145deg,#16203adb,#0a0d18eb);border-radius:8px;flex-direction:column;gap:.16rem;min-width:168px;padding:.32rem .36rem;transition:border-color 1s,box-shadow .6s;display:flex;position:fixed;box-shadow:0 4px 16px #00000080}.nar-tog-row{color:#ece4d073;letter-spacing:.16em;border-radius:4px;align-items:center;gap:.45rem;padding:.32rem .5rem;font-size:.7rem;transition:all .6s;display:flex}.nar-tog-row.active{color:var(--accent-warm);text-shadow:0 0 10px var(--accent-glow);background:#f1c18714}body.narrator-hanae .nar-tog-row.active{background:#b4cdf514}.nar-tog-icon{min-width:1rem;font-size:.95rem;line-height:1}.nar-tog-label{letter-spacing:.2em;opacity:.9;min-width:1.6rem}.nar-tog-name{opacity:.85;font-size:.7rem}#reset-zoom-btn{z-index:60;bottom:calc(env(safe-area-inset-bottom,0px) + .7rem);left:calc(env(safe-area-inset-left,0px) + .7rem);width:2.6rem;height:2.6rem;font-size:1.3rem;font-family:var(--font-mono-jp);color:var(--porcelain);border:1px solid var(--accent-rule);cursor:pointer;background:linear-gradient(145deg,#16203adb,#0a0d18eb);border-radius:999px;justify-content:center;align-items:center;padding:0;transition:border-color 1s;display:flex;position:fixed;box-shadow:0 0 18px #0006}body.beat-mode #narrator-toggle,body.beat-mode #reset-zoom-btn,body.beat-mode #clue-log,body.ending-mode #narrator-toggle,body.ending-mode #reset-zoom-btn,body.ending-mode #clue-log{opacity:0;pointer-events:none;transition:opacity 1.2s}body:has(#title-screen) #narrator-toggle{opacity:0;pointer-events:none;transition:opacity 1.2s}body:has(#title-screen) #reset-zoom-btn{opacity:0;pointer-events:none;transition:opacity 1.2s}body:has(#title-screen) #clue-log{opacity:0;pointer-events:none;transition:opacity 1.2s}.intro-mono{z-index:180;padding:2rem env(safe-area-inset-right,2rem) 2rem env(safe-area-inset-left,2rem);background:linear-gradient(#0a0d18f0,#0a0d18c7);flex-direction:column;justify-content:center;align-items:center;gap:1.1rem;display:flex;position:fixed;inset:0}.intro-mono-line{color:var(--porcelain);text-align:center;letter-spacing:.06em;max-width:760px;font-size:clamp(.95rem,1.8vw,1.25rem);line-height:1.85;font-family:var(--font-mono-jp)}.intro-thunder{color:var(--fused-gold);text-shadow:0 0 18px #ffe9b059;letter-spacing:.14em;margin-top:1.4rem;font-size:clamp(1.1rem,2.4vw,1.7rem)!important}.act-enter{z-index:160;background:#0a0d18d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.act-enter-inner{text-align:center;max-width:720px}.act-enter-title{font-family:var(--font-mono-jp);color:var(--gold-rule);letter-spacing:.4em;border-bottom:1px solid #c8a36a59;margin-bottom:1.6rem;padding-bottom:.8rem;font-size:clamp(1.2rem,2.6vw,1.8rem)}.act-enter-line{color:var(--porcelain);letter-spacing:.08em;margin-bottom:.8rem;font-size:clamp(.92rem,1.6vw,1.15rem);line-height:1.9}.beat-sequence{z-index:150;padding:1.4rem env(safe-area-inset-right,1.6rem) 1.4rem env(safe-area-inset-left,1.6rem);background:linear-gradient(#0a0d18f0,#0a0d18e0);grid-template-columns:38% 1fr;gap:1.6rem;display:grid;position:fixed;inset:0}.beat-sequence.beat-henri{background:linear-gradient(#28160699,#0a0d18eb),radial-gradient(at 70% 20%,#d996562e,#0000 60%)}.beat-sequence.beat-hanae{background:linear-gradient(#141e3699,#0a0d18eb),radial-gradient(at 30% 20%,#7ea0d62e,#0000 60%)}.beat-closeup{border:1px solid var(--accent-rule);background:#14182a;border-radius:6px;position:relative;overflow:hidden;box-shadow:0 6px 30px #0009,inset 0 0 50px #0006}.beat-closeup img{object-fit:cover;width:100%;height:100%;display:block}.beat-closeup-narrator{font-family:var(--font-mono-jp);color:var(--accent-warm);letter-spacing:.2em;border:1px solid var(--accent-rule);background:#0a0d1899;border-radius:4px;padding:.2rem .55rem;font-size:clamp(.75rem,1vw,.9rem);position:absolute;top:.6rem;left:.8rem}.beat-closeup-label{font-family:var(--font-mono-jp);color:var(--accent-warm);letter-spacing:.3em;text-shadow:0 0 8px #000000e6;font-size:clamp(.8rem,1.2vw,1rem);position:absolute;bottom:.8rem;left:.8rem;right:.8rem}.beat-stack{scroll-behavior:smooth;flex-direction:column;gap:.7rem;padding-right:.4rem;display:flex;overflow-y:auto}.beat-line{border-left:2px solid var(--accent-rule);background:#0a0d1899;border-radius:0 4px 4px 0;padding:.7rem .9rem;position:relative}.beat-line p{font-size:clamp(.85rem,1.45vw,1.05rem);line-height:1.85;font-family:var(--font-mono-jp);margin:0}.beat-tag{letter-spacing:.3em;color:#c8a36aa6;font-size:.7rem;position:absolute;top:.4rem;right:.6rem}.beat-observe{border-left-color:var(--porcelain)}.beat-observe p{color:var(--porcelain)}.beat-memory{border-left-color:var(--accent-warm);background:linear-gradient(90deg,#3c240c52,#0a0d1866)}.beat-memory p{color:var(--accent-warm);font-style:italic}body.narrator-hanae .beat-memory{background:linear-gradient(90deg,#14244652,#0a0d1866)}.beat-reflect{border-left-color:#a0aac8b3}.beat-reflect p{color:#c3c8dccc;font-size:clamp(.8rem,1.3vw,.98rem);font-style:italic}.beat-history{background:#281c0c66;border:1px solid #c8a36a73;border-left-width:2px}.beat-history p{color:#f1c187e6;font-size:clamp(.82rem,1.32vw,.98rem)}.beat-suspect{border-left-color:var(--fused-amber)}.beat-suspect p{color:var(--fused-amber);text-shadow:0 0 12px #ffba6566;letter-spacing:.06em}.beat-skip{bottom:calc(env(safe-area-inset-bottom,0px) + 1rem);right:calc(env(safe-area-inset-right,0px) + 1.2rem);z-index:152;color:var(--accent-warm);border:1px solid var(--accent-rule);font-family:var(--font-mono-jp);letter-spacing:.3em;cursor:pointer;background:linear-gradient(145deg,#16203aeb,#0a0d18eb);border-radius:999px;padding:.7rem 2.2rem;font-size:.85rem;position:fixed}.convergence-reveal{z-index:195;cursor:pointer;background:radial-gradient(#3c2a0e66,#0000 70%),linear-gradient(#0a0d18f2,#0a0d18e6);flex-direction:column;justify-content:center;align-items:center;gap:1.4rem;padding:2rem;display:flex;position:fixed;inset:0}.conv-rule{background:linear-gradient(90deg, transparent, var(--fused-gold), transparent);width:70%;max-width:540px;height:1px}.conv-label{font-family:var(--font-mono-jp);color:var(--gold-rule);letter-spacing:.5em;font-size:clamp(.75rem,1.1vw,.95rem)}.conv-text{font-family:var(--font-mono-jp);color:var(--fused-gold);text-align:center;letter-spacing:.1em;text-shadow:0 0 18px #ffe9b066;max-width:760px;min-height:2.4em;font-size:clamp(1.1rem,2.4vw,1.6rem);line-height:2}.conv-tap{letter-spacing:.5em;color:var(--gold-rule);font-size:1.2rem;position:absolute;bottom:1.6rem}.mid-reveal{z-index:200;padding:2rem env(safe-area-inset-right,2rem) 2rem env(safe-area-inset-left,2rem);cursor:pointer;background:#0a0d18ed;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.mid-rule{background:linear-gradient(90deg, transparent, var(--gold-rule), transparent);width:80%;max-width:600px;height:1px;margin-bottom:2.4rem}.mid-line{font-family:var(--font-mono-jp);color:var(--porcelain);text-align:center;letter-spacing:.08em;max-width:720px;margin-bottom:1.1rem;font-size:clamp(1.05rem,2.2vw,1.5rem);line-height:1.95}.mid-tap-hint{letter-spacing:.5em;color:var(--gold-rule);font-size:1.2rem;position:absolute;bottom:1.6rem}.final-reveal{z-index:320;padding:1.4rem env(safe-area-inset-right,2rem) 1.4rem env(safe-area-inset-left,2rem);cursor:pointer;background:radial-gradient(at 50% 30%,#3c280e52,#0000 60%),linear-gradient(#0a0d18f7,#0a0d18eb);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.final-paragraph{max-width:740px;font-family:var(--font-mono-jp);color:var(--porcelain);letter-spacing:.06em;margin-bottom:1.4rem;font-size:clamp(.95rem,1.5vw,1.15rem);line-height:2}.final-paragraph p{margin:0}.final-bookend p{color:var(--fused-gold);text-shadow:0 0 14px #ffe9b040;letter-spacing:.08em;font-size:clamp(1.05rem,1.8vw,1.35rem)}.final-golden p{color:var(--fused-amber);text-align:center;text-shadow:0 0 18px #ffba6580,0 0 36px #ffba6540;letter-spacing:.14em;border-top:1px solid #c8a36a59;margin-top:.8rem;padding-top:1.6rem;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:500}.final-tap{color:var(--gold-rule);letter-spacing:.5em;margin-top:1.6rem;font-size:1.4rem}.screen-flash{z-index:360;pointer-events:none;position:fixed;inset:0}.canvas-glow{z-index:290;pointer-events:none;background:radial-gradient(at 50% 35%,#ffd38280,#0000 65%);position:fixed;inset:0}.toast{bottom:calc(env(safe-area-inset-bottom,0px) + 5rem);border:1px solid var(--accent-rule);color:var(--accent-warm);letter-spacing:.08em;z-index:400;background:#0a0d18e0;border-radius:4px;padding:.55rem 1rem;font-size:.85rem;position:fixed;left:50%;transform:translate(-50%)}#memory-pane{z-index:80;pointer-events:none;background:radial-gradient(at 50% 40%,#ffd39180 0%,#da9c5c38 30%,#0000 70%),linear-gradient(#0000 40%,#ffc88c26 100%);position:fixed;inset:0}#clock-tick{z-index:300;text-align:center;font-family:var(--font-mono-jp);background:#0a0d18b8;border:1px solid #c8a36a80;border-radius:8px;min-width:280px;padding:.8rem 1.8rem;position:fixed;top:8vh;left:50%;transform:translate(-50%);box-shadow:0 0 30px #0009}.clock-cities{color:var(--porcelain);letter-spacing:.24em;flex-wrap:wrap;justify-content:center;align-items:center;gap:.7rem;font-size:clamp(1.1rem,2.6vw,1.7rem);display:flex}.clock-cities .city.paris{color:var(--henri-warm);text-shadow:0 0 14px #f1c1878c}.clock-cities .city.yokohama{color:var(--hanae-cool);text-shadow:0 0 14px #b4cdf580}.clock-cities .bridge{color:var(--fused-gold);letter-spacing:.16em;text-shadow:0 0 16px #ffe9b0a6;font-size:.85em}.clock-caption{color:var(--gold-rule);letter-spacing:.36em;margin-top:.55rem;font-size:clamp(.7rem,1.1vw,.9rem);transition:color 1.6s}#ending-card{z-index:310;text-align:center;font-family:var(--font-mono-jp);max-width:92vw;position:fixed;bottom:14vh;left:50%;transform:translate(-50%)}.ending-card-line{color:var(--fused-gold);letter-spacing:.24em;text-shadow:0 0 22px #ffe9b08c;margin-bottom:1.2rem;font-size:clamp(1.2rem,3.4vw,2.2rem);line-height:1.6}.ending-card-sub{color:#c8a36abf;letter-spacing:.5em;font-size:clamp(.75rem,1.2vw,.95rem)}#credits{z-index:311;text-align:center;font-family:var(--font-mono-jp);color:#f1c18799;letter-spacing:.4em;font-size:.72rem;line-height:1.9;position:fixed;bottom:2vh;left:50%;transform:translate(-50%)}#credits .sm{opacity:.7;font-size:.62rem}@media (max-width:1024px) and (orientation:landscape) and (max-height:500px){#clue-log{top:calc(env(safe-area-inset-top,0px) + .3rem);right:calc(env(safe-area-inset-right,0px) + .3rem);max-width:26vw;padding:.3rem .45rem}.clue-log-title{font-size:.55rem}.clue-item{font-size:.6rem}#narrator-toggle{top:calc(env(safe-area-inset-top,0px) + .25rem);left:calc(env(safe-area-inset-left,0px) + .25rem);gap:.1rem;min-width:132px;padding:.22rem .26rem}.nar-tog-row{gap:.32rem;padding:.22rem .36rem;font-size:.6rem}.nar-tog-icon{font-size:.8rem}.nar-tog-name{font-size:.6rem}#reset-zoom-btn{width:2rem;height:2rem;bottom:calc(env(safe-area-inset-bottom,0px) + .35rem);left:calc(env(safe-area-inset-left,0px) + .35rem);font-size:1rem}.beat-sequence{grid-template-columns:34% 1fr;gap:.9rem;padding:.7rem .9rem}.beat-stack{padding-right:.2rem}.beat-line{padding:.45rem .7rem}.beat-line p{font-size:clamp(.78rem,1.5vw,.95rem);line-height:1.7}.beat-closeup-narrator{padding:.14rem .4rem;font-size:.62rem;top:.4rem;left:.4rem}.beat-closeup-label{letter-spacing:.22em;font-size:.72rem;bottom:.5rem;left:.5rem;right:.5rem}.beat-skip{bottom:calc(env(safe-area-inset-bottom,0px) + .4rem);right:calc(env(safe-area-inset-right,0px) + .5rem);padding:.5rem 1.4rem;font-size:.72rem}.intro-mono{gap:.55rem;padding:1rem}.intro-mono-line{font-size:clamp(.78rem,1.7vw,1rem);line-height:1.65}.intro-thunder{margin-top:.7rem;font-size:clamp(.92rem,2vw,1.2rem)!important}.mid-line{margin-bottom:.7rem;font-size:clamp(.95rem,2.4vw,1.25rem);line-height:1.7}.mid-rule{margin-bottom:1.4rem}.conv-text{font-size:clamp(.95rem,2.4vw,1.3rem);line-height:1.7}.conv-label{font-size:.6rem}.final-paragraph{margin-bottom:1rem;font-size:clamp(.82rem,1.5vw,.98rem);line-height:1.75}.final-bookend p{font-size:clamp(.95rem,1.85vw,1.18rem)}.final-golden p{padding-top:1rem;font-size:clamp(1rem,2vw,1.3rem)}#clock-tick{min-width:220px;padding:.5rem 1.2rem;top:4vh}.clock-cities{gap:.4rem;font-size:clamp(.95rem,2.2vw,1.3rem)}#ending-card{bottom:10vh}.ending-card-line{letter-spacing:.18em;font-size:clamp(1rem,2.8vw,1.6rem)}}@media (orientation:portrait){.beat-sequence{grid-template-rows:36% 1fr;grid-template-columns:1fr}}
