@charset "UTF-8";
/***************　field　  ***************/
/***************　mixin　  ***************/
section {
  padding: 30px 10px 0;
}
@media screen and (min-width: 1025px) {
  section {
    padding: 40px 0;
  }
}
section p {
  line-height: 1.5;
}
@media screen and (min-width: 1025px) {
  section p {
    margin: 0 20px;
  }
}

/****indexページ****/
.linkbox {
  margin-bottom: 30px;
}
.linkbox:last-of-type {
  margin-bottom: 60px;
}
@media screen and (min-width: 1025px) {
  .linkbox {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-around;
  }
}
.linkbox div {
  width: 100%;
  height: 60px;
  margin-bottom: 20px;
  background: #fff url(/homework/common/images/arrow-link.svg) no-repeat;
  background-size: 31.5px auto;
  background-position: right 10px center;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 1025px) {
  .linkbox div {
    width: 48%;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .linkbox div {
    background-size: auto auto;
    background-position: right 20px center;
  }
}
@media screen and (min-width: 2561px) {
  .linkbox div {
    background-size: 126px auto;
    background-position: right 40px center;
  }
}
.linkbox div a {
  width: 100%;
  height: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.linkbox div a span {
  font-size: 1.25em;
  font-weight: 700;
}
.linkbox div.btn-sp {
  background-color: #3C9B7E;
}
.linkbox div.btn-co {
  background-color: #ED7780;
}
.linkbox div.btn-school {
  background-color: #F5A3D7;
}
.linkbox div.btn-license {
  background-color: #0068CF;
}
.linkbox div.btn-money {
  background-color: #FFBB00;
}

.index-lead {
  margin: 0 10px;
}
@media screen and (min-width: 1025px) {
  .index-lead {
    margin: 0;
  }
}

.sc-link {
  color: #00A5CF;
}
.sc-link a::before {
  content: "※";
}

p.sc-link {
  text-decoration: underline;
  transition: 0.5s;
}
p.sc-link:hover {
  opacity: 0.75;
}
@media screen and (min-width: 1025px) {
  p.sc-link {
    margin: 10px 0 0;
  }
}

p.explanation {
  width: 100%;
  background-color: #ECECEC;
  text-align: center;
  padding: 10px 0;
  margin: 20px 0 0;
}
@media screen and (min-width: 1025px) {
  p.explanation {
    margin: 40px 0 0;
  }
}

#schematic {
  width: 100%;
  margin: 60px 0 30px;
  position: relative;
}
@media screen and (min-width: 1025px) {
  #schematic {
    width: 1024px;
    min-height: 100vh;
    margin: 60px auto 120px;
    display: grid;
  }
}
#schematic h2 {
  width: calc(100% - 20px);
  font-size: 18px;
  color: #fff;
  border-radius: 3px;
  padding: 15px 20px;
  position: absolute;
  left: 10px;
  top: 0;
}
@media screen and (min-width: 1025px) {
  #schematic h2 {
    width: auto;
    font-size: 24px;
    text-align: center;
    z-index: 200;
    left: 50%;
    white-space: nowrap;
    transform: translate(-50%, -50%);
  }
}
#schematic h2.acc::after {
  content: "\f13a";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  margin-left: 10px;
}
@media screen and (min-width: 1025px) {
  #schematic h2.acc::after {
    content: none;
  }
}
#schematic .open-main h2.acc::after {
  content: "\f139";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  margin-left: 10px;
}
@media screen and (min-width: 1025px) {
  #schematic .open-main h2.acc::after {
    content: none;
  }
}
#schematic #main-humanities {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-humanities > div {
  height: 0;
  opacity: 0;
}
#schematic #main-humanities.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-humanities.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-humanities.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-humanities.open-main {
  background-color: rgba(237, 105, 66, 0.1);
  border: #ED6942 solid 5px;
}
@media screen and (min-width: 1025px) {
  #schematic #main-humanities {
    width: 100%;
    background-color: rgba(237, 105, 66, 0.1);
    border: #ED6942 solid 5px;
    grid-column: 1/6;
    grid-row: 1/5;
    padding: 50px 15px 125%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    align-items: flex-start !important;
    justify-content: space-between;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-humanities > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-humanities h2 {
  background-color: #ED6942;
}
@media screen and (min-width: 1025px) {
  #schematic #main-humanities h2 span.explan {
    opacity: 0;
    width: 300px;
    background-color: #FFFFE1;
    border-radius: 3px;
    position: absolute;
    left: calc(100% + 5px);
    top: 0;
    font-size: 16px;
    color: #484848;
    font-weight: normal;
    text-align: left;
    display: block;
    padding: 15px;
    white-space: initial;
  }
  #schematic #main-humanities h2 span.explan::before {
    content: "";
    position: absolute;
    top: calc(50% + 5px); /* 縦軸をセンタリングする */
    left: -30px;
    transform: translateY(-50%); /* 縦軸をセンタリングする */
    border: 15px solid transparent;
    border-right: 18px solid #FFFFE1;
  }
  #schematic #main-humanities h2:hover span.explan {
    opacity: 1;
  }
  #schematic #main-humanities h2::after {
    content: "系統説明";
    font-size: 0.7em;
    color: #ED6942;
    padding: 5px 10px;
    background-color: #ffffff;
    border-radius: 3px;
  }
}
@media screen and (min-width: 1025px) {
  #schematic #main-humanities #linguistics {
    margin-top: 50px;
  }
}
#schematic #main-humanities #linguistics::after {
  content: url("/homework/field/images/back-linguistics.svg");
}
#schematic #main-humanities #literature::after {
  content: url("/homework/field/images/back-literature.svg");
}
#schematic #main-socialscience {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-socialscience > div {
  height: 0;
  opacity: 0;
}
#schematic #main-socialscience.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-socialscience.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-socialscience.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-socialscience.open-main {
  border: #93C856 solid 5px;
  background-color: rgba(147, 200, 86, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-socialscience {
    width: calc(100% - 10px);
    background-color: rgba(147, 200, 86, 0.1);
    grid-column: 2/9;
    grid-row: 2/4;
    padding: 50px 0 200px;
    border: none;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-socialscience > div {
    height: auto;
    opacity: 1;
  }
  #schematic #main-socialscience::after {
    content: "";
    width: 100%;
    height: 100%;
    border: #93C856 solid 5px;
    border-radius: 20px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 150;
    pointer-events: none;
  }
}
#schematic #main-socialscience h2 {
  background-color: #93C856;
}
@media screen and (min-width: 1025px) {
  #schematic #main-socialscience h2 {
    left: 80%;
  }
  #schematic #main-socialscience h2 span.explan {
    opacity: 0;
    width: 300px;
    background-color: #FFFFE1;
    border-radius: 3px;
    position: absolute;
    left: calc(100% + 5px);
    top: 0;
    font-size: 16px;
    color: #484848;
    font-weight: normal;
    text-align: left;
    display: block;
    padding: 15px;
    white-space: initial;
  }
  #schematic #main-socialscience h2 span.explan::before {
    content: "";
    position: absolute;
    top: calc(50% + 5px); /* 縦軸をセンタリングする */
    left: -30px;
    transform: translateY(-50%); /* 縦軸をセンタリングする */
    border: 15px solid transparent;
    border-right: 18px solid #FFFFE1;
  }
  #schematic #main-socialscience h2:hover span.explan {
    opacity: 1;
  }
  #schematic #main-socialscience h2::after {
    content: "系統説明";
    font-size: 0.7em;
    color: #93C856;
    padding: 5px 10px;
    background-color: #ffffff;
    border-radius: 3px;
  }
}
@media screen and (min-width: 1025px) {
  #schematic #main-socialscience > div {
    float: right;
    clear: right;
    margin-right: 15px;
  }
}
#schematic #main-naturalscience {
  border: none;
  height: 0;
  overflow: hidden;
  padding: 80px 10px 20px;
}
#schematic #main-naturalscience > div {
  height: 0;
  opacity: 0;
}
#schematic #main-naturalscience.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-naturalscience.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-naturalscience.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-naturalscience.open-main {
  background-color: rgba(0, 174, 183, 0.1);
  border: #00AEB7 solid 5px;
}
@media screen and (min-width: 1025px) {
  #schematic #main-naturalscience {
    width: 100%;
    background-color: rgba(0, 174, 183, 0.1);
    border: #00AEB7 solid 5px;
    grid-column: 3/7;
    grid-row: 3/8;
    display: grid;
    grid-template-rows: auto 120px auto;
    grid-template-columns: auto;
    padding: 200px 15px 0;
    border: none;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-naturalscience > div {
    height: auto;
    opacity: 1;
  }
  #schematic #main-naturalscience::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    display: block;
    border: #00AEB7 solid 5px;
    border-radius: 20px;
    z-index: 150;
    pointer-events: none;
  }
}
#schematic #main-naturalscience h2:not(.include) {
  background-color: #00AEB7;
}
@media screen and (min-width: 1025px) {
  #schematic #main-naturalscience h2:not(.include) {
    top: 100%;
  }
  #schematic #main-naturalscience h2:not(.include) span.explan {
    opacity: 0;
    width: 300px;
    background-color: #FFFFE1;
    border-radius: 3px;
    position: absolute;
    left: calc(100% + 5px);
    top: 0;
    font-size: 16px;
    color: #484848;
    font-weight: normal;
    text-align: left;
    display: block;
    padding: 15px;
    white-space: initial;
  }
  #schematic #main-naturalscience h2:not(.include) span.explan::before {
    content: "";
    position: absolute;
    top: calc(50% + 5px); /* 縦軸をセンタリングする */
    left: -30px;
    transform: translateY(-50%); /* 縦軸をセンタリングする */
    border: 15px solid transparent;
    border-right: 18px solid #FFFFE1;
  }
  #schematic #main-naturalscience h2:not(.include):hover span.explan {
    opacity: 1;
  }
  #schematic #main-naturalscience h2:not(.include)::after {
    content: "系統説明";
    font-size: 0.7em;
    color: #00AEB7;
    padding: 5px 10px;
    background-color: #ffffff;
    border-radius: 3px;
  }
}
#schematic #main-naturalscience .include {
  margin-bottom: 20px;
}
#schematic #physical-education {
  border: 5px solid #2c74bc;
}
@media screen and (min-width: 1025px) {
  #schematic #physical-education {
    grid-row: 1;
    grid-column: 1;
  }
}
#schematic #physical-education .systembox::after {
  content: url("/homework/field/images/back-physical-education.svg");
}
#schematic #physical-education h2 {
  background-color: #2c74bc;
}
#schematic #welfare {
  border: 5px solid #ca589b;
}
@media screen and (min-width: 1025px) {
  #schematic #welfare {
    grid-row: 1/3;
    grid-column: 2;
  }
}
#schematic #welfare .systembox::after {
  content: url("/homework/field/images/back-welfare.svg");
}
#schematic #welfare h2 {
  background-color: #ca589b;
}
#schematic #art {
  border: 5px solid #ef7a35;
}
@media screen and (min-width: 1025px) {
  #schematic #art {
    grid-row: 2/4;
    grid-column: 1;
  }
}
#schematic #art .systembox::after {
  content: url("/homework/field/images/back-art.svg");
}
#schematic #art h2 {
  background-color: #ef7a35;
}
#schematic #life {
  border: 5px solid #34b16d;
}
@media screen and (min-width: 1025px) {
  #schematic #life {
    grid-row: 3;
    grid-column: 2;
  }
}
#schematic #life .systembox::after {
  content: url("/homework/field/images/back-life.svg");
}
#schematic #life h2 {
  background-color: #34b16d;
}
#schematic #physical-education,
#schematic #welfare,
#schematic #art,
#schematic #life {
  width: 100%;
  padding: 0 10px;
  border-radius: 20px;
  position: relative;
  padding: 40px 10px 10px;
  margin-bottom: 40px;
}
@media screen and (min-width: 1025px) {
  #schematic #physical-education,
  #schematic #welfare,
  #schematic #art,
  #schematic #life {
    border: none;
    padding: 50px 0 40px;
    margin-bottom: 0;
  }
}
#schematic #physical-education > div,
#schematic #welfare > div,
#schematic #art > div,
#schematic #life > div {
  text-align: left;
}
#schematic #department-of-engineering {
  grid-row: 4/6;
  grid-column: 2;
}
#schematic #department-of-engineering::after {
  content: url("/homework/field/images/back-department-of-engineering.svg");
}
#schematic #science {
  grid-row: 4;
  grid-column: 1;
}
#schematic #science::after {
  content: url("/homework/field/images/back-science.svg");
}
#schematic #agronomy {
  grid-row: 6/8;
  grid-column: 2;
}
#schematic #agronomy::after {
  content: url("/homework/field/images/back-agronomy.svg");
}
#schematic #medical-treatment {
  grid-row: 5/7;
  grid-column: 1;
}
#schematic #medical-treatment::after {
  content: url("/homework/field/images/back-medical-treatment.svg");
}
#schematic #medical {
  grid-row: 7/9;
  grid-column: 1;
}
#schematic #medical::after {
  content: url("/homework/field/images/back-medical.svg");
}
#schematic #economy::after {
  content: url("/homework/field/images/back-economy.svg");
}
#schematic #jurisprudence::after {
  content: url("/homework/field/images/back-jurisprudence.svg");
}
#schematic #sociology::after {
  content: url("/homework/field/images/back-sociology.svg");
}
#schematic #main-it-computer {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-it-computer > div {
  height: 0;
  opacity: 0;
}
#schematic #main-it-computer.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-it-computer.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-it-computer.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-it-computer.open-main {
  border: #65B67E 5px solid;
  background-color: rgba(101, 182, 126, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-it-computer {
    grid-row: 1;
    grid-column: 1/4;
    border: #65B67E 5px solid;
    background-color: rgba(101, 182, 126, 0.1);
    height: auto;
    overflow: inherit;
  }
  #schematic #main-it-computer > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-it-computer h2 {
  background-color: #65B67E;
}
#schematic #main-it-computer #building::after {
  content: url("/homework/field/images/back-building.svg");
}
#schematic #main-it-computer #car::after {
  content: url("/homework/field/images/back-car.svg");
}
#schematic #main-it-computer #electron::after {
  content: url("/homework/field/images/back-electron.svg");
}
#schematic #main-educate-childcare {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-educate-childcare > div {
  height: 0;
  opacity: 0;
}
#schematic #main-educate-childcare.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-educate-childcare.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-educate-childcare.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-educate-childcare.open-main {
  border: #EEAC4B 5px solid;
  background-color: rgba(238, 172, 75, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-educate-childcare {
    grid-row: 2;
    grid-column: 1;
    border: #EEAC4B 5px solid;
    background-color: rgba(238, 172, 75, 0.1);
    margin-right: 17px;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-educate-childcare > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-educate-childcare h2 {
  background-color: #EEAC4B;
}
@media screen and (min-width: 1025px) {
  #schematic #main-educate-childcare h2 {
    padding: 15px 10px;
  }
}
#schematic #main-educate-childcare #educate::after {
  content: url("/homework/field/images/back-educate.svg");
}
#schematic #main-beauty-fashion {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-beauty-fashion > div {
  height: 0;
  opacity: 0;
}
#schematic #main-beauty-fashion.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-beauty-fashion.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-beauty-fashion.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-beauty-fashion.open-main {
  border: #A2C755 5px solid;
  background-color: rgba(162, 199, 85, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-beauty-fashion {
    grid-row: 2;
    grid-column: 2/4;
    border: #A2C755 5px solid;
    background-color: rgba(162, 199, 85, 0.1);
    height: auto;
    overflow: inherit;
  }
  #schematic #main-beauty-fashion > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-beauty-fashion h2 {
  background-color: #A2C755;
}
#schematic #main-beauty-fashion #beauty::after {
  content: url("/homework/field/images/back-beauty.svg");
}
#schematic #main-beauty-fashion #fashion::after {
  content: url("/homework/field/images/back-fashion.svg");
}
#schematic #main-tourism-business {
  border: none;
  height: 0;
  overflow: hidden;
  margin-bottom: 20px;
}
#schematic #main-tourism-business > div {
  height: 0;
  opacity: 0;
}
#schematic #main-tourism-business.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-tourism-business.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-tourism-business.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-tourism-business.open-main {
  border: #ECACC7 5px solid;
  background-color: rgba(236, 172, 199, 0.1);
  margin-top: 30px;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) {
  #schematic #main-tourism-business {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1025px) {
  #schematic #main-tourism-business {
    grid-row: 3/5;
    grid-column: 1/3;
    border: #ECACC7 5px solid;
    background-color: rgba(236, 172, 199, 0.1);
    margin-right: 17px;
    margin-bottom: 68px;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-tourism-business > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-tourism-business h2 {
  background-color: #ECACC7;
}
#schematic #main-tourism-business #commercial-practice::after {
  content: url("/homework/field/images/back-commercial-practice.svg");
}
#schematic #main-tourism-business #tourism::after {
  content: url("/homework/field/images/back-tourism.svg");
}
#schematic #main-tourism-business #public-servant::after {
  content: url("/homework/field/images/back-public-servant.svg");
}
#schematic #main-tourism-business #sale::after {
  content: url("/homework/field/images/back-sale.svg");
}
#schematic #main-food-cooking {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-food-cooking > div {
  height: 0;
  opacity: 0;
}
#schematic #main-food-cooking.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-food-cooking.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-food-cooking.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-food-cooking.open-main {
  border: #F5E164 5px solid;
  background-color: rgba(245, 225, 100, 0.1);
  margin-top: 40px;
}
@media screen and (min-width: 1025px) {
  #schematic #main-food-cooking {
    grid-row: 3;
    grid-column: 3;
    border: #F5E164 5px solid;
    background-color: rgba(245, 225, 100, 0.1);
    height: auto;
    overflow: inherit;
  }
  #schematic #main-food-cooking > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-food-cooking h2 {
  background-color: #F5E164;
}
#schematic #main-food-cooking #food::after {
  content: url("/homework/field/images/back-food.svg");
}
#schematic #main-entertainment-design {
  border: none;
  height: 0;
  overflow: hidden;
  margin-bottom: 20px;
}
#schematic #main-entertainment-design > div {
  height: 0;
  opacity: 0;
}
#schematic #main-entertainment-design.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-entertainment-design.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-entertainment-design.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-entertainment-design.open-main {
  border: #C280AE 5px solid;
  background-color: rgba(194, 128, 174, 0.1);
  margin-top: 30px;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) {
  #schematic #main-entertainment-design {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1025px) {
  #schematic #main-entertainment-design {
    grid-row: 5/8;
    grid-column: 1/3;
    border: #C280AE 5px solid;
    background-color: rgba(194, 128, 174, 0.1);
    margin-right: 17px;
    margin-bottom: 68px;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-entertainment-design > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-entertainment-design h2 {
  background-color: #C280AE;
}
#schematic #main-entertainment-design #entertainment::after {
  content: url("/homework/field/images/back-entertainment.svg");
}
#schematic #main-entertainment-design #design::after {
  content: url("/homework/field/images/back-design.svg");
}
#schematic #main-animal-environment {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-animal-environment > div {
  height: 0;
  opacity: 0;
}
#schematic #main-animal-environment.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-animal-environment.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-animal-environment.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-animal-environment.open-main {
  border: #57B8D8 5px solid;
  background-color: rgba(87, 184, 216, 0.1);
  margin-top: 40px;
}
@media screen and (min-width: 1025px) {
  #schematic #main-animal-environment {
    grid-row: 8;
    grid-column: 1/3;
    border: #57B8D8 5px solid;
    background-color: rgba(87, 184, 216, 0.1);
    margin-right: 17px;
    height: auto;
    overflow: inherit;
  }
  #schematic #main-animal-environment > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-animal-environment h2 {
  background-color: #57B8D8;
}
#schematic #main-animal-environment #animal::after {
  content: url("/homework/field/images/back-animal.svg");
}
#schematic #main-animal-environment #environment::after {
  content: url("/homework/field/images/back-environment.svg");
}
#schematic #main-nurse-care {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-nurse-care > div {
  height: 0;
  opacity: 0;
}
#schematic #main-nurse-care.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-nurse-care.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-nurse-care.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-nurse-care.open-main {
  border: #45A6D5 5px solid;
  background-color: rgba(69, 166, 213, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-nurse-care {
    grid-row: 4/6;
    grid-column: 3;
    border: #45A6D5 5px solid;
    background-color: rgba(69, 166, 213, 0.1);
    height: auto;
    overflow: inherit;
  }
  #schematic #main-nurse-care > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-nurse-care h2 {
  background-color: #45A6D5;
}
@media screen and (min-width: 1025px) {
  #schematic #main-nurse-care h2 {
    padding: 15px 10px;
  }
}
#schematic #main-nurse-care #nurse::after {
  content: url("/homework/field/images/back-nurse.svg");
}
#schematic #main-sports {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-sports > div {
  height: 0;
  opacity: 0;
}
#schematic #main-sports.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-sports.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-sports.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-sports.open-main {
  border: #AC9AC4 5px solid;
  background-color: rgba(172, 154, 196, 0.1);
}
@media screen and (min-width: 1025px) {
  #schematic #main-sports {
    grid-row: 5/7;
    grid-column: 3;
    border: #AC9AC4 5px solid;
    background-color: rgba(172, 154, 196, 0.1);
    height: auto;
    overflow: inherit;
  }
  #schematic #main-sports > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-sports h2 {
  background-color: #AC9AC4;
}
#schematic #main-sports #sport::after {
  content: url("/homework/field/images/back-sport.svg");
}
#schematic .systembox {
  width: 100%;
  background-color: rgb(230, 230, 230);
  background-image: repeating-linear-gradient(105deg, transparent, transparent 2px, rgb(255, 255, 255) 2px, rgb(255, 255, 255) 3px);
  padding: 20px 10px;
  margin-bottom: 20px;
  position: relative;
}
@media screen and (min-width: 1025px) {
  #schematic .systembox {
    width: 300px;
    padding: 30px 10px;
    margin-bottom: 40px;
    z-index: 100;
  }
}
#schematic .systembox::after {
  position: absolute;
  right: 10px;
  bottom: 10px;
}
#schematic .systembox h3 {
  margin-bottom: 10px;
  font-size: 18px;
}
#schematic .systembox h3 a {
  position: relative;
  color: #ED7780;
  text-decoration: underline;
  font-weight: 700;
}
#schematic .systembox h3 a::before {
  content: "";
  background-color: #ED7780;
  display: inline-block;
  height: 12px;
  width: 19px;
  -webkit-mask: url("/homework/common/images/tip-link.svg");
  mask: url("/homework/common/images/tip-link.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  vertical-align: middle;
  margin-right: 20px;
  margin-top: -3px;
}
@media screen and (min-width: 2561px) {
  #schematic .systembox h3 a::before {
    height: 24px;
    width: 38px;
  }
}
#schematic .systembox h3 a::before {
  margin-right: 0 !important;
}
#schematic .systembox dt {
  font-weight: normal;
  font-size: 16px;
  color: #565656;
}
#schematic .systembox dt::before {
  content: "●";
}
#schematic .systembox dt:not(:first-of-type) {
  margin-top: 30px;
}
#schematic .systembox ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#schematic .systembox ul li {
  font-weight: normal;
  font-size: 16px;
  color: #565656;
  margin-right: 1em;
  margin-bottom: 10px;
}
#schematic .systembox ul li::before {
  content: "●";
}
#schematic .systembox dd {
  margin-left: 1em;
  margin-top: 10px;
}
#schematic .systembox dd ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#schematic .systembox dd ul li {
  margin-bottom: 10px;
  margin-right: 0;
}
#schematic .systembox dd ul li:not(:last-of-type)::after {
  content: "／";
}
#schematic .systembox dd ul li::before {
  content: "";
}

