├── .gitignore ├── .vscode ├── extensions.json └── settings.json ├── LICENCE ├── README.md ├── demo └── formSimple.js ├── index.html ├── jsconfig.json ├── package-lock.json ├── package.json ├── public ├── build │ ├── bundle.css │ ├── bundle.js.map │ ├── bundle.mjs │ └── form-builder-v1.js ├── favicon.png └── form-editor.css ├── scripts └── setupTypeScript.js ├── src ├── App.svelte ├── lib │ ├── FormBuilder.svelte │ ├── Step.svelte │ ├── ui │ │ ├── Common │ │ │ ├── Inputs │ │ │ │ ├── InputAddButton.svelte │ │ │ │ ├── InputWrapper.svelte │ │ │ │ ├── Menu.svelte │ │ │ │ ├── SideMenu.svelte │ │ │ │ └── Switcher.svelte │ │ │ ├── Steps │ │ │ │ ├── SideStepMenu.svelte │ │ │ │ ├── StepLine.svelte │ │ │ │ ├── StepMenu.svelte │ │ │ │ └── StepWrapper.svelte │ │ │ └── inputs.js │ │ ├── EditorSteps.svelte │ │ ├── Icons │ │ │ ├── AsteriskIcon.svelte │ │ │ ├── CheckboxIcon.svelte │ │ │ ├── CloneIcon.svelte │ │ │ ├── CloseIcon.svelte │ │ │ ├── DateIcon.svelte │ │ │ ├── DateTimeIcon.svelte │ │ │ ├── EmailIcon.svelte │ │ │ ├── Icon.svelte │ │ │ ├── MenuIcon.svelte │ │ │ ├── MultichoiceIcon.svelte │ │ │ ├── NumberIcon.svelte │ │ │ ├── PasswordIcon.svelte │ │ │ ├── PlusIcon.svelte │ │ │ ├── RadioIcon.svelte │ │ │ ├── SelectIcon.svelte │ │ │ ├── TextContentIcon.svelte │ │ │ ├── TextIcon.svelte │ │ │ ├── TextareaIcon.svelte │ │ │ ├── TimeIcon.svelte │ │ │ ├── TrashIcon.svelte │ │ │ └── VisiblityIcon.svelte │ │ ├── InputTypes │ │ │ ├── Checkbox.svelte │ │ │ ├── Date.svelte │ │ │ ├── DateTime.svelte │ │ │ ├── Email.svelte │ │ │ ├── Multichoice.svelte │ │ │ ├── Number.svelte │ │ │ ├── Password.svelte │ │ │ ├── Radio.svelte │ │ │ ├── Select.svelte │ │ │ ├── Submit.svelte │ │ │ ├── Text.svelte │ │ │ ├── TextContent.svelte │ │ │ ├── Textarea.svelte │ │ │ └── Time.svelte │ │ ├── ListInputs.svelte │ │ └── Modal.svelte │ └── utils │ │ ├── clickOutside.js │ │ ├── cmpsRegistry.js │ │ ├── random.js │ │ ├── store.js │ │ └── util.js └── main.js ├── tailwind.config.js └── vite.config.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | .DS_Store -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | "recommendations": [ 3 | "svelte.svelte-vscode", 4 | "esbenp.prettier-vscode", 5 | "dbaeumer.vscode-eslint", 6 | "rvest.vs-code-prettier-eslint" 7 | ] 8 | } -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "editor.tabSize": 2, 3 | "editor.insertSpaces": true, 4 | "editor.detectIndentation": false, 5 | "svelte.plugin.css.documentSymbols.enable": false, 6 | "[svelte]": { 7 | "editor.tabSize": 4, 8 | "editor.insertSpaces": true, 9 | "editor.detectIndentation": true, 10 | "editor.defaultFormatter": "svelte.svelte-vscode" 11 | }, 12 | 13 | "editor.defaultFormatter": "esbenp.prettier-vscode", 14 | "editor.formatOnSave": true, 15 | "editor.codeActionsOnSave": { 16 | "source.fixAll.eslint": true, 17 | "source.organizeImports": false 18 | }, 19 | "workbench.colorCustomizations": { 20 | "activityBar.background": "#ffcb49d5", 21 | "activityBar.foreground": "#000" 22 | }, 23 | 24 | "eslint.packageManager": "npm", 25 | "eslint.alwaysShowStatus": true, 26 | "eslint.validate": ["javascript", "typescript", "svelte"], 27 | "eslint.format.enable": true, 28 | "editor.formatOnSaveMode": "file", 29 | "svelte.plugin.svelte.compilerWarnings": { 30 | "a11y-aria-attributes": "ignore", 31 | "a11y-incorrect-aria-attribute-type": "ignore", 32 | "a11y-unknown-aria-attribute": "ignore", 33 | "a11y-hidden": "ignore", 34 | "a11y-misplaced-role": "ignore", 35 | "a11y-unknown-role": "ignore", 36 | "a11y-no-abstract-role": "ignore", 37 | "a11y-no-redundant-roles": "ignore", 38 | "a11y-role-has-required-aria-props": "ignore", 39 | "a11y-accesskey": "ignore", 40 | "a11y-autofocus": "ignore", 41 | "a11y-misplaced-scope": "ignore", 42 | "a11y-positive-tabindex": "ignore", 43 | "a11y-invalid-attribute": "ignore", 44 | "a11y-missing-attribute": "ignore", 45 | "a11y-img-redundant-alt": "ignore", 46 | "a11y-label-has-associated-control": "ignore", 47 | "a11y-media-has-caption": "ignore", 48 | "a11y-distracting-elements": "ignore", 49 | "a11y-structure": "ignore", 50 | "a11y-mouse-events-have-key-events": "ignore", 51 | "a11y-missing-content": "ignore", 52 | "a11y-click-events-have-key-events": "ignore" 53 | } 54 | } -------------------------------------------------------------------------------- /LICENCE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Fouita 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## Form Builder With Svelte & Tailwindcss 2 | 3 | NoCode Customizable Form Editor 4 | 5 | ### Demo 6 | [Demo Form Builder](https://fouita.com/explore/form-builder/forms/0x57341/edit) 7 | 8 | 9 | ### Screenshots 10 | 11 | ![Form Builder Fouita](https://cdn.fouita.com/0x2713/media/imgs/form-builder-2-1672321442528.png) 12 | 13 | ![Form builder Fouita](https://cdn.fouita.com/0x2713/media/imgs/form-builder-6-1672322223740.png) 14 | 15 | ![Form builder Fouita](https://cdn.fouita.com/0x2713/media/imgs/form-builder-5-1672322203693.png) 16 | 17 | 18 | ## Features 19 | 20 | - Customize text and inputs (WYSIWYG) 21 | - Multi Steps Forms 22 | - Customize colors 23 | - RTL support 24 | - Add images and videos by inserting a link inside the text 25 | - Form Schema is exported so you can manipulate the data yourself 26 | - Form data is dispatched when user click on the Submit of the last step 27 | 28 | 29 | 30 | ### Install 31 | 32 | ```bash 33 | npm i @fouita/form-editor 34 | ``` 35 | 36 | ### How to use 37 | 38 | Inside your svelte app 39 | 40 | ```html 41 | 87 | 88 | 89 | ``` 90 | 91 | 92 | ### Generate CSS 93 | To be able to see the styled Editor, you can either use `form-editor.css` in your index.html or you can build the CSS using tailwind 94 | 95 | 1. Copy the file `tailwind.config.js` 96 | 2. Generate a seperate CSS for the Form Editor using the following command in your project 97 | 98 | ```bash 99 | npx tailwindcss -i ./src/global.css -o ./public/form-editor.css --minify 100 | ``` 101 | 102 | ( change `global.css` to your css file that includes `@tailwind`) 103 | 104 | `gloabl.css` 105 | ```css 106 | @tailwind base; 107 | @tailwind components; 108 | @tailwind utilities; 109 | ``` 110 | 111 | Include the file in your HTML index file 112 | 113 | ```html 114 | 115 | ``` 116 | 117 | 118 | 119 | ## Use it as widget 120 | 121 | You can use the form-editor in your project as an external widget, with backend data collection at [Fouita](https://fouita.com/explore/form-builder) for Free 122 | 123 | 124 | -------------------------------------------------------------------------------- /demo/formSimple.js: -------------------------------------------------------------------------------- 1 | export default { 2 | "name": "My Form", 3 | "steps": [ 4 | { 5 | "index": 0, 6 | "props": { 7 | "previousBtn": "Back", 8 | "nextBtn": "Next" 9 | }, 10 | "inputs": [ 11 | { 12 | "label": "Text Content", 13 | "type": "TextContent", 14 | "props": { 15 | "fields": { 16 | "arr_content": [ 17 | { 18 | "html": "", 19 | "klass": "md:text-xl text-lg leading-loose" 20 | } 21 | ], 22 | "validation": { 23 | "required": false 24 | } 25 | }, 26 | "help_html": [], 27 | "arr_html": [], 28 | "inline": false 29 | }, 30 | "key": "d3h4prkkwn" 31 | }, 32 | { 33 | "label": "Text Input", 34 | "type": "Text", 35 | "value": "", 36 | "props": { 37 | "arr_html": [ 38 | { 39 | "html": "Full Name", 40 | "klass": "md:text-xl text-lg leading-loose" 41 | } 42 | ], 43 | "help_html": [ 44 | { 45 | "html": "First Name", 46 | "klass": "md:text-sm text-sm leading-loose" 47 | } 48 | ], 49 | "fields": { 50 | "placeholder": "", 51 | "validation": { 52 | "required": false 53 | } 54 | }, 55 | "inline": true 56 | }, 57 | "key": "v19lse84ab" 58 | }, 59 | { 60 | "label": "Text Input", 61 | "type": "Text", 62 | "value": "", 63 | "props": { 64 | "arr_html": [ 65 | { 66 | "html": "", 67 | "klass": "md:text-xl text-lg leading-loose" 68 | } 69 | ], 70 | "help_html": [ 71 | { 72 | "html": "Last Name", 73 | "klass": "md:text-sm text-sm leading-loose" 74 | } 75 | ], 76 | "fields": { 77 | "placeholder": "", 78 | "validation": { 79 | "required": false 80 | } 81 | }, 82 | "inline": false 83 | }, 84 | "key": "ddnerzf9u2" 85 | } 86 | ] 87 | } 88 | ], 89 | "props": { 90 | "withMessage": false, 91 | "message": [ 92 | { 93 | "html": "Thank you!! Your submission has been sent.", 94 | "klass": "text-center md:text-xl text-lg" 95 | } 96 | ] 97 | }, 98 | "version": "18" 99 | } -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Fouita Form Editor 8 | 9 | 10 | 11 | 12 | 13 | 19 | 20 | 21 | 22 | 23 | 24 | -------------------------------------------------------------------------------- /jsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "moduleResolution": "node", 4 | "target": "esnext", 5 | "module": "esnext", 6 | /** 7 | * svelte-preprocess cannot figure out whether you have 8 | * a value or a type, so tell TypeScript to enforce using 9 | * `import type` instead of `import` for Types. 10 | */ 11 | "importsNotUsedAsValues": "error", 12 | "isolatedModules": true, 13 | "resolveJsonModule": true, 14 | /** 15 | * To have warnings / errors of the Svelte compiler at the 16 | * correct position, enable source maps by default. 17 | */ 18 | "sourceMap": true, 19 | "esModuleInterop": true, 20 | "skipLibCheck": true, 21 | "forceConsistentCasingInFileNames": false, 22 | "baseUrl": ".", 23 | /** 24 | * Typecheck JS in `.svelte` and `.js` files by default. 25 | * Disable this if you'd like to use dynamic types. 26 | */ 27 | "checkJs": false 28 | }, 29 | /** 30 | * Use global.d.ts instead of compilerOptions.types 31 | * to avoid limiting type declarations. 32 | */ 33 | "include": ["src/**/*.d.ts", "src/**/*.js", "src/**/*.svelte"] 34 | } 35 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@fouita/form-editor", 3 | "version": "0.0.5", 4 | "type": "module", 5 | "private": false, 6 | "module": "./src/main.js", 7 | "scripts": { 8 | "build": "vite build", 9 | "dev": "vite", 10 | "start": "vite preview", 11 | "prepublishOnly": "npm run build" 12 | }, 13 | "description": "Svelte component to build forms using nocode editor. Built with svelte and tailwindcss.", 14 | "repository": { 15 | "type": "git", 16 | "url": "git+https://github.com/fouita/form-editor.git" 17 | }, 18 | "author": "fouita", 19 | "license": "MIT", 20 | "keywords": [ 21 | "svelte", 22 | "tailwind", 23 | "wysiwyg", 24 | "editor", 25 | "form", 26 | "builder", 27 | "fouita" 28 | ], 29 | "bugs": { 30 | "url": "https://github.com/fouita/form-editor/issues" 31 | }, 32 | "homepage": "https://github.com/fouita/form-editor#readme", 33 | "publishConfig": { 34 | "access": "public", 35 | "registry": "https://registry.npmjs.org/" 36 | }, 37 | "devDependencies": { 38 | "@sveltejs/vite-plugin-svelte": "^2.0.2", 39 | "autoprefixer": "^10.4.7", 40 | "postcss": "^8.4.14", 41 | "svelte": "^3.55.0", 42 | "svelte-preprocess": "^4.10.7", 43 | "vite": "^4.0.3", 44 | "vite-plugin-css-injected-by-js": "^1.5.1", 45 | "tailwindcss": "^3.2.4" 46 | }, 47 | "dependencies": { 48 | "@tailwindcss/forms": "^0.5.3", 49 | "tailwind-editor": "^0.2.1" 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /public/build/bundle.css: -------------------------------------------------------------------------------- 1 | *,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::before,::after{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type='search']{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder,textarea:-ms-input-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role="button"]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,::before,::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}::-webkit-backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}.container{width:100%}@media(min-width: 640px){.container{max-width:640px}}@media(min-width: 768px){.container{max-width:768px}}@media(min-width: 1024px){.container{max-width:1024px}}@media(min-width: 1280px){.container{max-width:1280px}}@media(min-width: 1536px){.container{max-width:1536px}}.form-checkbox,.form-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}.form-checkbox{border-radius:0px}.form-radio{border-radius:100%}.form-checkbox:focus,.form-radio:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.form-checkbox:checked,.form-radio:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}.form-checkbox:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}.form-radio:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e")}.form-checkbox:checked:hover,.form-checkbox:checked:focus,.form-radio:checked:hover,.form-radio:checked:focus{border-color:transparent;background-color:currentColor}.form-checkbox:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}.form-checkbox:indeterminate:hover,.form-checkbox:indeterminate:focus{border-color:transparent;background-color:currentColor}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.\!fixed{position:fixed !important}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.right-0{right:0px}.top-7{top:1.75rem}.top-0{top:0px}.left-0{left:0px}.-left-5{left:-1.25rem}.top-10{top:2.5rem}.-left-3{left:-0.75rem}.-bottom-11{bottom:-2.75rem}.left-0\.5{left:0.125rem}.bottom-10{bottom:2.5rem}.-left-6{left:-1.5rem}.bottom-5{bottom:1.25rem}.bottom-0{bottom:0px}.z-50{z-index:50}.z-20{z-index:20}.z-40{z-index:40}.m-5{margin:1.25rem}.m-1{margin:0.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-9{margin-top:2.25rem;margin-bottom:2.25rem}.mx-2{margin-left:0.5rem;margin-right:0.5rem}.my-2{margin-top:0.5rem;margin-bottom:0.5rem}.my-3{margin-top:0.75rem;margin-bottom:0.75rem}.my-1{margin-top:0.25rem;margin-bottom:0.25rem}.my-4{margin-top:1rem;margin-bottom:1rem}.ml-16{margin-left:4rem}.mt-1{margin-top:0.25rem}.mb-4{margin-bottom:1rem}.mt-10{margin-top:2.5rem}.mt-4{margin-top:1rem}.ml-2{margin-left:0.5rem}.mr-4{margin-right:1rem}.mt-px{margin-top:1px}.mr-px{margin-right:1px}.mr-0\.5{margin-right:0.125rem}.mr-0{margin-right:0px}.mt-2{margin-top:0.5rem}.mt-0\.5{margin-top:0.125rem}.mt-0{margin-top:0px}.mb-2{margin-bottom:0.5rem}.mb-8{margin-bottom:2rem}.mt-8{margin-top:2rem}.mr-2{margin-right:0.5rem}.-ml-24{margin-left:-6rem}.ml-1{margin-left:0.25rem}.ml-5{margin-left:1.25rem}.-ml-1{margin-left:-0.25rem}.-mt-6{margin-top:-1.5rem}.block{display:block}.\!block{display:block !important}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.\!contents{display:contents !important}.hidden{display:none}.h-3\/4{height:75%}.h-screen{height:100vh}.h-4{height:1rem}.h-\[0\]{height:0}.h-1{height:0.25rem}.h-5{height:1.25rem}.h-full{height:100%}.h-3{height:0.75rem}.h-8{height:2rem}.h-auto{height:auto}.max-h-fit{max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content}.min-h-fit{min-height:-webkit-fit-content;min-height:-moz-fit-content;min-height:fit-content}.w-screen{width:100vw}.w-full{width:100%}.w-4{width:1rem}.w-1\/2{width:50%}.w-\[0\]{width:0}.w-32{width:8rem}.w-8{width:2rem}.w-20{width:5rem}.w-2\/5{width:40%}.w-5{width:1.25rem}.w-64{width:16rem}.w-3{width:0.75rem}.w-24{width:6rem}.w-auto{width:auto}.w-\[\\w\\\.\]{width:\w\.}.w-10{width:2.5rem}.max-w-screen-xl{max-width:1280px}.max-w-screen-lg{max-width:1024px}.max-w-2xl{max-width:42rem}.max-w-\[350px\]{max-width:350px}.max-w-fit{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}.flex-auto{flex:1 1 auto}.flex-shrink-0{flex-shrink:0}.flex-shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.resize{resize:both}.grid-cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.grid-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:0.25rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.5rem * var(--tw-space-x-reverse));margin-left:calc(0.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.5rem * var(--tw-space-y-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.75rem * var(--tw-space-x-reverse));margin-left:calc(0.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.25rem * var(--tw-space-x-reverse));margin-left:calc(0.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.125rem * var(--tw-space-x-reverse));margin-left:calc(0.125rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-0>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0px * var(--tw-space-x-reverse));margin-left:calc(0px * calc(1 - var(--tw-space-x-reverse)))}.overflow-auto{overflow:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:0.25rem}.rounded-lg{border-radius:0.5rem}.rounded-full{border-radius:9999px}.rounded-sm{border-radius:0.125rem}.rounded-l{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-t-\[22px\]{border-top-width:22px}.border-l-\[25px\]{border-left-width:25px}.border-t-2{border-top-width:2px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-l{border-left-width:1px}.border-dashed{border-style:dashed}.border-tertiary{--tw-border-opacity:1;border-color:rgb(var(--ft-tertiary,31 41 55) / var(--tw-border-opacity))}.border-tertiary\/30{border-color:rgb(var(--ft-tertiary,31 41 55) / 0.3)}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55 / var(--tw-border-opacity))}.border-gray-400{--tw-border-opacity:1;border-color:rgb(156 163 175 / var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235 / var(--tw-border-opacity))}.border-l-transparent{border-left-color:transparent}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255 / var(--tw-bg-opacity))}.bg-secondary{--tw-bg-opacity:1;background-color:rgb(var(--ft-secondary,251 113 133) / var(--tw-bg-opacity))}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-primary\/90{background-color:rgb(var(--ft-primary,59 130 246) / 0.9)}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219 / var(--tw-bg-opacity))}.bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99 / var(--tw-bg-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246 / var(--tw-bg-opacity))}.bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(254 240 138 / var(--tw-bg-opacity))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254 / var(--tw-bg-opacity))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-opacity-75{--tw-bg-opacity:0.75}.fill-current{fill:currentColor}.p-3{padding:0.75rem}.p-5{padding:1.25rem}.p-10{padding:2.5rem}.p-2{padding:0.5rem}.p-4{padding:1rem}.p-2\.5{padding:0.625rem}.p-1{padding:0.25rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.px-3{padding-left:0.75rem;padding-right:0.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.px-1{padding-left:0.25rem;padding-right:0.25rem}.px-2{padding-left:0.5rem;padding-right:0.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-1{padding-top:0.25rem;padding-bottom:0.25rem}.pt-4{padding-top:1rem}.pb-10{padding-bottom:2.5rem}.pl-16{padding-left:4rem}.pb-5{padding-bottom:1.25rem}.pt-2{padding-top:0.5rem}.pl-5{padding-left:1.25rem}.pr-2{padding-right:0.5rem}.pl-2{padding-left:0.5rem}.pr-3{padding-right:0.75rem}.pl-1{padding-left:0.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.font-mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:0.875rem;line-height:1.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-xs{font-size:0.75rem;line-height:1rem}.text-6xl{font-size:3.75rem;line-height:1}.text-5xl{font-size:3rem;line-height:1}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.font-bold{font-weight:700}.font-normal{font-weight:400}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-loose{line-height:2}.text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity))}.text-primary{--tw-text-opacity:1;color:rgb(var(--ft-primary,59 130 246) / var(--tw-text-opacity))}.text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55 / var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81 / var(--tw-text-opacity))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216 / var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219 / var(--tw-text-opacity))}.text-secondary{--tw-text-opacity:1;color:rgb(var(--ft-secondary,251 113 133) / var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128 / var(--tw-text-opacity))}.text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14 / var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28 / var(--tw-text-opacity))}.text-black{--tw-text-opacity:1;color:rgb(0 0 0 / var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235 / var(--tw-text-opacity))}.text-red-100{--tw-text-opacity:1;color:rgb(254 226 226 / var(--tw-text-opacity))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.opacity-50{opacity:0.5}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 rgb(0 0 0 / 0.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.outline-gray-50{outline-color:#f9fafb}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.\!filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow) !important}.transition{transition-property:color, background-color, border-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-text-decoration-color, -webkit-backdrop-filter;transition-property:color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;transition-property:color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-text-decoration-color, -webkit-backdrop-filter;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.placeholder\:text-gray-400::-moz-placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.placeholder\:text-gray-400:-ms-input-placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.placeholder\:text-gray-400::placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.after\:absolute::after{content:var(--tw-content);position:absolute}.after\:top-0\.5::after{content:var(--tw-content);top:0.125rem}.after\:left-\[5px\]::after{content:var(--tw-content);left:5px}.after\:top-0::after{content:var(--tw-content);top:0px}.after\:h-3::after{content:var(--tw-content);height:0.75rem}.after\:w-3::after{content:var(--tw-content);width:0.75rem}.after\:rounded-full::after{content:var(--tw-content);border-radius:9999px}.after\:border::after{content:var(--tw-content);border-width:1px}.after\:border-gray-300::after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.after\:bg-white::after{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.after\:transition-all::after{content:var(--tw-content);transition-property:all;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.after\:content-\[\'\'\]::after{--tw-content:'';content:var(--tw-content)}.hover\:border-indigo-700:hover{--tw-border-opacity:1;border-color:rgb(67 56 202 / var(--tw-border-opacity))}.hover\:bg-indigo-100:hover{--tw-bg-opacity:1;background-color:rgb(224 231 255 / var(--tw-bg-opacity))}.hover\:bg-primary:hover{--tw-bg-opacity:1;background-color:rgb(var(--ft-primary,59 130 246) / var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219 / var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235 / var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.hover\:text-indigo-700:hover{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81 / var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99 / var(--tw-text-opacity))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:outline-indigo-300:focus{outline-color:#a5b4fc}.focus\:outline-quaternary:focus{outline-color:rgb(var(--ft-quaternary,250 204 21) / 1)}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.focus\:drop-shadow-sm:focus{--tw-drop-shadow:drop-shadow(0 1px 1px rgb(0 0 0 / 0.05));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.active\:bg-indigo-50:active{--tw-bg-opacity:1;background-color:rgb(238 242 255 / var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229 / var(--tw-bg-opacity))}.peer:checked~.peer-checked\:after\:translate-x-full::after{content:var(--tw-content);--tw-translate-x:100%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:checked~.peer-checked\:after\:border-white::after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(255 255 255 / var(--tw-border-opacity))}.peer:focus~.peer-focus\:ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.peer:focus~.peer-focus\:ring-indigo-300{--tw-ring-opacity:1;--tw-ring-color:rgb(165 180 252 / var(--tw-ring-opacity))}@media(prefers-color-scheme: dark){.dark\:border-gray-600{--tw-border-opacity:1;border-color:rgb(75 85 99 / var(--tw-border-opacity))}.dark\:bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81 / var(--tw-bg-opacity))}.dark\:text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219 / var(--tw-text-opacity))}.peer:focus~.dark\:peer-focus\:ring-indigo-800{--tw-ring-opacity:1;--tw-ring-color:rgb(55 48 163 / var(--tw-ring-opacity))}}@media(min-width: 640px){.sm\:px-4{padding-left:1rem;padding-right:1rem}}@media(min-width: 768px){.md\:p-6{padding:1.5rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-sm{font-size:0.875rem;line-height:1.25rem}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}} -------------------------------------------------------------------------------- /public/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/fouita/form-editor/b2982cf83534a5ab7004e0007c5962439ab1d36a/public/favicon.png -------------------------------------------------------------------------------- /public/form-editor.css: -------------------------------------------------------------------------------- 1 | /*! tailwindcss v3.1.0 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,sans-serif}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder,textarea:-ms-input-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}::-webkit-backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.form-checkbox,.form-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}.form-checkbox{border-radius:0}.form-radio{border-radius:100%}.form-checkbox:focus,.form-radio:focus{outline:2px solid #0000;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.form-checkbox:checked,.form-radio:checked{border-color:#0000;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}.form-checkbox:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z'/%3E%3C/svg%3E")}.form-radio:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E")}.form-checkbox:checked:focus,.form-checkbox:checked:hover,.form-checkbox:indeterminate,.form-radio:checked:focus,.form-radio:checked:hover{border-color:#0000;background-color:currentColor}.form-checkbox:indeterminate{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");background-size:100% 100%;background-position:50%;background-repeat:no-repeat}.form-checkbox:indeterminate:focus,.form-checkbox:indeterminate:hover{border-color:#0000;background-color:currentColor}.ft .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.ft .visible{visibility:visible}.ft .fixed{position:fixed}.ft .absolute{position:absolute}.ft .relative{position:relative}.ft .right-0{right:0}.ft .top-7{top:28px}.ft .top-0{top:0}.ft .left-0{left:0}.ft .bottom-0{bottom:0}.ft .-left-20{left:-80px}.ft .top-6{top:24px}.ft .top-10{top:40px}.ft .-left-3{left:-12px}.ft .left-0\.5{left:2px}.ft .bottom-10{bottom:40px}.ft .-left-6{left:-24px}.ft .bottom-5{bottom:20px}.ft .top-1{top:4px}.ft .top-2{top:8px}.ft .top-3{top:12px}.ft .top-4{top:16px}.ft .top-5{top:20px}.ft .top-16{top:64px}.ft .top-20{top:80px}.ft .top-40{top:160px}.ft .top-60{top:240px}.ft .top-px{top:1px}.ft .top-0\.5{top:2px}.ft .-top-0{top:0}.ft .-top-1{top:-4px}.ft .-top-2{top:-8px}.ft .-top-3{top:-12px}.ft .-top-4{top:-16px}.ft .-top-5{top:-20px}.ft .-top-10{top:-40px}.ft .-top-16{top:-64px}.ft .-top-20{top:-80px}.ft .-top-40{top:-160px}.ft .-top-60{top:-240px}.ft .-top-px{top:-1px}.ft .-top-0\.5{top:-2px}.ft .bottom-1{bottom:4px}.ft .bottom-2{bottom:8px}.ft .bottom-3{bottom:12px}.ft .bottom-4{bottom:16px}.ft .bottom-16{bottom:64px}.ft .bottom-20{bottom:80px}.ft .bottom-40{bottom:160px}.ft .bottom-60{bottom:240px}.ft .bottom-px{bottom:1px}.ft .bottom-0\.5{bottom:2px}.ft .-bottom-0{bottom:0}.ft .-bottom-1{bottom:-4px}.ft .-bottom-2{bottom:-8px}.ft .-bottom-3{bottom:-12px}.ft .-bottom-4{bottom:-16px}.ft .-bottom-5{bottom:-20px}.ft .-bottom-10{bottom:-40px}.ft .-bottom-16{bottom:-64px}.ft .-bottom-20{bottom:-80px}.ft .-bottom-40{bottom:-160px}.ft .-bottom-60{bottom:-240px}.ft .-bottom-px{bottom:-1px}.ft .-bottom-0\.5{bottom:-2px}.ft .z-50{z-index:50}.ft .z-20{z-index:20}.ft .z-40{z-index:40}.ft .row-auto{grid-row:auto}.ft .m-5{margin:20px}.ft .m-1{margin:4px}.ft .m-0{margin:0}.ft .m-2{margin:8px}.ft .m-3{margin:12px}.ft .m-4{margin:16px}.ft .m-10{margin:40px}.ft .m-16{margin:64px}.ft .m-20{margin:80px}.ft .m-40{margin:160px}.ft .m-60{margin:240px}.ft .m-px{margin:1px}.ft .m-0\.5{margin:2px}.ft .-m-0{margin:0}.ft .-m-1{margin:-4px}.ft .-m-2{margin:-8px}.ft .-m-3{margin:-12px}.ft .-m-4{margin:-16px}.ft .-m-5{margin:-20px}.ft .-m-10{margin:-40px}.ft .-m-16{margin:-64px}.ft .-m-20{margin:-80px}.ft .-m-40{margin:-160px}.ft .-m-60{margin:-240px}.ft .-m-px{margin:-1px}.ft .-m-0\.5{margin:-2px}.ft .mx-auto{margin-left:auto;margin-right:auto}.ft .mx-2{margin-left:8px;margin-right:8px}.ft .my-2{margin-top:8px;margin-bottom:8px}.ft .my-3{margin-top:12px;margin-bottom:12px}.ft .my-4{margin-top:16px}.ft .mb-4,.ft .my-4{margin-bottom:16px}.ft .mt-10{margin-top:40px}.ft .mt-4{margin-top:16px}.ft .ml-2{margin-left:8px}.ft .mb-8{margin-bottom:32px}.ft .mt-8{margin-top:32px}.ft .-ml-1{margin-left:-4px}.ft .-ml-24{margin-left:-96px}.ft .mt-1{margin-top:4px}.ft .mr-2{margin-right:8px}.ft .ml-1{margin-left:4px}.ft .ml-5{margin-left:20px}.ft .-mt-6{margin-top:-24px}.ft .mb-2{margin-bottom:8px}.ft .mt-2{margin-top:8px}.ft .mr-4{margin-right:16px}.ft .ml-16{margin-left:64px}.ft .mt-0{margin-top:0}.ft .mt-3{margin-top:12px}.ft .mt-5{margin-top:20px}.ft .mt-16{margin-top:64px}.ft .mt-20{margin-top:80px}.ft .mt-40{margin-top:160px}.ft .mt-60{margin-top:240px}.ft .mt-px{margin-top:1px}.ft .mt-0\.5{margin-top:2px}.ft .-mt-0{margin-top:0}.ft .-mt-1{margin-top:-4px}.ft .-mt-2{margin-top:-8px}.ft .-mt-3{margin-top:-12px}.ft .-mt-4{margin-top:-16px}.ft .-mt-5{margin-top:-20px}.ft .-mt-10{margin-top:-40px}.ft .-mt-16{margin-top:-64px}.ft .-mt-20{margin-top:-80px}.ft .-mt-40{margin-top:-160px}.ft .-mt-60{margin-top:-240px}.ft .-mt-px{margin-top:-1px}.ft .-mt-0\.5{margin-top:-2px}.ft .mr-0{margin-right:0}.ft .mr-1{margin-right:4px}.ft .mr-3{margin-right:12px}.ft .mr-5{margin-right:20px}.ft .mr-10{margin-right:40px}.ft .mr-16{margin-right:64px}.ft .mr-20{margin-right:80px}.ft .mr-40{margin-right:160px}.ft .mr-60{margin-right:240px}.ft .mr-px{margin-right:1px}.ft .mr-0\.5{margin-right:2px}.ft .-mr-0{margin-right:0}.ft .-mr-1{margin-right:-4px}.ft .-mr-2{margin-right:-8px}.ft .-mr-3{margin-right:-12px}.ft .-mr-4{margin-right:-16px}.ft .-mr-5{margin-right:-20px}.ft .-mr-10{margin-right:-40px}.ft .-mr-16{margin-right:-64px}.ft .-mr-20{margin-right:-80px}.ft .-mr-40{margin-right:-160px}.ft .-mr-60{margin-right:-240px}.ft .-mr-px{margin-right:-1px}.ft .-mr-0\.5{margin-right:-2px}.ft .mb-0{margin-bottom:0}.ft .mb-1{margin-bottom:4px}.ft .mb-3{margin-bottom:12px}.ft .mb-5{margin-bottom:20px}.ft .mb-10{margin-bottom:40px}.ft .mb-16{margin-bottom:64px}.ft .mb-20{margin-bottom:80px}.ft .mb-40{margin-bottom:160px}.ft .mb-60{margin-bottom:240px}.ft .mb-px{margin-bottom:1px}.ft .mb-0\.5{margin-bottom:2px}.ft .-mb-0{margin-bottom:0}.ft .-mb-1{margin-bottom:-4px}.ft .-mb-2{margin-bottom:-8px}.ft .-mb-3{margin-bottom:-12px}.ft .-mb-4{margin-bottom:-16px}.ft .-mb-5{margin-bottom:-20px}.ft .-mb-10{margin-bottom:-40px}.ft .-mb-16{margin-bottom:-64px}.ft .-mb-20{margin-bottom:-80px}.ft .-mb-40{margin-bottom:-160px}.ft .-mb-60{margin-bottom:-240px}.ft .-mb-px{margin-bottom:-1px}.ft .-mb-0\.5{margin-bottom:-2px}.ft .ml-0{margin-left:0}.ft .ml-3{margin-left:12px}.ft .ml-4{margin-left:16px}.ft .ml-10{margin-left:40px}.ft .ml-20{margin-left:80px}.ft .ml-40{margin-left:160px}.ft .ml-60{margin-left:240px}.ft .ml-px{margin-left:1px}.ft .ml-0\.5{margin-left:2px}.ft .-ml-0{margin-left:0}.ft .-ml-2{margin-left:-8px}.ft .-ml-3{margin-left:-12px}.ft .-ml-4{margin-left:-16px}.ft .-ml-5{margin-left:-20px}.ft .-ml-10{margin-left:-40px}.ft .-ml-16{margin-left:-64px}.ft .-ml-20{margin-left:-80px}.ft .-ml-40{margin-left:-160px}.ft .-ml-60{margin-left:-240px}.ft .-ml-px{margin-left:-1px}.ft .-ml-0\.5{margin-left:-2px}.ft .block{display:block}.ft .inline{display:inline}.ft .\!inline{display:inline!important}.ft .flex{display:flex}.ft .inline-flex{display:inline-flex}.ft .grid{display:grid}.ft .hidden{display:none}.ft .h-3\/4{height:75%}.ft .h-screen{height:100vh}.ft .h-5{height:20px}.ft .h-4{height:16px}.ft .h-8{height:32px}.ft .h-3{height:12px}.ft .h-full{height:100%}.ft .h-auto{height:auto}.ft .h-6{height:24px}.ft .h-1{height:4px}.ft .h-0{height:0}.ft .h-10{height:40px}.ft .h-16{height:64px}.ft .h-20{height:80px}.ft .h-32{height:128px}.ft .h-40{height:160px}.ft .h-60{height:240px}.ft .h-80{height:320px}.ft .h-96{height:384px}.ft .h-128{height:512px}.ft .max-h-fit{max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content}.ft .max-h-0{max-height:0}.ft .max-h-3{max-height:12px}.ft .max-h-4{max-height:16px}.ft .max-h-10{max-height:40px}.ft .max-h-16{max-height:64px}.ft .max-h-20{max-height:80px}.ft .max-h-32{max-height:128px}.ft .max-h-40{max-height:160px}.ft .max-h-60{max-height:240px}.ft .max-h-80{max-height:320px}.ft .max-h-96{max-height:384px}.ft .max-h-128{max-height:512px}.ft .max-h-full{max-height:100%}.ft .min-h-fit{min-height:-webkit-fit-content;min-height:-moz-fit-content;min-height:fit-content}.ft .min-h-0{min-height:0}.ft .min-h-full{min-height:100%}.ft .w-screen{width:100vw}.ft .w-full{width:100%}.ft .w-32{width:128px}.ft .w-5{width:20px}.ft .w-4{width:16px}.ft .w-8{width:32px}.ft .w-3{width:12px}.ft .w-64{width:256px}.ft .w-auto{width:auto}.ft .w-\[\\w\\\.\]{width:\w\.}.ft .w-10{width:40px}.ft .w-24{width:96px}.ft .w-6{width:24px}.ft .w-1\/2{width:50%}.ft .w-20{width:80px}.ft .w-2\/5{width:40%}.ft .w-0{width:0}.ft .w-16{width:64px}.ft .w-40{width:160px}.ft .w-60{width:240px}.ft .w-80{width:320px}.ft .w-96{width:384px}.ft .w-128{width:512px}.ft .w-1\/3{width:33.333333%}.ft .w-1\/4{width:25%}.ft .w-1\/5{width:20%}.ft .w-1\/6{width:16.666667%}.ft .w-1\/12{width:8.333333%}.ft .min-w-0{min-width:0}.ft .min-w-full{min-width:100%}.ft .max-w-2xl{max-width:42rem}.ft .max-w-\[350px\]{max-width:350px}.ft .max-w-fit{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}.ft .max-w-0{max-width:0}.ft .max-w-none{max-width:none}.ft .max-w-xs{max-width:20rem}.ft .max-w-sm{max-width:24rem}.ft .max-w-md{max-width:28rem}.ft .max-w-lg{max-width:32rem}.ft .max-w-xl{max-width:36rem}.ft .max-w-3xl{max-width:48rem}.ft .max-w-4xl{max-width:56rem}.ft .max-w-5xl{max-width:64rem}.ft .max-w-6xl{max-width:72rem}.ft .max-w-7xl{max-width:80rem}.ft .max-w-full{max-width:100%}.ft .max-w-min{max-width:-webkit-min-content;max-width:-moz-min-content;max-width:min-content}.ft .max-w-max{max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}.ft .max-w-prose{max-width:65ch}.ft .flex-auto{flex:1 1 auto}.ft .flex-shrink-0,.ft .shrink-0{flex-shrink:0}.ft .flex-grow-0,.ft .grow-0{flex-grow:0}.ft .cursor-pointer{cursor:pointer}.ft .touch-auto{touch-action:auto}.ft .select-none{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ft .scroll-m-0{scroll-margin:0}.ft .scroll-m-1{scroll-margin:4px}.ft .scroll-m-2{scroll-margin:8px}.ft .scroll-m-3{scroll-margin:12px}.ft .scroll-m-4{scroll-margin:16px}.ft .scroll-m-5{scroll-margin:20px}.ft .scroll-m-10{scroll-margin:40px}.ft .scroll-m-16{scroll-margin:64px}.ft .scroll-m-20{scroll-margin:80px}.ft .scroll-m-40{scroll-margin:160px}.ft .scroll-m-60{scroll-margin:240px}.ft .scroll-m-px{scroll-margin:1px}.ft .scroll-m-0\.5{scroll-margin:2px}.ft .-scroll-m-0{scroll-margin:0}.ft .-scroll-m-1{scroll-margin:-4px}.ft .-scroll-m-2{scroll-margin:-8px}.ft .-scroll-m-3{scroll-margin:-12px}.ft .-scroll-m-4{scroll-margin:-16px}.ft .-scroll-m-5{scroll-margin:-20px}.ft .-scroll-m-10{scroll-margin:-40px}.ft .-scroll-m-16{scroll-margin:-64px}.ft .-scroll-m-20{scroll-margin:-80px}.ft .-scroll-m-40{scroll-margin:-160px}.ft .-scroll-m-60{scroll-margin:-240px}.ft .-scroll-m-px{scroll-margin:-1px}.ft .-scroll-m-0\.5{scroll-margin:-2px}.ft .scroll-mt-0{scroll-margin-top:0}.ft .scroll-mt-1{scroll-margin-top:4px}.ft .scroll-mt-2{scroll-margin-top:8px}.ft .scroll-mt-3{scroll-margin-top:12px}.ft .scroll-mt-4{scroll-margin-top:16px}.ft .scroll-mt-5{scroll-margin-top:20px}.ft .scroll-mt-10{scroll-margin-top:40px}.ft .scroll-mt-16{scroll-margin-top:64px}.ft .scroll-mt-20{scroll-margin-top:80px}.ft .scroll-mt-40{scroll-margin-top:160px}.ft .scroll-mt-60{scroll-margin-top:240px}.ft .scroll-mt-px{scroll-margin-top:1px}.ft .scroll-mt-0\.5{scroll-margin-top:2px}.ft .-scroll-mt-0{scroll-margin-top:0}.ft .-scroll-mt-1{scroll-margin-top:-4px}.ft .-scroll-mt-2{scroll-margin-top:-8px}.ft .-scroll-mt-3{scroll-margin-top:-12px}.ft .-scroll-mt-4{scroll-margin-top:-16px}.ft .-scroll-mt-5{scroll-margin-top:-20px}.ft .-scroll-mt-10{scroll-margin-top:-40px}.ft .-scroll-mt-16{scroll-margin-top:-64px}.ft .-scroll-mt-20{scroll-margin-top:-80px}.ft .-scroll-mt-40{scroll-margin-top:-160px}.ft .-scroll-mt-60{scroll-margin-top:-240px}.ft .-scroll-mt-px{scroll-margin-top:-1px}.ft .-scroll-mt-0\.5{scroll-margin-top:-2px}.ft .scroll-mr-0{scroll-margin-right:0}.ft .scroll-mr-1{scroll-margin-right:4px}.ft .scroll-mr-2{scroll-margin-right:8px}.ft .scroll-mr-3{scroll-margin-right:12px}.ft .scroll-mr-4{scroll-margin-right:16px}.ft .scroll-mr-5{scroll-margin-right:20px}.ft .scroll-mr-10{scroll-margin-right:40px}.ft .scroll-mr-16{scroll-margin-right:64px}.ft .scroll-mr-20{scroll-margin-right:80px}.ft .scroll-mr-40{scroll-margin-right:160px}.ft .scroll-mr-60{scroll-margin-right:240px}.ft .scroll-mr-px{scroll-margin-right:1px}.ft .scroll-mr-0\.5{scroll-margin-right:2px}.ft .-scroll-mr-0{scroll-margin-right:0}.ft .-scroll-mr-1{scroll-margin-right:-4px}.ft .-scroll-mr-2{scroll-margin-right:-8px}.ft .-scroll-mr-3{scroll-margin-right:-12px}.ft .-scroll-mr-4{scroll-margin-right:-16px}.ft .-scroll-mr-5{scroll-margin-right:-20px}.ft .-scroll-mr-10{scroll-margin-right:-40px}.ft .-scroll-mr-16{scroll-margin-right:-64px}.ft .-scroll-mr-20{scroll-margin-right:-80px}.ft .-scroll-mr-40{scroll-margin-right:-160px}.ft .-scroll-mr-60{scroll-margin-right:-240px}.ft .-scroll-mr-px{scroll-margin-right:-1px}.ft .-scroll-mr-0\.5{scroll-margin-right:-2px}.ft .scroll-mb-0{scroll-margin-bottom:0}.ft .scroll-mb-1{scroll-margin-bottom:4px}.ft .scroll-mb-2{scroll-margin-bottom:8px}.ft .scroll-mb-3{scroll-margin-bottom:12px}.ft .scroll-mb-4{scroll-margin-bottom:16px}.ft .scroll-mb-5{scroll-margin-bottom:20px}.ft .scroll-mb-10{scroll-margin-bottom:40px}.ft .scroll-mb-16{scroll-margin-bottom:64px}.ft .scroll-mb-20{scroll-margin-bottom:80px}.ft .scroll-mb-40{scroll-margin-bottom:160px}.ft .scroll-mb-60{scroll-margin-bottom:240px}.ft .scroll-mb-px{scroll-margin-bottom:1px}.ft .scroll-mb-0\.5{scroll-margin-bottom:2px}.ft .-scroll-mb-0{scroll-margin-bottom:0}.ft .-scroll-mb-1{scroll-margin-bottom:-4px}.ft .-scroll-mb-2{scroll-margin-bottom:-8px}.ft .-scroll-mb-3{scroll-margin-bottom:-12px}.ft .-scroll-mb-4{scroll-margin-bottom:-16px}.ft .-scroll-mb-5{scroll-margin-bottom:-20px}.ft .-scroll-mb-10{scroll-margin-bottom:-40px}.ft .-scroll-mb-16{scroll-margin-bottom:-64px}.ft .-scroll-mb-20{scroll-margin-bottom:-80px}.ft .-scroll-mb-40{scroll-margin-bottom:-160px}.ft .-scroll-mb-60{scroll-margin-bottom:-240px}.ft .-scroll-mb-px{scroll-margin-bottom:-1px}.ft .-scroll-mb-0\.5{scroll-margin-bottom:-2px}.ft .scroll-ml-0{scroll-margin-left:0}.ft .scroll-ml-1{scroll-margin-left:4px}.ft .scroll-ml-2{scroll-margin-left:8px}.ft .scroll-ml-3{scroll-margin-left:12px}.ft .scroll-ml-4{scroll-margin-left:16px}.ft .scroll-ml-5{scroll-margin-left:20px}.ft .scroll-ml-10{scroll-margin-left:40px}.ft .scroll-ml-16{scroll-margin-left:64px}.ft .scroll-ml-20{scroll-margin-left:80px}.ft .scroll-ml-40{scroll-margin-left:160px}.ft .scroll-ml-60{scroll-margin-left:240px}.ft .scroll-ml-px{scroll-margin-left:1px}.ft .scroll-ml-0\.5{scroll-margin-left:2px}.ft .-scroll-ml-0{scroll-margin-left:0}.ft .-scroll-ml-1{scroll-margin-left:-4px}.ft .-scroll-ml-2{scroll-margin-left:-8px}.ft .-scroll-ml-3{scroll-margin-left:-12px}.ft .-scroll-ml-4{scroll-margin-left:-16px}.ft .-scroll-ml-5{scroll-margin-left:-20px}.ft .-scroll-ml-10{scroll-margin-left:-40px}.ft .-scroll-ml-16{scroll-margin-left:-64px}.ft .-scroll-ml-20{scroll-margin-left:-80px}.ft .-scroll-ml-40{scroll-margin-left:-160px}.ft .-scroll-ml-60{scroll-margin-left:-240px}.ft .-scroll-ml-px{scroll-margin-left:-1px}.ft .-scroll-ml-0\.5{scroll-margin-left:-2px}.ft .scroll-p-0{scroll-padding:0}.ft .scroll-p-1{scroll-padding:4px}.ft .scroll-p-2{scroll-padding:8px}.ft .scroll-p-3{scroll-padding:12px}.ft .scroll-p-4{scroll-padding:16px}.ft .scroll-p-5{scroll-padding:20px}.ft .scroll-p-10{scroll-padding:40px}.ft .scroll-p-16{scroll-padding:64px}.ft .scroll-p-20{scroll-padding:80px}.ft .scroll-p-40{scroll-padding:160px}.ft .scroll-p-60{scroll-padding:240px}.ft .scroll-p-px{scroll-padding:1px}.ft .scroll-p-0\.5{scroll-padding:2px}.ft .scroll-pt-0{scroll-padding-top:0}.ft .scroll-pt-1{scroll-padding-top:4px}.ft .scroll-pt-2{scroll-padding-top:8px}.ft .scroll-pt-3{scroll-padding-top:12px}.ft .scroll-pt-4{scroll-padding-top:16px}.ft .scroll-pt-5{scroll-padding-top:20px}.ft .scroll-pt-10{scroll-padding-top:40px}.ft .scroll-pt-16{scroll-padding-top:64px}.ft .scroll-pt-20{scroll-padding-top:80px}.ft .scroll-pt-40{scroll-padding-top:160px}.ft .scroll-pt-60{scroll-padding-top:240px}.ft .scroll-pt-px{scroll-padding-top:1px}.ft .scroll-pt-0\.5{scroll-padding-top:2px}.ft .scroll-pr-0{scroll-padding-right:0}.ft .scroll-pr-1{scroll-padding-right:4px}.ft .scroll-pr-2{scroll-padding-right:8px}.ft .scroll-pr-3{scroll-padding-right:12px}.ft .scroll-pr-4{scroll-padding-right:16px}.ft .scroll-pr-5{scroll-padding-right:20px}.ft .scroll-pr-10{scroll-padding-right:40px}.ft .scroll-pr-16{scroll-padding-right:64px}.ft .scroll-pr-20{scroll-padding-right:80px}.ft .scroll-pr-40{scroll-padding-right:160px}.ft .scroll-pr-60{scroll-padding-right:240px}.ft .scroll-pr-px{scroll-padding-right:1px}.ft .scroll-pr-0\.5{scroll-padding-right:2px}.ft .scroll-pb-0{scroll-padding-bottom:0}.ft .scroll-pb-1{scroll-padding-bottom:4px}.ft .scroll-pb-2{scroll-padding-bottom:8px}.ft .scroll-pb-3{scroll-padding-bottom:12px}.ft .scroll-pb-4{scroll-padding-bottom:16px}.ft .scroll-pb-5{scroll-padding-bottom:20px}.ft .scroll-pb-10{scroll-padding-bottom:40px}.ft .scroll-pb-16{scroll-padding-bottom:64px}.ft .scroll-pb-20{scroll-padding-bottom:80px}.ft .scroll-pb-40{scroll-padding-bottom:160px}.ft .scroll-pb-60{scroll-padding-bottom:240px}.ft .scroll-pb-px{scroll-padding-bottom:1px}.ft .scroll-pb-0\.5{scroll-padding-bottom:2px}.ft .scroll-pl-0{scroll-padding-left:0}.ft .scroll-pl-1{scroll-padding-left:4px}.ft .scroll-pl-2{scroll-padding-left:8px}.ft .scroll-pl-3{scroll-padding-left:12px}.ft .scroll-pl-4{scroll-padding-left:16px}.ft .scroll-pl-5{scroll-padding-left:20px}.ft .scroll-pl-10{scroll-padding-left:40px}.ft .scroll-pl-16{scroll-padding-left:64px}.ft .scroll-pl-20{scroll-padding-left:80px}.ft .scroll-pl-40{scroll-padding-left:160px}.ft .scroll-pl-60{scroll-padding-left:240px}.ft .scroll-pl-px{scroll-padding-left:1px}.ft .scroll-pl-0\.5{scroll-padding-left:2px}.ft .grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.ft .grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.ft .flex-row{flex-direction:row}.ft .flex-col{flex-direction:column}.ft .place-items-start{place-items:start}.ft .place-items-end{place-items:end}.ft .place-items-center{place-items:center}.ft .place-items-stretch{place-items:stretch}.ft .items-start{align-items:flex-start}.ft .items-end{align-items:flex-end}.ft .items-center{align-items:center}.ft .items-baseline{align-items:baseline}.ft .items-stretch{align-items:stretch}.ft .justify-start{justify-content:flex-start}.ft .justify-end{justify-content:flex-end}.ft .justify-center{justify-content:center}.ft .justify-between{justify-content:space-between}.ft .justify-around{justify-content:space-around}.ft .justify-evenly{justify-content:space-evenly}.ft .justify-items-start{justify-items:start}.ft .justify-items-end{justify-items:end}.ft .justify-items-center{justify-items:center}.ft .justify-items-stretch{justify-items:stretch}.ft .gap-1{gap:4px}.ft .gap-0{gap:0}.ft .gap-2{gap:8px}.ft .gap-3{gap:12px}.ft .gap-4{gap:16px}.ft .gap-5{gap:20px}.ft .gap-10{gap:40px}.ft .gap-16{gap:64px}.ft .gap-20{gap:80px}.ft .gap-40{gap:160px}.ft .gap-60{gap:240px}.ft .gap-px{gap:1px}.ft .gap-0\.5{gap:2px}.ft .space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(4px*var(--tw-space-x-reverse));margin-left:calc(4px*(1 - var(--tw-space-x-reverse)))}.ft .space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(8px*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(8px*var(--tw-space-y-reverse))}.ft .space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(12px*var(--tw-space-x-reverse));margin-left:calc(12px*(1 - var(--tw-space-x-reverse)))}.ft .space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(8px*var(--tw-space-x-reverse));margin-left:calc(8px*(1 - var(--tw-space-x-reverse)))}.ft .space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(2px*var(--tw-space-x-reverse));margin-left:calc(2px*(1 - var(--tw-space-x-reverse)))}.ft .overflow-auto{overflow:auto}.ft .whitespace-nowrap{white-space:nowrap}.ft .rounded{border-radius:.25rem}.ft .rounded-none{border-radius:0}.ft .rounded-lg{border-radius:.5rem}.ft .rounded-sm{border-radius:.125rem}.ft .rounded-full{border-radius:9999px}.ft .rounded-md{border-radius:.375rem}.ft .rounded-xl{border-radius:.75rem}.ft .rounded-2xl{border-radius:1rem}.ft .rounded-3xl{border-radius:1.5rem}.ft .rounded-l{border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.ft .rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.ft .rounded-r{border-top-right-radius:.25rem}.ft .rounded-b,.ft .rounded-r{border-bottom-right-radius:.25rem}.ft .rounded-b{border-bottom-left-radius:.25rem}.ft .rounded-tl{border-top-left-radius:.25rem}.ft .rounded-tr{border-top-right-radius:.25rem}.ft .rounded-br{border-bottom-right-radius:.25rem}.ft .rounded-bl{border-bottom-left-radius:.25rem}.ft .border{border-width:1px}.ft .border-0{border-width:0}.ft .border-2{border-width:2px}.ft .border-l-4{border-left-width:4px}.ft .border-t{border-top-width:1px}.ft .border-b{border-bottom-width:1px}.ft .border-r{border-right-width:1px}.ft .border-l{border-left-width:1px}.ft .border-t-2{border-top-width:2px}.ft .border-dashed{border-style:dashed}.ft .border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity))}.ft .border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.ft .border-gray-400{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity))}.ft .border-tertiary{--tw-border-opacity:1;border-color:rgb(var(--ft-tertiary,31 41 55)/var(--tw-border-opacity))}.ft .border-tertiary\/50{border-color:rgb(var(--ft-tertiary,31 41 55)/.5)}.ft .border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.ft .bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.ft .bg-transparent{background-color:initial}.ft .bg-secondary{--tw-bg-opacity:1;background-color:rgb(var(--ft-secondary,251 113 133)/var(--tw-bg-opacity))}.ft .bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.ft .bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity))}.ft .bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.ft .bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(254 240 138/var(--tw-bg-opacity))}.ft .bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.ft .bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity))}.ft .bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity))}.ft .bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity))}.ft .bg-primary\/90{background-color:rgb(var(--ft-primary,59 130 246)/.9)}.ft .bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}.ft .bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.ft .bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.ft .bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.ft .bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.ft .bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}.ft .bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.ft .bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}.ft .bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}.ft .bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.ft .bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity))}.ft .bg-red-200{--tw-bg-opacity:1;background-color:rgb(254 202 202/var(--tw-bg-opacity))}.ft .bg-red-300{--tw-bg-opacity:1;background-color:rgb(252 165 165/var(--tw-bg-opacity))}.ft .bg-red-400{--tw-bg-opacity:1;background-color:rgb(248 113 113/var(--tw-bg-opacity))}.ft .bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity))}.ft .bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.ft .bg-red-800{--tw-bg-opacity:1;background-color:rgb(153 27 27/var(--tw-bg-opacity))}.ft .bg-red-900{--tw-bg-opacity:1;background-color:rgb(127 29 29/var(--tw-bg-opacity))}.ft .bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity))}.ft .bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity))}.ft .bg-yellow-300{--tw-bg-opacity:1;background-color:rgb(253 224 71/var(--tw-bg-opacity))}.ft .bg-yellow-400{--tw-bg-opacity:1;background-color:rgb(250 204 21/var(--tw-bg-opacity))}.ft .bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity))}.ft .bg-yellow-600{--tw-bg-opacity:1;background-color:rgb(202 138 4/var(--tw-bg-opacity))}.ft .bg-yellow-700{--tw-bg-opacity:1;background-color:rgb(161 98 7/var(--tw-bg-opacity))}.ft .bg-yellow-800{--tw-bg-opacity:1;background-color:rgb(133 77 14/var(--tw-bg-opacity))}.ft .bg-yellow-900{--tw-bg-opacity:1;background-color:rgb(113 63 18/var(--tw-bg-opacity))}.ft .bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity))}.ft .bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity))}.ft .bg-green-200{--tw-bg-opacity:1;background-color:rgb(187 247 208/var(--tw-bg-opacity))}.ft .bg-green-300{--tw-bg-opacity:1;background-color:rgb(134 239 172/var(--tw-bg-opacity))}.ft .bg-green-400{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity))}.ft .bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity))}.ft .bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity))}.ft .bg-green-700{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity))}.ft .bg-green-800{--tw-bg-opacity:1;background-color:rgb(22 101 52/var(--tw-bg-opacity))}.ft .bg-green-900{--tw-bg-opacity:1;background-color:rgb(20 83 45/var(--tw-bg-opacity))}.ft .bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity))}.ft .bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity))}.ft .bg-blue-300{--tw-bg-opacity:1;background-color:rgb(147 197 253/var(--tw-bg-opacity))}.ft .bg-blue-400{--tw-bg-opacity:1;background-color:rgb(96 165 250/var(--tw-bg-opacity))}.ft .bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity))}.ft .bg-blue-800{--tw-bg-opacity:1;background-color:rgb(30 64 175/var(--tw-bg-opacity))}.ft .bg-blue-900{--tw-bg-opacity:1;background-color:rgb(30 58 138/var(--tw-bg-opacity))}.ft .bg-indigo-100{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity))}.ft .bg-indigo-200{--tw-bg-opacity:1;background-color:rgb(199 210 254/var(--tw-bg-opacity))}.ft .bg-indigo-300{--tw-bg-opacity:1;background-color:rgb(165 180 252/var(--tw-bg-opacity))}.ft .bg-indigo-400{--tw-bg-opacity:1;background-color:rgb(129 140 248/var(--tw-bg-opacity))}.ft .bg-indigo-500{--tw-bg-opacity:1;background-color:rgb(99 102 241/var(--tw-bg-opacity))}.ft .bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.ft .bg-indigo-700{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.ft .bg-indigo-800{--tw-bg-opacity:1;background-color:rgb(55 48 163/var(--tw-bg-opacity))}.ft .bg-indigo-900{--tw-bg-opacity:1;background-color:rgb(49 46 129/var(--tw-bg-opacity))}.ft .bg-purple-50{--tw-bg-opacity:1;background-color:rgb(250 245 255/var(--tw-bg-opacity))}.ft .bg-purple-100{--tw-bg-opacity:1;background-color:rgb(243 232 255/var(--tw-bg-opacity))}.ft .bg-purple-200{--tw-bg-opacity:1;background-color:rgb(233 213 255/var(--tw-bg-opacity))}.ft .bg-purple-300{--tw-bg-opacity:1;background-color:rgb(216 180 254/var(--tw-bg-opacity))}.ft .bg-purple-400{--tw-bg-opacity:1;background-color:rgb(192 132 252/var(--tw-bg-opacity))}.ft .bg-purple-500{--tw-bg-opacity:1;background-color:rgb(168 85 247/var(--tw-bg-opacity))}.ft .bg-purple-600{--tw-bg-opacity:1;background-color:rgb(147 51 234/var(--tw-bg-opacity))}.ft .bg-purple-700{--tw-bg-opacity:1;background-color:rgb(126 34 206/var(--tw-bg-opacity))}.ft .bg-purple-800{--tw-bg-opacity:1;background-color:rgb(107 33 168/var(--tw-bg-opacity))}.ft .bg-purple-900{--tw-bg-opacity:1;background-color:rgb(88 28 135/var(--tw-bg-opacity))}.ft .bg-pink-50{--tw-bg-opacity:1;background-color:rgb(253 242 248/var(--tw-bg-opacity))}.ft .bg-pink-100{--tw-bg-opacity:1;background-color:rgb(252 231 243/var(--tw-bg-opacity))}.ft .bg-pink-200{--tw-bg-opacity:1;background-color:rgb(251 207 232/var(--tw-bg-opacity))}.ft .bg-pink-300{--tw-bg-opacity:1;background-color:rgb(249 168 212/var(--tw-bg-opacity))}.ft .bg-pink-400{--tw-bg-opacity:1;background-color:rgb(244 114 182/var(--tw-bg-opacity))}.ft .bg-pink-500{--tw-bg-opacity:1;background-color:rgb(236 72 153/var(--tw-bg-opacity))}.ft .bg-pink-600{--tw-bg-opacity:1;background-color:rgb(219 39 119/var(--tw-bg-opacity))}.ft .bg-pink-700{--tw-bg-opacity:1;background-color:rgb(190 24 93/var(--tw-bg-opacity))}.ft .bg-pink-800{--tw-bg-opacity:1;background-color:rgb(157 23 77/var(--tw-bg-opacity))}.ft .bg-pink-900{--tw-bg-opacity:1;background-color:rgb(131 24 67/var(--tw-bg-opacity))}.ft .bg-opacity-50{--tw-bg-opacity:0.5}.ft .bg-opacity-75{--tw-bg-opacity:0.75}.ft .fill-current{fill:currentColor}.ft .p-3{padding:12px}.ft .p-5{padding:20px}.ft .p-10{padding:40px}.ft .p-2{padding:8px}.ft .p-4{padding:16px}.ft .p-1{padding:4px}.ft .p-2\.5{padding:10px}.ft .p-0{padding:0}.ft .p-16{padding:64px}.ft .p-20{padding:80px}.ft .p-40{padding:160px}.ft .p-60{padding:240px}.ft .p-px{padding:1px}.ft .p-0\.5{padding:2px}.ft .px-4{padding-left:16px;padding-right:16px}.ft .py-2{padding-top:8px;padding-bottom:8px}.ft .px-3{padding-left:12px;padding-right:12px}.ft .px-8{padding-left:32px;padding-right:32px}.ft .py-6{padding-top:24px;padding-bottom:24px}.ft .px-1{padding-left:4px;padding-right:4px}.ft .py-1{padding-top:4px;padding-bottom:4px}.ft .px-2{padding-left:8px;padding-right:8px}.ft .px-5{padding-left:20px;padding-right:20px}.ft .px-10{padding-left:40px;padding-right:40px}.ft .py-2\.5{padding-top:10px;padding-bottom:10px}.ft .pt-4{padding-top:16px}.ft .pb-10{padding-bottom:40px}.ft .pl-16{padding-left:64px}.ft .pb-5{padding-bottom:20px}.ft .pl-2{padding-left:8px}.ft .pr-3{padding-right:12px}.ft .pr-2{padding-right:8px}.ft .pl-1{padding-left:4px}.ft .pt-2{padding-top:8px}.ft .pl-5{padding-left:20px}.ft .pt-0{padding-top:0}.ft .pt-1{padding-top:4px}.ft .pt-3{padding-top:12px}.ft .pt-5{padding-top:20px}.ft .pt-10{padding-top:40px}.ft .pt-16{padding-top:64px}.ft .pt-20{padding-top:80px}.ft .pt-40{padding-top:160px}.ft .pt-60{padding-top:240px}.ft .pt-px{padding-top:1px}.ft .pt-0\.5{padding-top:2px}.ft .pr-0{padding-right:0}.ft .pr-1{padding-right:4px}.ft .pr-4{padding-right:16px}.ft .pr-5{padding-right:20px}.ft .pr-10{padding-right:40px}.ft .pr-16{padding-right:64px}.ft .pr-20{padding-right:80px}.ft .pr-40{padding-right:160px}.ft .pr-60{padding-right:240px}.ft .pr-px{padding-right:1px}.ft .pr-0\.5{padding-right:2px}.ft .pb-0{padding-bottom:0}.ft .pb-1{padding-bottom:4px}.ft .pb-2{padding-bottom:8px}.ft .pb-3{padding-bottom:12px}.ft .pb-4{padding-bottom:16px}.ft .pb-16{padding-bottom:64px}.ft .pb-20{padding-bottom:80px}.ft .pb-40{padding-bottom:160px}.ft .pb-60{padding-bottom:240px}.ft .pb-px{padding-bottom:1px}.ft .pb-0\.5{padding-bottom:2px}.ft .pl-0{padding-left:0}.ft .pl-3{padding-left:12px}.ft .pl-4{padding-left:16px}.ft .pl-10{padding-left:40px}.ft .pl-20{padding-left:80px}.ft .pl-40{padding-left:160px}.ft .pl-60{padding-left:240px}.ft .pl-px{padding-left:1px}.ft .pl-0\.5{padding-left:2px}.ft .text-left{text-align:left}.ft .text-center{text-align:center}.ft .text-right{text-align:right}.ft .text-justify{text-align:justify}.ft .font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.ft .text-xl{font-size:20px}.ft .text-lg{font-size:18px}.ft .text-2xl{font-size:24px}.ft .text-sm{font-size:14px}.ft .text-xs{font-size:12px}.ft .text-6xl{font-size:60px}.ft .text-5xl{font-size:48px}.ft .text-4xl{font-size:36px}.ft .text-3xl{font-size:30px}.ft .text-base{font-size:16px}.ft .font-semibold{font-weight:600}.ft .font-medium{font-weight:500}.ft .font-bold{font-weight:700}.ft .font-normal{font-weight:400}.ft .capitalize{text-transform:capitalize}.ft .italic{font-style:italic}.ft .leading-3{line-height:12px}.ft .leading-4{line-height:16px}.ft .leading-5{line-height:20px}.ft .leading-6{line-height:24px}.ft .leading-7{line-height:28px}.ft .leading-8{line-height:32px}.ft .leading-9{line-height:36px}.ft .leading-10{line-height:40px}.ft .leading-none{line-height:1}.ft .leading-tight{line-height:1.25}.ft .leading-snug{line-height:1.375}.ft .leading-normal{line-height:1.5}.ft .leading-relaxed{line-height:1.625}.ft .leading-loose{line-height:2}.ft .text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity))}.ft .text-primary{--tw-text-opacity:1;color:rgb(var(--ft-primary,59 130 246)/var(--tw-text-opacity))}.ft .text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity))}.ft .text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.ft .text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.ft .text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity))}.ft .text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.ft .text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity))}.ft .text-red-100{--tw-text-opacity:1;color:rgb(254 226 226/var(--tw-text-opacity))}.ft .text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity))}.ft .text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity))}.ft .text-primary\/40{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .text-secondary{--tw-text-opacity:1;color:rgb(var(--ft-secondary,251 113 133)/var(--tw-text-opacity))}.ft .text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.ft .text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity))}.ft .text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.ft .text-gray-50{--tw-text-opacity:1;color:rgb(249 250 251/var(--tw-text-opacity))}.ft .text-gray-100{--tw-text-opacity:1;color:rgb(243 244 246/var(--tw-text-opacity))}.ft .text-gray-200{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity))}.ft .text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}.ft .text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.ft .text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.ft .text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.ft .text-red-50{--tw-text-opacity:1;color:rgb(254 242 242/var(--tw-text-opacity))}.ft .text-red-200{--tw-text-opacity:1;color:rgb(254 202 202/var(--tw-text-opacity))}.ft .text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity))}.ft .text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity))}.ft .text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity))}.ft .text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity))}.ft .text-red-900{--tw-text-opacity:1;color:rgb(127 29 29/var(--tw-text-opacity))}.ft .text-yellow-50{--tw-text-opacity:1;color:rgb(254 252 232/var(--tw-text-opacity))}.ft .text-yellow-100{--tw-text-opacity:1;color:rgb(254 249 195/var(--tw-text-opacity))}.ft .text-yellow-200{--tw-text-opacity:1;color:rgb(254 240 138/var(--tw-text-opacity))}.ft .text-yellow-300{--tw-text-opacity:1;color:rgb(253 224 71/var(--tw-text-opacity))}.ft .text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity))}.ft .text-yellow-500{--tw-text-opacity:1;color:rgb(234 179 8/var(--tw-text-opacity))}.ft .text-yellow-600{--tw-text-opacity:1;color:rgb(202 138 4/var(--tw-text-opacity))}.ft .text-yellow-700{--tw-text-opacity:1;color:rgb(161 98 7/var(--tw-text-opacity))}.ft .text-yellow-900{--tw-text-opacity:1;color:rgb(113 63 18/var(--tw-text-opacity))}.ft .text-green-50{--tw-text-opacity:1;color:rgb(240 253 244/var(--tw-text-opacity))}.ft .text-green-100{--tw-text-opacity:1;color:rgb(220 252 231/var(--tw-text-opacity))}.ft .text-green-200{--tw-text-opacity:1;color:rgb(187 247 208/var(--tw-text-opacity))}.ft .text-green-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity))}.ft .text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity))}.ft .text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity))}.ft .text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity))}.ft .text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity))}.ft .text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity))}.ft .text-green-900{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity))}.ft .text-blue-50{--tw-text-opacity:1;color:rgb(239 246 255/var(--tw-text-opacity))}.ft .text-blue-200{--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity))}.ft .text-blue-300{--tw-text-opacity:1;color:rgb(147 197 253/var(--tw-text-opacity))}.ft .text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity))}.ft .text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity))}.ft .text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity))}.ft .text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity))}.ft .text-indigo-50{--tw-text-opacity:1;color:rgb(238 242 255/var(--tw-text-opacity))}.ft .text-indigo-100{--tw-text-opacity:1;color:rgb(224 231 255/var(--tw-text-opacity))}.ft .text-indigo-200{--tw-text-opacity:1;color:rgb(199 210 254/var(--tw-text-opacity))}.ft .text-indigo-300{--tw-text-opacity:1;color:rgb(165 180 252/var(--tw-text-opacity))}.ft .text-indigo-400{--tw-text-opacity:1;color:rgb(129 140 248/var(--tw-text-opacity))}.ft .text-indigo-500{--tw-text-opacity:1;color:rgb(99 102 241/var(--tw-text-opacity))}.ft .text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity))}.ft .text-indigo-800{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity))}.ft .text-indigo-900{--tw-text-opacity:1;color:rgb(49 46 129/var(--tw-text-opacity))}.ft .text-purple-50{--tw-text-opacity:1;color:rgb(250 245 255/var(--tw-text-opacity))}.ft .text-purple-100{--tw-text-opacity:1;color:rgb(243 232 255/var(--tw-text-opacity))}.ft .text-purple-200{--tw-text-opacity:1;color:rgb(233 213 255/var(--tw-text-opacity))}.ft .text-purple-300{--tw-text-opacity:1;color:rgb(216 180 254/var(--tw-text-opacity))}.ft .text-purple-400{--tw-text-opacity:1;color:rgb(192 132 252/var(--tw-text-opacity))}.ft .text-purple-500{--tw-text-opacity:1;color:rgb(168 85 247/var(--tw-text-opacity))}.ft .text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234/var(--tw-text-opacity))}.ft .text-purple-700{--tw-text-opacity:1;color:rgb(126 34 206/var(--tw-text-opacity))}.ft .text-purple-800{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity))}.ft .text-purple-900{--tw-text-opacity:1;color:rgb(88 28 135/var(--tw-text-opacity))}.ft .text-pink-50{--tw-text-opacity:1;color:rgb(253 242 248/var(--tw-text-opacity))}.ft .text-pink-100{--tw-text-opacity:1;color:rgb(252 231 243/var(--tw-text-opacity))}.ft .text-pink-200{--tw-text-opacity:1;color:rgb(251 207 232/var(--tw-text-opacity))}.ft .text-pink-300{--tw-text-opacity:1;color:rgb(249 168 212/var(--tw-text-opacity))}.ft .text-pink-400{--tw-text-opacity:1;color:rgb(244 114 182/var(--tw-text-opacity))}.ft .text-pink-500{--tw-text-opacity:1;color:rgb(236 72 153/var(--tw-text-opacity))}.ft .text-pink-600{--tw-text-opacity:1;color:rgb(219 39 119/var(--tw-text-opacity))}.ft .text-pink-700{--tw-text-opacity:1;color:rgb(190 24 93/var(--tw-text-opacity))}.ft .text-pink-800{--tw-text-opacity:1;color:rgb(157 23 77/var(--tw-text-opacity))}.ft .text-pink-900{--tw-text-opacity:1;color:rgb(131 24 67/var(--tw-text-opacity))}.ft .underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.ft .line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.ft .opacity-50{opacity:.5}.ft .shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.ft .shadow,.ft .shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ft .shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.ft .shadow-inner{--tw-shadow:inset 0 2px 4px 0 #0000000d;--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color)}.ft .shadow-inner,.ft .shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ft .shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.ft .outline-none{outline:2px solid #0000;outline-offset:2px}.ft .outline{outline-style:solid}.ft .outline-gray-50{outline-color:#f9fafb}.ft .grayscale{--tw-grayscale:grayscale(100%)}.ft .filter,.ft .grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ft .placeholder\:text-primary\/40::-moz-placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .placeholder\:text-primary\/40:-ms-input-placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .placeholder\:text-primary\/40::placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .after\:absolute:after{content:var(--tw-content);position:absolute}.ft .after\:top-0\.5:after{content:var(--tw-content);top:2px}.ft .after\:left-\[5px\]:after{content:var(--tw-content);left:5px}.ft .after\:h-3:after{content:var(--tw-content);height:12px}.ft .after\:w-3:after{content:var(--tw-content);width:12px}.ft .after\:rounded-full:after{content:var(--tw-content);border-radius:9999px}.ft .after\:border:after{content:var(--tw-content);border-width:1px}.ft .after\:border-gray-300:after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.ft .after\:bg-white:after{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.ft .after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ft .after\:content-\[\'\'\]:after{--tw-content:"";content:var(--tw-content)}.ft .hover\:border-indigo-700:hover{--tw-border-opacity:1;border-color:rgb(67 56 202/var(--tw-border-opacity))}.ft .hover\:bg-indigo-100:hover{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity))}.ft .hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.ft .hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.ft .hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.ft .hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.ft .hover\:bg-primary:hover{--tw-bg-opacity:1;background-color:rgb(var(--ft-primary,59 130 246)/var(--tw-bg-opacity))}.ft .hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.ft .hover\:text-indigo-700:hover{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity))}.ft .hover\:text-primary\/60:hover{color:rgb(var(--ft-primary,59 130 246)/.6)}.ft .focus\:border-transparent:focus{border-color:#0000}.ft .focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.ft .focus\:outline-indigo-300:focus{outline-color:#a5b4fc}.ft .focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ft .focus\:ring-quaternary:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(var(--ft-quaternary,250 204 21)/var(--tw-ring-opacity))}.ft .focus\:drop-shadow-sm:focus{--tw-drop-shadow:drop-shadow(0 1px 1px #0000000d);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ft .active\:bg-indigo-50:active{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.ft .peer:checked~.peer-checked\:bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.ft .peer:checked~.peer-checked\:after\:translate-x-full:after{content:var(--tw-content);--tw-translate-x:100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.ft .peer:checked~.peer-checked\:after\:border-white:after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity))}.ft [dir=rtl] .rtl\:ml-2{margin-left:8px}@media (min-width:640px){.ft .sm\:mr-4{margin-right:16px}.ft .sm\:flex{display:flex}.ft .sm\:w-1\/2{width:50%}.ft .sm\:w-1\/3{width:33.333333%}.ft .sm\:w-1\/4{width:25%}.ft .sm\:w-1\/5{width:20%}.ft .sm\:w-1\/6{width:16.666667%}.ft .sm\:w-1\/12{width:8.333333%}.ft .sm\:px-4{padding-left:16px;padding-right:16px}}@media (min-width:768px){.ft .md\:p-6{padding:24px}.ft .md\:text-xl{font-size:20px}.ft .md\:text-sm{font-size:14px}.ft .md\:text-base{font-size:16px}.ft .md\:text-6xl{font-size:60px}.ft .md\:text-5xl{font-size:48px}.ft .md\:text-4xl{font-size:36px}.ft .md\:text-3xl{font-size:30px}.ft .md\:text-2xl{font-size:24px}} -------------------------------------------------------------------------------- /scripts/setupTypeScript.js: -------------------------------------------------------------------------------- 1 | // @ts-check 2 | 3 | /** This script modifies the project to support TS code in .svelte files like: 4 | 5 | 8 | 9 | As well as validating the code for CI. 10 | */ 11 | 12 | /** To work on this script: 13 | rm -rf test-template template && git clone sveltejs/template test-template && node scripts/setupTypeScript.js test-template 14 | */ 15 | 16 | const fs = require("fs") 17 | const path = require("path") 18 | const { argv } = require("process") 19 | 20 | const projectRoot = argv[2] || path.join(__dirname, "..") 21 | 22 | // Add deps to pkg.json 23 | const packageJSON = JSON.parse(fs.readFileSync(path.join(projectRoot, "package.json"), "utf8")) 24 | packageJSON.devDependencies = Object.assign(packageJSON.devDependencies, { 25 | "svelte-check": "^2.0.0", 26 | "svelte-preprocess": "^4.0.0", 27 | "@rollup/plugin-typescript": "^8.0.0", 28 | "typescript": "^4.0.0", 29 | "tslib": "^2.0.0", 30 | "@tsconfig/svelte": "^2.0.0" 31 | }) 32 | 33 | // Add script for checking 34 | packageJSON.scripts = Object.assign(packageJSON.scripts, { 35 | "check": "svelte-check --tsconfig ./tsconfig.json" 36 | }) 37 | 38 | // Write the package JSON 39 | fs.writeFileSync(path.join(projectRoot, "package.json"), JSON.stringify(packageJSON, null, " ")) 40 | 41 | // mv src/main.js to main.ts - note, we need to edit rollup.config.js for this too 42 | const beforeMainJSPath = path.join(projectRoot, "src", "main.js") 43 | const afterMainTSPath = path.join(projectRoot, "src", "main.ts") 44 | fs.renameSync(beforeMainJSPath, afterMainTSPath) 45 | 46 | // Switch the app.svelte file to use TS 47 | const appSveltePath = path.join(projectRoot, "src", "App.svelte") 48 | let appFile = fs.readFileSync(appSveltePath, "utf8") 49 | appFile = appFile.replace(" 19 | 20 |
23 | 35 |
36 | -------------------------------------------------------------------------------- /src/lib/FormBuilder.svelte: -------------------------------------------------------------------------------- 1 | 111 | 112 |
118 | {#if editable} 119 |
120 | {#each formStore?.steps ?? [] as step, i} 121 | 134 | addStep(i)} 144 | /> 145 | {/each} 146 | 147 | {#if formStore?.props.withMessage} 148 |
149 | 150 |
151 | {/if} 152 |
153 | {:else if !editable && !withMessage} 154 | 167 | {:else if !editable && withMessage} 168 | 169 | {/if} 170 |
171 | -------------------------------------------------------------------------------- /src/lib/Step.svelte: -------------------------------------------------------------------------------- 1 | 108 | 109 |
110 | 111 | 112 | {#each inputGroups as inputs, indexGrp} 113 |
114 | {#each inputs as input, index} 115 | getIndex(indexGrp, index)} 131 | > 132 | 144 | 145 | {/each} 146 |
147 | {/each} 148 | {#if inputGroups.length} 149 | 150 | {/if} 151 |
152 |
153 | {#if stepInd == numberOfSteps - 1 && numberOfSteps !== 1} 154 | 164 | 172 | {:else if stepInd == numberOfSteps - 1 && numberOfSteps == 1} 173 | 181 | {:else if stepInd == 0} 182 | 190 | {:else} 191 | 201 | 209 | {/if} 210 |
211 |
212 | 213 | {#if show_inputs} 214 | 215 | {/if} 216 |
217 | -------------------------------------------------------------------------------- /src/lib/ui/Common/Inputs/InputAddButton.svelte: -------------------------------------------------------------------------------- 1 | 13 | 14 | {#if editable} 15 |
16 |
20 | 21 |
Add Input
22 |
23 |
24 | {/if} 25 | -------------------------------------------------------------------------------- /src/lib/ui/Common/Inputs/InputWrapper.svelte: -------------------------------------------------------------------------------- 1 | 37 | 38 |
39 | {#if showElement} 40 |
{ 43 | if (editable) { 44 | showDrag = true; 45 | } 46 | }} 47 | on:mouseleave={() => { 48 | if (menu) { 49 | } else { 50 | showDrag = false; 51 | } 52 | }} 53 | > 54 | {#if !isTextContent} 55 | 56 | {/if} 57 |
58 |
64 | 65 | 66 | {#if showDrag} 67 |
70 | 79 |
80 | {/if} 81 |
82 |
83 | {#if !editable && validation.errorMsg} 84 |
85 | {validation.errorMsg} 86 |
87 | {/if} 88 | 89 | {#if help_html !== undefined} 90 | 91 | {/if} 92 |
93 | {/if} 94 |
95 | -------------------------------------------------------------------------------- /src/lib/ui/Common/Inputs/Menu.svelte: -------------------------------------------------------------------------------- 1 | 13 | 14 |
19 |
{ 22 | inline = !inline; 23 | }} 24 | > 25 | Inline 26 | 27 |
28 | {#if required !== undefined} 29 |
{ 32 | required = !required; 33 | }} 34 | > 35 | 36 | {label} 37 | 38 | 39 |
40 | {/if} 41 |
42 | -------------------------------------------------------------------------------- /src/lib/ui/Common/Inputs/SideMenu.svelte: -------------------------------------------------------------------------------- 1 | 31 | 32 |
33 | 34 |
35 |
removeInput()} 38 | on:mouseenter={() => (showDelete = true)} 39 | on:mouseleave={() => (showDelete = false)} 40 | > 41 | 42 |
43 | {#if showDelete} 44 |
47 | Delete input 48 |
49 | {/if} 50 |
51 | 52 | 53 |
54 |
(showAdd = true)} 58 | on:mouseleave={() => (showAdd = false)} 59 | > 60 | 61 |
62 | {#if showAdd} 63 |
66 | Add input 67 |
68 | {/if} 69 |
70 | 71 | 72 |
73 |
{ 77 | menu = !menu; 78 | showMenu = false; 79 | }} 80 | on:mouseenter={() => { 81 | if (!menu) { 82 | showMenu = true; 83 | } 84 | }} 85 | on:mouseleave={() => (showMenu = false)} 86 | > 87 | 88 |
89 | {#if showMenu} 90 |
93 | Show menu 94 |
95 | {/if} 96 | 97 | {#if menu} 98 | 99 | {/if} 100 |
101 |
102 | -------------------------------------------------------------------------------- /src/lib/ui/Common/Inputs/Switcher.svelte: -------------------------------------------------------------------------------- 1 | 11 | 12 |