@charset "UTF-8";

* {
  margin: 0;
  padding: 0;
  max-height: 999999px;
}

:root {
  font-size: 100%;
}

/* body {
  font-family: "Inter", sans-serif;
  line-height: 1.4;
  text-align: center;
  color: #333333;
  -webkit-text-size-adjust: 100%;
  background: #fff;
  font-size: 100%;
}

html:lang(kh) body {
  font-family: 'Battambang', sans-serif;
} */

/* Default: English / Latin */
body {
  font-family: "Inter", "Noto Sans JP", "Noto Sans Khmer", sans-serif;
  line-height: 1.4;
  text-align: center;
  color: #333333;
  -webkit-text-size-adjust: 100%;
  background: #fff;
  font-size: 100%;
}

/* Khmer language (km / kh) */
html:lang(kh) body,
html:lang(km) body {
  font-family: "Noto Sans Khmer", "Inter", "Noto Sans JP", sans-serif;
}

/* Japanese language */
html:lang(ja) body {
  font-family: "Noto Sans JP", "Inter", "Noto Sans Khmer", sans-serif;
}


img {
  width: 100%;
}

button {
  cursor: pointer;
}

a {
  text-decoration: none;
  cursor: pointer;
  color: #333333;
}

a:hover {
  opacity: 0.7;
  text-decoration: none;
}

ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

li {
  display: inline-block;
}

h1 {
  line-height: 0;
}

h5 {
  font-size: 1.125rem;
  color: #333333;
}

h2 {
  font-size: 1.5rem;
  text-align: left;
  line-height: 1.625rem;
  padding: 30px 0;
  color: #333333;
}

h4 {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

h3 {
  font-size: 0.875rem;
  line-height: 1.625rem;
}

.fz_bold {
  font-weight: bold;
}

select::-ms-expand {
  display: none;
}

.main .btn {
  width: 100px;
  height: 60px;
  border: none;
  padding: 0 5px;
  background-color: #333333;
  color: #fff;
  font-weight: bold;
}

.main.bn_top {
  margin-bottom: 120px;
}

.btn-01 {
  background: #92d050;
}

.btn-02 {
  background: #ffc000;
}

.btn-03 {
  background: #7030a0;
}

.bor-top {
  /* border-top: 2px solid #12204f; */
}

.c0 {
  background: #f3b0c1;
}

.c1 {
  background: #f8b500;
}

.c2 {
  background: #ffe327;
}

.c3 {
  background: #9DC3E5;
}

.c3.active:after {
  border-top-color: #9DC3E5;
}

.c4 {
  background: #a9d18e;
}

.c4.active:after {
  border-top-color: #a9d18e;
}

.c1t1 {
  background: #0B4975;
}

.c1t2 {
  background: #CF5B38;
}

.c1t3 {
  background: #007372;
}

.c1t4 {
  background: #4F3763;
}

.c1t5 {
  background: #8F292B;
}

.c1t6 {
  background: #4B7F3E;
}

.c1t7 {
  background: #7F4C45;
}

.c1t8 {
  background: #36356A;
}

.c1t9 {
  background: #8C2A45;
}

.c2t0 {
  background: #ccc;
}

.c2t1 {
  background: #0B4975;
}

.c2t2 {
  background: #4B7F3E;
}

.c2t3 {
  background: #007372;
}

.c2t4 {
  background: #7F4C45;
}

.c2t5 {
  background: #8F292B;
}

.c2t6 {
  background: #4D2D1F;
}

.c2t7 {
  background: #4E3663;
}

.c2t8 {
  background: #fc5530;
}

.c2t9 {
  background: #A94E6F;
}

.c0t1 {
  background: #b50721;
}

.c0t2 {
  background: #005395;
}

.c0t3 {
  background: #318c39;
}

.c0t4 {
  background: #f77321;
}

.c0t5 {
  background: #c64a7b;
}

.c0t6 {
  background: #5a397b;
}

.c0t7 {
  background: #007b81;
}

.c0t8 {
  background: #632910;
}

.c0t9 {
  background: #7b0042;
}

.fz-8 {
  font-size: 0.5rem !important;
}

.fz-20 {
  font-size: 1.25rem !important;
}

.pd-btm-25 {
  padding-bottom: 25px !important;
}

.pd-btm-0 {
  padding-bottom: 0 !important;
}

.hid_btn .img_block {
  margin-top: 0 !important;
}

a.txt_link {
  text-decoration: underline;
  color: #0000ff;
}

span.icon {
  position: relative;
}

span.icon::before {
  content: "";
  top: 5px;
  left: 7px;
  position: absolute;
  pointer-events: none;
  z-index: 2;
  width: 5px;
  padding-top: 5px;
  border-style: solid;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
  transform: rotate(315deg);
}

.border_0 {
  border: 0 !important;
}

.img_size {
  font-size: 0.875rem !important;
  font-weight: normal;
  position: relative;
  top: -10px;
}

.bn_block {
  margin: unset;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 100%;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  position: relative;
}

.bn_block a {
  width: 100%;
}

.bn_block .cover {
  margin-top: 0 !important;
}

.title_line {
  position: relative;
  padding-left: 15px !important;
}

.title_line::before {
  content: '';
  display: block;
  width: 5px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #e94609), color-stop(0%, #f49fa1));
  background-image: linear-gradient(#e94609 50%, #f49fa1 0%);
  position: relative;
  display: inline-block;
  top: 10px;
  left: -15px;
}

figure {
  line-height: 0;
}

.mt-30 {
  margin-top: 30px !important;
}

.mt_0 {
  margin-top: 0;
}

.inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 20px;
}

.txt_hide {
  display: none !important;
}

/* header */
.header {
  max-width: 1200px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.header .Jft_logo {
  max-width: 244px;
  width: 100%;
}

.header .Jft_logo img {
  width: 100%;
  height: auto;
}

.header .gsc-search-box-tools .gsc-search-box .gsc-input {
  padding-right: 0;
}

.header .gsc-input-box {
  border-right: 0;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  padding: 0;
}

.header table.gsc-search-box td {
  margin-left: 0;
}

.header table.gsc-search-box td.gsib_a {
  width: 150px;
  padding: 10px 9px;
}

.header .cse .gsc-search-button-v2, .header .gsc-search-button-v2 {
  margin-left: 0;
  padding: 9px 15px;
  background: #005bc2;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  border-color: #005bc2;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border: 1px solid #005bc2;
}

.header table.gsc-search-box {
  margin-bottom: 0;
}

.header .gsc-search-button-v2 svg {
  width: 20px;
  height: 20px;
}

.header table.gsc-search-box td.gsib_a {
  width: 230px;
  padding: 0 9px;
  height: 39px;
}

.header table.gsc-search-box td.gsib_b {
  width: 25px;
}

.header form.gsc-search-box {
  margin-bottom: 0px;
}

.header ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.header ul li {
  padding: 15px;
}

.header ul li .lang_sel_top {
  position: relative;
  cursor: pointer;
}

.header ul li .lang_sel_top::after {
  content: "";
  right: 12px;
  top: 10px;
  position: absolute;
  pointer-events: none;
  z-index: 2;
  width: 10px;
  padding-top: 10px;
  border-style: solid;
  border-color: #005bc2;
  border-width: 0px 2px 2px 0px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.header ul li .lang_sel_top select {
  width: 100px;
  padding: 6.5px 29px 6.5px 15px;
  border-radius: 5px;
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  background-color: #fff;
  color: #000137;
  line-height: 1.625rem;
  text-transform: uppercase;
}

.header ul li .menu_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: flex-end;
}

.header ul li .menu_nav input {
  width: 228px;
  padding: 5px;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  border-style: none;
  border: 1px solid rgba(216, 216, 216, 1);
}

.header ul li .menu_nav button {
  padding: 0 15px;
  background-color: rgba(32, 68, 149, 1);
  color: #fff;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  border-style: none;
  height: 41px;
}

.header ul li .menu_nav button img {
  width: 25px;
  height: auto;
}

.search-form {
  display: flex;
}

/* header */
.ua_header {
  padding: 15px 15px 15px 0;
  height: 71px;
  max-width: 1200px;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.ua_header .Jft_logo {
  max-width: 244px;
  width: 100%;
  margin-left: 50px;
}

.ua_header ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.ua_header ul li {
  width: auto !important;
  margin-right: 30px;
}

.ua_header ul li:last-child {
  margin-right: 0;
}

.ua_header ul li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
}

.ua_header ul li a:after {
  content: '';
  display: block;
  width: 15px;
  height: 15px;
  background: url("../img/f-externa.svg") no-repeat;
  margin-left: 5px;
}

.main {
  position: relative;
}

.main a.link {
  margin: 0 auto;
  display: block;
  border-radius: 5px;
  position: relative;
}

.main a.link::after {
  content: '\f105';
  font-family: "Font Awesome 5 Free";
  color: #fff;
  font-size: 1.375rem;
  padding-left: 0;
  font-weight: bold;
  position: relative;
  top: 3px;

}

.main a.link.new_l {
  position: relative;
}

.main a.link.new_l::after {
  content: '';
  background-image: url(../../assets/img/i_right.png);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 17px;
  padding: 11px;
  position: absolute;
  right: -4px;
  top: 4px;
  color: rgba(32, 68, 149, 1);
}

.main .note_txt, .main .desc_txt {
  color: #333333 !important;
  margin-top: 30px;
}

.main .pdf_link_txt {
  padding-top: 15px;
  font-size: 1.125rem;
  line-height: 1.625rem;
  text-align: left;
}

.main .pdf_link_txt a {
  text-decoration: underline;
  color: #0000ff;
}

.main .pdf_link_txt img {
  width: auto;
  margin-top: .2rem;
  margin-left: .2rem;
}

.main .container {
  max-width: 1420px;
  margin: 0 auto;
}

.main .container .home-link {
  padding-top: 20px;
  text-align: left;
}

.main .container .home-link .rank-math-breadcrumb p,
.main .container .home-link ul li {
  font-size: 0.875rem;
  line-height: 1.75rem;
  color: #333333;
}

.main .container .home-link ul li a::after {
  padding: 0 5px;
  content: '>';
  display: inline-block;
  font-weight: bold;
}

.main .container .home-link ul li:last-of-type a::after {
  content: ' ';
}

.main .container .ele_btn {
  text-align: left;
}
.tit_download {
    margin-top: 35px;
}
.main .container .ele_btn ul li.c3.active .current-menu-item{
background: #9DC3E5;
}
.main .container .ele_btn > ul {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* -ms-flex-wrap: wrap; */
  /* flex-wrap: wrap; */
}

.main .container .ele_btn ul li {
  color: #333333;
  position: relative;
  font-size: 1.125rem;
  font-weight: bold;
  background: #cccccc;
  margin-right: 2px;
  text-align: center;
}

.main .container .ele_btn ul li:last-of-type {
  margin-right: 0;
}

/* .main .container .ele_btn ul li >:hover {
  opacity: 0.7;
} */
 .main .container .ele_btn ul li.open{
  position: relative;
 }
.main .container .ele_btn ul li.open::after,
.main .container .ele_btn ul li.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border: 8px solid transparent;
  border-bottom: 0;
  margin-left: -8px;
  margin-bottom: -8px;
}

.main .container .ele_btn ul li.active.c0 {
  background: #f3b0c1;
}

.main .container .ele_btn ul li.active.c0::after {
  border-top-color: #f3b0c1;
}

.main .container .ele_btn ul li.active.c1 {
  background: #f1ae29;
}

.main .container .ele_btn ul li.active.c1::after {
  border-top-color: #f1ae29;
}

.main .container .ele_btn ul li.active.c2 {
  background: #ffe327;
}

.main .container .ele_btn ul li.active.c2::after {
  border-top-color: #ffe327;
}
.main .container .ele_btn ul li.open,
.main .container .ele_btn ul li.active.c3 {
  background: #9DC3E5;
}
.main .container .ele_btn ul li.open::after,
.main .container .ele_btn ul li.active.c3::after {
  border-top-color: #9DC3E5;
}

.main .container .ele_btn ul li.active.c4 {
  background: #a9d18e;
}

.main .container .ele_btn ul li.active.c4::after {
  border-top-color: #a9d18e;
}

.main .container .ele_btn ul li a {
  display: block;
  padding: 7px 10px;
}



/* ---------- SUBMENU (hidden until click) ---------- */
.main .container .ele_btn ul.l-gnav-links>li .sub-menu {
  display: none;
  position: absolute;
  left: 0;
  top: 55px;
  margin: 0;
  padding: 0;
  list-style: none;
  /* white-space: nowrap; */
  /* gap: 0px; */
  z-index: 1;
}
.main .container .ele_btn ul.l-gnav-links>li .sub-menu li{
  margin: 0;
  /* border-bottom: 1px solid #ffff; */
  width: 100%;
}
.main .container .ele_btn ul.l-gnav-links>li.open>.sub-menu {
  display: block;
}

.main .container .ele_btn ul li .sub-menu .active {
  background: #9DC3E5;
}

.l-gnav-links .menu-item-has-children>.sub-menu {
  display: none;
}

.l-gnav-links .menu-item-has-children.open>.sub-menu {
  display: block;
}
.main .container .ele_btn ul.l-gnav-links>li .sub-menu li a{
  font-size: 1rem;
}


/* Hide first-level submenu */
.l-gnav-links .menu-item-has-children > .sub-menu {
    display: none;
}

/* Show when parent has .open */
.l-gnav-links .menu-item-has-children.open > .sub-menu {
    display: block;
}

/* Hide second-level submenu */
.l-gnav-links .submenu2 {
    display: none;
}

/* Show submenu2 when parent has .open-sub */
.l-gnav-links li.open-sub > .submenu2 {
    display: block;
}

.l-gnav-links li.actives > a.nav-link {
    font-weight: bold;
    color: #e94609;
}
.main .container .ele_btn ul li .sub-menu .current_page_item{
  background-color: #9DC3E5;
}



.main .common h1 {
  font-size: 1.5rem;
  line-height: 1.625rem;
  text-align: left;
  padding: 30px 0 10px 0;
}

.main .common h1.tit_new {
  color: #204495;
  border-bottom: 1px solid #204495;
}

.main .common h1 span {
  font-size: 1.125rem;
  line-height: 1.625rem;
  padding: 0 14px;
  color: #fff;
}

.main .common h1 label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.main .common h1 label.elementary_label {
  width: 100%;
}

.main .common h1 label.elementary_label a, .main .common h1 label.elementary_label span {
  font-size: 1.125rem;
  line-height: 1.625rem;
  padding: 7px 14px;
  color: #333333;
}

.main .common h1 label.elementary_label a:hover {
  opacity: 0.7;
}

.main .common h1 label.topic_label {
  margin-top: 30px;
}

.main .common h1 label.topic_label span {
  padding: 7px 20px;
}

.main .common h1 label.topic_label span:first-of-type {
  background: #000;
  text-align: center;
}

.main .common h1 label.lesson_label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-top: 30px;
  text-align: left;
}

