@charset "UTF-8";
/*--------------------
	ADMISSION
--------------------*/
#admission .lower-ttl {
  writing-mode: horizontal-tb;
  color: var(--main_font_color);
  font-size: 2rem;
  font-weight: normal;
  letter-spacing: .2em;
  margin: 60px 0 60px 15%; }
  @media screen and (max-width: 767px) {
    #admission .lower-ttl {
      font-size: 1.6rem;
      margin: 60px 0 60px 5%; } }
  #admission .lower-ttl span {
    color: #ccc;
    font-size: 1.2rem;
    letter-spacing: .05em; }
    @media screen and (max-width: 767px) {
      #admission .lower-ttl span {
        font-size: 1rem; } }
#admission #lower-lst {
  margin-bottom: 120px; }
  @media screen and (max-width: 767px) {
    #admission #lower-lst {
      margin: 0; } }
  #admission #lower-lst ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 45px; }
    @media screen and (max-width: 767px) {
      #admission #lower-lst ul {
        grid-template-columns: 1fr;
        gap: 15px; } }
    #admission #lower-lst ul li {
      background: #fff;
      line-height: 6rem;
      border-radius: 5px;
      position: relative; }
      @media screen and (max-width: 767px) {
        #admission #lower-lst ul li {
          line-height: 4rem; } }
      #admission #lower-lst ul li a {
        text-decoration: none;
        display: block;
        padding-left: 30px; }
        #admission #lower-lst ul li a:hover {
          text-decoration: underline; }
        @media screen and (max-width: 767px) {
          #admission #lower-lst ul li a {
            text-decoration: none;
            display: block;
            padding-left: 30px; } }
        #admission #lower-lst ul li a i {
          font-size: 1.6rem;
          position: absolute;
          top: 35px;
          right: 15px; }
          @media screen and (max-width: 767px) {
            #admission #lower-lst ul li a i {
              top: 20px; } }
#admission .mv {
  width: 1200px;
  margin: 60px auto; }
  @media screen and (max-width: 767px) {
    #admission .mv {
      width: auto;
      padding-bottom: 65px;
      margin: 30px 0 45px;
      position: relative; } }
  #admission .mv .txt {
    display: grid;
    grid-template-columns: 100px 1fr;
    column-gap: 100px; }
    @media screen and (max-width: 767px) {
      #admission .mv .txt {
        grid-template-columns: 1fr; } }
    #admission .mv .txt h2 {
      writing-mode: vertical-rl;
      color: var(--main_font_color);
      font-size: 2rem;
      font-weight: normal;
      letter-spacing: .2em; }
      @media screen and (max-width: 767px) {
        #admission .mv .txt h2 {
          writing-mode: horizontal-tb;
          font-size: 1.6rem;
          letter-spacing: .05em;
          position: absolute;
          bottom: 0;
          left: 5%; } }
      #admission .mv .txt h2 span {
        color: #ccc;
        font-size: 1.2rem;
        letter-spacing: .05em; }
        @media screen and (max-width: 767px) {
          #admission .mv .txt h2 span {
            color: #999; } }
#admission section {
  margin-bottom: 120px; }
  @media screen and (max-width: 767px) {
    #admission section {
      margin-bottom: 60px; } }
#admission h3 {
  display: inline-block;
  min-width: 47%;
  background-color: #fff;
  font-size: 1.6rem;
  font-weight: normal;
  letter-spacing: .2em;
  padding: 30px 5% 30px 20%;
  margin-bottom: 60px; }
  @media screen and (max-width: 767px) {
    #admission h3 {
      font-size: 1.4rem;
      padding: 30px 5%;
      letter-spacing: 0; } }
@media screen and (max-width: 767px) {
  #admission .inner {
    width: 96%;
    margin: 0 auto; } }
#admission .tel {
  text-decoration: none; }
  @media screen and (max-width: 767px) {
    #admission .tel {
      text-decoration: underline; } }
  #admission .tel:hover {
    text-decoration: none !important; }
#admission .box {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 60px;
  margin-bottom: 90px;
  position: relative; }
  @media screen and (max-width: 767px) {
    #admission .box {
      grid-template-columns: 1fr;
      margin-bottom: 30px; } }
#admission .life-footer {
  background-color: var(--main_color_yellow);
  padding: 45px 0;
  margin: 90px 0 0 0; }
  #admission .life-footer ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 45px; }
    @media screen and (max-width: 767px) {
      #admission .life-footer ul {
        grid-template-columns: 1fr;
        gap: 15px; } }
    #admission .life-footer ul li {
      background: #fff;
      line-height: 6rem;
      border-radius: 5px;
      position: relative; }
      @media screen and (max-width: 767px) {
        #admission .life-footer ul li {
          line-height: 4rem; } }
      #admission .life-footer ul li a {
        text-decoration: none;
        display: block;
        padding-left: 30px; }
        #admission .life-footer ul li a:hover {
          text-decoration: underline; }
        #admission .life-footer ul li a i {
          font-size: 1.6rem;
          position: absolute;
          top: 35px;
          right: 15px; }
          @media screen and (max-width: 767px) {
            #admission .life-footer ul li a i {
              top: 20px; } }

/*--------------------
	EXAM
--------------------*/
#exam .inner {
  padding: 0 1%; }
#exam .sec01 h3 {
  background-color: var(--main_color_yellow);
  padding: 120px 5% 120px 20%;
  margin: 0; }
  @media screen and (max-width: 767px) {
    #exam .sec01 h3 {
      padding: 60px 5% 60px 20%; } }
#exam .sec01 ul {
  list-style: none;
  display: grid;
  grid-template-columns: 500px 1fr;
  column-gap: 90px;
  margin-top: -60px; }
  @media screen and (max-width: 767px) {
    #exam .sec01 ul {
      grid-template-columns: 1fr;
      margin-top: -30px; } }
  #exam .sec01 ul li a {
    display: block;
    widows: 100%;
    text-decoration: none;
    background: #fff;
    padding: 30px;
    border: 1px solid #ddd;
    position: relative; }
    #exam .sec01 .entr li a:hover {
      text-decoration: underline; }
    #exam .sec01 .entr li a i {
      position: absolute;
      font-size: 2rem;
      top: 27px;
      right: 30px; }
@media screen and (max-width: 767px) {
  #exam .sec02 h3 {
    margin-bottom: 30px; } }
