@charset "UTF-8";
:root {
  --main-bg: #292929;
  --header-bg: #1f1a27;
  --footer-bg: #1f1a27;

  --font-primary: #1c1d22;
  --font-white: #ffffff;
  --font-black: #000000;
  --font-red: #fa7676;
  --font-lighter: #f9e1ff;
  --font-violet: #a468f7;

  --bg-violet: #a468f7;
  --bg-step: rgba(164, 104, 247, 0.34);
  --bg-input: #f9e1ff;

  --border-color: #5d1073;

  --btn-bg: #f9e1ff;
  --btn-bg-hover: #a468f7;
  --btn-login: rgba(89, 10, 107, 0.5);
}

* {box-sizing: border-box; scroll-behavior: smooth;}

/*========================------- CUSTOM CSS  ------========================*/
html {
  min-width: 320px;
  scroll-behavior: smooth;
}
body {
  font-family: 'Montserrat', Arial, sans-serif;
  min-width: 320px;
  color: var(--font-white);
  background-image: url('../img/tarot_sun.png'), url('../img/main_bg.jpg');
  background-repeat: no-repeat;
  background-position: right -60px top 40px, center top;
  background-size: 250px, cover;
  /*background-color: var(--main-bg);*/
}
@media only screen and (max-width: 576px) {
  body {
    background-position: right -50px top 70px, center top;
    background-size: 200px, cover;
  }
}
p { margin: 0 0 20px 0; font-family: 'Montserrat', Arial, sans-serif; color: var(--font-white); }
h1, h2, h3 {color:var(--font-white); font-weight: 600; margin-bottom: 20px;}
h4, h5, h6 {color:var(--font-white); font-weight: 600; margin-bottom: 16px;}

a:link, a:visited, a:hover, a:active {color: var(--font-blue);}
a:hover {text-decoration: none;}

/*------ MAIN ---------*/
.main-container { margin: 0 auto; max-width: 960px; overflow: hidden; }

/*---- Header ----*/
.header { position: relative; margin: 0 0 16px 0; padding: 0; /*background-color: var(--header-bg);*/ }

.header-container {display: flex; justify-content:space-between; align-items: center; gap:16px; margin: 0; padding: 16px 5px; }

.header-logo {display: flex; align-items: center; justify-content: space-between; margin: 0; padding: 0; text-align: left;}
.header-logo img {display: inline-block; margin: 0; padding: 0; width: 60px;}

.header-logo-text {
  display: inline-block;
  margin: 0;
  padding: 0;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--font-violet);
  text-align: left;
}

/*---------*/
.header-btn-container {margin: 0; padding: 0;}

.login-btn,
.login-btn:link,
.login-btn:visited,
.login-btn:active {
  display: inline-block;
  margin: 0;
  padding: 12px 24px 12px 52px;
  min-width: 120px;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  color:var(--font-btn);
  text-align: center;
  border: 1px solid var(--font-white);
  border-radius: 26px;
  cursor: pointer;
  text-decoration: none;
  background: url('../img/login-user.png');
  background-repeat: no-repeat;
  background-position: 12px center;
  background-size: 26px;
  background-color: var(--btn-login);
  box-shadow: 0 0 15px rgba(0,0,0,0.33);
}
.login-btn:hover { box-shadow: 0 0 15px rgba(164,104,247,0.5); }

@media only screen and (max-width: 768px) {
  .header { margin: 0 0 10px 0; }
  .header-container { padding: 12px 10px; }
  /*----*/
  .header-logo img { width: 120px; }
}
@media only screen and (max-width: 576px) {
  .header-container { flex-direction: column; }
}
/*---- end: Header ----*/


/*--- Section Main ---*/
.section { /*display: none;*/
  position: relative;
  margin: 0;
  padding: 0; 
  border-radius: 26px;
  border: 2px solid var(--font-violet);
  background: url('../img/stars_left.png'), url('../img/stars_right.png');
  background-repeat: no-repeat;
  background-position: 20px 35px, right 20px bottom 35px;
  background-size: 60px, 60px;
  overflow: hidden;
}

.section::before { content: ""; width: 55px; height: 5px; position: absolute; top: 0px; left: 65%; background-color: var(--bg-violet); }
.section::after { content: ""; width: 75px; height: 6px; position: absolute; bottom: 0px; left: 25%; background-color: var(--bg-violet); }

