narrat 3.3.8 → 3.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/components/achievements/achievements-ui.vue.d.ts +2 -1
- package/dist/components/dialog-picture.vue.d.ts +18 -2
- package/dist/components/utils/floating-tooltip.vue.d.ts +14 -0
- package/dist/config/achievements-config.d.ts +8 -4
- package/dist/config/animations-config.d.ts +64 -0
- package/dist/config/characters-config.d.ts +3 -0
- package/dist/config/common-config.d.ts +2 -0
- package/dist/config/config-input.d.ts +4 -0
- package/dist/config/config-output.d.ts +43 -20
- package/dist/config.d.ts +42 -22
- package/dist/exports/others.d.ts +1 -0
- package/dist/exports/utils.d.ts +1 -0
- package/dist/inputs/Inputs.d.ts +2 -0
- package/dist/main.d.ts +2 -0
- package/dist/narrat.es.js +15535 -15034
- package/dist/narrat.es.js.map +1 -1
- package/dist/narrat.umd.js +124 -109
- package/dist/narrat.umd.js.map +1 -1
- package/dist/stores/inputs-store.d.ts +1 -0
- package/dist/stores/inventory-store.d.ts +1 -0
- package/dist/stores/main-store.d.ts +5029 -217
- package/dist/stores/rendering-store.d.ts +13 -0
- package/dist/style.css +1 -1
- package/dist/types/app-types.d.ts +5 -0
- package/dist/types/game-save.d.ts +2 -0
- package/dist/utils/animation.d.ts +8 -0
- package/dist/utils/data-helpers.d.ts +330 -0
- package/dist/utils/interact-utils.d.ts +15 -0
- package/dist/utils/save-helpers.d.ts +1 -1
- package/dist/vm/commands/util-commands.d.ts +13 -1
- package/package.json +1 -1
|
@@ -2,7 +2,12 @@ export interface RenderingState {
|
|
|
2
2
|
screenWidth: number;
|
|
3
3
|
screenHeight: number;
|
|
4
4
|
layoutMode: 'horizontal' | 'vertical';
|
|
5
|
+
containerElement: HTMLElement | null;
|
|
6
|
+
narratAppElement: HTMLElement | null;
|
|
7
|
+
resizeObserver: ResizeObserver | null;
|
|
8
|
+
dialogPanelMode: 'auto' | 'off' | 'on';
|
|
5
9
|
}
|
|
10
|
+
export type RenderingSaveData = Pick<RenderingState, 'dialogPanelMode'>;
|
|
6
11
|
export declare const useRenderingStore: import("pinia").StoreDefinition<"rendering", RenderingState, {
|
|
7
12
|
gameScaleRatio(state: RenderingState): number;
|
|
8
13
|
overlayMode(state: RenderingState): boolean;
|
|
@@ -15,6 +20,14 @@ export declare const useRenderingStore: import("pinia").StoreDefinition<"renderi
|
|
|
15
20
|
viewportHeight(state: RenderingState): number;
|
|
16
21
|
viewportWidth(state: RenderingState): number;
|
|
17
22
|
showDialog(state: RenderingState): boolean;
|
|
23
|
+
container(): HTMLElement;
|
|
24
|
+
inputsContainer(): HTMLElement;
|
|
25
|
+
narratApp(): HTMLElement;
|
|
18
26
|
}, {
|
|
27
|
+
generateSaveData(): RenderingSaveData;
|
|
28
|
+
loadSaveData(saveData: RenderingSaveData): void;
|
|
29
|
+
reset(): void;
|
|
19
30
|
updateScreenSize(width: number, height: number): void;
|
|
31
|
+
setContainer(container: HTMLElement): void;
|
|
32
|
+
refreshScreenSize(): void;
|
|
20
33
|
}>;
|
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
*,:before,:after{-webkit-box-sizing:border-box;box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}*{--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgba(59, 130, 246, .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000}:root{-moz-tab-size:4;-o-tab-size:4;tab-size:4}:-moz-focusring{outline:1px dotted ButtonText}:-moz-ui-invalid{box-shadow:none}::moz-focus-inner{border-style:none;padding:0}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}body{margin:0;font-family:inherit;line-height:inherit}b{font-weight:bolder}button,input,select{font-family:inherit;font-size:100%;line-height:1.15;margin:0;padding:0;line-height:inherit;color:inherit}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button{background-color:transparent;background-image:none}button,[role=button]{cursor:pointer}html{-webkit-text-size-adjust:100%;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";line-height:1.5}hr{height:0;color:inherit;border-top-width:1px}h3,h1,p,h2,hr,h4{margin:0}h3,h1,h2,h4{font-size:inherit;font-weight:inherit}img{border-style:solid}input::placeholder{opacity:1;color:#9ca3af}input::webkit-input-placeholder{opacity:1;color:#9ca3af}input::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder{opacity:1;color:#9ca3af}input::-ms-input-placeholder{opacity:1;color:#9ca3af}img,video{display:block;vertical-align:middle;max-width:100%;height:auto}table{text-indent:0;border-color:inherit;border-collapse:collapse}ul{list-style:none;margin:0;padding:0}.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}}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgba(229,231,235,var(--tw-bg-opacity))}.dark .dark\:bg-gray-700{--tw-bg-opacity: 1;background-color:rgba(55,65,81,var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgba(31,41,55,var(--tw-bg-opacity))}.border-0{border-width:0px}.block{display:block}.inline{display:inline}.flex{display:-webkit-box;display:-ms-flexbox;display:-webkit-flex;display:flex}.grid{display:-ms-grid;display:grid}.hidden{display:none}.flex-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;-webkit-flex-direction:row;flex-direction:row}.flex-col{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column}.items-center{-webkit-box-align:center;-ms-flex-align:center;-webkit-align-items:center;align-items:center}.justify-center{-webkit-box-pack:center;-ms-flex-pack:center;-webkit-justify-content:center;justify-content:center}.justify-between{-webkit-box-pack:justify;-ms-flex-pack:justify;-webkit-justify-content:space-between;justify-content:space-between}.h-px{height:1px}.list-disc{list-style-type:disc}.mx-8{margin-left:2rem;margin-right:2rem}.my-8{margin-top:2rem;margin-bottom:2rem}.mx-auto{margin-left:auto;margin-right:auto}.tab\.condition\(\),.tab\.id,.tab,.tab\.icon,.tab\.label,.\.tab{-moz-tab-size:4;-o-tab-size:4;tab-size:4}.static{position:static}.absolute{position:absolute}.resize{resize:both}.table-auto{table-layout:auto}.text-left{text-align:left}.text-center{text-align:center}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.indent{text-indent:1.5rem}.visible{visibility:visible}.w-full{width:100%}.gap-4{grid-gap:1rem;gap:1rem}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.transform{--tw-translate-x: 0;--tw-translate-y: 0;--tw-translate-z: 0;--tw-rotate: 0;--tw-rotate-x: 0;--tw-rotate-y: 0;--tw-rotate-z: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-scale-z: 1;-webkit-transform:translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotateZ(var(--tw-rotate-z)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z));-ms-transform:translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotateZ(var(--tw-rotate-z)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z));transform:translate(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotate(var(--tw-rotate-z)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z))}.\<transition,.transition,.transition\.duration,.transition\.delay{-webkit-transition-property:background-color,border-color,color,fill,stroke,opacity,-webkit-box-shadow,-webkit-transform,filter,backdrop-filter;-o-transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,-webkit-box-shadow,transform,-webkit-transform,filter,backdrop-filter;-webkit-transition-timing-function:cubic-bezier(.4,0,.2,1);-o-transition-timing-function:cubic-bezier(.4,0,.2,1);transition-timing-function:cubic-bezier(.4,0,.2,1);-webkit-transition-duration:.15s;-o-transition-duration:.15s;transition-duration:.15s}.ease-in-out{-webkit-transition-timing-function:cubic-bezier(.4,0,.2,1);-o-transition-timing-function:cubic-bezier(.4,0,.2,1);transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration{-webkit-transition-duration:.15s;-o-transition-duration:.15s;transition-duration:.15s}:root{--font-family: "Helvetica", sans-serif, "Arial", "sans-serif";--bg-color: rgba(19, 23, 32, .9);--text-color: #d9e1f2;--grey-text-color: #a6a6a6;--primary: hsl(255, 30%, 55%);--focus: hsl(210, 90%, 50%);--secondary: #42b983;--border-color: hsla(0, 0%, 100%, .2);--light-1: hsl(210, 30%, 40%);--light-2: hsl(255, 30%, 50%);--light-gradient: linear-gradient(to right, var(--light-1), var(--light-2));--light-background: rgba(255, 255, 255, .3);--button-background: var(--tile-background);--button-text-color: var(--text-color);--modal-gradient-1: rgba(18, 21, 26, .8);--modal-gradient-2: rgba(37, 40, 44, .6);--modal-background: linear-gradient( 90deg, var(--modal-gradient-1) 0%, var(--modal-gradient-2) 100% );--tile-gradient-1: rgba(18, 21, 26, .9);--tile-gradient-2: rgba(37, 40, 44, .7);--tile-background: linear-gradient( 90deg, var(--tile-gradient-1) 0%, var(--tile-gradient-2) 100% );--tile-border-color: rgba(166, 166, 166, .3);--shadow-1: hsla(236, 50%, 50%, .3);--shadow-2: hsla(236, 50%, 50%, .4);--hud-background: rgba(0, 0, 0, .4);--hud-text-color: var(--text-color);--notification-bg: var(--tile-background);--notification-text-color: var(--text-color);--notification-description-color: var(--grey-text-color);--notification-icon-size: 40px;--skills-text-background: rgba(0, 0, 0, .5);--skills-text-color: var(--text-color);--skills-level-background: rgba(0, 0, 0, .5);--skills-level-color: orange;--skills-xp-bar-height: 40px;--skill-check-name-color: orange;--skill-check-difficulty: orange;--skill-check-success: green;--skill-check-failed: red;--skill-check-color: orange;--dialog-choice-color: orange;--dialog-choice-seen-before-color: grey;--dialog-choice-key-color: red;--dialog-choice-hover-color: var(--text-color);--inventory-text-background: rgba(0, 0, 0, .5);--inventory-text-color: var(--text-color);--inventory-amount-background: rgba(0, 0, 0, .5);--inventory-amount-color: orange;--quest-title-color: yellow;--completed-quest-title-color: grey;--objective-in-progress-color: white;--objective-completed-color: grey;--loading-bar-inner-bg: var(--light-background);--loading-bar-outer-bg: var(--bg-color);--dialog-box-bg: var(--bg-color);--dialog-box-border: none;--tabs-background: linear-gradient( 90deg, rgba(0, 0, 0, .2) 0%, rgba(100, 100, 100, 1) 53%, rgba(0, 0, 0, .2) 100% );--tab-active-background: rgba(0, 0, 0, 0);--tab-active-text-color: var(--text-color);--tab-inactive-background: rgba(0, 0, 0, 0);--tab-inactive-text-color: var(--text-color);--tab-border-style: solid;--tab-border-color: white;--tab-selected-glow-color: var(--focus);--tooltip-background: #331d00;--tooltip-border: 1px solid orange;--tooltip-border-radius: 5px;--tooltip-title-font-size: 1.2rem;--tooltip-font-size: 1rem;--tooltip-title-color: red;--tooltip-color: var(--text-color);--highlighted-tooltip-keyword-color: red;--highlighted-tooltip-keyword-font-size: 1.1em;--highlighted-tooltip-keyword-font-weight: bold;--achievement-title-color: var(--text-color);--achievement-tile-background: var(--tile-background);--achievement-tile-border-color: var(--tile-border-color);--achievement-description-color: rgb(170, 170, 170);--separator-bg-color: rgba(250, 250, 250, .8);--separator-height: 1px;--separator-width: 100%;--save-ui-border-style: dashed;--save-ui-border-width: 1px;--save-ui-border-color: rgba(255, 255, 255, .3);--save-ui-selected-background: #bf9a21;--selected-border: 2px solid cyan;--game-bg-color: transparent}body{font-family:var(--font-family);padding:0;margin:0;font-family:Arial,sans-serif;background-color:#000}.red{color:red}.tile{background:var(--tile-background);border-color:var(--tile-border-color);border-radius:15px;border-style:solid;border-width:2px;padding:20px}*{font-family:var(--font-family);-webkit-user-select:none;user-select:none;box-sizing:border-box}.list-item{display:inline-block;margin-right:10px}.list-enter-active,.list-leave-active{transition:all .3s ease}.think-command{color:#0ff}#app{background-size:cover}.list-enter-from,.list-leave-to{opacity:0;transform:translate(300px)}.notification-item{display:inline-block;margin-right:10px}.notification-enter-active,.notification-leave-active{transition:all .3s ease}.notification-enter-from,.notification-leave-to{opacity:0;transform:translateY(-300px)}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.fade-in-enter-active{transition:opacity .1s ease}.fade-in-enter-from{opacity:0}.select{background:var(--light-background);padding:10px}.option{background-color:var(--light-2);padding:5px;color:var(--text-color)}.button{background:var(--button-background);color:var(--button-text-color);border-color:var(--tile-border-color);border-radius:10px;border-width:2px;padding:10px;font-weight:800;font-size:1rem;margin:10px;transition:.2s}.button.large{border-radius:20px}.menu-button{border-radius:5px}.button.main-menu-button{border-radius:20px}.button:focus,.button:hover{transform:translateY(-.2rem)}.disabled{-webkit-user-select:none;user-select:none;pointer-events:none}.button.disabled{box-shadow:unset;color:gray;background:var(--border-color)}.input{background:var(--light-background);color:var(--text-color);box-shadow:.4rem .4rem 2.4rem .2rem var(--shadow-1);border-radius:100px;padding:10px;font-weight:800;font-size:1rem;margin:10px;transition:.2s}.input:focus,.input:hover{transform:translateY(-.2rem);box-shadow:0 0 2.4rem .2rem var(--shadow-2)}a{color:pink;text-decoration:underline}th,td{padding:4px;border:1px solid var(--text-color);text-align:center}#game-holder{width:100vw;height:100vh;padding:0;margin:0;top:0;left:0;background-color:#000;display:flex;align-items:center;justify-content:center;min-height:-webkit-fill-available}.title{font-size:1.8rem;font-weight:700;text-align:center}.container{padding:20px}h1,h2,h3,h4{font-weight:700}h1{font-size:1.8rem}h2{font-size:1.5rem}h3{font-size:1.4rem}hr.solid{border:1px solid var(--text-color);margin-top:20px;margin-bottom:0}.card-1{box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;transition:all .3s cubic-bezier(.25,.8,.25,1)}.card-1:hover{box-shadow:0 14px 28px #00000040,0 10px 10px #00000038}.card-2{box-shadow:0 3px 6px #00000029,0 3px 6px #0000003b}.card-3{box-shadow:0 10px 20px #00000030,0 6px 6px #0000003b}.card-4{box-shadow:0 14px 28px #00000040,0 10px 10px #00000038}.card-5{box-shadow:0 19px 38px #000000b3,0 15px 12px #00000080}.dialog-choice{transition:.2s}.dialog-choice:hover,.dialog-choice.selected{transform:scale(1.05);background-color:#faad394d;transform-origin:center}.dialog-choice:not(:hover)>.skill-check-name,.passive-skill-check>.skill-check-name{color:var(--skill-check-name-color)}.dialog-choice:not(:hover)>.skill-check-difficulty,.passive-skill-check>.skill-check-difficulty{color:var(--skill-check-difficulty)}.skill-check-difficulty{font-weight:700}.dialog-choice:not(:hover)>.skill-check-success,.passive-skill-check>.skill-check-success{color:var(--skill-check-success)}.dialog-choice:not(:hover)>.skill-check-failed,.passive-skill-check>.skill-check-failed{color:var(--skill-check-failed)}.dialog-choice:not(:hover)>.skill-check,.passive-skill-check.skill-check{color:var(--skill-check-color)}.narrat-canvas{position:absolute;height:100%;top:0;left:0}#touchTrigger{pointer-events:none}.narrat-transition-fade-enter-active,.narrat-transition-fade-leave-active{transition-property:opacity;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-fade-enter-from,.narrat-transition-fade-leave-to{opacity:0}.narrat-transition-slide-right-enter-active,.narrat-transition-slide-right-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-right-enter-from{transform:translate(-100%)}.narrat-transition-slide-right-leave-to{transform:translate(100%)}.narrat-transition-slide-left-enter-active,.narrat-transition-slide-left-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-left-enter-from{transform:translate(100%)}.narrat-transition-slide-left-leave-to{transform:translate(-100%)}.narrat-transition-slide-top-enter-active,.narrat-transition-slide-top-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-top-enter-from{transform:translateY(100%)}.narrat-transition-slide-top-leave-to{transform:translateY(-100%)}.narrat-transition-slide-bottom-enter-active,.narrat-transition-slide-bottom-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-bottom-enter-from{transform:translateY(-100%)}.narrat-transition-slide-bottom-leave-to{transform:translateY(100%)}.screens-fade-enter-active,.screens-fade-leave-active{transition:opacity .5s ease}.screens-fade-enter-from,.screens-fade-leave-to{opacity:0}.dialog-transition-enter-active,.dialog-transition-leave-active{transition:transform .25s ease-out}.dialog-transition-enter-from,.dialog-transition-leave-to{transform:translateY(-100%)}.highlighted-tooltip-keyword{color:var(--highlighted-tooltip-keyword-color);font-size:var(--highlighted-tooltip-keyword-font-size);font-weight:var(--highlighted-tooltip-keyword-font-weight);-webkit-user-select:auto;user-select:auto;pointer-events:all}.button.selected{border:var(--selected-border)}.modal-mask{position:absolute;z-index:9998;top:0;left:0;width:100%;height:100%;background-color:#0003;transition:opacity .3s ease;display:flex;flex-direction:column;flex-shrink:2 2;align-items:center;justify-content:center}.modal-container{min-width:300px;max-width:90vw;max-height:100%;overflow-y:hidden;margin:10px auto;padding:20px 30px;border-radius:5px;transition:all .3s ease;font-family:Helvetica,Arial,sans-serif;background:var(--modal-background);display:flex;flex-direction:column}.modal-header{position:relative}.modal-header h3{flex-shrink:0;margin-top:0;color:var(--secondary)}.modal-body{overflow-y:auto;flex-shrink:2}.modal-default-button{float:right}.modal-enter,.modal-leave-active{opacity:0}.modal-enter .modal-container,.modal-leave-active .modal-container{-webkit-transform:scale(1.1);transform:scale(1.1)}.close-button{border:1px solid var(--text-color);border-radius:50px;font-size:1.8rem;font-weight:700;position:absolute;right:-20px;top:-10px;width:50px;height:50px}.close-button:hover{background-color:var(--focus)}.debug-menu{z-index:9999}.debug-button{position:fixed;bottom:10px;right:10px;padding:5px}.error-message{margin-top:10px;margin-bottom:10px}.error{color:#ff4500}.warning{color:orange}.error-filename{color:gray;text-decoration:underline}.debug-menu-container{width:100%}.search-result{border:1px solid var(--text-color);padding:10px;font-weight:700;font-size:1.25rem;width:100}.jump-menu-container{width:80%}.debug-info{position:fixed;background-color:#0009;border:1px dotted var(--text-color);top:0;left:0;padding:5px}.variables-viewer{height:100%}.notifications-holder{position:fixed;top:0;right:0;padding:10px;display:flex;flex-direction:column-reverse;align-items:center;pointer-events:none;z-index:2}.notification{margin-top:10px;margin-bottom:10px;border-radius:10px;padding:9px;width:400px;text-align:left}.notification-icon{float:left;width:var(--notification-icon-size);height:var(--notification-icon-size);margin-right:10px}.notification-text{color:var(--notifications-text-color);font-size:1.2rem;font-weight:600}.notification-description{margin-top:10px;color:var(--notifications-description-color);font-size:1rem;font-style:italic}.save-slot{background-color:#00000080;border-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);width:100%;transition:background-color .3s}.save-slot:hover,.save-slot.selected{background-color:var(--save-ui-selected-background)}.save-slot:not(:last-child){margin-bottom:20px}.save-name{font-size:1.2rem;font-weight:700;background-color:var(--bg-color);color:var(--text-color);padding:0 5px}.save-slot-number-container{width:100px;text-align:center}.save-slot-number{font-size:1.8rem;font-weight:700}.save-slot-screenshot{width:170px;background-size:contain;background-position:center;height:100%;border-left-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);background-repeat:no-repeat}.save-info{border-left-width:var(--save-ui-border-width);border-right-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);padding:10px;height:100%}.saves-section{margin-bottom:20px}.saves-section-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}#game-menu{width:100%;height:100%;padding:20px;background-color:#000}#game-title-container{margin-bottom:80px}#game-title-text{text-align:center;font-size:3rem}.menu-button{font-size:1.5rem;margin-bottom:10px}#game-header{position:relative;top:100px}.start-menu-buttons-container{width:400px}.save-modal{width:70%}.saves-container{padding:20px}.dialog-picture{position:absolute;width:80px;height:80px;border:2px solid white;border-radius:10px;background-color:gray;z-index:99;transition:all .5s ease-in-out}.dialog-picture img{width:100%;height:100%}.dialog-title{font-size:1.25rem;font-weight:700}.dialog-text{font-size:1rem}.dialog-box{color:var(--text-color);margin-top:15px;padding:0 10px 0 2em}.dialog-box-followup{margin-top:0}.dialog-choice{color:var(--dialog-choice-color)}.dialog-choice.seen-before{color:var(--dialog-choice-seen-before-color)!important}.key-choice{color:var(--dialog-choice-key-color)}.unimportant-choice{color:#fff}.dialog-choice:hover{color:var(--dialog-choice-hover-color);cursor:pointer}.buttons-container{width:100%;padding:10px;display:flex;justify-content:space-evenly;align-items:stretch;box-sizing:border-box}.interact-button{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-color);font-weight:700;font-size:1.3rem;text-align:center;flex-grow:2;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.interact-button:not(:last-child){margin-right:10px}.choice-index{color:#fff;margin-right:10px}.dialog-container{flex-shrink:2;min-height:100%;width:100%;background-color:(var(--bg-color));box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;overflow-x:hidden}.dialog{overflow-y:auto;overflow-x:hidden;position:relative;-ms-overflow-style:none;scrollbar-width:none;background:var(--dialog-box-bg);border:var(--dialog-box-border);box-shadow:0 19px 38px #000000b3,0 15px 12px #00000080}.dialog::-webkit-scrollbar{display:none}.dialog *{overflow-anchor:none}.anchor{overflow-anchor:auto;height:1px}.auto-skip-buttons{position:absolute;top:10px;right:160px}.tab{background:var(--tab-background);border-style:var(--tab-border-style);border-color:var(--tab-border-color);flex-grow:1;padding:5px 1rem;text-align:center}.tab:not(:last-child){border-right-width:1px}.tab-active{background:var(--tab-active-background);color:var(--tab-active-color);text-shadow:0 0 20px #fff,0 0 30px var(--tab-selected-glow-color),0 0 40px var(--tab-selected-glow-color),0 0 50px var(--tab-selected-glow-color),0 0 60px var(--tab-selected-glow-color),0 0 70px var(--tab-selected-glow-color),0 0 80px var(--tab-selected-glow-color)}.tab-inactive{background:var(--tab-inactive-background);color:var(--tab-inactive-color)}.tab-icon{width:16px;height:16px}.tab-title-container{font-size:1.3rem;font-weight:700}.tabs-controller{display:flex;flex-direction:column;width:100%;height:100%;padding:0px 2rem}.tab-content{position:relative;width:100%}.tabs-controller__tabs{position:relative;width:100%;display:flex;flex-direction:row;justify-content:space-evenly;background:var(--tabs-background)}.menu-content{text-align:center}.menu-toggle-button{margin:0;padding:2px;border-radius:5px}.menu-toggle-button:not(:last-child){margin-right:10px}.menu-modal{width:90%;height:90%}.viewport-object{position:absolute;display:flex;justify-content:center;align-items:center;color:#fff;font-size:1.8rem;font-weight:700;background-size:cover;background-repeat:no-repeat}.viewport-object.selected{border:var(--selected-border)}.viewport-object.interactable{cursor:pointer;pointer-events:auto}.viewport-object.disabled{pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-button{position:absolute;display:flex;justify-content:center;align-items:center;background:var(--button-background);color:var(--button-text-color);font-size:1.8rem;font-weight:700}.viewport-button.interactable{cursor:pointer;pointer-events:auto}.viewport-button.disabled{pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-button.greyed{opacity:.3}.viewport-button.hidden{opacity:0;display:none}.viewport-button.selected{border:var(--selected-border)}.viewport-layer{background-size:cover;background-repeat:no-repeat;background-position:center;position:absolute;left:0;top:0}.transition-holder{position:absolute;top:0;left:0;width:100%;height:100%}.viewport{position:relative}.layer-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.hud{position:absolute;right:0;top:0;display:flex;flex-direction:row-reverse;z-index:3}.hud-stat{border:1px dotted white;background-color:var(--hud-background);color:var(--hud-text-color);padding:5px}.hud-icon{display:inline-block;height:1em}.hud-text{margin-left:5px}.auto-play-feedback-container{position:absolute;top:0;left:0;display:flex;background-color:#00000080}.auto-play-feedback{font-size:1.2rem}@keyframes auto-feedback{0%{opacity:.5}to{opacity:1}}.auto-play-feedback-auto,.auto-play-feedback-skip{animation:auto-feedback 1.5s ease-in-out alternate-reverse infinite}.game{position:absolute;background-color:var(--game-bg-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;height:100%;box-sizing:border-box;overflow:hidden}.menu-toggle{position:fixed;bottom:0;right:15%;z-index:2}#loading-bar{position:relative;width:60vw;height:50px;border-radius:50px;background:var(--loading-bar-outer-bg);border:3px solid white}#inner-loading-bar{height:100%;border-radius:50px 0 0 50px;background:var(--loading-bar-inner-bg)}#loading-text{z-index:99999;display:flex;align-items:center;justify-content:space-around;position:absolute;width:100%;height:100%;top:0}@keyframes animate-logo{0%{transform:perspective(10000px) rotateY(0) rotateX(0) scale(.8)}50%{transform:perspective(10000px) rotateY(180deg) rotateX(-10deg) scale(1)}to{transform:perspective(10000px) rotateY(360deg) rotateX(0) scale(.8)}}#engine-splash-header{position:absolute;width:50%;perspective:300px;transition-property:opacity}#engine-splash-header.invisible{opacity:0}#engine-splash-screen{position:absolute;width:100%;height:100%;background-color:#000}#engine-splash-logo{width:300px;height:300px;margin:50px;transform-style:preserve-3d;animation:animate-logo infinite 10s;animation-timing-function:linear}#game-splash-title{font-size:4.3rem;text-align:center;margin-bottom:40px}#game-splash-screen{width:100%;height:100%;position:absolute;background-color:#000}.splash-start-button{padding:10px 20px;font-size:2rem}.floating-tooltip{position:fixed;background:var(--tooltip-background);border:var(--tooltip-border);border-radius:var(--tooltip-border-radius);padding:10px;z-index:100}.floating-tooltip-title{font-size:var(--tooltip-title-font-size);color:var(--tooltip-title-color);font-weight:700;margin-bottom:5px}.floating-tooltip-text{font-size:var(--tooltip-font-size);color:var(--tooltip-color)}#app-container{background-color:var(--bg-color);width:100%;height:100%;position:absolute;display:flex;flex-direction:row;align-items:center;justify-content:center;color:var(--text-color);box-sizing:border-box;overflow:hidden;transform-origin:center center}#app{z-index:2;width:100%;height:100%;position:absolute;display:flex;flex-direction:row;align-items:center;justify-content:center;color:var(--text-color);box-sizing:border-box;overflow:hidden;transform-origin:center center}.app-blurred-by-modal{filter:blur(5px)}.volume-label{font-size:1.25rem;font-weight:700;width:180px;text-align:right;margin-right:20px}.volume-controls{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--light-background);border:1px dashed white;padding:20px;margin:20px 0}.volume-control{width:100%;font-size:1.5rem;display:flex;align-items:center;justify-content:space-between;margin:0 20px}.volume-slider{flex-grow:2;background-color:#00f}.yellow{background-color:#ff0}.setting-label{font-size:1.25rem;font-weight:700;text-align:left;margin-right:20px}.setting-slider{flex-grow:2;background-color:#00f}.settings-widget-container{width:100%;font-size:1.5rem;display:flex;align-items:center;justify-content:flex-start}.setting-description{margin-left:2rem}.setting-separator{background-color:var(--separator-bg-color);width:var(--separator-width);height:var(--separator-height);margin-top:.5rem;margin-bottom:.5rem;text-align:center;margin-left:auto;margin-right:auto}.settings-menu-title{margin-top:1rem;margin-bottom:1rem}.settings-menu-container{position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;background:var(--light-background);border:1px dashed white;padding:20px;margin:20px 0}.quit-button{margin:20px;text-align:center}.main-menu-modal{width:60%}.sub-tabs-controller{display:flex;flex-direction:column;width:100%;height:100%;padding:0px 2rem}.sub-tab-content{position:relative;width:100%;margin-top:2rem}.sub-tabs-controller__tabs{position:relative;width:100%;display:flex;flex-direction:row;justify-content:space-evenly;background:var(--tabs-background)}.inventory-section{display:flex;flex-direction:column;margin:1rem 0}.inventory-section-items{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.item-display{width:200px;height:200px;position:relative;background-repeat:no-repeat;background-size:contain}.item-display.selected{border:var(--selected-border)}.item-title{position:absolute;bottom:0;text-align:center;width:100%;color:var(--inventory-text-color);background:var(--inventory-text-background)}.item-amount{position:absolute;top:0;right:0;font-weight:700;font-size:1.25rem;color:var(--inventory-amount-color);width:40px;height:40px;background-color:var(--inventory-amount-background)}.inventory-modal{width:800px;min-height:50%}.inventory-container{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.item-description-container{justify-content:space-between;align-items:stretch}.item-left{border:1px dashed white;flex-direction:column;padding:10px;justify-content:center}.item-right{border:1px dashed white;flex-direction:column;flex-grow:2;align-items:baseline;padding:10px}.achievement-display{display:flex;align-items:center;flex-direction:column;border-color:var(--achievement-tile-border-color);position:relative;background:var(--achievement-tile-background)}.achievement-icon{width:200px;height:200px;background-size:contain;background-repeat:no-repeat}.obtained-status{width:100%;text-align:left;color:var(--achievement-description-color);font-style:italic}.achievement-title{text-align:left;width:100%;color:var(--achievement-title-color);margin-bottom:5px}.achievement-description{width:100%;text-align:left;color:var(--achievement-description-color)}.achievements-section{display:flex;flex-direction:column;margin:1rem 0}.achievements-section-achievements{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.achievements-modal{width:800px;min-height:50%}.achievements-container{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.achievement-description-container{justify-content:space-between;align-items:stretch}.achievement-left{border:1px dashed white;flex-direction:column;padding:10px;justify-content:center}.achievement-right{border:1px dashed white;flex-direction:column;flex-grow:2;align-items:baseline;padding:10px}.quest-header{display:flex;flex-direction:row;align-items:center}.quest-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.quest-completed{color:var(--completed-quest-title-color)}.quest-in-progress{color:var(--quest-title-color)}.quest-state{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.quest-description{font-size:1.1rem;text-align:justify;font-style:italic;margin-bottom:.5rem}.quest-objectives-container{margin-left:10px}.quest-objective-completed{color:var(--objective-completed-color);text-decoration:line-through}.quest-objective-in-progress{color:var(--objective-in-progress-color)}.quest-objective-description{font-size:1rem;margin-bottom:.5rem}.quest-list-display{cursor:pointer;transition:transform .2s ease-in-out}.quest-list-display:hover{transform:translateY(-2px)}.quest-list-title{padding-left:10px;font-size:1.2rem}.quest-list-completed{color:var(--completed-quest-title-color)}.quest-list-in-progress{color:var(--quest-title-color)}.quests-category{margin-left:.6rem}.quests-modal{width:100%;min-height:50%}.quests-ui{display:flex;align-items:stretch;width:100%;flex-grow:2;height:400px}.quests-ui-horizontal{flex-direction:row}.quests-ui-vertical{flex-direction:column}.quests-list-container{background-color:#96969680;margin-right:20px;flex-shrink:0;border:1px dashed white;padding:20px;height:100%;overflow-y:auto}.quest-details{background-color:#96969680;flex-grow:1;border:1px dashed white;padding:20px;height:100%;overflow-y:auto}.skill-display[data-v-db9d98bf]{width:200px;height:300px;position:relative;background-size:cover}.skill-description-container[data-v-db9d98bf]{justify-content:space-between;align-items:stretch}.skill-left[data-v-db9d98bf]{flex-direction:column;border:1px dashed white;padding:10px;justify-content:center}.skill-right[data-v-db9d98bf]{border:1px dashed white;flex-direction:column;align-items:baseline;flex-grow:2}.skill-grid-element[data-v-8d457bf9]{width:200px;height:300px;position:relative;background-size:cover}.skill-grid-element.selected[data-v-8d457bf9]{border:var(--selected-border)}.skill-title[data-v-8d457bf9]{position:absolute;bottom:0;text-align:center;width:100%;color:var(--skills-text-color);background:var(--skills-text-background)}.skill-xp-container[data-v-8d457bf9]{position:absolute;top:0;left:0;height:var(--skills-xp-bar-height);width:calc(100% - var(--skills-xp-bar-height));background-color:#00000080}.skill-xp-bar[data-v-8d457bf9]{position:absolute;top:0;left:0;width:50%;height:100%;background-color:#0000fa80}.skill-xp-text[data-v-8d457bf9]{z-index:2}.skill-level[data-v-8d457bf9]{position:absolute;top:0;right:0;font-weight:700;font-size:1.5rem;color:var(--skills-level-color);width:var(--skills-xp-bar-height);height:var(--skills-xp-bar-height);background-color:var(--skills-level-background)}.skills-container[data-v-31202bb8]{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}
|
|
1
|
+
*,:before,:after{-webkit-box-sizing:border-box;box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}*{--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgba(59, 130, 246, .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000}:root{-moz-tab-size:4;-o-tab-size:4;tab-size:4}:-moz-focusring{outline:1px dotted ButtonText}:-moz-ui-invalid{box-shadow:none}::moz-focus-inner{border-style:none;padding:0}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}body{margin:0;font-family:inherit;line-height:inherit}b{font-weight:bolder}button,input,select{font-family:inherit;font-size:100%;line-height:1.15;margin:0;padding:0;line-height:inherit;color:inherit}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button{background-color:transparent;background-image:none}button,[role=button]{cursor:pointer}html{-webkit-text-size-adjust:100%;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";line-height:1.5}hr{height:0;color:inherit;border-top-width:1px}h3,h1,p,h2,hr,h4{margin:0}h3,h1,h2,h4{font-size:inherit;font-weight:inherit}img{border-style:solid}input::placeholder{opacity:1;color:#9ca3af}input::webkit-input-placeholder{opacity:1;color:#9ca3af}input::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder{opacity:1;color:#9ca3af}input::-ms-input-placeholder{opacity:1;color:#9ca3af}img,video{display:block;vertical-align:middle;max-width:100%;height:auto}table{text-indent:0;border-color:inherit;border-collapse:collapse}ul{list-style:none;margin:0;padding:0}.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}}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgba(229,231,235,var(--tw-bg-opacity))}.dark .dark\:bg-gray-700{--tw-bg-opacity: 1;background-color:rgba(55,65,81,var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgba(31,41,55,var(--tw-bg-opacity))}.border-0{border-width:0px}.block{display:block}.inline{display:inline}.flex{display:-webkit-box;display:-ms-flexbox;display:-webkit-flex;display:flex}.grid{display:-ms-grid;display:grid}.hidden{display:none}.flex-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;-webkit-flex-direction:row;flex-direction:row}.flex-col{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column}.items-center{-webkit-box-align:center;-ms-flex-align:center;-webkit-align-items:center;align-items:center}.justify-center{-webkit-box-pack:center;-ms-flex-pack:center;-webkit-justify-content:center;justify-content:center}.justify-between{-webkit-box-pack:justify;-ms-flex-pack:justify;-webkit-justify-content:space-between;justify-content:space-between}.h-px{height:1px}.list-disc{list-style-type:disc}.mx-8{margin-left:2rem;margin-right:2rem}.my-8{margin-top:2rem;margin-bottom:2rem}.mx-auto{margin-left:auto;margin-right:auto}.tab\.condition\(\),.tab\.id,.tab,.tab\.icon,.tab\.label,.\.tab{-moz-tab-size:4;-o-tab-size:4;tab-size:4}.static{position:static}.absolute{position:absolute}.resize{resize:both}.table-auto{table-layout:auto}.text-left{text-align:left}.text-center{text-align:center}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.indent{text-indent:1.5rem}.visible{visibility:visible}.w-full{width:100%}.gap-4{grid-gap:1rem;gap:1rem}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.transform{--tw-translate-x: 0;--tw-translate-y: 0;--tw-translate-z: 0;--tw-rotate: 0;--tw-rotate-x: 0;--tw-rotate-y: 0;--tw-rotate-z: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-scale-z: 1;-webkit-transform:translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotateZ(var(--tw-rotate-z)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z));-ms-transform:translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotateZ(var(--tw-rotate-z)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z));transform:translate(var(--tw-translate-x)) translateY(var(--tw-translate-y)) translateZ(var(--tw-translate-z)) rotate(var(--tw-rotate)) rotateX(var(--tw-rotate-x)) rotateY(var(--tw-rotate-y)) rotate(var(--tw-rotate-z)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) scaleZ(var(--tw-scale-z))}.\<transition,.transition,.transition\.duration,.transition\.delay{-webkit-transition-property:background-color,border-color,color,fill,stroke,opacity,-webkit-box-shadow,-webkit-transform,filter,backdrop-filter;-o-transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,-webkit-box-shadow,transform,-webkit-transform,filter,backdrop-filter;-webkit-transition-timing-function:cubic-bezier(.4,0,.2,1);-o-transition-timing-function:cubic-bezier(.4,0,.2,1);transition-timing-function:cubic-bezier(.4,0,.2,1);-webkit-transition-duration:.15s;-o-transition-duration:.15s;transition-duration:.15s}.ease-in-out{-webkit-transition-timing-function:cubic-bezier(.4,0,.2,1);-o-transition-timing-function:cubic-bezier(.4,0,.2,1);transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration{-webkit-transition-duration:.15s;-o-transition-duration:.15s;transition-duration:.15s}.animate{-webkit-animation-iteration-count:1;animation-iteration-count:1}:root{--font-family: "Helvetica", sans-serif, "Arial", "sans-serif";--bg-color: rgba(19, 23, 32, .9);--text-color: #d9e1f2;--grey-text-color: #a6a6a6;--primary: hsl(255, 30%, 55%);--focus: hsl(210, 90%, 50%);--secondary: #42b983;--border-color: hsla(0, 0%, 100%, .2);--light-1: hsl(210, 30%, 40%);--light-2: hsl(255, 30%, 50%);--light-gradient: linear-gradient(to right, var(--light-1), var(--light-2));--light-background: rgba(255, 255, 255, .3);--button-background: var(--tile-background);--button-text-color: var(--text-color);--modal-gradient-1: rgba(18, 21, 26, .8);--modal-gradient-2: rgba(37, 40, 44, .6);--modal-background: linear-gradient( 90deg, var(--modal-gradient-1) 0%, var(--modal-gradient-2) 100% );--tile-gradient-1: rgba(18, 21, 26, .9);--tile-gradient-2: rgba(37, 40, 44, .7);--tile-background: linear-gradient( 90deg, var(--tile-gradient-1) 0%, var(--tile-gradient-2) 100% );--tile-border-color: rgba(166, 166, 166, .3);--shadow-1: hsla(236, 50%, 50%, .3);--shadow-2: hsla(236, 50%, 50%, .4);--hud-background: rgba(0, 0, 0, .4);--hud-text-color: var(--text-color);--notification-bg: var(--tile-background);--notification-text-color: var(--text-color);--notification-description-color: var(--grey-text-color);--notification-icon-size: 40px;--skills-text-background: rgba(0, 0, 0, .5);--skills-text-color: var(--text-color);--skills-level-background: rgba(0, 0, 0, .5);--skills-level-color: orange;--skills-xp-bar-height: 40px;--skill-check-name-color: orange;--skill-check-difficulty: orange;--skill-check-success: green;--skill-check-failed: red;--skill-check-color: orange;--dialog-choice-color: orange;--dialog-choice-seen-before-color: grey;--dialog-choice-key-color: red;--dialog-choice-hover-color: var(--text-color);--inventory-text-background: rgba(0, 0, 0, .5);--inventory-text-color: var(--text-color);--inventory-amount-background: rgba(0, 0, 0, .5);--inventory-amount-color: orange;--quest-title-color: yellow;--completed-quest-title-color: grey;--objective-in-progress-color: white;--objective-completed-color: grey;--loading-bar-inner-bg: var(--light-background);--loading-bar-outer-bg: var(--bg-color);--dialog-box-bg: var(--bg-color);--dialog-box-border: none;--tabs-background: linear-gradient( 90deg, rgba(0, 0, 0, .2) 0%, rgba(100, 100, 100, 1) 53%, rgba(0, 0, 0, .2) 100% );--tab-active-background: rgba(0, 0, 0, 0);--tab-active-text-color: var(--text-color);--tab-inactive-background: rgba(0, 0, 0, 0);--tab-inactive-text-color: var(--text-color);--tab-border-style: solid;--tab-border-color: white;--tab-selected-glow-color: var(--focus);--tooltip-background: #331d00;--tooltip-border: 1px solid orange;--tooltip-border-radius: 5px;--tooltip-title-font-size: 1.2rem;--tooltip-font-size: 1rem;--tooltip-title-color: red;--tooltip-color: var(--text-color);--highlighted-tooltip-keyword-color: red;--highlighted-tooltip-keyword-font-size: 1.1em;--highlighted-tooltip-keyword-font-weight: bold;--achievement-title-color: var(--text-color);--achievement-tile-background: var(--tile-background);--achievement-tile-border-color: var(--tile-border-color);--achievement-description-color: rgb(170, 170, 170);--separator-bg-color: rgba(250, 250, 250, .8);--separator-height: 1px;--separator-width: 100%;--save-ui-border-style: dashed;--save-ui-border-width: 1px;--save-ui-border-color: rgba(255, 255, 255, .3);--save-ui-selected-background: #bf9a21;--selected-border: 2px solid cyan;--game-bg-color: transparent}body{font-family:var(--font-family);padding:0;margin:0;font-family:Arial,sans-serif;background-color:#000}.red{color:red}.tile{background:var(--tile-background);border-color:var(--tile-border-color);border-radius:15px;border-style:solid;border-width:2px;padding:20px}*{font-family:var(--font-family);-webkit-user-select:none;user-select:none;box-sizing:border-box}.list-item{display:inline-block;margin-right:10px}.list-enter-active,.list-leave-active{transition:all .3s ease}.think-command{color:#0ff}#narrat-app{background-size:cover}.list-enter-from,.list-leave-to{opacity:0;transform:translate(300px)}.notification-item{display:inline-block;margin-right:10px}.notification-enter-active,.notification-leave-active{transition:all .3s ease}.notification-enter-from,.notification-leave-to{opacity:0;transform:translateY(-300px)}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.fade-in-enter-active{transition:opacity .1s ease}.fade-in-enter-from{opacity:0}.select{background:var(--light-background);padding:10px}.option{background-color:var(--light-2);padding:5px;color:var(--text-color)}.button{background:var(--button-background);color:var(--button-text-color);border-color:var(--tile-border-color);border-radius:10px;border-width:2px;padding:10px;font-weight:800;font-size:1rem;margin:10px;transition:.2s}.button.large{border-radius:20px}.menu-button{border-radius:5px}.button.main-menu-button{border-radius:20px}.button:focus,.button:hover{transform:translateY(-.2rem)}.disabled{-webkit-user-select:none;user-select:none;pointer-events:none}.button.disabled{box-shadow:unset;color:gray;background:var(--border-color)}.input{background:var(--light-background);color:var(--text-color);box-shadow:.4rem .4rem 2.4rem .2rem var(--shadow-1);border-radius:100px;padding:10px;font-weight:800;font-size:1rem;margin:10px;transition:.2s}.input:focus,.input:hover{transform:translateY(-.2rem);box-shadow:0 0 2.4rem .2rem var(--shadow-2)}a{color:pink;text-decoration:underline}th,td{padding:4px;border:1px solid var(--text-color);text-align:center}#game-holder{width:100vw;height:100vh;padding:0;margin:0;top:0;left:0;background-color:#000;display:flex;align-items:center;justify-content:center;min-height:-webkit-fill-available}.title{font-size:1.8rem;font-weight:700;text-align:center}.container{padding:20px}h1,h2,h3,h4{font-weight:700}h1{font-size:1.8rem}h2{font-size:1.5rem}h3{font-size:1.4rem}hr.solid{border:1px solid var(--text-color);margin-top:20px;margin-bottom:0}.card-1{box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;transition:all .3s cubic-bezier(.25,.8,.25,1)}.card-1:hover{box-shadow:0 14px 28px #00000040,0 10px 10px #00000038}.card-2{box-shadow:0 3px 6px #00000029,0 3px 6px #0000003b}.card-3{box-shadow:0 10px 20px #00000030,0 6px 6px #0000003b}.card-4{box-shadow:0 14px 28px #00000040,0 10px 10px #00000038}.card-5{box-shadow:0 19px 38px #000000b3,0 15px 12px #00000080}.dialog-choice{transition:.2s}.dialog-choice:hover,.dialog-choice.selected{transform:scale(1.05);background-color:#faad394d;transform-origin:center}.dialog-choice:not(:hover)>.skill-check-name,.passive-skill-check>.skill-check-name{color:var(--skill-check-name-color)}.dialog-choice:not(:hover)>.skill-check-difficulty,.passive-skill-check>.skill-check-difficulty{color:var(--skill-check-difficulty)}.skill-check-difficulty{font-weight:700}.dialog-choice:not(:hover)>.skill-check-success,.passive-skill-check>.skill-check-success{color:var(--skill-check-success)}.dialog-choice:not(:hover)>.skill-check-failed,.passive-skill-check>.skill-check-failed{color:var(--skill-check-failed)}.dialog-choice:not(:hover)>.skill-check,.passive-skill-check.skill-check{color:var(--skill-check-color)}.narrat-canvas{position:absolute;height:100%;top:0;left:0}#touchTrigger{pointer-events:none}.narrat-transition-fade-enter-active,.narrat-transition-fade-leave-active{transition-property:opacity;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-fade-enter-from,.narrat-transition-fade-leave-to{opacity:0}.narrat-transition-slide-right-enter-active,.narrat-transition-slide-right-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-right-enter-from{transform:translate(-100%)}.narrat-transition-slide-right-leave-to{transform:translate(100%)}.narrat-transition-slide-left-enter-active,.narrat-transition-slide-left-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-left-enter-from{transform:translate(100%)}.narrat-transition-slide-left-leave-to{transform:translate(-100%)}.narrat-transition-slide-top-enter-active,.narrat-transition-slide-top-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-top-enter-from{transform:translateY(100%)}.narrat-transition-slide-top-leave-to{transform:translateY(-100%)}.narrat-transition-slide-bottom-enter-active,.narrat-transition-slide-bottom-leave-active{transition-property:transform;transition-timing-function:ease;transition-duration:.3s}.narrat-transition-slide-bottom-enter-from{transform:translateY(-100%)}.narrat-transition-slide-bottom-leave-to{transform:translateY(100%)}.screens-fade-enter-active,.screens-fade-leave-active{transition:opacity .5s ease}.screens-fade-enter-from,.screens-fade-leave-to{opacity:0}.dialog-transition-enter-active,.dialog-transition-leave-active{transition:transform .25s ease-out}.dialog-transition-enter-from,.dialog-transition-leave-to{transform:translateY(-100%)}.highlighted-tooltip-keyword{color:var(--highlighted-tooltip-keyword-color);font-size:var(--highlighted-tooltip-keyword-font-size);font-weight:var(--highlighted-tooltip-keyword-font-weight);-webkit-user-select:auto;user-select:auto;pointer-events:all}.button.selected{border:var(--selected-border)}@keyframes narrat-screenshake{0%{transform:translate(0)}25%{transform:translate(5px)}50%{transform:translate(-5px)}75%{transform:translate(5px)}to{transform:translate(0)}}.modal-mask{position:absolute;z-index:9998;top:0;left:0;width:100%;height:100%;background-color:#0003;transition:opacity .3s ease;display:flex;flex-direction:column;flex-shrink:2 2;align-items:center;justify-content:center}.modal-container{min-width:300px;max-width:90vw;max-height:100%;overflow-y:hidden;margin:10px auto;padding:20px 30px;border-radius:5px;transition:all .3s ease;font-family:Helvetica,Arial,sans-serif;background:var(--modal-background);display:flex;flex-direction:column}.modal-header{position:relative}.modal-header h3{flex-shrink:0;margin-top:0;color:var(--secondary)}.modal-body{overflow-y:auto;flex-shrink:2}.modal-default-button{float:right}.modal-enter,.modal-leave-active{opacity:0}.modal-enter .modal-container,.modal-leave-active .modal-container{-webkit-transform:scale(1.1);transform:scale(1.1)}.close-button{border:1px solid var(--text-color);border-radius:50px;font-size:1.8rem;font-weight:700;position:absolute;right:-20px;top:-10px;width:50px;height:50px}.close-button:hover{background-color:var(--focus)}.debug-menu{z-index:9999}.debug-button{position:fixed;bottom:10px;right:10px;padding:5px}.error-message{margin-top:10px;margin-bottom:10px}.error{color:#ff4500}.warning{color:orange}.error-filename{color:gray;text-decoration:underline}.debug-menu-container{width:100%}.search-result{border:1px solid var(--text-color);padding:10px;font-weight:700;font-size:1.25rem;width:100}.jump-menu-container{width:80%}.debug-info{position:fixed;background-color:#0009;border:1px dotted var(--text-color);top:0;left:0;padding:5px}.variables-viewer{height:100%}.notifications-holder{position:fixed;top:0;right:0;padding:10px;display:flex;flex-direction:column-reverse;align-items:center;pointer-events:none;z-index:2}.notification{margin-top:10px;margin-bottom:10px;border-radius:10px;padding:9px;width:400px;text-align:left}.notification-icon{float:left;width:var(--notification-icon-size);height:var(--notification-icon-size);margin-right:10px}.notification-text{color:var(--notifications-text-color);font-size:1.2rem;font-weight:600}.notification-description{margin-top:10px;color:var(--notifications-description-color);font-size:1rem;font-style:italic}.save-slot{background-color:#00000080;border-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);width:100%;transition:background-color .3s}.save-slot:hover,.save-slot.selected{background-color:var(--save-ui-selected-background)}.save-slot:not(:last-child){margin-bottom:20px}.save-name{font-size:1.2rem;font-weight:700;background-color:var(--bg-color);color:var(--text-color);padding:0 5px}.save-slot-number-container{width:100px;text-align:center}.save-slot-number{font-size:1.8rem;font-weight:700}.save-slot-screenshot{width:170px;background-size:contain;background-position:center;height:100%;border-left-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);background-repeat:no-repeat}.save-info{border-left-width:var(--save-ui-border-width);border-right-width:var(--save-ui-border-width);border-style:var(--save-ui-border-style);border-color:var(--save-ui-border-color);padding:10px;height:100%}.saves-section{margin-bottom:20px}.saves-section-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}#game-menu{width:100%;height:100%;padding:20px;background-color:#000}#game-title-container{margin-bottom:80px}#game-title-text{text-align:center;font-size:3rem}.menu-button{font-size:1.5rem;margin-bottom:10px}#game-header{position:relative;top:100px}.start-menu-buttons-container{width:400px}.save-modal{width:70%}.saves-container{padding:20px}.dialog-picture{position:absolute;width:80px;height:80px;border:2px solid white;border-radius:10px;background-color:gray;z-index:99;transition:all .5s ease-in-out}.dialog-picture img{width:100%;height:100%}.dialog-title{font-size:1.25rem;font-weight:700}.dialog-text{font-size:1rem}.dialog-box{color:var(--text-color);margin-top:15px;padding:0 10px 0 2em}.dialog-box-followup{margin-top:0}.dialog-choice{color:var(--dialog-choice-color)}.dialog-choice.seen-before{color:var(--dialog-choice-seen-before-color)!important}.key-choice{color:var(--dialog-choice-key-color)}.unimportant-choice{color:#fff}.dialog-choice:hover{color:var(--dialog-choice-hover-color);cursor:pointer}.buttons-container{width:100%;padding:10px;display:flex;justify-content:space-evenly;align-items:stretch;box-sizing:border-box}.interact-button{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-color);font-weight:700;font-size:1.3rem;text-align:center;flex-grow:2;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.interact-button:not(:last-child){margin-right:10px}.choice-index{color:#fff;margin-right:10px}.dialog-container{flex-shrink:2;min-height:100%;width:100%;background-color:(var(--bg-color));box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;overflow-x:hidden}.dialog{overflow-y:auto;overflow-x:hidden;position:relative;-ms-overflow-style:none;scrollbar-width:none;background:var(--dialog-box-bg);border:var(--dialog-box-border);box-shadow:0 19px 38px #000000b3,0 15px 12px #00000080}.dialog::-webkit-scrollbar{display:none}.dialog *{overflow-anchor:none}.anchor{overflow-anchor:auto;height:1px}.auto-skip-buttons{position:absolute;top:10px;right:160px}.tab{background:var(--tab-background);border-style:var(--tab-border-style);border-color:var(--tab-border-color);flex-grow:1;padding:5px 1rem;text-align:center}.tab:not(:last-child){border-right-width:1px}.tab-active{background:var(--tab-active-background);color:var(--tab-active-color);text-shadow:0 0 20px #fff,0 0 30px var(--tab-selected-glow-color),0 0 40px var(--tab-selected-glow-color),0 0 50px var(--tab-selected-glow-color),0 0 60px var(--tab-selected-glow-color),0 0 70px var(--tab-selected-glow-color),0 0 80px var(--tab-selected-glow-color)}.tab-inactive{background:var(--tab-inactive-background);color:var(--tab-inactive-color)}.tab-icon{width:16px;height:16px}.tab-title-container{font-size:1.3rem;font-weight:700}.tabs-controller{display:flex;flex-direction:column;width:100%;height:100%;padding:0px 2rem}.tab-content{position:relative;width:100%}.tabs-controller__tabs{position:relative;width:100%;display:flex;flex-direction:row;justify-content:space-evenly;background:var(--tabs-background)}.menu-content{text-align:center}.menu-toggle-button{margin:0;padding:2px;border-radius:5px}.menu-toggle-button:not(:last-child){margin-right:10px}.menu-modal{width:90%;height:90%}.viewport-object{position:absolute;display:flex;justify-content:center;align-items:center;color:#fff;font-size:1.8rem;font-weight:700;background-size:cover;background-repeat:no-repeat}.viewport-object.selected{border:var(--selected-border)}.viewport-object.interactable{cursor:pointer;pointer-events:auto}.viewport-object.disabled{pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-button{position:absolute;display:flex;justify-content:center;align-items:center;background:var(--button-background);color:var(--button-text-color);font-size:1.8rem;font-weight:700}.viewport-button.interactable{cursor:pointer;pointer-events:auto}.viewport-button.disabled{pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-button.greyed{opacity:.3}.viewport-button.hidden{opacity:0;display:none}.viewport-button.selected{border:var(--selected-border)}.viewport-layer{background-size:cover;background-repeat:no-repeat;background-position:center;position:absolute;left:0;top:0}.transition-holder{position:absolute;top:0;left:0;width:100%;height:100%}.viewport{position:relative}.layer-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.hud{position:absolute;right:0;top:0;display:flex;flex-direction:row-reverse;z-index:3}.hud-stat{border:1px dotted white;background-color:var(--hud-background);color:var(--hud-text-color);padding:5px}.hud-icon{display:inline-block;height:1em}.hud-text{margin-left:5px}.auto-play-feedback-container{position:absolute;top:0;left:0;display:flex;background-color:#00000080}.auto-play-feedback{font-size:1.2rem}@keyframes auto-feedback{0%{opacity:.5}to{opacity:1}}.auto-play-feedback-auto,.auto-play-feedback-skip{animation:auto-feedback 1.5s ease-in-out alternate-reverse infinite}.game{position:absolute;background-color:var(--game-bg-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;height:100%;box-sizing:border-box;overflow:hidden}.menu-toggle{position:fixed;bottom:0;right:15%;z-index:2}#loading-bar{position:relative;width:60vw;height:50px;border-radius:50px;background:var(--loading-bar-outer-bg);border:3px solid white}#inner-loading-bar{height:100%;border-radius:50px 0 0 50px;background:var(--loading-bar-inner-bg)}#loading-text{z-index:99999;display:flex;align-items:center;justify-content:space-around;position:absolute;width:100%;height:100%;top:0}@keyframes animate-logo{0%{transform:perspective(10000px) rotateY(0) rotateX(0) scale(.8)}50%{transform:perspective(10000px) rotateY(180deg) rotateX(-10deg) scale(1)}to{transform:perspective(10000px) rotateY(360deg) rotateX(0) scale(.8)}}#engine-splash-header{position:absolute;width:50%;perspective:300px;transition-property:opacity}#engine-splash-header.invisible{opacity:0}#engine-splash-screen{position:absolute;width:100%;height:100%;background-color:#000}#engine-splash-logo{width:300px;height:300px;margin:50px;transform-style:preserve-3d;animation:animate-logo infinite 10s;animation-timing-function:linear}#game-splash-title{font-size:4.3rem;text-align:center;margin-bottom:40px}#game-splash-screen{width:100%;height:100%;position:absolute;background-color:#000}.splash-start-button{padding:10px 20px;font-size:2rem}.floating-tooltip{position:fixed;background:var(--tooltip-background);border:var(--tooltip-border);border-radius:var(--tooltip-border-radius);padding:10px;z-index:100}.floating-tooltip-title{font-size:var(--tooltip-title-font-size);color:var(--tooltip-title-color);font-weight:700;margin-bottom:5px}.floating-tooltip-text{font-size:var(--tooltip-font-size);color:var(--tooltip-color)}#narrat-app-container{background-color:var(--bg-color);width:100%;height:100%;position:absolute;display:flex;flex-direction:row;align-items:center;justify-content:center;color:var(--text-color);box-sizing:border-box;overflow:hidden;transform-origin:center center;transition:all .15s ease}#narrat-app{z-index:2;width:100%;height:100%;position:absolute;display:flex;flex-direction:row;align-items:center;justify-content:center;color:var(--text-color);box-sizing:border-box;overflow:hidden;transform-origin:center center}.app-blurred-by-modal{filter:blur(5px)}.volume-label{font-size:1.25rem;font-weight:700;width:180px;text-align:right;margin-right:20px}.volume-controls{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--light-background);border:1px dashed white;padding:20px;margin:20px 0}.volume-control{width:100%;font-size:1.5rem;display:flex;align-items:center;justify-content:space-between;margin:0 20px}.volume-slider{flex-grow:2;background-color:#00f}.yellow{background-color:#ff0}.setting-label{font-size:1.25rem;font-weight:700;text-align:left;margin-right:20px}.setting-slider{flex-grow:2;background-color:#00f}.settings-widget-container{width:100%;font-size:1.5rem;display:flex;align-items:center;justify-content:flex-start}.setting-description{margin-left:2rem}.setting-separator{background-color:var(--separator-bg-color);width:var(--separator-width);height:var(--separator-height);margin-top:.5rem;margin-bottom:.5rem;text-align:center;margin-left:auto;margin-right:auto}.settings-menu-title{margin-top:1rem;margin-bottom:1rem}.settings-menu-container{position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;background:var(--light-background);border:1px dashed white;padding:20px;margin:20px 0}.quit-button{margin:20px;text-align:center}.main-menu-modal{width:60%}.sub-tabs-controller{display:flex;flex-direction:column;width:100%;height:100%;padding:0px 2rem}.sub-tab-content{position:relative;width:100%;margin-top:2rem}.sub-tabs-controller__tabs{position:relative;width:100%;display:flex;flex-direction:row;justify-content:space-evenly;background:var(--tabs-background)}.inventory-section{display:flex;flex-direction:column;margin:1rem 0}.inventory-section-items{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.item-display{width:200px;height:200px;position:relative;background-repeat:no-repeat;background-size:contain}.item-display.selected{border:var(--selected-border)}.item-title{position:absolute;bottom:0;text-align:center;width:100%;color:var(--inventory-text-color);background:var(--inventory-text-background)}.item-amount{position:absolute;top:0;right:0;font-weight:700;font-size:1.25rem;color:var(--inventory-amount-color);width:40px;height:40px;background-color:var(--inventory-amount-background)}.inventory-modal{width:800px;min-height:50%}.inventory-container{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.item-description-container{justify-content:space-between;align-items:stretch}.item-left{border:1px dashed white;flex-direction:column;padding:10px;justify-content:center}.item-right{border:1px dashed white;flex-direction:column;flex-grow:2;align-items:baseline;padding:10px}.achievement-display{display:flex;align-items:center;flex-direction:column;border-color:var(--achievement-tile-border-color);position:relative;background:var(--achievement-tile-background)}.achievement-icon{width:200px;height:200px;background-size:contain;background-repeat:no-repeat}.obtained-status{width:100%;text-align:left;color:var(--achievement-description-color);font-style:italic}.achievement-title{text-align:left;width:100%;color:var(--achievement-title-color);margin-bottom:5px}.achievement-description{width:100%;text-align:left;color:var(--achievement-description-color)}.achievements-section{display:flex;flex-direction:column;margin:1rem 0}.achievements-section-achievements{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.achievements-modal{width:800px;min-height:50%}.achievements-container{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}.achievement-description-container{justify-content:space-between;align-items:stretch}.achievement-left{border:1px dashed white;flex-direction:column;padding:10px;justify-content:center}.achievement-right{border:1px dashed white;flex-direction:column;flex-grow:2;align-items:baseline;padding:10px}.quest-header{display:flex;flex-direction:row;align-items:center}.quest-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.quest-completed{color:var(--completed-quest-title-color)}.quest-in-progress{color:var(--quest-title-color)}.quest-state{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.quest-description{font-size:1.1rem;text-align:justify;font-style:italic;margin-bottom:.5rem}.quest-objectives-container{margin-left:10px}.quest-objective-completed{color:var(--objective-completed-color);text-decoration:line-through}.quest-objective-in-progress{color:var(--objective-in-progress-color)}.quest-objective-description{font-size:1rem;margin-bottom:.5rem}.quest-list-display{cursor:pointer;transition:transform .2s ease-in-out}.quest-list-display:hover{transform:translateY(-2px)}.quest-list-title{padding-left:10px;font-size:1.2rem}.quest-list-completed{color:var(--completed-quest-title-color)}.quest-list-in-progress{color:var(--quest-title-color)}.quests-category{margin-left:.6rem}.quests-modal{width:100%;min-height:50%}.quests-ui{display:flex;align-items:stretch;width:100%;flex-grow:2;height:400px}.quests-ui-horizontal{flex-direction:row}.quests-ui-vertical{flex-direction:column}.quests-list-container{background-color:#96969680;margin-right:20px;flex-shrink:0;border:1px dashed white;padding:20px;height:100%;overflow-y:auto}.quest-details{background-color:#96969680;flex-grow:1;border:1px dashed white;padding:20px;height:100%;overflow-y:auto}.skill-display[data-v-db9d98bf]{width:200px;height:300px;position:relative;background-size:cover}.skill-description-container[data-v-db9d98bf]{justify-content:space-between;align-items:stretch}.skill-left[data-v-db9d98bf]{flex-direction:column;border:1px dashed white;padding:10px;justify-content:center}.skill-right[data-v-db9d98bf]{border:1px dashed white;flex-direction:column;align-items:baseline;flex-grow:2}.skill-grid-element[data-v-8d457bf9]{width:200px;height:300px;position:relative;background-size:cover}.skill-grid-element.selected[data-v-8d457bf9]{border:var(--selected-border)}.skill-title[data-v-8d457bf9]{position:absolute;bottom:0;text-align:center;width:100%;color:var(--skills-text-color);background:var(--skills-text-background)}.skill-xp-container[data-v-8d457bf9]{position:absolute;top:0;left:0;height:var(--skills-xp-bar-height);width:calc(100% - var(--skills-xp-bar-height));background-color:#00000080}.skill-xp-bar[data-v-8d457bf9]{position:absolute;top:0;left:0;width:50%;height:100%;background-color:#0000fa80}.skill-xp-text[data-v-8d457bf9]{z-index:2}.skill-level[data-v-8d457bf9]{position:absolute;top:0;right:0;font-weight:700;font-size:1.5rem;color:var(--skills-level-color);width:var(--skills-xp-bar-height);height:var(--skills-xp-bar-height);background-color:var(--skills-level-background)}.skills-container[data-v-31202bb8]{display:grid;grid-auto-rows:auto;grid-template-columns:repeat(3,1fr);grid-gap:20px 20px}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { ConfigInput } from '../config/config-input';
|
|
1
2
|
export type NarratScript = {
|
|
2
3
|
code: string;
|
|
3
4
|
fileName: string;
|
|
@@ -10,5 +11,9 @@ export interface AppOptions {
|
|
|
10
11
|
scripts: NarratScript[];
|
|
11
12
|
logging?: boolean;
|
|
12
13
|
debug?: boolean;
|
|
14
|
+
container?: HTMLElement | string;
|
|
15
|
+
configs?: {
|
|
16
|
+
[Key in keyof ConfigInput]: ConfigInput[Key];
|
|
17
|
+
};
|
|
13
18
|
}
|
|
14
19
|
export type AppOptionsInput = Partial<AppOptions>;
|
|
@@ -12,6 +12,7 @@ import { AchievementsSave } from '../stores/achievements-store';
|
|
|
12
12
|
import { GameUserSettingsSave } from '../stores/settings-store';
|
|
13
13
|
import { ConfigStoreSave } from '../stores/config-store';
|
|
14
14
|
import { ChoiceTrackingSave } from '../stores/choices-tracking-store';
|
|
15
|
+
import { RenderingSaveData } from '../stores/rendering-store';
|
|
15
16
|
export interface SaveSlot {
|
|
16
17
|
slotType: 'manual' | 'auto';
|
|
17
18
|
id: string;
|
|
@@ -35,6 +36,7 @@ export type GameSave = {
|
|
|
35
36
|
settings: GameUserSettingsSave;
|
|
36
37
|
config: ConfigStoreSave;
|
|
37
38
|
choices: ChoiceTrackingSave;
|
|
39
|
+
rendering: RenderingSaveData;
|
|
38
40
|
};
|
|
39
41
|
export type GlobalGameSave = {
|
|
40
42
|
achievements: AchievementsSave;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AnimationsConfig, CSSAnimationKeyframes, CSSAnimationOptions, NarratAnimation, NarratAnimationInput } from '../config/animations-config';
|
|
2
|
+
export declare const defaultAnimations: AnimationsConfig;
|
|
3
|
+
export declare function getElementOrQuery(elementOrQuery: string | HTMLElement): Element | null;
|
|
4
|
+
export declare function getAnimationKeyframes(animation: string | CSSAnimationKeyframes): CSSAnimationKeyframes;
|
|
5
|
+
export declare function getNarratAnimation(animationInput: string | NarratAnimationInput): NarratAnimation;
|
|
6
|
+
export declare function animationInputToAnimation(animation: NarratAnimationInput): NarratAnimation;
|
|
7
|
+
export declare function animate(elementOrQuery: string | HTMLElement, animationInput: string, extraOptions?: string | CSSAnimationOptions): Promise<unknown>;
|
|
8
|
+
export declare function screenshake(elementOrQuery: string | HTMLElement): Promise<unknown>;
|
|
@@ -35,6 +35,336 @@ export declare function getModifiableDataPinia(): {
|
|
|
35
35
|
}[];
|
|
36
36
|
logging?: boolean | undefined;
|
|
37
37
|
debug?: boolean | undefined;
|
|
38
|
+
container?: string | HTMLElement | undefined;
|
|
39
|
+
configs?: {
|
|
40
|
+
skillChecks?: string | {
|
|
41
|
+
options: {
|
|
42
|
+
extraDicePerLevel?: number | undefined;
|
|
43
|
+
finalRollIsHighest?: boolean | undefined;
|
|
44
|
+
finalRollIsLowest?: boolean | undefined;
|
|
45
|
+
failOnRollsEqualToThreshold?: boolean | undefined;
|
|
46
|
+
diceRange: [number, number];
|
|
47
|
+
diceCount: number;
|
|
48
|
+
difficultyText: [number, string][];
|
|
49
|
+
extraPointsPerLevel: number;
|
|
50
|
+
successOnRollsBelowThreshold: boolean;
|
|
51
|
+
showDifficultyText: boolean;
|
|
52
|
+
showDifficultyNumber: boolean;
|
|
53
|
+
showDifficultyWithoutModifiers: boolean;
|
|
54
|
+
};
|
|
55
|
+
skillChecks: Record<string, {
|
|
56
|
+
winsNeeded?: number | undefined;
|
|
57
|
+
hideAfterRoll?: boolean | undefined;
|
|
58
|
+
repeatable?: boolean | undefined;
|
|
59
|
+
skill: string;
|
|
60
|
+
difficulty: number;
|
|
61
|
+
}>;
|
|
62
|
+
} | undefined;
|
|
63
|
+
skills?: string | {
|
|
64
|
+
skills?: Record<string, {
|
|
65
|
+
hidden?: boolean | undefined;
|
|
66
|
+
name: string;
|
|
67
|
+
description: string;
|
|
68
|
+
startingLevel: number;
|
|
69
|
+
icon: string;
|
|
70
|
+
}> | undefined;
|
|
71
|
+
skillOptions?: {
|
|
72
|
+
xpPerLevel: number;
|
|
73
|
+
notifyLevelUp: boolean;
|
|
74
|
+
} | undefined;
|
|
75
|
+
} | undefined;
|
|
76
|
+
buttons?: string | {
|
|
77
|
+
clickableDuringScriptsByDefault?: boolean | undefined;
|
|
78
|
+
buttons: Record<string, {
|
|
79
|
+
text?: string | undefined;
|
|
80
|
+
background?: string | undefined;
|
|
81
|
+
cssClass?: string | undefined;
|
|
82
|
+
anchor?: {
|
|
83
|
+
x: number;
|
|
84
|
+
y: number;
|
|
85
|
+
} | undefined;
|
|
86
|
+
action?: string | undefined;
|
|
87
|
+
actionType?: string | undefined;
|
|
88
|
+
scriptClickable?: boolean | undefined;
|
|
89
|
+
tag?: string | undefined;
|
|
90
|
+
enabled: boolean;
|
|
91
|
+
position: {
|
|
92
|
+
width?: number | undefined;
|
|
93
|
+
height?: number | undefined;
|
|
94
|
+
left: number;
|
|
95
|
+
top: number;
|
|
96
|
+
};
|
|
97
|
+
}>;
|
|
98
|
+
} | undefined;
|
|
99
|
+
items?: string | {
|
|
100
|
+
categories?: {
|
|
101
|
+
title: string;
|
|
102
|
+
id: string;
|
|
103
|
+
}[] | undefined;
|
|
104
|
+
items?: Record<string, {
|
|
105
|
+
tag?: string | undefined;
|
|
106
|
+
onUse?: {
|
|
107
|
+
label: string;
|
|
108
|
+
action: string;
|
|
109
|
+
} | undefined;
|
|
110
|
+
category?: string | undefined;
|
|
111
|
+
showIfEmpty?: boolean | undefined;
|
|
112
|
+
name: string;
|
|
113
|
+
description: string;
|
|
114
|
+
icon: string;
|
|
115
|
+
}> | undefined;
|
|
116
|
+
} | undefined;
|
|
117
|
+
quests?: string | {
|
|
118
|
+
categories: {
|
|
119
|
+
title: string;
|
|
120
|
+
id: string;
|
|
121
|
+
}[];
|
|
122
|
+
quests: Record<string, {
|
|
123
|
+
category?: string | undefined;
|
|
124
|
+
succeededDescription?: string | undefined;
|
|
125
|
+
failedDescription?: string | undefined;
|
|
126
|
+
endings?: Record<string, {
|
|
127
|
+
description: string;
|
|
128
|
+
success: boolean;
|
|
129
|
+
}> | undefined;
|
|
130
|
+
title: string;
|
|
131
|
+
description: string;
|
|
132
|
+
objectives: Record<string, {
|
|
133
|
+
hidden?: boolean | undefined;
|
|
134
|
+
succeededDescription?: string | undefined;
|
|
135
|
+
failedDescription?: string | undefined;
|
|
136
|
+
description: string;
|
|
137
|
+
}>;
|
|
138
|
+
}>;
|
|
139
|
+
} | undefined;
|
|
140
|
+
tooltips?: string | {
|
|
141
|
+
options: {
|
|
142
|
+
delay?: number | undefined;
|
|
143
|
+
screenEdgesMinimumMargin?: number | undefined;
|
|
144
|
+
styling?: {
|
|
145
|
+
cssClass?: string | undefined;
|
|
146
|
+
textCssClass?: string | undefined;
|
|
147
|
+
titleCssClass?: string | undefined;
|
|
148
|
+
} | undefined;
|
|
149
|
+
width: number;
|
|
150
|
+
keywordsPrefix: string;
|
|
151
|
+
};
|
|
152
|
+
tooltips: {
|
|
153
|
+
styling?: {
|
|
154
|
+
cssClass?: string | undefined;
|
|
155
|
+
textCssClass?: string | undefined;
|
|
156
|
+
titleCssClass?: string | undefined;
|
|
157
|
+
} | undefined;
|
|
158
|
+
title: string;
|
|
159
|
+
description: string;
|
|
160
|
+
keywords: string[];
|
|
161
|
+
}[];
|
|
162
|
+
} | undefined;
|
|
163
|
+
baseAssetsPath?: string | undefined;
|
|
164
|
+
baseDataPath?: string | undefined;
|
|
165
|
+
images?: Record<string, string> | undefined;
|
|
166
|
+
settings?: {
|
|
167
|
+
customSettings?: Record<string, ({
|
|
168
|
+
description?: string | undefined;
|
|
169
|
+
name: string;
|
|
170
|
+
} & {
|
|
171
|
+
type: "number";
|
|
172
|
+
maxValue: number;
|
|
173
|
+
minValue: number;
|
|
174
|
+
defaultValue: number;
|
|
175
|
+
step: number;
|
|
176
|
+
}) | ({
|
|
177
|
+
description?: string | undefined;
|
|
178
|
+
name: string;
|
|
179
|
+
} & {
|
|
180
|
+
type: "integer";
|
|
181
|
+
maxValue: number;
|
|
182
|
+
minValue: number;
|
|
183
|
+
defaultValue: number;
|
|
184
|
+
step: number;
|
|
185
|
+
}) | ({
|
|
186
|
+
description?: string | undefined;
|
|
187
|
+
name: string;
|
|
188
|
+
} & {
|
|
189
|
+
type: "boolean";
|
|
190
|
+
defaultValue: boolean;
|
|
191
|
+
}) | ({
|
|
192
|
+
description?: string | undefined;
|
|
193
|
+
name: string;
|
|
194
|
+
} & {
|
|
195
|
+
type: "string";
|
|
196
|
+
defaultValue: string;
|
|
197
|
+
})> | undefined;
|
|
198
|
+
} | undefined;
|
|
199
|
+
gameFlow?: {
|
|
200
|
+
labelToJumpOnScriptEnd?: string | undefined;
|
|
201
|
+
} | undefined;
|
|
202
|
+
dialogPanel?: {
|
|
203
|
+
width?: number | undefined;
|
|
204
|
+
height?: number | undefined;
|
|
205
|
+
animateText?: boolean | undefined;
|
|
206
|
+
textSpeed?: number | undefined;
|
|
207
|
+
timeBetweenLines?: number | undefined;
|
|
208
|
+
overlayMode?: boolean | undefined;
|
|
209
|
+
rightOffset?: number | undefined;
|
|
210
|
+
bottomOffset?: number | undefined;
|
|
211
|
+
hideDuringTransition?: boolean | undefined;
|
|
212
|
+
showAfterScriptEnd?: boolean | undefined;
|
|
213
|
+
} | undefined;
|
|
214
|
+
splashScreens?: {
|
|
215
|
+
engineSplashScreen?: {
|
|
216
|
+
skip?: boolean | undefined;
|
|
217
|
+
fadeDuration?: number | undefined;
|
|
218
|
+
timeBeforeFadeout?: number | undefined;
|
|
219
|
+
overrideText?: string | undefined;
|
|
220
|
+
overrideLogo?: string | undefined;
|
|
221
|
+
} | undefined;
|
|
222
|
+
gameSplashScreen?: {
|
|
223
|
+
startButtonText?: string | undefined;
|
|
224
|
+
} | undefined;
|
|
225
|
+
} | undefined;
|
|
226
|
+
scripts?: string | string[] | undefined;
|
|
227
|
+
notifications?: {
|
|
228
|
+
alsoPrintInDialogue?: boolean | undefined;
|
|
229
|
+
timeOnScreen: number;
|
|
230
|
+
} | undefined;
|
|
231
|
+
achievements?: string | undefined;
|
|
232
|
+
interactionTags?: Record<string, {
|
|
233
|
+
onlyInteractOutsideOfScripts?: boolean | undefined;
|
|
234
|
+
}> | undefined;
|
|
235
|
+
transitions?: Record<string, {
|
|
236
|
+
delay?: number | undefined;
|
|
237
|
+
duration?: number | undefined;
|
|
238
|
+
}> | undefined;
|
|
239
|
+
menuButtons?: Record<string, {
|
|
240
|
+
cssClass?: string | undefined;
|
|
241
|
+
text: string;
|
|
242
|
+
}> | undefined;
|
|
243
|
+
debugging?: {
|
|
244
|
+
showScriptFinishedMessage?: boolean | undefined;
|
|
245
|
+
} | undefined;
|
|
246
|
+
saves?: {
|
|
247
|
+
runOnReload?: string | undefined;
|
|
248
|
+
slots: number;
|
|
249
|
+
mode: string;
|
|
250
|
+
} | undefined;
|
|
251
|
+
choices?: string | undefined;
|
|
252
|
+
animations?: string | undefined;
|
|
253
|
+
audio: string | {
|
|
254
|
+
options: {
|
|
255
|
+
volume?: number | undefined;
|
|
256
|
+
defaultMusic?: string | undefined;
|
|
257
|
+
musicFadeInTime?: number | undefined;
|
|
258
|
+
musicFadeOutTime?: number | undefined;
|
|
259
|
+
musicFadeInDelay?: number | undefined;
|
|
260
|
+
};
|
|
261
|
+
files: Record<string, {
|
|
262
|
+
path?: string | undefined;
|
|
263
|
+
volume?: number | undefined;
|
|
264
|
+
rate?: number | undefined;
|
|
265
|
+
html5?: boolean | undefined;
|
|
266
|
+
fadeInTime?: number | undefined;
|
|
267
|
+
fadeInDelay?: number | undefined;
|
|
268
|
+
fadeOutTime?: number | undefined;
|
|
269
|
+
loop?: boolean | undefined;
|
|
270
|
+
src: string;
|
|
271
|
+
}>;
|
|
272
|
+
audioTriggers: Record<string, string>;
|
|
273
|
+
};
|
|
274
|
+
characters: string | {
|
|
275
|
+
config: {
|
|
276
|
+
playerCharacter?: string | undefined;
|
|
277
|
+
gameCharacter?: string | undefined;
|
|
278
|
+
imagesPath: string;
|
|
279
|
+
};
|
|
280
|
+
characters: Record<string, {
|
|
281
|
+
style?: {
|
|
282
|
+
portraitCssClass?: string | undefined;
|
|
283
|
+
color?: string | undefined;
|
|
284
|
+
boxCss?: Record<string, any> | undefined;
|
|
285
|
+
nameCss?: Record<string, any> | undefined;
|
|
286
|
+
textCss?: Record<string, any> | undefined;
|
|
287
|
+
} | undefined;
|
|
288
|
+
sprites?: Record<string, string | {
|
|
289
|
+
loop?: boolean | undefined;
|
|
290
|
+
width?: number | undefined;
|
|
291
|
+
height?: number | undefined;
|
|
292
|
+
autoplay?: boolean | undefined;
|
|
293
|
+
muted?: boolean | undefined;
|
|
294
|
+
video: string;
|
|
295
|
+
} | {
|
|
296
|
+
width?: number | undefined;
|
|
297
|
+
height?: number | undefined;
|
|
298
|
+
image: string;
|
|
299
|
+
}> | undefined;
|
|
300
|
+
name: string;
|
|
301
|
+
}>;
|
|
302
|
+
};
|
|
303
|
+
screens: string | {
|
|
304
|
+
screens?: Record<string, {
|
|
305
|
+
video?: {
|
|
306
|
+
loop?: boolean | undefined;
|
|
307
|
+
muted?: boolean | undefined;
|
|
308
|
+
} | undefined;
|
|
309
|
+
buttons?: (string | ({
|
|
310
|
+
text?: string | undefined;
|
|
311
|
+
background?: string | undefined;
|
|
312
|
+
cssClass?: string | undefined;
|
|
313
|
+
anchor?: {
|
|
314
|
+
x: number;
|
|
315
|
+
y: number;
|
|
316
|
+
} | undefined;
|
|
317
|
+
action?: string | undefined;
|
|
318
|
+
actionType?: string | undefined;
|
|
319
|
+
scriptClickable?: boolean | undefined;
|
|
320
|
+
tag?: string | undefined;
|
|
321
|
+
enabled: boolean;
|
|
322
|
+
position: {
|
|
323
|
+
width?: number | undefined;
|
|
324
|
+
height?: number | undefined;
|
|
325
|
+
left: number;
|
|
326
|
+
top: number;
|
|
327
|
+
};
|
|
328
|
+
} & {
|
|
329
|
+
id: string;
|
|
330
|
+
}))[] | undefined;
|
|
331
|
+
background: string;
|
|
332
|
+
}> | undefined;
|
|
333
|
+
};
|
|
334
|
+
gameTitle: string;
|
|
335
|
+
saveFileName: string;
|
|
336
|
+
layout: {
|
|
337
|
+
minTextWidth?: number | undefined;
|
|
338
|
+
defaultFontSize?: number | undefined;
|
|
339
|
+
backgrounds: {
|
|
340
|
+
width: number;
|
|
341
|
+
height: number;
|
|
342
|
+
};
|
|
343
|
+
dialogBottomPadding: string | number;
|
|
344
|
+
verticalLayoutThreshold: number;
|
|
345
|
+
portraits: {
|
|
346
|
+
offset?: {
|
|
347
|
+
landscape?: {
|
|
348
|
+
right: number;
|
|
349
|
+
bottom: number;
|
|
350
|
+
} | undefined;
|
|
351
|
+
portrait?: {
|
|
352
|
+
right: number;
|
|
353
|
+
bottom: number;
|
|
354
|
+
} | undefined;
|
|
355
|
+
} | undefined;
|
|
356
|
+
width: number;
|
|
357
|
+
height: number;
|
|
358
|
+
};
|
|
359
|
+
};
|
|
360
|
+
hudStats: Record<string, {
|
|
361
|
+
maxValue?: number | undefined;
|
|
362
|
+
minValue?: number | undefined;
|
|
363
|
+
name: string;
|
|
364
|
+
icon: string;
|
|
365
|
+
startingValue: number;
|
|
366
|
+
}>;
|
|
367
|
+
} | undefined;
|
|
38
368
|
};
|
|
39
369
|
baseSettings: {
|
|
40
370
|
[x: string]: any;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ScreenObjectState } from '../stores/screen-objects-store';
|
|
2
|
+
export interface RenderingState {
|
|
3
|
+
selected: boolean;
|
|
4
|
+
clickable: boolean;
|
|
5
|
+
viewportClickable: boolean;
|
|
6
|
+
transitioning: boolean;
|
|
7
|
+
greyed?: boolean;
|
|
8
|
+
hidden?: boolean;
|
|
9
|
+
cssClass?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function getCSSClassForObject(state: RenderingState): Record<string, boolean>;
|
|
12
|
+
export declare function getRenderingStateForScreenObject(state: ScreenObjectState, selected: boolean, transitioning: boolean): RenderingState;
|
|
13
|
+
export declare function getRenderingStateForButton(button: string, selected: boolean, transitioning: boolean): RenderingState;
|
|
14
|
+
export declare function getCSSClassForButton(button: string, selected: boolean, transitioning: boolean): Record<string, boolean>;
|
|
15
|
+
export declare function getCSSClassForScreenObject(state: ScreenObjectState, selected: boolean, transitioning: boolean): Record<string, boolean>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { GameSave, GlobalGameSave, SaveFile, SaveSlotMetadata } from '../types/game-save';
|
|
2
|
-
export declare const CURRENT_SAVE_VERSION = "3.3.
|
|
2
|
+
export declare const CURRENT_SAVE_VERSION = "3.3.9";
|
|
3
3
|
export declare function saveFileName(): string;
|
|
4
4
|
export declare function getSaveFile(): SaveFile;
|
|
5
5
|
export declare function resetSave(): void;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CommandPlugin } from './command-plugin';
|
|
1
|
+
import { ArgTypes, CommandPlugin } from './command-plugin';
|
|
2
2
|
export declare const loadDataPlugin: CommandPlugin<{
|
|
3
3
|
url: string;
|
|
4
4
|
}, {}>;
|
|
@@ -14,3 +14,15 @@ export declare const jsonEncode: CommandPlugin<{
|
|
|
14
14
|
export declare const jsonDecode: CommandPlugin<{
|
|
15
15
|
value: string;
|
|
16
16
|
}, {}>;
|
|
17
|
+
export declare const setDialogPanelMode: CommandPlugin<{
|
|
18
|
+
mode: 'auto' | 'on' | 'off';
|
|
19
|
+
}, {}>;
|
|
20
|
+
export interface AnimationOptions {
|
|
21
|
+
element: string;
|
|
22
|
+
animation: string;
|
|
23
|
+
duration?: number;
|
|
24
|
+
iterations?: number;
|
|
25
|
+
}
|
|
26
|
+
export declare const animationArgs: ArgTypes;
|
|
27
|
+
export declare const animatePlugin: CommandPlugin<AnimationOptions, {}>;
|
|
28
|
+
export declare const animateWaitPlugin: CommandPlugin<AnimationOptions, {}>;
|