#exam .sec02 dl {
  display: grid;
  grid-template-columns: 300px 1fr;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #exam .sec02 dl {
      grid-template-columns: 1fr; } }
  #exam .sec02 dl dt {
    font-weight: 500;
    padding: 15px 0;
    position: relative; }
    #exam .sec02 dl dt span {
      position: absolute;
      top: calc(50% - 15px); }
  #exam .sec02 dl dd {
    border-left: 1px solid #999;
    padding: 15px 0 15px 60px; }
    @media screen and (max-width: 767px) {
      #exam .sec02 dl dd {
        border-left: none;
        border-top: 1px solid #999;
        padding: 15px 0; } }
#exam .sec03 {
  position: relative; }
  @media screen and (max-width: 767px) {
    #exam .sec03 h3 {
      margin-bottom: 30px; } }
	#exam .sec03 .inner {
		background: #f9f9f9;
		position: relative;
		z-index: 1;
	}
  #exam .sec03 dl {
    font-size: 1.1rem;
    letter-spacing: .05em;
    display: grid;
    grid-template-columns: 400px 300px 300px;
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      #exam .sec03 dl {
        grid-template-columns: 1fr;
        font-size: 1rem;
        position: relative; } }
    #exam .sec03 dl dt {
      font-weight: 500;
      padding-top: 15px;
      border-right: 1px solid #999;
      margin-right: 60px;
      position: relative; }
      @media screen and (max-width: 767px) {
        #exam .sec03 dl dt {
          border-right: none;
          padding-bottom: 15px;
          border-bottom: 1px solid #999;
          margin: 0 0 15px 0; } }
      #exam .sec03 dl dt span {
        position: absolute;
        top: calc(50% - 15px); }
    @media screen and (max-width: 767px) {
      #exam .sec03 dl dd {
        width: 48%;
		font-size: .9rem; } }
    @media screen and (max-width: 767px) {
      #exam .sec03 dl dd:last-child {
        position: absolute;
        bottom: 0;
		right: 0; } }
  #exam .sec03 img {
    height: 627px;
    position: absolute;
    top: 161px;
    right: 0; }
    @media screen and (max-width: 767px) {
      #exam .sec03 img {
        display: none; } }
@media screen and (max-width: 767px) {
  #exam .sec04 h3 {
    margin-bottom: 30px; } }
#exam .sec04 h4 {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: normal;
  letter-spacing: .1em;
  border-bottom: 1px solid #999; }
  @media screen and (max-width: 767px) {
    #exam .sec04 h4 {
      font-size: 1.2rem; } }
#exam .sec04 p {
  line-height: 2;
  letter-spacing: .1em;
  margin-top: 15px; }
  #exam .sec04 p span {
    font-weight: 500; }
@media screen and (max-width: 767px) {
  #exam .sec05 h3 {
    margin-bottom: 30px; } }
#exam .sec05 h4 {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: normal;
  letter-spacing: .1em;
  border-bottom: 1px solid #999;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #exam .sec05 h4 {
      display: block;
      font-size: 1.2rem;
      letter-spacing: 0; } }
#exam .sec05 dl {
  font-size: 1.1rem;
  letter-spacing: .05em;
  display: grid;
  grid-template-columns: 300px 1fr;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #exam .sec05 dl {
      grid-template-columns: 1fr;
      font-size: 1rem; } }
  #exam .sec05 dl dt {
    font-weight: 500;
    border-right: 1px solid #999;
    margin-right: 60px;
    position: relative; }
    @media screen and (max-width: 767px) {
      #exam .sec05 dl dt {
        border-right: none;
        padding-bottom: 5px;
        border-bottom: 1px dotted #999;
        margin: 0 0 5px 0; } }
#exam .sec06 .inner {
  overflow: hidden; }
  #exam .sec06 .inner .tabs {
    width: 100%;
    /*選択されているタブのコンテンツのみを表示*/ }
    #exam .sec06 .inner .tabs input {
      display: none;
      /*選択されているタブのスタイルを変える*/ }
      #exam .sec06 .inner .tabs input:checked + .tab-item {
        position: relative;
        background: #fff;
        border-top: 5px solid var(--main_color_yellow); }
        #exam .sec06 .inner .tabs input:checked + .tab-item:after {
          content: '';
          display: block;
          width: 100%;
          height: 1px;
          background: #fff;
          position: absolute;
          bottom: 0; }
    #exam .sec06 .inner .tabs .tab-item {
      cursor: pointer;
      float: left;
      width: 200px;
      background: #eee;
      text-align: center;
      font-size: 1.6rem;
      padding: 5px 0;
      border-top: 5px solid #eee;
      position: relative; }
      @media screen and (max-width: 767px) {
        #exam .sec06 .inner .tabs .tab-item {
          width: 25%;
          max-width: 150px;
          font-size: .9rem; } }
      #exam .sec06 .inner .tabs .tab-item:after {
        content: '';
        display: block;
        width: 1000px;
        height: 1px;
        background: #999;
        position: absolute;
        bottom: 0; }
    #exam .sec06 .inner .tabs #selection01:checked ~ #selection01-content,
    #exam .sec06 .inner .tabs #selection02:checked ~ #selection02-content,
    #exam .sec06 .inner .tabs #selection03:checked ~ #selection03-content,
    #exam .sec06 .inner .tabs #selection04:checked ~ #selection04-content {
      display: block;
      position: relative; }
    #exam .sec06 .inner .tabs .tab-content {
      display: none;
      padding: 20px;
      clear: both;
      overflow: hidden; }
    #exam .sec06 .inner .tabs p {
      margin-bottom: 30px; }
    #exam .sec06 .inner .tabs .tgl {
      margin-bottom: 30px; }
      #exam .sec06 .inner .tabs .tgl h3 {
        width: 100%;
        background: none !important;
        font-size: 1.6rem;
        font-weight: normal;
        letter-spacing: .05em;
        padding: 0 0 5px 0;
        border-bottom: 1px solid #999;
        margin: 0;
        position: relative; }
        @media screen and (max-width: 767px) {
          #exam .sec06 .inner .tabs .tgl h3 {
            font-size: 1.2rem;
            letter-spacing: 0; } }
        #exam .sec06 .inner .tabs .tgl h3 .scdl {
          display: inline-block;
          font-size: 1.2rem;
          padding-left: 30px;
          border-left: 1px solid #999;
          margin-left: 30px; }
          @media screen and (max-width: 767px) {
            #exam .sec06 .inner .tabs .tgl h3 .scdl {
              font-size: 1rem;
              border: none;
              padding: 0;
              margin: 0; } }
        #exam .sec06 .inner .tabs .tgl h3 i {
          position: absolute;
          right: 0; }
        #exam .sec06 .inner .tabs .tgl h3 .cls {
          opacity: 1; }
        #exam .sec06 .inner .tabs .tgl h3 .opn {
          opacity: 0; }
      #exam .sec06 .inner .tabs .tgl .open .cls {
        opacity: 0; }
      #exam .sec06 .inner .tabs .tgl .open .opn {
        opacity: 1; }
      #exam .sec06 .inner .tabs .tgl .y-b {
        background: #fff;
        padding: 30px;
        border-left: 10px solid var(--main_color_yellow);
        margin-bottom: 30px; }
        @media screen and (max-width: 767px) {
          #exam .sec06 .inner .tabs .tgl .y-b {
            padding: 30px 5%; } }
        #exam .sec06 .inner .tabs .tgl .y-b dl {
          display: grid;
          grid-template-columns: 250px 1fr;
          font-size: 1.1rem;
          margin-bottom: 30px; }
          @media screen and (max-width: 767px) {
            #exam .sec06 .inner .tabs .tgl .y-b dl {
              grid-template-columns: 1fr;
              font-size: 1rem; } }
          #exam .sec06 .inner .tabs .tgl .y-b dl:last-child {
            margin: 0; }
          #exam .sec06 .inner .tabs .tgl .y-b dl dt {
            position: relative; }
            #exam .sec06 .inner .tabs .tgl .y-b dl dt span {
              position: absolute;
              top: calc(50% - 15px); }
          #exam .sec06 .inner .tabs .tgl .y-b dl dd {
            font-weight: 300;
            padding: 0 60px;
            border-left: 1px solid #999; }
            @media screen and (max-width: 767px) {
              #exam .sec06 .inner .tabs .tgl .y-b dl dd {
                border-left: none;
                border-top: 1px solid #999;
                padding: 15px 0; } }
            #exam .sec06 .inner .tabs .tgl .y-b dl dd span {
              color: #e50211;
              font-weight: 500; }
        #exam .sec06 .inner .tabs .tgl .y-b .uln {
          padding-bottom: 15px;
          border-bottom: 1px solid #999;
          margin-bottom: 15px; }
        #exam .sec06 .inner .tabs .tgl .y-b .trd {
          grid-template-columns: 150px 250px 1fr; }
          @media screen and (max-width: 767px) {
            #exam .sec06 .inner .tabs .tgl .y-b .trd {
              grid-template-columns: 1fr; } }