.section-hide { display: none; }

.section-quiz {margin: 0 0 20px 0; padding: 2rem 0 2rem 0;}

@media only screen and (max-width: 576px) {
  .section-quiz {padding: 1rem 0;}
}
/*--- end: Section Main ---*/


/*--- Quiz section ---*/
.quiz-container {display: flex; gap:10px; justify-content:space-between; align-items: stretch; margin: 0; padding: 0 20px; min-height: 500px;}

.section-quiz-left {flex-grow: 1; /*width:50%;*/ margin: 0; padding: 0; display: flex; align-items:center; /*border:1px solid #5fd8d5;*/}
.section-quiz-right {flex-grow: 0; /*width:50%;*/ margin: 0; padding: 0; /*border: 1px solid #ebee51;*/}

.exe-hide {display: none;}

/*---- QUIZ Item ----*/
.quiz-info {margin: 0; padding: 0; font-family: 'Montserrat', Arial, sans-serif; }

.quiz-step {display:inline-block; margin: 0 0 24px 0; padding: 4px 16px; font-size:18px; font-weight: 400; line-height: 1.2; color:var(--font-white); text-transform:uppercase; text-align: center; min-width: 80px; border-radius: 36px; background-color: var(--bg-step);}
.quiz-step-item {color:var(--font-white)}

.quiz-info-title {margin: 0 0 32px 0; padding: 0; font-size:32px; font-weight: 600; line-height: 1.2; color:var(--font-white); text-align: left;}
.quiz-info-title span { color:var(--font-lighter);}

.quiz-info-text {margin: 0 0 20px 0; padding: 0; font-size:18px; font-weight: 600; line-height: 1.2; color:var(--font-white); text-align: left; }
.quiz-result-y0, .quiz-result-y1, .quiz-result-y2, .quiz-result-y3, .quiz-result-n0, .quiz-result-n1, .quiz-result-n2, .quiz-result-n3 {display: none;}

.quiz-info-text span { color: var(--font-violet); }

.quiz-info-line {margin: 0 0 20px 0; padding: 10px; font-size:18px; font-weight: 400; line-height: 1.2; color:var(--font-white); text-align: left; border: 1px solid var(--font-violet); border-radius: 6px; }

.quiz-card {position: relative; display: flex; justify-content: center; align-items: flex-end;}
.quiz-card-img {margin: 0; padding: 0; }
.quiz-card-img img {display: block; max-width:100%; max-height: 480px; min-width: 280px; }

/*-------------*/
.quiz-buttons { display: flex; flex-direction: column; gap: 10px; max-width: 360px; }

.quiz-btn,
.quiz-btn:link,
.quiz-btn:visited,
.quiz-btn:active {
  display: inline-block;
  margin: 0;
  padding: 16px 24px;
  min-width: 150px;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;
  color:var(--font-primary);
  text-align: left;
  border: 0;
  border-radius: 12px;
  background: #ffffff;
  cursor: pointer;
  text-decoration: none;
  background-color: var(--btn-bg);
  box-shadow: 0px 2px 6px rgba(0,0,0,0.3);
}
.quiz-btn:hover {
  color: var(--font-white);
  background-color: var(--btn-bg-hover);
}

/*--------------------*/
@media only screen and (max-width: 768px) {
  .quiz-container {display: flex; flex-wrap: wrap; margin: 0; padding: 0 10px;}
  .section-quiz-left { width:100%; }
  .section-quiz-right { width:100%; }
  /*-------*/
  .quiz-info-title {margin: 0 0 24px 0; font-size:26px;}
  /*-------*/
  .quiz-card {justify-content: center;}
  /*-------*/
  .quiz-btn,
  .quiz-btn:link,
  .quiz-btn:visited,
  .quiz-btn:hover,
  .quiz-btn:active {
    padding: 12px 20px;
    font-size: 22px;
  }
}
@media only screen and (max-width: 576px) {
  .quiz-container { gap: 15px; min-height: 300px;}
  .quiz-info-title {margin: 0 0 20px 0; font-size:22px;}
  /*-------*/
  .quiz-btn,
  .quiz-btn:link,
  .quiz-btn:visited,
  .quiz-btn:hover,
  .quiz-btn:active {
    padding: 12px 18px;
    font-size: 20px;
  }
}
@media only screen and (max-width: 440px) {
  .quiz-info-title {margin: 0 0 16px 0; font-size:18px;}
  .quiz-info-text {margin: 0 0 16px 0; font-size:16px; }
  /*-------*/
  .quiz-btn,
  .quiz-btn:link,
  .quiz-btn:visited,
  .quiz-btn:hover,
  .quiz-btn:active {
    padding: 12px 10px;
    font-size: 16px;
  }
}

