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

/*--------------------
	FACILITIES
--------------------*/
#facilities .sec01 {
  margin: 120px 0 90px; }
  @media screen and (max-width: 767px) {
    #facilities .sec01 {
      margin: 60px 0 30px; } }
  #facilities .sec01 h3 {
    background: none;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 600;
    padding: 0; }
    @media screen and (max-width: 767px) {
      #facilities .sec01 h3 {
        font-size: 1.4rem;
        margin-bottom: 30px; } }
  @media screen and (max-width: 767px) {
    #facilities .sec01 img {
      display: block;
      width: 100%;
      max-width: 400px;
      margin: 15px auto; } }
  #facilities .sec01 .box {
    grid-template-columns: 1fr 500px; }
    @media screen and (max-width: 767px) {
      #facilities .sec01 .box {
        grid-template-columns: 1fr; } }
    #facilities .sec01 .box h4 {
      font-size: 1.6rem;
      font-weight: normal;
      margin-bottom: 60px; }
    #facilities .sec01 .box p {
      width: 600px; }
      @media screen and (max-width: 767px) {
        #facilities .sec01 .box p {
          width: auto; } }
#facilities .sec02 {
  /*タブ切り替え全体のスタイル*/ }
  #facilities .sec02 .tabs {
    width: 1000px;
    margin: 0 auto;
    /*選択されているタブのコンテンツのみを表示*/ }
    @media screen and (max-width: 767px) {
      #facilities .sec02 .tabs {
        width: 100%; } }
    #facilities .sec02 .tabs input {
      display: none;
      /*選択されているタブのスタイルを変える*/ }
      #facilities .sec02 .tabs input:checked + label {
        background: #333;
        color: #fff; }
    #facilities .sec02 .tabs label {
      cursor: pointer;
      background: #fff;
      color: #333;
      font-size: 1.6rem;
      font-weight: 100;
      padding: 30px 33px;
      border: 1px solid #333;
      border-radius: 100px;
      margin: 0 15px; }
      @media screen and (max-width: 767px) {
        #facilities .sec02 .tabs label {
          font-size: 1.2rem;
          padding: 15px 18px;
          margin: 0 10px; } }
      #facilities .sec02 .tabs label.fst {
        margin-left: 247px; }
        @media screen and (max-width: 767px) {
          #facilities .sec02 .tabs label.fst {
            margin: 0 10px; } }
    #facilities .sec02 .tabs #fst:checked ~ #fst-map,
    #facilities .sec02 .tabs #snd:checked ~ #snd-map,
    #facilities .sec02 .tabs #trd:checked ~ #trd-map,
    #facilities .sec02 .tabs #frt:checked ~ #frt-map {
      display: block;
      position: relative; }
    #facilities .sec02 .tabs .tab-content {
      display: none;
      margin-top: 90px; }
#facilities .sec03 .box {
  column-gap: 120px;
  grid-row-gap: 60px; }
  #facilities .sec03 .box figuare img {
    margin-bottom: 30px; }
  #facilities .sec03 .box figuare figcaption dl {
    display: grid;
    grid-template-columns: 60px 1fr;
    column-gap: 15px; }
    #facilities .sec03 .box figuare figcaption dl dt {
      width: 60px;
      height: 60px;
      background: #333;
      text-align: center;
      color: #fff;
      font-size: 1.2rem;
      line-height: 3.1;
      border-radius: 30px; }
    #facilities .sec03 .box figuare figcaption dl dd {
      letter-spacing: .05em; }
      #facilities .sec03 .box figuare figcaption dl dd span {
        display: inline-block;
        font-size: 1.2rem;
        font-weight: 500;
        margin-bottom: 5px; }
#facilities .sec04 .box {
  grid-template-columns: 1fr 600px;
  column-gap: 120px; }
  @media screen and (max-width: 767px) {
    #facilities .sec04 .box {
      grid-template-columns: 1fr; } }
  #facilities .sec04 .box div img {
    width: 90%; }
    @media screen and (max-width: 767px) {
      #facilities .sec04 .box div img {
        display: block;
        max-width: 300px;
        margin: 0 auto; } }
  #facilities .sec04 .box div h4 {
    font-size: 1.6rem;
    font-weight: normal;
    letter-spacing: .2em;
    margin: 30px 0 15px; }
    @media screen and (max-width: 767px) {
      #facilities .sec04 .box div h4 {
        text-align: center;
        font-size: 1.2rem; } }
  @media screen and (max-width: 767px) {
    #facilities .sec04 .box div p {
      margin-bottom: 15px; } }

