@charset "UTF-8";
/* --------------------------------------------------
  めし丸元気つくし /genkitukusi/ 下層共通
-------------------------------------------------- */
body {
  background: url(../img/genkitukusi/sub-page-title-back.jpg) center/auto;
}
#globalNavi .has-sub > a.genkitukusi {
  color: #ffff00;
}
#sub-page-title .h-image {
  margin: 12px;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
}
#sub-page-title .h-image::after {
  content: '';
  width: 100%;
  height: 100%;
	background: linear-gradient(to right, rgba(255,255,255,0) 25%, rgba(255,255,255,.6) 50%, rgba(255, 255, 255, 0) 75%);
  position: absolute;
	left: -100%;
	top: 0;
	transform: skewX(-15deg);
  z-index: 10;
}
  @keyframes shine {
  20% {
    left: 100%;
  }
  100%{
    left: 100%;
  }
}
#sub-page-title h1 span {
  letter-spacing: 0.17em;
}
#sub-page-title h1 strong {
  letter-spacing: 0.12em;
}
#sub-page-title nav li a {
  box-shadow: 0 4px 0 #001141;
}
#sub-page-title nav li a span {
  display: flex;
  flex-direction: column;
  gap: 2px;
  justify-content: center;
  align-items: center;
  font-size: 3.0rem;
  letter-spacing: 0.17em;
  line-height: 1.2;
}
#sub-page-title nav li a span span {
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
#sub-page-title nav li:nth-child(1) a {
  padding-left: 112px;
  background: #466da0 url(../img/genkitukusi/nav01.png) no-repeat 17px center / 65px auto;
}
#sub-page-title nav li:nth-child(2) a {
  padding-left: 83px;
  background: #466da0 url(../img/genkitukusi/nav02.png) no-repeat 17px 12px / 61.4px auto;
}
#sub-page-title nav li:nth-child(2) a span {
    letter-spacing: 0.02em;
}
#sub-page-title nav li:nth-child(3) a {
  padding-left: 88px;
  background: #466da0 url(../img/genkitukusi/nav03.png) no-repeat 20px center / 55.8px auto;
  font-size: 1.404rem;
  letter-spacing: .06em;
  line-height: 1.4;
}
#sub-page-title nav li a.active {
  background-color: #001141 !important;
}

.line {
  margin-bottom: 100px;
  text-align: center;
}

@media screen and (max-width: 1000px) {
  #globalNavi .has-sub > a.genkitukusi {
     color: #42210b;
  }
}
@media screen and (max-width: 767px) {
  #sub-page-title::after {
    height: 180vw;
  }
  #sub-page-title h1 span {
    letter-spacing: 0.07em;
  }
  #sub-page-title h1 strong {
    letter-spacing: 0.09em;
  }
  #sub-page-title nav li a {
    width: 110px;
    height: 118px;
  }
  #sub-page-title nav li:nth-child(1) a {
    padding: 10px 0;
    background: #466da0 url(../img/genkitukusi/nav01.png) no-repeat center bottom 5px / auto 54px;
  }
  #sub-page-title nav li:nth-child(2) a {
    padding: 10px 0;
    background: #466da0 url(../img/genkitukusi/nav02.png) no-repeat center bottom -10px / auto 69px;
  }
  #sub-page-title nav li:nth-child(2) a span {
    letter-spacing: 0;
  }
  #sub-page-title nav li:nth-child(3) a {
    padding: 10px 0;
    background: #466da0 url(../img/genkitukusi/nav03.png) no-repeat center bottom 8px / auto 49px;
  }
  #sub-page-title nav li:nth-child(3) a span {
    letter-spacing: 0.04em;
  }
  #sub-page-title nav li:nth-child(3) a span span {
    letter-spacing: 0.07em;
  }
  #sub-page-title nav li a span {
    font-size: 2.0rem;
    letter-spacing: 0.17em;
  }
  #sub-page-title nav li a span span {
    font-size: 1.0rem;
    letter-spacing: 0.04em;
  }
  .line {
    margin-bottom: 60px;
  }
  .line img {
    width: 152px;
    height: auto;
  }
}

