*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans JP,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}a{color:#64b5f6;text-decoration:none}a:hover{color:#42a5f5}.chat-window{display:flex;flex-direction:column;height:100%;background:linear-gradient(135deg,#e3f2fd,#f0f4ff);border-radius:24px;overflow:hidden;box-shadow:0 8px 32px #6496c826}.messages-container{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#7796b8;text-align:center}.empty-state p{margin:8px 0;font-size:18px}.empty-state .hint{font-size:14px;opacity:.7}.message{display:flex;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.admin{justify-content:flex-start}.message-content{max-width:70%;padding:16px 20px;border-radius:20px;box-shadow:0 2px 8px #0000001a}.message.user .message-content{background:linear-gradient(135deg,#64b5f6,#42a5f5);color:#fff;border-bottom-right-radius:4px}.message.admin .message-content{background:#fff;color:#333;border-bottom-left-radius:4px}.message-sender{font-size:12px;font-weight:600;margin-bottom:6px;opacity:.8}.message.user .message-sender{color:#ffffffe6}.message.admin .message-sender{color:#64b5f6}.message-text{font-size:15px;line-height:1.5;word-wrap:break-word}.message-time{font-size:11px;margin-top:6px;opacity:.7}.input-form{display:flex;gap:12px;padding:20px 24px;background:#fff;border-top:1px solid rgba(100,181,246,.2)}.input-container{flex:1;position:relative}.message-input{width:100%;padding:14px 20px;border:2px solid rgba(100,181,246,.3);border-radius:24px;font-size:15px;outline:none;transition:all .3s ease;background:#f8fbff}.validation-error{position:absolute;bottom:-20px;left:20px;font-size:12px;color:#f44336;background:#fff;padding:2px 8px;border-radius:4px;white-space:nowrap}.message-input:focus{border-color:#64b5f6;background:#fff;box-shadow:0 0 0 3px #64b5f61a}.send-button{padding:14px 32px;background:linear-gradient(135deg,#64b5f6,#42a5f5);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #64b5f64d}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #64b5f666}.send-button:disabled{opacity:.5;cursor:not-allowed}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#64b5f61a;border-radius:4px}.messages-container::-webkit-scrollbar-thumb{background:#64b5f64d;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#64b5f680}.user-page{min-height:100vh;background:linear-gradient(135deg,#e3f2fd,#bbdefb);padding:24px;display:flex;flex-direction:column}.header{text-align:center;margin-bottom:32px;animation:slideDown .5s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}.logo-icon{font-size:48px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.logo h1{font-size:48px;font-weight:800;background:linear-gradient(135deg,#42a5f5,#1976d2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.subtitle{font-size:18px;color:#5c7a99;margin:0}.new-thread-btn{margin-top:16px;padding:12px 24px;background:linear-gradient(135deg,#64b5f6,#42a5f5);color:#fff;border:none;border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #64b5f64d}.new-thread-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #64b5f666;background:linear-gradient(135deg,#42a5f5,#1976d2)}.new-thread-btn:active{transform:translateY(0);box-shadow:0 2px 6px #64b5f64d}.chat-container{flex:1;max-width:900px;width:100%;margin:0 auto;display:flex;flex-direction:column;animation:fadeIn .5s ease-out .2s both}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:24px;color:#64b5f6}@media(max-width:768px){.user-page{padding:16px}.logo h1{font-size:36px}.subtitle{font-size:16px}}.admin-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8eef5);display:flex;flex-direction:column}.admin-header{background:linear-gradient(135deg,#42a5f5,#1976d2);color:#fff;padding:24px 32px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.admin-header>div:first-child{flex:1}.admin-header h1{margin:0 0 8px;font-size:32px;font-weight:700}.admin-header p{margin:0;opacity:.9;font-size:16px}.websocket-status{padding:8px 16px;border-radius:12px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.websocket-status.connected{background:#fff3;color:#fff}.websocket-status.disconnected{background:#ffffff26;color:#ffffffe6}.notification-banner{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #f57c00;padding:16px 24px;margin:16px 24px 0;border-radius:12px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #f57c0026;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-icon{font-size:24px;animation:ring 1s ease-in-out infinite}@keyframes ring{0%,to{transform:rotate(0)}10%,30%{transform:rotate(-10deg)}20%,40%{transform:rotate(10deg)}}.notification-text{flex:1;color:#e65100;font-weight:600;font-size:15px}.notification-dismiss{background:none;border:none;color:#f57c00;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:8px;transition:all .2s ease}.notification-dismiss:hover{background:#f57c001a}.admin-content{flex:1;display:flex;gap:24px;padding:24px;overflow:hidden}.threads-sidebar{width:350px;background:#fff;border-radius:16px;box-shadow:0 4px 16px #00000014;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px 24px;border-bottom:1px solid #e3f2fd;display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.thread-count{background:#e3f2fd;color:#42a5f5;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:600}.status-filter{padding:12px 16px;display:flex;gap:8px;border-bottom:1px solid #e3f2fd}.filter-btn{flex:1;padding:10px 16px;border:2px solid #e3f2fd;background:#fff;border-radius:12px;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#64b5f6;background:#f8fbff}.filter-btn.active{background:linear-gradient(135deg,#64b5f6,#42a5f5);color:#fff;border-color:#42a5f5;box-shadow:0 2px 8px #64b5f64d}.threads-list{flex:1;overflow-y:auto;padding:8px}.empty-threads{display:flex;align-items:center;justify-content:center;height:200px;color:#999}.thread-item{padding:16px;margin-bottom:8px;border-radius:12px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.thread-item:hover{background:#f8fbff;border-color:#e3f2fd}.thread-item.active{background:linear-gradient(135deg,#e3f2fd,#f0f7ff);border-color:#64b5f6}.thread-title{font-size:15px;font-weight:600;color:#333;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#999}.status{padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600}.status-pending{background:#fff3e0;color:#f57c00}.status-answered{background:#e8f5e9;color:#2e7d32}.status-closed{background:#f5f5f5;color:#757575}.thread-date{font-size:12px}.chat-area{flex:1;display:flex;flex-direction:column}.chat-actions{background:#fff;padding:12px 16px;border-radius:16px 16px 0 0;box-shadow:0 4px 16px #00000014;margin-bottom:-8px;display:flex;justify-content:flex-end;gap:12px}.mark-answered-btn{padding:10px 20px;background:linear-gradient(135deg,#66bb6a,#43a047);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #43a0474d;display:flex;align-items:center;gap:6px}.mark-answered-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #43a04766;background:linear-gradient(135deg,#43a047,#2e7d32)}.mark-answered-btn:active{transform:translateY(0)}.no-selection{flex:1;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:16px;box-shadow:0 4px 16px #00000014;color:#999;font-size:18px}.loading{flex:1;display:flex;align-items:center;justify-content:center;font-size:18px;color:#64b5f6}.threads-list::-webkit-scrollbar{width:6px}.threads-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:3px}.threads-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.threads-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.api-key-prompt{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.prompt-card{background:#fff;padding:48px;border-radius:24px;box-shadow:0 8px 32px #0000001f;max-width:480px;width:100%;text-align:center;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.prompt-card h2{margin:0 0 16px;font-size:28px;color:#333;font-weight:700}.prompt-card p{margin:0 0 32px;color:#666;font-size:16px}.auth-error{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:12px;margin-bottom:24px;font-size:14px;font-weight:500}.api-key-input{width:100%;padding:16px 20px;border:2px solid #e3f2fd;border-radius:16px;font-size:16px;margin-bottom:16px;transition:all .3s ease;box-sizing:border-box}.api-key-input:focus{outline:none;border-color:#64b5f6;box-shadow:0 0 0 4px #64b5f61a}.api-key-submit{width:100%;padding:16px;background:linear-gradient(135deg,#64b5f6,#42a5f5);color:#fff;border:none;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #64b5f64d}.api-key-submit:hover{transform:translateY(-2px);box-shadow:0 6px 16px #64b5f666;background:linear-gradient(135deg,#42a5f5,#1976d2)}.api-key-submit:active{transform:translateY(0)}@media(max-width:1024px){.admin-content{flex-direction:column}.threads-sidebar{width:100%;max-height:300px}.prompt-card{padding:32px 24px}}#root{width:100%;height:100vh;margin:0;padding:0}
