/** THEMES **/
:root {
  color-scheme: light;
  --color-scheme: light;

  --cl-card: #fdfeff;
  --cl-card-border: #eaebec;

  --cl-body-bg: #fff;
  --cl-body-color: #444;
  --wrap-content-dash: #f5f7f9;

  --base-color: #f9fafe;
  --accent-color: #3cb8a9;
  --accent-color2: #1ae6b3;
  --accent-hue: #358;
  --accent-hue2: #679;

  --nav-float-bg: rgba(248, 250, 255, .9);
  --nav-item-hover: #eceffc;
  --nav-item-active: #005588;

  --logo-color: #565e77;
  --logo-color2: #3cb8a9;

  --cl-text-header: #565e77;
  --cl-text-weight-600: #757f99;
  --cl-text-weight-darkest: #2f3546;
  --cl-ins: #356fbb;

  /* dash main menu */
  --dash-mm-bold: #66686c;
  --dash-mm-bold-c: #88949f;
  --dash-mm-bold-hover: #eceffc;
  --dash-mm-bold-active: #eceffc;
  --dash-mm-hover: #eceffc;
  --dash-mm-hover-color: #444649;
  --dash-mm-active-color: #444649;

  /* components */
  --cl-popup-win: #fff;
  --cl-popup-list-border: #f0f5f9;
  --cl-popup-list-hover: #e0e6ee;
  --cl-popup-list-active: #eef5ff;
  --cl-popup-list-hover-text: #454f69;

  /* input */
  --input-lookup: #fff;
  --input-lookup-border: #e5e9ef;
  --input-lookup-active: #eef4f8;
  --input-bg: #fdfdff;
  --input-bg-dim: #f7f8f9;
  --input-bg-disabled: #eef4f8;
  --input-focus: #fff;
  --input-text: #69728a;
  --input-text-focus: #606a83;
  --input-placeholder: #a0aab5;
  --input-border: #dbe3f3;
  --input-border-disabled: #aaacaf;
  --input-editor-tollbar: #f8fbff;

  /* contents */
  --content-text: #69728a;

  /* buttons */
  --button-bg: #3876c7;
  --button-bg-hover: #356fbb;
  --button-bg-active: #225597;
  --button-text: #fff;

  /* white button */
  --button-white-bg: #fff;
  --button-white-border: #ddd;
  --button-white-border-hover: #bbb;
  --button-white-border-active: #aaa;
  --button-white-text: #777;
  --button-white-text-active: #555;

  /* tabling */
  --tbl-th-border: #e0e2e6;
  --tbl-th-color: #66686c;
  --tbl-th-active: rgba(255, 255, 255, .8);
  --tbl-td: #fcfeff;
  --tbl-td-hover: #f5f8ff;
  --tbl-color: #88949f;

  /* footer */
  --cl-foot-wrap: #2f3546;
  --cl-foot-wrap-header: #6a7486;
  --cl-foot-wrap-color: #abb3c4;
  --cl-foot-wrap-link: #c4cad6;
  --cl-foot-wrap-hover: #fff;
  --cl-foot-end: #292f3d;
  --cl-foot-end-color: #a3abb8;
}