.main .common h1 label.lesson_label span {
  color: #333333;
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1.625rem;
  text-align: left;
  width: auto;
  padding-left: 0px;
}

.main .common h1 label.lesson_label span:last-of-type {
  border-left: 2px solid #12204f;
  padding: 0 0 0 10px;
}

.main .common h1 label.lesson_label.bor_0 span:first-of-type {
  display: none;
}

.main .common h1 label.lesson_label.bor_0 span:last-of-type {
  border-left: 0;
  padding-left: 0;
}

.main .common p.section_txt {
  font-size: 1.25rem;
  line-height: 1.625rem;
  font-weight: bold;
  padding-top: 40px;
}

.main .top_img {
  background: #f7c6c7;
  line-height: 0;
}

.main .top_img figure {
  margin: 0 auto;
}

.main .txt_link_gp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 10px;
  margin-top: -30px;
}

.main .txt_link_gp h2 {
  margin-top: 20px;
}

.main .txt_link_gp h2 span {
  display: block;
  width: 100%;
  margin-left: 20px;
}

.main .ua_btn nav ul li {
  width: auto !important;
  margin-left: 20px;
}

.main .ua_btn_gp ul {
  display: block !important;
  line-height: normal !important;
  line-height: normal;
}

.main .ua_btn_gp ul li {
  display: block;
  max-width: 100% !important;
  width: auto !important;
  margin-top: 25px;
}

.main .ua_btn_gp ul li a {
  display: block !important;
  background: #005bbb;
  color: #fff;
  padding: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 4px solid #ffd500;
  font-size: 1rem;
  position: relative;
  text-align: left;
}

.main .ua_btn_gp ul li a:after {
  content: '>';
  color: #fff;
  font-size: 1.5625rem;
  position: relative;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.main .ua_btn_gp ul li a span {
  display: block;
}

.main .ua_btn_gp ul li a span.ua {
  font-family: Helvetica Neue, Helvetica, Roboto, Droid Sans, Arial, Verdana, sans-serif;
}

.main .ua-txt {
  font-family: Helvetica Neue, Helvetica, Roboto, Droid Sans, Arial, Verdana, sans-serif;
  padding-top: 0 !important;
}

.main .bn-txt {
  font-family: Helvetica Neue, Helvetica, Roboto, Droid Sans, Vrinda, Arial, Verdana, "Noto Serif Bengali", sans-serif;
  padding-top: 0 !important;
}

.main .ua .dl_all_lst ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 30px;
}

.main .ua .dl_all_lst ul li {
  margin-right: 2.8%;
  margin-top: 0;
}

.main .ua .dl_all_lst ul li:nth-child(4n) {
  margin-right: 0;
}

.main .ua .dl_all_lst ul li .download figure img {
  border: 1px solid #ddd;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.main .ua .batch_download {
  margin-top: 30px;
  margin-bottom: 0;
}

.main .ua .batch_download h4 {
  text-align: left;
}

.main .ua .batch_download .download {
  margin-top: 10px;
}

.main .ua .section_download ul {
  margin-bottom: 30px;
}

.main .ua .section_download h3 .cm_txt {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.main .ua .section_download h3 .cm_txt span {
  display: block !important;
  width: 100% !important;
  background-color: transparent !important;
  text-align: left !important;
  padding: 0 !important;
  margin-bottom: auto;
  font-size: 100% !important;
}

.main .ua .section_download .lesson_text h4 span:first-of-type {
  font-size: 0.875rem;
}

.main .ua .section_download ul li .topic h3 .topic_txt {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding-top: 23px;
}

.main .ua .section_download ul li .topic h3 .topic_txt span.ua-txt, .main .ua .section_download ul li .topic h3 .topic_txt span.bn-txt {
  font-size: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.main .ua .cm_list {
  padding-top: 0 !important;
}

.main .ua .modal .modal-content .bg01_batch p span {
  display: block;
  width: 100%;
}

.main .ua .modal .modal-content .bg01_batch p br {
  display: none;
}

.main .ua a.link {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.main .ua h2:before {
  top: 45px !important;
}

.main .ua h2 span {
  display: block;
  margin-left: 10px;
  font-size: 1.375rem;
}

.main .ua h2 span:first-child {
  margin-left: 0;
}

.main .ua h2 span.fz-24 {
  font-size: 1.5rem;
}

.main .ua h2 span.fz-24_mt {
  margin-top: 5px;
}

.main .ua h2 span.ml-10 {
  margin-left: 10px;
}

.main .ua h2.ml_10 span {
  margin-left: 10px;
}

.main .ua.bn_content .batch_download {
  margin-bottom: 50px;
}

.main .ua.bn_content h2 {
  padding-top: 0 !important;
}

.main .ua.bn_content h2.sub_title:before {
  top: 10px !important;
}

.main .ua.bn_content .section_download .lesson_list {
  padding-top: 30px !important;
}

.main .ua.bn_content .section_download .dl_all_lst ul {
  grid-gap: 0 !important;
  margin-bottom: 0 !important;
}

.main .ua.bn_content .section_download .dl_all_lst ul li {
  margin-bottom: 30px !important;
}

.main .ua.bn_content .section_download ul {
  padding-top: 0;
}

.main .ua.bn_content .section_download ul.lesson_list {
  padding-top: 0 !important;
}

.main .ua.bn_content .ele_btn ul {
  margin-top: 45px;
}

.main .ua_lesson .topic_label span span {
  background: transparent !important;
  padding: 0 !important;
}

.main .ua_lesson .elementary_label a {
  padding: 0 !important;
}

.main .ua_lesson h1 .lesson_label {
  display: block !important;
}

.main .ua_lesson h1 .lesson_label span {
  font-size: 1.375rem !important;
  margin-top: 10px;
  padding-left: 15px !important;
}

.main .ua_lesson h1 .lesson_label span.fz-20 {
  font-size: 1.25rem !important;
}

.main .ua_lesson h1 .lesson_label span:first-child {
  padding-left: 0 !important;
  padding-right: 10px;
}

.main .ua_lesson h1 .lesson_label span span {
  background: transparent !important;
  display: block !important;
  margin-top: 0;
  border: 0 !important;
  padding-left: 0 !important;
}

.main h1.top_banner {
  background: #f7c6c7;
  line-height: 0;
}

.main h1.top_banner img {
  max-width: 1405px;
  margin: 0 auto;
  width: 100%;
}

.main .btn-group {
  background: #e94609;
  padding: 7px 0;
}

.main .btn-group ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  justify-content: center;
}

.main .btn-group ul li {
  width: 31.482%;
  padding: 5px 0;
  min-width: 104px;
  position: relative;
}

.main .btn-group ul li:after {
  content: '';
  display: block;
  width: 2px;
  height: 40px;
  background: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  margin-top: auto;
  margin-bottom: auto;
}

.main .btn-group ul li a {
  display: inline;
  color: #fff;
  font-weight: bold;
  font-size: 1.25rem;
  line-height: 1.625rem;
  position: relative;
}

.main .btn-group ul li a::before {
  content: "";
  display: inline-block;
  color: #fff;
  height: 30px;
  margin-right: 10px;
  position: relative;
  top: -2px;
  vertical-align: middle;
  width: 30px;
}

/* .main .btn-group ul li a::after {
  content: '\f105';
  font-family: "Font Awesome 5 Free";
  color: #fff;
  font-size: 1.25rem;
  position: relative;
  left: 7px;
} */

.main .btn-group ul li:first-of-type {
  width: 12%;
  padding: 7px 0;
  min-width: auto;
}

.main .btn-group ul li:first-of-type:after {
  content: none;
}

.main .btn-group ul li:first-of-type a::before, .main .btn-group ul li:first-of-type a::after {
  content: none;
}

.main .btn-group ul li:nth-of-type(2n) a::before {
  background: url("../img/question.png") no-repeat scroll center center/100% auto;
}

.main .btn-group ul li:nth-of-type(3n) a::before {
  background: url("../img/answer.png") no-repeat scroll center center/100% auto;
  width: 45px;
}

.main .btn-group ul li:nth-of-type(4n) a::before {
  background: url("../img/contact.png") no-repeat scroll center center/100% auto;
}

.main .btn-group ul li:last-of-type {
  width: 24%;
}

/* .main .btn-group ul li:last-of-type a:before {
  background: url("../img/note.png") no-repeat scroll center center/100% auto;
} */

.main .news_update {
  width: 100%;
  margin-top: 90px;
  background: #fffbd1;
  padding: 50px 0 50px 0;
  font-size: 1.375rem;
  line-height: 1.625rem;
  color: #333333;
}

.main .news_update p {
  font-weight: bold;
}

.main .news_update .inner a.link {
  font-size: 1rem;
  line-height: 1.75rem;
  max-width: 180px;
  /* padding: 8px 15px; */
  width: 110px;
  color: rgba(32, 68, 149, 1);
  margin-right: 0;
  text-decoration: underline;
  display: inline-block;
}

[lang="km"] .main .news_update .inner a.link {
  width: 140px;
}

.main .news_update .inner .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.main .news_update .inner .text_link {
  /* padding-top: 30px; */
  text-align: left;
  font-size: 1rem;
  line-height: 1.75rem;
}

.main .news_update .inner .text_link a {
  text-decoration: none;
  margin-left: 50px;
  color: #333333;
}

.main .news_update .inner .text_link a b {
  font-size: 1.15rem;
}

.news_list {
  border-bottom: 1px solid rgba(179, 179, 179, 0.5);
  padding: 15px 0;
}

.main .news_update h2 {
  padding: 0;
}

.main .news_update .row {
  margin-bottom: 15px;
}

.main .top h2 {
  position: relative;
  padding-left: 15px;
}

.main .top h2::before {
  content: '';
  display: block;
  width: 5px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #e94609), color-stop(0%, #f49fa1));
  background-image: linear-gradient(#e94609 50%, #f49fa1 0%);
  position: relative;
  display: inline-block;
  top: 10px;
  left: -15px;
}

.main .top .course_title h2 {
  text-align: center;
  padding: 0;
  padding: 60px 0 15px 0;
  color: rgba(32, 68, 149, 1);
}

.main .top .course_title h2::before {
  display: none;
}

.main .top .elementary_lst p {
  text-align: left;
  font-size: 1.25rem;
  line-height: 1.5625rem;
  padding-bottom: 12px;
  font-weight: bold;
}

.main .top .elementary_lst figure {
  max-width: 320px;
}

.main .top .elementary_lst ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 60px 1fr 60px 1fr;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 60px;
  padding-top: 25px;
  line-height: 0;
}

.main .top .elementary_lst ul li {
  max-width: 320px;
  width: 100%;
}

.main .top .elementary_lst ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  height: 100%;
}

.main .top .elementary_lst ul li a figure {
  margin-top: auto;
}

.main .pdf.common h1 span {
  font-size: 1.125rem;
  line-height: 1.625rem;
  padding: 8px 14px;
  color: #333333;
}

.main .pdf {
  padding-bottom: 90px;
}

.main .pdf hr {
  border: 1px solid #cccccc;
  background-color: #cccccc;
}

.main .pdf h2 {
  padding: 10px 0 0 15px;
}

.main .pdf h2:before {
  content: '';
  display: block;
  width: 5px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #e94609), color-stop(0%, #f49fa1));
  background-image: linear-gradient(#e94609 50%, #f49fa1 0%);
  position: relative;
  display: inline-block;
  top: 10px;
  left: -15px;
}

.main .pdf p {
  font-size: 1.125rem;
  line-height: 1.625rem;
  text-align: left;
  color: #23316a;
}

.main .pdf #news_36+.section_download ul.cm_list li:nth-of-type(4) .img_block {
  margin-bottom: calc(3.3125rem + 34px);
}

.main .pdf .section_download .inner {
  padding: 0;
}

.main .pdf .section_download h2 {
  padding-top: 30px;
}

.main .pdf .section_download ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}

.main .pdf .modal {
  display: none;
  position: fixed;
  z-index: 99;
  padding-top: 100px;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: black;
  background-color: rgba(0, 0, 0, 0.4);
}

.main .pdf .modal .modal-content {
  max-width: 500px;
  margin: 70px auto;
  padding: 20px;
  background: #fff;
  border-radius: 5px;
  position: relative;
  -webkit-transition: all 5s ease-in-out;
  transition: all 5s ease-in-out;
}

.main .pdf .modal .modal-content span.close {
  color: #aaaaaa;
  float: right;
  font-size: 28px;
  font-weight: bold;
}

.main .pdf .modal .modal-content span.close:hover, .main .pdf .modal .modal-content span.close:focus {
  color: #333333;
  text-decoration: none;
  cursor: pointer;
}

.main .pdf .modal .modal-content .bg01_batch {
  max-width: 400px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 20px;
}

.main .pdf .modal .modal-content .bg01_batch p {
  padding-left: 30px;
  font-size: 0.875rem;
  font-weight: bold;
  text-align: left;
}

