@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;700&family=Cinzel:wght@400;700&display=swap");:root{--bg-primary:#0a0a12;--bg-secondary:#12121e;--bg-panel:rgba(10,8,20,.92);--accent-primary:#8b4fa0;--accent-secondary:#c44060;--accent-gold:#c8a060;--text-primary:#e8deff;--text-secondary:#a090c0;--text-muted:#605880;--border-color:rgba(139,79,160,.4);--correct-color:#4fc880;--wrong-color:#c04040}*{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:"Noto Serif JP",Hiragino Mincho ProN,Yu Mincho,serif;overflow:hidden;-moz-user-select:none;user-select:none;-webkit-user-select:none}.game-container{position:fixed;inset:0;display:flex;flex-direction:column;cursor:pointer;overflow:hidden}.bg-layer{background-size:cover;background-position:50%;background-repeat:no-repeat;transition:background-image .6s ease;z-index:0}.bg-gradient,.bg-layer{position:absolute;inset:0}.bg-gradient{background:radial-gradient(ellipse at center top,#1a0a2e 0,#0a0a12 100%);z-index:1;pointer-events:none}.characters-layer{position:absolute;inset:0;z-index:2;pointer-events:none}.char-sprite{position:absolute;bottom:220px;width:260px;max-width:40%;display:flex;align-items:flex-end;justify-content:center}.char-sprite img{width:100%;max-height:60vh;object-fit:contain;filter:drop-shadow(0 0 20px rgba(139,79,160,.3));transition:opacity .3s}.char-left{left:4%}.char-center{left:50%;transform:translateX(-50%)}.char-right{right:4%}.textbox{bottom:0;min-height:190px;background:var(--bg-panel);border-top:1px solid var(--border-color);padding:14px 20px 18px;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.textbox,.textbox:before{position:absolute;left:0;right:0}.textbox:before{content:"";top:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary),transparent)}.speaker-name{font-size:15px;font-weight:700;letter-spacing:.1em;margin-bottom:8px;text-shadow:0 0 10px currentColor}.dialogue-text{font-size:16px;line-height:1.8;color:var(--text-primary);min-height:80px;word-break:break-all}.system-text{color:var(--accent-gold);font-size:14px;text-align:center;letter-spacing:.08em}.cursor{animation:blink .7s infinite;color:var(--accent-primary)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.advance-hint{position:absolute;bottom:10px;right:16px;font-size:11px;color:var(--text-muted);letter-spacing:.05em}.evidence-badge-bar{position:absolute;top:12px;right:12px;z-index:20;display:flex;gap:8px;align-items:center}.evidence-badge{background:rgba(139,79,160,.25);border:1px solid var(--accent-primary);color:var(--text-primary);padding:5px 12px;border-radius:20px;font-size:12px;cursor:pointer;font-family:inherit;transition:background .2s}.evidence-badge:hover{background:rgba(139,79,160,.4)}.mistake-badge{background:rgba(192,64,64,.3);border:1px solid var(--wrong-color);color:#ff8080;padding:5px 10px;border-radius:20px;font-size:12px}.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:50;display:flex;align-items:flex-end;justify-content:center;padding-bottom:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.panel{background:var(--bg-panel);border:1px solid var(--border-color);border-bottom:none;border-radius:16px 16px 0 0;padding:20px 16px 24px;width:100%;max-width:480px;max-height:70vh;overflow-y:auto;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.panel-title{font-size:16px;font-weight:700;text-align:center;color:var(--accent-gold);letter-spacing:.1em;margin-bottom:4px}.panel-warning{font-size:12px;color:var(--wrong-color);text-align:center;margin-bottom:14px}.evidence-list,.suspect-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.evidence-item,.suspect-item{background:rgba(139,79,160,.12);border:1px solid var(--border-color);border-radius:10px;padding:12px 14px;text-align:left;cursor:pointer;color:var(--text-primary);font-family:inherit;transition:background .15s,border-color .15s;width:100%}.evidence-item:hover,.suspect-item:hover{background:rgba(139,79,160,.3);border-color:var(--accent-primary)}.evidence-name{font-size:14px;font-weight:700;margin-bottom:4px;color:var(--accent-gold)}.evidence-desc{font-size:12px;color:var(--text-secondary);line-height:1.6}.suspect-item{font-size:15px;font-weight:700;text-align:center;letter-spacing:.08em}.panel-close{display:block;width:100%;padding:12px;background:transparent;border:1px solid var(--text-muted);border-radius:8px;color:var(--text-muted);font-family:inherit;font-size:13px;cursor:pointer;margin-top:8px;transition:color .2s,border-color .2s}.panel-close:hover{color:var(--text-primary);border-color:var(--text-secondary)}.flash{position:fixed;inset:0;z-index:100;pointer-events:none;animation:flashAnim .6s ease forwards}.wrong-flash{background:rgba(192,64,64,.5)}.correct-flash{background:rgba(79,200,128,.35)}@keyframes flashAnim{0%{opacity:1}to{opacity:0}}.end-screen{position:fixed;inset:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:200}.end-content{text-align:center;padding:40px 24px;max-width:400px}.end-title{font-family:Cinzel,serif;font-size:32px;font-weight:700;letter-spacing:.2em;margin-bottom:8px}.true-end{color:var(--accent-gold);text-shadow:0 0 20px var(--accent-gold)}.bad-end{color:var(--wrong-color);text-shadow:0 0 20px var(--wrong-color)}.end-subtitle{font-size:18px;margin-bottom:24px;letter-spacing:.1em}.end-subtitle,.end-text{color:var(--text-secondary)}.end-text{font-size:15px;line-height:2;margin-bottom:32px}.restart-btn{background:rgba(139,79,160,.2);border:1px solid var(--accent-primary);color:var(--text-primary);padding:14px 32px;border-radius:8px;font-family:inherit;font-size:15px;cursor:pointer;letter-spacing:.08em;transition:background .2s}.restart-btn:hover{background:rgba(139,79,160,.4)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a0a2e 0,#0a0a12 100%);padding:20px}.auth-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:16px;padding:32px 28px;width:100%;max-width:380px}.auth-title{font-family:Cinzel,serif;font-size:22px;text-align:center;color:var(--accent-gold);letter-spacing:.1em;margin-bottom:6px}.auth-subtitle{text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:24px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.05em}.form-input{width:100%;background:hsla(0,0%,100%,.06);border:1px solid var(--border-color);border-radius:8px;padding:12px 14px;color:var(--text-primary);font-family:inherit;font-size:15px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent-primary)}.form-input::placeholder{color:var(--text-muted)}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent-primary),#6030a0);border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;letter-spacing:.08em;transition:opacity .2s;margin-top:8px}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-link{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--text-muted);text-decoration:none}.auth-link a{color:var(--accent-primary);text-decoration:underline}.error-msg{background:rgba(192,64,64,.15);border:1px solid var(--wrong-color);border-radius:6px;padding:10px 12px;font-size:13px;color:#ff8080;margin-bottom:14px}.title-page{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 40%,#1a0a2e 0,#05050f 100%);overflow:hidden}.title-stars{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 20% 30%,rgba(200,180,255,.8),transparent),radial-gradient(1px 1px at 60% 20%,rgba(200,180,255,.6),transparent),radial-gradient(1px 1px at 80% 70%,rgba(200,180,255,.5),transparent),radial-gradient(1px 1px at 40% 80%,rgba(200,180,255,.7),transparent),radial-gradient(1px 1px at 10% 60%,rgba(200,180,255,.4),transparent),radial-gradient(2px 2px at 70% 50%,rgba(200,160,255,.3),transparent);pointer-events:none}.title-logo{position:relative;z-index:1;text-align:center;margin-bottom:48px}.title-main{font-family:"Noto Serif JP",serif;font-size:clamp(26px,6vw,42px);font-weight:300;letter-spacing:.15em;color:var(--text-primary);text-shadow:0 0 30px rgba(139,79,160,.6);line-height:1.6}.title-sub{font-family:Cinzel,serif;font-size:clamp(12px,2.5vw,18px);color:var(--accent-gold);letter-spacing:.2em;margin-top:8px;opacity:.8}.title-menu{position:relative;z-index:1;display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px}.title-btn{background:rgba(139,79,160,.12);border:1px solid var(--border-color);border-radius:8px;padding:14px;color:var(--text-primary);font-family:"Noto Serif JP",serif;font-size:15px;letter-spacing:.1em;cursor:pointer;text-align:center;transition:background .2s,border-color .2s;text-decoration:none;display:block}.title-btn:hover{background:rgba(139,79,160,.3);border-color:var(--accent-primary)}.title-btn.primary{background:linear-gradient(135deg,rgba(139,79,160,.3),rgba(96,48,160,.3));border-color:var(--accent-primary);font-weight:700}.save-page{min-height:100vh;background:radial-gradient(ellipse at center,#1a0a2e 0,#0a0a12 100%);padding:24px 16px}.save-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.back-btn{background:transparent;border:1px solid var(--border-color);border-radius:6px;padding:8px 14px;color:var(--text-secondary);font-family:inherit;font-size:13px;cursor:pointer}.save-title{font-size:18px;color:var(--accent-gold);letter-spacing:.1em}.slot-list{display:flex;flex-direction:column;gap:12px;max-width:480px;margin:0 auto}.slot-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:12px;padding:16px;display:flex;justify-content:space-between;align-items:center}.slot-info{flex:1 1}.slot-no{font-size:12px;color:var(--text-muted);margin-bottom:4px}.slot-name{font-size:15px;color:var(--text-primary);margin-bottom:2px}.slot-date{font-size:11px}.slot-date,.slot-empty{color:var(--text-muted)}.slot-empty{font-size:14px;font-style:italic}.slot-actions{display:flex;gap:8px}.slot-btn{padding:8px 14px;border-radius:6px;font-family:inherit;font-size:12px;cursor:pointer;transition:opacity .2s}.slot-btn.load{background:rgba(139,79,160,.3);border:1px solid var(--accent-primary);color:var(--text-primary)}.slot-btn.save{background:rgba(79,200,128,.15);border:1px solid var(--correct-color);color:#80ffb0}.slot-btn.del{background:rgba(192,64,64,.15);border:1px solid var(--wrong-color);color:#ff8080}@media (orientation:landscape) and (max-height:500px){.char-sprite{bottom:160px}.textbox{min-height:150px;padding:10px 20px 14px}.dialogue-text{font-size:14px;min-height:60px}}@media (min-width:600px){.textbox{max-width:640px;left:50%;transform:translateX(-50%);border-radius:12px 12px 0 0;right:auto;width:100%}.evidence-badge-bar{right:calc(50% - 300px)}}