/** DARK-MODE **/
@media screen {
  .dark-mode {
    color-scheme: dark;
    --color-scheme: dark;

    --cl-card: #18191a;
    --cl-card-border: #242526;

    --cl-body-bg: #141516;
    --cl-body-color: #ddd;
    --wrap-content-dash: #141516;

    --base-color: #16181a;
    --accent-color: #3cb8a9;
    --accent-color2: #1ae6b3;
    --accent-hue: #7ae;
    --accent-hue2: #8ac;

    --nav-float-bg: rgba(48, 50, 55, .9);
    --nav-item-active: #fff;
    --nav-item-hover: #1c1f2c;
    --cl-ins: #659feb;

    --logo-color: #a6aec7;
    --logo-color2: #3cb8a9;

    --cl-text-header: #a6aec7;
    --cl-text-weight-600: #a5afc9;
    --cl-text-weight-darkest: #bfc5d6;

    /* dash main menu */
    --dash-mm-bold: #66686c;
    --dash-mm-bold-c: #88949f;
    --dash-mm-bold-hover: #020508;
    --dash-mm-bold-active: #191b1d;
    --dash-mm-hover: #101213;
    --dash-mm-hover-color: #aaccdd;
    --dash-mm-active-color: #ccddee;

    /* components */
    --cl-popup-win: #202325;
    --cl-popup-list-border: #2b2d2f;
    --cl-popup-list-hover: #20262e;
    --cl-popup-list-active: #2e353f;
    --cl-popup-list-hover-text: #a5afc9;

    /* input */
    --input-lookup: #101015;
    --input-lookup-border: #1b1c1d;
    --input-lookup-active: #fff;
    --input-bg: #151518;
    --input-bg-dim: #181a1c;
    --input-bg-disabled: #1a1c1e;
    --input-focus: #0d0d0f;
    --input-text: #c9d2ea;
    --input-text-focus: #d9e2fa;
    --input-placeholder: #707a85;
    --input-border: #2b2e31;
    --input-border-disabled: #2c2c2c;
    --input-editor-tollbar: #1a1c1e;

    /* white button */
    --button-white-bg: #1a1c1e;
    --button-white-border: #101315;
    --button-white-border-hover: #202d36;
    --button-white-border-active: #00050f;
    --button-white-text: #aaa;
    --button-white-text-active: #ddd;

    /* contents */
    --content-text: #99a2ba;

    /* tabling */
    --tbl-th-border: #101216;
    --tbl-th-color: #96989c;
    --tbl-th-active: rgba(0, 0, 0, .4);
    --tbl-td: #1a1b1c;
    --tbl-td-hover: #0a0b0c;
    --tbl-color: #88949f;

    /* footer */
    --cl-foot-wrap: #1c2029;
    --cl-foot-wrap-header: #6a7486;
    --cl-foot-wrap-color: #abb3c4;
    --cl-foot-wrap-link: #c4cad6;
    --cl-foot-wrap-hover: #fff;
    --cl-foot-end: #181d23;
    --cl-foot-end-color: #a3abb8;
  }
}

body,
html {
  margin: 0;
  padding: 0;
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-size: 14px;
  font-weight: normal;
  background: var(--cl-body-bg) !important;
  scroll-behavior: smooth;
  cursor: default;
  color: var(--cl-body-color);
}

html.on-app .app-hide {
  display: none !important;
}

html:not(.on-app) .app-only {
  display: none !important;
}

@media screen {
  body>article#print_content {
    display: none;
  }

  body.printing>article#print_content {
    display: block;
    position: absolute;
    pointer-events: none;
    user-select: none;
    top: 0;
    left: 0;
    width: 1000px;
    height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
  }
}

@media screen and (min-width: 1211px) {
  .mobile-only {
    display: none !important;
  }
}