@media screen and (max-width: 767px) {
  #exam .sec07 h3 {
    margin-bottom: 30px; } }
#exam .sec07 .tgl {
  margin-bottom: 60px; }
  @media screen and (max-width: 767px) {
    #exam .sec07 .tgl {
      margin-bottom: 30px; } }
#exam .sec07 h4 {
  font-size: 1.6rem;
  font-weight: normal;
  border-bottom: 1px solid #999;
  position: relative; }
  @media screen and (max-width: 767px) {
    #exam .sec07 h4 {
      font-size: 1.2rem; } }
  #exam .sec07 h4 i {
    position: absolute;
    right: 0; }
  #exam .sec07 h4 .cls {
    opacity: 1; }
  #exam .sec07 h4 .opn {
    opacity: 0; }
#exam .sec07 .open .cls {
  opacity: 0; }
#exam .sec07 .open .opn {
  opacity: 1; }
#exam .sec07 p {
  font-size: 1.1rem;
  margin: 15px 0; }
  @media screen and (max-width: 767px) {
    #exam .sec07 p {
      font-size: 1rem; } }
#exam .sec07 dl {
  font-size: 1.1rem;
  margin-bottom: 5px; }
  @media screen and (max-width: 767px) {
    #exam .sec07 dl {
      font-size: 1rem; } }
  #exam .sec07 dl dt span {
    color: #e50211; }
  #exam .sec07 dl dd {
    margin-left: 45px; }
#exam .sec07 .box {
  column-gap: 15px;
  margin: 0; }
  #exam .sec07 .box dl {
    font-size: 1rem;
    margin: 15px 0; }
    #exam .sec07 .box dl dt {
      display: inline-block;
      background-color: var(--main_color_yellow);
      font-weight: 500;
      letter-spacing: .1em;
      padding: 5px 15px;
      margin-bottom: 15px; }
      @media screen and (max-width: 767px) {
        #exam .sec07 .box dl dt {
          letter-spacing: 0; } }
    #exam .sec07 .box dl dd {
      line-height: 2;
      margin: 0; }
      #exam .sec07 .box dl dd span {
        font-weight: 500; }
#exam .sec07 .entr {
  list-style: none;
  display: grid;
  grid-template-columns: 500px 1fr;
  column-gap: 90px;
  margin-top: 90px; }
  @media screen and (max-width: 767px) {
    #exam .sec07 .entr {
      grid-template-columns: 1fr; } }
  #exam .sec07 .entr li a {
    display: block;
    widows: 100%;
    text-decoration: none;
    background: #fff;
    padding: 30px;
    border: 1px solid #ddd;
    position: relative; }
    #exam .sec07 .entr li a:hover {
      text-decoration: underline; }
    #exam .sec07 .entr li a i {
      position: absolute;
      font-size: 2rem;
      top: 27px;
      right: 30px; }


@media screen and (max-width: 767px) {
  #exam .sec08 h3 {
    margin-bottom: 30px; } }
#exam .sec08 .lst {
  list-style: decimal;
  padding-left: 1.5em;}
  #exam .sec08 .lst li {
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      #exam .sec08 .lst li {
        font-size: 1rem; } }
#exam .sec08 .entr {
  list-style: none;
  display: grid;
  grid-template-columns: 500px 1fr;
  column-gap: 90px;
  margin-top: 90px; }
  @media screen and (max-width: 767px) {
    #exam .sec08 .entr {
      grid-template-columns: 1fr; } }
  #exam .sec08 .entr li a {
    display: block;
    widows: 100%;
    text-decoration: none;
    background: #fff;
    padding: 30px;
    border: 1px solid #ddd;
    position: relative; }
    #exam .sec08 .entr li a:hover {
      text-decoration: underline; }
    #exam .sec08 .entr li a i {
      position: absolute;
      font-size: 2rem;
      top: 27px;
      right: 30px; }
