:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #ffffff;--text: #111213;--muted: #555;--border: #d0d5dd;--panel: #f8f9fa;--bubble-player: #007aff;--bubble-player-text: #ffffff;--bubble-dm: #e5e5ea;--bubble-dm-text: #000000;--bubble-suspect: #e5e5ea;--bubble-suspect-text: #000000;--primary-bg: #f7f8ff;--primary-border: #c7cbe0;--info-bg: #cfe2ff;--info-border: #b6d4fe;--restart-bg: #e7f1ff;--restart-border: #b6d4fe}@media(prefers-color-scheme:dark){:root{--bg: #0f1115;--text: #eaeef6;--muted: #9aa3b2;--border: #2a3340;--panel: #161a20;--bubble-player: #0a84ff;--bubble-player-text: #ffffff;--bubble-dm: #3a3a3c;--bubble-dm-text: #ffffff;--bubble-suspect: #3a3a3c;--bubble-suspect-text: #ffffff;--primary-bg: #1a1f2a;--primary-border: #39465d;--info-bg: #1a2a45;--info-border: #31507b;--restart-bg: #1b2c49;--restart-border: #31507b}}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.home-layout{min-height:100vh;width:100vw;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);color:var(--text);padding:1rem;position:fixed;top:0;left:0}.home-content{max-width:500px;width:100%;text-align:center;transform:translateY(-10vh)}.home-header{margin-bottom:3rem}.home-title{font-size:3rem;font-weight:700;margin:0 0 .5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.title-clue{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:700}.title-break{font-family:Georgia,Times New Roman,serif;font-weight:600;font-style:italic}.home-subtitle{font-size:1.2rem;color:var(--muted);margin:0}.home-buttons{display:flex;flex-direction:column;gap:1rem;align-items:center}.home-btn{padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;min-width:250px;max-width:300px}.home-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.home-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.home-btn-secondary{background:var(--panel);color:var(--text);border:1px solid var(--border)}.home-btn-secondary:hover{background:var(--primary-bg);border-color:var(--primary-border)}.settings-list{display:flex;flex-direction:column;gap:.5rem}.settings-option{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.settings-option:hover{background:var(--panel);border-color:var(--primary-border)}.settings-icon{font-size:1.5rem;flex-shrink:0}.settings-label{font-size:1rem;font-weight:500;color:var(--text)}@media(max-width:768px){.home-title{font-size:2.5rem}.home-subtitle{font-size:1rem}.home-btn{padding:.9rem 1.5rem;font-size:1rem;min-width:200px}.settings-option{padding:.75rem}.settings-icon{font-size:1.25rem}.settings-label{font-size:.9rem}}.case-layout{height:100dvh;width:100%;max-width:100vw;display:grid;grid-template-rows:auto 1fr;background:var(--bg);color:var(--text);overflow-x:hidden}.info-panel{border-bottom:1px solid var(--border);background:var(--panel)}.info-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem}.info-title{flex:1}.info-title .title{margin:0}.subtitle{font-size:.9rem;color:var(--muted);margin-bottom:0}.info-icon-btn{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;padding:0;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:1.2rem;z-index:5}.floating-restart-btn{position:absolute;top:3.25rem;right:.75rem;width:36px;height:36px;padding:0;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:1.2rem;z-index:5}.floating-restart-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.info-icon-btn,.floating-restart-btn{display:flex}.info-actions .restart-btn{display:none}}.toggle-btn{padding:.35rem .6rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer}.main{display:flex;flex-direction:column;min-height:0;padding:.75rem 1rem;gap:.5rem}.synopsis{padding:1rem;border:none;border-left:4px solid #4a90e2;border-radius:12px;background:linear-gradient(135deg,#667eea15,#764ba215);box-shadow:0 2px 8px #00000014;font-size:.95rem;position:relative;overflow:hidden;margin-bottom:1rem}.synopsis:before{content:"📋";position:absolute;top:.75rem;right:.75rem;font-size:1.5rem;opacity:.3}@media(prefers-color-scheme:dark){.synopsis{background:linear-gradient(135deg,#667eea25,#764ba225);box-shadow:0 2px 12px #0000004d}}.synopsis-title{font-weight:700;margin-bottom:.5rem;color:#4a90e2;font-size:1rem;letter-spacing:.025em}.case-conclusion{padding:1rem;border:none;border-left:4px solid #4a90e2;border-radius:12px;background:linear-gradient(135deg,#667eea15,#764ba215);box-shadow:0 2px 8px #00000014;font-size:.95rem;position:relative;overflow:hidden;margin-bottom:.35rem}.case-conclusion:before{content:"🔎";position:absolute;top:.75rem;right:.75rem;font-size:1.5rem;opacity:.3}@media(prefers-color-scheme:dark){.case-conclusion{background:linear-gradient(135deg,#667eea25,#764ba225);box-shadow:0 2px 12px #0000004d}}.case-conclusion-title{font-weight:700;margin-bottom:.5rem;color:#4a90e2;font-size:1rem;letter-spacing:.025em}.case-closed{padding:.75rem;border:1px solid var(--info-border);border-radius:8px;background:var(--info-bg);font-size:.9rem}.case-closed-title{font-weight:600;margin-bottom:.25rem}.case-closed-line{margin:0}.setting-text{font-size:.9rem;color:var(--muted);margin-top:.25rem}.setting-text-mobile{font-size:.8rem;color:var(--muted);margin-top:.25rem;margin-bottom:.75rem;width:100%;line-height:1.3}.primary-btn{margin-top:.6rem;width:100%;padding:.55rem .75rem;border-radius:10px;border:1px solid var(--primary-border);background:var(--primary-bg);color:var(--text);cursor:pointer}.primary-btn:disabled{opacity:.5;cursor:not-allowed}@media(min-width:769px){.info-actions{display:flex;flex-direction:row;gap:.5rem}}@media(max-width:768px){.info-actions .toggle-btn{display:none}}.restart-btn{padding:.35rem .6rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer}.chat-scroll{flex:1 1 auto;border:1px solid var(--border);border-radius:8px;padding:.5rem;overflow-y:auto;min-height:0;background:var(--bg)}.empty-hint{color:var(--muted)}.bubble-row{display:flex;margin-bottom:.35rem}.bubble-row.player{justify-content:flex-end}.bubble-row.dm,.bubble-row.suspect{justify-content:flex-start}.bubble{max-width:78%;padding:.5rem .65rem;border-radius:10px;font-size:.95rem}.bubble.player{background:var(--bubble-player);color:var(--bubble-player-text)}.bubble.dm{background:var(--bubble-dm);color:var(--bubble-dm-text)}.bubble.suspect{background:var(--bubble-suspect);color:var(--bubble-suspect-text)}.bubble-label{font-weight:600;margin-bottom:.15rem}.typing-indicator{display:flex;align-items:center;gap:.3rem;padding:.5rem .75rem;border-radius:10px;background:var(--bubble-dm);width:fit-content;margin-bottom:.35rem}.typing-indicator .dot{width:8px;height:8px;border-radius:50%;background:var(--bubble-dm-text);opacity:.6;animation:typing-bounce 1.4s infinite ease-in-out}.typing-indicator .dot:nth-child(1){animation-delay:0s}.typing-indicator .dot:nth-child(2){animation-delay:.2s}.typing-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}.confetti-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:100;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;background:red;top:-10px;animation:confetti-fall 3s linear forwards;opacity:1}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-10px)}20%,40%,60%,80%{transform:translate(10px)}}.input-bar{display:flex;align-items:center;gap:.5rem;flex-shrink:0;position:sticky;bottom:0;background:var(--bg);padding-top:.35rem}.input{flex:1 1 auto;padding:.6rem .7rem;border:1px solid var(--border);border-radius:10px;font-size:1rem;background:var(--bg);color:var(--text)}.send-btn{padding:.55rem .9rem;border-radius:10px;border:1px solid var(--primary-border);background:var(--primary-bg);color:var(--text);cursor:pointer}.send-btn:disabled{opacity:.5;cursor:not-allowed}.target-select-wrap{flex:0 0 auto;display:flex;align-items:center}.target-select{appearance:none;padding:.5rem .75rem;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);font-size:1rem;min-width:110px;max-width:40vw}.input-bar .target-select-wrap{margin-right:.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.centered{display:grid;place-items:center;height:80vh;background:var(--bg);color:var(--text)}@media(max-width:768px){.bubble{max-width:88%}.target-select{min-width:90px;font-size:.95rem;padding:.45rem .6rem}.input-bar{position:fixed;bottom:0;left:0;right:0;padding:.5rem 1rem;background:var(--bg);border-top:1px solid var(--border);z-index:10}.chat-scroll{padding-bottom:4rem}.main{padding-bottom:0}.info-bar{flex-direction:column;align-items:stretch}.info-actions{flex-direction:column;width:100%}.info-actions .toggle-btn,.info-actions .primary-btn{width:100%;margin-top:0}}.modal-backdrop{position:fixed;inset:0;background:#0006;display:grid;place-items:center;padding:1rem;z-index:50}.modal-sheet{width:min(560px,100%);background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #0000004d;padding:1rem}.modal-title{margin:0 0 .5rem;font-size:1.1rem}.modal-body{max-height:50vh;overflow:auto;border:1px solid var(--border);border-radius:8px;background:var(--panel);padding:.5rem}.accuse-list{display:grid;gap:.35rem}.accuse-option{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:6px;cursor:pointer}.accuse-option:hover{background:#0000000a}@media(prefers-color-scheme:dark){.accuse-option:hover{background:#ffffff0f}}.accuse-name{font-weight:600}.accuse-role{color:var(--muted)}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.btn-primary,.btn-secondary{padding:.5rem .8rem;border-radius:10px;cursor:pointer;border:1px solid var(--primary-border);background:var(--primary-bg);color:var(--text)}.btn-secondary{border-color:var(--border);background:var(--bg)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.info-actions{display:flex;gap:.5rem;align-items:center}.instructions-list{margin:.25rem 1.25rem;padding-left:1rem;line-height:1.4;color:var(--text)}.instructions-list li{margin:.25rem 0}.cookie-consent-backdrop{z-index:100;background:#000000b3}.cookie-consent-sheet{max-width:600px}.cookie-options{display:flex;flex-direction:column;gap:1rem}.cookie-option{padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.cookie-option-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.cookie-checkbox-label{cursor:pointer}.cookie-checkbox-label input[type=checkbox]{margin-right:.5rem;cursor:pointer}.cookie-required{color:#d9534f;font-size:.85rem;font-weight:600}.cookie-optional{color:var(--muted);font-size:.85rem}.cookie-description{margin:0;font-size:.9rem;color:var(--muted);line-height:1.4}