a {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

.playstore-link img {
  margin-top: 8px;
  width: 170px;
  height: 50px;
}

.contents a:not(.button):visited,
.contents a:not(.button) {
  color: var(--accent-color);
  text-decoration: none;
}

.contents a:not(.button):hover {
  color: var(--button-bg-active);
}

* {
  -webkit-tap-highlight-color: transparent !important;
  outline: none;
}

*:not(textarea):not(input) {
  user-select: none;
}

form,
h1,
h2,
h3,
h4 {
  margin: 0;
}

.text[type="datetime-local"]:before,
.text[type="date"]:before,
.dash-data-view:not(.error):empty:before,
.fa,
.cbefore::before,
.cafter::after,
.c,
c {
  font-family: 'Material Symbols Outlined' !important;
  font-weight: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  vertical-align: middle;
  -webkit-font-feature-settings: 'liga';
  font-feature-settings: liga;
  font-variation-settings:
    'FILL' 0,
    'wght' 400,
    'GRAD' 0,
    'opsz' 24;
}

c.thin {
  font-variation-settings:
    'FILL' 0,
    'wght' 200,
    'GRAD' 0,
    'opsz' 24;
}

c.bold {
  font-weight: 800;
  font-variation-settings:
    'FILL' 0,
    'wght' 800,
    'GRAD' 200,
    'opsz' 24;
}

@keyframes loader_keyframe {
  0% {
    transform: rotate(0deg)
  }

  100% {
    transform: rotate(360deg)
  }
}

.dash-data-view:not(.error):empty:before,
c.loader:empty::before {
  content: '\e9d0';
}

c.loader {
  animation: loader_keyframe 1.5s linear infinite;
}

.dash-data-view:not(.error):empty:before,
c.medium.loader {
  animation: loader_keyframe 1.5s linear infinite;
  font-size: 32px;
}

c.big.loader {
  font-size: 64px;
  font-variation-settings:
    'FILL' 0,
    'wght' 200,
    'GRAD' 0,
    'opsz' 24;
}

/* Template Sizing */
.wrap-main {
  max-width: 1190px;
  margin: auto;
}

.wrap-content {
  padding-top: 65px;
  min-height: calc(80vh - 53px);
  box-sizing: border-box;
}

.wrap-footer {
  background-color: var(--cl-foot-wrap);
  padding: 30px 0 0 0;
  min-height: 20vh;
  box-sizing: border-box;
}

.wrap-footer-end {
  background-color: var(--cl-foot-end);
  color: var(--cl-foot-end-color);
  padding: 18px 0;
  font-size: 14px;
}

.footer-row {
  padding-bottom: 15px;
}

.footer-menu {
  display: block;
  padding-bottom: 15px;
  box-sizing: border-box;
  position: relative;
}

.footer-links {
  display: inline-block;
  width: 25%;
  min-width: 240px;
  box-sizing: border-box;
  vertical-align: top;
  padding-bottom: 15px;
}


.footer-links h2 {
  color: var(--cl-foot-wrap-header);
  text-transform: uppercase;
  font-size: 14px;
  font-family: "Inter", sans-serif;
  font-weight: 700;
  padding: 5px 0 8px 0;
}

.footer-links div,
.footer-links a {
  display: block;
  line-height: 28px;
  color: var(--cl-foot-wrap-link);
}

.footer-links div {
  color: var(--cl-foot-wrap-color);
  font-weight: 600;
}

.footer-links a:hover {
  color: var(--cl-foot-wrap-hover);
}

.footer-links div {
  padding-left: 28px;
}

.footer-links div c {
  margin-left: -28px;
  width: 28px;
}

.footer-logo {
  text-decoration: none;
  color: var(--cl-foot-wrap-hover);
  font-size: 16px;
  font-weight: 400;
  text-transform: uppercase;
  font-family: "Inter Tight", sans-serif;
}

.footer-logo b {
  font-weight: 700;
}

.footer-logo img {
  width: 32px;
  height: 32px;
  border: none;
  vertical-align: middle;
  margin-right: 8px;
}

.footer-mask {
  display: none;
}

/* Popup */
.popup-holder {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  background-color: rgba(0, 0, 0, .5);
  box-sizing: border-box;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 999999;
  visibility: hidden;
  opacity: 0;
  transition: all 0.3s cubic-bezier(.25, .8, .25, 1);
}

.body-show-popup .popup-holder {
  visibility: visible;
  opacity: 1;
}

.popup-win {
  border-radius: 4px;
  background-color: var(--cl-popup-win);
  box-sizing: border-box;
  max-width: 96vw;
  max-height: 96vh;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);
  color: var(--cl-text-weight-600);
}

.popup-header {
  font-size: 20px;
  font-weight: 600;
  padding: 30px 20px 10px 20px;
  color: var(--cl-text-weight-darkest);
}

.popup-tools {
  padding: 10px 20px 20px 20px;
  text-align: right;
}

.popup-tools button {
  border-radius: 30px;
  padding: 6px 15px 6px 15px;
  /* min-width: 80px; */
  margin-left: 4px;
}

.popup-tools button.left {
  float: left;
  margin-right: 4px;
  margin-left: 0;
}

.popup-content {
  font-size: 16px;
}

.popup-content.message {
  padding: 20px;
  width: 90vw;
  max-width: 600px;
  line-height: 1.5;
  box-sizing: border-box;
}

.popup-content.dialog,
.popup-content.list {
  border-top: 1px solid var(--cl-popup-list-border);
  border-bottom: 1px solid var(--cl-popup-list-border);
  max-height: calc(94vh - 150px);
  overflow-y: auto;
  position: relative;
}

.popup-content:last-child {
  border-bottom: none !important;
}

.popup-content.list {
  width: 90vw;
  max-width: 500px;
}

.popup-content .popup-list {
  padding: 15px 20px 15px 50px;
  border-bottom: 1px solid var(--cl-popup-list-border);
  cursor: pointer;
  position: relative;
  font-size: 16px;
}

.popup-list-title>ins {
  text-decoration: none;
  color: var(--cl-ins);
  display: block;
}

.popup-content .popup-list:last-child {
  border-bottom: none;
}

.popup-content .popup-list>c {
  position: absolute;
  margin-left: -30px;
  font-size: 20px;
}

.popup-content .popup-list.active>c {
  color: var(--accent-color);
}

.popup-content .popup-list:hover {
  background-color: var(--cl-popup-list-hover);
  color: var(--cl-popup-list-hover-text);
}

.popup-content .popup-list:active {
  background-color: var(--cl-popup-list-active);
  color: var(--cl-popup-list-hover-text);
}