#schematic #main-datascience {
  border: none;
  height: 0;
  overflow: hidden;
}
#schematic #main-datascience > div {
  height: 0;
  opacity: 0;
}
#schematic #main-datascience.open-main {
  height: auto;
  overflow: inherit;
}
#schematic #main-datascience.open-main h2 {
  transform: translate(0, -50%);
}
#schematic #main-datascience.open-main > div {
  height: auto;
  opacity: 1;
}
#schematic #main-datascience.open-main {
  background-color: rgba(237, 105, 66, 0.1);
  border: #eeba11 solid 5px;
}
@media screen and (min-width: 1025px) {
  #schematic #main-datascience {
    width: calc(100% - 10px);
    background-color: rgba(237, 197, 66, 0.1);
    border: #eeba11 solid 5px;
    grid-column: 7/9;
    grid-row: 5/6;
    padding: 50px 15px 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    align-items: flex-start !important;
    justify-content: space-between;
    height: auto;
    overflow: inherit;
    margin-top: 20px;
  }
  #schematic #main-datascience > div {
    height: auto;
    opacity: 1;
  }
}
#schematic #main-datascience h2 {
  background-color: #eeba11;
}
@media screen and (min-width: 1025px) {
  #schematic #main-datascience h2 span.explan {
    opacity: 0;
    width: 300px;
    background-color: #FFFFE1;
    border-radius: 3px;
    position: absolute;
    left: calc(100% + 5px);
    top: 0;
    font-size: 16px;
    color: #484848;
    font-weight: normal;
    text-align: left;
    display: block;
    padding: 15px;
    white-space: initial;
  }
  #schematic #main-datascience h2 span.explan::before {
    content: "";
    position: absolute;
    top: calc(50% + 5px); /* 縦軸をセンタリングする */
    left: -30px;
    transform: translateY(-50%); /* 縦軸をセンタリングする */
    border: 15px solid transparent;
    border-right: 18px solid #FFFFE1;
  }
  #schematic #main-datascience h2:hover span.explan {
    opacity: 1;
  }
  #schematic #main-datascience h2::after {
    content: "系統説明";
    font-size: 0.7em;
    color: #eeba11;
    padding: 5px 10px;
    background-color: #ffffff;
    border-radius: 3px;
  }
}
@media screen and (min-width: 1025px) {
  #schematic #main-datascience#datascience {
    margin-top: 50px;
  }
}

