/* https://andy-bell.co.uk/a-more-modern-css-reset/ */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Prevent font size inflation */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

/* Remove default margin in favour of better control in authored CSS */
body, h1, h2, h3, h4, p,
figure, blockquote, dl, dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  line-height: 1.5;
}

/* Set shorter line heights on headings and interactive elements */
h1, h2, h3, h4,
button, input, label {
  line-height: 1.1;
}

/* Balance text wrapping on headings */
h1, h2,
h3, h4 {
  text-wrap: balance;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input, button,
textarea, select {
  font: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */
textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */
:target {
  scroll-margin-block: 5ex;
}
/* nunito-cyrillic-ext-400-normal */
@font-face {
  font-family: 'Nunito';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/nunito-cyrillic-ext-400-normal.woff2) format('woff2'), url(/static/files/nunito-cyrillic-ext-400-normal.woff) format('woff');
  unicode-range: U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* nunito-cyrillic-400-normal */
@font-face {
  font-family: 'Nunito';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/nunito-cyrillic-400-normal.woff2) format('woff2'), url(/static/files/nunito-cyrillic-400-normal.woff) format('woff');
  unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}

/* nunito-vietnamese-400-normal */
@font-face {
  font-family: 'Nunito';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/nunito-vietnamese-400-normal.woff2) format('woff2'), url(/static/files/nunito-vietnamese-400-normal.woff) format('woff');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* nunito-latin-ext-400-normal */
@font-face {
  font-family: 'Nunito';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/nunito-latin-ext-400-normal.woff2) format('woff2'), url(/static/files/nunito-latin-ext-400-normal.woff) format('woff');
  unicode-range: U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* nunito-latin-400-normal */
@font-face {
  font-family: 'Nunito';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/nunito-latin-400-normal.woff2) format('woff2'), url(/static/files/nunito-latin-400-normal.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
/* poppins-devanagari-400-normal */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/poppins-devanagari-400-normal.woff2) format('woff2'), url(/static/files/poppins-devanagari-400-normal.woff) format('woff');
  unicode-range: U+0900-097F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+25CC,U+A830-A839,U+A8E0-A8FF;
}

/* poppins-latin-ext-400-normal */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/poppins-latin-ext-400-normal.woff2) format('woff2'), url(/static/files/poppins-latin-ext-400-normal.woff) format('woff');
  unicode-range: U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* poppins-latin-400-normal */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/static/files/poppins-latin-400-normal.woff2) format('woff2'), url(/static/files/poppins-latin-400-normal.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
body {
  font-family: "Nunito", sans-serif;
}
.navbar {
  display: flex;
  justify-content: center;
}
.navbar ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
}
.navbar li {
  margin: 0 20px;
}
.navbar a {
  text-decoration: none;
  color: #333;
  font-weight: bold;
  transition: color 0.3s ease;
}
.navbar a:hover {
  color: #F06060;
}
.navbar .large-view-items-inverse a {
  color: #fafafa;
}
.navbar .dropdown {
  display: none;
}

@media only screen and (max-width: 576px) {
  .navbar .large-view-items {
    display: none;
  }
  .navbar .dropdown {
    display: block;
    position: relative;
  }
  .navbar .dropdown-toggle {
    display: block;
    padding: 0;
    background-color: transparent;
    color: #333;
    cursor: pointer;
    border: none;
  }
  .navbar .dropdown-toggle svg {
    width: 2em;
    height: 2em;
    color: #333;
  }
  .navbar .large-view-items-inverse svg {
    color: #fafafa;
  }
  .navbar li {
    display: inline-block;
    width: 100%;
    padding: 4px 2em;
    margin: 0;
  }
  .navbar li:hover {
    background-color: #F2EBBF;
  }
  .navbar a:hover {
    color: #F06060;
  }
  .navbar .dropdown-menu {
    text-align: left;
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    background-color: #f6f6f6;
    border: 1px solid #ccc;
    border-radius: 5px;
    padding: 0.5em 0;
    z-index: 1;
  }
  .navbar .dropdown-menu a {
    white-space: nowrap;
  }
  .navbar .dropdown-menu-up {
    top: auto;
    bottom: 100%;
  }
  .navbar .dropdown-toggle:hover + .dropdown-menu,
  .navbar .dropdown-menu:hover, .navbar .dropdown-menu-open {
    display: block;
  }
}
.button {
  display: inline-block;
  padding: 10px 20px;
  border-radius: 5px;
  border: 1px solid #ccc;
  background-color: #fafafa;
  color: #333;
  font-weight: bold;
  text-decoration: none;
  transition: color 0.3s ease;
  cursor: pointer;
}
.button:hover {
  color: #F06060;
}