/* Template */
.topnav {
  position: fixed;
  box-shadow: rgba(1, 20, 82, 0.2) 0px 0px 7px 0px;
  background-color: var(--base-color);
  box-sizing: border-box;
  height: 65px;
  left: 0;
  right: 0;
  z-index: 99999;
  border-bottom: 1px solid var(--input-border);
}

.topnav .wrap-header {
  position: relative;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.topnav .wrap-main {
  display: flex;
  align-items: center;
  box-sizing: border-box;
  height: 65px;
}

.topnav .topnav-items {
  display: inline-block;
  vertical-align: middle;
}

.topnav .topnav-logo {
  padding-right: 15px;
}

.topnav .topnav-logo img {
  width: 48px;
  height: 48px;
  border: none;
  vertical-align: middle;
}

.topnav .topnav-logo span {
  padding-left: 5px;
  vertical-align: middle;
  display: inline-block;
  font-size: 14px;
  font-weight: 400;
  font-family: "Inter Tight", sans-serif;
  color: var(--logo-color);
}

.topnav .topnav-logo span b {
  font-weight: 700;
  color: var(--logo-color2);
}

.topnav a.topnav-menu-item {
  display: inline-block;
  vertical-align: middle;
  padding: 0 15px;
  line-height: 40px;
  text-decoration: none;
  box-sizing: border-box;
  color: var(--cl-text-weight-600);
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
}

.topnav a.topnav-menu-item:hover {
  background-color: var(--nav-item-hover);
}

.topnav .topnav-account {
  margin-left: auto;
}

.topnav .topnav-account .switch-dark-mode {
  display: inline-block;
  font-size: 16px;
  margin-right: 15px;
  border-radius: 50px;
  width: 50px;
  background-color: var(--input-border);
  padding: 2px;
  position: relative;
  cursor: pointer;
  color: var(--button-text);
  overflow: hidden;
}

.topnav .topnav-account .switch-dark-mode::before {
  content: '\e518';
  display: inline-block;
  background-color: var(--input-text-focus);
  border-radius: 50px;
  padding: 4px;
  margin-left: 0;
  transition: all 0.3s cubic-bezier(.25, .8, .25, 1);
  transform: rotate(-90deg);
}

.dark-mode .topnav .topnav-account .switch-dark-mode::before {
  content: '\e51c';
  background-color: var(--button-bg);
  margin-left: 25px;
  transform: rotate(0deg);
}

.topnav .topnav-account a.topnav-menu-item {
  background-color: var(--button-bg);
  color: var(--button-text);
}

.topnav .topnav-account a.topnav-menu-item:hover {
  background-color: var(--cl-ins);
}

.topnav .topnav-account a.topnav-menu-item.pp {
  background-color: transparent;
  width: 54px;
  height: 54px;
  border-radius: 27px;
  padding: 3px;
}

.topnav .topnav-account a.topnav-menu-item.pp img {
  width: 48px;
  height: 48px;
  border-radius: 24px;
}

.topnav .topnav-account a.topnav-menu-item.pp:hover {
  background-color: var(--accent-color2);
}

.topnav .topnav-menu-wrapper a.topnav-menu-item>c {
  display: none;
}

.topnav a.topnav-menu-item.active {
  color: var(--nav-item-active);
  background-color: transparent;
}

/* MODULES */
.welcome {
  background-color: #4e92d6;
  background-image: linear-gradient(-225deg, #473B7B 0%, #3584A7 51%, #3cb8a9 100%);
}

.dark-mode .welcome {
  background-color: #1e7236;
  background-image: linear-gradient(-225deg, #170B3B 0%, #055477 51%, #005849 100%);
}

.welcome-wrapper {
  background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 320"><path fill="%23273036" fill-opacity="0.07" d="M0,256L60,261.3C120,267,240,277,360,250.7C480,224,600,160,720,160C840,160,960,224,1080,245.3C1200,267,1320,245,1380,234.7L1440,224L1440,320L1380,320C1320,320,1200,320,1080,320C960,320,840,320,720,320C600,320,480,320,360,320C240,320,120,320,60,320L0,320Z"></path></svg>');
  background-size: cover;
  background-position: right bottom;
  background-repeat: no-repeat;
}

.welcome .welcome-wrapper {
  min-height: 500px;
  display: flex;
  align-items: stretch;
}

.welcome .welcome-wrapper .welcome-content {
  display: flex;
  flex-flow: column;
  justify-content: center;
  padding: 25px 10px 25px 10px;
  color: #fff;
  width: 100%;
}

.welcome .welcome-wrapper .welcome-content h1 {
  font-family: "Inter", sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: #dbe3f3;
  padding-bottom: 20px;
  text-shadow: 0 0 10px rgba(0, 0, 0, .05)
}

.welcome .welcome-wrapper .welcome-content h1 span {
  font-weight: inherit;
  font-size: inherit;
  font-family: inherit;
  color: var(--accent-color2);
}

.welcome .welcome-wrapper .welcome-content h2 {
  color: #fff;
  font-size: 48px;
  text-shadow: 0 0 10px rgba(0, 0, 0, .05);
  padding: 5px 0 20px 0;
  margin: 0;
}

.welcome .welcome-wrapper .welcome-content p {
  max-width: 600px;
  width: 100%;
  color: #dbe3f3;
  line-height: 28px;
  font-weight: 300;
}

.welcome .welcome-wrapper .welcome-content .btns {
  padding-top: 20px
}

.welcome .welcome-wrapper .welcome-content .btns .btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  color: #fff;
  background-color: #233044;
  padding: 20px 25px;
  border-radius: 30px;
  font-size: 14px;
  font-weight: 500;
  box-shadow: 0 0 10px rgba(0, 0, 0, .1);
  margin: 0 15px 15px 0
}

.welcome .welcome-wrapper .welcome-content .btns .btn c {
  padding-left: 20px;
  color: #6b7d97;
  font-size: 18px;
}

.welcome .welcome-wrapper .welcome-content .btns .btn:hover {
  background-color: #1e293a
}

.welcome .welcome-wrapper .welcome-content .btns .btn.alt {
  background-color: rgba(0, 0, 0, 0);
  box-shadow: inset 0 0 0 2px #739ab4;
  color: #dbe3f3
}

.welcome .welcome-wrapper .welcome-content .btns .btn.alt c {
  color: #739ab4
}

.welcome .welcome-wrapper .welcome-content .btns .btn.alt:hover {
  box-shadow: inset 0 0 0 2px #fff;
  color: #fff
}

.welcome .welcome-wrapper .welcome-content .btns .btn:hover c {
  color: #fff
}

.welcome .welcome-wrapper .welcome-content .btns .btn:last-child {
  margin-right: 0
}

.explore {
  background-color: #2c3342;
  margin-bottom: 10px
}

.explore.nogap {
  margin-bottom: 0;
}

.dark-mode .explore {
  background-color: #1c2029;
}

.explore .explore-wrapper {
  color: #fff;
  position: relative;
  display: flex;
  flex-wrap: wrap;
}

.explore .explorer-title,
.explore .explorer-items {
  display: flex;
  flex-wrap: wrap;
  text-decoration: none;
  color: #d6d8da;
  box-sizing: border-box;
}

.explore .explorer-items {
  width: 25%;
  min-width: 240px;
  padding: 40px 10px 40px 20px;
  flex: 1 1 auto;
}

.explore .explorer-title {
  padding: 20px 10px;
}

.explore a:hover {
  background-color: rgba(0, 0, 0, .1)
}

.explore .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #3a67c2;
  border-radius: 50px;
  font-size: 24px;
  width: 70px;
  height: 70px;
  margin-right: 20px;
  color: #fff
}

.explore .explorer-title .icon {
  background-color: transparent;
  height: auto;
  width: auto;
}

.explore .icon c {
  fill: #fff;
  font-size: 36px;
}

.explore h2 {
  color: #fff;
  font-size: 22px;
  margin-top: 8px;
  padding-bottom: 6px
}

.explore .slogan {
  font-size: 13px;
  font-weight: 500;
  color: #8992a5;
  padding: 0
}

.explore p {
  margin: 0;
  margin-top: 0;
  font-size: 14px;
  line-height: 22px;
  color: #c1c6d4
}

/* contents */
.contents {
  color: var(--content-text);
  font-size: 16px;
}

.wrap-main hr,
.contents hr {
  border: none;
  border-bottom: 1px dotted var(--cl-popup-list-border);
}

.contents h1,
.contents h2,
.contents h4,
.contents h3 {
  font-family: "Inter Tight", sans-serif;
  font-weight: 600;
  padding: 0;
  line-height: 1.4;
  color: var(--cl-text-header);
}

.contents h1 {
  font-size: 28px;
}

.contents h2 {
  font-size: 24px;
}

.contents h3 {
  font-size: 20px;
}

.contents h4 {
  font-size: 18px;
}


/* boxes */
.box {
  display: flex;
  position: relative;
  flex-wrap: wrap;
}

.box-quarter {
  box-sizing: border-box;
  flex: 1 1 auto;
  width: 220px;
}

.box-half {
  box-sizing: border-box;
  flex: 1 1 auto;
  width: 480px;
}

.box-third {
  box-sizing: border-box;
  flex: 1 1 auto;
  width: 360px;
}

.box-34 {
  box-sizing: border-box;
  flex: 1 1 auto;
  width: 600px;
}

.box-half34 {
  box-sizing: border-box;
  flex: 1 1 auto;
  width: 320px;
}

/* FORM */
a.button,
.button,
button {
  color-scheme: var(--color-scheme);
  display: inline-block;
  vertical-align: middle;
  padding: 8px 15px;
  line-height: 1.5;
  box-sizing: border-box;
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
  background-color: var(--button-bg);
  color: var(--button-text);
  border: none;
  cursor: pointer;
  font-family: "Inter", sans-serif;
}

.button:disabled,
button:disabled {
  pointer-events: none;
  touch-action: none;
  opacity: .5;
}

.button.small,
button.small {
  padding: 6px 15px 6px 15px;
}

.button.round,
button.round {
  border-radius: 30px;
}

button c,
button img {
  vertical-align: middle;
  margin-right: 0;
  margin-top: -3px;
}

button c+span,
button img+span {
  margin-left: 5px;
}

a.button:hover,
.button:hover,
button:hover {
  background-color: var(--button-bg-hover);
}

a.button:active,
.button:active,
button:active {
  background-color: var(--button-bg-active);
}

button.white {
  background-color: var(--button-white-bg);
  border: 1px solid var(--button-white-border);
  color: var(--button-white-text);
}

button.white:hover {
  background-color: var(--button-white-bg);
  border: 1px solid var(--button-white-border-hover);
}

button.white:active {
  background-color: var(--button-white-bg);
  border: 1px solid var(--button-white-border-active);
  color: var(--button-white-text-active);
}


button.red {
  background-color: #811;
}

button.red:hover {
  background-color: #833;
}

button.red:active {
  background-color: #600;
}

button.green {
  background-color: #080;
}

button.green:hover {
  background-color: #282;
}

button.green:active {
  background-color: #060;
}

button.purple {
  background-color: #92a;
}

button.purple:hover {
  background-color: #a4b;
}

button.purple:active {
  background-color: #609;
}

button.notext c {
  margin-right: 0;
}

input.text,
textarea.text {
  color-scheme: var(--color-scheme);
  font-family: "Inter", sans-serif;
  display: inline-block;
  vertical-align: middle;
  padding: 8px 15px;
  line-height: 1.5;
  box-sizing: border-box;
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
  background-color: var(--input-bg);
  color: var(--input-text);
  border: 1px solid var(--input-border);
}

input.text:focus,
textarea.text:focus {
  color: var(--input-text-focus);
  background-color: var(--input-focus);
  border: 1px solid var(--accent-color);
}

input.text::placeholder,
textarea.text::placeholder {
  color: var(--input-placeholder);
  font-weight: 300;
}

/* toast */
#main_toast {
  position: fixed;
  z-index: 999999999;
  bottom: 50px;
  left: 0;
  right: 0;
  text-align: center;
  transition: all 0.3s cubic-bezier(.25, .8, .25, 1);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  touch-action: none;
}