/*------ COURSE -------*/
.course-container { width: 70%; margin: 0 auto; padding: 0; border-radius: 32px; background: var(--bg-violet); }

.course-box { display: flex; justify-content: space-between; align-items: stretch; flex-wrap: wrap; margin: 0; padding: 10px 10px; border-radius: 28px; border: none; }
.course-box-left { width: 40%; margin: 0; padding: 40px 20px;}
.course-box-right { width: 60%; margin: 0; padding: 0;}

/*--- course info ---*/
.course-info {display: flex; flex-direction: column; justify-content: center; height: 100%; margin: 0; padding: 0; font-family: 'Montserrat', Arial, sans-serif;}

.course-info-top { margin: 0 0 12px 0; padding: 0; font-size:16px; font-weight: 400; line-height: 1.2; color: var(--font-lighter); text-align: left; }
.course-info-top span { text-decoration: line-through; }
.course-info-top.price-full { display: none; }

.course-price { margin: 0; padding: 0; font-size: 64px; font-weight: 600; line-height: 50px; color: var(--font-white); text-align: left; }
.course-price.price-full { display: none; }
.course-countdown { margin: 20px 0; padding: 0; }
.course-countdown-text { margin: 0; padding: 0; font-size: 16px; font-weight: 400; line-height: 1.2; color: var(--font-lighter); text-align: left; }
.course-countdown-timer { margin: 0; padding: 0; font-size: 42px; font-weight: 400; line-height: 1.2; color: var(--font-lighter); text-align: left; }

@media only screen and (max-width: 800px) {
  /*-------------*/
  .course-container { width: 90%; }
  .course-box-left { width: 100%; margin: 0; padding: 20px 10px;}
  .course-box-right { width: 100%; margin: 0; padding: 0;}
  /*-------------*/
  .course-price { font-size: 48px; }
  .course-countdown { margin: 10px 0; }
  .course-countdown-timer { font-size: 32px; }
  /*----------------*/
}
@media only screen and (max-width: 576px) {
  /*-------------*/
  .course-container { width: 100%; padding: 0px;}
}
@media only screen and (max-width: 400px) {
  /*-------------*/
  .course-container { width: 100%; padding: 0px;}
  .course-box-left { padding: 10px 10px;}
  /*-------------*/
  .course-price { font-size: 48px; }
  .course-countdown { margin: 10px 0; }
  .course-countdown-timer { font-size: 32px; }
  /*----------------*/
}
/*---- end: COURSE Section -----*/

/*--- Form Course ----*/
.form-course { margin: 0; padding: 12px 12px; border-radius: 16px; border: 1px dashed var(--border-color);}

.form-line {padding:8px 8px; border-radius: 16px; background-color: var(--bg-input);}
.form-control {font-weight: 400; color: var(--font-primary); border: 1px solid transparent; background-color: var(--bg-input); border-radius: 10px; }
.form-control::placeholder { color: var(--font-primary); text-decoration-line: underline; text-decoration-style: dashed; text-decoration-color: var(--font-primary);text-underline-offset: 2px; }
.form-control:focus { color: var(--font-input); box-shadow: none; background-color: transparent; border: 1px solid var(--font-primary); }

.form-check-input {background-color: transparent; border-color: var(--border-color);}
.form-check-input:focus { box-shadow: none; border-color: var(--border-color);}
.form-check-input:checked { background-color: transparent; border-color: var(--border-color); }
.form-check-input:checked[type=checkbox] { background: url('../img/checkbox.svg'); }
.form-check label {margin: 0 0 6px 0; font-size: 10px; color: var(--font-white);}

/*--- form btn ----*/
.form-btn-container {position: relative; margin: 0 0 1rem 0; padding: 5px 0; border-radius: 16px; text-align: center;}