@media screen and (max-width: 767px) {
  #exam .sec09 h3 {
    margin-bottom: 30px; } }
#exam .sec09 h4 {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: normal;
  letter-spacing: .1em;
  border-bottom: 1px solid #999;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #exam .sec09 h4 {
      font-size: 1.2rem; } }
#exam .sec09 dl {
  font-size: 1.1rem;
  letter-spacing: .05em;
  display: grid;
  grid-template-columns: 300px 1fr;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #exam .sec09 dl {
      grid-template-columns: 1fr;
      font-size: 1rem; } }
  #exam .sec09 dl dt {
    font-weight: 500;
    border-right: 1px solid #999;
    margin-right: 60px;
    position: relative; }
    @media screen and (max-width: 767px) {
      #exam .sec09 dl dt {
        border-right: none;
        border-bottom: 1px dotted #999;
        padding-bottom: 5px;
        margin: 0 0 5px 0; } }
#exam .sec10 dl {
  display: grid;
  grid-template-columns: 350px 1fr;
  font-size: 1.1rem; }
  @media screen and (max-width: 767px) {
    #exam .sec10 dl {
      grid-template-columns: 1fr; } }
  #exam .sec10 dl dt {
    font-weight: 500;
    padding: 15px 0;
    border-right: 1px solid #333;
    position: relative; }
    @media screen and (max-width: 767px) {
      #exam .sec10 dl dt {
        text-align: center; } }
    #exam .sec10 dl dt span {
      position: absolute;
      top: calc(50% - 15px); }
      @media screen and (max-width: 767px) {
        #exam .sec10 dl dt span {
          position: relative; } }
  #exam .sec10 dl dd {
    padding: 15px 0 15px 30px; }
    @media screen and (max-width: 767px) {
      #exam .sec10 dl dd {
        text-align: center;
        padding: 0 0 15px 0; } }
#exam .sec10 i {
  font-size: 2rem;
  margin: 5px; }
  @media screen and (max-width: 767px) {
    #exam .sec10 i {
      margin-left: calc(50% - 10px); } }
@media screen and (max-width: 767px) {
  #exam .sec11 h3 {
    margin-bottom: 30px; } }
#exam .sec11 ul {
  font-size: 1.1rem; }
  @media screen and (max-width: 767px) {
    #exam .sec11 ul {
      font-size: 1rem; } }
  #exam .sec11 ul li {
    margin-bottom: 15px; }
#exam .sec11 img {
  margin-top: -160px; }
  @media screen and (max-width: 767px) {
    #exam .sec11 img {
      margin: 0; } }

/*--------------------
	WEB
--------------------*/
#web .sec01 .box {
  grid-template-columns: 1fr 500px; }
  @media screen and (max-width: 767px) {
    #web .sec01 .box {
      grid-template-columns: 1fr; } }
  #web .sec01 .box h3 {
    background: none;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 600;
    padding: 0;
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      #web .sec01 .box h3 {
        font-size: 1.4rem; } }
  #web .sec01 .box img {
    margin-top: -130px; }
    @media screen and (max-width: 767px) {
      #web .sec01 .box img {
        width: 70%;
        max-width: 350px;
        margin: 0 auto; } }
#web .sec02 {
  margin-top: -260px; }
  @media screen and (max-width: 767px) {
    #web .sec02 {
      margin: 0; } }
  #web .sec02 h3 {
    background-color: var(--main_color_yellow);
    padding: 120px 5% 120px 20%;
    margin: 0; }
    @media screen and (max-width: 767px) {
      #web .sec02 h3 {
        padding: 30px 5% 60px 20%; } }
  #web .sec02 ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 90px;
    margin-top: -60px; }
    @media screen and (max-width: 767px) {
      #web .sec02 ul {
        grid-template-columns: 1fr;
        gap: 15px;
        margin: -30px 0 60px; } }
    #web .sec02 ul li a {
      display: block;
      widows: 100%;
      text-decoration: none;
      background: #fff;
      padding: 30px;
      border: 1px solid #ddd;
      position: relative; }
      #web .sec02 ul li a:hover {
        text-decoration: underline; }
      #web .sec02 ul li a i {
        position: absolute; }
    #web .sec02 ul li:first-child i {
      font-size: 2rem;
      top: 27px;
      right: 30px; }
    #web .sec02 ul li:last-child i {
      color: #999;
      font-size: 1.4rem;
      top: 15px;
      right: 15px; }
@media screen and (max-width: 767px) {
  #web .sec03 h3 {
    margin-bottom: 30px; } }
#web .sec03 .box {
  grid-template-columns: 1fr 1fr 1fr;
  column-gap: 60px; }
  @media screen and (max-width: 767px) {
    #web .sec03 .box {
      grid-template-columns: 1fr; } }
  @media screen and (max-width: 767px) {
    #web .sec03 .box dl {
      margin-bottom: 45px; } }
  #web .sec03 .box dl dt {
    font-size: 1.6rem;
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      #web .sec03 .box dl dt {
        font-size: 1.2rem;
        margin-bottom: 15px; } }
@media screen and (max-width: 767px) {
  #web .sec04 h3 {
    margin-bottom: 30px; } }
#web .sec04 dl {
  display: grid;
  grid-template-columns: 200px 1fr;
  font-size: 1.2rem; }
  @media screen and (max-width: 767px) {
    #web .sec04 dl {
      grid-template-columns: 1fr;
      text-align: center;
      font-size: 1rem; } }
  #web .sec04 dl dt {
    font-weight: 500;
    padding: 30px 0;
    border-right: 1px solid #333; }
    @media screen and (max-width: 767px) {
      #web .sec04 dl dt {
        padding: 15px 0 0; } }
  #web .sec04 dl dd {
    padding: 30px; }
    @media screen and (max-width: 767px) {
      #web .sec04 dl dd {
        padding: 15px 0; } }
  #web .sec04 dl .dbl {
    padding: 14px 30px; }
    @media screen and (max-width: 767px) {
      #web .sec04 dl .dbl {
        padding: 15px 0; } }
#web .sec04 i {
  font-size: 2rem;
  margin: 5px; }
  @media screen and (max-width: 767px) {
    #web .sec04 i {
      margin: 5px 0 0 calc(50% - 10px); } }