#main_toast.active {
  opacity: 1;
  visibility: visible;
}

#main_toast div {
  display: inline-block;
  padding: 10px 30px 10px 30px;
  font-size: 16px;
  font-weight: 600;
  background-color: rgba(20, 20, 20, .9);
  line-height: 1.8;
  color: #fff;
  border-radius: 32px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
}

#main_toast div.green {
  background-color: rgba(10, 140, 10, .9);
}

#main_toast div.yellow {
  background-color: rgba(180, 180, 10, .9);
}

#main_toast div.red {
  background-color: rgba(140, 20, 20, .9);
}

/* maps */
.maps {
  position: relative;
  width: 100%;
  height: 200px;
  overflow: hidden;
  box-sizing: border-box;
}

.dark-mode .maps .ol-layer canvas {
  filter: invert(100%) hue-rotate(180deg);
}

.popup-content.dialog .maps {
  width: 90vw;
  max-width: 600px;
  max-height: 300px;
  height: calc(94vh - 150px);
}

.maps.medium,
.maps.full {
  border: 1px solid var(--input-border);
  border-radius: 10px;
}

.maps.noround {
  border-radius: 0 !important;
  border: none !important;
}

.maps.medium {
  height: 300px;
}

.maps.full {
  height: calc(100vh - 148px);
}