/* --------------------------------------------------
  取り組み
-------------------------------------------------- */
#about {
  padding: 96px 0 540px;
  background: url(../img/genkitukusi/torikumi/about-bg.png) no-repeat bottom center/contain, linear-gradient(to bottom, transparent, #fff) no-repeat bottom center/100% 960px, #64c9f6;
  border-bottom-left-radius: 100% 40px;
  border-bottom-right-radius: 100% 40px;
  position: relative;
  z-index: 2;
}
#about .inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}
#about h2 {
  margin-bottom: 90px;
  text-align: center;
}
#about .about-text {
  color: #fff;
  font-size: 2.0rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 2.1;
}
#about .block-wrap {
  padding: 50px 0;
  margin-top: 100px;
  width: 100%;
  background: #fff;
  border-radius: 20px;
}
#about .block-wrap .flex {
  display: flex;
  justify-content: center;
}
#about .block01, #about .block02, #about .block03 {
  width: 28%;
  flex-shrink: 0;
}
#about .arrow {
  margin: 0 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#about .arrow span  {
  display: block;

  --r: 1.8px;
  height: 24px;
  aspect-ratio: cos(30deg);
  --_g:calc(tan(60deg)*var(--r)) left var(--r),#000 98%,#0000 101%;
  -webkit-mask:
    conic-gradient(from 60deg at calc(3*var(--r)/2 - 100%),#000 60deg,#0000 0)
     0 0/calc(100% - 3*var(--r)/2) 100% no-repeat,
    radial-gradient(var(--r) at calc(100% - 2*var(--r)) 50%,#000 98%,#0000 101%),
    radial-gradient(var(--r) at top    var(--_g)),
    radial-gradient(var(--r) at bottom var(--_g));
  clip-path: polygon(100% 50%,0 100%,0 0);
  background: #466da0;
}
#about strong.title {
  margin-bottom: 14px;
  padding: 11px 0;
  width: 100%;
  display: block;
  background: #466da0;
  border-radius: 10vw;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
#about .block01 {
  display: flex;
  flex-direction: column;
}
#about .block01 .concept {
  margin-bottom: 15px;
  padding: 20px;
  background: #fff6e3;
}
#about .block01 .concept ol {
  display: flex;
  flex-direction: column;
  row-gap: 18px;
}
#about .block01 .concept li {
  display: flex;
  gap: 15px;
  align-items: center;
  list-style: none;
}
#about .block01 .concept li span {
  color: #466da0;
  font-size: 1.6rem;
  font-weight: 700;
}
#about .block01 .concept li p {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
#about .block01 .concept li p span {
  color: #42210b;
  font-size: 1.0rem;
}
#about .block01 .torikumi {
  padding: 20px;
  background: #fff6e3;
}
#about .block01 .torikumi dl div {
  display: flex;
  align-items: center;
}
#about .block01 .torikumi dl div:first-child {
  margin-bottom: 14px;
}
#about .block01 .torikumi dt {
  padding-bottom: 2px;
  padding-right: 12px;
  color: #466da0;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}
#about .block01 .torikumi dd {
  padding-left: 12px;
  border-left: solid 2px #466da0;
  color: #42210b;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.28;
}
#about .block02 {
    padding: 20px;
  background: #fff6e3;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#about .block02 .flex {
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
}
#about .block02 .flex p {
  font-size: 1.8rem;
  font-weight: 700;
  color: #466da0;
  line-height: 1.2;
}
#about .block02 .arrow span {
  rotate: 90deg;
}
#about .block02 .koukoku p {
  color: #466da0;
  font-size: 1.6rem;
  font-weight: bold;
}
#about .block03 {
  display: flex;
  align-items: center;
  justify-content: center;
}
#about .block03 div {
 width: 100%;
 aspect-ratio: 1/1;
 background: #466da0;
 border-radius: 50%;
 display: flex;
 align-items: center;
 justify-content: center;
}
#about .block03 div p {
  color: #fff;
  font-size: 2.7rem;
  font-weight: 900;
  line-height: 1.6;
  text-align: center;
}

