@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  max-height: 999999px; }

:root {
  font-size: 100%; }

body {
  font-family: 'Hiragino Kaku Gothic Pro';
  line-height: 1.4;
  text-align: center;
  color: #333333;
  -webkit-text-size-adjust: 100%;
  background: #fff;
  font-size: 100%; }

img {
  width: 100%; }

button {
  cursor: pointer; }

a {
  text-decoration: none;
  cursor: pointer;
  color: #333333; }

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 !important; }
  .c3.active:after {
    border-top-color: #9DC3E5 !important; }

.c4 {
  background: #a9d18e !important; }
  .c4.active:after {
    border-top-color: #a9d18e !important; }

.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%;
    margin-left: 50px; }
  .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 {
        position: relative;
        cursor: pointer; }
        .header ul li .lang_sel::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 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; }
      .header ul li .menu_nav {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; }
        .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 #12204f; }
        .header ul li .menu_nav button {
          padding: 0 15px;
          background-color: #005bc2;
          color: #fff;
          border-top-right-radius: 5px;
          border-bottom-right-radius: 5px;
          border-style: none;
          height: 41px; }

/* 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: '\f138';
      font-family: "Font Awesome 5 Free";
      color: #fff;
      font-size: 1.375rem;
      padding-left: 15px;
      font-weight: bold; }
  .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 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; }
      .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.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 a {
            display: block;
            padding: 7px 10px; }
  .main .common h1 {
    font-size: 1.5rem;
    line-height: 1.625rem;
    text-align: left;
    padding: 30px 0 20px 0; }
    .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; }
      .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: 120px;
    background: #fffbd1;
    padding: 40px 0 95px 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: 100%;
      background: #005bc2;
      color: #fff;
      margin-right: 0; }
    .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: underline;
        margin-left: 50px;
        color: blue; }
        .main .news_update .inner .text_link a b {
          font-size: 1.15rem; }
  .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 .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: 120px; }
    .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 h4 {
      padding: 10px 0;
      font-size: 1.0625rem; }
      .main .lesson_text h4 span:first-of-type {
        font-size: 1.125rem;
        display: block; }
      .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 200px 0; }
    .main .news .notice_list dl {
      font-size: 1.125rem;
      line-height: 1.625rem;
      text-align: left;
      padding: 26px 0;
      border-bottom: 2px solid #999999; }
      .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: 196px;
    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 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; }
  .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: 80px 20px 74px 20px; }
  .footer .site {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-bottom: 60px;
    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 ul li:last-child {
        margin-left: 10px; }
  .footer .cp-right {
    font-size: 0.6875rem;
    line-height: 1.75rem;
    padding-top: 60px; }

#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; }
  #cookieWarnBox.loaded .text {
    padding: 0 15px; }
  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 10px;
        width: 100%; }
        .header ul li .lang_sel {
          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-top: 20px;
          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 #808080;
          text-align: left;
          position: relative; }
          .header .menu_list ul li a {
            width: 100%;
            display: block;
            padding: 10px 10px 10px 20px; }
            .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; }
  .main .batch_download {
    width: 47.83%;
    margin-bottom: 40px; }
    .main .batch_download .download {
      margin-top: 20px; }
  .main .lesson_text h4 {
    font-size: 0.875rem;
    line-height: 1.375rem;
    padding: 5px 0; }
    .main .lesson_text h4 span:first-of-type {
      font-size: 0.75rem; }
    .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; }
    .main .container .ele_btn ul li {
      font-size: 0.8125rem;
      margin-top: 15px;
      width: 45%;
      max-width: 160px; }
      .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.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 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: 30px 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; }
  .main .news_update {
    padding: 22px 0 60px 0;
    margin-top: 60px; }
    .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: 20px;
      margin-top: 11px; }
      .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 10px; }
    .footer .site {
      font-size: 0.75rem;
      padding: 0 10px 30px 10px; }
      .footer .site p {
        font-size: 0.75rem; }
    .footer .cp-right {
      padding-top: 30px;
      line-height: 1.27rem; }
  .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; }
  .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; }

@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; } }