.maps .ol-rotate,
.maps .ol-attribution {
  display: none !important;
}

.maps .ol-gps-button {
  position: absolute;
  right: 15px;
  top: 15px;
}

.maps .ol-gps-button c {
  margin: 0 !important;
}

.maps .ol-control {
  width: 36px;
}

.maps button {
  padding: 0 !important;
  margin: 2px;
  text-align: center;
  line-height: 18px;
  width: 32px;
  height: 32px;
  border-radius: 32px;
  font-size: 20px;
  font-weight: 800;
  box-sizing: border-box;
}

.maps .ol-control {
  padding: 15px 0 0 15px;
}

/* charts */
.chart-container {
  padding: 0;
}

.chart-container-element {
  height: 600px;
  max-height: calc(96vh - 250px);
}

@media screen {
  .dark-mode .chart-container .chart-container-element {
    filter: invert(100%) hue-rotate(180deg);
  }
}

#print_content .chart-container-element {
  height: 600px !important;
  max-height: 600px !important;
}

.chart-title {
  text-align: center;
  padding: 15px 0 5px 0;
  color: var(--cl-text-weight-600);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.2;
}

.chart-title.morepadding {
  padding: 30px 0 20px 0;
}

.dialog-chart {
  box-sizing: border-box;
  max-width: 96vw;
  width: 1200px;
}