#web .sec04 p {
  margin: 30px 0 90px; }
#web .sec04 ul {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 90px; }
  @media screen and (max-width: 767px) {
    #web .sec04 ul {
      grid-template-columns: 1fr; } }
  #web .sec04 ul li a {
    display: block;
    widows: 100%;
    text-decoration: none;
    background: #fff;
    padding: 30px;
    border: 1px solid #ddd;
    position: relative; }
    #web .sec04 ul li a:hover {
      text-decoration: underline; }
    #web .sec04 ul li a i {
      position: absolute;
      color: #999;
      font-size: 1.4rem;
      top: 15px;
      right: 15px; }

/*--------------------
	EXPENSES
--------------------*/
@media screen and (max-width: 767px) {
  #expenses .sec01 h3 {
    margin-bottom: 30px; } }
#expenses .sec01 h4 {
  font-size: 1.4rem;
  font-weight: normal;
  margin-bottom: 5px; }
  @media screen and (max-width: 767px) {
    #expenses .sec01 h4 {
      font-size: 1.2rem; } }
@media screen and (max-width: 767px) {
  #expenses .sec01 .scrl {
    overflow-x: scroll; } }
#expenses .sec01 .scrl .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #expenses .sec01 .scrl .y-b {
      min-width: 500px;
      padding: 30px; } }
  #expenses .sec01 .scrl .y-b dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #expenses .sec01 .scrl .y-b dl {
        font-size: 1rem;
        grid-template-columns: 120px 1fr; } }
    #expenses .sec01 .scrl .y-b dl:last-child dd {
      padding-left: 195px; }
      @media screen and (max-width: 767px) {
		#expenses .sec01 .scrl .y-b dl:last-child dd {
		  padding-left: 105px; } }
    #expenses .sec01 .scrl .y-b dl dt {
      position: relative; }
      #expenses .sec01 .scrl .y-b dl dt span {
        position: absolute;
        top: calc(50% - 15px); }
    #expenses .sec01 .scrl .y-b dl dd {
      font-weight: 300;
      padding: 0 60px;
      border-left: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #expenses .sec01 .scrl .y-b dl dd {
          padding: 0 30px; } }
      #expenses .sec01 .scrl .y-b dl dd span {
        color: #e50211;
        font-weight: 500; }
  #expenses .sec01 .scrl .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
  #expenses .sec01 .scrl .y-b .trd {
    grid-template-columns: 150px 250px 1fr; }
    @media screen and (max-width: 767px) {
      #expenses .sec01 .scrl .y-b .trd {
        grid-template-columns: 120px 150px 1fr; } }
#expenses .sec01 ul {
  list-style: none; }
  #expenses .sec01 ul li {
	padding-left: 1em;
	text-indent: -1em; }
#expenses .sec02 h4 {
  font-size: 1.4rem;
  font-weight: normal;
  margin-bottom: 5px; }
  @media screen and (max-width: 767px) {
    #expenses .sec02 h4 {
      font-size: 1.2rem; } }
@media screen and (max-width: 767px) {
  #expenses .sec02 .scrl {
    overflow-x: scroll; } }
#expenses .sec02 .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #expenses .sec02 .y-b {
      min-width: 650px;
      padding: 30px; } }
  #expenses .sec02 .y-b h5 {
    display: inline-block;
    font-size: 1.6rem;
    font-weight: normal;
    border: 1px solid #333;
    padding: 0 15px;
    margin-top: 30px; }
    @media screen and (max-width: 767px) {
      #expenses .sec02 .y-b h5 {
        font-size: 1.2rem; } }
  #expenses .sec02 .y-b dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #expenses .sec02 .y-b dl {
        font-size: 1rem;
        grid-template-columns: 120px 1fr; } }
    #expenses .sec02 .y-b dl dt {
      position: relative; }
      #expenses .sec02 .y-b dl dt span {
        position: absolute;
        top: calc(50% - 15px); }
    #expenses .sec02 .y-b dl dd {
      font-weight: 300;
      padding: 0 60px;
      border-left: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #expenses .sec02 .y-b dl dd {
          padding: 0 30px; } }
      #expenses .sec02 .y-b dl dd span {
        color: #e50211;
        font-weight: 500; }
  #expenses .sec02 .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
  #expenses .sec02 .y-b .frt {
    grid-template-columns: 150px 250px 250px 1fr; }
    @media screen and (max-width: 767px) {
      #expenses .sec02 .y-b .frt {
        grid-template-columns: 120px 150px 150px 1fr; } }
  #expenses .sec02 .y-b .lst {
    margin-top: 60px; }
#expenses .sec02 ul {
  list-style: none; }
  #expenses .sec02 ul li {
	padding-left: 1em;
	text-indent: -1em; }
@media screen and (max-width: 767px) {
  #expenses .sec03 .scrl {
    overflow-x: scroll; } }
#expenses .sec03 h4 {
  font-size: 1.4rem;
  font-weight: normal;
  margin-bottom: 5px; }
  @media screen and (max-width: 767px) {
    #expenses .sec03 h4 {
      font-size: 1.2rem; } }
#expenses .sec03 .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #expenses .sec03 .y-b {
      min-width: 600px;
      padding: 30px; } }
  #expenses .sec03 .y-b dl {
    display: grid;
    grid-template-columns: 250px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #expenses .sec03 .y-b dl {
        font-size: 1rem;
        grid-template-columns: 200px 1fr; } }
    #expenses .sec03 .y-b dl dt {
      position: relative; }
      #expenses .sec03 .y-b dl dt span {
        position: absolute;
        top: calc(50% - 15px); }
    #expenses .sec03 .y-b dl dd {
      font-weight: 300;
      padding: 0 60px;
      border-left: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #expenses .sec03 .y-b dl dd {
          padding: 0 30px; } }
      #expenses .sec03 .y-b dl dd span {
        color: #e50211;
        font-weight: 500; }
  #expenses .sec03 .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
  #expenses .sec03 .y-b .trd {
    grid-template-columns: 250px 350px 1fr; }
    @media screen and (max-width: 767px) {
      #expenses .sec03 .y-b .trd {
        grid-template-columns: 200px 150px 1fr; } }
  #expenses .sec03 .y-b .lst {
    margin-top: 60px; }
#expenses .sec03 ul {
  list-style: none; }
  #expenses .sec03 ul li {
	padding-left: 1em;
	text-indent: -1em; }
