Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                <!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1">

  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
  <style>
    .fixed {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      z-index: 99;
    }
  </style>
  <script>
    $(window).scroll(function() {
      var sticky = $('.fancytext'),
        scroll = $(window).scrollTop();
      if (scroll >= 100) sticky.addClass('fixed');
      else sticky.removeClass('fixed');
    });
  </script>
</head>

<body>
  <textarea type="text" class="form-control fancytext" style="width:100%;   color:#000000" required="required" name="text" placeholder="โปรดกรอกตัวอักษรของคุณที่นี่.." value=""></textarea>
  <br />
  <div id="result">
    <div class="input-group mb-3"><input type="text" class="form-control text-1" value="𝔓𝔯𝔢𝔳𝔦𝔢𝔴 𝔗𝔢𝔵𝔱" id="copy_0" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_0">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-2" value="𝕻𝖗𝖊𝖛𝖎𝖊𝖜 𝕿𝖊𝖝𝖙" id="copy_1" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_1">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-3" value="✋♪  Ƥ𝔯Ⓔᐯ𝔦乇ω т乇𝐗𝐭  😈🌷" id="copy_2" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_2">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-4" value="𝓟𝓻𝓮𝓿𝓲𝓮𝔀 𝓣𝓮𝔁𝓽" id="copy_3" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_3">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-5" value="𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉" id="copy_4" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_4">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-6" value="ℙ𝕣𝕖𝕧𝕚𝕖𝕨 𝕋𝕖𝕩𝕥" id="copy_5" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_5">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-7" value="Preview Text" id="copy_6" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_6">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-8" value="🐓 ⋆ 🐤  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  🐤 ⋆ 🐓" id="copy_7" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_7">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-9" value="ᴘʀᴇᴠɪᴇᴡ ᴛᴇxᴛ" id="copy_8" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_8">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-10" value="ʇxǝ⊥ ʍǝıʌǝɹԀ" id="copy_9" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_9">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-11" value="P⃣&nbsp;&nbsp;&nbsp;r⃣&nbsp;&nbsp;&nbsp;e⃣&nbsp;&nbsp;&nbsp;v⃣&nbsp;&nbsp;&nbsp;i⃣&nbsp;&nbsp;&nbsp;e⃣&nbsp;&nbsp;&nbsp;w⃣ &nbsp;&nbsp;&nbsp;T⃣&nbsp;&nbsp;&nbsp;e⃣&nbsp;&nbsp;&nbsp;x⃣&nbsp;&nbsp;&nbsp;t⃣" id="copy_10" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_10">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-12" value="P⃞ &nbsp;&nbsp; r⃞ &nbsp;&nbsp; e⃞ &nbsp;&nbsp; v⃞ &nbsp;&nbsp; i⃞ &nbsp;&nbsp; e⃞ &nbsp;&nbsp; w⃞  &nbsp;&nbsp; T⃞ &nbsp;&nbsp; e⃞ &nbsp;&nbsp; x⃞ &nbsp;&nbsp; t⃞" id="copy_11" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_11">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-13" value="🄿🅁🄴🅅🄸🄴🅆 🅃🄴🅇🅃" id="copy_12" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_12">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-14" value="ƚxɘT wɘivɘɿꟼ" id="copy_13" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_13">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-15" value="P̸̡̛̬̪̙͎̻̺̹̻̎͆̇̋̆r̸̡͙̦̺̜̪̋̅͌͋̈̈́̀̈́͠͝ȩ̶̯͙̰̜̈́̂̒͠v̸̛͖̰̤̗̝͕̆͊̐̂́̀͜͝͝ị̵̡̲̩̘̟͎̫̝̊̀̎̌̎̈́͂̀̕ẻ̴͓͈̗̖̞̖̣̯̰̓͑͊̐̕w̷̨̛̟͎̗͈̯̘̤͆͆̇͒̈̋̈͠ ̶̲̮̦͇̣̎̾́ͅT̴̖̜̄͋̄͋̇̄̄͗͘͝e̶̳̰̲͙̼͓̣̰͕̩͊̿̐͆͗̽x̵̼̫̙͇̘̗̒̄̽̾̎̑̽̀̾̚t̴͙́̈́͝" id="copy_14" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_14">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-16" value="🅿🆁🅴🆅🅸🅴🆆 🆃🅴🆇🆃" id="copy_15" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_15">Copy</span></div>
    </div>

    <div class="input-group mb-3"><input type="text" class="form-control text-17" value="ₚᵣₑᵥᵢₑw ₜₑₓₜ" id="copy_16" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_16">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-18" value="ᴾʳᵉᵛⁱᵉʷ ᵀᵉˣᵗ" id="copy_17" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_17">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-19" value="Ⓟⓡⓔⓥⓘⓔⓦ Ⓣⓔⓧⓣ" id="copy_18" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_18">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-20" value="קгєשเєฬ ՇєאՇ" id="copy_19" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_19">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-21" value="Pɾҽʋιҽɯ Tҽxƚ" id="copy_20" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_20">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-22" value="քʀɛʋɨɛա ȶɛӼȶ" id="copy_21" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_21">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-23" value="ᎮᏒᏋᏉᎥᏋᏇ ᏖᏋጀᏖ" id="copy_22" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_22">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-24" value="℘ཞɛ۷ıɛῳ ɬɛҳɬ" id="copy_23" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_23">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-25" value="prēงiēຟ tēxt" id="copy_24" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_24">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-26" value="𝐏𝐫𝐞𝐯𝐢𝐞𝐰 𝐓𝐞𝐱𝐭" id="copy_25" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_25">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-27" value="𝗣𝗿𝗲𝘃𝗶𝗲𝘄 𝗧𝗲𝘅𝘁" id="copy_26" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_26">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-28" value="𝘗𝘳𝘦𝘷𝘪𝘦𝘸 𝘛𝘦𝘹𝘵" id="copy_27" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_27">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-29" value="𝙋𝙧𝙚𝙫𝙞𝙚𝙬 𝙏𝙚𝙭𝙩" id="copy_28" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_28">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-30" value="𝙿𝚛𝚎𝚟𝚒𝚎𝚠 𝚃𝚎𝚡𝚝" id="copy_29" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_29">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-31" value="PЯΣVIΣЩ ƬΣXƬ" id="copy_30" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_30">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-32" value="ρяєνιєω тєχт" id="copy_31" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_31">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-33" value="þrêvïêw †êx†" id="copy_32" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_32">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-34" value="₱ⱤɆVłɆ₩ ₮ɆӾ₮" id="copy_33" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_33">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-35" value="卩尺乇ᐯ丨乇山 ㄒ乇乂ㄒ" id="copy_34" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_34">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-36" value="ア尺乇√ノ乇W イ乇メイ" id="copy_35" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_35">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-37" value="【P】【r】【e】【v】【i】【e】【w】 【T】【e】【x】【t】" id="copy_36" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_36">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-38" value="『P』『r』『e』『v』『i』『e』『w』 『T』『e』『x』『t』" id="copy_37" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_37">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-39" value="≋P≋r≋e≋v≋i≋e≋w≋ ≋T≋e≋x≋t≋" id="copy_38" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_38">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-40" value="░P░r░e░v░i░e░w░ ░T░e░x░t░" id="copy_39" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_39">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-41" value="(っ◔◡◔)っ ♥ Preview Text ♥" id="copy_40" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_40">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-42" value="Preview Text 閲ワョ" id="copy_41" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_41">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-43" value="Preview░Text (閲ワョ)" id="copy_42" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_42">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-44" value="【&#65279;Preview Text】" id="copy_43" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_43">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-45" value="˜”*°•.˜”*°• Preview Text •°*”˜.•°*”˜" id="copy_44" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_44">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-46" value="[̲̅P][̲̅r][̲̅e][̲̅v][̲̅i][̲̅e][̲̅w] [̲̅T][̲̅e][̲̅x][̲̅t]" id="copy_45" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_45">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-47" value="P҉r҉e҉v҉i҉e҉w҉ ҉T҉e҉x҉t҉" id="copy_46" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_46">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-48" value="φɾҽѵìҽա Ͳҽ×է" id="copy_47" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_47">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-49" value="ᑭᖇEᐯIEᗯ TE᙭T" id="copy_48" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_48">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-50" value="ᕵᖇᘿᐺᓰᘿᘺ ᖶᘿ᙭ᖶ" id="copy_49" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_49">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-51" value="P̶r̶e̶v̶i̶e̶w̶ ̶T̶e̶x̶t̶" id="copy_50" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_50">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-52" value="P̴r̴e̴v̴i̴e̴w̴ ̴T̴e̴x̴t̴" id="copy_51" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_51">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-53" value="P̷r̷e̷v̷i̷e̷w̷ ̷T̷e̷x̷t̷" id="copy_52" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_52">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-54" value="P̲r̲e̲v̲i̲e̲w̲ ̲T̲e̲x̲t̲" id="copy_53" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_53">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-55" value="P̳r̳e̳v̳i̳e̳w̳ ̳T̳e̳x̳t̳" id="copy_54" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_54">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-56" value="P̾r̾e̾v̾i̾e̾w̾ ̾T̾e̾x̾t̾" id="copy_55" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_55">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-57" value="P♥r♥e♥v♥i♥e♥w♥ ♥T♥e♥x♥t" id="copy_56" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_56">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-58" value="P͎r͎e͎v͎i͎e͎w͎ ͎T͎e͎x͎t͎" id="copy_57" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_57">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-59" value="P͓̽r͓̽e͓̽v͓̽i͓̽e͓̽w͓̽ ͓̽T͓̽e͓̽x͓̽t͓̽" id="copy_58" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_58">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-60" value="Wingdings: 🏱︎❒︎♏︎❖︎♓︎♏︎⬥︎ ❄︎♏︎⌧︎⧫︎" id="copy_59" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_59">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-61" value="✴  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  ✴" id="copy_60" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_60">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-62" value="✶  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  ✶" id="copy_61" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_61">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-63" value="✴。  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  。✴" id="copy_62" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_62">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-64" value="🐳  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  🐳" id="copy_63" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_63">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-65" value="—(••÷  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  ÷••(—" id="copy_64" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_64">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-66" value="👊😎  𝓟яε𝐯ᶤ€ʷ 𝓉ᵉ𝔁𝓣  ★🐙" id="copy_65" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_65">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-67" value="💀♪  𝕡𝕣Ⓔᐯᶤ𝐄ω 丅乇𝐗Ť  ☞🐙" id="copy_66" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_66">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-68" value="`•.¸¸.•´´¯`••._.• ρⓡєⓥเ𝓔Ŵ 𝓣ε𝔁𝔱 •._.••`¯´´•.¸¸.•`" id="copy_67" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_67">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-69" value="🐣💜  ƤяⒺν𝓘ᵉᗯ тᵉX𝐭  🎃🐠" id="copy_68" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_68">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-70" value="|!¤*'~``~'*¤!| ρŕ𝑒𝕍เⓔ𝓦 ţ𝔼𝔵Ŧ |!¤*'~``~'*¤!|" id="copy_69" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_69">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-71" value="♘💔  קŕᵉ𝐯i𝐄Ⓦ 𝐓ex𝐭  ♗🐸" id="copy_70" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_70">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-72" value="🐲😎  𝓅ŕⓔᵛĮ𝐞𝓌 Ť𝒆𝓧𝔱  ☢♙" id="copy_71" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_71">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-73" value="¸,ø¤º°`°º¤ø,¸¸,ø¤º° ρ𝓇є𝐕𝒾€ฬ Ŧεx𝐭 °º¤ø,¸¸,ø¤º°`°º¤ø,¸" id="copy_72" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_72">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-74" value="👣🎯  ρᖇᗴνᶤ𝐞𝐰 𝔱Ẹ𝔵𝓽  ✊🍧" id="copy_73" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_73">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-75" value="🍔🍓  ρŕє𝐯𝔦є𝓌 Ⓣε𝕩𝓣  🍟🐠" id="copy_74" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_74">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-76" value="░▒▓█►─═  𝓅RẸV𝐢εᗯ 𝓉𝒆𝕩𝓽 ═─◄█▓▒░" id="copy_75" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_75">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-77" value="]|I{•------» ᑭR乇𝕧Ꭵe𝔀 𝐓€x丅 «------•}I|[" id="copy_76" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_76">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-78" value="♧☹  𝔭Ř𝐄ν𝒾ε𝐖 𝕥є𝓍𝓽  💜♝" id="copy_77" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_77">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-79" value="💞🎄  ƤR乇ѶĮⒺ𝓌 ᵗe𝔁𝐭  👤♕" id="copy_78" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_78">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-80" value="🐊♤  ⓟ𝓇ⒺV𝓲ew Ťєx𝐭  🐳👺" id="copy_79" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_79">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-81" value="🎄🎅  𝓹ⓇᵉVƗє𝓦 𝓣εχ𝐓  ♨🍩" id="copy_80" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_80">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-82" value="💢♖  pг𝕖𝐕ᶤє𝐖 T𝔼ⓍŤ  ♖♙" id="copy_81" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_81">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-83" value="ඏ🐚  ℙ尺𝔢v𝓲єŴ 𝕥E𝓍t  ♝💚" id="copy_82" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_82">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-84" value="🔥💔  ⓟⓇєViEW t𝐄𝕩𝐭  🎉♜" id="copy_83" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_83">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-85" value="😈☞  ℙ𝕣乇νiᵉ𝓦 𝐭𝑒Xţ  💲♤" id="copy_84" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_84">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-86" value="♔☠  𝓹R€ᐯ丨ᗴŴ Tєx𝔱  💚💢" id="copy_85" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_85">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-87" value=".  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  ." id="copy_86" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_86">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-88" value="🐢  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  🐢" id="copy_87" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_87">Copy</span></div>
    </div>
    <div class="input-group mb-3"><input type="text" class="form-control text-89" value="🐞 ⋆ 🐾  🎀  𝒫𝓇𝑒𝓋𝒾𝑒𝓌 𝒯𝑒𝓍𝓉  🎀  🐾 ⋆ 🐞" id="copy_88" readonly="readonly">
      <div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_88">Copy</span></div>
    </div>
  </div>
  <center>
    <button class="btn btn-primary loadmore">ดูต่อไป</button>
  </center>

  <hr />

  <script>
    /*!
     * clipboard.js v2.0.0
     * https://zenorocha.github.io/clipboard.js
     * 
     * Licensed MIT © Zeno Rocha
     */
    ! function(t, e) {
      "object" == typeof exports && "object" == typeof module ? module.exports = e() : "function" == typeof define && define.amd ? define([], e) : "object" == typeof exports ? exports.ClipboardJS = e() : t.ClipboardJS = e()
    }(this, function() {
      return function(t) {
        function e(o) {
          if (n[o]) return n[o].exports;
          var r = n[o] = {
            i: o,
            l: !1,
            exports: {}
          };
          return t[o].call(r.exports, r, r.exports, e), r.l = !0, r.exports
        }
        var n = {};
        return e.m = t, e.c = n, e.i = function(t) {
          return t
        }, e.d = function(t, n, o) {
          e.o(t, n) || Object.defineProperty(t, n, {
            configurable: !1,
            enumerable: !0,
            get: o
          })
        }, e.n = function(t) {
          var n = t && t.__esModule ? function() {
            return t.default
          } : function() {
            return t
          };
          return e.d(n, "a", n), n
        }, e.o = function(t, e) {
          return Object.prototype.hasOwnProperty.call(t, e)
        }, e.p = "", e(e.s = 3)
      }([function(t, e, n) {
        var o, r, i;
        ! function(a, c) {
          r = [t, n(7)], o = c, void 0 !== (i = "function" == typeof o ? o.apply(e, r) : o) && (t.exports = i)
        }(0, function(t, e) {
          "use strict";

          function n(t, e) {
            if (!(t instanceof e)) throw new TypeError("Cannot call a class as a function")
          }
          var o = function(t) {
              return t && t.__esModule ? t : {
                default: t
              }
            }(e),
            r = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(t) {
              return typeof t
            } : function(t) {
              return t && "function" == typeof Symbol && t.constructor === Symbol && t !== Symbol.prototype ? "symbol" : typeof t
            },
            i = function() {
              function t(t, e) {
                for (var n = 0; n < e.length; n++) {
                  var o = e[n];
                  o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(t, o.key, o)
                }
              }
              return function(e, n, o) {
                return n && t(e.prototype, n), o && t(e, o), e
              }
            }(),
            a = function() {
              function t(e) {
                n(this, t), this.resolveOptions(e), this.initSelection()
              }
              return i(t, [{
                key: "resolveOptions",
                value: function() {
                  var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
                  this.action = t.action, this.container = t.container, this.emitter = t.emitter, this.target = t.target, this.text = t.text, this.trigger = t.trigger, this.selectedText = ""
                }
              }, {
                key: "initSelection",
                value: function() {
                  this.text ? this.selectFake() : this.target && this.selectTarget()
                }
              }, {
                key: "selectFake",
                value: function() {
                  var t = this,
                    e = "rtl" == document.documentElement.getAttribute("dir");
                  this.removeFake(), this.fakeHandlerCallback = function() {
                    return t.removeFake()
                  }, this.fakeHandler = this.container.addEventListener("click", this.fakeHandlerCallback) || !0, this.fakeElem = document.createElement("textarea"), this.fakeElem.style.fontSize = "12pt", this.fakeElem.style.border = "0", this.fakeElem.style.padding = "0", this.fakeElem.style.margin = "0", this.fakeElem.style.position = "absolute", this.fakeElem.style[e ? "right" : "left"] = "-9999px";
                  var n = window.pageYOffset || document.documentElement.scrollTop;
                  this.fakeElem.style.top = n + "px", this.fakeElem.setAttribute("readonly", ""), this.fakeElem.value = this.text, this.container.appendChild(this.fakeElem), this.selectedText = (0, o.default)(this.fakeElem), this.copyText()
                }
              }, {
                key: "removeFake",
                value: function() {
                  this.fakeHandler && (this.container.removeEventListener("click", this.fakeHandlerCallback), this.fakeHandler = null, this.fakeHandlerCallback = null), this.fakeElem && (this.container.removeChild(this.fakeElem), this.fakeElem = null)
                }
              }, {
                key: "selectTarget",
                value: function() {
                  this.selectedText = (0, o.default)(this.target), this.copyText()
                }
              }, {
                key: "copyText",
                value: function() {
                  var t = void 0;
                  try {
                    t = document.execCommand(this.action)
                  } catch (e) {
                    t = !1
                  }
                  this.handleResult(t)
                }
              }, {
                key: "handleResult",
                value: function(t) {
                  this.emitter.emit(t ? "success" : "error", {
                    action: this.action,
                    text: this.selectedText,
                    trigger: this.trigger,
                    clearSelection: this.clearSelection.bind(this)
                  })
                }
              }, {
                key: "clearSelection",
                value: function() {
                  this.trigger && this.trigger.focus(), window.getSelection().removeAllRanges()
                }
              }, {
                key: "destroy",
                value: function() {
                  this.removeFake()
                }
              }, {
                key: "action",
                set: function() {
                  var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : "copy";
                  if (this._action = t, "copy" !== this._action && "cut" !== this._action) throw new Error('Invalid "action" value, use either "copy" or "cut"')
                },
                get: function() {
                  return this._action
                }
              }, {
                key: "target",
                set: function(t) {
                  if (void 0 !== t) {
                    if (!t || "object" !== (void 0 === t ? "undefined" : r(t)) || 1 !== t.nodeType) throw new Error('Invalid "target" value, use a valid Element');
                    if ("copy" === this.action && t.hasAttribute("disabled")) throw new Error('Invalid "target" attribute. Please use "readonly" instead of "disabled" attribute');
                    if ("cut" === this.action && (t.hasAttribute("readonly") || t.hasAttribute("disabled"))) throw new Error('Invalid "target" attribute. You can\'t cut text from elements with "readonly" or "disabled" attributes');
                    this._target = t
                  }
                },
                get: function() {
                  return this._target
                }
              }]), t
            }();
          t.exports = a
        })
      }, function(t, e, n) {
        function o(t, e, n) {
          if (!t && !e && !n) throw new Error("Missing required arguments");
          if (!c.string(e)) throw new TypeError("Second argument must be a String");
          if (!c.fn(n)) throw new TypeError("Third argument must be a Function");
          if (c.node(t)) return r(t, e, n);
          if (c.nodeList(t)) return i(t, e, n);
          if (c.string(t)) return a(t, e, n);
          throw new TypeError("First argument must be a String, HTMLElement, HTMLCollection, or NodeList")
        }

        function r(t, e, n) {
          return t.addEventListener(e, n), {
            destroy: function() {
              t.removeEventListener(e, n)
            }
          }
        }

        function i(t, e, n) {
          return Array.prototype.forEach.call(t, function(t) {
            t.addEventListener(e, n)
          }), {
            destroy: function() {
              Array.prototype.forEach.call(t, function(t) {
                t.removeEventListener(e, n)
              })
            }
          }
        }

        function a(t, e, n) {
          return u(document.body, t, e, n)
        }
        var c = n(6),
          u = n(5);
        t.exports = o
      }, function(t, e) {
        function n() {}
        n.prototype = {
          on: function(t, e, n) {
            var o = this.e || (this.e = {});
            return (o[t] || (o[t] = [])).push({
              fn: e,
              ctx: n
            }), this
          },
          once: function(t, e, n) {
            function o() {
              r.off(t, o), e.apply(n, arguments)
            }
            var r = this;
            return o._ = e, this.on(t, o, n)
          },
          emit: function(t) {
            var e = [].slice.call(arguments, 1),
              n = ((this.e || (this.e = {}))[t] || []).slice(),
              o = 0,
              r = n.length;
            for (o; o < r; o++) n[o].fn.apply(n[o].ctx, e);
            return this
          },
          off: function(t, e) {
            var n = this.e || (this.e = {}),
              o = n[t],
              r = [];
            if (o && e)
              for (var i = 0, a = o.length; i < a; i++) o[i].fn !== e && o[i].fn._ !== e && r.push(o[i]);
            return r.length ? n[t] = r : delete n[t], this
          }
        }, t.exports = n
      }, function(t, e, n) {
        var o, r, i;
        ! function(a, c) {
          r = [t, n(0), n(2), n(1)], o = c, void 0 !== (i = "function" == typeof o ? o.apply(e, r) : o) && (t.exports = i)
        }(0, function(t, e, n, o) {
          "use strict";

          function r(t) {
            return t && t.__esModule ? t : {
              default: t
            }
          }

          function i(t, e) {
            if (!(t instanceof e)) throw new TypeError("Cannot call a class as a function")
          }

          function a(t, e) {
            if (!t) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
            return !e || "object" != typeof e && "function" != typeof e ? t : e
          }

          function c(t, e) {
            if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e);
            t.prototype = Object.create(e && e.prototype, {
              constructor: {
                value: t,
                enumerable: !1,
                writable: !0,
                configurable: !0
              }
            }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e)
          }

          function u(t, e) {
            var n = "data-clipboard-" + t;
            if (e.hasAttribute(n)) return e.getAttribute(n)
          }
          var l = r(e),
            s = r(n),
            f = r(o),
            d = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(t) {
              return typeof t
            } : function(t) {
              return t && "function" == typeof Symbol && t.constructor === Symbol && t !== Symbol.prototype ? "symbol" : typeof t
            },
            h = function() {
              function t(t, e) {
                for (var n = 0; n < e.length; n++) {
                  var o = e[n];
                  o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(t, o.key, o)
                }
              }
              return function(e, n, o) {
                return n && t(e.prototype, n), o && t(e, o), e
              }
            }(),
            p = function(t) {
              function e(t, n) {
                i(this, e);
                var o = a(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this));
                return o.resolveOptions(n), o.listenClick(t), o
              }
              return c(e, t), h(e, [{
                key: "resolveOptions",
                value: function() {
                  var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
                  this.action = "function" == typeof t.action ? t.action : this.defaultAction, this.target = "function" == typeof t.target ? t.target : this.defaultTarget, this.text = "function" == typeof t.text ? t.text : this.defaultText, this.container = "object" === d(t.container) ? t.container : document.body
                }
              }, {
                key: "listenClick",
                value: function(t) {
                  var e = this;
                  this.listener = (0, f.default)(t, "click", function(t) {
                    return e.onClick(t)
                  })
                }
              }, {
                key: "onClick",
                value: function(t) {
                  var e = t.delegateTarget || t.currentTarget;
                  this.clipboardAction && (this.clipboardAction = null), this.clipboardAction = new l.default({
                    action: this.action(e),
                    target: this.target(e),
                    text: this.text(e),
                    container: this.container,
                    trigger: e,
                    emitter: this
                  })
                }
              }, {
                key: "defaultAction",
                value: function(t) {
                  return u("action", t)
                }
              }, {
                key: "defaultTarget",
                value: function(t) {
                  var e = u("target", t);
                  if (e) return document.querySelector(e)
                }
              }, {
                key: "defaultText",
                value: function(t) {
                  return u("text", t)
                }
              }, {
                key: "destroy",
                value: function() {
                  this.listener.destroy(), this.clipboardAction && (this.clipboardAction.destroy(), this.clipboardAction = null)
                }
              }], [{
                key: "isSupported",
                value: function() {
                  var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : ["copy", "cut"],
                    e = "string" == typeof t ? [t] : t,
                    n = !!document.queryCommandSupported;
                  return e.forEach(function(t) {
                    n = n && !!document.queryCommandSupported(t)
                  }), n
                }
              }]), e
            }(s.default);
          t.exports = p
        })
      }, function(t, e) {
        function n(t, e) {
          for (; t && t.nodeType !== o;) {
            if ("function" == typeof t.matches && t.matches(e)) return t;
            t = t.parentNode
          }
        }
        var o = 9;
        if ("undefined" != typeof Element && !Element.prototype.matches) {
          var r = Element.prototype;
          r.matches = r.matchesSelector || r.mozMatchesSelector || r.msMatchesSelector || r.oMatchesSelector || r.webkitMatchesSelector
        }
        t.exports = n
      }, function(t, e, n) {
        function o(t, e, n, o, r) {
          var a = i.apply(this, arguments);
          return t.addEventListener(n, a, r), {
            destroy: function() {
              t.removeEventListener(n, a, r)
            }
          }
        }

        function r(t, e, n, r, i) {
          return "function" == typeof t.addEventListener ? o.apply(null, arguments) : "function" == typeof n ? o.bind(null, document).apply(null, arguments) : ("string" == typeof t && (t = document.querySelectorAll(t)), Array.prototype.map.call(t, function(t) {
            return o(t, e, n, r, i)
          }))
        }

        function i(t, e, n, o) {
          return function(n) {
            n.delegateTarget = a(n.target, e), n.delegateTarget && o.call(t, n)
          }
        }
        var a = n(4);
        t.exports = r
      }, function(t, e) {
        e.node = function(t) {
          return void 0 !== t && t instanceof HTMLElement && 1 === t.nodeType
        }, e.nodeList = function(t) {
          var n = Object.prototype.toString.call(t);
          return void 0 !== t && ("[object NodeList]" === n || "[object HTMLCollection]" === n) && "length" in t && (0 === t.length || e.node(t[0]))
        }, e.string = function(t) {
          return "string" == typeof t || t instanceof String
        }, e.fn = function(t) {
          return "[object Function]" === Object.prototype.toString.call(t)
        }
      }, function(t, e) {
        function n(t) {
          var e;
          if ("SELECT" === t.nodeName) t.focus(), e = t.value;
          else if ("INPUT" === t.nodeName || "TEXTAREA" === t.nodeName) {
            var n = t.hasAttribute("readonly");
            n || t.setAttribute("readonly", ""), t.select(), t.setSelectionRange(0, t.value.length), n || t.removeAttribute("readonly"), e = t.value
          } else {
            t.hasAttribute("contenteditable") && t.focus();
            var o = window.getSelection(),
              r = document.createRange();
            r.selectNodeContents(t), o.removeAllRanges(), o.addRange(r), e = o.toString()
          }
          return e
        }
        t.exports = n
      }])
    });
  </script>

  <!-- 