.dialog-chart-holder {
  padding: 0 10px 0 10px;
}

.tags {
  background: #456;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  padding: 2px 8px 2px 8px;
  line-height: 1;
  border-radius: 20px;
  white-space: nowrap;
}

/* MAPS POPUP */
.ol-popup {
  position: absolute;
  background-color: var(--base-color);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  padding: 18px 8px 8px 8px;
  border-radius: 10px;
  border: 1px solid var(--input-border);
  bottom: 40px;
  left: -131px;
  width: 260px;
  box-sizing: border-box;
  color: var(--input-text);
  pointer-events: none;
}

.ol-popup:after,
.ol-popup:before {
  top: 100%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}

.ol-popup:after {
  border-top-color: var(--base-color);
  border-width: 10px;
  left: 130px;
  margin-left: -10px;
}

.ol-popup:before {
  border-top-color: var(--input-border);
  border-width: 11px;
  left: 130px;
  margin-left: -11px;
}

.ol-popup-content {
  position: relative;
}

.ol-popup-closer {
  color: var(--accent-hue2);
  text-decoration: none;
  position: absolute;
  top: 4px;
  right: 4px;
  font-size: 22px;
  cursor: pointer;
  z-index: 10;
  pointer-events: all;
}

.ol-popup-content a.button {
  font-weight: 400;
  pointer-events: all;
}

.ol-popup-content a.button c {
  font-weight: 400;
  font-size: 22px;
  margin-top: -2px;
}

.ol-popup-closer:hover {
  color: var(--accent-color);
}

.ol-popup-closer:after {
  content: "\e5c9";
}

/* geo popup */
.geo-popup {
  text-align: center;
}

.geo-popup img {
  width: 128px;
  height: 128px;
  border-radius: 128px;
  display: block;
  margin: auto;
  margin-top: -70px;
  padding: 10px;
  background-color: var(--base-color);
}

.geo-popup .geo-popup-nama {
  display: block;
  font-size: 16px;
  font-weight: 600;
  color: var(--accent-hue);
  text-align: center;
  line-height: 1.2;
}

.geo-popup .geo-popup-umur,
.geo-popup .geo-popup-alamat {
  text-align: center;
  font-size: 12px;
  color: var(--input-text);
  line-height: 1.2;
}

.geo-popup .geo-popup-alamat {
  padding-bottom: 10px;
}

.geo-popup .geo-popup-umur {
  color: var(--accent-color);
  font-weight: 600;
}

.geo-popup .tags {
  display: inline-block;
  margin: 2px;
  line-height: 1.5;
  cursor: help;
  pointer-events: visible;
}

.geo-popup .tags c {
  margin-top: -2px;
}

/* modules */
.module-container {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}

.module-main {
  flex: 1 1 auto;
  padding: 30px 0 30px 0;
  max-width: 800px;
}

.module-side {
  flex: 1 1 auto;
  max-width: 800px;
  width: 360px;
  padding: 30px 0 30px 0;
}

.module-side-box {
  border: 1px solid var(--input-border);
  padding: 15px;
  border-radius: 6px;
  margin-bottom: 15px;
}