.modal-map {
  /*モーダルを開くボタン*/
  /*モーダルを開くボタン*/
  /*モーダル本体の指定 + モーダル外側の背景の指定*/
  /*モーダル本体の擬似要素の指定*/
  /*モーダル本体に「active」クラス付与した時のスタイル*/
  /*モーダル枠の指定*/
  /*モーダルを閉じるボタンの指定*/
  /*モーダル内のコンテンツの指定*/
}
.modal-map .modal-open {
  width: calc(100% - 40px);
  height: 40px;
  background-color: #D8D8D8;
  border-radius: 50vh;
  font-size: 18px;
  color: #484848;
  line-height: 40px;
  text-align: center;
  margin: auto;
}
.modal-map .modal-open::after {
  font-family: "Font Awesome 5 Free";
  content: "\f00e";
  font-weight: 900;
  margin-left: 5px;
}
.modal-map .modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  padding: 20px 5px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  box-sizing: border-box;
}
.modal-map .modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}
.modal-map .modal-container.active {
  opacity: 1;
  visibility: visible;
  z-index: 3000;
}
.modal-map .modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 90%;
}
.modal-map .modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  bottom: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #484848;
  cursor: pointer;
}
.modal-map .modal-content {
  background: #fff;
  text-align: left;
  padding: 10px;
}
.modal-map .modal-content img {
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .modal-map {
    display: none;
  }
}