/*--------------------
	SCHEDULE
--------------------*/
#schedule .sec01 {
  margin: 90px 0; }
  @media screen and (max-width: 767px) {
    #schedule .sec01 {
      margin: 30px 0; } }
  #schedule .sec01 .box {
    grid-template-columns: 1fr 750px; }
    @media screen and (max-width: 767px) {
      #schedule .sec01 .box {
        grid-template-columns: 1fr; } }
    #schedule .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) {
        #schedule .sec01 .box h3 {
          font-size: 1.4rem; } }
    @media screen and (max-width: 767px) {
      #schedule .sec01 .box img {
        display: block;
        width: 100%;
        max-width: 400px;
        margin: 15px auto; } }
	#schedule .sec02 p {
		text-align: right;
		margin-bottom: 20px; }
	@media screen and (max-width: 767px) {
		#schedule .sec02 p {
			text-align: left; } }
	#schedule .sec02 .pnk {
		color: #d685b0;
	}
	#schedule .sec02 .grn {
		color: #9ec45f;
	}
	#schedule .sec02 .org {
		color: #eabf4b;
	}
#schedule .sec02 .box {
  column-gap: 30px;
  grid-row-gap: 60px; }
  @media screen and (max-width: 767px) {
    #schedule .sec02 .box {
      width: 100%;
      column-gap: 0; } }
  #schedule .sec02 .box div {
    display: grid;
    grid-template-columns: 380px 1fr;
    column-gap: 40px; }
    @media screen and (max-width: 767px) {
      #schedule .sec02 .box div {
        grid-template-columns: 48% 52%;
        column-gap: 0; } }
    #schedule .sec02 .box div ul {
      margin-top: 30px; }
      @media screen and (max-width: 767px) {
        #schedule .sec02 .box div ul {
          margin: 10% 0 0 30px; } }
      #schedule .sec02 .box div ul li {
        line-height: 1.8; }
      #schedule .sec02 .box div ul li span {
		vertical-align: text-bottom;
		font-size: .8em; }

/*--------------------
	LIFESTYLE
--------------------*/
#lifestyle .sec01 {
  margin-bottom: 30px; }
  #lifestyle .sec01 h3 {
    background: none;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    font-weight: 600;
    letter-spacing: .1em;
    padding: 0; }
    @media screen and (max-width: 767px) {
      #lifestyle .sec01 h3 {
        font-size: 1.4rem;
        margin-bottom: 0; } }
  @media screen and (max-width: 767px) {
    #lifestyle .sec01 img {
      display: block;
      width: 100%;
      max-width: 400px;
      margin: 15px auto; } }
#lifestyle .sec02 {
  margin-bottom: 60px; }
  #lifestyle .sec02 .box {
    margin-bottom: 0; }
    @media screen and (max-width: 767px) {
      #lifestyle .sec02 .box img {
        display: block;
        width: 100%;
        max-width: 500px;
        margin: 0 auto; } }
    #lifestyle .sec02 .box div h4 {
      font-size: 1.6rem;
      font-weight: normal;
      letter-spacing: .1em; }
      @media screen and (max-width: 767px) {
        #lifestyle .sec02 .box div h4 {
          text-align: center;
          font-size: 1.2rem;
          margin: 30px 0; } }
    #lifestyle .sec02 .box div p {
      margin: 60px 0 90px; }
      @media screen and (max-width: 767px) {
        #lifestyle .sec02 .box div p {
          margin: 30px 0 60px; } }
#lifestyle .sec03 .box {
  margin-bottom: 0; }
  @media screen and (max-width: 767px) {
    #lifestyle .sec03 .box img {
      display: block;
      width: 100%;
      max-width: 500px;
      margin: 0 auto; } }
  #lifestyle .sec03 .box div h4 {
    font-size: 1.6rem;
    font-weight: normal;
    letter-spacing: .1em; }
    @media screen and (max-width: 767px) {
      #lifestyle .sec03 .box div h4 {
        text-align: center;
        font-size: 1.2rem;
        margin: 30px 0; } }
  #lifestyle .sec03 .box div p {
    margin: 60px 0 90px; }
    @media screen and (max-width: 767px) {
      #lifestyle .sec03 .box div p {
        margin: 30px 0 60px; } }