Author : Rohit Kumar
Version : 0.0.1
App Name : Fancy Text Generator
Website: https://www.iamrohit.in
Youtube: https://youtube.com/AskRohit 
-->

  <script>
    //try {
    var reverseIsDisabled = false;
    //<![CDATA[
    var luni = new Lunicode();
    luni.tools.creepify.options.maxHeight = 10;

    function backward(text) {
      return $("#english-text").val();
    }

    function createMap(chars) {
      var alphanum = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
      var i = 0;
      var map = {};
      for (var c of chars) {
        map[alphanum[i]] = c;
        i++;
      }
      return JSON.stringify(map);
    }

    function forward(text) {
      text = text.trim();
      if (text === "") {
        return "";
      }
      var finalText = "";
      finalText += applyCharMap(oldEnglishCharMap, text) + "\n\n";
      finalText += applyCharMap(medievalCharMap, text) + "\n\n";
      finalText += fullCrazy(text) + "\n\n";
      finalText += applyCharMap(cursiveCharMap, text) + "\n\n";
      finalText += scriptify(text) + "\n\n";
      finalText += applyCharMap(doubleStruckCharMap, text) + "\n\n";
      finalText += applyCharMap(wideTextCharMap, text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += luni.tools.tiny.encode(text) + "\n\n";
      finalText += luni.tools.flip.encode(text) + "\n\n";
      finalText += luni.tools.roundsquares.encode(text) + "\n\n";
      finalText += luni.tools.squares.encode(text) + "\n\n";
      finalText += applyCharMap(squaresCharMap, text) + "\n\n";
      finalText += luni.tools.mirror.encode(text) + "\n\n";
      finalText += luni.tools.creepify.encode(text) + "\n\n";
      finalText += applyCharMap(invertedSquaresCharMap, text) + "\n\n";
      finalText += applyCharMap(subscriptCharMap, text) + "\n\n";
      finalText += applyCharMap(superscriptCharMap, text) + "\n\n";
      finalText += luni.tools.bubbles.encode(text) + "\n\n";
      finalText += applyCharMap(squiggleCharMap, text) + "\n\n";
      finalText += applyCharMap(squiggle2CharMap, text) + "\n\n";
      finalText += applyCharMap(squiggle3CharMap, text) + "\n\n";
      finalText += applyCharMap(squiggle4CharMap, text) + "\n\n";
      finalText += applyCharMap(squiggle5CharMap, text) + "\n\n";
      finalText += applyCharMap(squiggle6CharMap, text) + "\n\n";
      finalText += applyCharMap(boldCharMap, text) + "\n\n";
      finalText += applyCharMap(boldSansCharMap, text) + "\n\n";
      finalText += applyCharMap(italicCharMap, text) + "\n\n";
      finalText += applyCharMap(boldItalicCharMap, text) + "\n\n";
      finalText += applyCharMap(monospaceCharMap, text) + "\n\n";
      finalText += applyCharMap(upperAnglesCharMap, text) + "\n\n";
      finalText += applyCharMap(greekCharMap, text) + "\n\n";
      finalText += applyCharMap(symbolsCharMap, text) + "\n\n";
      finalText += applyCharMap(currencyCharMap, text) + "\n\n";
      finalText += applyCharMap(asianStyleCharMap, text) + "\n\n";
      finalText += applyCharMap(asianStyle2CharMap, text) + "\n\n";
      finalText += thickBlockFramed(text) + "\n\n";
      finalText += diametricAngleFrame(text) + "\n\n";
      finalText += wavyJoiner(text) + "\n\n";
      finalText += dottyJoiner(text) + "\n\n";
      finalText += kirbyHug(text) + "\n\n";
      finalText += vaporwaveText(text) + "\n\n";
      finalText += littleSparkles(text) + "\n\n";
      finalText += weirdBox(text) + "\n\n";
      finalText += firework(text) + "\n\n";
      finalText += applyCharMap(bentTextCharMap, text) + "\n\n";
      finalText += applyCharMap(neonCharMap, text) + "\n\n";
      finalText += applyCharMap(futureAlienCharMap, text) + "\n\n";
      finalText += strikeThrough(text) + "\n\n";
      finalText += tildeStrikeThrough(text) + "\n\n";
      finalText += slashThrough(text) + "\n\n";
      finalText += underline(text) + "\n\n";
      finalText += doubleUnderline(text) + "\n\n";
      finalText += stinky(text) + "\n\n";
      finalText += heartsBetween(text) + "\n\n";
      finalText += arrowBelow(text) + "\n\n";
      finalText += crossAboveBelow(text) + "\n\n";
      finalText += "Wingdings: " + wingdings(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += crazyWithFlourishOrSymbols(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      finalText += cuteText(text) + "\n\n";
      return finalText.trim();
    }

    function crazyWithFlourishOrSymbols(text) {
      if (Math.random() < 0.7) return wrapInSymbols(crazifyText(text), 2);
      else return wrapInFlourish(crazifyText(text), 2);
    }

    function strikeThrough(text) {
      return text.split("").join("̶") + "̶";
    }

    function tildeStrikeThrough(text) {
      return text.split("").join("̴") + "̴";
    }

    function underline(text) {
      return text.split("").join("̲") + "̲";
    }

    function doubleUnderline(text) {
      return text.split("").join("̳") + "̳";
    }

    function slashThrough(text) {
      return text.split("").join("̷") + "̷";
    }

    function stinky(text) {
      return text.split("").join("̾") + "̾"
    }

    function heartsBetween(text) {
      return text.split("").join("♥");
    }

    function arrowBelow(text) {
      return text.split("").join("͎") + "͎";
    }

    function crossAboveBelow(text) {
      return text.split("").join("͓̽") + "͓̽";
    }
    const wingdingsCharMap = {
      "0": "📁︎",
      "1": "📂︎",
      "2": "📄︎",
      "3": "🗏︎",
      "4": "🗐︎",
      "5": "🗄︎",
      "6": "⌛︎",
      "7": "🖮︎",
      "8": "🖰︎",
      "9": "🖲︎",
      "!": "✏︎",
      "\"": "✂︎",
      "#": "✁︎",
      "$": "👓︎",
      "%": "🕭︎",
      "&": "🕮︎",
      "'": "🕯︎",
      "(": "🕿︎",
      ")": "✆︎",
      "*": "🖂︎",
      "+": "🖃︎",
      ",": "📪︎",
      "-": "📫︎",
      ".": "📬︎",
      "/": "📭︎",
      ":": "🖳︎",
      ";": "🖴︎",
      "<": "🖫︎",
      "=": "🖬︎",
      ">": "✇︎",
      "?": "✍︎",
      "A": "✌︎",
      "B": "👌︎",
      "C": "👍︎",
      "D": "👎︎",
      "E": "☜︎",
      "F": "☞︎",
      "G": "☝︎",
      "H": "☟︎",
      "I": "✋︎",
      "J": "☺︎",
      "K": "😐︎",
      "L": "☹︎",
      "M": "💣︎",
      "N": "☠︎",
      "O": "⚐︎",
      "P": "🏱︎",
      "Q": "✈︎",
      "R": "☼︎",
      "S": "💧︎",
      "T": "❄︎",
      "U": "🕆︎",
      "V": "✞︎",
      "W": "🕈︎",
      "X": "✠︎",
      "Y": "✡︎",
      "Z": "☪︎",
      "[": "☯︎",
      "\\": "ॐ︎",
      "]": "☸︎",
      "^": "♈︎",
      "_": "♉︎",
      "`": "♊︎",
      "a": "♋︎",
      "b": "♌︎",
      "c": "♍︎",
      "d": "♎︎",
      "e": "♏︎",
      "f": "♐︎",
      "g": "♑︎",
      "h": "♒︎",
      "i": "♓︎",
      "j": "🙰",
      "k": "🙵",
      "l": "●︎",
      "m": "❍︎",
      "n": "■︎",
      "o": "□︎",
      "p": "◻︎",
      "q": "❑︎",
      "r": "❒︎",
      "s": "⬧︎",
      "t": "⧫︎",
      "u": "◆︎",
      "v": "❖︎",
      "w": "⬥︎",
      "x": "⌧︎",
      "y": "⍓︎",
      "z": "⌘︎",
      "{": "❀︎",
      "|": "✿︎",
      "}": "❝︎",
      "~": "❞︎",
      " ": "▯︎",
      "€": "⓪︎",
      " ": "①︎",
      "‚": "②︎",
      "ƒ": "③︎",
      "„": "④︎",
      "…": "⑤︎",
      "†": "⑥︎",
      "‡": "⑦︎",
      "ˆ": "⑧︎",
      "‰": "⑨︎",
      "Š": "⑩︎",
      "‹": "⓿︎",
      "Œ": "❶︎",
      " ": "❷︎",
      "Ž": "❸︎",
      " ": "❹︎",
      " ": "❺︎",
      "‘": "❻︎",
      "’": "❼︎",
      "“": "❽︎",
      "”": "❾︎",
      "•": "❿︎",
      "–": "◻︎",
      "—": "◻︎",
      "˜": "◻︎",
      "™": "◻︎",
      "š": "◻︎",
      "›": "◻︎",
      "œ": "◻︎",
      " ": "◻︎",
      "ž": "·︎",
      "Ÿ": "•︎",
      "¡": "○︎",
      "¢": "⭕︎",
      "£": "◻︎",
      "¤": "◉︎",
      "¥": "◎︎",
      "¦": "◻︎",
      "§": "▪︎",
      "¨": "◻︎",
      "©": "◻︎",
      "ª": "✦︎",
      "«": "★︎",
      "¬": "✶︎",
      "®": "✹︎",
      "¯": "✵︎",
      "°": "◻︎",
      "±": "⌖︎",
      "²": "⟡︎",
      "³": "⌑︎",
      "´": "◻︎",
      "µ": "✪︎",
      "¶": "✰︎",
      "·": "🕐︎",
      "¸": "🕑︎",
      "¹": "🕒︎",
      "º": "🕓︎",
      "»": "🕔︎",
      "¼": "🕕︎",
      "½": "🕖︎",
      "¾": "🕗︎",
      "¿": "🕘︎",
      "À": "🕙︎",
      "Á": "🕚︎",
      "Â": "🕛︎",
      "Ã": "◻︎",
      "Ä": "◻︎",
      "Å": "◻︎",
      "Æ": "◻︎",
      "Ç": "◻︎",
      "È": "◻︎",
      "É": "◻︎",
      "Ê": "◻︎",
      "Ë": "◻︎",
      "Ì": "◻︎",
      "Í": "◻︎",
      "Î": "◻︎",
      "Ï": "◻︎",
      "Ð": "◻︎",
      "Ñ": "◻︎",
      "Ò": "◻︎",
      "Ó": "◻︎",
      "Ô": "◻︎",
      "Õ": "⌫︎",
      "Ö": "⌦︎",
      "×": "◻︎",
      "Ø": "➢︎",
      "Ù": "◻︎",
      "Ú": "◻︎",
      "Û": "◻︎",
      "Ü": "➲︎",
      "Ý": "◻︎",
      "Þ": "◻︎",
      "ß": "◻︎",
      "à": "◻︎",
      "á": "◻︎",
      "â": "◻︎",
      "ã": "◻︎",
      "ä": "◻︎",
      "å": "◻︎",
      "æ": "◻︎",
      "ç": "◻︎",
      "è": "➔︎",
      "é": "◻︎",
      "ê": "◻︎",
      "ë": "◻︎",
      "ì": "◻︎",
      "í": "◻︎",
      "î": "◻︎",
      "ï": "⇦︎",
      "ð": "⇨︎",
      "ñ": "⇧︎",
      "ò": "⇩︎",
      "ó": "⬄︎",
      "ô": "⇳︎",
      "õ": "⬀︎",
      "ö": "⬁︎",
      "÷": "⬃︎",
      "ø": "⬂︎",
      "ù": "▭︎",
      "ú": "▫︎",
      "û": "✗︎",
      "ü": "✓︎",
      "ý": "☒︎",
      "þ": "☑︎",
      "ÿ": "◻︎"
    };

    function wingdings(text) {
      return text.split("").map(function(a) {
        return wingdingsCharMap[a] ? wingdingsCharMap[a] : a
      }).join("");
    }
    const vaporwaveCharMap = {
      " ": " ",
      "`": "`",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "0": "0",
      "-": "-",
      "=": "=",
      "~": "~",
      "!": "!",
      "@": "@",
      "#": "#",
      "$": "$",
      "%": "%",
      "^": "^",
      "&": "&",
      "*": "*",
      "(": "(",
      ")": ")",
      "_": "_",
      "+": "+",
      "q": "q",
      "w": "w",
      "e": "e",
      "r": "r",
      "t": "t",
      "y": "y",
      "u": "u",
      "i": "i",
      "o": "o",
      "p": "p",
      "[": "[",
      "]": "]",
      "\\": "\\",
      "Q": "Q",
      "W": "W",
      "E": "E",
      "R": "R",
      "T": "T",
      "Y": "Y",
      "U": "U",
      "I": "I",
      "O": "O",
      "P": "P",
      "{": "{",
      "}": "}",
      "|": "|",
      "a": "a",
      "s": "s",
      "d": "d",
      "f": "f",
      "g": "g",
      "h": "h",
      "j": "j",
      "k": "k",
      "l": "l",
      ";": ";",
      "'": "'",
      "A": "A",
      "S": "S",
      "D": "D",
      "F": "F",
      "G": "G",
      "H": "H",
      "J": "J",
      "K": "K",
      "L": "L",
      ":": ":",
      "\"": "\"",
      "z": "z",
      "x": "x",
      "c": "c",
      "v": "v",
      "b": "b",
      "n": "n",
      "m": "m",
      ",": ",",
      ".": ".",
      "/": "/",
      "Z": "Z",
      "X": "X",
      "C": "C",
      "V": "V",
      "B": "B",
      "N": "N",
      "M": "M",
      "<": "<",
      ">": ">",
      "?": "?"
    };

    function vaporwaveText(text) {
      var numSpaces = text.split(" ").length;
      text = applyCharMap(vaporwaveCharMap, text);
      var asianChars = getAsianChars(Math.max(3, numSpaces));
      if (numSpaces > 6) asianChars = asianChars.split("").map(c => c + ["", " "][Math.round(Math.random() * 0.6)]).join("");
      var outputs = [];
      outputs.push(text + " " + asianChars);
      outputs.push(text.replace(/ /g, "░").replace(/ae/, "æ").replace(/A/g, "Λ").replace(/E/g, function() {
        return Math.random() > 0.5 ? "Ξ" : "Σ";
      }).replace(/O/g, "♢") + " (" + asianChars + ")");
      outputs.push("【" + text + "】");
      return outputs.join("\n\n");
    }

    function getAsianChars(n) {
      if (!n) n = 1;
      var chars = "リサフランク現代のコンピュ竹内 まりや若者が履く流行のスニーカー真夜中のドアホットドッグマスターストライカーソニーブギ新しい日の誕生ライフ - ヒスイ蒸気波 無線゠ァアィイゥウェエォオカガキギクグケゲコゴサザシジスズセゼソゾタダチヂッツヅテデトドナニヌネノハバパヒビピフブプヘベペホボポマミムメモャヤュユョヨラリルレロヮワヰヱヲンヴヵヶヷヸヹヺ・ーヽヾヿぁあぃいぅうぇえぉおかがきぎくぐけげこごさざしじすずせぜそぞただちぢっつづてでとどなにぬねのはばぱひびぴふぶぷへべぺほぼぽまみむめもゃやゅゆょよらりるれろゎわゐゑをんゔゕゖ゙゚゛゜ゝゞゟ亜哀挨愛曖悪握圧扱宛嵐安案暗以衣位囲医依委威為畏胃尉異移萎偉椅彙意違維慰遺緯域育壱逸茨芋引印因咽姻員院淫陰飲隠韻右宇羽雨唄鬱畝浦運雲永泳英映栄営詠影鋭衛易疫益液駅悦越謁閲円延沿炎怨宴媛援園煙猿遠鉛塩演縁艶汚王凹央応往押旺欧殴桜翁奥横岡屋億憶臆虞乙俺卸音恩温穏下化火加可仮何花佳価果河苛科";
      var str = "";
      for (var i = 0; i < n; i++) {
        str += chars[Math.floor(Math.random() * chars.length)];
      }
      return str;
    }
    const flourishArray = ["★·.·´¯`·.·★ [[text]] ★·.·´¯`·.·★", "▁ ▂ ▄ ▅ ▆ ▇ █ [[text]] █ ▇ ▆ ▅ ▄ ▂ ▁", "°°°·.°·..·°¯°·._.· [[text]] ·._.·°¯°·.·° .·°°°", "¸,ø¤º°`°º¤ø,¸¸,ø¤º° [[text]] °º¤ø,¸¸,ø¤º°`°º¤ø,¸", "ıllıllı [[text]] ıllıllı", "•?((¯°·._.• [[text]] •._.·°¯))؟•", "▌│█║▌║▌║ [[text]] ║▌║▌║█│▌", "׺°”˜`”°º× [[text]] ׺°”˜`”°º×", "•]••´º´•» [[text]] «•´º´••[•", "*•.¸♡ [[text]] ♡¸.•*", "╰☆☆ [[text]] ☆☆╮", ".•°¤*(¯`★´¯)*¤° [[text]] °¤*(¯´★`¯)*¤°•.", "(¯´•._.• [[text]] •._.•´¯)", "¸„.-•~¹°”ˆ˜¨ [[text]] ¨˜ˆ”°¹~•-.„¸", "░▒▓█ [[text]] █▓▒░", "░▒▓█►─═  [[text]] ═─◄█▓▒░", "★彡 [[text]] 彡★", "•´¯`•. [[text]] .•´¯`•", "§.•´¨'°÷•..× [[text]] ×,.•´¨'°÷•..§", "•°¯`•• [[text]] ••´¯°•", "(¯`*•.¸,¤°´✿.。.:* [[text]] *.:。.✿`°¤,¸.•*´¯)", "|!¤*'~``~'*¤!| [[text]] |!¤*'~``~'*¤!|", "•._.••´¯``•.¸¸.•` [[text]] `•.¸¸.•´´¯`••._.•", "¸„.-•~¹°”ˆ˜¨ [[text]] ¨˜ˆ”°¹~•-.„¸", "(¯´•._.• [[text]] •._.•´¯)", "••¤(`×[¤ [[text]] ¤]×´)¤••", "•´¯`•» [[text]] «•´¯`•", " .o0×X×0o. [[text]] .o0×X×0o.", "¤¸¸.•´¯`•¸¸.•..>> [[text]] <<..•.¸¸•´¯`•.¸¸¤", "—(••÷[ [[text]] ]÷••)—", "¸,ø¤º°`°º¤ø,¸ [[text]] ¸,ø¤º°`°º¤ø,¸", "`•.¸¸.•´´¯`••._.• [[text]] •._.••`¯´´•.¸¸.•`", ",-*' ^ '~*-.,_,.-*~ [[text]] ~*-.,_,.-*~' ^ '*-,", "`•.,¸¸,.•´¯ [[text]] ¯`•.,¸¸,.•´", "↤↤↤↤↤ [[text]] ↦↦↦↦↦", "➶➶➶➶➶ [[text]] ➷➷➷➷➷", "↫↫↫↫↫ [[text]] ↬↬↬↬↬", "·.¸¸.·♩♪♫ [[text]] ♫♪♩·.¸¸.·", "【。_。】 [[text]] 【。_。】", "]|I{•------» [[text]] «------•}I|[", "▀▄▀▄▀▄ [[text]] ▄▀▄▀▄▀", "(-_-) [[text]] (-_-)", "•´¯`•. [[text]] .•´¯`•", "-漫~*'¨¯¨'*·舞~ [[text]] ~舞*'¨¯¨'*·~漫-", "๑۞๑,¸¸,ø¤º°`°๑۩ [[text]] ๑۩ ,¸¸,ø¤º°`°๑۞๑", ".•°¤*(¯`★´¯)*¤° [[text]] °¤*(¯´★`¯)*¤°•.", "••.•´¯`•.•• [[text]] ••.•´¯`•.••", "¤¸¸.•´¯`•¸¸.•..>> [[text]] <<..•.¸¸•´¯`•.¸¸¤", "◦•●◉✿ [[text]] ✿◉●•◦", "╚»★«╝ [[text]] ╚»★«╝", "-·=»‡«=·- [[text]] -·=»‡«=·-", "∙∙·▫▫ᵒᴼᵒ▫ₒₒ▫ᵒᴼᵒ▫ₒₒ▫ᵒᴼᵒ [[text]] ᵒᴼᵒ▫ₒₒ▫ᵒᴼᵒ▫ₒₒ▫ᵒᴼᵒ▫▫·∙∙", "¸¸♬·¯·♩¸¸♪·¯·♫¸¸ [[text]] ¸¸♫·¯·♪¸¸♩·¯·♬¸¸", "ஜ۩۞۩ஜ [[text]] ஜ۩۞۩ஜ", "¤ (¯´☆✭.¸_)¤ [[text]] ¤(_¸.✭☆´¯) ¤", "(¯`·.¸¸.·´¯`·.¸¸.-> [[text]] <-.¸¸.·´¯`·.¸¸.·´¯)", "✿.。.:* ☆:**:. [[text]] .:**:.☆*.:。.✿", ".•♫•♬• [[text]] •♬•♫•.", "ღ(¯`◕‿◕´¯) ♫ ♪ ♫ [[text]] ♫ ♪ ♫ (¯`◕‿◕´¯)ღ", "«-(¯`v´¯)-« [[text]] »-(¯`v´¯)-»"];

    function wrapInFlourish(text) {
      return flourishArray[Math.floor(Math.random() * flourishArray.length)].replace("[[text]]", text);
    }

    function wrapInSymbols(text, number) {
      return randomSymbols(number) + "  " + text + "  " + randomSymbols(number)
    }

    function firework(text) {
      return text.split("").join("҉") + "҉";
    }

    function weirdBox(text) {
      return text.replace(/([^\s])/g, "[̲̅$1]");
    }

    function littleSparkles(text) {
      return "˜”*°•.˜”*°• " + text + " •°*”˜.•°*”˜";
    }

    function kirbyHug(text) {
      return "(っ◔◡◔)っ ♥ " + text + " ♥"
    }

    function dottyJoiner(text) {
      return "░" + text.split("").join("░") + "░";
    }

    function wavyJoiner(text) {
      return "≋" + text.split("").join("≋") + "≋";
    }

    function diametricAngleFrame(text) {
      return text.replace(/([^\s])/g, "『$1』");
    }

    function thickBlockFramed(text) {
      return text.replace(/([^\s])/g, "【$1】");
    }

    function applyCharMap(map, text) {
      let out = "";
      for (let c of text.split("")) {
        if (map[c] !== undefined) out += map[c];
        else if (map[c.toLowerCase()] !== undefined) out += map[c.toLowerCase()];
        else out += c;
      }
      return out;
    }
    /* eslint-disable */
    const futureAlienCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ᗩ",
      "b": "ᗷ",
      "c": "ᑢ",
      "d": "ᕲ",
      "e": "ᘿ",
      "f": "ᖴ",
      "g": "ᘜ",
      "h": "ᕼ",
      "i": "ᓰ",
      "j": "ᒚ",
      "k": "ᖽᐸ",
      "l": "ᒪ",
      "m": "ᘻ",
      "n": "ᘉ",
      "o": "ᓍ",
      "p": "ᕵ",
      "q": "ᕴ",
      "r": "ᖇ",
      "s": "S",
      "t": "ᖶ",
      "u": "ᑘ",
      "v": "ᐺ",
      "w": "ᘺ",
      "x": "᙭",
      "y": "ᖻ",
      "z": "ᗱ",
      "A": "ᗩ",
      "B": "ᗷ",
      "C": "ᑢ",
      "D": "ᕲ",
      "E": "ᘿ",
      "F": "ᖴ",
      "G": "ᘜ",
      "H": "ᕼ",
      "I": "ᓰ",
      "J": "ᒚ",
      "K": "ᖽᐸ",
      "L": "ᒪ",
      "M": "ᘻ",
      "N": "ᘉ",
      "O": "ᓍ",
      "P": "ᕵ",
      "Q": "ᕴ",
      "R": "ᖇ",
      "S": "S",
      "T": "ᖶ",
      "U": "ᑘ",
      "V": "ᐺ",
      "W": "ᘺ",
      "X": "᙭",
      "Y": "ᖻ",
      "Z": "ᗱ"
    };
    const squiggle6CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ค",
      "b": "๖",
      "c": "¢",
      "d": "໓",
      "e": "ē",
      "f": "f",
      "g": "ງ",
      "h": "h",
      "i": "i",
      "j": "ว",
      "k": "k",
      "l": "l",
      "m": "๓",
      "n": "ຖ",
      "o": "໐",
      "p": "p",
      "q": "๑",
      "r": "r",
      "s": "Ş",
      "t": "t",
      "u": "น",
      "v": "ง",
      "w": "ຟ",
      "x": "x",
      "y": "ฯ",
      "z": "ຊ",
      "A": "ค",
      "B": "๖",
      "C": "¢",
      "D": "໓",
      "E": "ē",
      "F": "f",
      "G": "ງ",
      "H": "h",
      "I": "i",
      "J": "ว",
      "K": "k",
      "L": "l",
      "M": "๓",
      "N": "ຖ",
      "O": "໐",
      "P": "p",
      "Q": "๑",
      "R": "r",
      "S": "Ş",
      "T": "t",
      "U": "น",
      "V": "ง",
      "W": "ຟ",
      "X": "x",
      "Y": "ฯ",
      "Z": "ຊ"
    };
    const squiggle5CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ą",
      "b": "ც",
      "c": "ƈ",
      "d": "ɖ",
      "e": "ɛ",
      "f": "ʄ",
      "g": "ɠ",
      "h": "ɧ",
      "i": "ı",
      "j": "ʝ",
      "k": "ƙ",
      "l": "Ɩ",
      "m": "ɱ",
      "n": "ŋ",
      "o": "ơ",
      "p": "℘",
      "q": "զ",
      "r": "ཞ",
      "s": "ʂ",
      "t": "ɬ",
      "u": "ų",
      "v": "۷",
      "w": "ῳ",
      "x": "ҳ",
      "y": "ყ",
      "z": "ʑ",
      "A": "ą",
      "B": "ც",
      "C": "ƈ",
      "D": "ɖ",
      "E": "ɛ",
      "F": "ʄ",
      "G": "ɠ",
      "H": "ɧ",
      "I": "ı",
      "J": "ʝ",
      "K": "ƙ",
      "L": "Ɩ",
      "M": "ɱ",
      "N": "ŋ",
      "O": "ơ",
      "P": "℘",
      "Q": "զ",
      "R": "ཞ",
      "S": "ʂ",
      "T": "ɬ",
      "U": "ų",
      "V": "۷",
      "W": "ῳ",
      "X": "ҳ",
      "Y": "ყ",
      "Z": "ʑ"
    };
    const asianStyle2CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ム",
      "b": "乃",
      "c": "ᄃ",
      "d": "り",
      "e": "乇",
      "f": "キ",
      "g": "ム",
      "h": "ん",
      "i": "ノ",
      "j": "フ",
      "k": "ズ",
      "l": "レ",
      "m": "ᄊ",
      "n": "刀",
      "o": "の",
      "p": "ア",
      "q": "ゐ",
      "r": "尺",
      "s": "丂",
      "t": "イ",
      "u": "ひ",
      "v": "√",
      "w": "W",
      "x": "メ",
      "y": "リ",
      "z": "乙",
      "A": "ム",
      "B": "乃",
      "C": "ᄃ",
      "D": "り",
      "E": "乇",
      "F": "キ",
      "G": "ム",
      "H": "ん",
      "I": "ノ",
      "J": "フ",
      "K": "ズ",
      "L": "レ",
      "M": "ᄊ",
      "N": "刀",
      "O": "の",
      "P": "ア",
      "Q": "ゐ",
      "R": "尺",
      "S": "丂",
      "T": "イ",
      "U": "ひ",
      "V": "√",
      "W": "W",
      "X": "メ",
      "Y": "リ",
      "Z": "乙"
    };
    const asianStyleCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "卂",
      "b": "乃",
      "c": "匚",
      "d": "ᗪ",
      "e": "乇",
      "f": "千",
      "g": "Ꮆ",
      "h": "卄",
      "i": "丨",
      "j": "フ",
      "k": "Ҝ",
      "l": "ㄥ",
      "m": "爪",
      "n": "几",
      "o": "ㄖ",
      "p": "卩",
      "q": "Ɋ",
      "r": "尺",
      "s": "丂",
      "t": "ㄒ",
      "u": "ㄩ",
      "v": "ᐯ",
      "w": "山",
      "x": "乂",
      "y": "ㄚ",
      "z": "乙",
      "A": "卂",
      "B": "乃",
      "C": "匚",
      "D": "ᗪ",
      "E": "乇",
      "F": "千",
      "G": "Ꮆ",
      "H": "卄",
      "I": "丨",
      "J": "フ",
      "K": "Ҝ",
      "L": "ㄥ",
      "M": "爪",
      "N": "几",
      "O": "ㄖ",
      "P": "卩",
      "Q": "Ɋ",
      "R": "尺",
      "S": "丂",
      "T": "ㄒ",
      "U": "ㄩ",
      "V": "ᐯ",
      "W": "山",
      "X": "乂",
      "Y": "ㄚ",
      "Z": "乙"
    };
    const squaresCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "🄰",
      "b": "🄱",
      "c": "🄲",
      "d": "🄳",
      "e": "🄴",
      "f": "🄵",
      "g": "🄶",
      "h": "🄷",
      "i": "🄸",
      "j": "🄹",
      "k": "🄺",
      "l": "🄻",
      "m": "🄼",
      "n": "🄽",
      "o": "🄾",
      "p": "🄿",
      "q": "🅀",
      "r": "🅁",
      "s": "🅂",
      "t": "🅃",
      "u": "🅄",
      "v": "🅅",
      "w": "🅆",
      "x": "🅇",
      "y": "🅈",
      "z": "🅉",
      "A": "🄰",
      "B": "🄱",
      "C": "🄲",
      "D": "🄳",
      "E": "🄴",
      "F": "🄵",
      "G": "🄶",
      "H": "🄷",
      "I": "🄸",
      "J": "🄹",
      "K": "🄺",
      "L": "🄻",
      "M": "🄼",
      "N": "🄽",
      "O": "🄾",
      "P": "🄿",
      "Q": "🅀",
      "R": "🅁",
      "S": "🅂",
      "T": "🅃",
      "U": "🅄",
      "V": "🅅",
      "W": "🅆",
      "X": "🅇",
      "Y": "🅈",
      "Z": "🅉"
    };
    const squiggle4CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "Ꮧ",
      "b": "Ᏸ",
      "c": "ፈ",
      "d": "Ꮄ",
      "e": "Ꮛ",
      "f": "Ꭶ",
      "g": "Ꮆ",
      "h": "Ꮒ",
      "i": "Ꭵ",
      "j": "Ꮰ",
      "k": "Ꮶ",
      "l": "Ꮭ",
      "m": "Ꮇ",
      "n": "Ꮑ",
      "o": "Ꭷ",
      "p": "Ꭾ",
      "q": "Ꭴ",
      "r": "Ꮢ",
      "s": "Ꮥ",
      "t": "Ꮦ",
      "u": "Ꮼ",
      "v": "Ꮙ",
      "w": "Ꮗ",
      "x": "ጀ",
      "y": "Ꭹ",
      "z": "ፚ",
      "A": "Ꮧ",
      "B": "Ᏸ",
      "C": "ፈ",
      "D": "Ꮄ",
      "E": "Ꮛ",
      "F": "Ꭶ",
      "G": "Ꮆ",
      "H": "Ꮒ",
      "I": "Ꭵ",
      "J": "Ꮰ",
      "K": "Ꮶ",
      "L": "Ꮭ",
      "M": "Ꮇ",
      "N": "Ꮑ",
      "O": "Ꭷ",
      "P": "Ꭾ",
      "Q": "Ꭴ",
      "R": "Ꮢ",
      "S": "Ꮥ",
      "T": "Ꮦ",
      "U": "Ꮼ",
      "V": "Ꮙ",
      "W": "Ꮗ",
      "X": "ጀ",
      "Y": "Ꭹ",
      "Z": "ፚ"
    };
    const neonCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ᗩ",
      "b": "ᗷ",
      "c": "ᑕ",
      "d": "ᗪ",
      "e": "E",
      "f": "ᖴ",
      "g": "G",
      "h": "ᕼ",
      "i": "I",
      "j": "ᒍ",
      "k": "K",
      "l": "ᒪ",
      "m": "ᗰ",
      "n": "ᑎ",
      "o": "O",
      "p": "ᑭ",
      "q": "ᑫ",
      "r": "ᖇ",
      "s": "ᔕ",
      "t": "T",
      "u": "ᑌ",
      "v": "ᐯ",
      "w": "ᗯ",
      "x": "᙭",
      "y": "Y",
      "z": "ᘔ",
      "A": "ᗩ",
      "B": "ᗷ",
      "C": "ᑕ",
      "D": "ᗪ",
      "E": "E",
      "F": "ᖴ",
      "G": "G",
      "H": "ᕼ",
      "I": "I",
      "J": "ᒍ",
      "K": "K",
      "L": "ᒪ",
      "M": "ᗰ",
      "N": "ᑎ",
      "O": "O",
      "P": "ᑭ",
      "Q": "ᑫ",
      "R": "ᖇ",
      "S": "ᔕ",
      "T": "T",
      "U": "ᑌ",
      "V": "ᐯ",
      "W": "ᗯ",
      "X": "᙭",
      "Y": "Y",
      "Z": "ᘔ"
    };
    const squiggle3CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ǟ",
      "b": "ɮ",
      "c": "ƈ",
      "d": "ɖ",
      "e": "ɛ",
      "f": "ʄ",
      "g": "ɢ",
      "h": "ɦ",
      "i": "ɨ",
      "j": "ʝ",
      "k": "ӄ",
      "l": "ʟ",
      "m": "ʍ",
      "n": "ռ",
      "o": "օ",
      "p": "ք",
      "q": "զ",
      "r": "ʀ",
      "s": "ֆ",
      "t": "ȶ",
      "u": "ʊ",
      "v": "ʋ",
      "w": "ա",
      "x": "Ӽ",
      "y": "ʏ",
      "z": "ʐ",
      "A": "ǟ",
      "B": "ɮ",
      "C": "ƈ",
      "D": "ɖ",
      "E": "ɛ",
      "F": "ʄ",
      "G": "ɢ",
      "H": "ɦ",
      "I": "ɨ",
      "J": "ʝ",
      "K": "ӄ",
      "L": "ʟ",
      "M": "ʍ",
      "N": "ռ",
      "O": "օ",
      "P": "ք",
      "Q": "զ",
      "R": "ʀ",
      "S": "ֆ",
      "T": "ȶ",
      "U": "ʊ",
      "V": "ʋ",
      "W": "ա",
      "X": "Ӽ",
      "Y": "ʏ",
      "Z": "ʐ"
    };
    const monospaceCharMap = {
      "0": "𝟶",
      "1": "𝟷",
      "2": "𝟸",
      "3": "𝟹",
      "4": "𝟺",
      "5": "𝟻",
      "6": "𝟼",
      "7": "𝟽",
      "8": "𝟾",
      "9": "𝟿",
      "a": "𝚊",
      "b": "𝚋",
      "c": "𝚌",
      "d": "𝚍",
      "e": "𝚎",
      "f": "𝚏",
      "g": "𝚐",
      "h": "𝚑",
      "i": "𝚒",
      "j": "𝚓",
      "k": "𝚔",
      "l": "𝚕",
      "m": "𝚖",
      "n": "𝚗",
      "o": "𝚘",
      "p": "𝚙",
      "q": "𝚚",
      "r": "𝚛",
      "s": "𝚜",
      "t": "𝚝",
      "u": "𝚞",
      "v": "𝚟",
      "w": "𝚠",
      "x": "𝚡",
      "y": "𝚢",
      "z": "𝚣",
      "A": "𝙰",
      "B": "𝙱",
      "C": "𝙲",
      "D": "𝙳",
      "E": "𝙴",
      "F": "𝙵",
      "G": "𝙶",
      "H": "𝙷",
      "I": "𝙸",
      "J": "𝙹",
      "K": "𝙺",
      "L": "𝙻",
      "M": "𝙼",
      "N": "𝙽",
      "O": "𝙾",
      "P": "𝙿",
      "Q": "𝚀",
      "R": "𝚁",
      "S": "𝚂",
      "T": "𝚃",
      "U": "𝚄",
      "V": "𝚅",
      "W": "𝚆",
      "X": "𝚇",
      "Y": "𝚈",
      "Z": "𝚉"
    };
    const boldItalicCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "𝙖",
      "b": "𝙗",
      "c": "𝙘",
      "d": "𝙙",
      "e": "𝙚",
      "f": "𝙛",
      "g": "𝙜",
      "h": "𝙝",
      "i": "𝙞",
      "j": "𝙟",
      "k": "𝙠",
      "l": "𝙡",
      "m": "𝙢",
      "n": "𝙣",
      "o": "𝙤",
      "p": "𝙥",
      "q": "𝙦",
      "r": "𝙧",
      "s": "𝙨",
      "t": "𝙩",
      "u": "𝙪",
      "v": "𝙫",
      "w": "𝙬",
      "x": "𝙭",
      "y": "𝙮",
      "z": "𝙯",
      "A": "𝘼",
      "B": "𝘽",
      "C": "𝘾",
      "D": "𝘿",
      "E": "𝙀",
      "F": "𝙁",
      "G": "𝙂",
      "H": "𝙃",
      "I": "𝙄",
      "J": "𝙅",
      "K": "𝙆",
      "L": "𝙇",
      "M": "𝙈",
      "N": "𝙉",
      "O": "𝙊",
      "P": "𝙋",
      "Q": "𝙌",
      "R": "𝙍",
      "S": "𝙎",
      "T": "𝙏",
      "U": "𝙐",
      "V": "𝙑",
      "W": "𝙒",
      "X": "𝙓",
      "Y": "𝙔",
      "Z": "𝙕"
    };
    const boldCharMap = {
      "0": "𝟎",
      "1": "𝟏",
      "2": "𝟐",
      "3": "𝟑",
      "4": "𝟒",
      "5": "𝟓",
      "6": "𝟔",
      "7": "𝟕",
      "8": "𝟖",
      "9": "𝟗",
      "a": "𝐚",
      "b": "𝐛",
      "c": "𝐜",
      "d": "𝐝",
      "e": "𝐞",
      "f": "𝐟",
      "g": "𝐠",
      "h": "𝐡",
      "i": "𝐢",
      "j": "𝐣",
      "k": "𝐤",
      "l": "𝐥",
      "m": "𝐦",
      "n": "𝐧",
      "o": "𝐨",
      "p": "𝐩",
      "q": "𝐪",
      "r": "𝐫",
      "s": "𝐬",
      "t": "𝐭",
      "u": "𝐮",
      "v": "𝐯",
      "w": "𝐰",
      "x": "𝐱",
      "y": "𝐲",
      "z": "𝐳",
      "A": "𝐀",
      "B": "𝐁",
      "C": "𝐂",
      "D": "𝐃",
      "E": "𝐄",
      "F": "𝐅",
      "G": "𝐆",
      "H": "𝐇",
      "I": "𝐈",
      "J": "𝐉",
      "K": "𝐊",
      "L": "𝐋",
      "M": "𝐌",
      "N": "𝐍",
      "O": "𝐎",
      "P": "𝐏",
      "Q": "𝐐",
      "R": "𝐑",
      "S": "𝐒",
      "T": "𝐓",
      "U": "𝐔",
      "V": "𝐕",
      "W": "𝐖",
      "X": "𝐗",
      "Y": "𝐘",
      "Z": "𝐙"
    };
    const boldSansCharMap = {
      "0": "𝟬",
      "1": "𝟭",
      "2": "𝟮",
      "3": "𝟯",
      "4": "𝟰",
      "5": "𝟱",
      "6": "𝟲",
      "7": "𝟳",
      "8": "𝟴",
      "9": "𝟵",
      "a": "𝗮",
      "b": "𝗯",
      "c": "𝗰",
      "d": "𝗱",
      "e": "𝗲",
      "f": "𝗳",
      "g": "𝗴",
      "h": "𝗵",
      "i": "𝗶",
      "j": "𝗷",
      "k": "𝗸",
      "l": "𝗹",
      "m": "𝗺",
      "n": "𝗻",
      "o": "𝗼",
      "p": "𝗽",
      "q": "𝗾",
      "r": "𝗿",
      "s": "𝘀",
      "t": "𝘁",
      "u": "𝘂",
      "v": "𝘃",
      "w": "𝘄",
      "x": "𝘅",
      "y": "𝘆",
      "z": "𝘇",
      "A": "𝗔",
      "B": "𝗕",
      "C": "𝗖",
      "D": "𝗗",
      "E": "𝗘",
      "F": "𝗙",
      "G": "𝗚",
      "H": "𝗛",
      "I": "𝗜",
      "J": "𝗝",
      "K": "𝗞",
      "L": "𝗟",
      "M": "𝗠",
      "N": "𝗡",
      "O": "𝗢",
      "P": "𝗣",
      "Q": "𝗤",
      "R": "𝗥",
      "S": "𝗦",
      "T": "𝗧",
      "U": "𝗨",
      "V": "𝗩",
      "W": "𝗪",
      "X": "𝗫",
      "Y": "𝗬",
      "Z": "𝗭"
    };
    const italicCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "𝘢",
      "b": "𝘣",
      "c": "𝘤",
      "d": "𝘥",
      "e": "𝘦",
      "f": "𝘧",
      "g": "𝘨",
      "h": "𝘩",
      "i": "𝘪",
      "j": "𝘫",
      "k": "𝘬",
      "l": "𝘭",
      "m": "𝘮",
      "n": "𝘯",
      "o": "𝘰",
      "p": "𝘱",
      "q": "𝘲",
      "r": "𝘳",
      "s": "𝘴",
      "t": "𝘵",
      "u": "𝘶",
      "v": "𝘷",
      "w": "𝘸",
      "x": "𝘹",
      "y": "𝘺",
      "z": "𝘻",
      "A": "𝘈",
      "B": "𝘉",
      "C": "𝘊",
      "D": "𝘋",
      "E": "𝘌",
      "F": "𝘍",
      "G": "𝘎",
      "H": "𝘏",
      "I": "𝘐",
      "J": "𝘑",
      "K": "𝘒",
      "L": "𝘓",
      "M": "𝘔",
      "N": "𝘕",
      "O": "𝘖",
      "P": "𝘗",
      "Q": "𝘘",
      "R": "𝘙",
      "S": "𝘚",
      "T": "𝘛",
      "U": "𝘜",
      "V": "𝘝",
      "W": "𝘞",
      "X": "𝘟",
      "Y": "𝘠",
      "Z": "𝘡"
    };
    const squiggle2CharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "α",
      "b": "Ⴆ",
      "c": "ƈ",
      "d": "ԃ",
      "e": "ҽ",
      "f": "ϝ",
      "g": "ɠ",
      "h": "ԋ",
      "i": "ι",
      "j": "ʝ",
      "k": "ƙ",
      "l": "ʅ",
      "m": "ɱ",
      "n": "ɳ",
      "o": "σ",
      "p": "ρ",
      "q": "ϙ",
      "r": "ɾ",
      "s": "ʂ",
      "t": "ƚ",
      "u": "υ",
      "v": "ʋ",
      "w": "ɯ",
      "x": "x",
      "y": "ყ",
      "z": "ȥ",
      "A": "A",
      "B": "B",
      "C": "C",
      "D": "D",
      "E": "E",
      "F": "F",
      "G": "G",
      "H": "H",
      "I": "I",
      "J": "J",
      "K": "K",
      "L": "L",
      "M": "M",
      "N": "N",
      "O": "O",
      "P": "P",
      "Q": "Q",
      "R": "R",
      "S": "S",
      "T": "T",
      "U": "U",
      "V": "V",
      "W": "W",
      "X": "X",
      "Y": "Y",
      "Z": "Z"
    };
    const currencyCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "₳",
      "b": "฿",
      "c": "₵",
      "d": "Đ",
      "e": "Ɇ",
      "f": "₣",
      "g": "₲",
      "h": "Ⱨ",
      "i": "ł",
      "j": "J",
      "k": "₭",
      "l": "Ⱡ",
      "m": "₥",
      "n": "₦",
      "o": "Ø",
      "p": "₱",
      "q": "Q",
      "r": "Ɽ",
      "s": "₴",
      "t": "₮",
      "u": "Ʉ",
      "v": "V",
      "w": "₩",
      "x": "Ӿ",
      "y": "Ɏ",
      "z": "Ⱬ",
      "A": "₳",
      "B": "฿",
      "C": "₵",
      "D": "Đ",
      "E": "Ɇ",
      "F": "₣",
      "G": "₲",
      "H": "Ⱨ",
      "I": "ł",
      "J": "J",
      "K": "₭",
      "L": "Ⱡ",
      "M": "₥",
      "N": "₦",
      "O": "Ø",
      "P": "₱",
      "Q": "Q",
      "R": "Ɽ",
      "S": "₴",
      "T": "₮",
      "U": "Ʉ",
      "V": "V",
      "W": "₩",
      "X": "Ӿ",
      "Y": "Ɏ",
      "Z": "Ⱬ"
    };
    const symbolsCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "å",
      "b": "ß",
      "c": "¢",
      "d": "Ð",
      "e": "ê",
      "f": "£",
      "g": "g",
      "h": "h",
      "i": "ï",
      "j": "j",
      "k": "k",
      "l": "l",
      "m": "m",
      "n": "ñ",
      "o": "ð",
      "p": "þ",
      "q": "q",
      "r": "r",
      "s": "§",
      "t": "†",
      "u": "µ",
      "v": "v",
      "w": "w",
      "x": "x",
      "y": "¥",
      "z": "z",
      "A": "Ä",
      "B": "ß",
      "C": "Ç",
      "D": "Ð",
      "E": "È",
      "F": "£",
      "G": "G",
      "H": "H",
      "I": "Ì",
      "J": "J",
      "K": "K",
      "L": "L",
      "M": "M",
      "N": "ñ",
      "O": "Ö",
      "P": "þ",
      "Q": "Q",
      "R": "R",
      "S": "§",
      "T": "†",
      "U": "Ú",
      "V": "V",
      "W": "W",
      "X": "×",
      "Y": "¥",
      "Z": "Z"
    };
    const greekCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "α",
      "b": "в",
      "c": "¢",
      "d": "∂",
      "e": "є",
      "f": "ƒ",
      "g": "g",
      "h": "н",
      "i": "ι",
      "j": "נ",
      "k": "к",
      "l": "ℓ",
      "m": "м",
      "n": "η",
      "o": "σ",
      "p": "ρ",
      "q": "q",
      "r": "я",
      "s": "ѕ",
      "t": "т",
      "u": "υ",
      "v": "ν",
      "w": "ω",
      "x": "χ",
      "y": "у",
      "z": "z",
      "A": "α",
      "B": "в",
      "C": "¢",
      "D": "∂",
      "E": "є",
      "F": "ƒ",
      "G": "g",
      "H": "н",
      "I": "ι",
      "J": "נ",
      "K": "к",
      "L": "ℓ",
      "M": "м",
      "N": "η",
      "O": "σ",
      "P": "ρ",
      "Q": "q",
      "R": "я",
      "S": "ѕ",
      "T": "т",
      "U": "υ",
      "V": "ν",
      "W": "ω",
      "X": "χ",
      "Y": "у",
      "Z": "z"
    };
    const bentTextCharMap = {
      "0": "⊘",
      "1": "𝟙",
      "2": "ϩ",
      "3": "Ӡ",
      "4": "५",
      "5": "Ƽ",
      "6": "Ϭ",
      "7": "7",
      "8": "𝟠",
      "9": "९",
      "a": "ą",
      "b": "ҍ",
      "c": "ç",
      "d": "ժ",
      "e": "ҽ",
      "f": "ƒ",
      "g": "ց",
      "h": "հ",
      "i": "ì",
      "j": "ʝ",
      "k": "ҟ",
      "l": "Ӏ",
      "m": "ʍ",
      "n": "ղ",
      "o": "օ",
      "p": "ք",
      "q": "զ",
      "r": "ɾ",
      "s": "ʂ",
      "t": "է",
      "u": "մ",
      "v": "ѵ",
      "w": "ա",
      "x": "×",
      "y": "վ",
      "z": "Հ",
      "A": "Ⱥ",
      "B": "β",
      "C": "↻",
      "D": "Ꭰ",
      "E": "Ɛ",
      "F": "Ƒ",
      "G": "Ɠ",
      "H": "Ƕ",
      "I": "į",
      "J": "ل",
      "K": "Ҡ",
      "L": "Ꝉ",
      "M": "Ɱ",
      "N": "ហ",
      "O": "ට",
      "P": "φ",
      "Q": "Ҩ",
      "R": "འ",
      "S": "Ϛ",
      "T": "Ͳ",
      "U": "Ա",
      "V": "Ỽ",
      "W": "చ",
      "X": "ჯ",
      "Y": "Ӌ",
      "Z": "ɀ"
    };
    const upperAnglesCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "Λ",
      "b": "B",
      "c": "ᄃ",
      "d": "D",
      "e": "Σ",
      "f": "F",
      "g": "G",
      "h": "Ή",
      "i": "I",
      "j": "J",
      "k": "K",
      "l": "ᄂ",
      "m": "M",
      "n": "П",
      "o": "Ө",
      "p": "P",
      "q": "Q",
      "r": "Я",
      "s": "Ƨ",
      "t": "Ƭ",
      "u": "Ц",
      "v": "V",
      "w": "Щ",
      "x": "X",
      "y": "Y",
      "z": "Z",
      "A": "Λ",
      "B": "B",
      "C": "ᄃ",
      "D": "D",
      "E": "Σ",
      "F": "F",
      "G": "G",
      "H": "Ή",
      "I": "I",
      "J": "J",
      "K": "K",
      "L": "ᄂ",
      "M": "M",
      "N": "П",
      "O": "Ө",
      "P": "P",
      "Q": "Q",
      "R": "Я",
      "S": "Ƨ",
      "T": "Ƭ",
      "U": "Ц",
      "V": "V",
      "W": "Щ",
      "X": "X",
      "Y": "Y",
      "Z": "Z"
    };
    const subscriptCharMap = {
      "0": "₀",
      "1": "₁",
      "2": "₂",
      "3": "₃",
      "4": "₄",
      "5": "₅",
      "6": "₆",
      "7": "₇",
      "8": "₈",
      "9": "₉",
      "a": "ₐ",
      "b": "b",
      "c": "c",
      "d": "d",
      "e": "ₑ",
      "f": "f",
      "g": "g",
      "h": "ₕ",
      "i": "ᵢ",
      "j": "ⱼ",
      "k": "ₖ",
      "l": "ₗ",
      "m": "ₘ",
      "n": "ₙ",
      "o": "ₒ",
      "p": "ₚ",
      "q": "q",
      "r": "ᵣ",
      "s": "ₛ",
      "t": "ₜ",
      "u": "ᵤ",
      "v": "ᵥ",
      "w": "w",
      "x": "ₓ",
      "y": "y",
      "z": "z",
      "A": "ₐ",
      "B": "B",
      "C": "C",
      "D": "D",
      "E": "ₑ",
      "F": "F",
      "G": "G",
      "H": "ₕ",
      "I": "ᵢ",
      "J": "ⱼ",
      "K": "ₖ",
      "L": "ₗ",
      "M": "ₘ",
      "N": "ₙ",
      "O": "ₒ",
      "P": "ₚ",
      "Q": "Q",
      "R": "ᵣ",
      "S": "ₛ",
      "T": "ₜ",
      "U": "ᵤ",
      "V": "ᵥ",
      "W": "W",
      "X": "ₓ",
      "Y": "Y",
      "Z": "Z",
      "+": "₊",
      "-": "₋",
      "=": "₌",
      "(": "₍",
      ")": "₎"
    };
    const superscriptCharMap = {
      "0": "⁰",
      "1": "¹",
      "2": "²",
      "3": "³",
      "4": "⁴",
      "5": "⁵",
      "6": "⁶",
      "7": "⁷",
      "8": "⁸",
      "9": "⁹",
      "a": "ᵃ",
      "b": "ᵇ",
      "c": "ᶜ",
      "d": "ᵈ",
      "e": "ᵉ",
      "f": "ᶠ",
      "g": "ᵍ",
      "h": "ʰ",
      "i": "ⁱ",
      "j": "ʲ",
      "k": "ᵏ",
      "l": "ˡ",
      "m": "ᵐ",
      "n": "ⁿ",
      "o": "ᵒ",
      "p": "ᵖ",
      "q": "q",
      "r": "ʳ",
      "s": "ˢ",
      "t": "ᵗ",
      "u": "ᵘ",
      "v": "ᵛ",
      "w": "ʷ",
      "x": "ˣ",
      "y": "ʸ",
      "z": "ᶻ",
      "A": "ᴬ",
      "B": "ᴮ",
      "C": "ᶜ",
      "D": "ᴰ",
      "E": "ᴱ",
      "F": "ᶠ",
      "G": "ᴳ",
      "H": "ᴴ",
      "I": "ᴵ",
      "J": "ᴶ",
      "K": "ᴷ",
      "L": "ᴸ",
      "M": "ᴹ",
      "N": "ᴺ",
      "O": "ᴼ",
      "P": "ᴾ",
      "Q": "Q",
      "R": "ᴿ",
      "S": "ˢ",
      "T": "ᵀ",
      "U": "ᵁ",
      "V": "ⱽ",
      "W": "ᵂ",
      "X": "ˣ",
      "Y": "ʸ",
      "Z": "ᶻ",
      "+": "⁺",
      "-": "⁻",
      "=": "⁼",
      "(": "⁽",
      ")": "⁾"
    };
    const squiggleCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "ค",
      "b": "๒",
      "c": "ς",
      "d": "๔",
      "e": "є",
      "f": "Ŧ",
      "g": "ﻮ",
      "h": "ђ",
      "i": "เ",
      "j": "ן",
      "k": "к",
      "l": "ɭ",
      "m": "๓",
      "n": "ภ",
      "o": "๏",
      "p": "ק",
      "q": "ợ",
      "r": "г",
      "s": "ร",
      "t": "Շ",
      "u": "ย",
      "v": "ש",
      "w": "ฬ",
      "x": "א",
      "y": "ץ",
      "z": "չ",
      "A": "ค",
      "B": "๒",
      "C": "ς",
      "D": "๔",
      "E": "є",
      "F": "Ŧ",
      "G": "ﻮ",
      "H": "ђ",
      "I": "เ",
      "J": "ן",
      "K": "к",
      "L": "ɭ",
      "M": "๓",
      "N": "ภ",
      "O": "๏",
      "P": "ק",
      "Q": "ợ",
      "R": "г",
      "S": "ร",
      "T": "Շ",
      "U": "ย",
      "V": "ש",
      "W": "ฬ",
      "X": "א",
      "Y": "ץ",
      "Z": "չ"
    };
    const doubleStruckCharMap = {
      "0": "𝟘",
      "1": "𝟙",
      "2": "𝟚",
      "3": "𝟛",
      "4": "𝟜",
      "5": "𝟝",
      "6": "𝟞",
      "7": "𝟟",
      "8": "𝟠",
      "9": "𝟡",
      "a": "𝕒",
      "b": "𝕓",
      "c": "𝕔",
      "d": "𝕕",
      "e": "𝕖",
      "f": "𝕗",
      "g": "𝕘",
      "h": "𝕙",
      "i": "𝕚",
      "j": "𝕛",
      "k": "𝕜",
      "l": "𝕝",
      "m": "𝕞",
      "n": "𝕟",
      "o": "𝕠",
      "p": "𝕡",
      "q": "𝕢",
      "r": "𝕣",
      "s": "𝕤",
      "t": "𝕥",
      "u": "𝕦",
      "v": "𝕧",
      "w": "𝕨",
      "x": "𝕩",
      "y": "𝕪",
      "z": "𝕫",
      "A": "𝔸",
      "B": "𝔹",
      "C": "ℂ",
      "D": "𝔻",
      "E": "𝔼",
      "F": "𝔽",
      "G": "𝔾",
      "H": "ℍ",
      "I": "𝕀",
      "J": "𝕁",
      "K": "𝕂",
      "L": "𝕃",
      "M": "𝕄",
      "N": "ℕ",
      "O": "𝕆",
      "P": "ℙ",
      "Q": "ℚ",
      "R": "ℝ",
      "S": "𝕊",
      "T": "𝕋",
      "U": "𝕌",
      "V": "𝕍",
      "W": "𝕎",
      "X": "𝕏",
      "Y": "𝕐",
      "Z": "ℤ"
    };
    const medievalCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "𝖆",
      "b": "𝖇",
      "c": "𝖈",
      "d": "𝖉",
      "e": "𝖊",
      "f": "𝖋",
      "g": "𝖌",
      "h": "𝖍",
      "i": "𝖎",
      "j": "𝖏",
      "k": "𝖐",
      "l": "𝖑",
      "m": "𝖒",
      "n": "𝖓",
      "o": "𝖔",
      "p": "𝖕",
      "q": "𝖖",
      "r": "𝖗",
      "s": "𝖘",
      "t": "𝖙",
      "u": "𝖚",
      "v": "𝖛",
      "w": "𝖜",
      "x": "𝖝",
      "y": "𝖞",
      "z": "𝖟",
      "A": "𝕬",
      "B": "𝕭",
      "C": "𝕮",
      "D": "𝕯",
      "E": "𝕰",
      "F": "𝕱",
      "G": "𝕲",
      "H": "𝕳",
      "I": "𝕴",
      "J": "𝕵",
      "K": "𝕶",
      "L": "𝕷",
      "M": "𝕸",
      "N": "𝕹",
      "O": "𝕺",
      "P": "𝕻",
      "Q": "𝕼",
      "R": "𝕽",
      "S": "𝕾",
      "T": "𝕿",
      "U": "𝖀",
      "V": "𝖁",
      "W": "𝖂",
      "X": "𝖃",
      "Y": "𝖄",
      "Z": "𝖅"
    };
    const invertedSquaresCharMap = {
      q: "🆀",
      w: "🆆",
      e: "🅴",
      r: "🆁",
      t: "🆃",
      y: "🆈",
      u: "🆄",
      i: "🅸",
      o: "🅾",
      p: "🅿",
      a: "🅰",
      s: "🆂",
      d: "🅳",
      f: "🅵",
      g: "🅶",
      h: "🅷",
      j: "🅹",
      k: "🅺",
      l: "🅻",
      z: "🆉",
      x: "🆇",
      c: "🅲",
      v: "🆅",
      b: "🅱",
      n: "🅽",
      m: "🅼"
    }
    const cursiveCharMap = {
      "0": "0",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "a": "𝓪",
      "b": "𝓫",
      "c": "𝓬",
      "d": "𝓭",
      "e": "𝓮",
      "f": "𝓯",
      "g": "𝓰",
      "h": "𝓱",
      "i": "𝓲",
      "j": "𝓳",
      "k": "𝓴",
      "l": "𝓵",
      "m": "𝓶",
      "n": "𝓷",
      "o": "𝓸",
      "p": "𝓹",
      "q": "𝓺",
      "r": "𝓻",
      "s": "𝓼",
      "t": "𝓽",
      "u": "𝓾",
      "v": "𝓿",
      "w": "𝔀",
      "x": "𝔁",
      "y": "𝔂",
      "z": "𝔃",
      "A": "𝓐",
      "B": "𝓑",
      "C": "𝓒",
      "D": "𝓓",
      "E": "𝓔",
      "F": "𝓕",
      "G": "𝓖",
      "H": "𝓗",
      "I": "𝓘",
      "J": "𝓙",
      "K": "𝓚",
      "L": "𝓛",
      "M": "𝓜",
      "N": "𝓝",
      "O": "𝓞",
      "P": "𝓟",
      "Q": "𝓠",
      "R": "𝓡",
      "S": "𝓢",
      "T": "𝓣",
      "U": "𝓤",
      "V": "𝓥",
      "W": "𝓦",
      "X": "𝓧",
      "Y": "𝓨",
      "Z": "𝓩"
    };
    const oldEnglishCharMap = {
      "a": "𝔞",
      "b": "𝔟",
      "c": "𝔠",
      "d": "𝔡",
      "e": "𝔢",
      "f": "𝔣",
      "g": "𝔤",
      "h": "𝔥",
      "i": "𝔦",
      "j": "𝔧",
      "k": "𝔨",
      "l": "𝔩",
      "m": "𝔪",
      "n": "𝔫",
      "o": "𝔬",
      "p": "𝔭",
      "q": "𝔮",
      "r": "𝔯",
      "s": "𝔰",
      "t": "𝔱",
      "u": "𝔲",
      "v": "𝔳",
      "w": "𝔴",
      "x": "𝔵",
      "y": "𝔶",
      "z": "𝔷",
      "A": "𝔄",
      "B": "𝔅",
      "C": "ℭ",
      "D": "𝔇",
      "E": "𝔈",
      "F": "𝔉",
      "G": "𝔊",
      "H": "ℌ",
      "I": "ℑ",
      "J": "𝔍",
      "K": "𝔎",
      "L": "𝔏",
      "M": "𝔐",
      "N": "𝔑",
      "O": "𝔒",
      "P": "𝔓",
      "Q": "𝔔",
      "R": "ℜ",
      "S": "𝔖",
      "T": "𝔗",
      "U": "𝔘",
      "V": "𝔙",
      "W": "𝔚",
      "X": "𝔛",
      "Y": "𝔜",
      "Z": "ℨ"
    };
    const wideTextCharMap = {
      "`": "`",
      "1": "1",
      "2": "2",
      "3": "3",
      "4": "4",
      "5": "5",
      "6": "6",
      "7": "7",
      "8": "8",
      "9": "9",
      "0": "0",
      "-": "-",
      "=": "=",
      "~": "~",
      "!": "!",
      "@": "@",
      "#": "#",
      "$": "$",
      "%": "%",
      "^": "^",
      "&": "&",
      "*": "*",
      "(": "(",
      ")": ")",
      "_": "_",
      "+": "+",
      "q": "q",
      "w": "w",
      "e": "e",
      "r": "r",
      "t": "t",
      "y": "y",
      "u": "u",
      "i": "i",
      "o": "o",
      "p": "p",
      "[": "[",
      "]": "]",
      "\\": "\\",
      "Q": "Q",
      "W": "W",
      "E": "E",
      "R": "R",
      "T": "T",
      "Y": "Y",
      "U": "U",
      "I": "I",
      "O": "O",
      "P": "P",
      "{": "{",
      "}": "}",
      "|": "|",
      "a": "a",
      "s": "s",
      "d": "d",
      "f": "f",
      "g": "g",
      "h": "h",
      "j": "j",
      "k": "k",
      "l": "l",
      ";": ";",
      "'": "'",
      "A": "A",
      "S": "S",
      "D": "D",
      "F": "F",
      "G": "G",
      "H": "H",
      "J": "J",
      "K": "K",
      "L": "L",
      ":": ":",
      "\"": "\"",
      "z": "z",
      "x": "x",
      "c": "c",
      "v": "v",
      "b": "b",
      "n": "n",
      "m": "m",
      ",": ",",
      ".": ".",
      "/": "/",
      "Z": "Z",
      "X": "X",
      "C": "C",
      "V": "V",
      "B": "B",
      "N": "N",
      "M": "M",
      "<": "<",
      ">": ">",
      "?": "?"
    }

    function Lunicode() {
      this.tools = {
        flip: {
          init: function() {
            for (i in this.map) this.map[this.map[i]] = i
          },
          encode: function(i) {
            for (var r, t = [], o = 0, h = i.length; h > o; o++) r = i.charAt(o), o > 0 && ("̤" == r || "̗" == r || "̖" == r || "̮" == r) ? (r = this.map[i.charAt(o - 1) + r], t.pop()) : (r = this.map[r], "undefined" == typeof r && (r = i.charAt(o))), t.push(r);
            return t.reverse().join("")
          },
          decode: function(i) {
            for (var r, t = [], o = 0, h = i.length; h > o; o++) r = i.charAt(o), o > 0 && ("̤" == r || "̗" == r || "̖" == r || "̮" == r) ? (r = this.map[i.charAt(o - 1) + r], t.pop()) : (r = this.map[r], "undefined" == typeof r && (r = i.charAt(o))), t.push(r);
            return t.reverse().join("")
          },
          map: {
            a: "ɐ",
            b: "q",
            c: "ɔ",
            d: "p",
            e: "ǝ",
            f: "ɟ",
            g: "ɓ",
            h: "ɥ",
            i: "ı",
            j: "ɾ",
            k: "ʞ",
            l: "l",
            m: "ɯ",
            n: "u",
            r: "ɹ",
            t: "ʇ",
            v: "ʌ",
            w: "ʍ",
            y: "ʎ",
            A: "∀",
            B: "ᙠ",
            C: "Ɔ",
            D: "ᗡ",
            E: "Ǝ",
            F: "Ⅎ",
            G: "⅁",
            J: "ſ",
            K: "⋊",
            L: "˥",
            M: "W",
            P: "Ԁ",
            Q: "Ό",
            R: "ᴚ",
            T: "⊥",
            U: "∩",
            V: "Λ",
            Y: "⅄",
            1: "⇂",
            2: "ᄅ",
            3: "Ɛ",
            4: "ㄣ",
            5: "ގ",
            6: "9",
            7: "ㄥ",
            "&": "⅋",
            ".": "˙",
            '"': "„",
            ";": "؛",
            "[": "]",
            "(": ")",
            "{": "}",
            "?": "¿",
            "!": "¡",
            "'": ",",
            "<": ">",
            "‾": "_",
            "¯": "_",
            "‿": "⁀",
            "⁅": "⁆",
            "∴": "∵",
            "\r": "\n",
            "ß": "ᙠ",
            "̈": "̤",
            "ä": "ɐ̤",
            "ö": "o̤",
            "ü": "n̤",
            "Ä": "∀̤",
            "Ö": "O̤",
            "Ü": "∩̤",
            "´": " ̗",
            "é": "ǝ̗",
            "á": "ɐ̗",
            "ó": "o̗",
            "ú": "n̗",
            "É": "Ǝ̗",
            "Á": "∀̗",
            "Ó": "O̗",
            "Ú": "∩̗",
            "`": " ̖",
            "è": "ǝ̖",
            "à": "ɐ̖",
            "ò": "o̖",
            "ù": "n̖",
            "È": "Ǝ̖",
            "À": "∀̖",
            "Ò": "O̖",
            "Ù": "∩̖",
            "^": " ̮",
            "ê": "ǝ̮",
            "â": "ɐ̮",
            "ô": "o̮",
            "û": "n̮",
            "Ê": "Ǝ̮",
            "Â": "∀̮",
            "Ô": "O̮",
            "Û": "∩̮"
          }
        },
        mirror: {
          init: function() {
            for (i in this.map) this.map[this.map[i]] = i
          },
          encode: function(i) {
            for (var r, t = [], o = [], h = 0, n = i.length; n > h; h++) r = i.charAt(h), h > 0 && ("̈" == r || "̀" == r || "́" == r || "̂" == r) ? (r = this.map[i.charAt(h - 1) + r], t.pop()) : (r = this.map[r], "undefined" == typeof r && (r = i.charAt(h))), "\n" == r ? (o.push(t.reverse().join("")), t = []) : t.push(r);
            return o.push(t.reverse().join("")), o.join("\n")
          },
          decode: function(i) {
            for (var r, t = [], o = [], h = 0, n = i.length; n > h; h++) r = i.charAt(h), h > 0 && ("̈" == r || "̀" == r || "́" == r || "̂" == r) ? (r = this.map[i.charAt(h - 1) + r], t.pop()) : (r = this.map[r], "undefined" == typeof r && (r = i.charAt(h))), "\n" == r ? (o.push(t.reverse().join("")), t = []) : t.push(r);
            return o.push(t.reverse().join("")), o.join("\n")
          },
          map: {
            a: "ɒ",
            b: "d",
            c: "ɔ",
            e: "ɘ",
            f: "Ꮈ",
            g: "ǫ",
            h: "ʜ",
            j: "ꞁ",
            k: "ʞ",
            l: "|",
            n: "ᴎ",
            p: "q",
            r: "ɿ",
            s: "ꙅ",
            t: "ƚ",
            y: "ʏ",
            z: "ƹ",
            B: "ᙠ",
            C: "Ɔ",
            D: "ᗡ",
            E: "Ǝ",
            F: "ꟻ",
            G: "Ꭾ",
            J: "Ⴑ",
            K: "⋊",
            L: "⅃",
            N: "Ͷ",
            P: "ꟼ",
            Q: "Ọ",
            R: "Я",
            S: "Ꙅ",
            Z: "Ƹ",
            1: "",
            2: "",
            3: "",
            4: "",
            5: "",
            6: "",
            7: "",
            "&": "",
            ";": "",
            "[": "]",
            "(": ")",
            "{": "}",
            "?": "⸮",
            "<": ">",
            "ä": "ɒ̈",
            "ß": "ᙠ",
            "´": "`",
            "é": "ɘ̀",
            "á": "ɒ̀",
            "ó": "ò",
            "ú": "ù",
            "É": "Ǝ̀",
            "Á": "À",
            "Ó": "Ò",
            "Ú": "Ù",
            "`": "´",
            "è": "ɘ́",
            "à": "ɒ́",
            "È": "Ǝ́",
            "ê": "ɘ̂",
            "â": "ɒ̂",
            "Ê": "Ǝ̂",
            "Ø": "ᴓ",
            "ø": "ᴓ"
          }
        },
        creepify: {
          init: function() {
            for (var i = 768; 789 >= i; i++) this.diacriticsTop.push(String.fromCharCode(i));
            for (var i = 790; 819 >= i; i++) 794 != i && 795 != i && this.diacriticsBottom.push(String.fromCharCode(i));
            this.diacriticsTop.push(String.fromCharCode(794)), this.diacriticsTop.push(String.fromCharCode(795));
            for (var i = 820; 824 >= i; i++) this.diacriticsMiddle.push(String.fromCharCode(i));
            for (var i = 825; 828 >= i; i++) this.diacriticsBottom.push(String.fromCharCode(i));
            for (var i = 829; 836 >= i; i++) this.diacriticsTop.push(String.fromCharCode(i));
            this.diacriticsTop.push(String.fromCharCode(836)), this.diacriticsBottom.push(String.fromCharCode(837)), this.diacriticsTop.push(String.fromCharCode(838)), this.diacriticsBottom.push(String.fromCharCode(839)), this.diacriticsBottom.push(String.fromCharCode(840)), this.diacriticsBottom.push(String.fromCharCode(841)), this.diacriticsTop.push(String.fromCharCode(842)), this.diacriticsTop.push(String.fromCharCode(843)), this.diacriticsTop.push(String.fromCharCode(844)), this.diacriticsBottom.push(String.fromCharCode(845)), this.diacriticsBottom.push(String.fromCharCode(846)), this.diacriticsTop.push(String.fromCharCode(848)), this.diacriticsTop.push(String.fromCharCode(849)), this.diacriticsTop.push(String.fromCharCode(850)), this.diacriticsBottom.push(String.fromCharCode(851)), this.diacriticsBottom.push(String.fromCharCode(852)), this.diacriticsBottom.push(String.fromCharCode(853)), this.diacriticsBottom.push(String.fromCharCode(854)), this.diacriticsTop.push(String.fromCharCode(855)), this.diacriticsTop.push(String.fromCharCode(856)), this.diacriticsBottom.push(String.fromCharCode(857)), this.diacriticsBottom.push(String.fromCharCode(858)), this.diacriticsTop.push(String.fromCharCode(859)), this.diacriticsBottom.push(String.fromCharCode(860)), this.diacriticsTop.push(String.fromCharCode(861)), this.diacriticsTop.push(String.fromCharCode(861)), this.diacriticsBottom.push(String.fromCharCode(863)), this.diacriticsTop.push(String.fromCharCode(864)), this.diacriticsTop.push(String.fromCharCode(865))
          },
          encode: function(r) {
            var t, o = "";
            for (i in r) {
              if (t = r[i], this.options.middle && (t += this.diacriticsMiddle[Math.floor(Math.random() * this.diacriticsMiddle.length)]), this.options.top)
                for (var h = this.diacriticsTop.length - 1, n = 0, a = this.options.maxHeight - Math.random() * (this.options.randomization / 100 * this.options.maxHeight); a > n; n++) t += this.diacriticsTop[Math.floor(Math.random() * h)];
              if (this.options.bottom)
                for (var s = this.diacriticsBottom.length - 1, n = 0, a = this.options.maxHeight - Math.random() * (this.options.randomization / 100 * this.options.maxHeight); a > n; n++) t += this.diacriticsBottom[Math.floor(Math.random() * s)];
              o += t
            }
            return o
          },
          decode: function(r) {
            var t, o = "";
            for (i in r) t = r[i].charCodeAt(0), (768 > t || t > 865) && (o += r[i]);
            return o
          },
          diacriticsTop: [],
          diacriticsMiddle: [],
          diacriticsBottom: [],
          options: {
            top: !0,
            middle: !0,
            bottom: !0,
            maxHeight: 15,
            randomization: 100
          }
        },
        bubbles: {
          init: function() {
            for (var i = 49; 57 >= i; i++) this.map[String.fromCharCode(i)] = String.fromCharCode(i + 9263);
            this.map[0] = "⓪";
            for (var i = 65; 90 >= i; i++) this.map[String.fromCharCode(i)] = String.fromCharCode(i + 9333);
            for (var i = 97; 122 >= i; i++) this.map[String.fromCharCode(i)] = String.fromCharCode(i + 9327);
            for (i in this.map) this.mapInverse[this.map[i]] = i
          },
          encode: function(r) {
            var t, o = "",
              h = !0;
            for (i in r) t = this.map[r[i]], "undefined" == typeof t && (r[i].charCodeAt(0) >= 33 ? (t = r[i] + String.fromCharCode(8413), h || (t = String.fromCharCode(8239) + String.fromCharCode(160) + String.fromCharCode(160) + String.fromCharCode(8239) + t)) : t = r[i]), o += t, h = "\n" == t;
            return o
          },
          decode: function(r) {
            var t, o = "",
              h = "";
            for (i in r) t = this.mapInverse[r[i]], o += "undefined" == typeof t ? r[i] : t;
            for (i in o) t = o[i].charCodeAt(0), 160 != t && 8239 != t && 8413 != t && (h += o[i]);
            return h
          },
          map: {},
          mapInverse: {}
        },
        squares: {
          init: function() {},
          encode: function(r) {
            var t, o = "",
              h = !0;
            for (i in r) r[i].charCodeAt(0) >= 33 ? (t = r[i] + String.fromCharCode(8414), h || (t = String.fromCharCode(8239) + String.fromCharCode(160) + String.fromCharCode(160) + String.fromCharCode(8239) + t)) : t = r[i], o += t, h = "\n" == t;
            return o
          },
          decode: function(r) {
            var t, o = "";
            for (i in r) t = r[i].charCodeAt(0), 160 != t && 8239 != t && 8414 != t && (o += r[i]);
            return o
          }
        },
        roundsquares: {
          init: function() {},
          encode: function(r) {
            var t, o = "",
              h = !0;
            for (i in r) r[i].charCodeAt(0) >= 33 ? (t = r[i] + String.fromCharCode(8419), h || (t = String.fromCharCode(160) + String.fromCharCode(160) + String.fromCharCode(160) + t)) : t = r[i], o += t, h = "\n" == t;
            return o
          },
          decode: function(r) {
            var t, o = "";
            for (i in r) t = r[i].charCodeAt(0), 160 != t && 8239 != t && 8419 != t && (o += r[i]);
            return o
          }
        },
        bent: {
          init: function() {
            for (i in this.map) this.map[this.map[i]] = i
          },
          encode: function(i) {
            for (var r, t = "", o = 0, h = i.length; h > o; o++) r = this.map[i.charAt(o)], "undefined" == typeof r && (r = i.charAt(o)), t += r;
            return t
          },
          decode: function(i) {
            for (var r, t = "", o = 0, h = i.length; h > o; o++) r = this.map[i.charAt(o)], "undefined" == typeof r && (r = i.charAt(o)), t += r;
            return t
          },
          map: {
            a: "ą",
            b: "ҍ",
            c: "ç",
            d: "ժ",
            e: "ҽ",
            f: "ƒ",
            g: "ց",
            h: "հ",
            i: "ì",
            j: "ʝ",
            k: "ҟ",
            l: "Ӏ",
            m: "ʍ",
            n: "ղ",
            o: "օ",
            p: "ք",
            q: "զ",
            r: "ɾ",
            s: "ʂ",
            t: "է",
            u: "մ",
            v: "ѵ",
            w: "ա",
            x: "×",
            y: "վ",
            z: "Հ",
            A: "Ⱥ",
            B: "β",
            C: "↻",
            D: "Ꭰ",
            E: "Ɛ",
            F: "Ƒ",
            G: "Ɠ",
            H: "Ƕ",
            I: "į",
            J: "ل",
            K: "Ҡ",
            L: "Ꝉ",
            M: "Ɱ",
            N: "ហ",
            O: "ට",
            P: "φ",
            Q: "Ҩ",
            R: "འ",
            S: "Ϛ",
            T: "Ͳ",
            U: "Ա",
            V: "Ỽ",
            W: "చ",
            X: "ჯ",
            Y: "Ӌ",
            Z: "ɀ",
            0: "⊘",
            1: "������",
            2: "ϩ",
            3: "Ӡ",
            4: "५",
            5: "Ƽ",
            6: "Ϭ",
            7: "7",
            8: "������",
            9: "९",
            "&": "⅋",
            "(": "{",
            ")": "}",
            "{": "(",
            "}": ")",
            "ä": "ą̈",
            "ö": "օ̈",
            "ü": "մ̈",
            "Ä": "Ⱥ̈",
            "Ö": "ට̈",
            "Ü": "Ա̈",
            "é": "ҽ́",
            "á": "ą́",
            "ó": "օ́",
            "ú": "մ́",
            "É": "Ɛ́",
            "Á": "Ⱥ́",
            "Ó": "ට́",
            "Ú": "Ա́",
            "è": "ҽ̀",
            "à": "ą̀",
            "ò": "օ̀",
            "ù": "մ̀",
            "È": "Ɛ̀",
            "À": "Ⱥ̀",
            "Ò": "ට̀",
            "Ù": "Ա̀",
            "ê": "ҽ̂",
            "â": "ą̂",
            "ô": "օ̂",
            "û": "մ̂",
            "Ê": "Ɛ̂",
            "Â": "Ⱥ̂",
            "Ô": "ට̂",
            "Û": "Ա̂"
          }
        },
        tiny: {
          init: function() {
            for (i in this.map) this.map[this.map[i]] = i
          },
          encode: function(i) {
            var r, t = "";
            i = i.toUpperCase();
            for (var o = 0, h = i.length; h > o; o++) r = this.map[i.charAt(o)], "undefined" == typeof r && (r = i.charAt(o)), t += r;
            return t
          },
          decode: function(i) {
            for (var r, t = "", o = 0, h = i.length; h > o; o++) r = this.map[i.charAt(o)], "undefined" == typeof r && (r = i.charAt(o)), t += r;
            return t
          },
          map: {
            A: "ᴀ",
            B: "ʙ",
            C: "ᴄ",
            D: "ᴅ",
            E: "ᴇ",
            F: "ꜰ",
            G: "ɢ",
            H: "ʜ",
            I: "ɪ",
            J: "ᴊ",
            K: "ᴋ",
            L: "ʟ",
            M: "ᴍ",
            N: "ɴ",
            O: "ᴏ",
            P: "ᴘ",
            Q: "Q",
            R: "ʀ",
            S: "ꜱ",
            T: "ᴛ",
            U: "ᴜ",
            V: "ᴠ",
            W: "ᴡ",
            X: "x",
            Y: "ʏ",
            Z: "ᴢ"
          }
        }
      };
      for (i in this.tools) this.tools[i].init();
      this.getHTML = function(i) {
        for (var r, t = "", o = !0, h = 0, n = 0, a = 0, s = i.length; s > a; a++) r = i.charCodeAt(a), 10 == r || 13 == r ? (t += "<br>\n", o = !0) : 32 == r ? o ? (t += " ", o = !1) : (t += " ", o = !0) : (r >= 55296 && 56319 >= r ? (h = r, n = 0) : h > 0 ? (r >= 56320 && 57343 >= r && (n = 1024 * (h - 55296) + (r - 56320) + 65536), h = 0) : n = r, 0 != n && (t += "&#x" + n.toString(16) + ";", o = !0));
        return t
      }
    }
    // CUTE TEXT:
    function cuteText(text) {
      if (text.trim() === "") return "";
      qi = -1;
      var bounds = boundingString(Math.floor(Math.random() * 2) + 1);
      return bounds + "  🎀  " + text.split(/([!?.]+)/gi).map(cuteSentence).join("") + "  🎀  " + esrever.reverse(bounds);
    }

    function cuteSentence(sentence) {
      return sentence.split(/([\s,]+)/gi).map(cuteWord).join("");
    }

    function cuteWord(word) {
      //remember to handle exclamations, empty strings, commas etc. etc.!!
      if (word === "" || /[[!?.\s,]+]/gi.test(word)) return word;
      //TODO: random turn o's into flowers, turn quotes into unicode and ! and ?
      word = roundReplace(word);
      word = punctReplace(word);
      word = emojiReplace(word);
      return scriptify(word);
    }
    var qi = -1;
    var qa = ["❝", "❞"];

    function quotes() {
      qi++;
      if (qi === 2) qi = 0;
      return qa[qi];
    }

    function punctReplace(word) {
      return word.split("")
        .map(function(a) {
          if (a === "!") return randomElement(["❣", "❢"]);
          else if (a === "?") return randomElement(["¿", "?"]);
          else if (a === "\"") return quotes();
          else return a;
        }).join("");
    }

    function emojiReplace(word) {
      return word
        .replace(":)", randomElement(emoji[":)"]))
        .replace("(:", randomElement(emoji[":)"]))
        .replace("^^", randomElement(emoji["^^"]))
        .replace(":P", randomElement(emoji[":p"]))
        .replace(":p", randomElement(emoji[":p"]))
        .replace(":D", randomElement(emoji[":D"]))
        .replace("<3", randomElement(emoji["<3"]))
        .replace("(y)", randomElement(emoji["(y)"]))
        .replace("(Y)", randomElement(emoji["(y)"]));
    }

    function roundReplace(text) {
      return text.split("").map(function(a) {
        if (a.toLowerCase() === "o" || a === "0") {
          return randomElement(round);
        } else {
          return a;
        }
      }).join("");
    }
    var emoji = {
      ":)": ["٩(˘◡˘)۶", "(•◡•)", "(ɔ◔‿◔)ɔ", "❀◕‿◕❀", "(。◕‿◕。)", "●‿●", "◕‿◕", "😍", "ツ", "(✿ヘᴥヘ)", "🌘‿🌘", "(づ。◕‿‿◕。)づ", "(/◔◡◔)/", "s(^‿^)-b", "(人◕‿◕)", "(✿╹◡╹)", "◔◡◔"],
      "^^": ["(^▽^)", "(✿^▽^)", "ᵔ⌣ᵔ", "ᵔᴥᵔ", "(≧◡≦)", "^ㅅ^", "^ㅂ^", "(⌒‿⌒)", "◠◡◠", "⁀‿⁀", ""],
      ":p": [":Þ", ""],
      ":D": ["(ノ◕ヮ◕)ノ*:・゚✧", "(✿◕ᗜ◕)━♫.*・。゚", "ᕕ(ᐛ)ᕗ"],
      "<3": ["♡", "❤", "♥", "❥", "💘", "💙", "💗", "💖", "💕", "💓", "💞", "💝", "💟"],
      "(y)": ["👍", "👌"],
    };
    var round = ["❁", "🌺", "❀", "💮", "🏵", "🌸", "☯", "😍", "♡", "🍩", "🍬", "💙", "🌞", "💍", "🍪", "❤", "💗", "🍑", "💞"];
    var food = ["🍬", "🍭", "🍒", "🍎", "🍉", "🍇", "🍓", "🍌", "🍑", "🍰", "🎂", "🍩", "🍪", "🍧", "🍦", "🍫", "🍡"];
    var flowers = ["✿", "⚘", "❦", "❧", "✾", "❁", "❀", "💐", "🌸", "💮", "🏵", "🌹", "🌺", "🌻", "🌷", "☘", "🌱", "🌲", "🌳", "🌴", "🌿", "🍂"];
    var twinkles = ["⚛", "🌌", "🌠", "*", ":", "。", "・゚", "✧", "✮", "★", "✩", "⋆", ".", "°", "`", "✴", "。", "✴", "⋆", "✳", "✶", "✷", "❈"];
    var animals = ["🐯", "🐎", "🐖", "🐷", "🐏", "🐑", "🐐", "🐫", "🐘", "🐭", "🐁", "🐀", "🐹", "🐰", "🐇", "🐿", "🐻", "🐨", "🐼", "🐾", "🐔", "🐓", "🐣", "🐤", "🐥", "🐦", "🐧", "🕊", "🐸", "🐢", "🐳", "🐋", "🐬", "🐟", "🐠", "🐡", "🐙", "🐚", "🐌", "🐞"];
    var plants = ["✿", "⚘", "❦", "❧", "✾", "❁", "❀", "💐", "🌸", "💮", "🏵", "🌹", "🌺", "🌻", "🌷", "☘", "🌱", "🌲", "🌳", "🌴", "🌿", "🍂"];
    var misc = ["🌌", "🌠", "🎉", "🎊", "🎈", "💌", "🎎", "🎁", "🎀", "🕯", "🔮", "🛀", "🎖", "🏆", "🏅", "👑", "💍", "👶", "👼", "👸", "👯", "👒", "👻"];
    var music = ["♫", "♬", "♪", "♩", "°", "。", "✧", "🎻", "🎺", "🎸", "🎷", "📯"];
    var flourish = ["•?((¯°·._.• ", "ıllıllı ", "¸,ø¤º°`°º¤ø,¸¸,ø¤º° ", "°°°·.°·..·°¯°·._.· ", "•´¯`•. ", "׺°”˜`”°º× ", "•]••´º´•» ", "]|I{•------» ", "§.•´¨'°÷•..× ", "•°¯`•• ", "(¯`·.¸¸.·´¯`·.¸¸.-> ", "*´¯`*.¸¸.*´¯`* ", "(¯`·.¸¸.-> °º ", "°·.¸.·°¯°·.¸.·°¯°·.¸.-> ", "•._.••´¯``•.¸¸.•` ", "¸„.-•~¹°”ˆ˜¨ ", "(¯´•._.• ", "••¤(`×", "•´¯`•» ", "`•.,¸¸,.•´¯ ", "¸,ø¤º°`°º¤ø,¸ ", ".o0×X×0o. ", ",-*'^'~*-.,_,.-*~ ", "`•.¸¸.•´´¯`••._.• ", "—(••÷", "¤¸¸.•´¯`•¸¸.•..>> ", "••.•´¯`•.•• ", ".•°¤*(¯`★´¯)*¤° ", "๑۞๑,¸¸,ø¤º°`°๑۩ ", "-漫~*'¨¯¨'*·舞~ ", "★·.·´¯`·.·★ ", "▁ ▂ ▄ ▅ ▆ ▇ █ ", "▀▄▀▄▀▄ ", "▌│█║▌║▌║ "];

    function boundingString(n) {
      return randomElement([foodString, twinkleString, animalString, flourishString])(n);
    }

    function foodString(n) {
      return new Array(n + 1).join('0').split('').map(function(a) {
        return randomElement(food);
      }).join(' ⋆ ');
    }

    function twinkleString(n) {
      return new Array(n + 1).join('0').split('').map(function() {
        return randomElement(twinkles);
      }).join("");
    }

    function animalString(n) {
      return new Array(n + 1).join('0').split('').map(function(a) {
        return randomElement(animals);
      }).join(' ⋆ ');
    }

    function flourishString(n) {
      return randomElement(flourish);
    }

    function scriptify(text) {
      var map = {
        "0": "𝟢",
        "1": "𝟣",
        "2": "𝟤",
        "3": "𝟥",
        "4": "𝟦",
        "5": "𝟧",
        "6": "𝟨",
        "7": "𝟩",
        "8": "𝟪",
        "9": "𝟫",
        "a": "𝒶",
        "b": "𝒷",
        "c": "𝒸",
        "d": "𝒹",
        "e": "𝑒",
        "f": "𝒻",
        "g": "𝑔",
        "h": "𝒽",
        "i": "𝒾",
        "j": "𝒿",
        "k": "𝓀",
        "l": "𝓁",
        "m": "𝓂",
        "n": "𝓃",
        "o": "𝑜",
        "p": "𝓅",
        "q": "𝓆",
        "r": "𝓇",
        "s": "𝓈",
        "t": "𝓉",
        "u": "𝓊",
        "v": "𝓋",
        "w": "𝓌",
        "x": "𝓍",
        "y": "𝓎",
        "z": "𝓏",
        "A": "𝒜",
        "B": "𝐵",
        "C": "𝒞",
        "D": "𝒟",
        "E": "𝐸",
        "F": "𝐹",
        "G": "𝒢",
        "H": "𝐻",
        "I": "𝐼",
        "J": "𝒥",
        "K": "𝒦",
        "L": "𝐿",
        "M": "𝑀",
        "N": "𝒩",
        "O": "𝒪",
        "P": "𝒫",
        "Q": "𝒬",
        "R": "𝑅",
        "S": "𝒮",
        "T": "𝒯",
        "U": "𝒰",
        "V": "𝒱",
        "W": "𝒲",
        "X": "𝒳",
        "Y": "𝒴",
        "Z": "𝒵"
      };
      var charArray = text.split("");
      for (var i = 0; i < charArray.length; i++) {
        if (map[charArray[i].toLowerCase()]) {
          charArray[i] = map[charArray[i]];
        }
      }
      text = charArray.join("");
      return text;
    }

    function shuffleArray(array) {
      var currentIndex = array.length,
        temporaryValue, randomIndex;
      // While there remain elements to shuffle...
      while (0 !== currentIndex) {
        // Pick a remaining element...
        randomIndex = Math.floor(Math.random() * currentIndex);
        currentIndex -= 1;
        // And swap it with the current element.
        temporaryValue = array[currentIndex];
        array[currentIndex] = array[randomIndex];
        array[randomIndex] = temporaryValue;
      }
      return array;
    }

    function randomElement(a) {
      return a[Math.floor(Math.random() * a.length)];
    }
    //https://github.com/mathiasbynens/esrever
    ! function(e) {
      var o = "object" == typeof exports && exports,
        r = "object" == typeof module && module && module.exports == o && module,
        n = "object" == typeof global && global;
      (n.global === n || n.window === n) && (e = n);
      var t = /(<%= allExceptCombiningMarks %>)(<%= combiningMarks %>+)/g,
        i = /([\uD800-\uDBFF])([\uDC00-\uDFFF])/g,
        f = function(e) {
          e = e.replace(t, function(e, o, r) {
            return f(r) + o
          }).replace(i, "$2$1");
          for (var o = "", r = e.length; r--;) o += e.charAt(r);
          return o
        },
        l = {
          version: "<%= version %>",
          reverse: f
        };
      if ("function" == typeof define && "object" == typeof define.amd && define.amd) define(function() {
        return l
      });
      else if (o && !o.nodeType)
        if (r) r.exports = l;
        else
          for (var a in l) l.hasOwnProperty(a) && (o[a] = l[a]);
      else e.esrever = l
    }(this);
    // CRAZY TEXT
    function fullCrazy(text) {
      if (text.trim() === "") return "";
      return randomSymbols(2) + "  " + crazifyText(text) + "  " + randomSymbols(2)
    }

    function crazifyText(text) {
      text = text.split("");
      for (var i = 0; i < text.length; i++) {
        text[i] = crazifyCharacter(text[i]);
      }
      return text.join("");
    }

    function crazifyCharacter(c) {
      c = c.toLowerCase();
      var map = {
        "&": "⅋",
        "%": ["⅍", "℀", "℁", "℆", "℅"],
        "0": ["0", "Ѳ", "ʘ"],
        "1": ["➀", "❶", "1"],
        "2": ["2", "❷", "➁"],
        "3": ["3", "❸", "➂"],
        "4": ["4", "❹", "➃"],
        "5": ["❺", "➄", "5"],
        "6": ["6", "❻", "➅"],
        "7": ["7", "❼", "➆"],
        "8": ["8", "➇", "❽"],
        "9": ["➈", "❾", "9"],
        "<": ["≼", "≺", "≪", "☾", "≾", "⋜", "⋞", "⋐", "⊂", "⊏", "⊑", "《", "<", "❮", "❰", "⫷"],
        ">": "☽≫≻≽≿⋝⋟⋑⊃⊐⊒⫸》>❯❱",
        "[": "【〖〘〚[",
        "]": "】〗〙〛]",
        "*": "✨✩✪✫✬✭✮✯✰✦✱✲✳✴✵✶✷֍֎✸✹✺✻✼✽✾✿❀❁❂❃❄★☆*",
        "a": ["Ⓐ", "ⓐ", "α", "A", "a", "ᗩ", "卂", "Δ", "ค", "α", "ά", "Ã", "𝔞", "𝓪", "𝒶", "𝓐", "𝐀", "𝐚", "𝔸", "𝕒", "ᵃ"],
        "b": ["Ⓑ", "ⓑ", "в", "B", "乃", "b", "ᗷ", "β", "๒", "в", "в", "β", "𝔟", "𝓫", "𝒷", "𝓑", "𝐁", "𝐛", "𝔹", "𝕓", "ᵇ"],
        "c": ["Ⓒ", "ⓒ", "匚", "¢", "C", "c", "ᑕ", "Ć", "ς", "c", "ς", "Č", "℃", "𝔠", "𝓬", "𝒸", "𝓒", "𝐂", "𝐜", "ℂ", "𝕔", "ᶜ"],
        "d": ["Ⓓ", "ⓓ", "∂", "D", "d", "ᗪ", "Đ", "๔", "∂", "đ", "Ď", "𝔡", "𝓭", "𝒹", "𝓓", "𝐃", "ᗪ", "𝐝", "𝔻", "𝕕", "ᵈ"],
        "e": ["Ⓔ", "乇", "ⓔ", "є", "E", "e", "ᗴ", "€", "є", "ε", "έ", "Ẹ", "𝔢", "𝒆", "𝑒", "𝓔", "𝐄", "𝐞", "𝔼", "𝕖", "ᵉ"],
        "f": ["Ⓕ", "ⓕ", "ƒ", "F", "f", "千", "ᖴ", "ℱ", "Ŧ", "ғ", "ғ", "Ƒ", "𝔣", "𝒇", "𝒻", "𝓕", "𝐅", "𝐟", "𝔽", "𝕗", "ᶠ"],
        "g": ["Ⓖ", "ⓖ", "ق", "g", "G", "g", "Ǥ", "Ꮆ", "ﻮ", "g", "ģ", "Ğ", "𝔤", "𝓰", "𝑔", "𝓖", "𝐆", "𝐠", "𝔾", "𝕘", "ᵍ", "Ꮆ"],
        "h": ["Ⓗ", "卄", "ⓗ", "н", "H", "h", "ᕼ", "Ħ", "ђ", "н", "ħ", "Ĥ", "𝔥", "𝓱", "𝒽", "𝓗", "𝐇", "𝐡", "ℍ", "𝕙", "ʰ"],
        "i": ["Ⓘ", "ⓘ", "ι", "I", "i", "Ꭵ", "丨", "Ɨ", "เ", "ι", "ί", "Į", "𝔦", "𝓲", "𝒾", "𝓘", "𝐈", "𝐢", "𝕀", "𝕚", "ᶤ"],
        "j": ["Ⓙ", "ⓙ", "נ", "J", "ڶ", "j", "ᒎ", "Ĵ", "ן", "נ", "ј", "Ĵ", "𝔧", "𝓳", "𝒿", "𝓙", "𝐉", "𝐣", "𝕁", "𝕛", "ʲ"],
        "k": ["Ⓚ", "ⓚ", "к", "K", "k", "ᛕ", "Ҝ", "к", "к", "ķ", "Ќ", "𝔨", "𝓴", "𝓀", "𝓚", "𝐊", "𝐤", "𝕂", "𝕜", "ᵏ", "Ҝ"],
        "l": ["Ⓛ", "ⓛ", "ℓ", "ㄥ", "L", "l", "ᒪ", "Ł", "l", "ℓ", "Ļ", "Ĺ", "𝔩", "𝓵", "𝓁", "𝓛", "𝐋", "𝐥", "𝕃", "𝕝", "ˡ"],
        "m": ["Ⓜ", "ⓜ", "м", "M", "m", "ᗰ", "Μ", "๓", "м", "м", "ϻ", "𝔪", "𝓶", "𝓂", "𝓜", "𝐌", "𝐦", "𝕄", "𝕞", "ᵐ", "爪"],
        "n": ["Ⓝ", "几", "ⓝ", "η", "N", "n", "ᑎ", "Ň", "ภ", "η", "ή", "Ň", "𝔫", "𝓷", "𝓃", "𝓝", "𝐍", "𝐧", "ℕ", "𝕟", "ᶰ"],
        "o": ["Ⓞ", "ㄖ", "ⓞ", "σ", "O", "o", "ᗝ", "Ø", "๏", "σ", "ό", "Ỗ", "𝔬", "𝓸", "𝑜", "𝓞", "𝐎", "𝐨", "𝕆", "𝕠", "ᵒ"],
        "p": ["Ⓟ", "ⓟ", "ρ", "P", "p", "卩", "ᑭ", "Ƥ", "ק", "ρ", "ρ", "Ƥ", "𝔭", "𝓹", "𝓅", "𝓟", "𝐏", "𝐩", "ℙ", "𝕡", "ᵖ"],
        "q": ["Ⓠ", "ⓠ", "q", "Q", "q", "Ɋ", "Ω", "ợ", "q", "q", "Ǫ", "𝔮", "𝓺", "𝓆", "𝓠", "𝐐", "𝐪", "ℚ", "𝕢", "ᵠ"],
        "r": ["Ⓡ", "ⓡ", "я", "尺", "R", "r", "ᖇ", "Ř", "г", "я", "ŕ", "Ř", "𝔯", "𝓻", "𝓇", "𝓡", "𝐑", "𝐫", "ℝ", "𝕣", "ʳ"],
        "s": ["Ⓢ", "ⓢ", "ѕ", "S", "丂", "s", "ᔕ", "Ş", "ร", "s", "ş", "Ŝ", "𝔰", "𝓼", "𝓈", "𝓢", "𝐒", "𝐬", "𝕊", "𝕤", "ˢ"],
        "t": ["Ⓣ", "ⓣ", "т", "T", "t", "丅", "Ŧ", "t", "т", "ţ", "Ť", "𝔱", "𝓽", "𝓉", "𝓣", "𝐓", "𝐭", "𝕋", "𝕥", "ᵗ"],
        "u": ["Ⓤ", "ⓤ", "υ", "U", "u", "ᑌ", "Ữ", "ย", "υ", "ù", "Ǘ", "𝔲", "𝓾", "𝓊", "𝓤", "𝐔", "𝐮", "𝕌", "𝕦", "ᵘ"],
        "v": ["Ⓥ", "ⓥ", "ν", "V", "v", "ᐯ", "V", "ש", "v", "ν", "Ѷ", "𝔳", "𝓿", "𝓋", "𝓥", "𝐕", "𝐯", "𝕍", "𝕧", "ᵛ"],
        "w": ["Ⓦ", "ⓦ", "ω", "W", "w", "ᗯ", "Ŵ", "ฬ", "ω", "ώ", "Ŵ", "𝔴", "𝔀", "𝓌", "𝓦", "𝐖", "𝐰", "𝕎", "𝕨", "ʷ", "山"],
        "x": ["Ⓧ", "ⓧ", "χ", "X", "乂", "x", "᙭", "Ж", "א", "x", "x", "Ж", "𝔵", "𝔁", "𝓍", "𝓧", "𝐗", "𝐱", "𝕏", "𝕩", "ˣ"],
        "y": ["Ⓨ", "ㄚ", "ⓨ", "у", "Y", "y", "Ƴ", "¥", "ץ", "ү", "ч", "Ў", "𝔶", "𝔂", "𝓎", "𝓨", "𝐘", "𝐲", "𝕐", "𝕪", "ʸ"],
        "z": ["Ⓩ", "ⓩ", "z", "乙", "Z", "z", "Ƶ", "Ž", "z", "z", "ž", "Ż", "𝔷", "𝔃", "𝓏", "𝓩", "𝐙", "𝐳", "ℤ", "𝕫", "ᶻ"]
      };
      if (map[c]) {
        return randomElement(map[c]);
      } else {
        return c;
      }
    }

    function randomElement(array) {
      return array[Math.floor(Math.random() * array.length)]
    }

    function randomSymbols(n) {
      var symbols = ["🐙", "🐉", "🐊", "🐒", "🐝", "🐜", "🐚", "🐲", "🐳", "🐸", "👑", "👹", "👺", "👤", "💲", "💣", "💙", "💚", "💛", "💜", "💝", "💗", "💘", "💞", "💔", "💥", "🐯", "🐼", "🐻", "🐺", "👌", "🐍", "🐧", "🐟", "🐠", "🐨", "🎯", "🏆", "🎁", "🎀", "🎉", "🎈", "🍮", "🍭", "🍬", "🍫", "🍪", "🍧", "🌷", "🍓", "😺", "😾", "✎", "😎", "😝", "😂", "😈", "😡", "😲", "😳", "🍔", "🍟", "🍩", "🎃", "🎄", "🎅", "🐣", "🐤", "👍", "👊", "👻", "👽", "👮", "💎", "💋", "👣", "💀", "💢", "🔥", "♔", "♕", "♖", "♗", "♘", "♙", "♚", "♛", "♜", "♝", "♞", "♟", "♠", "♡", "♢", "♣", "♤", "♥", "♦", "♧", "♨", "♩", "♪", "♬", "★", "☆", "☺", "☹", "☯", "☮", "☢", "☠", "☟", "☞", "☝", "☜", "✌", "✋", "✊", "⛵", "ൠ", "✌", "ඏ"];
      var s = [];
      for (var i = 0; i < n; i++) s.push(randomElement(symbols));
      return s.join("");
    }

    function randInt(min, max) {
      return min + Math.floor(Math.random() * (max - min + 1));
    }
    reverseIsDisabled = true;

    function backward(text) {
      return $('#english-text').val();
    } //]]>
    //} catch(e) {
    //    alert("There's an error in the custom script of this translator. Error:"+e);
    //}
    try {
      var jsonData = {
        "phrases1": "",
        "phrases2": "",
        "words1": "",
        "words2": "",
        "intraword1": "",
        "intraword2": "",
        "prefixes1": "",
        "prefixes2": "",
        "suffixes1": "",
        "suffixes2": "",
        "regex1": "",
        "regex2": "",
        "rev_regex1": "",
        "rev_regex2": "",
        "ordering1": "",
        "ordering2": ""
      };
      phrases1 = jsonData.phrases1.split("\n");
      phrases2 = jsonData.phrases2.split("\n");
      words1 = jsonData.words1.split("\n");
      words2 = jsonData.words2.split("\n");
      intraword1 = jsonData.intraword1.split("\n");
      intraword2 = jsonData.intraword2.split("\n");
      prefixes1 = jsonData.prefixes1.split("\n");
      prefixes2 = jsonData.prefixes2.split("\n");
      suffixes1 = jsonData.suffixes1.split("\n");
      suffixes2 = jsonData.suffixes2.split("\n");
      regex1 = jsonData.regex1.split("\n");
      regex2 = jsonData.regex2.split("\n");
      rev_regex1 = jsonData.rev_regex1.split("\n");
      rev_regex2 = jsonData.rev_regex2.split("\n");
      ordering1 = jsonData.ordering1.split("\n");
      ordering2 = jsonData.ordering2.split("\n");
    } catch (err) {
      alert("Ahh an error! Please contact me via hello@josephrocca.com and I'll fix it asap. Error log: " + err.message);
    }
    evenUpSizes(phrases1, phrases2);
    evenUpSizes(words1, words2);
    evenUpSizes(intraword1, intraword2);
    evenUpSizes(prefixes1, prefixes2);
    evenUpSizes(suffixes1, suffixes2);
    //fix for mysql trailing newline deletion problem
    function evenUpSizes(a, b) {
      if (a.length > b.length) {
        while (a.length > b.length) b.push("");
      } else if (b.length > a.length) {
        while (b.length > a.length) a.push("");
      }
    }
  </script>

  <script>
    $(function() {
      /*if($.trim($("#fancytext").val())!='') { 
         generateFancy($("#fancytext").val());
       } else {
        generateFancy("Preview Text");
       }*/
      $(".fancytext").keyup(function() {
        $(".fancytext").val($(this).val());
        if ($.trim($(this).val()) != '') {
          generateFancy($(this).val());
        } else {
          generateFancy("Preview Text");
        }
      });
      var ct = 89;

      function generateFancy(txt) {
        var fancyText = '';
        var result = forward(txt);
        var finalRes = result.split('\n\n');
        var sn = 1;
        $.each(finalRes, function(inx, vl) {
          $("#copy_" + inx).val(vl);
          // fancyText  +=  '<div class="input-group mb-3"><input type="text" class="form-control text-'+sn+'" value="'+vl+'" id="copy_'+inx+'" readonly="readonly"><div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_'+inx+'">Copy</span></div></div>';
          sn++;
        });
        for (k = 89; k <= ct; k++) {
          //console.log(k);
          $("#copy_" + k).val(crazyWithFlourishOrSymbols(txt));
        }
        //$("#result").html(fancyText); 
      }
      $(".loadmore").click(function() {
        $(this).html('Loading...');
        var text = $.trim($(".fancytext").val());
        if (text == '') {
          text = 'Preview Text';
        }
        var that = $(this);
        var intvl = setInterval(function() {
          that.html('ดูต่อไป');
          clearInterval(intvl);
        }, 1000);
        for (var i = 1; i <= 10; i++) {
          fancyText = '<div class="input-group mb-3"><input type="text" class="form-control" value="' + crazyWithFlourishOrSymbols(text) + '" id="copy_' + ct + '" readonly="readonly"><div class="input-group-append"><span class="input-group-text copybutton" style="cursor:pointer;" data-clipboard-action="copy" data-clipboard-target="#copy_' + ct + '">Copy</span></div></div>';
          ct++;
          $("#result").append(fancyText);
        }
      });
    });
  </script>
  <script>
    $(function() {
      var intv = setInterval(function() {
        $(".copybutton").html('Copy');
      }, 2000);
      $("body").on('click', ".copybutton", function() {
        $(".copybutton").html('Copy');
        $(this).html('Copied');
        clearInterval(intv);
      });
    });
    var clipboard = new ClipboardJS('.copybutton');
    clipboard.on('success', function(e) {
      //console.log(e);
    });
    clipboard.on('error', function(e) {
      //console.log(e);
    });
  </script>
</body>

</html>
              
            
!

CSS

              
                
              
            
!

JS

              
                
              
            
!
999px

Console