.co-list {
  grid-template-columns: repeat(3, 10px) repeat(2, minmax(310px, 1fr)) 10px 25px minmax(310px, 1fr);
  grid-template-rows: 275px 180px auto 35px auto;
}
.co-list div[id^=main-] {
  margin-top: 0;
  margin-bottom: 0;
  position: relative;
  padding: 50px 10px 20px;
}
.co-list div[id^=main-].open-main {
  margin-top: 20px;
  margin-bottom: 60px;
  border-radius: 20px;
}
@media screen and (min-width: 1025px) {
  .co-list div[id^=main-] {
    margin-bottom: 0;
    border-radius: 20px;
  }
}

.sp-list {
  grid-template-columns: repeat(3, minmax(310px, 1fr));
  grid-template-rows: auto auto auto auto 10px auto auto auto;
}
.sp-list div[id^=main-] {
  margin-top: 0;
  margin-bottom: 0;
  position: relative;
  padding: 50px 10px 20px;
}
.sp-list div[id^=main-].open-main {
  margin-top: 20px;
  margin-bottom: 60px;
  border-radius: 20px;
}
@media screen and (min-width: 1025px) {
  .sp-list div[id^=main-] {
    border-radius: 20px;
    padding: 50px 15px 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    margin-bottom: 68px;
  }
}