#expenses .sec04 .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #expenses .sec04 .y-b {
      padding: 30px; } }
  #expenses .sec04 .y-b dl {
    display: grid;
    grid-template-columns: 450px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #expenses .sec04 .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #expenses .sec04 .y-b dl dt {
      position: relative; }
      #expenses .sec04 .y-b dl dt span {
        position: absolute;
        top: calc(50% - 15px); }
    #expenses .sec04 .y-b dl dd {
      font-weight: 300;
      padding: 0 60px;
      border-left: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #expenses .sec04 .y-b dl dd {
          border-left: none;
          border-top: 1px solid #999;
          padding: 15px 0 0;
          margin-top: 15px; } }
      #expenses .sec04 .y-b dl dd span {
        color: #e50211;
        font-weight: 500; }
#expenses .sec05 p span {
  font-weight: 500;
  letter-spacing: .1em; }
  #expenses .sec05 p span a {
    text-decoration: none; }
    #expenses .sec05 p span a:hover {
      text-decoration: underline; }
  #expenses .sec05 p span i {
    color: #333;
    font-size: 1.6rem;
    vertical-align: middle; }

/*--------------------
	SYSTEM
--------------------*/
#system .sec01 {
  margin-top: -135px; }
  @media screen and (max-width: 767px) {
    #system .sec01 {
      margin: 0; } }
  #system .sec01 ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px; }
    @media screen and (max-width: 767px) {
      #system .sec01 ul {
        grid-template-columns: 1fr;
        gap: 15px;
        max-width: 500px;
        margin: 0 auto 60px; } }
#system .sec02 #sprt01 {
  width: 35%;
  background-color: var(--main_color_yellow);
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 767px) {
    #system .sec02 #sprt01 {
      width: 40%; } }
  #system .sec02 #sprt01 p {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: .1em;
    padding: 30px 20% 30px 0; }
    @media screen and (max-width: 767px) {
      #system .sec02 #sprt01 p {
        font-size: 1.2rem;
        padding: 15px 10% 15px 0; } }
    #system .sec02 #sprt01 p span {
      vertical-align: middle;
      font-size: 2.4rem;
      font-weight: bold;
      margin-left: 5px; }
      @media screen and (max-width: 767px) {
        #system .sec02 #sprt01 p span {
          font-size: 1.6rem; } }
#system .sec02 h3 {
  padding-top: 60px;
  margin-top: -30px; }
#system .sec02 .inner p {
  font-size: 1.1rem;
  letter-spacing: .05em; }
  @media screen and (max-width: 767px) {
    #system .sec02 .inner p {
      font-size: 1rem; } }
#system .sec02 .inner h4 {
  font-size: 1.6rem;
  font-weight: normal;
  margin: 30px 0 5px; }
#system .sec02 .inner .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow); }
  @media screen and (max-width: 767px) {
    #system .sec02 .inner .y-b {
      padding: 30px; } }
  #system .sec02 .inner .y-b dl {
    display: grid;
    grid-template-columns: 300px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #system .sec02 .inner .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #system .sec02 .inner .y-b dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec02 .inner .y-b dl dt {
          border-right: none;
          border-bottom: 1px solid #999;
          padding-bottom: 15px;
          margin-bottom: 15px; } }
    #system .sec02 .inner .y-b dl dd {
      font-weight: 300;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        #system .sec02 .inner .y-b dl dd {
          margin: 0; } }
  #system .sec02 .inner .y-b ul {
    list-style: none; }
    #system .sec02 .inner .y-b ul li {
      font-size: 1.2rem;
      padding: 15px 0;
      border-bottom: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec02 .inner .y-b ul li {
          font-size: 1rem; } }
      #system .sec02 .inner .y-b ul li:last-child {
        border: none; }
#system .sec03 #sprt02 {
  width: 35%;
  background-color: var(--main_color_yellow);
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 767px) {
    #system .sec03 #sprt02 {
      width: 40%; } }
  #system .sec03 #sprt02 p {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: .1em;
    padding: 30px 20% 30px 0; }
    @media screen and (max-width: 767px) {
      #system .sec03 #sprt02 p {
        font-size: 1.2rem;
        padding: 15px 10% 15px 0; } }
    #system .sec03 #sprt02 p span {
      vertical-align: middle;
      font-size: 2.4rem;
      font-weight: bold;
      margin-left: 5px; }
      @media screen and (max-width: 767px) {
        #system .sec03 #sprt02 p span {
          font-size: 1.6rem; } }
#system .sec03 h3 {
  padding-top: 60px;
  margin-top: -30px; }
#system .sec03 .inner p {
  font-size: 1.1rem;
  letter-spacing: .05em; }
  @media screen and (max-width: 767px) {
    #system .sec03 .inner p {
      font-size: 1rem; } }
#system .sec03 .inner h4 {
  font-size: 1.6rem;
  font-weight: normal;
  margin: 30px 0 5px; }
#system .sec03 .inner .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-top: 30px; }
  @media screen and (max-width: 767px) {
    #system .sec03 .inner .y-b {
      padding: 30px; } }
  #system .sec03 .inner .y-b dl {
    display: grid;
    grid-template-columns: 300px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #system .sec03 .inner .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #system .sec03 .inner .y-b dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec03 .inner .y-b dl dt {
          border-right: none;
          border-bottom: 1px solid #999;
          padding-bottom: 15px;
          margin-bottom: 15px; } }
    #system .sec03 .inner .y-b dl dd {
      font-weight: 300;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        #system .sec03 .inner .y-b dl dd {
          margin: 0; } }
#system .sec03 .inner .w-b {
  background: #fff;
  padding: 30px 60px;
  border: 1px solid #ccc;
  margin-top: 60px; }
  @media screen and (max-width: 767px) {
    #system .sec03 .inner .w-b {
      padding: 30px; } }
  #system .sec03 .inner .w-b h4 {
    text-align: center;
    font-family: "Noto Serif JP", serif;
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 15px 0 30px; }
    @media screen and (max-width: 767px) {
      #system .sec03 .inner .w-b h4 {
        font-size: 1.2rem; } }
  #system .sec03 .inner .w-b ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    column-gap: 60px;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      #system .sec03 .inner .w-b ul {
        grid-template-columns: 1fr;
        gap: 15px;
        max-width: 300px;
        margin: 0 auto 30px; } }