.module-side-box h4 {
  padding: 15px 0 15px 0;
  border-bottom: 1px solid var(--input-border);
}

/* news */
.info-list-title {
  border-bottom: 1px dashed var(--input-border);
  margin-bottom: 5px;
  box-sizing: border-box;
  min-height: 101px;
  color: var(--accent-hue);
  display: flex;
  align-items: center;
  padding-bottom: 10px;
}

.info-list-title h1 c {
  margin-top: -4px;
  margin-right: 15px;
}

.info-list-title span {
  color: var(--accent-hue2);
}

.info-list-title span c {
  font-weight: 800;
  margin-top: -2px;
  margin-right: 4px;
  color: var(--accent-color);
}

.news-list-empty {
  padding: 30px;
  text-align: center;
  color: var(--input-placeholder);
}

.news-list {
  border-bottom: 1px dashed var(--input-border);
  padding: 0;
  margin-bottom: 30px;
}

.news-list-side {
  padding: 15px 0 15px 0;
  border-bottom: 1px dashed var(--input-border);
}

.news-list-side a {
  font-size: 18px;
}

.news-list-side a.active {
  font-weight: 600;
  color: var(--accent-hue) !important;
}

.news-list-side:last-child,
.news-list:last-child {
  border-bottom: none;
}

.news-list-side span,
.news-list span {
  font-size: 13px;
  color: var(--input-placeholder);
  font-weight: 600;
}

.news-list p {
  padding: 4px 0 30px 0;
  line-height: 2;
}

.news-paging {
  padding: 30px 0 30px 0;
  text-align: center;
}

.news-paging:empty {
  display: none;
}

/* public chart */
.pubchart-summary {
  display: flex;
  flex-wrap: wrap;
  gap: -1px;
  justify-content: center;
  align-items: center;
  margin: 30px 0 30px 0;
  border: 1px solid var(--input-border);
}

.pubchart-summary div {
  flex: 1;
  width: 30%;
  padding: 30px;
  min-width: 180px;
  border: 1px solid var(--input-border);
  box-sizing: border-box;
  text-align: center;
  background-color: var(--input-bg);
}

.pubchart-summary div c {
  font-size: 40px;
  line-height: 64px;
  width: 64px;
  border-radius: 64px;
  background-color: var(--accent-hue2);
  color: #fff;
}

.pubchart-summary div span {
  display: block;
  line-height: 1;
  font-size: 14px;
  height: 30px;
  padding-top: 10px;
  overflow: hidden;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}

.pubchart-summary div b {
  display: block;
  font-size: 34px;
  color: var(--accent-color);
}


.pubchart-holder {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
  align-items: start;
}

.pubchart-holder .chart-title {
  padding: 4px 0 10px 0 !important;
  font-size: 16px;
}

.pubchart-holder .table-container,
.pubchart-holder .chart-container {
  flex: 1 1 auto;
  width: 500px;
  max-width: 100%;
}

.pubchart-holder .table-container {
  overflow: auto;
  position: relative;
}

.pubchart-holder .table-container.full,
.pubchart-holder .chart-container.full {
  width: 100%;
}

.pubchart-holder hr {
  border-bottom: 1px dotted var(--input-border);
}

.pubchart-holder .chart-container-element {
  height: 400px;
}

.pubchart-table table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--tbl-th-border);
  box-sizing: border-box;
  border-spacing: 0;
}

.pubchart-table td,
.pubchart-table th {
  text-align: left;
  font-size: 12px;
  padding: 8px 4px 8px 4px;
  border: none;
  border-bottom: 1px solid var(--tbl-th-border);
}

.pubchart-table td {
  background-color: var(--tbl-td);
}

.pubchart-table th {
  padding: 10px 4px 10px 4px;
  color: var(--tbl-th-color);
  background-color: var(--tbl-td-hover);
}

/* card */
.card {
  border-radius: 10px;
  padding: 15px;
  margin: 15px 0 15px 0;
  background-color: var(--cl-card);
  border: 1px solid var(--cl-card-border);
  box-sizing: border-box;
}

.card>.dash-edit {
  padding: 0;
}

.card>.news-list {
  padding: 0 15px 0 15px;
}

.card>.news-list:first-child {
  padding: 30px 15px 0 15px;
}

.card>.markdown-body {
  padding: 15px 0 15px 0;
}

@media screen and (min-width: 1211px) {
  .card>.markdown-body {
    padding: 15px 15px 15px 15px;
  }
}