/****下層ページ****/
#contents-top-sub-literature {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/literature/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-literature {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-literature {
    margin-top: -30px;
  }
}
#contents-top-sub-literature div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-literature div {
    max-width: 75%;
  }
}
#contents-top-sub-literature div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-linguistics {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/linguistics/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-linguistics {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-linguistics {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-linguistics {
    margin-top: -30px;
  }
}
#contents-top-sub-linguistics div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-linguistics div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-linguistics div {
    max-width: 75%;
  }
}
#contents-top-sub-linguistics div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-linguistics div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-economy {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/economy/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-economy {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-economy {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-economy {
    margin-top: -30px;
  }
}
#contents-top-sub-economy div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-economy div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-economy div {
    max-width: 75%;
  }
}
#contents-top-sub-economy div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-economy div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-jurisprudence {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/jurisprudence/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-jurisprudence {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-jurisprudence {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-jurisprudence {
    margin-top: -30px;
  }
}
#contents-top-sub-jurisprudence div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-jurisprudence div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-jurisprudence div {
    max-width: 75%;
  }
}
#contents-top-sub-jurisprudence div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-jurisprudence div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-sociology {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/sociology/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-sociology {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sociology {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sociology {
    margin-top: -30px;
  }
}
#contents-top-sub-sociology div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sociology div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sociology div {
    max-width: 75%;
  }
}
#contents-top-sub-sociology div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sociology div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-science {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/science/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-science {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-science {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-science {
    margin-top: -30px;
  }
}
#contents-top-sub-science div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-science div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-science div {
    max-width: 75%;
  }
}
#contents-top-sub-science div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-science div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-department-of-engineering {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/department-of-engineering/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-department-of-engineering {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-department-of-engineering {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-department-of-engineering {
    margin-top: -30px;
  }
}
#contents-top-sub-department-of-engineering div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-department-of-engineering div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-department-of-engineering div {
    max-width: 75%;
  }
}
#contents-top-sub-department-of-engineering div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-department-of-engineering div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-agronomy {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/agronomy/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-agronomy {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-agronomy {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-agronomy {
    margin-top: -30px;
  }
}
#contents-top-sub-agronomy div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-agronomy div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-agronomy div {
    max-width: 75%;
  }
}
#contents-top-sub-agronomy div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-agronomy div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-welfare {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/welfare/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-welfare {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-welfare {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-welfare {
    margin-top: -30px;
  }
}
#contents-top-sub-welfare div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-welfare div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-welfare div {
    max-width: 75%;
  }
}
#contents-top-sub-welfare div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-welfare div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-life {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/life/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-life {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-life {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-life {
    margin-top: -30px;
  }
}
#contents-top-sub-life div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-life div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-life div {
    max-width: 75%;
  }
}
#contents-top-sub-life div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-life div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-physical-education {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/physical-education/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-physical-education {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-physical-education {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-physical-education {
    margin-top: -30px;
  }
}
#contents-top-sub-physical-education div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-physical-education div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-physical-education div {
    max-width: 75%;
  }
}
#contents-top-sub-physical-education div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-physical-education div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-art {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/art/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-art {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-art {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-art {
    margin-top: -30px;
  }
}
#contents-top-sub-art div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-art div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-art div {
    max-width: 75%;
  }
}
#contents-top-sub-art div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-art div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-medical {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/medical/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-medical {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-medical {
    margin-top: -30px;
  }
}
#contents-top-sub-medical div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-medical div {
    max-width: 75%;
  }
}
#contents-top-sub-medical div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-medical-treatment {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/medical-treatment/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-medical-treatment {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical-treatment {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-medical-treatment {
    margin-top: -30px;
  }
}
#contents-top-sub-medical-treatment div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical-treatment div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-medical-treatment div {
    max-width: 75%;
  }
}
#contents-top-sub-medical-treatment div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-medical-treatment div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-building {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/building/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-building {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-building {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-building {
    margin-top: -30px;
  }
}
#contents-top-sub-building div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-building div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-building div {
    max-width: 75%;
  }
}
#contents-top-sub-building div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-building div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-car {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/car/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-car {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-car {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-car {
    margin-top: -30px;
  }
}
#contents-top-sub-car div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-car div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-car div {
    max-width: 75%;
  }
}
#contents-top-sub-car div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-car div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-electron {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/electron/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-electron {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-electron {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-electron {
    margin-top: -30px;
  }
}
#contents-top-sub-electron div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-electron div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-electron div {
    max-width: 75%;
  }
}
#contents-top-sub-electron div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-electron div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-beauty {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/beauty/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-beauty {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-beauty {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-beauty {
    margin-top: -30px;
  }
}
#contents-top-sub-beauty div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-beauty div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-beauty div {
    max-width: 75%;
  }
}
#contents-top-sub-beauty div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-beauty div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-food {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/food/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-food {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-food {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-food {
    margin-top: -30px;
  }
}
#contents-top-sub-food div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-food div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-food div {
    max-width: 75%;
  }
}
#contents-top-sub-food div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-food div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-educate {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/educate/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-educate {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-educate {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-educate {
    margin-top: -30px;
  }
}
#contents-top-sub-educate div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-educate div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-educate div {
    max-width: 75%;
  }
}
#contents-top-sub-educate div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-educate div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-commercial-practice {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/commercial-practice/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-commercial-practice {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-commercial-practice {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-commercial-practice {
    margin-top: -30px;
  }
}
#contents-top-sub-commercial-practice div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-commercial-practice div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-commercial-practice div {
    max-width: 75%;
  }
}
#contents-top-sub-commercial-practice div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-commercial-practice div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-public-servant {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/public-servant/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-public-servant {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-public-servant {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-public-servant {
    margin-top: -30px;
  }
}
#contents-top-sub-public-servant div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-public-servant div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-public-servant div {
    max-width: 75%;
  }
}
#contents-top-sub-public-servant div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-public-servant div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-sale {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/sale/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-sale {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sale {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sale {
    margin-top: -30px;
  }
}
#contents-top-sub-sale div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sale div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sale div {
    max-width: 75%;
  }
}
#contents-top-sub-sale div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sale div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-tourism {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/tourism/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-tourism {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-tourism {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-tourism {
    margin-top: -30px;
  }
}
#contents-top-sub-tourism div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-tourism div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-tourism div {
    max-width: 75%;
  }
}
#contents-top-sub-tourism div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-tourism div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-fashion {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/fashion/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-fashion {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-fashion {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-fashion {
    margin-top: -30px;
  }
}
#contents-top-sub-fashion div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-fashion div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-fashion div {
    max-width: 75%;
  }
}
#contents-top-sub-fashion div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-fashion div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-design {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/design/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-design {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-design {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-design {
    margin-top: -30px;
  }
}
#contents-top-sub-design div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-design div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-design div {
    max-width: 75%;
  }
}
#contents-top-sub-design div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-design div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-entertainment {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/entertainment/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-entertainment {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-entertainment {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-entertainment {
    margin-top: -30px;
  }
}
#contents-top-sub-entertainment div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-entertainment div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-entertainment div {
    max-width: 75%;
  }
}
#contents-top-sub-entertainment div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-entertainment div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-animal {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/animal/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-animal {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-animal {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-animal {
    margin-top: -30px;
  }
}
#contents-top-sub-animal div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-animal div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-animal div {
    max-width: 75%;
  }
}
#contents-top-sub-animal div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-animal div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-environment {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/environment/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-environment {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-environment {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-environment {
    margin-top: -30px;
  }
}
#contents-top-sub-environment div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-environment div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-environment div {
    max-width: 75%;
  }
}
#contents-top-sub-environment div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-environment div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-nurse {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/nurse/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-nurse {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-nurse {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-nurse {
    margin-top: -30px;
  }
}
#contents-top-sub-nurse div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-nurse div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-nurse div {
    max-width: 75%;
  }
}
#contents-top-sub-nurse div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-nurse div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-sport {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/sport/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-sport {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sport {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sport {
    margin-top: -30px;
  }
}
#contents-top-sub-sport div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sport div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-sport div {
    max-width: 75%;
  }
}
#contents-top-sub-sport div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-sport div h1 {
    max-width: 1024px;
    left: 0;
  }
}

#contents-top-sub-literature {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/literature/images/header.webp);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-literature {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-literature {
    margin-top: -30px;
  }
}
#contents-top-sub-literature div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-literature div {
    max-width: 75%;
  }
}
#contents-top-sub-literature div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-literature div h1 {
    max-width: 1024px;
    left: 0;
  }
}