#system .sec04 #sprt03 {
  width: 35%;
  background-color: var(--main_color_yellow);
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 767px) {
    #system .sec04 #sprt03 {
      width: 40%; } }
  #system .sec04 #sprt03 p {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: .1em;
    padding: 30px 20% 30px 0; }
    @media screen and (max-width: 767px) {
      #system .sec04 #sprt03 p {
        font-size: 1.2rem;
        padding: 15px 10% 15px 0; } }
    #system .sec04 #sprt03 p span {
      vertical-align: middle;
      font-size: 2.4rem;
      font-weight: bold;
      margin-left: 5px; }
      @media screen and (max-width: 767px) {
        #system .sec04 #sprt03 p span {
          font-size: 1.6rem; } }
#system .sec04 h3 {
  padding-top: 60px;
  margin-top: -30px; }
#system .sec04 .inner p {
  width: 540px;
  margin: -148px 0 0 660px; }
  @media screen and (max-width: 767px) {
    #system .sec04 .inner p {
      width: 100%;
      max-width: 500px;
      margin: -40px auto 0; } }
  #system .sec04 .inner p a {
    text-decoration: none;
    display: block;
    width: 100%;
    background: #fff;
    padding: 30px;
    border: 1px solid #ccc;
    position: relative; }
    @media screen and (max-width: 767px) {
      #system .sec04 .inner p a {
        padding: 30px 5%; } }
    #system .sec04 .inner p a:hover {
      text-decoration: underline; }
    #system .sec04 .inner p a i {
      font-size: 1.5rem;
      position: absolute;
      top: 31px;
      right: 15px; }
      @media screen and (max-width: 767px) {
        #system .sec04 .inner p a i {
          top: 27px;
          right: 10px; } }
#system .sec05 #sprt04 {
  width: 35%;
  background-color: var(--main_color_yellow);
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 767px) {
    #system .sec05 #sprt04 {
      width: 40%; } }
  #system .sec05 #sprt04 p {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: .1em;
    padding: 30px 20% 30px 0; }
    @media screen and (max-width: 767px) {
      #system .sec05 #sprt04 p {
        font-size: 1.2rem;
        padding: 15px 10% 15px 0; } }
    #system .sec05 #sprt04 p span {
      vertical-align: middle;
      font-size: 2.4rem;
      font-weight: bold;
      margin-left: 5px; }
      @media screen and (max-width: 767px) {
        #system .sec05 #sprt04 p span {
          font-size: 1.6rem; } }
#system .sec05 h3 {
  padding-top: 60px;
  margin-top: -30px; }
#system .sec05 .inner p {
  font-size: 1.1rem;
  letter-spacing: .05em; }
  @media screen and (max-width: 767px) {
    #system .sec05 .inner p {
      font-size: 1rem; } }
#system .sec05 .inner h4 {
  font-size: 1.6rem;
  font-weight: normal;
  margin: 30px 0 5px; }
  @media screen and (max-width: 767px) {
    #system .sec05 .inner h4 {
      font-size: 1.2rem; } }
#system .sec05 .inner .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #system .sec05 .inner .y-b {
      padding: 30px;
      font-size: 1rem; } }
  #system .sec05 .inner .y-b dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #system .sec05 .inner .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #system .sec05 .inner .y-b dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec05 .inner .y-b dl dt {
          border-right: none;
          border-bottom: 1px solid #999;
          padding-bottom: 15px;
          margin-bottom: 15px; } }
    #system .sec05 .inner .y-b dl dd {
      font-weight: 300;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        #system .sec05 .inner .y-b dl dd {
          margin: 0; } }
  #system .sec05 .inner .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      #system .sec05 .inner .y-b .uln {
        border: none;
        padding-bottom: 0;
        margin-bottom: 30px; } }
#system .sec05 .inner a {
  text-decoration: none; }
  #system .sec05 .inner a:hover {
    text-decoration: underline; }
#system .sec06 .box {
  column-gap: 120px; }
#system .sec06 ul {
  list-style: none; }
  @media screen and (max-width: 767px) {
    #system .sec06 ul {
      margin-top: 20px; } }
  #system .sec06 ul li a {
    text-decoration: none;
    display: block;
    width: 100%;
    background: #fff;
    padding: 30px;
    border: 1px solid #ccc;
    position: relative; }
    @media screen and (max-width: 767px) {
      #system .sec06 ul li a {
        padding: 30px 5%; } }
    #system .sec06 ul li a:hover {
      text-decoration: underline; }
    #system .sec06 ul li a i {
      color: #ccc;
      font-size: 1.4rem;
      position: absolute;
      top: 15px;
      right: 15px; }
      @media screen and (max-width: 767px) {
        #system .sec06 ul li a i {
          font-size: 1rem;
          top: 10px;
          right: 10px; } }
#system .sec06 h4 {
  font-size: 1.6rem;
  font-weight: normal;
  padding-bottom: 5px;
  border-bottom: 1px solid #999;
  margin: 60px 0 15px; }
  @media screen and (max-width: 767px) {
    #system .sec06 h4 {
      font-size: 1.2rem; } }
#system .sec06 h5 {
  font-size: 1.4rem;
  font-weight: normal;
  margin-bottom: 5px; }
  @media screen and (max-width: 767px) {
    #system .sec06 h5 {
      font-size: 1.1rem;
      margin: 15px 0 5px; } }
#system .sec06 .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #system .sec06 .y-b {
      padding: 30px;
      font-size: 1rem; } }
  #system .sec06 .y-b dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #system .sec06 .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #system .sec06 .y-b dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec06 .y-b dl dt {
          border-right: none;
          border-bottom: 1px solid #999;
          padding-bottom: 15px;
          margin-bottom: 15px; } }
    #system .sec06 .y-b dl dd {
      font-weight: 300;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        #system .sec06 .y-b dl dd {
          margin: 0; } }
  #system .sec06 .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      #system .sec06 .y-b .uln {
        border: none;
        padding-bottom: 0;
        margin-bottom: 30px; } }
  #system .sec06 .y-b .trd {
    grid-template-columns: 150px 1fr 1fr; }
    @media screen and (max-width: 767px) {
      #system .sec06 .y-b .trd {
        grid-template-columns: 1fr; } }
#system .sec07 h3 {
  margin-bottom: 0; }
#system .sec07 .box {
  column-gap: 120px; }
