import { L as LanguageSelect } from "./LanguageSelect.79bf81f4.js";
import { K as createComponent, C as computed, J as h, a6 as hSlot, O as useDarkProps, S as useDark, z as watch, bL as isNumber, t as onMounted, u as onBeforeUnmount, aG as hDir, Z as getCurrentInstance, q as QBtn, W as hMergeSlot, r as resolveComponent, o as openBlock, d as createBlock, w as withCtx, g as createBaseVNode, k as createVNode, v as toDisplayString, G as createTextVNode, e as createCommentVNode, c as createElementBlock, F as Fragment, f as renderList, h as renderSlot, bg as QPage, j as defineComponent, s as ref, aA as useAuthStore, _ as _export_sfc } from "./index.71084c31.js";
import { c as usePanelChildProps, u as usePanelProps, a as usePanelEmits, b as usePanel } from "./use-panel.82d82e5f.js";
import { u as useFullscreenProps, a as useFullscreenEmits, b as useFullscreen } from "./use-fullscreen.b492e705.js";
var QCarouselSlide = createComponent({
  name: "QCarouselSlide",
  props: {
    ...usePanelChildProps,
    imgSrc: String
  },
  setup(props, { slots }) {
    const style = computed(() => props.imgSrc ? { backgroundImage: `url("${props.imgSrc}")` } : {});
    return () => h("div", {
      class: "q-carousel__slide",
      style: style.value
    }, hSlot(slots.default));
  }
});
const navigationPositionOptions = ["top", "right", "bottom", "left"];
const controlTypeOptions = ["regular", "flat", "outline", "push", "unelevated"];
var QCarousel = createComponent({
  name: "QCarousel",
  props: {
    ...useDarkProps,
    ...usePanelProps,
    ...useFullscreenProps,
    transitionPrev: {
      type: String,
      default: "fade"
    },
    transitionNext: {
      type: String,
      default: "fade"
    },
    height: String,
    padding: Boolean,
    controlColor: String,
    controlTextColor: String,
    controlType: {
      type: String,
      validator: (v) => controlTypeOptions.includes(v),
      default: "flat"
    },
    autoplay: [Number, Boolean],
    arrows: Boolean,
    prevIcon: String,
    nextIcon: String,
    navigation: Boolean,
    navigationPosition: {
      type: String,
      validator: (v) => navigationPositionOptions.includes(v)
    },
    navigationIcon: String,
    navigationActiveIcon: String,
    thumbnails: Boolean
  },
  emits: [
    ...useFullscreenEmits,
    ...usePanelEmits
  ],
  setup(props, { slots }) {
    const { proxy: { $q } } = getCurrentInstance();
    const isDark = useDark(props, $q);
    let timer = null, panelsLen;
    const {
      updatePanelsList,
      getPanelContent,
      panelDirectives,
      goToPanel,
      previousPanel,
      nextPanel,
      getEnabledPanels,
      panelIndex
    } = usePanel();
    const { inFullscreen } = useFullscreen();
    const style = computed(() => inFullscreen.value !== true && props.height !== void 0 ? { height: props.height } : {});
    const direction = computed(() => props.vertical === true ? "vertical" : "horizontal");
    const navigationPosition = computed(
      () => props.navigationPosition || (props.vertical === true ? "right" : "bottom")
    );
    const classes = computed(
      () => `q-carousel q-panel-parent q-carousel--with${props.padding === true ? "" : "out"}-padding` + (inFullscreen.value === true ? " fullscreen" : "") + (isDark.value === true ? " q-carousel--dark q-dark" : "") + (props.arrows === true ? ` q-carousel--arrows-${direction.value}` : "") + (props.navigation === true ? ` q-carousel--navigation-${navigationPosition.value}` : "")
    );
    const arrowIcons = computed(() => {
      const ico = [
        props.prevIcon || $q.iconSet.carousel[props.vertical === true ? "up" : "left"],
        props.nextIcon || $q.iconSet.carousel[props.vertical === true ? "down" : "right"]
      ];
      return props.vertical === false && $q.lang.rtl === true ? ico.reverse() : ico;
    });
    const navIcon = computed(() => props.navigationIcon || $q.iconSet.carousel.navigationIcon);
    const navActiveIcon = computed(() => props.navigationActiveIcon || navIcon.value);
    const controlProps = computed(() => ({
      color: props.controlColor,
      textColor: props.controlTextColor,
      round: true,
      [props.controlType]: true,
      dense: true
    }));
    watch(() => props.modelValue, () => {
      if (props.autoplay) {
        startTimer();
      }
    });
    watch(() => props.autoplay, (val) => {
      if (val) {
        startTimer();
      } else if (timer !== null) {
        clearTimeout(timer);
        timer = null;
      }
    });
    function startTimer() {
      const duration = isNumber(props.autoplay) === true ? Math.abs(props.autoplay) : 5e3;
      timer !== null && clearTimeout(timer);
      timer = setTimeout(() => {
        timer = null;
        if (duration >= 0) {
          nextPanel();
        } else {
          previousPanel();
        }
      }, duration);
    }
    onMounted(() => {
      props.autoplay && startTimer();
    });
    onBeforeUnmount(() => {
      timer !== null && clearTimeout(timer);
    });
    function getNavigationContainer(type, mapping) {
      return h("div", {
        class: `q-carousel__control q-carousel__navigation no-wrap absolute flex q-carousel__navigation--${type} q-carousel__navigation--${navigationPosition.value}` + (props.controlColor !== void 0 ? ` text-${props.controlColor}` : "")
      }, [
        h("div", {
          class: "q-carousel__navigation-inner flex flex-center no-wrap"
        }, getEnabledPanels().map(mapping))
      ]);
    }
    function getContent() {
      const node = [];
      if (props.navigation === true) {
        const fn = slots["navigation-icon"] !== void 0 ? slots["navigation-icon"] : (opts) => h(QBtn, {
          key: "nav" + opts.name,
          class: `q-carousel__navigation-icon q-carousel__navigation-icon--${opts.active === true ? "" : "in"}active`,
          ...opts.btnProps,
          onClick: opts.onClick
        });
        const maxIndex = panelsLen - 1;
        node.push(
          getNavigationContainer("buttons", (panel, index) => {
            const name = panel.props.name;
            const active = panelIndex.value === index;
            return fn({
              index,
              maxIndex,
              name,
              active,
              btnProps: {
                icon: active === true ? navActiveIcon.value : navIcon.value,
                size: "sm",
                ...controlProps.value
              },
              onClick: () => {
                goToPanel(name);
              }
            });
          })
        );
      } else if (props.thumbnails === true) {
        const color = props.controlColor !== void 0 ? ` text-${props.controlColor}` : "";
        node.push(getNavigationContainer("thumbnails", (panel) => {
          const slide = panel.props;
          return h("img", {
            key: "tmb#" + slide.name,
            class: `q-carousel__thumbnail q-carousel__thumbnail--${slide.name === props.modelValue ? "" : "in"}active` + color,
            src: slide.imgSrc || slide["img-src"],
            onClick: () => {
              goToPanel(slide.name);
            }
          });
        }));
      }
      if (props.arrows === true && panelIndex.value >= 0) {
        if (props.infinite === true || panelIndex.value > 0) {
          node.push(
            h("div", {
              key: "prev",
              class: `q-carousel__control q-carousel__arrow q-carousel__prev-arrow q-carousel__prev-arrow--${direction.value} absolute flex flex-center`
            }, [
              h(QBtn, {
                icon: arrowIcons.value[0],
                ...controlProps.value,
                onClick: previousPanel
              })
            ])
          );
        }
        if (props.infinite === true || panelIndex.value < panelsLen - 1) {
          node.push(
            h("div", {
              key: "next",
              class: `q-carousel__control q-carousel__arrow q-carousel__next-arrow q-carousel__next-arrow--${direction.value} absolute flex flex-center`
            }, [
              h(QBtn, {
                icon: arrowIcons.value[1],
                ...controlProps.value,
                onClick: nextPanel
              })
            ])
          );
        }
      }
      return hMergeSlot(slots.control, node);
    }
    return () => {
      panelsLen = updatePanelsList(slots);
      return h("div", {
        class: classes.value,
        style: style.value
      }, [
        hDir(
          "div",
          { class: "q-carousel__slides-container" },
          getPanelContent(),
          "sl-cont",
          props.swipeable,
          () => panelDirectives.value
        )
      ].concat(getContent()));
    };
  }
});
const _hoisted_1 = { class: "absolute-bottom-right q-pb-md q-px-lg" };
const _hoisted_2 = { class: "auth-card-wrap col-12 col-md-6" };
const _hoisted_3 = { class: "auth-card relative-position fit column justify-between items-stretch bg-primaryBlue text-white q-pa-xl" };
const _hoisted_4 = { class: "full-width col" };
const _hoisted_5 = { class: "full-width col auth-card-title flex items-center" };
const _hoisted_6 = { class: "full-width col flex justify-center items-end" };
const _hoisted_7 = { class: "flex flex-center" };
const _hoisted_8 = { class: "q-mt-md text-center" };
const _hoisted_9 = { class: "auth-page-content-wrap col col-md-6 flex flex-center" };
function render(_ctx, _cache, $props, $setup, $data, $options) {
  const _component_language_select = resolveComponent("language-select");
  const _component_velo_icon = resolveComponent("velo-icon");
  return _ctx.ready ? (openBlock(), createBlock(QPage, {
    key: 0,
    class: "auth-page fit row q-pa-md"
  }, {
    default: withCtx(() => [
      createBaseVNode("div", _hoisted_1, [
        createVNode(_component_language_select)
      ]),
      createBaseVNode("div", _hoisted_2, [
        createBaseVNode("div", _hoisted_3, [
          createBaseVNode("div", _hoisted_4, [
            createVNode(_component_velo_icon, {
              name: "velo",
              color: "white",
              size: "90px"
            })
          ]),
          createBaseVNode("div", _hoisted_5, toDisplayString(_ctx.cardTitle), 1),
          createBaseVNode("div", _hoisted_6, [
            _ctx.showShortcut ? (openBlock(), createBlock(QBtn, {
              key: 0,
              class: "absolute-bottom-right bg-green text-white text-bold q-ma-lg",
              "no-caps": "",
              to: { name: "admin.stats" }
            }, {
              default: withCtx(() => [
                createTextVNode(toDisplayString(_ctx.$t("admin.nav.stats")), 1)
              ]),
              _: 1
            })) : createCommentVNode("", true),
            createVNode(QCarousel, {
              class: "bg-primaryBlue text-white",
              modelValue: _ctx.slide,
              "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.slide = $event),
              "transition-prev": "scale",
              "transition-next": "scale",
              swipeable: "",
              animated: "",
              "control-color": "white",
              navigation: _ctx.slides.length > 1,
              padding: "",
              height: "10em"
            }, {
              default: withCtx(() => [
                (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.slides, (slide) => {
                  return openBlock(), createBlock(QCarouselSlide, {
                    class: "flex justify-center items-end",
                    name: slide.name
                  }, {
                    default: withCtx(() => [
                      createBaseVNode("div", _hoisted_7, [
                        slide.icon ? (openBlock(), createBlock(_component_velo_icon, {
                          key: 0,
                          name: slide.icon
                        }, null, 8, ["name"])) : createCommentVNode("", true),
                        createBaseVNode("div", _hoisted_8, toDisplayString(slide.text), 1)
                      ])
                    ]),
                    _: 2
                  }, 1032, ["name"]);
                }), 256))
              ]),
              _: 1
            }, 8, ["modelValue", "navigation"])
          ])
        ])
      ]),
      createBaseVNode("div", _hoisted_9, [
        renderSlot(_ctx.$slots, "default", {}, void 0, true)
      ])
    ]),
    _: 3
  })) : createCommentVNode("", true);
}
var Page_vue_vue_type_style_index_0_scoped_true_lang = "";
const _sfc_main = defineComponent({
  name: "AuthPage",
  components: {
    LanguageSelect
  },
  props: {
    cardTitle: {
      type: String,
      required: false,
      default: ""
    },
    slides: {
      type: Array,
      required: false,
      default: () => []
    }
  },
  setup(props) {
    const slide = ref(props.slides.length ? props.slides[0].name : "");
    const authStore = useAuthStore();
    const showShortcut = authStore.is("elevated");
    const ready = ref(false);
    onMounted(() => {
      ready.value = true;
    });
    return {
      slide,
      showShortcut,
      ready
    };
  }
});
var AuthPage = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", render], ["__scopeId", "data-v-2c7f9f5a"], ["__file", "Page.vue"]]);
export { AuthPage as A };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Page.f4998049.js","sources":["../../../../node_modules/quasar/src/components/carousel/QCarouselSlide.js","../../../../node_modules/quasar/src/components/carousel/QCarousel.js","../../../../src/components/auth/Page.vue"],"sourcesContent":["import { h, computed } from 'vue'\n\nimport { createComponent } from '../../utils/private.create/create.js'\nimport { usePanelChildProps } from '../../composables/private.use-panel/use-panel.js'\n\nimport { hSlot } from '../../utils/private.render/render.js'\n\nexport default createComponent({\n  name: 'QCarouselSlide',\n\n  props: {\n    ...usePanelChildProps,\n    imgSrc: String\n  },\n\n  setup (props, { slots }) {\n    const style = computed(() => (\n      props.imgSrc\n        ? { backgroundImage: `url(\"${ props.imgSrc }\")` }\n        : {}\n    ))\n\n    return () => h('div', {\n      class: 'q-carousel__slide',\n      style: style.value\n    }, hSlot(slots.default))\n  }\n})\n","import { h, computed, watch, onMounted, onBeforeUnmount, getCurrentInstance } from 'vue'\n\nimport QBtn from '../btn/QBtn.js'\n\nimport useDark, { useDarkProps } from '../../composables/private.use-dark/use-dark.js'\nimport usePanel, { usePanelProps, usePanelEmits } from '../../composables/private.use-panel/use-panel.js'\nimport useFullscreen, { useFullscreenProps, useFullscreenEmits } from '../../composables/private.use-fullscreen/use-fullscreen.js'\n\nimport { createComponent } from '../../utils/private.create/create.js'\nimport { isNumber } from '../../utils/is/is.js'\nimport { hMergeSlot, hDir } from '../../utils/private.render/render.js'\n\nconst navigationPositionOptions = [ 'top', 'right', 'bottom', 'left' ]\nconst controlTypeOptions = [ 'regular', 'flat', 'outline', 'push', 'unelevated' ]\n\nexport default createComponent({\n  name: 'QCarousel',\n\n  props: {\n    ...useDarkProps,\n    ...usePanelProps,\n    ...useFullscreenProps,\n\n    transitionPrev: { // usePanelParentProps override\n      type: String,\n      default: 'fade'\n    },\n    transitionNext: { // usePanelParentProps override\n      type: String,\n      default: 'fade'\n    },\n\n    height: String,\n    padding: Boolean,\n\n    controlColor: String,\n    controlTextColor: String,\n    controlType: {\n      type: String,\n      validator: v => controlTypeOptions.includes(v),\n      default: 'flat'\n    },\n\n    autoplay: [ Number, Boolean ],\n\n    arrows: Boolean,\n    prevIcon: String,\n    nextIcon: String,\n\n    navigation: Boolean,\n    navigationPosition: {\n      type: String,\n      validator: v => navigationPositionOptions.includes(v)\n    },\n    navigationIcon: String,\n    navigationActiveIcon: String,\n\n    thumbnails: Boolean\n  },\n\n  emits: [\n    ...useFullscreenEmits,\n    ...usePanelEmits\n  ],\n\n  setup (props, { slots }) {\n    const { proxy: { $q } } = getCurrentInstance()\n\n    const isDark = useDark(props, $q)\n\n    let timer = null, panelsLen\n\n    const {\n      updatePanelsList, getPanelContent,\n      panelDirectives, goToPanel,\n      previousPanel, nextPanel, getEnabledPanels,\n      panelIndex\n    } = usePanel()\n\n    const { inFullscreen } = useFullscreen()\n\n    const style = computed(() => (\n      inFullscreen.value !== true && props.height !== void 0\n        ? { height: props.height }\n        : {}\n    ))\n\n    const direction = computed(() => (props.vertical === true ? 'vertical' : 'horizontal'))\n\n    const navigationPosition = computed(() => props.navigationPosition\n      || (props.vertical === true ? 'right' : 'bottom')\n    )\n\n    const classes = computed(() =>\n      `q-carousel q-panel-parent q-carousel--with${ props.padding === true ? '' : 'out' }-padding`\n      + (inFullscreen.value === true ? ' fullscreen' : '')\n      + (isDark.value === true ? ' q-carousel--dark q-dark' : '')\n      + (props.arrows === true ? ` q-carousel--arrows-${ direction.value }` : '')\n      + (props.navigation === true ? ` q-carousel--navigation-${ navigationPosition.value }` : '')\n    )\n\n    const arrowIcons = computed(() => {\n      const ico = [\n        props.prevIcon || $q.iconSet.carousel[ props.vertical === true ? 'up' : 'left' ],\n        props.nextIcon || $q.iconSet.carousel[ props.vertical === true ? 'down' : 'right' ]\n      ]\n\n      return props.vertical === false && $q.lang.rtl === true\n        ? ico.reverse()\n        : ico\n    })\n\n    const navIcon = computed(() => props.navigationIcon || $q.iconSet.carousel.navigationIcon)\n    const navActiveIcon = computed(() => props.navigationActiveIcon || navIcon.value)\n\n    const controlProps = computed(() => ({\n      color: props.controlColor,\n      textColor: props.controlTextColor,\n      round: true,\n      [ props.controlType ]: true,\n      dense: true\n    }))\n\n    watch(() => props.modelValue, () => {\n      if (props.autoplay) {\n        startTimer()\n      }\n    })\n\n    watch(() => props.autoplay, val => {\n      if (val) {\n        startTimer()\n      }\n      else if (timer !== null) {\n        clearTimeout(timer)\n        timer = null\n      }\n    })\n\n    function startTimer () {\n      const duration = isNumber(props.autoplay) === true\n        ? Math.abs(props.autoplay)\n        : 5000\n\n      timer !== null && clearTimeout(timer)\n      timer = setTimeout(() => {\n        timer = null\n\n        if (duration >= 0) {\n          nextPanel()\n        }\n        else {\n          previousPanel()\n        }\n      }, duration)\n    }\n\n    onMounted(() => {\n      props.autoplay && startTimer()\n    })\n\n    onBeforeUnmount(() => {\n      timer !== null && clearTimeout(timer)\n    })\n\n    function getNavigationContainer (type, mapping) {\n      return h('div', {\n        class: 'q-carousel__control q-carousel__navigation no-wrap absolute flex'\n          + ` q-carousel__navigation--${ type } q-carousel__navigation--${ navigationPosition.value }`\n          + (props.controlColor !== void 0 ? ` text-${ props.controlColor }` : '')\n      }, [\n        h('div', {\n          class: 'q-carousel__navigation-inner flex flex-center no-wrap'\n        }, getEnabledPanels().map(mapping))\n      ])\n    }\n\n    function getContent () {\n      const node = []\n\n      if (props.navigation === true) {\n        const fn = slots[ 'navigation-icon' ] !== void 0\n          ? slots[ 'navigation-icon' ]\n          : opts => h(QBtn, {\n            key: 'nav' + opts.name,\n            class: `q-carousel__navigation-icon q-carousel__navigation-icon--${ opts.active === true ? '' : 'in' }active`,\n            ...opts.btnProps,\n            onClick: opts.onClick\n          })\n\n        const maxIndex = panelsLen - 1\n        node.push(\n          getNavigationContainer('buttons', (panel, index) => {\n            const name = panel.props.name\n            const active = panelIndex.value === index\n\n            return fn({\n              index,\n              maxIndex,\n              name,\n              active,\n              btnProps: {\n                icon: active === true ? navActiveIcon.value : navIcon.value,\n                size: 'sm',\n                ...controlProps.value\n              },\n              onClick: () => { goToPanel(name) }\n            })\n          })\n        )\n      }\n      else if (props.thumbnails === true) {\n        const color = props.controlColor !== void 0\n          ? ` text-${ props.controlColor }`\n          : ''\n\n        node.push(getNavigationContainer('thumbnails', panel => {\n          const slide = panel.props\n\n          return h('img', {\n            key: 'tmb#' + slide.name,\n            class: `q-carousel__thumbnail q-carousel__thumbnail--${ slide.name === props.modelValue ? '' : 'in' }active` + color,\n            src: slide.imgSrc || slide[ 'img-src' ],\n            onClick: () => { goToPanel(slide.name) }\n          })\n        }))\n      }\n\n      if (props.arrows === true && panelIndex.value >= 0) {\n        if (props.infinite === true || panelIndex.value > 0) {\n          node.push(\n            h('div', {\n              key: 'prev',\n              class: `q-carousel__control q-carousel__arrow q-carousel__prev-arrow q-carousel__prev-arrow--${ direction.value } absolute flex flex-center`\n            }, [\n              h(QBtn, {\n                icon: arrowIcons.value[ 0 ],\n                ...controlProps.value,\n                onClick: previousPanel\n              })\n            ])\n          )\n        }\n\n        if (props.infinite === true || panelIndex.value < panelsLen - 1) {\n          node.push(\n            h('div', {\n              key: 'next',\n              class: 'q-carousel__control q-carousel__arrow q-carousel__next-arrow'\n                + ` q-carousel__next-arrow--${ direction.value } absolute flex flex-center`\n            }, [\n              h(QBtn, {\n                icon: arrowIcons.value[ 1 ],\n                ...controlProps.value,\n                onClick: nextPanel\n              })\n            ])\n          )\n        }\n      }\n\n      return hMergeSlot(slots.control, node)\n    }\n\n    return () => {\n      panelsLen = updatePanelsList(slots)\n\n      return h('div', {\n        class: classes.value,\n        style: style.value\n      }, [\n        hDir(\n          'div',\n          { class: 'q-carousel__slides-container' },\n          getPanelContent(),\n          'sl-cont',\n          props.swipeable,\n          () => panelDirectives.value\n        )\n      ].concat(getContent()))\n    }\n  }\n})\n","<template lang=\"pug\">\nq-page.auth-page.fit.row.q-pa-md(v-if=\"ready\")\n  .absolute-bottom-right.q-pb-md.q-px-lg\n    language-select\n  .auth-card-wrap.col-12.col-md-6\n    .auth-card.relative-position.fit.column.justify-between.items-stretch.bg-primaryBlue.text-white.q-pa-xl\n      .full-width.col\n        velo-icon(\n          name=\"velo\"\n          color=\"white\"\n          size=\"90px\"\n        )\n      .full-width.col.auth-card-title.flex.items-center {{ cardTitle }}\n      .full-width.col.flex.justify-center.items-end\n        q-btn.absolute-bottom-right.bg-green.text-white.text-bold.q-ma-lg(\n          no-caps\n          v-if=\"showShortcut\"\n          :to=\"{ name: 'admin.stats' }\"\n        ) {{ $t('admin.nav.stats') }}\n        q-carousel.bg-primaryBlue.text-white(\n          v-model=\"slide\"\n          transition-prev=\"scale\"\n          transition-next=\"scale\"\n          swipeable\n          animated\n          control-color=\"white\"\n          :navigation=\"slides.length > 1\"\n          padding\n          height=\"10em\"\n        )\n          q-carousel-slide.flex.justify-center.items-end(\n            v-for=\"slide in slides\"\n            :name=\"slide.name\"\n          )\n            .flex.flex-center\n              velo-icon(\n                v-if=\"slide.icon\"\n                :name=\"slide.icon\"\n              )\n              .q-mt-md.text-center {{ slide.text }}\n  .auth-page-content-wrap.col.col-md-6.flex.flex-center\n    slot\n</template>\n<script>\nimport { defineComponent, ref, onMounted } from 'vue'\nimport LanguageSelect from 'src/components/layout/LanguageSelect.vue'\nimport { useAuthStore } from 'src/stores/auth'\nexport default defineComponent({\n  name: 'AuthPage',\n\n  components: {\n    LanguageSelect\n  },\n\n  props: {\n    cardTitle: {\n      type: String,\n      required: false,\n      default: ''\n    },\n    slides: {\n      type: Array,\n      required: false,\n      default: () => []\n    }\n  },\n\n  setup (props) {\n    const slide = ref(props.slides.length ? props.slides[0].name : '')\n    const authStore = useAuthStore()\n    const showShortcut = authStore.is('elevated')\n    const ready = ref(false)\n\n    onMounted(() => {\n      // prevent ssr\n      ready.value = true\n    })\n\n    return {\n      slide,\n      showShortcut,\n      ready\n    }\n  }\n})\n</script>\n<style lang=\"sass\" scoped>\n.auth-card\n  border-radius: 8px\n.auth-card-title\n  font-size: 28px\n@media screen and (max-width: $breakpoint-sm-max)\n  .auth-page\n    flex-direction: column-reverse\n  .auth-page-content-wrap\n    flex: 10000 1 0%\n@media screen and (min-width: $breakpoint-md-min)\n  .auth-card-wrap\n    padding-right: 48px\n</style>\n"],"names":[],"mappings":"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"}