.main .pdf .modal .modal-content .bg01_batch i {
  font-size: 2.5rem;
  color: #919191;
}

.main .pdf .modal .modal-content .btn_group {
  padding-top: 30px;
}

.main .pdf .modal .modal-content .btn_group button {
  width: 150px;
  border: 1px solid #919191;
  border-radius: 5px;
  padding: 8px 0;
  background: #fff;
  position: relative;
  font-weight: bold;
  text-align: left;
  text-indent: 10px;
}

.main .pdf .modal .modal-content .btn_group button::after {
  font-family: "Font Awesome 5 Free";
  color: #919191;
  font-size: 23px;
  position: absolute;
  right: 10px;
  top: 5px;
}

.main .pdf .modal .modal-content .btn_group button:first-of-type::after {
  content: "\f019";
}

.main .pdf .modal .modal-content .btn_group button:last-of-type::after {
  content: "\f2ea";
}

.main .play_list {
  padding-bottom: 190px;
}

.main .play_list h1 p:first-of-type {
  max-width: 230px;
  width: 100%;
  clear: both;
  text-align: right;
  padding: 0;
}

.main .play_list h1 p:first-of-type span {
  width: 160px;
  display: inline-block;
  text-align: center;
  padding: 2px 0;
}

.main .play_list h1 p:last-of-type span {
  border-left: 2px solid #333;
  padding-left: 10px;
}

.main .play_list p.play_txt {
  font-size: 1.125rem;
  line-height: 1.625rem;
  padding-bottom: 28px;
}

.main .play_list p.play_txt span {
  font-weight: bold;
}

.main .play_list p.play_txt span:first-of-type {
  display: inline-block;
  padding: 2px 5px;
  border: 1px solid #333;
  border-radius: 50%;
  color: #333;
}

.main .play_list p.play_txt span:last-of-type {
  border: 1px solid #333;
  display: inline-block;
  padding: 0 5px;
  border-radius: 3px;
  border-left: 0;
  position: relative;
  left: -12px;
  text-indent: 8px;
  line-height: 1.5rem;
}

.main .play_list .lesson_btn_gp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.main .play_list .lesson_btn_gp .dynamic-button {
  background-color: #d3d3d3;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  margin-right: 10px;
  padding: 8px 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
  cursor: pointer;
  font-family: 'Hiragino Kaku Gothic Pro';
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: normal;
}

.main .play_list .lesson_btn_gp .dynamic-button.active {
  background-color: #f8deca;
  font-weight: bold;
}

.main .play_list .lesson_btn_gp .dynamic-button:last-child {
  margin-right: 0;
}

.main .play_list .audio_list {
  padding-top: 10px;
}

.main .play_list .audio_list ul {
  display: block;
}

.main .play_list .audio_list ul li {
  width: 100%;
}

.main .play_list .audio_list ul li .audio_block {
  display: block;
  border: 1px solid #808080;
  padding: 20px;
  margin-bottom: 15px;
}

.main .play_list .audio_list ul li .audio_block p {
  width: 100%;
  text-align: left;
  padding: 0 40px 10px 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 1rem;
  line-height: 1.625rem;
  font-weight: bold;
}

.main .play_list .audio_list ul li .audio_block p:before {
  content: '\f028';
  font-family: "Font Awesome 5 Free";
  color: #000;
  font-size: 1.25rem;
  font-weight: bold;
  padding-right: 12px;
}

.main .play_list .audio_list ul li .audio_block p .mp3_lesson_name {
  padding-right: 12px;
  display: inline-block;
  width: 180px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.main .play_list audio {
  background: #f1f3f4;
  width: 100%;
  height: 25px;
}

.main .batch_download {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  color: #333333;
  display: -ms-grid;
  display: grid;
  width: 22.779%;
  margin-bottom: 50px;
}

.main .batch_download .download {
  border-radius: 3px;
  margin-top: 30px;
}

.main .batch_download .download .cm_color {
  background: #666666;
}

.main .lesson_text {
  width: 100%;
  line-height: 1.625rem;
  font-weight: bold;
  position: relative;
  text-align: left;
}

.main .lesson_text h5, .main .lesson_text h4 {
  padding: 10px 0;
  font-size: 1.0625rem;
}

.main .lesson_text h5 span:first-of-type,
.main .lesson_text h4 span:first-of-type {
  font-size: 1.125rem;
  display: block;
}

.main .lesson_text h5 span:last-of-type,
.main .lesson_text h4 span:last-of-type {
  font-size: 0.875rem;
  display: block;
  padding-top: 5px;
}

.main .cover {
  width: 100%;
  margin-top: 8px;
}

.main .cover p {
  font-size: 1.125rem;
  font-weight: bold;
}

.main .cover p.size {
  font-size: 0.875rem;
  line-height: 1.6875rem;
  font-weight: normal;
  color: #fff;
}

.main .cover .download_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  color: #fff;
  margin-top: 6px;
  padding: 5px 0;
  background: #1c8819;
}

.main .cover .download_item p {
  padding-left: 15px;
}

.main .cover .download_item span {
  font-size: 1.25rem;
  padding-right: 15px;
}

.main .cover a.link {
  font-size: 0.875rem;
  line-height: 1.625rem;
  background: #005bc2;
  color: #fff;
  padding: 5.5px 5px 5.5px 10px;
  margin-top: 6px;
  border-radius: 0;
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.main .cover a.link:after {
  content: '\f105';
  padding: 0;
  font-size: 1rem;
  position: absolute;
  right: 10px;
}

.main .img_block {
  width: 100%;
  margin-top: auto;
}

.main .img_block.mt-unset {
  margin-top: initial;
}

.main .img_block.mar_btn {
  margin-bottom: 46px;
}

.main .img_block figure {
  width: 100%;
  border: 1px solid #ddd;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.main .img_block figure.n_bdr {
  border: none;
}

.main .section_download {
  clear: both;
}

.main .section_download ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 2.964% 1fr 2.964% 1fr 2.964% 1fr;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 30px 2.964%;
  padding-top: 30px;
}

.main .section_download ul.txt_list {
  display: block;
}

.main .section_download ul.txt_list li {
  margin-top: 10px;
}

.main .section_download ul.txt_list li .text_link_item {
  text-align: left;
  text-decoration: underline;
  color: #0000ff;
  font-size: 1.125rem;
  line-height: 1.625rem;
}

.main .section_download ul li .topic {
  width: 100%;
}

.main .section_download ul li .topic h3 {
  color: #fff;
  text-align: left;
  display: -webkit-box;
  line-height: inherit;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
}

.main .section_download ul li .topic h3 span {
  padding: 15px 0;
}

.main .section_download ul li .topic h3 span:first-of-type {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  text-align: center;
  width: 70px;
  background: #000;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-top-left-radius: 30px;
  font-size: 80%;
}

.main .section_download ul li .topic h3 span:last-of-type {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  width: 100%;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 10px 5px 10px 10px;
  word-break: break-word;
}

.main .section_download ul.cm_list {
  width: 100%;
}

.main .section_download ul.cm_list li .img_block.mar_btm {
  margin-bottom: 46px;
}

.main .lesson ul {
  margin: 0 auto;
}

.main .lesson ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 30px;
}

.main .lesson ul li button {
  margin-left: 20px;
  border-radius: 50px;
  width: 120px;
  height: 54px;
}

.main .news .notice_list {
  padding: 10px 0 80px 0;
}

.main .news .notice_list dl {
  font-size: 1.125rem;
  line-height: 1.625rem;
  text-align: left;
  padding: 26px 0;
  border-bottom: 1px solid rgba(179, 179, 179, 0.5);
}

.main .news .notice_list dl dd {
  padding-top: 15px;
}

.main .news .notice_list dl dd a {
  text-decoration: underline;
  color: blue;
}

.main .news .notice_list dl dd a.text-red {
  font-size: 1.25rem;
}

.main .news .notice_list dl dd img {
  width: auto;
  margin-top: .2rem;
  margin-left: .2rem;
}

.main .about {
  padding-bottom: 80px;
  text-align: left;
}

.main .about #movie_corner {
  margin: 20px auto 10px;
  max-width: 480px;
  width: 80%;
}

.main .about #movie_corner .movie-wrap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.main .about #movie_corner .movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.main .about h1 {
  padding-left: 15px;
}

.main .about h1:before {
  content: '';
  display: block;
  width: 5px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #e94609), color-stop(0%, #f49fa1));
  background-image: linear-gradient(#e94609 50%, #f49fa1 0%);
  position: relative;
  display: inline-block;
  top: 10px;
  left: -15px;
}

.main .about h2 {
  font-size: 1.85rem;
  line-height: 1.25;
  padding: 15px 20px 15px 0px;
  display: inline-block;
  float: left;
  margin: 15px 0 35px 0;
  color: #e94609;
}

.main .about ul.link {
  margin-bottom: 54px;
}

.main .about ul.link li {
  display: block;
  clear: both;
  text-align: left;
  margin-top: 10px;
}

.main .about ul.link li a {
  text-decoration: underline;
  padding-left: 15px;
  position: relative;
  line-height: 26px;
  font-size: 1.125rem;
}

.main .about ul.link li a:before {
  content: '\f105';
  font-family: "Font Awesome 5 Free";
  font-size: 1rem;
  font-weight: bold;
  color: #e74119;
  position: absolute;
  left: 0px;
}

.main .about .text h3 {
  padding: 10px 15px 10px 15px;
  background: #ea4609;
  color: #fff;
  margin: 20px 0;
  font-size: 1.25rem;
  line-height: 1.625rem;
}

.main .about .text h4 {
  font-size: 1.25rem;
  line-height: 1.625rem;
  position: relative;
  margin-bottom: 20px;
}

.main .about .text h4 span {
  display: inline-block;
  background: #e94609;
  font-size: 1.125rem;
  color: #fff;
  padding: 2px 6px;
  text-align: center;
  margin-right: 15px;
}

.main .about .text p {
  font-size: 1.125rem;
  line-height: 1.625rem;
  text-align: left;
  padding-bottom: 30px;
}

.main .about .text p span {
  font-size: 0.875rem;
  display: block;
}

.main .about .text a {
  text-decoration: underline;
  color: #005bc2;
}

.main .about .text dl {
  font-size: 1.125rem;
  line-height: 1.625rem;
}

.main .about .text dl dt {
  text-align: left;
  margin-bottom: 20px;
  position: relative;
  padding-left: 15px;
  font-weight: bold;
}

.main .about .text ul {
  list-style: none;
  counter-reset: item;
}

.main .about .text ul li {
  counter-increment: item;
  display: block;
  position: relative;
  padding-left: 35px;
  line-height: 1.625rem;
  font-size: 1.125rem;
}

.main .about .text ul li p {
  padding-bottom: 20px;
}

.main .about .text ul li p:first-of-type {
  font-weight: bold;
}

.main .about .text ul li p:first-of-type:before {
  content: counter(item);
  background: #e94609;
  border-radius: 50%;
  color: white;
  font-size: 16px;
  font-weight: normal;
  width: 26px;
  height: 26px;
  text-align: center;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: absolute;
  left: 0;
}

.main .about .text ul li .list_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 30px;
}

.main .about .text ul li .list_block .list {
  border: 1px solid #808080;
  width: 100%;
  padding: 20px;
}

.main .about .text ul li .list_block .list:first-of-type {
  margin-right: 30px;
}

.main .about .text ul li .list_block .list p {
  text-align: center;
  color: #ec571d;
  font-weight: bold;
}

.main .about .text ul li .list_block .list p:before {
  content: none;
}

.main .about .text ul li .list_block .list ul {
  list-style-type: decimal;
  padding: 0 0 0 20px;
}

.main .about .text ul li .list_block .list ul li {
  display: list-item;
  padding: 0;
}

.main .about .text ul li ul {
  list-style-type: decimal;
  padding: 0 0 0 20px;
}

.main .about .text ul li ul li {
  padding-left: 0;
  display: list-item;
  margin-bottom: 20px;
}

.main .about .text ul li ul li img {
  width: 16px;
}

.main .about .text ul li ul li p:first-of-type {
  font-weight: normal;
}

.main .about .text ul li ul li p:first-of-type:before {
  content: none;
}

.main .about .text ul li ul li p.icon_txt {
  position: relative;
  padding-bottom: 0;
}

.main .about .text ul li ul li p.icon_txt img {
  width: 22px;
  position: relative;
  top: 3px;
}

.main .about .text ul li ul li span {
  background: #ec571d;
  width: 20px;
  height: 20px;
  font-size: 0.875rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  border-radius: 50%;
  color: #fff;
}

.main .about .text .structure {
  margin-top: 40px;
}

.main .about .text .structure .section_list dl {
  padding-left: 20px;
  position: relative;
  margin-bottom: 20px;
}

.main .about .text .structure .section_list dl:before {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #333333;
  position: absolute;
  left: 0;
  top: 6px;
}

.main .about .text .structure .section_list dl dt {
  margin-bottom: 0;
}

.main .about .text .structure ul li {
  display: block;
  margin-bottom: 20px;
  position: relative;
  padding-left: 20px;
}

.main .about .text .structure ul li:before {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #333333;
  position: absolute;
  left: 0;
  top: 6px;
}

.main .about .text .structure ul li p {
  padding: 0;
}

.main .about .text .structure ul li p:first-of-type {
  font-weight: bold;
}

.main .about .text .structure ul li p:first-of-type:before {
  content: normal;
}

.main .about .text .structure dl dt {
  padding-left: 0;
}

.main .about .text .structure dl dt::before {
  content: none;
}

.main .about .text .activity {
  margin-top: 80px;
}

.main .about .text .activity dl {
  margin-top: 30px;
}

.main .about .text .activity dl dt {
  padding-left: 0;
  margin-bottom: 0;
  font-size: 1.25rem;
  line-height: 1.625rem;
  color: #e94609;
}

.main .about .text .activity dl dt:before {
  content: none;
}

.main .about .text .activity dl dd p {
  margin-top: 20px;
}