.co-datascience .bace-contents #main-contents #video-box .video img{
  width: 100%;
}
#contents-top-sub-datascience {
  width: 100%;
  margin-top: 0;
  width: 100%;
  height: 100px;
  margin-bottom: 20px;
  background-color: rgba(0, 0, 0, 0.3);
  background-image: url(../field/datascience/images/header.jpg);
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  background-position: left top;
  background-size: cover, cover;
  position: relative;
}
@media screen and (min-width: 768px) {
  #contents-top-sub-datascience {
    height: 200px;
    margin-bottom: 40px;
    background-position: left top;
  }
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-datascience {
    margin-top: -60px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-datascience {
    margin-top: -30px;
  }
}
#contents-top-sub-datascience div {
  width: 100%;
  height: 100%;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-datascience div {
    max-width: 1024px;
  }
}
@media screen and (min-width: 2561px) {
  #contents-top-sub-datascience div {
    max-width: 75%;
  }
}
#contents-top-sub-datascience div h1 {
  position: absolute;
  color: #fff;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 1025px) {
  #contents-top-sub-datascience div h1 {
    max-width: 1024px;
    left: 0;
  }
}

@media screen and (min-width: 1025px) {
  #co .bace-contents {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    align-items: stretch;
    justify-content: space-around;
  }
}
#co .bace-contents #main-contents {
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents #main-contents {
    width: 650px;
  }
}
#co .bace-contents #main-contents #video-box {
  margin-bottom: 30px;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents #main-contents #video-box {
    margin-bottom: 40px;
  }
}
#co .bace-contents #main-contents #video-box .video {
  width: 100%;
  max-width: 650px;
  position: relative;
  padding-top: 56.25%;
  margin-bottom: 10px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  #co .bace-contents #main-contents #video-box .video {
    margin-bottom: 20px;
  }
}
#co .bace-contents #main-contents #video-box .video iframe {
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  right: 0;
}
#co .bace-contents #main-contents #video-box .btn-arrow {
  background: #00CF6E url(/homework/common/images/arrow-link.svg) no-repeat;
  background-size: 31.5px auto;
  background-position: right 10px center;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  margin: 0 10px;
  transition: 0.5s;
}
@media screen and (min-width: 768px) {
  #co .bace-contents #main-contents #video-box .btn-arrow {
    background-size: auto auto;
    background-position: right 20px center;
  }
}
@media screen and (min-width: 2561px) {
  #co .bace-contents #main-contents #video-box .btn-arrow {
    background-size: 126px auto;
    background-position: right 40px center;
  }
}
@media screen and (min-width: 1025px) {
  #co .bace-contents #main-contents #video-box .btn-arrow {
    margin: 0 20px;
  }
}
#co .bace-contents #main-contents #video-box .btn-arrow a {
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
#co .bace-contents #main-contents #video-box .btn-arrow:hover {
  opacity: 0.5;
}
#co .bace-contents #pickup {
  margin-bottom: 40px;
}
#co .bace-contents #pickup h2 {
  background-color: #ff6e6e;
  border-radius: 3px;
  font-size: 18px;
  color: #fff;
  font-weight: normal;
  padding: 5px 10px;
  margin-bottom: 10px;
}
#co .bace-contents #pickup h2::before {
  content: "\f0a6";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-right: 5px;
}
#co .bace-contents #pickup div {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
#co .bace-contents #pickup div a figure {
  overflow: hidden;
  margin-bottom: 10px;
}
#co .bace-contents #pickup div a figure img {
  width: 100%;
  transition: 0.5s;
}
#co .bace-contents #pickup div a:hover img {
  transform: scale(115%);
  opacity: 0.75;
}
#co .bace-contents #pickup div a h3 {
  font-size: 18px;
  color: #ff6e6e;
  line-height: 1;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  #co .bace-contents #contract {
    margin-bottom: 40px;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    align-items: stretch;
  }
}
#co .bace-contents #contract div {
  width: 320px;
  border-radius: 5px;
  border: #ccc solid 1px;
  margin: 0 auto 10px;
  overflow: hidden;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents #contract div {
    width: calc((100% - 10px) / 2);
    margin: 0;
  }
}
#co .bace-contents #contract div h2 {
  font-size: 18px;
  color: #fff;
  font-weight: normal;
  padding: 10px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
#co .bace-contents #contract div h2 svg {
  fill: #fff;
  margin-right: 5px;
}
#co .bace-contents #contract div p {
  padding: 0 10px 10px;
}
#co .bace-contents #contract div ul {
  padding: 10px;
}
#co .bace-contents #contract div ul li {
  margin-bottom: 10px;
}
#co .bace-contents #contract div ul li a {
  color: #005bbb;
}
#co .bace-contents #contract div ul li a:hover {
  opacity: 0.5;
}
#co .bace-contents #contract #movie h2,
#co .bace-contents #contract #movie p {
  background-color: #6CC4E5;
}
#co .bace-contents #contract #movie svg {
  width: 17px;
  height: 16px;
}
#co .bace-contents #contract #pamph h2,
#co .bace-contents #contract #pamph p {
  background-color: #A9D150;
}
#co .bace-contents #contract #pamph svg {
  width: 24.62px;
  height: 16px;
}
#co .bace-contents section h2 {
  font-size: 24px;
  color: #ED7780;
  border-bottom: #CCCCCC solid 5px;
  position: relative;
  margin-bottom: 20px;
}
#co .bace-contents section h2:not(#explanation) {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  align-items: flex-start;
}
#co .bace-contents section h2::after {
  width: 200px;
  height: 5px;
  background-color: #ED7780;
  position: absolute;
  left: 0;
  bottom: -5px;
  content: "";
}
@media screen and (min-width: 1025px) {
  #co .bace-contents section h2::after {
    width: 300px;
  }
}
#co .bace-contents section#explanation article {
  border: #00A5CF solid 1px;
  border-radius: 5px;
  padding: 38px 10px 20px;
  margin: 54px 0 0;
  position: relative;
  clear: both;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents section#explanation article {
    margin: 64px 20px 0;
    padding: 38px 20px 20px;
  }
}
#co .bace-contents section#explanation article h3 {
  text-align: center;
  color: #fff;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
