body{font-family:Segoe UI,Meiryo,sans-serif;background:#f5f5f5;margin:0;padding:0}.header{background:#1976d2;color:#fff;padding:24px 0 16px;text-align:center;box-shadow:0 2px 8px #00000014}.header-title{font-size:1.5em;font-weight:700;margin-bottom:8px}.header-title .nowrap{white-space:nowrap}.header-dates{font-size:1em;color:#e3f2fd;margin-bottom:8px}.header-uid{font-size:.9em;color:#e3f2fd;background:#ffffff1a;padding:4px 12px;border-radius:12px;display:inline-block;font-family:Courier New,monospace}.chat-container{max-width:800px;margin:32px auto 0;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;padding:24px 16px}.msg{display:flex;margin-bottom:18px;align-items:flex-start}.msg.assistant,.msg.direct{justify-content:flex-start}.msg.user{justify-content:flex-end}.msg.user .bubble{background:#e3f2fd;color:#1565c0;align-self:flex-start;margin-left:auto;margin-right:0;width:fit-content;overflow-wrap:break-word;text-align:left}.msg.assistant .bubble,.msg.direct .bubble{background:#f1f8e9;color:#388e3c;align-self:flex-end}.bubble{border-radius:8px;padding:12px 16px;max-width:70%;box-shadow:0 1px 3px #0000000a;font-size:1.08em;word-break:break-word}.meta{font-size:.85em;color:#888;margin-bottom:2px}.role-label{font-size:.95em;font-weight:700;margin-bottom:2px;color:#1976d2}.msg.assistant .role-label,.msg.direct .role-label{color:#388e3c}.role-label-row{display:flex;align-items:center;margin-bottom:2px}.msg.assistant .role-label-row,.msg.direct .role-label-row{justify-content:flex-start}.msg.user .role-label-row{justify-content:flex-end}.loading{text-align:center;font-size:1.2em;color:#1976d2;margin:40px 0}.no-data{text-align:center;font-size:1.1em;color:#666;margin:40px 0}.error-container{max-width:800px;margin:32px auto 0;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;padding:24px 16px}.error-message{text-align:center;font-size:1.1em;color:#d32f2f;margin:20px 0}.error-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f5f5f5}.error-content{text-align:center;background:#fff;padding:48px 32px;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:500px}.error-content h1{font-size:4em;color:#1976d2;margin:0 0 16px}.error-content h2{font-size:1.5em;color:#333;margin:0 0 16px}.error-content p{color:#666;margin:8px 0;line-height:1.6}.error-example{margin-top:24px;padding:16px;background:#f5f5f5;border-radius:8px}.error-example code{background:#e3f2fd;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;color:#1976d2}.chat-image{max-width:480px;max-height:480px;width:100%;height:auto;border-radius:8px;box-shadow:0 1px 3px #00000014;display:block}.chat-image.image-square{width:480px;height:480px;object-fit:cover}.chat-image.image-normal{width:auto;height:auto;max-width:480px;max-height:480px}.image-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px}.image-modal-content{position:relative;max-width:96vw;max-height:92vh}.image-modal-content img{max-width:96vw;max-height:92vh;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000004d}.image-modal-close{position:absolute;top:-12px;right:-12px;width:36px;height:36px;border:none;border-radius:50%;background:#fff;color:#333;font-size:20px;cursor:pointer;box-shadow:0 2px 6px #0003}.image-modal-close:hover{background:#f1f1f1}
