*{box-sizing:border-box;margin:0;padding:0}html,body{color:#3a2d00;-webkit-text-size-adjust:100%;background:#fffbea;height:100%;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic,sans-serif;overflow:hidden}#root{height:100%}.chat-root{background:#fffbea;flex-direction:column;width:100%;height:100dvh;display:flex}.chat-header{background:#3d2e15;border-bottom:2px solid #f5b800;width:100%;box-shadow:0 2px 10px #3d2e1538}.chat-header-inner{justify-content:space-between;align-items:center;gap:10px;max-width:820px;margin:0 auto;padding:14px 20px;display:flex}.chat-header-title-wrap{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.chat-header-title{color:#fff4d6;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.04em;margin:0;font-size:19px;font-weight:800;line-height:1.2;overflow:hidden}.chat-avatar{color:#fff;background:#f5b800;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.chat-avatar-header{box-shadow:0 0 0 2px #f5b80059,0 0 16px #f5b8004d}.chat-avatar-star{width:18px;height:18px}.chat-header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex;position:relative}.chat-sister-btn{color:#b4d1f0;white-space:nowrap;background:#4a90e226;border:1px solid #4a90e2;border-radius:8px;flex-shrink:0;padding:8px 12px;font-size:11.5px;font-weight:700;text-decoration:none;transition:all .15s}.chat-sister-btn:hover{color:#d6e8fa;background:#4a90e24d;border-color:#6ba5eb}.chat-save-btn{color:#ffe4a8;white-space:nowrap;cursor:pointer;background:0 0;border:1px solid #f5b800;border-radius:8px;flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:700;transition:all .15s}.chat-save-btn.is-primary{color:#3d2e15;background:#f5b800;border-color:#f5b800}.chat-save-btn.is-primary:hover:not(:disabled){background:#ffd93d;border-color:#ffd93d}.chat-menu-btn{color:#ffe4a8;cursor:pointer;background:0 0;border:1px solid #f5b800;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;font-weight:700;line-height:1;transition:background .15s;display:flex}.chat-menu-btn:hover{background:#f5b80038}.chat-menu{z-index:100;background:#fff;border:1px solid #f2db6a;border-radius:10px;min-width:220px;padding:6px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #785a002e}.chat-menu button{text-align:left;color:#3a2d00;cursor:pointer;background:0 0;border:none;border-radius:6px;width:100%;padding:10px 14px;font-family:inherit;font-size:13px;display:block}.chat-menu button:hover:not(:disabled){background:#fff8e1}.chat-menu button:disabled{color:#bfb494;cursor:not-allowed}.chat-menu-link{color:#b58900;border-top:1px solid #f7efd0;margin-top:4px;padding:10px 14px;font-family:inherit;font-size:13px;text-decoration:none;display:block}.chat-menu-link:hover{background:#fff8e1;text-decoration:underline}.chat-footer-note{color:#d8c07e;text-align:center;letter-spacing:.02em;max-width:820px;margin:4px auto 0;padding:0 20px 8px;font-size:10.5px;line-height:1.6}.chat-footer-links{margin-left:10px;display:inline-block}.chat-footer-links a{color:#ffd93d;margin:0 2px;text-decoration:none}.chat-footer-links a:hover{text-decoration:underline}.chat-body{-webkit-overflow-scrolling:touch;background:#fffbea;flex:1;width:100%;overflow-y:auto}.chat-body-inner{flex-direction:column;gap:14px;max-width:820px;margin:0 auto;padding:20px;display:flex}.chat-msg-row{align-items:flex-start;gap:10px;display:flex}.chat-msg-bubble{color:#3a2d00;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;border-radius:14px;max-width:80%;padding:12px 16px;font-size:14.5px;line-height:1.7;box-shadow:0 1px 3px #785a0014}.chat-form{width:100%;padding-bottom:env(safe-area-inset-bottom);background:#3d2e15;border-top:2px solid #f5b800;box-shadow:0 -2px 10px #3d2e1538}.chat-form-inner{align-items:flex-end;gap:8px;max-width:820px;margin:0 auto;padding:14px 20px;display:flex}.chat-textarea{color:#3a2d00;resize:none;background:#fff;border:1px solid #e3ca6e;border-radius:12px;outline:none;flex:1;min-height:46px;max-height:300px;padding:12px 16px;font-family:inherit;font-size:16px;line-height:1.6;overflow-y:auto}.chat-textarea:focus{border-color:#f5b800;box-shadow:0 0 0 3px #f5b80040}.chat-send-btn{color:#3d2e15;cursor:pointer;background:#f5b800;border:none;border-radius:12px;flex-shrink:0;height:46px;padding:12px 20px;font-size:14.5px;font-weight:700;transition:background .15s;box-shadow:0 2px 6px #f5b80059}.chat-send-btn:hover:not(:disabled){background:#ffd93d}.chat-loading{color:#b8953e;padding:4px 40px;font-size:12px}.chat-offline{color:#5a4500;text-align:center;background:#ffe4a8;border:1px solid #e3a900;border-radius:10px;margin:4px 0;padding:10px 16px;font-size:13px}.chat-undo-bar{justify-content:flex-end;margin:-4px 40px 0;display:flex}.chat-undo-btn{color:#7a5f00;cursor:pointer;background:#fff8e1d9;border:1px solid #f2db6a;border-radius:999px;padding:6px 14px;font-size:11.5px;font-weight:600;transition:all .15s}.chat-undo-btn:hover{color:#4a3a00;background:#ffe98a;border-color:#d4a017}.chat-error{background:#fff3b8;border:1px solid #e3a900;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:16px 20px;display:flex}.chat-error-retry{color:#3d2e15;cursor:pointer;background:#f5b800;border:none;border-radius:8px;padding:8px 20px;font-size:13px;font-weight:700}@media (max-width:640px){.chat-header-inner{padding:11px 14px}.chat-header-title{letter-spacing:.01em;white-space:normal;font-size:15px;line-height:1.25}.chat-avatar{width:30px;height:30px;font-size:11px}.chat-avatar-star{width:15px;height:15px}.chat-save-btn{padding:7px 12px;font-size:11px}.chat-sister-btn{padding:7px 10px;font-size:10.5px}.chat-menu-btn{width:32px;height:32px;font-size:18px}.chat-menu{min-width:200px}.chat-footer-note{padding:0 12px 6px;font-size:10px}.chat-body-inner{gap:12px;padding:14px}.chat-msg-bubble{border-radius:12px;max-width:86%;padding:10px 13px;font-size:14px}.chat-form-inner{gap:6px;padding:10px 12px}.chat-textarea{border-radius:10px;min-height:42px;padding:10px 12px}.chat-send-btn{border-radius:10px;height:42px;padding:10px 14px;font-size:13px}.chat-undo-bar{margin:-4px 8px 0}.chat-undo-btn{padding:5px 12px;font-size:11px}}