#co .bace-contents section#explanation article h3 span {
  display: inline-block;
  background-color: #00A5CF;
  padding: 7px 10px;
}
#co .bace-contents section#explanation article h3 span::before {
  transform: skewX(-30deg);
  content: "";
  position: absolute;
  left: -15%;
  top: 0;
  z-index: -1;
  width: 130%;
  height: 100%;
  background-color: #00A5CF;
}
#co .bace-contents section#explanation article:nth-of-type(odd) figure {
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  #co .bace-contents section#explanation article:nth-of-type(odd) figure {
    width: auto;
    text-align: inherit;
    float: left;
    margin-right: 20px;
  }
}
#co .bace-contents section#explanation article:nth-of-type(even) figure {
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  #co .bace-contents section#explanation article:nth-of-type(even) figure {
    width: auto;
    text-align: inherit;
    float: right;
    margin-left: 20px;
  }
}
#co .bace-contents section#explanation article p {
  margin: 0;
}
#co .bace-contents section#explanation article .course {
  background-size: auto auto;
  background-color: rgb(230, 230, 230);
  background-image: repeating-linear-gradient(105deg, transparent, transparent 2px, rgb(255, 255, 255) 2px, rgb(255, 255, 255) 3px);
  padding: 20px 10px;
  margin-top: 20px;
  clear: both;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents section#explanation article .course {
    padding: 20px 30px;
  }
}
#co .bace-contents section#explanation article .course h4 {
  font-size: 18px;
  color: #ED7780;
}
#co .bace-contents section#explanation article .course h4:not(:first-of-type) {
  margin-top: 15px;
}
#co .bace-contents section#explanation article .course h4::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 12.44px;
  background-color: #ED7780;
  -webkit-mask: url("../field/images/icon-course.svg");
  mask: url("../field/images/icon-course.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  margin-right: 5px;
}
#co .bace-contents section#explanation article .course p {
  margin: 0;
}
#co .bace-contents section#chara svg {
  width: 16.5px;
  height: 24px;
  margin: 0 5px 7px;
  fill: #ED7780;
}
#co .bace-contents section#find-job svg {
  width: 26.67px;
  height: 24px;
  margin: 0 5px 7px;
  fill: #ED7780;
}
#co .bace-contents section#find-job article {
  margin: 0 0 30px;
}
@media screen and (min-width: 1025px) {
  #co .bace-contents section#find-job article {
    margin: 0 20px;
  }
}
#co .bace-contents section#find-job article h3 {
  color: #00A5CF;
  border-bottom: #00A5CF dashed 1px;
  margin-bottom: 10px;
}
#co .bace-contents section#find-job article p {
  margin: 0 0 15px;
}
#co aside {
  width: 100%;
  transition: 0.5s;
}
@media screen and (min-width: 1025px) {
  #co aside {
    max-width: 350px;
  }
}
#co aside .btn-list {
  height: 60px;
  background-color: #3C9B7E;
  margin-bottom: 20px;
  transition: 0.5s;
}
#co aside .btn-list a {
  width: 100%;
  height: 100%;
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
}
#co aside .btn-list a::before {
  content: "";
  background-color: #fff;
  display: inline-block;
  height: 12px;
  width: 19px;
  -webkit-mask: url("/homework/common/images/tip-link.svg");
  mask: url("/homework/common/images/tip-link.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  vertical-align: middle;
  margin-right: 20px;
  margin-top: -3px;
}
@media screen and (min-width: 2561px) {
  #co aside .btn-list a::before {
    height: 24px;
    width: 38px;
  }
}
#co aside .btn-list:hover {
  opacity: 0.5;
}
#co aside h2 {
  background-color: #ED7780;
  font-size: 18px;
  color: #fff;
  text-align: center;
  padding: 15px 0;
  position: relative;
  transition: 0.5s;
}
#co aside h2::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
  background-color: #fff;
  left: 0;
  bottom: 3px;
}
#co aside h2::after {
  position: absolute;
  content: "\f13a";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  right: 15px;
  color: #fff;
}
#co aside h2.open-acc::after {
  position: absolute;
  content: "\f139";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  right: 15px;
}
@media screen and (min-width: 1025px) {
  #co aside h2 {
    font-size: 24px;
    padding: 10px 0;
  }
  #co aside h2::after {
    display: none;
  }
}
#co aside #field_list {
  display: none;
}
@media screen and (min-width: 1025px) {
  #co aside #field_list {
    display: inherit;
    position: sticky;
    top: 70px;
  }
}
#co aside #field_list.open-list-acc {
  display: inherit;
}
#co aside li {
  border-bottom: #DEDEDE solid 1px;
  padding-bottom: 15px;
  position: relative;
  transition: ease-in 0.2s;
  /*hoverした際の形状*/
}
#co aside li a {
  padding: 15px 15px 5px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  font-size: 14px;
  position: relative;
  z-index: 3;
}
#co aside li a svg {
  width: 24px;
  height: 24px;
  margin-right: 20px;
  fill: #ED7780;
}
#co aside li a > div {
  width: 24px;
  height: 24px;
  margin-right: 20px;
  background-image: url(/homework/field/images/icon-datascience.png);
}
#co aside li span {
  display: inline-block;
  background-color: #FFE32D;
  border-radius: 3px;
  padding: 5px;
  font-size: 10px;
  color: #565656;
  margin-left: 59px;
  position: relative;
  z-index: 3;
}
#co aside li::before {
  content: "";
  /*絶対配置で位置を指定*/
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  /*色や形状*/
  background: #ED7780; /*背景色*/
  width: 100%;
  height: 100%;
  /*アニメーション*/
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
#co aside li:hover a {
  color: #fff;
}
#co aside li:hover a svg {
  fill: #fff;
}
#co aside li:hover a > div{
  background-image: url(/homework/field/images/icon-datascience-w.png);
}
#co aside li:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

@media screen and (min-width: 1025px) {
  #sp .bace-contents {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    align-items: stretch;
    justify-content: space-around;
  }
}
#sp .bace-contents #main-contents {
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents #main-contents {
    width: 650px;
  }
}
#sp .bace-contents #main-contents #video-box {
  margin-bottom: 30px;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents #main-contents #video-box {
    margin-bottom: 40px;
  }
}
#sp .bace-contents #main-contents #video-box .video {
  width: 100%;
  max-width: 650px;
  position: relative;
  padding-top: 56.25%;
  margin-bottom: 10px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  #sp .bace-contents #main-contents #video-box .video {
    margin-bottom: 20px;
  }
}
#sp .bace-contents #main-contents #video-box .video iframe {
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  right: 0;
}
#sp .bace-contents #main-contents #video-box .btn-arrow {
  background: #00CF6E url(/homework/common/images/arrow-link.svg) no-repeat;
  background-size: 31.5px auto;
  background-position: right 10px center;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  margin: 0 10px;
  transition: 0.5s;
}
@media screen and (min-width: 768px) {
  #sp .bace-contents #main-contents #video-box .btn-arrow {
    background-size: auto auto;
    background-position: right 20px center;
  }
}
@media screen and (min-width: 2561px) {
  #sp .bace-contents #main-contents #video-box .btn-arrow {
    background-size: 126px auto;
    background-position: right 40px center;
  }
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents #main-contents #video-box .btn-arrow {
    margin: 0 20px;
  }
}
#sp .bace-contents #main-contents #video-box .btn-arrow a {
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
#sp .bace-contents #main-contents #video-box .btn-arrow:hover {
  opacity: 0.5;
}
#sp .bace-contents #pickup {
  margin-bottom: 40px;
}
#sp .bace-contents #pickup h2 {
  background-color: #ff6e6e;
  border-radius: 3px;
  font-size: 18px;
  color: #fff;
  font-weight: normal;
  padding: 5px 10px;
  margin-bottom: 10px;
}
#sp .bace-contents #pickup h2::before {
  content: "\f0a6";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-right: 5px;
}
#sp .bace-contents #pickup div {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
#sp .bace-contents #pickup div a figure {
  overflow: hidden;
  margin-bottom: 10px;
}
#sp .bace-contents #pickup div a figure img {
  width: 100%;
  transition: 0.5s;
}
#sp .bace-contents #pickup div a:hover img {
  transform: scale(115%);
  opacity: 0.75;
}
#sp .bace-contents #pickup div a h3 {
  font-size: 18px;
  color: #ff6e6e;
  line-height: 1;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  #sp .bace-contents #contract {
    margin-bottom: 40px;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    align-items: stretch;
  }
}
#sp .bace-contents #contract div {
  width: 320px;
  border-radius: 5px;
  border: #ccc solid 1px;
  margin: 0 auto 10px;
  overflow: hidden;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents #contract div {
    width: calc((100% - 10px) / 2);
    margin: 0;
  }
}
#sp .bace-contents #contract div h2 {
  font-size: 18px;
  color: #fff;
  font-weight: normal;
  padding: 10px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