@media screen and (max-width: 1000px) {
 #about .block03 div p {
  font-size: 2.4vw;
 }
}
@media screen and (max-width: 767px) {
  #about {
    padding: 60px 0 240px;
    background-size: 800px, 100% 960px, auto;
  }
  #about h2 {
    margin-bottom: 40px;
  }
  #about .about-text {
    font-size: 1.8rem;
    line-height: 2.2;
    letter-spacing: 0.13em;
  }
  #about .block-wrap {
    max-width: 450px;
    margin-top: 40px;
    padding: 25px;
  }
  #about .block-wrap .flex {
    flex-direction: column;
    align-items: center;
  }
  #about strong.title {
    padding: 6px 0 7px;
  }
  #about .arrow {
    margin: 20px 0;
    rotate: 90deg;
  }
  #about .block01, #about .block02, #about .block03 {
    padding: 20px;
    width: 100%;
  }
  #about .block01 {
    background: #fff6e3;
  }
  #about .block01 .concept, #about .block01 .torikumi {
    padding: 0;
  }
  #about .block01 .concept {
    margin: 0 0 20px;
    padding: 0 0 20px;
    border-bottom: solid 2px #466da0;
  }
  #about .block02 {
    align-items: center;
  }
  #about .block02 .kikaku, #about .block02 .koukoku {
    width: 100%;
  }
  #about .block02 .flex {
    flex-direction: row;
  }
  #about .block02 .arrow span {
    rotate: 0deg;
  }
  #about .block03 div {
    width: 200px;
  }
  #about .block03 div p {
    font-size: 1.9rem;
    letter-spacing: 0.05em;
  }
}

/* --------------------------------------------------
  「めし丸元気つくし」研究会
-------------------------------------------------- */
#group {
  padding: 140px 0 200px;
}
#group h2 {
  margin-bottom: 90px;
  text-align: center;
}
#group .top-text {
  margin: 0 0 100px;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.17em;
  text-align: center;
}
#group .member {
  padding: 60px 45px;
  background: #fff;
  border-radius: 20px;
}
#group .member ul {
  display: flex;
  justify-content: space-between;
  list-style: none;
}
#group .member li {
  display: flex;
  gap: 12px;
  align-items: center;
}
#group .member li > div {
  display: flex;
  flex-direction: column;
  align-items: center;
}
#group .member li .position {
  padding: 10px;
  background: #79b625;
  border-radius: 10px;
  color: #fff;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-align: center;
  line-height: 1.3;
}
#group .member li .position span {
  font-size: 1.6rem;
  display: block;
}
#group .member li .name {
  margin-top: 24px;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.3;
}
#group .member li .name span {
  font-size: 2.24rem;
}
#group .member li .name .ja {
  display: block;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
}
#group .more-member  {
  margin-top: 48px;
  width: 100%;
}
#group .more-member a {
  width: 100%;
  height: 80px;
  display: block;
  background: #79b625;
  box-shadow: 0 4px 0 #006837;
  border-radius: 10vw;
  color: #ffff00;
  font-size: 3.0rem;
  font-weight: 900;
  letter-spacing: 0.17em;
  line-height: 80px;
  text-align: center;
  transition:  all .2s;
}
#group .more-member a:hover {
  box-shadow: 0 1px 0 #006837;
  transform: translateY(3px);
  text-decoration: none;
}
#group .works {
  margin-top: 60px;
}
#group .works ul {
  display: flex;
  gap: 36px;
  list-style: none;
}
#group .works li {
  padding: 20px;
  width: calc((100% - 72px)/3);
  background: #fff;
  display: flex;
  flex-direction: column;
}
#group .works li .title {
  min-height: 132px;
  background: #466da0;
  border-radius: 10px;
  color: #fff;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  line-height: 1.37;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