#system .sec07 h4 {
  font-size: 1.6rem;
  font-weight: normal;
  padding-bottom: 5px;
  border-bottom: 1px solid #999;
  margin: 60px 0 15px; }
  @media screen and (max-width: 767px) {
    #system .sec07 h4 {
      font-size: 1.2rem; } }
#system .sec07 h5 {
  font-size: 1.4rem;
  font-weight: normal;
  margin-bottom: 5px; }
#system .sec07 .y-b {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow);
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #system .sec07 .y-b {
      padding: 30px;
      font-size: 1rem; } }
  #system .sec07 .y-b dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    font-size: 1.2rem; }
    @media screen and (max-width: 767px) {
      #system .sec07 .y-b dl {
        grid-template-columns: 1fr;
        font-size: 1rem; } }
    #system .sec07 .y-b dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #system .sec07 .y-b dl dt {
          border-right: none;
          border-bottom: 1px solid #999;
          padding-bottom: 15px;
          margin-bottom: 15px; } }
    #system .sec07 .y-b dl dd {
      font-weight: 300;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        #system .sec07 .y-b dl dd {
          margin: 0; } }
  #system .sec07 .y-b .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      #system .sec07 .y-b .uln {
        border: none;
        padding-bottom: 0;
        margin-bottom: 30px; } }
  #system .sec07 .y-b .trd {
    grid-template-columns: 150px 1fr 1fr; }
    @media screen and (max-width: 767px) {
      #system .sec07 .y-b .trd {
        grid-template-columns: 1fr; } }
#system .sec08 #sprt05 {
  width: 35%;
  background-color: var(--main_color_yellow);
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 767px) {
    #system .sec08 #sprt05 {
      width: 40%; } }
  #system .sec08 #sprt05 p {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: .1em;
    padding: 30px 20% 30px 0; }
    @media screen and (max-width: 767px) {
      #system .sec08 #sprt05 p {
        font-size: 1.2rem;
        padding: 15px 10% 15px 0; } }
    #system .sec08 #sprt05 p span {
      vertical-align: middle;
      font-size: 2.4rem;
      font-weight: bold;
      margin-left: 5px; }
      @media screen and (max-width: 767px) {
        #system .sec08 #sprt05 p span {
          font-size: 1.6rem; } }
#system .sec08 h3 {
  padding-top: 60px;
  margin-top: -30px; }
  #system .sec08 h3 span {
    display: inline-block;
    background: #333;
    color: #fff;
    padding: 5px 15px 0 20px;
    border-radius: 10px;
    margin-bottom: 10px; }
#system .sec08 .inner p {
  width: 540px;
  margin: -148px 0 0 660px; }
  @media screen and (max-width: 767px) {
    #system .sec08 .inner p {
      width: 100%;
      max-width: 500px;
      margin: -40px auto 0; } }
  #system .sec08 .inner p a {
    text-decoration: none;
    display: block;
    width: 100%;
    background: #fff;
    padding: 30px;
    border: 1px solid #ccc;
    position: relative; }
    @media screen and (max-width: 767px) {
      #system .sec08 .inner p a {
        padding: 30px 5%; } }
    #system .sec08 .inner p a:hover {
      text-decoration: underline; }
    #system .sec08 .inner p a i {
      font-size: 1.5rem;
      position: absolute;
      top: 31px;
      right: 15px; }
      @media screen and (max-width: 767px) {
        #system .sec08 .inner p a i {
          top: 27px;
          right: 10px; } }
#system .sec09 h3 {
  background-color: var(--main_color_yellow); }
  @media screen and (max-width: 767px) {
    #system .sec09 h3 {
      margin-bottom: 30px; } }
#system .sec09 img {
  margin-top: -160px; }
  @media screen and (max-width: 767px) {
    #system .sec09 img {
      margin-top: 30px; } }

/*--------------------
	DORMITORY
--------------------*/
#dormitory .sec01 h3 {
  background: none;
  font-family: "Noto Serif JP", serif;
  font-size: 2.4rem;
  font-weight: 600;
  padding: 0;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    #dormitory .sec01 h3 {
      font-size: 1.4rem; } }
#dormitory .sec02 .inner div {
  background: #fff;
  padding: 30px 60px;
  border-left: 10px solid var(--main_color_yellow); }
  @media screen and (max-width: 767px) {
    #dormitory .sec02 .inner div {
      padding: 30px; } }
  #dormitory .sec02 .inner div dl {
    display: grid;
    grid-template-columns: 120px 1fr;
    font-size: 1.4rem; }
    @media screen and (max-width: 767px) {
      #dormitory .sec02 .inner div dl {
        grid-template-columns: 1fr; } }
    #dormitory .sec02 .inner div dl dt {
      border-right: 1px solid #999; }
      @media screen and (max-width: 767px) {
        #dormitory .sec02 .inner div dl dt {
          border: none;
          font-size: 1.2rem; } }
    #dormitory .sec02 .inner div dl dd {
      font-weight: 300;
      margin-left: 60px; }
      @media screen and (max-width: 767px) {
        #dormitory .sec02 .inner div dl dd {
          margin: 0;
          font-size: 1rem; } }
  #dormitory .sec02 .inner div .uln {
    padding-bottom: 15px;
    border-bottom: 1px solid #999;
    margin-bottom: 15px; }
#dormitory .sec02 .inner p {
  font-size: 1.2rem;
  margin-top: 30px; }
  @media screen and (max-width: 767px) {
    #dormitory .sec02 .inner p {
      font-size: 1rem; } }
#dormitory .sec03 h3 {
  margin-bottom: 30px; }
#dormitory .sec03 .inner p {
  font-size: 1.2rem;
  margin-bottom: 60px; }
  @media screen and (max-width: 767px) {
    #dormitory .sec03 .inner p {
      font-size: 1rem;
      margin-bottom: 30px; } }
#dormitory .sec03 .inner .box {
  grid-template-columns: 1fr 1fr 1fr 1fr;
  column-gap: 60px;
  grid-row-gap: 30px; }
  @media screen and (max-width: 767px) {
    #dormitory .sec03 .inner .box {
      grid-template-columns: 1fr 1fr;
      column-gap: 30px;
      grid-row-gap: 15px;
      max-width: 500px;
      margin: 0 auto; } }
  #dormitory .sec03 .inner .box figuare figcaption {
    text-align: center;
    margin-top: 15px; }