.form-btn,
.form-btn:link,
.form-btn:visited,
.form-btn:hover,
.form-btn:active {
  display: inline-block;
  margin: 0;
  padding: 14px 12px;
  width: 100%;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.2;
  color:var(--font-btn);
  text-align: center;
  text-shadow: 0 0 10px rgba(0,0,0,0.5);
  border: 0;
  border-radius: 16px;
  cursor: pointer;
  text-decoration: none;
  background: url('../img/btn_bg.jpg');
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-color: var(--btn-login);
}
.form-btn:disabled { opacity: 0.6; }

@media only screen and (max-width: 768px) {
  .form-btn,
  .form-btn:link,
  .form-btn:visited,
  .form-btn:hover,
  .form-btn:active {
    padding: 14px 10px;
    font-size: 18px;
  }
}
@media only screen and (max-width: 576px) {
  .form-control { font-size: 14px; }

  .form-btn,
  .form-btn:link,
  .form-btn:visited,
  .form-btn:hover,
  .form-btn:active {
    font-size: 16px;
  }
}
/*--- end: Form Course ----*/


/*--- Button ---*/
.btn-container {position: relative; margin: 0; padding: 24px 0; text-align: left;}

.main-btn,
.main-btn:link,
.main-btn:visited,
.main-btn:active {
  display: inline-block;
  margin: 0;
  padding: 16px 24px;
  min-width: 150px;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;
  color:var(--font-white);
  text-align: center;
  border: 0;
  border-radius: 12px;
  background: #ffffff;
  cursor: pointer;
  text-decoration: none;
  background-color: var(--btn-bg-hover);
  box-shadow: 0px 2px 6px rgba(0,0,0,0.3);
}
.main-btn:hover {
  color: var(--font-primary);
  background-color: var(--btn-bg);
}

@media only screen and (max-width: 768px) {
  .btn-container {padding: 12px 0;}
  .main-btn,
  .main-btn:link,
  .main-btn:visited,
  .main-btn:hover,
  .main-btn:active {
    padding: 12px 20px;
    font-size: 22px;
  }
}

@media only screen and (max-width: 576px) {
  .main-btn,
  .main-btn:link,
  .main-btn:visited,
  .main-btn:hover,
  .main-btn:active {
    padding: 12px 18px;
    font-size: 20px;
  }
}
@media only screen and (max-width: 400px) {
  .main-btn,
  .main-btn:link,
  .main-btn:visited,
  .main-btn:hover,
  .main-btn:active {
    padding: 12px 10px;
    font-size: 16px;
  }
}
/*--- end: Button ---*/


/*----- Footer ----*/
.footer-wrapper { position: relative; margin: 0; padding: 0; background-color: var(--footer-bg);}
.footer {padding: 3rem 10px 1rem 10px; max-width: 960px; background-color: var(--footer-bg);}
.footer-line {margin: 0 0 10px 0; padding: 0; color: var(--font-white); font-size: 16px; text-align: left;}

.footer-text { display: block; margin: 0 0 10px 0; padding: 0; font-family: 'Montserrat', Arial, sans-serif; font-size: 16px; font-weight: 400; line-height: 1.2; color:var(--font-white); text-align: center;}

.footer-image {margin: 0 0 16px 0; padding: 0; text-align: center;}
.footer-image img {display: inline-block; margin: 0 5px 5px 5px; padding: 0; max-width: 20%;}

/*---- footer menu ----*/
.footer-menu {margin: 0; padding: 0;}
.footer-menu-item:link,
.footer-menu-item:visited,
.footer-menu-item:active {
  display: block;
  margin: 0 0 5px 0;
  padding: 0;
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.2;
  color:var(--font-white);
  text-align: left;
  text-decoration: none;
}
.footer-menu-item:hover { text-decoration: underline; }

@media only screen and (max-width: 768px) {
  .footer {padding: 1rem 10px;}
  .footer-line {margin: 0 0 10px 0; font-size: 14px; text-align: left;}
  .footer-text { font-size: 14px; text-align: left; }
  .footer-image {margin: 0 0 16px 0; text-align: left;}

  .footer-menu-item:link,
  .footer-menu-item:visited,
  .footer-menu-item:active { font-size: 14px; }
}
@media only screen and (max-width: 400px) {
  .footer-line {font-size: 12px;}

  .footer-menu-item:link,
  .footer-menu-item:visited,
  .footer-menu-item:active { font-size: 12px; }
}
/*----- end: Footer ----*/

/*------- end: Custom css ----*/