#group .works li .flex-box {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
#group .works li .flex-box strong {
  display: flex;
  height: 63px;
  justify-content: center;
  align-items: center;
  color: #466da0;
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.07em;
  line-height: 1.3;
  text-align: center;
}
#group .works .arrow {
  margin: 32px 0;
  display: flex;
  justify-content: center;
}
#group .works .arrow span {
  display: block;
  --r: 2.5px;
  height: 34px;
  aspect-ratio: cos(30deg);
  --_g:calc(tan(60deg)*var(--r)) left var(--r),#000 98%,#0000 101%;
  -webkit-mask:
    conic-gradient(from 60deg at calc(3*var(--r)/2 - 100%),#000 60deg,#0000 0)
     0 0/calc(100% - 3*var(--r)/2) 100% no-repeat,
    radial-gradient(var(--r) at calc(100% - 2*var(--r)) 50%,#000 98%,#0000 101%),
    radial-gradient(var(--r) at top    var(--_g)),
    radial-gradient(var(--r) at bottom var(--_g));
  clip-path: polygon(100% 50%,0 100%,0 0);
  background: #466da0;
  rotate: 90deg;
}
#group .works li .arrow {
  margin: 8px 0;
}
#group .works li .arrow span {
  --r: 1.4px;
  height: 17px;
  background: #42210b;
}
#group .works li .flex-box p {
  font-size: 1.9rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  line-height: 1.3;
}
#group .works> p {
  color: #466da0;
  font-size: 2.7rem;
  font-weight: 700;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  #group .works li .title {
    font-size: 2.2vw;
  }
  #group .works li .flex-box strong {
    font-size: 2.2vw;
  }
}
@media screen and (max-width: 767px) {
  #group {
    padding: 100px 0;
  }
  #group h2 {
    margin-bottom: 50px;
  }
  #group .top-text {
    margin-bottom: 60px;
    font-size: 1.8rem;
    letter-spacing: 0.13em;
    line-height: 2.3;
  }
  #group .member {
    padding: 30px 34px;
    border-radius: 10px;
  }
  #group .member ul {
    flex-direction: column;
    align-items: center;
    row-gap: 25px;
  }
  #group .member li .position {
    padding: 10px 5px;
    min-width: 146px;
    font-size: 1.9rem;
  }
  #group .member li .position span {
    font-size: 1.1rem;
  }
  #group .member li .name {
    margin-top: 15px;
    font-size: 2.3rem;
  }
  #group .member li .name .ja {
    font-size: 1.3rem;
  }
  #group .member li .name span {
    font-size: 1.8rem;
  }
  #group .member li img {
    width: 120px;
    height: auto;
  }
  #group .more-member {
    margin-top: 36px;
  }
  #group .more-member a {
    height: 76px;
    font-size: 2.0rem;
    line-height: 1.2;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #group .works {
    margin-top: 30px;
  }
  #group .works ul {
    flex-direction: column;
    row-gap: 20px;
  }
  #group .works li {
    padding: 20px 20px 25px;
    width: 100%;
    border-radius: 5px;
  }
  #group .works li .title {
    padding: 12px 0;
    font-size: 1.8rem;
    min-height: auto;
  }
  #group .works li:nth-child(3) .title {
    padding: 6px 0;
  }
  #group .works li .flex-box {
    margin-top: 12px;
    height: auto;
    flex-direction: row;
    align-content: center;
    justify-content: center;
  }
  #group .works li .flex-box strong {
    font-size: 1.8rem;
    white-space:  nowrap;
    min-width: 135px;
    flex-shrink: 0;
  }
  #group .works li .arrow {
    margin: 0 10px;
    display: flex;
    align-items: center;
  }
  #group .works li .arrow span {
    rotate: 0deg;
    height: 19px;
  }
  #group .works li .flex-box p {
    font-size: 1.2rem;
    letter-spacing: 0;
    display: flex;
    align-items: center;
  }
  #group .works .arrow {
    margin: 28px 0 20px;
  }
  #group .works .arrow span {
    height: 38px;
  }
  #group .works > p {
    font-size: 1.8rem;
    line-height: 2.3;
    letter-spacing: 0.13em;
  }
}


/* --------------------------------------------------
  アニメーション
-------------------------------------------------- */
.img-onigiri {
  top: -265px;
  left: -95px;
}
.img-gohan {
  top: 13.5%;
  right: -230px;
}
.img-kome {
  top: 94%;
  left: -60px;
}

@media screen and (max-width: 767px) {
  .img-onigiri {
    top: -250px;
  }
  .img-gohan {
    top: 43%;
    right: -59px;
  }
  .img-kome {
    top: auto;
    bottom: -200px;
    left: 13px;
  }
}