.action {
  background-color: #F2EBBF;
  color: #5C4B51;
  border-color: #5C4B51;
}
.progress-bar {
  width: 100%;
  background-color: #ccc;
  height: 1.8em;
  border-radius: 4px;
  margin-bottom: 10px;
  position: relative;
}
.progress-bar__progress {
  height: 100%;
  background-color: #F06060;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.progress-bar__display {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 4px;
  text-align: center;
  color: #fafafa;
}
.timer-display {
  text-align: center;
  font-size: 1.2em;
}
/* Block: help-popup */
.help-popup {
  position: relative;
  display: inline-block;
}

/* Element: popup */
.help-popup__popup {
  position: absolute;
  top: 100%;
  right: 0;
  background-color: #fafafa;
  box-shadow: 0 2px 6px #333;
  padding: 10px;
  min-width: 340px;
  border-radius: 4px;
  display: none;
  z-index: 1;
}

/* Element: popup-title */
.help-popup__popup-title {
  font-weight: bold;
}

/* Show the popup when visible */
.help-popup:hover .help-popup__popup,
.help-popup:focus-within .help-popup__popup {
  display: block;
}
.toolbar-button {
  border: #ccc solid 1px;
  color: #333;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  font-size: 18px;
  cursor: pointer;
  outline: none;
  display: flex;
  justify-content: center;
  align-items: center;
}
.toolbar {
  height: 2rem;
}

.timer__toolbar {
  height: 3rem;
}
.five-app {
  min-width: 480px;
}
.title {
  text-align: center;
}

.legal-body {
  margin: 0 auto;
  max-width: 800px;
  padding: 0 1em;
}
.legal-body h1, .legal-body h2, .legal-body h3 {
  margin: 1em 0;
  text-align: center;
}