#sp .bace-contents #contract div h2 svg {
  fill: #fff;
  margin-right: 5px;
}
#sp .bace-contents #contract div p {
  padding: 0 10px 10px;
}
#sp .bace-contents #contract div ul {
  padding: 10px;
}
#sp .bace-contents #contract div ul li {
  margin-bottom: 10px;
}
#sp .bace-contents #contract div ul li a {
  color: #005bbb;
}
#sp .bace-contents #contract div ul li a:hover {
  opacity: 0.5;
}
#sp .bace-contents #contract #movie h2,
#sp .bace-contents #contract #movie p {
  background-color: #6CC4E5;
}
#sp .bace-contents #contract #movie svg {
  width: 17px;
  height: 16px;
}
#sp .bace-contents #contract #pamph h2,
#sp .bace-contents #contract #pamph p {
  background-color: #A9D150;
}
#sp .bace-contents #contract #pamph svg {
  width: 24.62px;
  height: 16px;
}
#sp .bace-contents section h2 {
  font-size: 24px;
  color: #3C9B7E;
  border-bottom: #CCCCCC solid 5px;
  position: relative;
  margin-bottom: 20px;
}
#sp .bace-contents section h2:not(#explanation) {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  align-items: flex-start;
}
#sp .bace-contents section h2::after {
  width: 200px;
  height: 5px;
  background-color: #3C9B7E;
  position: absolute;
  left: 0;
  bottom: -5px;
  content: "";
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents section h2::after {
    width: 300px;
  }
}
#sp .bace-contents section#explanation article {
  border: #00A5CF solid 1px;
  border-radius: 5px;
  padding: 38px 10px 20px;
  margin: 54px 0 0;
  position: relative;
  clear: both;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents section#explanation article {
    margin: 64px 20px 0;
    padding: 38px 20px 20px;
  }
}
#sp .bace-contents section#explanation article h3 {
  text-align: center;
  color: #fff;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
#sp .bace-contents section#explanation article h3 span {
  display: inline-block;
  background-color: #00A5CF;
  padding: 7px 10px;
}
#sp .bace-contents section#explanation article h3 span::before {
  transform: skewX(-30deg);
  content: "";
  position: absolute;
  left: -15%;
  top: 0;
  z-index: -1;
  width: 130%;
  height: 100%;
  background-color: #00A5CF;
}
#sp .bace-contents section#explanation article:nth-of-type(odd) figure {
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  #sp .bace-contents section#explanation article:nth-of-type(odd) figure {
    width: auto;
    text-align: inherit;
    float: left;
    margin-right: 20px;
  }
}
#sp .bace-contents section#explanation article:nth-of-type(even) figure {
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  #sp .bace-contents section#explanation article:nth-of-type(even) figure {
    width: auto;
    text-align: inherit;
    float: right;
    margin-left: 20px;
  }
}
#sp .bace-contents section#explanation article p {
  margin: 0;
}
#sp .bace-contents section#explanation article .course {
  background-size: auto auto;
  background-color: rgb(230, 230, 230);
  background-image: repeating-linear-gradient(105deg, transparent, transparent 2px, rgb(255, 255, 255) 2px, rgb(255, 255, 255) 3px);
  padding: 20px 10px;
  margin-top: 20px;
  clear: both;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents section#explanation article .course {
    padding: 20px 30px;
  }
}
#sp .bace-contents section#explanation article .course h4 {
  font-size: 18px;
  color: #3C9B7E;
}
#sp .bace-contents section#explanation article .course h4:not(:first-of-type) {
  margin-top: 15px;
}
#sp .bace-contents section#explanation article .course h4::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 12.44px;
  background-color: #3C9B7E;
  -webkit-mask: url("../field/images/icon-course.svg");
  mask: url("../field/images/icon-course.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  margin-right: 5px;
}
#sp .bace-contents section#explanation article .course p {
  margin: 0;
}
#sp .bace-contents section#chara svg {
  width: 16.5px;
  height: 24px;
  margin: 0 5px 7px;
  fill: #3C9B7E;
}
#sp .bace-contents section#find-job svg {
  width: 26.67px;
  height: 24px;
  margin: 0 5px 7px;
  fill: #3C9B7E;
}
#sp .bace-contents section#find-job article {
  margin: 0 0 30px;
}
@media screen and (min-width: 1025px) {
  #sp .bace-contents section#find-job article {
    margin: 0 20px;
  }
}
#sp .bace-contents section#find-job article h3 {
  color: #00A5CF;
  border-bottom: #00A5CF dashed 1px;
  margin-bottom: 10px;
}
#sp .bace-contents section#find-job article p {
  margin: 0 0 15px;
}
#sp aside {
  width: 100%;
  transition: 0.5s;
}
@media screen and (min-width: 1025px) {
  #sp aside {
    max-width: 350px;
  }
}
#sp aside .btn-list {
  height: 60px;
  background-color: #ED7780;
  margin-bottom: 20px;
  transition: 0.5s;
}
#sp aside .btn-list a {
  width: 100%;
  height: 100%;
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
}
#sp aside .btn-list a::before {
  content: "";
  background-color: #fff;
  display: inline-block;
  height: 12px;
  width: 19px;
  -webkit-mask: url("/homework/common/images/tip-link.svg");
  mask: url("/homework/common/images/tip-link.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  vertical-align: middle;
  margin-right: 20px;
  margin-top: -3px;
}
@media screen and (min-width: 2561px) {
  #sp aside .btn-list a::before {
    height: 24px;
    width: 38px;
  }
}
#sp aside .btn-list:hover {
  opacity: 0.5;
}
#sp aside h2 {
  background-color: #3C9B7E;
  font-size: 18px;
  color: #fff;
  text-align: center;
  padding: 15px 0;
  position: relative;
  transition: 0.5s;
}
#sp aside h2::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
  background-color: #fff;
  left: 0;
  bottom: 3px;
}
#sp aside h2::after {
  position: absolute;
  content: "\f13a";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  right: 15px;
  color: #fff;
}
#sp aside h2.open-acc::after {
  position: absolute;
  content: "\f139";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  right: 15px;
}
@media screen and (min-width: 1025px) {
  #sp aside h2 {
    font-size: 24px;
    padding: 10px 0;
  }
  #sp aside h2::after {
    display: none;
  }
}
#sp aside #field_list {
  display: none;
}
@media screen and (min-width: 1025px) {
  #sp aside #field_list {
    display: inherit;
    position: sticky;
    top: 70px;
  }
}
#sp aside #field_list.open-list-acc {
  display: inherit;
}
#sp aside li {
  border-bottom: #DEDEDE solid 1px;
  padding-bottom: 15px;
  position: relative;
  transition: ease-in 0.2s;
  /*hoverした際の形状*/
}
#sp aside li a {
  padding: 15px 15px 5px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  font-size: 14px;
  position: relative;
  z-index: 3;
}
#sp aside li a svg {
  width: 24px;
  height: 24px;
  margin-right: 20px;
  fill: #3C9B7E;
}
#sp aside li span {
  display: inline-block;
  background-color: #FFE32D;
  border-radius: 3px;
  padding: 5px;
  font-size: 10px;
  color: #565656;
  margin-left: 59px;
  position: relative;
  z-index: 3;
}
#sp aside li::before {
  content: "";
  /*絶対配置で位置を指定*/
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  /*色や形状*/
  background: #3C9B7E; /*背景色*/
  width: 100%;
  height: 100%;
  /*アニメーション*/
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
#sp aside li:hover a {
  color: #fff;
}
#sp aside li:hover a svg {
  fill: #fff;
}
#sp aside li:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

/* 250331 */
@media screen and (min-width: 1025px) {
  #art.art-top-adjust h2 {
    top: 10px;
  }
  #schematic #art.art-top-adjust {
    padding-top: 60px;
  }
  #life.life-top-adjust {
    top: -44px;
  }
  #schematic h2 span.explanation-hover-adjust {
    pointer-events: none;
  }
}
@media screen and (max-width: 1024px) {
    #schematic .systembox .sc-link:not(:last-child) {
      margin-bottom: 10px;
    }
}