.main .about .text .activity dl.type dt {
  font-size: 1.25rem;
  line-height: 1.625rem;
  margin-top: 20px;
}

.main .about .text .activity dl.type dd p {
  padding-bottom: 0;
}

.main .about .text .activity dl.type dd dl dt {
  padding-left: 18px;
  font-size: 1.125rem;
  line-height: 1.625rem;
  position: relative;
  color: #000;
}

.main .about .text .activity dl.type dd dl dt span {
  width: 24px;
  display: inline-block;
  position: relative;
  top: 5px;
  left: 10px;
}

.main .about .text .activity dl.type dd dl dt span img {
  margin: 0;
}

.main .about .text .activity dl.type dd dl dt:before {
  content: "";
  display: inline-block;
  padding: 12px;
  position: relative;
  top: 5px;
  left: -15px;
}

.main .about .text .activity dl.type dd dl dt:nth-of-type(1):before {
  background: url(../img/icon_01.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activity dl.type dd dl dt:nth-of-type(2):before {
  background: url(../img/icon_02.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activity dl.type dd dl dt:nth-of-type(3):before {
  background: url(../img/icon_03.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activity dl.type dd dl dt:nth-of-type(4):before {
  background: url(../img/icon_04.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activity dl.type dd dl dd {
  margin: 10px 0 0 0;
}

.main .about .text .activity dl.common_activity p {
  padding-bottom: 0px;
}

.main .about .text .activity dl.common_activity dt {
  font-size: 1.25rem;
  line-height: 1.625rem;
}

.main .about .text .activity dl.common_activity dd dl {
  padding-left: 30px;
  margin-top: 0;
}

.main .about .text .activity dl.common_activity dd dl dt {
  display: list-item;
  list-style-type: decimal;
  font-size: 1.125rem;
  line-height: 1.625rem;
  color: #000;
  margin-top: 20px;
}

.main .about .text .activity dl.common_activity dd dl dd {
  margin-bottom: 0px;
}

.main .about .text .activities_gp {
  margin-top: 30px;
}

.main .about .text .activities_gp h5 {
  background: #ffe3d8;
  padding: 12px 10px 12px 50px;
  position: relative;
  margin-bottom: 20px;
  font-size: 1.25rem;
}

.main .about .text .activities_gp h5:before {
  content: "";
  display: inline-block;
  padding: 12px;
  position: absolute;
  top: 13px;
  left: 15px;
}

.main .about .text .activities_gp .speaking h5:nth-of-type(1):before {
  background: url(../img/icon_01.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activities_gp .listening {
  margin-top: 20px;
}

.main .about .text .activities_gp .listening h5:before {
  background: url(../img/icon_02.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activities_gp .reading {
  margin-top: 20px;
}

.main .about .text .activities_gp .reading h5:before {
  background: url(../img/icon_03.png) no-repeat scroll center center/100% auto;
}

.main .about .text .activities_gp .writing {
  margin-top: 20px;
}

.main .about .text .activities_gp .writing h5:before {
  background: url(../img/icon_04.png) no-repeat scroll center center/100% auto;
}

.main .about .text .other_corner {
  margin-top: 60px;
}

.main .about .text .other_corner h4 {
  position: relative;
  margin-bottom: 20px;
}

.main .about .text .other_corner dl {
  margin-bottom: 25px;
}

.main .about .text .other_corner dl dt {
  padding: 10px 20px;
  background: #ffe3d8;
  position: relative;
  font-size: 1.25rem;
  line-height: 1.625rem;
}

.main .about .text .other_corner dl dd {
  margin-bottom: 0;
}

.main .about .text .other_corner dl dd img {
  width: 16px;
  margin: 0;
}

.main .about .text .other_corner dl dd span {
  display: block;
  font-size: 0.875rem;
  margin-top: 20px;
}

.main .about .text .other_corner .word dl dd {
  margin-bottom: 20px;
}

.main .about .text .production {
  border-top: 1px solid #808080;
  padding-top: 40px;
}

.main .about .text .production p {
  font-size: 1.25rem;
  line-height: 1.625rem;
  font-weight: bold;
  padding-bottom: 0;
}

.main .about .text .production dl dt {
  margin: 20px 0 0 0;
  padding: 0;
  font-weight: normal;
}

.main .about .text .production dl dd {
  margin: 0;
}

.main .about .text.material span {
  font-size: 0.875rem;
  display: block;
}

.main .about .text.material dl {
  margin-top: 30px;
  clear: both;
}

.main .about .text.material dl dd {
  margin-bottom: 30px;
}

.main .about .text.material dl dd span {
  font-size: 0.875rem;
  display: block;
}

.main .about .text.material dl dd img {
  margin-top: 30px;
}

.main .about .text.material dl dd.mar_btm {
  margin-bottom: 0;
}

.main .about .text.material dl figure {
  margin: 20px 0 20px 0;
}

.main .about .text.material dl.book_list dd {
  padding-left: 20px;
  position: relative;
  margin-bottom: 10px;
}

.main .about .text.material dl.book_list dd:before {
  content: '\f14a';
  font-family: "Font Awesome 5 Free";
  font-size: 1rem;
  font-weight: bold;
  color: #333333;
  position: absolute;
  left: 0;
}

.main .about .text.material dl.book_list:last-of-type {
  margin-bottom: 40px;
}

.main .about .text.material dl dt:before {
  content: '';
  width: 5px;
  height: 25px;
  background: #e94609;
  position: absolute;
  display: inline-block;
  top: 0;
  left: 0;
}

.main .about .text .text_bubble_gp {
  margin-top: 45px;
}

.main .about .text .text_bubble_gp .text_bg .list {
  text-align: left;
  border-radius: 10px;
  position: relative;
  padding: 2.315% 1.853%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 1;
  float: left;
  margin-bottom: 100px;
}

.main .about .text .text_bubble_gp .text_bg .list::before {
  content: '';
  width: 0;
  height: 0;
  border-left: 33px solid transparent;
  border-right: 13px solid transparent;
  position: absolute;
  bottom: -106px;
}

.main .about .text .text_bubble_gp .text_bg .list::after {
  content: '';
  width: 0;
  height: 0;
  border-top: 105px solid #fff;
  position: absolute;
  bottom: -85px;
}

.main .about .text .text_bubble_gp .text_bg .list.a01_lst {
  border: 4px solid #df4b87;
  width: 41.13%;
  background: #ffe6f0;
}

.main .about .text .text_bubble_gp .text_bg .list.a01_lst::before {
  -webkit-transform: rotate(-5deg);
  transform: rotate(-5deg);
  right: 5%;
  border-top: 104.6px solid #df4b87;
  border-left: 50px solid transparent;
  border-right: 0px solid transparent;
}

.main .about .text .text_bubble_gp .text_bg .list.a01_lst::after {
  -webkit-transform: rotate(-9deg);
  transform: rotate(-9deg);
  right: 5.3%;
  border-top-color: #ffe6f0;
  border-left: 42px solid transparent;
  border-right: 9px solid transparent;
}

.main .about .text .text_bubble_gp .text_bg .list.a02_lst {
  border: 4px solid #fbcc0a;
  width: 57%;
  background: #fff5ce;
  float: right;
}

.main .about .text .text_bubble_gp .text_bg .list.a02_lst::before {
  -webkit-transform: rotate(-5deg);
  transform: rotate(-5deg);
  left: 25px;
  border-top: 140px solid #fbcc0a;
  border-left: 9.7px solid transparent;
  border-right: 42px solid transparent;
  left: 6.1%;
  bottom: -141.5px;
}

.main .about .text .text_bubble_gp .text_bg .list.a02_lst::after {
  -webkit-transform: rotate(-6deg);
  transform: rotate(-6deg);
  left: 28px;
  bottom: -110px;
  border-top: 130px solid #fff5ce;
  border-left: 7px solid transparent;
  border-right: 44px solid transparent;
  left: 6.5%;
}

.main .about .text .text_bubble_gp .text_bg .list p {
  font-weight: bold;
  font-size: 1.25rem;
  line-height: 1.625rem;
  padding-bottom: 0;
}

.main .about .text .text_bubble_gp .text_bg .list ul {
  list-style-type: disc;
  padding-left: 20px;
}

.main .about .text .text_bubble_gp .text_bg .list ul li {
  padding: 20px 0 0 0;
  display: list-item;
  font-size: 1rem;
  line-height: 1.5rem;
}

.main .about .text .text_bubble_gp .run {
  width: 52.9%;
  float: right;
  margin-right: 10%;
}

.main .about .text .text_bubble_gp .run figure {
  margin: -26% 0 60px 0;
  float: right;
}

.main .about .text .text_bubble_gp .run figure img {
  margin: 0;
}

.main .faq h1 {
  text-align: center;
  padding: 50px 0 30px 0;
}

.main .faq_inner {
  display: none;
  counter-reset: item;
  list-style-type: decimal;
  margin-bottom: 34px;
}

.main .faq .inner {
  font-size: 0.875rem;
  line-height: 1.25rem;
  text-align: left;
}

.main .faq .inner h2 {
  font-size: 1.25rem;
  line-height: 1.625rem;
  padding: 0;
  margin-bottom: 26px;
  position: relative;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.main .faq .inner h2:before {
  content: '';
  display: inline-block;
  min-width: 30px;
  height: 30px;
  background: url("../img/icon-accordion-open.png") no-repeat scroll center center/100% auto;
  margin-right: 20px;
  position: relative;
  top: -2px;
}

.main .faq .inner h2.tg_open:before {
  background: url("../img/icon-accordion-close.png") no-repeat scroll center center/100% auto;
}

.main .faq .inner dl {
  position: relative;
  padding: 30px 40px;
  border-top: 1px solid #cbcbcb;
  background: #f5f9f9;
  line-height: 1.625rem;
}

.main .faq .inner dl span {
  font-size: 1rem;
  position: absolute;
  font-weight: bold;
  left: 0;
}

.main .faq .inner dl a {
  color: #005bc2;
  text-decoration: underline;
  font-weight: bold;
}

.main .faq .inner dl dt {
  font-weight: bold;
  font-size: 1.125rem;
  cursor: pointer;
  position: relative;
  padding-left: 35px;
}

.main .faq .inner dl dt span {
  color: #e94609;
}

.main .faq .inner dl dd {
  padding: 21px 21px 21px 55px;
  display: none;
  background: #fff;
  position: relative;
  font-size: 1.125rem;
  margin-top: 15px;
}

.main .faq .inner dl dd span {
  color: #005bc2;
  left: 21px;
}

.main .faq .inner dl:first-of-type {
  border: 0;
}

.main .faq .inner dl .ext_link {
  color: #1865c5;
  font-weight: normal;
}

.main .faq .inner dl .ext_link:after {
  content: '';
  display: inline-block;
  min-width: 13px;
  height: 13px;
  background: url("../img/ext_link.png") no-repeat scroll center center/100% auto;
  position: relative;
  top: 1px;
  margin-left: 3px;
}

.main .faq .inner dl .local_link {
  color: #1865c5;
  font-weight: normal;
}

.main .faq .inner dl.adjust_padding dt {
  padding-left: 50px;
}

.main .faq .inner dl.adjust_padding dd {
  padding-left: 65px;
}

.main .faq .inner dl .pdf_link_txt {
  font-weight: normal;
}

.main .faq .inner p.remark {
  font-size: 1.125rem;
  padding-bottom: 50px;
  text-align: center;
}

.main .faq .inner .other_txt {
  padding-bottom: 80px;
}

.main .faq .inner .other_txt p {
  border: 0;
  padding: 0;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: normal;
}

.main .faq .inner .other_txt a {
  color: #005bc2;
  text-decoration: underline;
  font-weight: bold;
}

.main .info {
  text-align: left;
  padding-bottom: 110px;
}

.main .info p {
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding: 20px 0 30px 0;
}

.main .privacy {
  text-align: left;
  padding-bottom: 115px;
}

.main .privacy dl {
  padding-top: 30px;
}

.main .privacy dl dt {
  font-weight: bold;
  font-size: 1rem;
  line-height: 1.25rem;
}

.main .privacy dl dt span {
  font-weight: bold;
}

.main .privacy dl dd {
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding-top: 10px;
}

.main .privacy dl dd dl {
  padding: 0;
}

.main .privacy dl dd dl dt {
  padding-top: 30px;
}

.main .privacy dl dd dl dt:first-of-type {
  padding-top: 0;
}

.main .privacy dl dd dl dd ul {
  padding-bottom: 30px;
}

.main .privacy dl ul li {
  display: block;
  padding-left: 5px;
}

.main .privacy p {
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding-bottom: 20px;
}

.main .privacy p.fz_16 {
  font-size: 1rem;
  line-height: 1.625rem;
  padding: 40px 0;
}

.main .privacy .member dl dd p {
  padding-bottom: 5px;
}

.main .privacy .member dl dd dl {
  padding: 0;
}

.main .privacy .member dl dd dl dt {
  padding-top: 30px;
}

.main .privacy .member dl dd dl dt:first-of-type {
  padding-top: 0;
}

.main .privacy .member dl dd dl dd ul {
  padding-bottom: 30px;
}

.main .sitemap {
  padding-bottom: 110px;
}

.main .sitemap h1 {
  padding: 30px 0 0 15px;
}

.main .sitemap h1:before {
  content: '';
  display: block;
  width: 5px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #e94609), color-stop(0%, #f49fa1));
  background-image: linear-gradient(#e94609 50%, #f49fa1 0%);
  position: relative;
  display: inline-block;
  top: 10px;
  left: -15px;
}

.main .sitemap h2 {
  font-size: 1.125rem;
  line-height: 1.625rem;
  padding-left: 15px;
}

.main .sitemap h2:before {
  content: '';
  display: block;
  width: 5px;
  height: 25px;
  background: #e94609;
  position: relative;
  display: inline-block;
  top: 6px;
  left: -15px;
}

.main .sitemap .text {
  text-align: left;
}

.main .sitemap .text a {
  font-size: 1.25rem;
  line-height: 1.625rem;
  text-decoration: underline;
  margin-top: 30px;
  display: block;
}

.main .sitemap .text .link_gp {
  margin-bottom: 30px;
}

.main .sitemap .text .link_gp p {
  font-size: 1.125rem;
  line-height: 1.625rem;
  margin-top: 30px;
  padding-left: 30px;
  position: relative;
}

.main .sitemap .text .link_gp p:before {
  content: '';
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 8px solid #000;
  position: absolute;
  left: 0;
  top: 6px;
}

.main .sitemap .text .link_gp a {
  font-size: 1.125rem;
  line-height: 1.625rem;
  margin-top: 0;
}

.main .sitemap .text .link_gp a.upper_link {
  margin-top: 15px;
}

.main .sitemap .text .link_gp ul {
  margin-top: 15px;
  max-width: 950px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.main .sitemap .text .link_gp ul li {
  padding: 5px 0;
  max-width: 105px;
  width: 100%;
}

.main .sitemap .text .link_gp ul.one_link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.main .sitemap .text .link_gp ul.one_link li {
  display: block;
  max-width: 100%;
}

.main .sitemap .text .other_link h2 {
  padding: 0 0 10px 15px;
}

.main .sitemap .text .other_link ul li {
  display: block;
  width: 100%;
}

.main .sitemap .text .other_link ul li a {
  font-size: 1.125rem;
  line-height: 2.5rem;
  margin: 0;
}

.main .edition {
  margin-bottom: 70px;
}

.main .edition .inner .inner_block ul li {
  text-align: left;
  width: 100%;
  margin-bottom: 20px;
  font-size: 1.125rem;
  line-height: 1.625rem;
}

.main .edition .inner .inner_block ul li a {
  color: blue;
}

.main .edition .inner .inner_block p.ver-txt {
  text-align: left;
  font-size: 1.125rem;
  line-height: 1.625rem;
  margin-top: 50px;
}

.main .resources .section_download.worksheet_item .lesson_text h4 {
  min-height: 40px;
}

.main .resources .section_download.worksheet_item .cm_list {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.main .resources .section_download ul.cm_list li:nth-of-type(3) .bn_block .rem_link {
  max-width: 195px;
  width: 78.45%;
  margin: 0 auto;
}

.main .resources .section_download .section-banner{ margin-top: 40px; text-align: left; }
.main .resources .section_download .section-banner img{ width: 50%; }

.main .resources h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.main .resources h2:before {
  top: 0;
}

.main .resources h2:first-of-type {
  margin-top: 20px;
}

.child-category-block h3 {
  font-size: 1.2rem;
  text-align: left;
  line-height: 1.625rem;
  margin: 30px 0 0 0;
  color: #333333;
  position: relative;
  border-left: 5px solid #e94609;
  padding-left: 7px;
  z-index: -1;
}

.grandchild-category-block h4 {
  font-size: 1.2rem;
  text-align: left;
  line-height: 1.625rem;
  padding: 0 0 0 20px;
  color: #333333;
  margin-top: 40px;
}

/* Start counter on the parent wrapper */
.child-category-block {
  counter-reset: section-number;
}

/* Each grandchild block increases the counter */
.grandchild-category-block h4 {
  position: relative;
  padding-left: 40px;
  /* space for number box */
  font-weight: 600;
}

/* Number box */
.grandchild-category-block h4::before {
  counter-increment: section-number;
  content: counter(section-number);
  position: absolute;
  left: 0;
  top: 0;
  width: 28px;
  height: 28px;
  background: #e94609;
  /* your orange */
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  font-weight: bold;
  border-radius: 3px;
}

.main .resources .lesson_text.hidden {
  display: none;
}

.main .resources p.capt {
  padding-top: 15px;
  color: #333;
}

.main .resources .section_download {
  /* margin-bottom: 30px; */
}

.main .illust_list .img_list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding-bottom: 10%;
}

.main .illust_list .img_list ul li {
  width: 15%;
  margin-right: 2%;
  margin-bottom: 3.242%;
}

.main .illust_list .img_list ul li p {
  font-size: 1rem;
  text-align: left;
  margin-top: 10px;
  overflow-wrap: anywhere;
  word-wrap: break-word;
}

.main .illust_list .img_list ul li p.size {
  display: none;
}

.main .illust_list .modal {
  padding-top: 0;
}

.main .illust_list .modal .modal-content {
  overflow-y: scroll;
  -ms-overflow-style: none;
  max-width: 463px;
  width: 100%;
  padding: 56px 31px 31px;
  scrollbar-width: none;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.main .illust_list .modal .modal-content::-webkit-scrollbar {
  display: none;
}

.main .illust_list .modal .modal-content .btn_group {
  padding-top: 10px;
}

.main .illust_list .modal .modal-content #img_download {
  cursor: pointer;
}

.main .illust_list .modal .modal-content .bg01_batch {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background: #005bc2;
  max-width: 100%;
  padding: 9px 14px;
  border-radius: 4px;
}

.main .illust_list .modal .modal-content .bg01_batch p {
  padding-left: 0;
}

.main .illust_list .modal .modal-content .bg01_batch p, .main .illust_list .modal .modal-content .bg01_batch i {
  color: #fff;
}

.main .illust_list .modal .modal-content .bg01_batch i {
  font-size: 2rem;
}

.main .illust_list .modal .modal-content .bg01_batch span {
  display: block;
}

.main .illust_list .modal .modal-content .bg01_batch span.img_name {
  font-weight: normal;
  font-size: 1.125rem;
  overflow-wrap: anywhere;
  word-wrap: break-word;
  word-break: break-all;
}

.main .illust_list .modal .modal-content .bg01_batch span.img_size {
  top: 0;
}

.main .illust_list .modal .modal-content span.close {
  position: absolute;
  right: 13px;
  top: 13px;
  width: 35px;
  height: 35px;
  background: #005bc2;
}

.main .illust_list .modal .modal-content span.close:before, .main .illust_list .modal .modal-content span.close:after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  content: ' ';
  height: 29.12px;
  width: 2px;
  background-color: #fff;
}

.main .illust_list .modal .modal-content span.close:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.main .illust_list .modal .modal-content span.close:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.teach .vd_note {
  margin: 30px 0;
  position: relative;
  padding-left: 20px;
}

.teach .vd_note a {
  text-decoration: underline;
  color: #0000ff;
}

.teach .vd_note span {
  position: absolute;
  left: 0;
}

.teach .title_line {
  padding-bottom: 0 !important;
}

.teach h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.teach h2:before {
  top: 0 !important;
  min-width: 3px !important;
  width: auto !important;
}

.teach .img_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
  width: 100%;
  border: 1px solid #ddd;
}

.teach .img_block figure {
  border: 0;
}

.teach .img_block a {
  width: 100%;
  height: 100%;
  display: block;
}

.teach .cm_list {
  -ms-grid-columns: 2fr 2fr !important;
  grid-template-columns: 2fr 2fr !important;
}

.teach .youtube_layer .youtube {
  position: relative;
  padding-bottom: 56.2%;
  width: 100%;
}

.teach .youtube_layer .youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
}

.teach .section_download .sub_container .sub_content:first-child .sub_title {
  padding-top: 30px;
}

.teach .section_download .sub_container .sub_content .sub_title {
  font-size: 20px;
  line-height: normal;
  text-align: left;
  padding-top: 50px;
}

.teach .section_download .sub_container .sub_content .sub_title::before {
  content: '◆';
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 16px;
  line-height: normal;
  margin-right: 5px;
  color: #ff0000;
}

.teach .section_download .sub_container .sub_content .desc_txt {
  margin-top: 5px;
}

.footer {
  margin: 0 auto;
  padding: 0 15px;
  background: #333333;
  color: #fff;
  padding: 60px 0px 60px 0px;
}

.footer .site {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-bottom: 50px;
  font-size: 1rem;
  line-height: 1.75rem;
}

.footer .site a {
  color: #fff;
}

.footer .site a span::before {
  top: 7px;
}

.footer .site a::after {
  padding: 0 10px;
  content: '>';
  display: inline-block;
}

.footer .site a:first-of-type {
  margin-right: 20px;
}

.footer .ft_banner ul {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.footer .ft_banner ul li {
  max-width: 180px;
  width: 30.944%;
}

.footer .ft_banner figure {
  margin-bottom: 0;
}

.footer .ft_banner ul li:last-child {
  margin-left: 10px;
}

.footer .cp-right {
  font-size: 0.6875rem;
  line-height: 1.75rem;
  padding-top: 40px;
}

.footer_in {
  display: grid;
  grid-gap: 10px;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}

.footer_in .footer_in_col {
  font-size: 1rem;
}

.footer_in_col:last-child {
  text-align: left;
}

.footer_in_col:last-child h3 {
  font-size: 1.5rem;
  display: block;
  margin-bottom: 20px;
}

.footer_in_col:last-child p {
  /* display: block; */
  padding-bottom: 10px;
}

.gmail,
.address {
  position: relative;
  display: flex;
}

.address::before {
  content: '\f3c5';
  font-family: "Font Awesome 5 Free";
  color: rgba(32, 68, 149, 1);
  font-size: 1.1rem;
  padding-right: 10px;
  font-weight: bold;
  color: #fff;
}

.gmail::before {
  content: '\f0ac';
  font-family: "Font Awesome 5 Free";
  color: rgba(32, 68, 149, 1);
  font-size: 1.1rem;
  padding-right: 10px;
  font-weight: bold;
  color: #fff;
  position: relative;
  top: 2px;
}

#cookieWarnBox {
  padding: 22px 0px;
}

#cookieWarnBox.loaded .text {
  max-width: 1080px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: left;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

#cookieWarnBox .btn {
  height: 30px;
  padding: 0 20px;
}

.pr_movie {
  margin-top: 20px;
}

.pr_movie a {
  display: block;
}

.pr_movie .pr_movie_inner {
  max-width: 236px;
  width: 100%;
  margin: 0 auto;
  background-color: #f7c6c7;
  padding: 13px;
  border-radius: 8px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: #1a1a1a70 0px 5px 15px;
  box-shadow: #1a1a1a70 0px 5px 15px;
}

.pr_movie .pr_movie_inner .pr_item {
  background-color: #fff;
  padding: 5px;
  border-radius: 5px;
}

.pr_movie .pr_movie_inner .pr_item figure {
  display: block;
  line-height: 0;
}

.pr_movie .pr_movie_inner .pr_item p {
  font-size: 0.9375rem;
  line-height: 1.25rem;
  font-weight: 900;
  font-family: 'Noto Sans JP', sans-serif;
  margin-top: 3px;
  color: #3f2b15;
  text-align: center;
  padding-bottom: 0;
}

.br_rb {
  display: none;
}

@media only screen and (min-width: 768px) {
  .en .br_rb {
    display: none;
  }

  .ua_header ul li {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    height: 26px;
  }

  .ua_header ul li a:hover {
    border-bottom: 4px solid #e94609;
  }

  .sp {
    display: none;
  }

  header .menu_list {
    display: none;
  }

  header ul li:first-child {
    width: 303px;
  }

  .navbar {
    -webkit-transition-duration: .3s;
    transition-duration: .3s;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
    transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
  }

  .navbar .toggle {
    display: none;
  }

  .logo-img-active, .logo-img-main {
    -webkit-transition-duration: .4s;
    transition-duration: .4s;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
    transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
  }

  .nav-item-child {
    -webkit-transition-duration: .3s;
    transition-duration: .3s;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
    transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
  }

  .main .bn_block a {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    display: contents;
  }

  .main .container .ele_btn ul li {
    min-width: 180px;
    margin-bottom: 10px;
  }

  .main .play_list .audio_list {
    max-width: 750px;
  }

  .main .cover a:hover {
    opacity: 0.7;
  }

  .main .cover a:hover .download_item:hover {
    opacity: 0.7;
  }

  .main .news_update .inner .text_link div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .main .illust_list .img_list ul li:nth-child(6n) {
    margin-right: 0;
  }

  .main .illust_list .modal .modal-content span.close:hover {
    opacity: 0.7;
  }

  .main .illust_list .modal .modal-content #img_download:hover {
    opacity: 0.7;
  }

  .main .teach .section_download h2 {
    padding-top: 90px;
  }

  .main .teach .section_download h2:first-of-type {
    padding-top: 30px;
  }

  .main .teach .lesson_text h4 {
    font-size: 1rem;
  }

  .main .teach .cm_list li .img_block {
    max-width: 480px;
    width: 91.223%;
  }

  .main .ua_btn_gp ul li a:after {
    content: none;
  }

  .en .about .text .text_bubble_gp .text_bg .list {
    margin-bottom: 125px;
  }

  .en .teach .lesson_text h4 {
    font-size: 1.0625rem;
  }

  .top {
    position: relative;
  }
}

@media only screen and (min-width: 768px) and (max-width: 900px) {
  :root {
    font-size: 80%;
  }

  .main .btn-group ul li a::after {
    margin-right: 8px;
  }

  .main .btn-group ul li:first-of-type {
    padding: 10px 0;
  }

  .main .about .text ul li .list_block .list {
    max-width: 525px;
  }

  .main .img_block.mar_btn {
    margin-bottom: 40.4px;
  }

  .main .play_list .lesson_btn_gp .dynamic-button {
    line-height: 1.444rem;
  }
}

@media only screen and (min-width: 1116px) {
  .main .about .text .text_bubble_gp .run figure {
    margin: -28% 0 60px 0;
  }
}

@media only screen and (min-width: 1068px) and (max-width: 1115px) {
  .en .about .text .text_bubble_gp .run figure {
    margin: -22% 0 60px 0;
  }
}

@media only screen and (min-width: 901px) and (max-width: 910px) {
  .en .about .text .text_bubble_gp .run figure {
    margin: -30% 0 60px 0;
  }
}

@media only screen and (min-width: 877px) and (max-width: 900px) {
  .en .about .text .text_bubble_gp .run figure {
    margin: -23% 0 60px 0;
  }
}

@media only screen and (min-width: 768px) and (max-width: 870px) {
  .main .about .text .text_bubble_gp .text_bg .list.a01_lst::after {
    right: 5.5%;
    border-right: 8px solid transparent;
  }

  .main .about .text .text_bubble_gp .text_bg .list.a02_lst::after {
    left: 6.7%;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1200px) {
  .pr_movie .pr_close {
    width: calc(35 / 1200 * 100vw);
    height: calc(35 / 1200 * 100vw);
    top: calc(16 / 1200 * 100vw);
    right: calc(-16 / 1200 * 100vw);
  }

  .pr_movie .pr_movie_inner {
    max-width: calc(236 / 1200 * 100vw);
    padding: calc(13 / 1200 * 100vw);
    border-radius: calc(8 / 1200 * 100vw);
  }

  .pr_movie .pr_movie_inner .pr_item p {
    font-size: calc(15 / 1200 * 100vw);
    line-height: calc(20 / 1200 * 100vw);
  }

  .ua_btn_gp ul li a {
    font-size: calc(16 / 1120 * 100vw);
  }

  .main.en .txt_link_gp h2 {
    font-size: calc(24 / 1200 * 100vw);
    line-height: calc(26 / 1200 * 100vw);
  }
}

@media only screen and (min-width: 768px) and (max-width: 1050px) {
  .br_rb {
    display: block;
  }
}

@media only screen and (width < 768px) {
  * {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }

  .main .resources .section_download .section-banner{ margin-top: 0; margin-bottom: 15px; }

  #cookieWarnBox.loaded .text {
    padding: 0 15px;
  }

  .main .news_update .row {
    margin-bottom: 0;
  }

  .footer_in {
    display: block;
  }

  .footer_in_col:last-child p {
    font-size: 0.9rem;
  }

  .footer_in_col:last-child h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
    text-align: center;
  }

  .footer .site a:first-of-type {
    margin-right: 0;
  }

  .footer .inner {
    padding: 0;
  }

  body {
    position: relative;
  }

  .pc {
    display: none;
  }

  .cse .gsc-control-cse, .gsc-control-cse {
    width: 100% !important;
    padding: 0;
  }

  .pd-btm-sm20 {
    padding-bottom: 20px !important;
  }

  .title_line {
    padding-left: 10px !important;
  }

  .title_line:before {
    width: 3px;
    height: 25px;
    top: 6px;
  }

  .img_size {
    font-size: 12px !important;
  }

  .header .gsc-input-box {
    padding: 0;
  }

  .header form.gsc-search-box {
    padding: 0 10px;
  }

  .header ul li .menu_nav button {
    padding: 10px 15px 11px 15px;
  }

  .header table.gsc-search-box td.gsib_b {
    width: 10px;
  }

  .header {
    padding-bottom: 10px;
  }

  .header .Jft_logo {
    max-width: 280px;
    margin-left: 15px;
  }

  .header ul {
    padding-top: 20px;
    display: block;
  }

  .header ul li {
    padding: 0;
    width: 100%;
  }

  .header ul li .lang_sel_top {
    position: absolute;
    top: 18px;
    right: 60px;
  }

  .header ul li .menu_nav {
    width: 100%;
    float: right;
  }

  .header ul li .menu_nav input {
    width: 100%;
  }

  .header ul li .toggle {
    width: 30px;
    height: 35px;
    opacity: 0;
    border: none;
    position: absolute;
    top: 15px;
    right: 13px;
    z-index: 1000;
    float: right;
    padding: 9px 10px;
    margin-bottom: 8px;
    border: 1px solid transparent;
    border-radius: 4px;
    cursor: pointer;
  }

  .header ul li .menu_nav {
    padding: 30px 15px 0 15px;
    text-align: center;
    width: 100%;
    height: 0px;
    display: none;
    overflow: hidden;
    -webkit-transition: height 300ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
    transition: height 300ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
    margin-top: 25px;
    min-height: calc(100vh - 60px);
    overflow-y: scroll;
    visibility: visible;
    -webkit-transform: translateZ(0px);
    transform: translateZ(0px);
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
  }

  .header ul li ::-webkit-scrollbar {
    display: none;
  }

  .header ul li .toggle:checked~.menu_nav {
    height: 100%;
    position: absolute;
    z-index: 9999;
    display: block;
    background: #fff;
    left: 0;
    right: 0;
    visibility: visible;
    -webkit-transform: translateZ(0px);
    transform: translateZ(0px);
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
  }

  .header ul li .toggle+label {
    position: absolute;
    top: 15px;
    right: 15px;
  }

  .header ul li .toggle+label:after {
    content: '\2630';
    font-size: 30px;
  }

  .header ul li .toggle:checked~.message {
    height: 150px;
  }

  .header ul li .toggle:checked+label:after {
    content: '\2573';
    font-size: 30px;
  }

  .header ul li:first-child {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .header ul li:last-child {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .header .menu_list {
    margin-top: 20px;
  }

  .header .menu_list ul {
    padding: 0;
    border-top: 1px solid #cccccc;
  }

  .header .menu_list ul li {
    width: 100%;
    border-bottom: 1px solid rgba(216, 216, 216, 1);
    text-align: left;
    position: relative;
  }

  .header .menu_list ul li a {
    width: 100%;
    display: block;
    padding: 10px 10px 10px 10px;
  }

  .header .menu_list ul li a.link::after {
    content: '\f105';
    font-family: "Font Awesome 5 Free";
    color: #333;
    font-size: 1.125rem;
    font-weight: bold;
    position: absolute;
    right: 10px;
  }

  .header .menu_list ul.sub_list {
    display: none;
  }

  .header .menu_list ul.sub_list li:first-of-type {
    text-align: center;
    padding: 10px 10px 10px 20px;
  }

  .header .menu_list ul.sub_list li:first-of-type a {
    padding: 0;
  }

  .header .menu_list ul.sub_list li:first-of-type a::before {
    content: '\f104';
    font-family: "Font Awesome 5 Free";
    color: #333;
    font-size: 1.125rem;
    font-weight: bold;
    position: absolute;
    left: 20px;
  }

  .bor-top {
    border-width: 1px;
  }

  h2 {
    font-size: 0.9375rem;
    line-height: 0.9375rem;
  }

  .ua_header {
    padding: 26.2px 20px 26.2px 0;
    height: 74.8px;
  }

  .ua_header .Jft_logo {
    max-width: 280px;
    margin-left: 15px;
    position: relative;
    top: -5px;
  }

  .ua_header ul li {
    margin-right: 20px;
  }

  #cookieWarnBox {
    font-size: 0.75rem;
  }

  .wordlists_audio .main .play_list .audio_list ul li .audio_block p .mp3_lesson_name {
    width: 110px;
  }

  .main .txt_link_gp {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 0;
    margin-bottom: 30px;
  }

  .main .txt_link_gp h2 {
    margin-top: 0;
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .main .txt_link_gp .ua_btn_gp {
    min-width: 100%;
    width: 100%;
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }

  .main .txt_link_gp .ua_btn_gp ul li {
    margin-top: 20px;
    max-width: 100% !important;
    min-width: 100%;
    width: 100% !important;
  }

  .main .txt_link_gp .ua_btn_gp ul li:first-child {
    margin-top: 0;
  }

  .main .txt_link_gp .ua_btn_gp ul li a {
    font-size: 0.875rem;
    padding: 5px 28px 5px 5px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }

  .main .txt_link_gp .ua_btn_gp ul li a:after {
    right: 10px;
    font-size: 1rem;
  }

  .main .pdf_link_txt {
    padding-top: 10px;
    font-size: 0.8125rem;
  }

  .main .ua h2 {
    padding-top: 0 !important;
  }

  .main .ua h2:before {
    top: 33px !important;
  }

  .main .ua h2 span {
    font-size: 0.9375rem !important;
    line-height: 1.2rem !important;
  }

  .main .ua h2 .fz-20 {
    font-size: 0.875rem !important;
    line-height: 1.2rem !important;
  }

  .main .ua .batch_download {
    margin-bottom: 30px !important;
  }

  .main .ua .batch_download h4 span {
    font-size: 0.75rem;
  }

  .main .ua .batch_download h4 span span {
    font-size: 0.875rem;
  }

  .main .ua .batch_download .lesson_text h4 span {
    font-size: 0.875rem !important;
  }

  .main .ua .dl_all_lst ul li {
    width: 47.75%;
    margin-right: 4.5%;
  }

  .main .ua .dl_all_lst ul li:nth-child(2n) {
    margin-right: 0;
  }

  .main .ua .section_download {
    padding-top: 0;
  }

  .main .ua .section_download .lesson_list {
    padding-top: 0;
  }

  .main .ua .section_download .lesson_text.cando-check br.lb-adjust {
    display: none;
  }

  .main .ua .section_download .lesson_text.cando-check span.pc {
    display: none;
  }

  .main .ua .lesson_text h4 {
    line-height: 1rem;
  }

  .main .ua .lesson_text h4 span {
    letter-spacing: -0.5px;
    padding-top: 5px !important;
  }

  .main .ua .lesson_text h4 span:first-child {
    padding-top: 0 !important;
  }

  .main .ua .cover a.link {
    padding-right: 6px;
    line-height: 1.125rem;
  }

  .main .ua.bn_content .batch_download {
    margin-bottom: 40px !important;
    margin-top: 20px;
  }

  .main .ua.bn_content .batch_download .download {
    margin-top: 0;
  }

  .main .ua.bn_content .section_download .dl_all_lst {
    margin-top: 30px;
  }

  .main .ua.bn_content .section_download .dl_all_lst ul {
    margin-top: 10px;
  }

  .main .ua.bn_content .section_download .dl_all_lst .batch_download {
    margin-top: 0;
  }

  .main .ua.bn_content .section_download .dl_all_lst .batch_download .download {
    margin-top: 10px;
  }

  .main .ua_lesson .topic_label span {
    min-width: 75px;
  }

  .main .ua_lesson .topic_label span span {
    font-size: 0.8125rem !important;
  }

  .main .ua_lesson h1 .elementary_label a span {
    padding-left: 5px !important;
  }

  .main .ua_lesson h1 .lesson_label span {
    font-size: 1rem !important;
    line-height: 1.2rem !important;
    margin-bottom: 0;
    padding-left: 10px !important;
    padding-right: 5px !important;
  }

  .main .ua_lesson h1 .lesson_label span:first-child {
    padding-left: 0 !important;
  }

  .main .ua_lesson h1 .lesson_label span.fz-20 {
    font-size: 0.875rem !important;
    line-height: 1.2rem !important;
  }

  .main.toggle_nav {
    display: none;
  }

  .main .pc_display {
    display: none;
  }

  .main .common h1 {
    font-size: 1rem;
  }

  .main .common h1 label.elementary_label a, .main .common h1 label.elementary_label span {
    font-size: 0.8125rem;
    padding: 5px 10px;
  }

  .main .common h1 label.topic_label span {
    font-size: 0.8125rem;
    padding: 5px 10px;
  }

  .main .common h1 label.lesson_label {
    padding-top: 30px;
  }

  .main .top_img {
    background: #f7c6c7;
  }

  .main h1.top_banner {
    background: #f7c6c7;
  }

  .main .inner {
    padding: 0 15px;
  }

  .main a.link::after {
    font-size: 1.125rem;
    top: 9px;
    background-size: 15px;
  }

  .main .batch_download {
    width: 47.83%;
    margin-bottom: 40px;
  }

  .main .batch_download .download {
    margin-top: 20px;
  }

  .main .lesson_text h5,
  .main .lesson_text h4 {
    font-size: 0.875rem;
    line-height: 1.375rem;
    padding: 5px 0;
  }

  .main .lesson_text h5 span:first-of-type,
  .main .lesson_text h4 span:first-of-type {
    font-size: 0.75rem;
  }

  .main .lesson_text h5 span:last-of-type,
  .main .lesson_text h4 span:last-of-type {
    font-size: 0.75rem;
    padding: 0;
  }

  .main .cover .download_item {
    padding: 1.5px 0;
  }

  .main .cover .download_item p {
    font-size: 0.75rem;
  }

  .main .cover .download_item span {
    font-size: 1.125rem;
  }

  .main .cover a.link {
    font-size: 0.75rem;
    line-height: 0.9375rem;
    padding: 7px 2px 7px 5px;
  }

  .main .cover a.link:after {
    right: 5px;
  }

  .main .img_block.mar_btn {
    margin-bottom: 37.4px;
  }

  .main .pdf #news_36+.section_download ul.cm_list li:nth-of-type(4) .img_block {
    margin-bottom: calc(2.625rem + 29px);
  }

  .main .section_download {
    padding-top: 30px;
  }

  .main .section_download ul {
    -ms-grid-columns: 1fr 4.35% 1fr;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 30px 4.35%;
    width: 100%;
  }

  .main .section_download ul.cm_list li .img_block.mar_btm {
    margin-bottom: 38px;
  }

  .main .section_download ul.txt_list {
    padding-top: 15px;
  }

  .main .section_download ul.txt_list li {
    margin-top: 10px;
  }

  .main .section_download ul.txt_list li .text_link_item {
    font-size: 0.8125rem;
    line-height: 1.25rem;
  }

  .main .section_download ul li {
    width: 100%;
    margin-right: 0;
  }

  .main .section_download ul li .topic h3 {
    font-size: 0.75rem;
    line-height: 0.9375rem;
  }

  .main .section_download ul li .topic h3 span:last-of-type {
    padding: 10px 5px;
  }

  .main .container .home-link {
    padding-top: 10px;
  }

  .main .container .home-link p {
    margin-top: 20px;
  }

  .main .container .ele_btn ul {
    margin-top: 0;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    display: block;
  }

  .main .container .ele_btn ul li {
    font-size: 0.8125rem;
    margin-top: 10px;
    width: 100%;
    max-width: unset;
  }

  .main .container .ele_btn ul li a {
    padding: 7px 5px;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }

  .main .container .ele_btn ul.l-gnav-links>li .sub-menu {
    position: static;
  }

  .main .container .ele_btn ul li.active.c3 {
    background: transparent;
  }

  .main .container .ele_btn ul li.active.c3>a {
    background: #9DC3E5;
  }

  .main .container .ele_btn ul li.active::after {
    display: none;
  }

  .main .container .ele_btn ul.l-gnav-links>li .sub-menu {
    margin: 0;
  }

  .main .container .ele_btn ul.l-gnav-links>li.open>.sub-menu {
    display: block;
    white-space: normal;
    width: 95%;
    margin: 0 auto;
  }

  .main .container.bn_content .ele_btn ul {
    margin-top: 0;
  }

  .main .btn-group {
    display: none;
    padding: 9px 0;
    border-top: 1px solid #fff;
  }

  .main .btn-group ul {
    padding: 0;
  }

  .main .btn-group ul li {
    width: 50% !important;
    padding: 0;
    border: 0;
  }

  .main .btn-group ul li:after {
    content: none;
  }

  .main .btn-group ul li a {
    font-size: 0.8125rem;
  }

  .main .btn-group ul li a::before {
    content: none;
  }

  .main .btn-group ul li a::after {
    content: none;
  }

  .main .btn-group ul li:first-of-type {
    width: 50%;
    border-right: 2px solid #fff;
    padding: 0;
  }

  .main .btn-group ul li:nth-of-type(3n) {
    display: none;
  }

  .main .btn-group ul li:nth-of-type(4n) {
    display: none;
  }

  .main .btn-group ul li:last-of-type {
    display: none;
  }

  .main .top h2 {
    padding-left: 10px;
    font-size: 1rem;
  }

  .main .top .course_title h2 {
    padding-top: 40px;
  }

  .main .top h2:before {
    height: 26px;
    width: 3px;
    left: -10px;
    top: 6px;
  }

  .main .top .elementary_lst p {
    font-size: 0.875rem;
    line-height: 1.2rem;
  }

  .main .top .elementary_lst ul {
    -ms-grid-columns: 1fr 15px 1fr;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 25px 15px;
    padding-top: 0;
  }

  .main .top .elementary_lst ul li a {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }

  .main .top .elementary_lst ul li a figure {
    margin-top: 0;
  }

  figure img {
    height: auto;
  }

  .main .news_update {
    padding: 22px 0 60px 0;
    margin-top: 35px;
  }

  .main .news_update .row h2 {
    padding: 0;
  }

  .main .news_update .row p {
    text-align: left;
  }

  .main .news_update .inner a.link {
    font-size: 0.8125rem;
    padding: 5px 5px;
    max-width: 130px;
  }

  .main .news_update .inner .text_link {
    font-size: 0.8125rem;
    line-height: 1.25rem;
    padding-top: 0;
    margin-top: 0;
  }

  .main .news_update .inner .text_link span {
    display: block;
    font-weight: bold;
  }

  .main .news_update .inner .text_link a {
    margin-left: 0;
    font-weight: bold;
  }

  .main .news_update .inner .text_link a b {
    font-size: 0.9rem;
  }

  .main .list .batch_download .download {
    width: 212px;
  }

  .main .list .section_download ul {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .main .list .section_download ul li {
    margin: 0 5px 20px 5px;
  }

  .main .list .download {
    padding: 13px 15px;
  }

  .main .pdf.common h1 span {
    font-size: 0.8125rem;
    padding: 5px 10px;
  }

  .main .pdf {
    padding-bottom: 80px;
  }

  .main .pdf h2 {
    padding-left: 10px;
  }

  .main .pdf h2:before {
    height: 28px;
    width: 3px;
    top: 7px;
    left: -10px;
  }

  .main .pdf .section_download h2 {
    padding: 0 0 0 10px;
  }

  .main .pdf .section_download h2:before {
    height: 28px;
    width: 3px;
    left: -10px;
  }

  .main .pdf p {
    font-size: 0.8125rem;
    line-height: 1.25rem;
  }

  .main .pdf .modal .modal-content {
    width: 90%;
    padding: 10px;
  }

  .main .pdf .modal .modal-content .content .btn_group button {
    margin-bottom: 10px;
  }

  .main .play_list {
    padding-bottom: 100px;
  }

  .main .play_list h1 label.lesson_label span {
    font-size: 1rem;
    padding-left: 0;
  }

  .main .play_list .lesson_btn_gp .dynamic-button {
    margin-right: 10px;
    padding: 5px 10px;
    font-size: 0.8125rem;
  }

  .main .play_list .audio_list ul li .audio_block {
    padding: 10px;
    border-radius: 5px;
  }

  .main .play_list .audio_list ul li .audio_block p {
    font-size: 0.8125rem;
    line-height: 1.125rem;
    padding-bottom: 10px;
    padding-right: 0;
  }

  .main .play_list .audio_list ul li .audio_block p::before {
    padding-bottom: 5px;
  }

  .main .play_list .audio_list ul li .audio_block p .mp3_lesson_name {
    padding-bottom: 5px;
    width: 140px;
  }

  .main .play_list .audio_list ul li .audio_block p .mp3_name {
    display: inline-block;
  }

  .main .about {
    padding-bottom: 60px;
  }

  .main .about h1 {
    padding-left: 10px;
  }

  .main .about h1:before {
    width: 3px;
    height: 25px;
    top: 6px;
  }

  .main .about h2 {
    margin: 0 0 20px 0;
    font-size: 1.25rem;
    padding: 15px 10px 15px 0;
    line-height: 1.25;
  }

  .main .about ul.link {
    margin-bottom: 30px;
  }

  .main .about ul.link li a {
    font-size: 0.8125rem;
    padding-left: 10px;
  }

  .main .about .text.material dl {
    margin-top: 20px;
  }

  .main .about .text.material dl dt:before {
    width: 3px;
    height: 20px;
    top: 3px;
  }

  .main .about .text.material dl dd {
    margin-bottom: 10px;
  }

  .main .about .text.material dl dd span {
    font-size: 0.8125rem;
  }

  .main .about .text.material dl.book_list:last-of-type {
    margin-bottom: 0;
  }

  .main .about .text.material span {
    font-size: 0.8125rem;
  }

  .main .about .text h3 {
    font-size: 0.9375rem;
    padding: 5px 10px 5px 10px;
  }

  .main .about .text h4 {
    font-size: 0.9375rem;
  }

  .main .about .text h4 span {
    padding: 0 7px;
    font-size: 0.8125rem;
  }

  .main .about .text p {
    font-size: 0.8125rem;
    padding-bottom: 10px;
  }

  .main .about .text p span {
    font-size: 0.8125rem;
  }

  .main .about .text dl {
    font-size: 0.8125rem;
  }

  .main .about .text dl dd {
    margin-bottom: 10px;
  }

  .main .about .text dl dd img {
    margin-bottom: 10px;
  }

  .main .about .text dl.list dd:before {
    font-size: 0.8125rem;
  }

  .main .about .text dl.list dd:last-of-type {
    margin-bottom: 15px;
  }

  .main .about .text ul li {
    padding-left: 30px;
    font-size: 0.8125rem;
  }

  .main .about .text ul li ul {
    padding-bottom: 10px;
  }

  .main .about .text ul li ul li {
    margin-bottom: 10px;
  }

  .main .about .text ul li ul li p.icon_txt img {
    width: 17px;
  }

  .main .about .text ul li p {
    padding-bottom: 10px;
  }

  .main .about .text ul li p:first-of-type:before {
    font-size: 0.8125rem;
  }

  .main .about .text ul li .list_block {
    display: block;
  }

  .main .about .text ul li .list_block .list {
    margin-bottom: 30px;
    font-size: 0.8125rem;
    padding: 15px;
  }

  .main .about .text ul li ul {
    font-size: 0.8125rem;
    padding-left: 10px;
  }

  .main .about .text .structure {
    margin-top: 30px;
  }

  .main .about .text .structure dl dt {
    margin-bottom: 10px;
  }

  .main .about .text .structure .section_list dl {
    margin-bottom: 10px;
  }

  .main .about .text .activity {
    margin-top: 30px;
  }

  .main .about .text .activity dl {
    margin-top: 20px;
  }

  .main .about .text .activity dl dt {
    font-size: 0.9375rem;
  }

  .main .about .text .activity dl.type dt {
    font-size: 0.9375rem;
  }

  .main .about .text .activity dl.type dd p {
    margin-top: 10px;
  }

  .main .about .text .activity dl.type dd dl dt {
    margin: 5px 0 10px 0;
    padding-left: 20px;
    font-size: 0.8125rem;
  }

  .main .about .text .activity dl.type dd dl dt:after {
    padding: 10px;
  }

  .main .about .text .activity dl.type dd dl dd {
    margin-bottom: 10px;
  }

  .main .about .text .activity dl.common_activity {
    margin-top: 20px;
  }

  .main .about .text .activity dl.common_activity p {
    padding-bottom: 10px;
    margin-top: 10px;
  }

  .main .about .text .activity dl.common_activity dt {
    font-size: 0.9375rem;
  }

  .main .about .text .activity dl.common_activity dd dl {
    padding-left: 15px;
  }

  .main .about .text .activity dl.common_activity dd dl dt {
    font-size: 0.8125rem;
    margin-top: 0;
  }

  .main .about .text .activity dl.common_activity dd dl dd {
    margin-bottom: 10px;
  }

  .main .about .text .activities_gp {
    margin-top: 20px;
  }

  .main .about .text .activities_gp h5 {
    font-size: 0.9375rem;
    padding: 8px 10px 8px 40px;
  }

  .main .about .text .activities_gp h5:before {
    top: 6px;
    left: 10px;
  }

  .main .about .text .activities_gp .listening {
    margin-top: 10px;
  }

  .main .about .text .activities_gp .reading {
    margin-top: 10px;
  }

  .main .about .text .activities_gp .writing {
    margin-top: 10px;
  }

  .main .about .text .other_corner {
    margin-top: 20px;
  }

  .main .about .text .other_corner dl {
    margin-bottom: 20px;
  }

  .main .about .text .other_corner dl dt {
    padding-left: 20px;
    margin-bottom: 0;
  }

  .main .about .text .other_corner dl dd span {
    font-size: 0.8125rem;
    margin-top: 10px;
  }

  .main .about .text .other_corner .word dl dt {
    margin-bottom: 10px;
    font-size: 0.9375rem;
    padding: 5px 10px;
  }

  .main .about .text .other_corner .word dl dd {
    margin-bottom: 10px;
  }

  .main .about .text .other_corner .word ul {
    margin-bottom: 10px;
  }

  .main .about .text .production {
    padding-top: 20px;
  }

  .main .about .text .production p {
    font-size: 1rem;
  }

  .main .about .text .production dl dt {
    margin-top: 10px;
  }

  .main .about .text .text_bubble_gp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 30px;
  }

  .main .about .text .text_bubble_gp .text_bg {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    margin: 0 auto;
  }

  .main .about .text .text_bubble_gp .text_bg .list {
    float: none;
    margin-bottom: 30px;
    padding: 15px;
  }

  .main .about .text .text_bubble_gp .text_bg .list p {
    font-size: 0.8125rem;
  }

  .main .about .text .text_bubble_gp .text_bg .list ul {
    padding-left: 15px;
  }

  .main .about .text .text_bubble_gp .text_bg .list ul li {
    font-size: 0.8125rem;
    padding-top: 10px;
  }

  .main .about .text .text_bubble_gp .text_bg .list::before {
    content: none;
  }

  .main .about .text .text_bubble_gp .text_bg .list::after {
    content: none;
  }

  .main .about .text .text_bubble_gp .text_bg .list.a01_lst {
    width: 100%;
  }

  .main .about .text .text_bubble_gp .text_bg .list.a02_lst {
    float: none;
    width: 100%;
  }

  .main .about .text .text_bubble_gp .run {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: auto;
    margin: 0 auto;
  }

  .main .about .text .text_bubble_gp .run figure {
    margin: 0 auto;
    margin-bottom: 30px;
  }

  .main .about .material dl dt {
    padding-left: 10px;
    margin-bottom: 10px;
  }

  .main .about .material dl dt:before {
    width: 3px;
    height: 25px;
  }

  .main .faq h1 {
    text-align: left;
    padding: 35px 0 10px 0;
  }

  .main .faq_inner {
    margin-bottom: 22px;
  }

  .main .faq .inner h2 {
    font-size: 0.875rem;
    margin-bottom: 15px;
  }

  .main .faq .inner h2:before {
    min-width: 15px;
    margin-right: 8px;
  }

  .main .faq .inner dl {
    border-width: 1px;
    padding: 13px 10px;
    line-height: 1.25rem;
  }

  .main .faq .inner dl:last-of-type {
    border-width: 1px;
  }

  .main .faq .inner dl span {
    font-size: 0.875rem;
  }

  .main .faq .inner dl dt, .main .faq .inner dl dd {
    font-size: 0.8125rem;
  }

  .main .faq .inner dl dt {
    padding-left: 30px;
  }

  .main .faq .inner dl dd {
    margin-top: 9px;
    padding: 15px 15px 15px 40px;
  }

  .main .faq .inner dl dd span {
    left: 10px;
  }

  .main .faq .inner dl.adjust_padding dt {
    padding-left: 45px;
  }

  .main .faq .inner dl.adjust_padding dd {
    padding-left: 55px;
  }

  .main .faq .inner p.remark {
    font-size: 0.875rem;
    padding-bottom: 40px;
    text-align: left;
  }

  .main .faq .inner .other_txt p {
    font-size: 0.8125rem;
  }

  .main .news .notice_list {
    padding: 0 0 50px 0;
  }

  .main .news .notice_list dl {
    font-size: 0.8125rem;
    padding: 20px 0;
  }

  .main .news .notice_list dl dd {
    padding-top: 10px;
    font-size: 0.8125rem;
  }

  .main .news .notice_list dl dd a.text-red {
    font-size: 0.9rem;
  }

  .main .privacy dl {
    padding-top: 25px;
  }

  .main .privacy dl dt {
    font-size: 0.8125rem;
  }

  .main .privacy dl dd {
    font-size: 0.8125rem;
  }

  .main .sitemap h1 {
    padding-left: 10px;
  }

  .main .sitemap h1:before {
    width: 3px;
    height: 25px;
    left: -10px;
    top: 6px;
  }

  .main .sitemap h2 {
    font-size: 1rem;
    padding: 20px 0 20px 10px;
  }

  .main .sitemap h2:before {
    width: 3px;
    left: -10px;
  }

  .main .sitemap .text a {
    margin-top: 20px;
    font-size: 1rem;
  }

  .main .sitemap .text .link_gp {
    margin-bottom: 20px;
  }

  .main .sitemap .text .link_gp a {
    font-size: 0.8125rem;
  }

  .main .sitemap .text .link_gp a.upper_link {
    margin-top: 0;
  }

  .main .sitemap .text .link_gp p {
    font-size: 0.8125rem;
    margin-top: 10px;
    padding-left: 23px;
  }

  .main .sitemap .text .link_gp p:before {
    top: 8px;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #000;
  }

  .main .sitemap .text .link_gp ul {
    margin-top: 0px;
  }

  .main .sitemap .text .link_gp ul li {
    padding-bottom: 0;
    max-width: 80px;
  }

  .main .sitemap .text .other_link h2 {
    padding-left: 10px;
  }

  .main .sitemap .text .other_link ul li a {
    font-size: 0.8125rem;
    line-height: 1.75rem;
  }

  .main .edition .inner .inner_block ul li {
    font-size: 0.8125rem;
  }

  .main .edition .inner .inner_block p.ver-txt {
    font-size: 0.8125rem;
    margin-top: 20px;
  }

  .main .resources h2:before {
    top: 0;
  }

  .main .resources .section_download ul.cm_list {
    padding-top: 0;
  }

  .main .illust_list .img_list ul li {
    width: 31.2%;
    margin-right: 3.18%;
    margin-bottom: 4.3%;
  }

  .main .illust_list .img_list ul li:nth-child(3n) {
    margin-right: 0;
  }

  .main .illust_list .img_list ul li p {
    font-size: 0.75rem;
    margin-top: 7.5px;
  }

  .main .illust_list .modal {
    padding-top: 0;
  }

  .main .illust_list .modal .modal-content {
    max-width: 600px;
    width: 80%;
    margin: 20% auto 50px auto;
    padding: 13.3% 6.67% 6.67%;
    overflow-y: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .main .illust_list .modal .modal-content::-webkit-scrollbar {
    display: none;
  }

  .main .illust_list .modal .modal-content .btn_group {
    padding-top: 10px;
  }

  .main .illust_list .modal .modal-content .bg01_batch {
    padding: 5px 15px;
  }

  .main .illust_list .modal .modal-content .bg01_batch span.img_name {
    font-size: 0.9375rem;
  }

  .main .illust_list .modal .modal-content .bg01_batch i {
    font-size: 1.40625rem;
  }

  .main .illust_list .modal .modal-content span.close {
    width: 30px;
    height: 30px;
  }

  .main .illust_list .modal .modal-content span.close:before, .main .illust_list .modal .modal-content span.close:after {
    height: 23.46px;
  }

  .main .teach .desc_txt {
    margin-top: 20px;
  }

  .main .teach .section_download {
    padding-top: 0;
  }

  .main .teach h2 {
    padding-top: 65px !important;
  }

  .main .teach h2:first-child {
    padding-top: 30px !important;
  }

  .main .teach .cm_list {
    -ms-grid-columns: 1fr !important;
    grid-template-columns: 1fr !important;
  }

  .main .teach .cm_list li {
    margin-right: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  .main .teach .cm_list li .lesson_text.eq_height {
    min-height: auto !important;
  }

  .main .teach .vd_note {
    padding-left: 15px;
  }

  .main .teach .section_download .sub_container .sub_content:first-child .sub_title {
    padding-top: 30px;
  }

  .main .teach .section_download .sub_container .sub_content .sub_title {
    font-size: 0.875rem;
    line-height: normal;
    padding-top: 45px;
  }

  .main .teach .section_download .sub_container .sub_content .sub_title::before {
    font-size: 0.75rem;
    line-height: normal;
    margin-right: 5px;
  }

  .main.bn_top {
    margin-bottom: 60px;
  }

  .pr_movie {
    padding: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: calc(40 / 750 * 100vw) auto calc(40 / 750 * 100vw) auto;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    max-width: calc(654 / 750 * 100vw);
  }

  .pr_movie .pr_close {
    display: none;
  }

  .pr_movie .pr_movie_inner {
    max-width: 100%;
    padding: calc(37 / 750 * 100vw);
    border-radius: calc(19 / 750 * 100vw);
  }

  .pr_movie .pr_movie_inner .pr_item {
    border-radius: calc(5 / 750 * 100vw);
    padding: calc(5 / 750 * 100vw);
  }

  .pr_movie .pr_movie_inner .pr_item p {
    font-size: 1rem;
    line-height: 2.25rem;
  }

  .pr_movie .pr_movie_inner .pr_item figure {
    max-width: 100%;
  }

  .footer {
    padding: 30px 15px;
  }

  .footer .site {
    font-size: 0.75rem;
    padding: 0 10px 20px 10px;
  }

  .footer .site p {
    font-size: 0.75rem;
  }

  .footer .cp-right {
    padding-top: 20px;
    line-height: 1.27rem;
  }

  .ft_banner {
    margin: 0 auto 30px;
  }

  .footer .ft_banner ul li {
    width: 40.944%;
  }

  .en .about .text ul li ul li span.imp_color {
    font-size: 0.8125rem !important;
  }

  .en .about h1:before {
    top: 6px;
  }

  .en .about .coming_soon {
    margin-top: 30px;
  }

}

@media only screen and (max-width: 500px) {
  .footer .site a:first-of-type {
    max-width: 200px;
    margin-right: 0;
  }

  .footer .site a::after {
    padding: 0 5px;
  }

  .header .Jft_logo, .ua_header .Jft_logo {
    max-width: 200px;
  }

  .main .resources .section_download.worksheet_item .lesson_text h4 {
    min-height: 54px;
  }
}

@media only screen and (max-width: 560px) {
  .en .br_rb {
    display: block;
  }
}

@media only screen and (max-width: 470px) {
  .en .br_rb {
    display: none;
  }
}

@media only screen and (max-width: 456px) {
  .br_rb {
    display: block;
  }
}

@media only screen and (max-width: 400px) {
  .header .Jft_logo, .ua_header .Jft_logo {
    max-width: 180px;
  }

  .main .ua .dl_all_lst ul .batch_download .lesson_text h4 {
    height: 60px;
  }
}

@media only screen and (max-width: 374px) {
  .header .Jft_logo, .ua_header .Jft_logo {
    max-width: 130px;
  }

  .main .ua_lesson h1 .lesson_label span {
    font-size: 4.27807vw !important;
  }

  .main .ua_lesson h1 .lesson_label span span {
    font-size: 3.47594vw !important;
  }

  .br_rb {
    display: none;
  }
}

@media only screen and (max-width: 320px) {
  .header .Jft_logo, .ua_header .Jft_logo {
    max-width: 120px;
  }

  .main .pdf #news_36+.section_download ul.cm_list li:nth-of-type(4) .img_block {
    margin-bottom: calc(5.25rem + 29px);
  }
}

.cookiealert {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: 0 !important;
  z-index: 999;
  opacity: 0;
  border-radius: 0;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -webkit-transition: all 500ms ease-out;
  transition: all 500ms ease-out;
  color: #ecf0f1;
  font-size: 0.875rem;
  background: #212327 url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAASwAAAEECAIAAAAd4J55AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyhpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTMyIDc5LjE1OTI4NCwgMjAxNi8wNC8xOS0xMzoxMzo0MCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTUuNSAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6OUIyQzg0Q0RDQ0ExMTFFNjkyMDJGQkMzNjQ3OUEyMTQiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6OUIyQzg0Q0VDQ0ExMTFFNjkyMDJGQkMzNjQ3OUEyMTQiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo5QjJDODRDQkNDQTExMUU2OTIwMkZCQzM2NDc5QTIxNCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo5QjJDODRDQ0NDQTExMUU2OTIwMkZCQzM2NDc5QTIxNCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PnMLhJsAAB3qSURBVHja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");
  padding: 14px 10px;
  line-height: 1.5625rem;
}

.cookiealert.show {
  opacity: 1;
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  -webkit-transition-delay: 1000ms;
  transition-delay: 1000ms;
}

.cookiealert a {
  text-decoration: underline;
  color: #007bff;
}

.cookiealert button {
  background: #007bff;
  padding: .25rem .5rem;
  font-size: .875rem;
  line-height: 1.5;
  border-radius: .2rem;
  height: auto;
  border: transparent;
  color: #fff;
}

.cookiealert .acceptcookies {
  margin-left: 10px;
  vertical-align: baseline;
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .header ul li .menu_nav #___gcse_0 {
    display: table;
    max-width: 768px;
    width: 100%;
  }

  .bn_block a {
    position: relative !important;
    margin: 0 !important;
  }

  .main .resources #news_33+.section_download ul li .img_block, .main .resources #news_36+.section_download ul li .img_block {
    height: auto;
  }

  .main .section_download ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .main .section_download ul li {
    max-width: 246px;
    width: 100%;
    margin: 0 20px 30px 0;
  }

  .main .section_download ul.cm_list {
    width: 100%;
  }

  .main .batch_download {
    max-width: 246px;
    width: 100%;
    display: block;
  }

  .main .top .elementary_lst ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .main .top .elementary_lst ul li {
    width: 30%;
    margin: 0 30px 30px 0;
  }

  .main .pdf .section_download ul li {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }

  .main .pdf .modal .modal-content .btn_group button {
    padding: 10px 0;
  }

  .main .batch_download .download .cover .download_item p {
    width: 200px;
  }

  .main .lesson_text {
    margin-bottom: 10px;
  }

  .main .img_block {
    height: 100%;
  }

  .main .teach .cm_list li {
    max-width: 524px;
    width: 48.54%;
    margin-right: 2.7%;
  }

  .main .teach .cm_list li:nth-child(2n) {
    margin-right: 0;
  }

  .main.en .teach .lesson_text {
    padding-bottom: 5px;
  }
}

.en {
  font-size: 50%;
}

.en .about .text ul li ul li span.imp_color {
  width: auto;
  background: transparent;
  border-radius: 0;
  color: #e45869;
  font-size: 1.125rem;
}

.en .about .text .text_bubble_gp .text_bg .list::before {
  bottom: -123px;
}

.en .about .text .text_bubble_gp .text_bg .list::after {
  border-top: 115px solid #fff;
  bottom: -100px;
}

.en .about .text .text_bubble_gp .text_bg .list.a01_lst::before {
  border-top: 121px solid #df4b87;
}

.en .about .text .text_bubble_gp .text_bg .list.a01_lst::after {
  border-left: 39px solid transparent;
}

.en .about h1:before {
  top: 11px;
}

.en .about .coming_soon {
  text-align: center;
  margin-top: 50px;
}

.en .pdf .modal .modal-content .btn_group button {
  padding: 10px 0;
}

.en .btn-group ul li {
  width: 16.8460%;
}

.en .btn-group ul li:first-of-type {
  /* width: 7.270%; */
}

.en .btn-group ul li:nth-of-type(2) {
  width: 28.0664%;
}

.en .btn-group ul li:nth-of-type(4) {
  width: 18.9062%;
}

.en .btn-group ul li:last-of-type {
  width: 28.6071%;
}

.en .btn-group ul li:last-of-type a {
  text-align: left;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.en .btn-group ul li:last-of-type a:before {
  min-width: 33px;
}

.pagetopArea {
  position: relative;
  z-index: 10;
  margin: auto;
}

.pagetopArea .pageTop {
  line-height: 0;
  position: fixed;
  right: 65px;
  bottom: 15px;
}

.pagetopArea .pageTop a {
  font-size: 16px;
  line-height: 0;
  display: inline-block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-decoration: none;
}

.pagetopArea .footerfix {
  position: absolute;
  top: -80px;
  bottom: auto;
}

.cat-collapse__heading {
  cursor: pointer;
    display: flex;
    align-items: center;
    margin-top: 30px;
}

.child-category-block h3.cat-collapse__title{ margin: 0; }

.cat-collapse__icon {
    margin-right: 20px;
}
.cat-collapse__icon img{ width: 30px; transition: transform .25s ease;}
.cat-collapse__content{ display: none; }
.grandchild-category-block > .grandchild__heading {
    cursor: pointer;
}

.cat-collapse__content,
.grandchild__content {
    display: none;
}

@media only screen and (max-width: 500px) {
  .pagetopArea .pageTop {
    right: 40px;
    width: 45px;
  }
}

@media print {
  body {
    -webkit-print-color-adjust: exact !important;
  }

  .header .menu_list {
    display: none;
    height: 0;
  }

  .navbar .toggle {
    display: none;
  }

  .main h1.top_banner img {
    display: block;
  }

  .main h1.top_banner img.sp {
    display: none;
  }

  .main .top_img figure img.sp {
    display: none;
  }

  .main .btn-group ul li a {
    font-size: 1rem;
  }

  .main .about .text .text_bubble_gp .run figure img.sp {
    display: none;
  }

  .pagetopArea .pageTop a {
    display: none;
  }

}

.main .ua .section_download .lesson_text.cando-check br.lb-adjust {
  display: none;
}

@media only screen and (max-width: 1070px) {
  .main .ua .section_download .lesson_text.cando-check br.lb-adjust {
    display: block;
  }
}
.box_last {
    border-top: 1px solid #333333;
    margin-top: 40px;
}