.left-line {
  border-left: 1px solid #ccc;
  padding-left: 1em;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.clear {
  clear: both;
}

html {
  color: #333;
  background-color: #fafafa;
}

body {
  background: #fafafa;
  font-family: "Nunito", sans-serif;
}
.action-area {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}
.action-area button {
  margin: 0 0.5rem;
}

.cookie-policies {
  position: fixed;
  bottom: 1rem;
  left: 1rem;
  width: calc(100% - 2rem);
  background-color: #fff;
  padding: 1rem;
  box-shadow: 0px -2px 10px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.cookie-policies p {
  text-align: center;
  margin: 0.3rem 0;
}
.title {
  text-align: center;
}

.legal-body {
  margin: 0 auto;
  max-width: 800px;
  padding: 0 1em;
}
.legal-body h1, .legal-body h2, .legal-body h3 {
  margin: 1em 0;
  text-align: center;
}

.left-line {
  border-left: 1px solid #ccc;
  padding-left: 1em;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.clear {
  clear: both;
}

.guide {
  background-color: #fafafa;
  margin: 20px auto;
  padding: 20px;
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.guide h1 {
  text-align: center;
  font-size: 34px;
  color: #333;
}
.guide h2 {
  font-size: 20px;
  margin-top: 20px;
  text-align: center;
}
.guide p {
  font-size: 16px;
}
.guide ol {
  margin-left: 20px;
}

.call-to-action {
  text-align: center;
  margin: 2em;
}

.get-started-button {
  font-size: 1.2em;
  margin: 3em;
}
.about-section {
  padding: 1em;
}
.about-section h1 {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  margin: 1rem;
}
.about-section h1, .about-section h2, .about-section h3 {
  margin: 1em 0;
  text-align: center;
}
.about-section p {
  margin: 1em 0;
  text-align: justify;
}
.tutorial-section {
  margin: 0 1em;
}
.tutorial-section h1 {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  margin: 1rem;
}
.tutorial-section h2 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 1rem 0;
}
.tutorial-section p {
  text-align: justify;
}
.tutorial-section .intro {
  font-style: italic;
}
.contact-section {
  padding: 1em;
}
.contact-section h1, .contact-section h2, .contact-section h3 {
  margin: 1em 0;
  text-align: center;
}

.contact-table {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

.contact-form-section {
  flex: 1;
  padding: 1em;
}
.contact-form-section h3 {
  margin-bottom: 1em;
  font-size: 1.5em;
}
.contact-form-section .form-group {
  display: flex;
  flex-direction: column;
}
.contact-form-section form {
  display: flex;
  flex-direction: column;
}
.contact-form-section form input[type=text], .contact-form-section form input[type=email],
.contact-form-section form textarea {
  margin: 0.5em 0;
  padding: 0.5em;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.address-section {
  padding: 1em;
}


.tools-section {
  margin: 0 1em;
}
.tools-section h1 {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  margin: 1rem;
}
.tools-section h2 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 1rem 0;
}
.tools-section p {
  text-align: justify;
}
.tools-section .intro {
  font-style: italic;
}


.not-found-area h1 {
  text-align: center;
}
.title {
  text-align: center;
}

.legal-body {
  margin: 0 auto;
  max-width: 800px;
  padding: 0 1em;
}
.legal-body h1, .legal-body h2, .legal-body h3 {
  margin: 1em 0;
  text-align: center;
}

.left-line {
  border-left: 1px solid #ccc;
  padding-left: 1em;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.clear {
  clear: both;
}

.footer {
  background-color: #333;
  color: #fafafa;
  padding: 1em;
  margin-top: 1em;
}
.footer .footer-content {
  margin: 0 auto;
  text-align: center;
}
.footer .copy-text {
  margin-bottom: 1em;
}
.footer .copy-text a {
  color: #fafafa;
  text-decoration: none;
}

@media only screen and (max-width: 576px) {
  .footer-content {
    display: flex;
    flex-direction: row;
    align-items: center;
  }
  .footer-content p {
    flex: 1;
  }
}
@media only screen and (max-width: 576px) {
  .hide-in-mobile {
    display: none;
  }
}
.title {
  text-align: center;
}

.legal-body {
  margin: 0 auto;
  max-width: 800px;
  padding: 0 1em;
}
.legal-body h1, .legal-body h2, .legal-body h3 {
  margin: 1em 0;
  text-align: center;
}

.left-line {
  border-left: 1px solid #ccc;
  padding-left: 1em;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.clear {
  clear: both;
}

.header {
  background-color: #fafafa;
  color: #333;
  padding: 0.8em;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo {
  display: flex;
  align-items: center;
}
.logo svg {
  width: 32px;
  height: 32px;
  margin: 0.5em;
}
.logo a {
  color: #333;
  font-size: 1.5rem;
  font-weight: 700;
  text-decoration: none;
}

.ace-logo_svg__solid-fill {
  fill: #333;
  stroke: #333;
}

.ace-logo_svg__stroke-only-fill {
  fill: none;
  stroke: #333;
}

@media only screen and (max-width: 576px) {
  .logo-link {
    display: none;
  }
}
.main-layout {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.main-layout .content {
  align-self: center;
  max-width: 800px;
  flex: 1;
}