@charset "utf-8";

/* ==========================================================================================
	--TOP
========================================================================================== */
body.index main {
	overflow: hidden;
}
body.index main > section {
	margin-bottom: 60px;
}
body.index h1 {
	margin-bottom: 40px;
	padding: 0 15px;
	color: #56728a;
	font-size: 1.2rem;
	font-weight: normal;
	letter-spacing: .15em;
}
body.index h1 span {
	margin-bottom: 15px;
	color: #005daa;
	font-family: 'Merriweather Sans';
	font-size: 3.7rem;
	font-weight: 700;
	letter-spacing: 0;
	display: block;
}

body.index .more {
	font-family: 'Merriweather Sans';
	font-size: 1.2rem;
	font-weight: 400;
	letter-spacing: .1em;
}
body.index .more a:hover {
	letter-spacing: .3em;
}

body.index .index_main {
	margin-bottom: 0;
  padding: 30px 15px;
	/* min-height: 214px; */
  min-height: 75vw;
	background: url("../img/index/main@2x.jpg") no-repeat center center;
	background-size: cover;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.index_main .image {
	margin: 0 auto;
	width: 112px;
}
.index_main .image.d2024 {
	width: 75%;
}
.index_main .image.d20242 {
	width: 100vw;
	text-align: center;
	background: #fff;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1) 15% 85%, rgba(255, 255, 255, 0));
}
.index_main .image.d20242 img {
	width: 70%;
}
body.index .index_main h1 {
	margin: 15px auto 0;
	width: 273px;
	padding: 0;
	font-size: 1.4rem;
}
.index_main h2 {
	margin-top: 35px;
	color: #fff;
	font-family: 'Merriweather Sans';
	font-size: 1.2rem;
	font-weight: 400;
	text-align: center;
}
.index_main .bnr {
  margin: 35px auto 0;
  max-width: 832px;
}

.index_nav {
	display: none;
}

.index_policy {
	padding-top: 60px;
	position: relative;
}
.index_policy:before {
	content: '';
	width: 100%;
	height: 90%;
	height: calc(100% - 50px);
	background: #eff5fa;
	position: absolute;
	top: 0;
	z-index: -1;
}
.index_policy:after {
	content: '';
	width: 50%;
	height: 100%;
	background: #5c7386;
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.index_policy .image {
	position: relative;
}
.index_policy .image img {
	max-width: 1200px;
}
.index_policy .more {
	margin: 0 0 20px 50%;
	padding-top: 50px;
	width: 50%;
	height: 100px;
	line-height: 50px;
	background: #5c7386;
}
.index_policy .more a {
	padding: 0 30px;
	color: #fff;
	display: inline-block;
}
.index_policy .more a:after {
	content: '';
	margin: -10px auto 0;
	width: 1px;
	height: 30px;
	background: #bbc7d1;
	display: block;
	transition: .5s;
	transform-origin: top;
}
.index_policy .more a:hover:after {
	transform: scaleY(1.5);
}

.index_news ul {
	padding: 0 15px;
}
.index_news li,
.news_list li {
	margin-bottom: 30px;
	font-weight: bold;
	line-height: 1.5;
}
.index_news li:last-of-type,
.news_list li:last-of-type {
	margin-bottom: 0;
}
.index_news li .date,
.news_list li .date {
	margin-bottom: .7em;
	color: #005daa;
	font-size: 1rem;
	line-height: 1;
}
.index_news .more {
	margin: 40px 0 0 50%;
	width: 50%;
	height: 50px;
	line-height: 50px;
	background: #005daa;
	position: relative;
}
.index_news .more a {
	padding: 0 30px;
	color: #fff;
	display: inline-block;
}
.index_news .more a:after {
	content: '';
	width: 50px;
	height: 1px;
	background: #bbc7d1;
	display: block;
	position: absolute;
	top: 50%;
	left: -35px;
	transition: .5s;
	transform-origin: right;
}
.index_news .more a:hover:after {
	transform: scaleX(1.5);
}

body.index .index_menu {
	margin-bottom: 0;
	padding: 60px 0;
	background: #f1f5f8;
}
.index_menu ul {
	margin: 0 auto;
	padding: 0 15px;
	max-width: 1300px;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.index_menu li {
	margin: 0 4% 13px 0;
	width: 48%;
	font-family: 'Merriweather Sans';
	font-size: 2.2rem;
	text-align: center;
	box-shadow: 0 0 7px 0 rgba(0, 0, 0, .5);
	overflow: hidden;
	position: relative;
}
.index_menu li:nth-of-type(2n) {
	margin-right: 0;
}
.index_menu li a {
	color: #fff;
}
.index_menu li a:before {
	content: '';
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .6);
	display: block;
	position: absolute;
	top: 0;
	z-index: 1;
	transition: .5s;
}
.index_menu li a:hover:before {
	background: rgba(0, 0, 0, .3);
}
.index_menu li a:hover img {
	opacity: 1;
	transform: scale(1.2);
}
.index_menu li a p {
	width: 100%;
	height: 100%;
	font-size: 1rem;
	line-height: 1.2;
	position: absolute;
	top: 0;
	left: 0;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
	z-index: 1;
}
.index_menu li span {
	margin-bottom: 15px;
	font-family: 'Merriweather Sans';
	font-size: 2.2rem;
	display: block;
}
.index_menu li .ico {
	padding: 1.7%;
	width: 33px;
	height: 33px;
	font-size: 0;
	text-align: left;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.index_menu li .ico:before {
	content: '';
	border-style: solid;
	border-width: 33px 33px 0 0;
	border-color: #f7a81b transparent transparent transparent;
	position: absolute;
	top: 0;
	left: 0;
}
.index_menu li .ico img {
	width: 47%;
	height: auto;
	position: relative;
}

.index_gallery {
	padding: 60px 0;
	background: #e9e9e9;
}
body.index .index_gallery h1 {
	color: #f7a81b;
	font-size: 3rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0;
}
.index_gallery div {
	margin: 0 -1px;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.index_gallery p {
	margin-bottom: 2px;
	padding: 0 1px;
	width: 33.3333%;
	width: calc(100% / 3);
}
.index_gallery .more {
	line-height: 1.5;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	position: relative;
}
.index_gallery .more a {
	width: 100%;
	color: #fff;
	background: #f7a81b;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.index_gallery .more a:after {
    content: '';
    width: 1px;
    height: 45px;
    background: #fff;
    display: block;
	position: absolute;
	bottom: -22px;
	left: 50%;
	transition: .5s;
	transform-origin: top;
}
.index_gallery .more a:hover:after {
	transform: scaleY(1.5);
}

body.index .index_support h1 {
	color: #8a9298;
	font-size: 2rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0;
}
.index_support div {
	margin-bottom: -30px;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.index_support p {
	margin: 0 15px 30px 15px;
}
.index_support p img {
	width: auto;
	height: 34px;
}

/* ==========================================================================================
	--NEWS
========================================================================================== */
.news_list li a {
	color: #005daa;
	text-decoration: underline;
}

/* ==========================================================================================
	--WHAT
========================================================================================== */
body.what .ttl_wrap {
	background: url("../img/what/ttl@2x.jpg") no-repeat center center;
	background-size: cover;
}
.what_nav,
.about_nav {
	margin: 30px auto 60px;
}
.what_nav ul,
.about_nav ul {
	display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.what_nav li,
.about_nav li {
	width: 50%;
	font-size: 1.2rem;
	text-align: center;
	line-height: 1.2;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
}
.what_nav li a,
.about_nav li a {
	padding: 1.5em 1em;
	width: 100%;
	color: #555;
	border-right: 1px solid #e1e8ee;
	border-bottom: 1px solid #e1e8ee;
	display: block;
}
.what_nav li a:hover,
.about_nav li a:hover {
	background: #eff5fa;
}
.what_nav li:nth-of-type(even) a,
.about_nav li:nth-of-type(even) a {
	border-right: none;
}
.what_nav li:nth-of-type(3) a,
.what_nav li:nth-of-type(4) a,
.about_nav li:nth-of-type(3) a,
.about_nav li:nth-of-type(4) a {
	border-bottom: none;
}
.what_nav li a:after,
.about_nav li a:after {
	content: '';
    margin: .7em auto 0;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #5c7386;
    border-right: 2px solid #5c7386;
    transform: rotate(45deg);
    display: block;
	transition: .5s;
}
.what_nav li a:hover:after,
.about_nav li a:hover:after {
	transform: rotate(45deg) translate(5px, 5px);
	transform-origin: center center;
}

body.what #what > div,
body.member main section > div,
.meeting_list > div,
body.gallery main section > div,
.join_fees > div {
	margin-bottom: 50px;
}
body.what #what > div:last-of-type,
body.member main section > div:last-of-type,
.meeting_list > div:last-of-type,
body.gallery main section > div:last-of-type,
.join_fees > div:last-of-type {
	margin-bottom: 0;
}
body.what #what p,
body.what #theme p,
body.greeting main section p,
body.rac main section p {
	line-height: 2;
}

body.what #object li {
	margin-bottom: 30px;
}
body.what #object li:last-of-type {
	margin-bottom: 0;
}
body.what #object dt {
	margin: 0 0 -0.4em .6em;
	color: #f7a81b;
	font-size: 2.6rem;
	font-weight: bold;
}
body.what #object dd {
	padding: 1.2em;
	line-height: 2;
	background: #fff4e0;
}

body.what #test .mark {
	margin: 0 auto;
	width: 23%;
	max-width: 162px;
}
body.what #test .txt {
	margin-top: 1.5em;
	text-align: center;
}
body.what #test ol {
    margin: 1.5em -15px 0;
}
body.what #test li {
	padding: 30px 15px;
	color: #fff;
	text-align: center;
}
body.what #test li:first-of-type {
	background: #005daa;
}
body.what #test li:nth-of-type(2) {
	background: #f7a81b;
}
body.what #test li:nth-of-type(3) {
	background: #d91b5c;
}
body.what #test li:nth-of-type(4) {
	background: #00aa68;
}
body.what #test dt {
	margin-bottom: .5em;
	padding-bottom: .3em;
	font-family: 'Merriweather Sans';
	font-size: 5rem;
	border-bottom: 2px solid #fff;
	display: inline-block;
}
body.what #test dd {
	font-size: 2rem;
	font-weight: bold;
}
body.what #test dd span {
	margin-top: 2em;
	font-family: 'Merriweather Sans';
	font-size: 1rem;
	font-weight: 400;
	display: block;
	opacity: .7;
}

body.what #theme h3 {
	margin-top: 30px;
	text-align: center;
}
body.what #theme .image {
	margin: 0 auto 40px;
	width: 75%;
	max-width: 442px;
}
body.what #theme div div p em {
	color: #005daa;
	font-weight: bold;
}

/* ==========================================================================================
	--ABOUT
========================================================================================== */
body.about .ttl_wrap,
body.news .ttl_wrap,
body.meeting .ttl_wrap,
body.gallery .ttl_wrap,
body.join .ttl_wrap,
body.contact .ttl_wrap,
body.error .ttl_wrap,
body.rac .ttl_wrap {
    background: url(../img/about/ttl@2x.jpg) no-repeat center center;
    background-size: cover;
}
body.about #slogan div {
	padding: 70px 0;
	background: url('../img/about/mark.svg') no-repeat center center;
	background-size: contain;
}
body.about #slogan p {
	color: #56728a;
	font-size: 3rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	letter-spacing: .2em;
}

body.about #about {
	overflow: hidden;
}
body.about #about dl,
body.about #sister li dl,
body.join main section dl,
body.rac main section dl {
	padding: 15px 0;
	line-height: 2;
	border-bottom: 1px dotted #bbc7d1;
}
body.about #about dl:first-of-type,
body.about #sister li dl:first-of-type,
body.join main section dl:first-of-type,
body.rac main section dl:first-of-type {
	border-top: 1px dotted #bbc7d1;
}
body.about #about dl:last-of-type,
body.rac main section dl:last-of-type {
	margin-bottom: 30px;
}
body.about #about dt,
body.about #sister li dt,
body.join main section dt,
body.rac main section dt {
	color: #005daa;
	font-size: 1.6rem;
	font-weight: bold;
}
body.about #about dd,
body.about #sister li dd,
body.join main section dd,
body.rac main section dd {
	margin-top: 1em;
}
body.about #about p:not(.btn) {
	line-height: 2;
}
body.about #about .btn,
body.join .join_about .btn,
body.meeting .meeting_list .btn {
	margin: 50px auto 0;
	max-width: 620px;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
}
body.about #about .btn a,
body.join .join_about .btn a,
body.meeting .meeting_list .btn a {
	padding: 1.7em 1em;
	color: #fff;
	background: #005daa;
	display: block;
	position: relative;
}
body.about #about .btn a:after,
body.join .join_about .btn a:after,
body.meeting .meeting_list .btn a:after {
    content: '';
    width: 1px;
    height: 30px;
    background: #bbc7d1;
    display: block;
    position: absolute;
    bottom: -15px;
    left: 50%;
    transition: .5s;
    transform-origin: top;
}
body.about #about .btn a:hover,
body.join .join_about .btn a:hover,
body.meeting .meeting_list .btn a:hover {
	background: #1677c7;
}
body.about #about .btn a:hover:after,
body.about #about .greeting .more a:hover:after,
body.join .join_about .btn a:hover:after,
body.meeting .meeting_list .btn a:hover:after {
    transform: scaleY(1.5);
}
body.about #about .greeting {
	margin: 215px -15px 0;
	background: #eff5fa;
	position: relative;
}
body.about #about .greeting:before {
	content: 'GREETING';
	color: #fff;
	font-family: 'Merriweather Sans';
	font-size: 5.8rem;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	position: absolute;
	top: 0;
	left: -.15em;
}
body.about #about .greeting div {
	position: relative;
}
body.about #about .greeting figure {
	position: absolute;
	top: -100px;
}
body.about #about .greeting figcaption,
body.greeting main section figcaption {
	padding: .5em 2em;
	color: #fff;
	font-weight: bold;
	text-align: center;
	position: absolute;
	bottom: 20px;
}
body.about #about .greeting h2 {
	margin: 30px auto 0;
	font-size: 3.8rem;
	text-align: center;
	letter-spacing: .2em;
}
body.about #about .greeting .more {
	margin: 30px auto 10px;
	width: 44%;
	max-width: 240px;
	font-family: 'Merriweather Sans';
    font-size: 1.2rem;
    font-weight: 400;
	text-align: center;
    letter-spacing: .1em;
}
body.about #about .greeting .more a {
	padding: 1em;
	color: #fff;
	display: block;
	position: relative;
}
body.about #about .greeting .more a:hover {
    letter-spacing: .3em;
}
body.about #about .greeting .more a:after {
    content: '';
    width: 1px;
    height: 20px;
    display: block;
    position: absolute;
    bottom: -10px;
    left: 50%;
    transition: .5s;
    transform-origin: top;
}
body.about #about .greeting .chaiman {
	margin-top: 100px;
	padding: 200px 0 125px;
}
body.about #about .greeting .chaiman figure {
	width: 60%;
	right: 8%;
}
body.about #about .greeting .chaiman figcaption {
	background: #56728a;
	left: -6em;
}
body.about #about .greeting .chaiman h2 {
	color: #005daa;
}
body.about #about .greeting .chaiman .more a {
	background: #005daa;
}
body.about #about .greeting .chaiman .more a:after {
    background: #bbc7d1;
}
body.about #about .greeting .organizer {
	padding: 173px 0 30px;
	background: #e9e9e9;
}
body.about #about .greeting .organizer figure {
	width: 54%;
	left: 8%;
}
body.about #about .greeting .organizer figcaption {
	background: #b78225;
	right: -6em;
}
body.about #about .greeting .organizer h2 {
	color: #f7a81b;
}
body.about #about .greeting .organizer .more a {
	background: #f7a81b;
}
body.about #about .greeting .organizer .more a:after {
	background: #fff;
}

body.about #sister li {
	margin-bottom: 30px;
}
body.about #sister li:last-of-type {
	margin-bottom: 0;
}
body.about #sister li figure {
	margin-bottom: 30px;
	text-align: center;
}
body.about #sister li figure img {
	width: 50%;
}
body.about #sister li figcaption {
	margin-top: 1em;
	color: #005daa;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
}
body.about #sister li figcaption span {
	font-size: 1.4rem;
	font-weight: normal;
}
body.about #sister h3:nth-of-type(n+2) {
	margin-top: 50px;
}

body.about #association > div {
	margin: 0 -15px;
}
body.about #association dl {
	margin-bottom: 10px;
}
body.about #association dl:last-of-type {
	margin-bottom: 0;
}
body.about #association dt {
	width: 100%;
	height: 36vw;
	max-height: 230px;
	text-align: center;
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
	position: relative;
	cursor: pointer;
}
body.about #association .drum dt {
	background: url("../img/about/association_drum@2x.jpg") no-repeat center center;
	background-size: cover;
}
body.about #association .photo dt {
	background: url("../img/about/association_photo@2x.jpg") no-repeat center center;
	background-size: cover;
}
body.about #association .baseball dt {
	background: url("../img/about/association_baseball@2x.jpg") no-repeat center center;
	background-size: cover;
}
body.about #association dt:before {
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .6);
    display: block;
    position: absolute;
    top: 0;
	left: 0;
    z-index: 1;
    transition: .5s;
}
body.about #association dt:hover:before {
    background: rgba(0, 0, 0, .3);
}
body.about #association dt p {
	color: #fff;
	font-size: 2.8rem;
	font-weight: bold;
	letter-spacing: .2em;
	z-index: 1;
	transition: .5s;
}
body.about #association dt:hover p {
	transform: scale(1.2);
}
body.about #association dt p span {
	margin-top: 1.5em;
	font-family: 'Merriweather Sans';
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: normal;
	display: block;
}
body.about #association dt > span {
	margin-top: -12px;
	width: 24px;
	height: 24px;
	position: absolute;
	top: 50%;
	right: 15px;
	z-index: 1;
}
body.about #association dt > span:before,
body.about #association dt > span:after {
	content: '';
	background: #fff;
	display: block;
	position: absolute;
}
body.about #association dt > span:before {
	margin-top: -1px;
	width: 100%;
	height: 2px;
	top: 50%;
	left: 0;
}
body.about #association dt > span:after {
	margin-left: -1px;
	width: 2px;
	height: 100%;
	top: 0;
	left: 50%;
	transition: .5s;
}
body.about #association dt.open > span:after {
    transform: scaleY(0);
}
body.about #association dd p {
	margin: 20px 0 30px;
	padding: 0 15px;
	line-height: 2;
}
body.about #association dd ul {
	margin: 0 -1px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
body.about #association dd li {
	margin-bottom: 2px;
    padding: 0 1px;
    width: 33.3333%;
    width: calc(100% / 3);
}

body.about .about_info,
body.volunteer .volunteer_archive,
body.meeting .meeting_archive {
	margin-bottom: 0;
	padding: 50px 15px;
	background: #c5cfd7;
}
.about_info h2 {
	margin-bottom: 30px;
	color: #fff;
	font-family: 'Merriweather Sans';
	font-size: 2rem;
	font-weight: 700;
	text-align: center;
}
.about_info li {
	margin-bottom: 15px;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	line-height: 20px;
}
.about_info li:last-of-type,
.meeting_list li:last-of-type {
	margin-bottom: 0;
}
.about_info li a,
.meeting_list li a {
	padding: 1.5em 1.5em 1.5em 1em;
	background: #fff;
	display: block;
	position: relative;
}
.about_info li a:hover,
.meeting_list li a:hover {
	color: #fff;
	background: #005daa;
}
.about_info li a:after,
.meeting_list li a:after {
    content: '';
	margin-top: -4px;
    width: 8px;
    height: 8px;
    border-top: 1px solid #666;
    border-right: 1px solid #666;
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 15px;
	transition: .5s;
}
.about_info li a:hover:after,
.meeting_list li a:hover:after {
	border-color: #fff;
}
.about_info li svg {
	margin-right: 1em;
    vertical-align: bottom;
}
.about_info li svg path {
    transition: .5s;
}
.about_info li a:hover svg path {
	fill: #fff;
}

/* ==========================================================================================
	--HISTORY
========================================================================================== */
body.about #history ol {
  position: relative;
}
body.about #history ol::before {
  content: '';
  width: 1px;
  height: calc(100% - 6em);
  background: #cbd4db;
  display: block;
  position: absolute;
  top: 3em;
  left: 50%;
  z-index: -1;
}
body.about #history li {
  line-height: 2;
  overflow: hidden;
}
body.about #history li:not(:last-of-type):not(:first-of-type) {
  margin-bottom: 2em;
}
body.about #history li .date {
  color: #005daa;
  background: #fff;
}
body.about #history li .txt {
  padding: .5em 0;
  background: #fff;
}
body.about #history li .number {
  margin-top: .5em;
  padding: .5em 1em;
  text-align: right;
  line-height: 1;
  background: #eff5fa;
  display: inline-block;
  float: right;
}

/* ==========================================================================================
	--PAST
========================================================================================== */
body.about #past table {
  width: 100%;
}
body.about #past th,
body.about #past td {
  padding: .5em;
  font-size: 1.2rem;
  vertical-align: middle;
  border: 1px solid #e6e6e6;
}
body.about #past th {
  font-weight: 700;
  text-align: center;
  background: #f3f3f3;
}
body.about #past td {
  line-height: 1.5;
}
body.about #past td:first-of-type {
  text-align: center;
}
body.about #past td svg {
  margin-top: .25em;
  width: 1em;
  height: auto;
  vertical-align: top;
}

/* ==========================================================================================
	--GREETING
========================================================================================== */
body.greeting .ttl_wrap {
	background: url("../img/greeting/ttl@2x.jpg") no-repeat center center;
	background-size: cover;
}
body.greeting main section figure {
	margin: 0 auto 30px;
	width: 60%;
	position: relative;
}
body.greeting main section figcaption {
	left: -2em;
}
body.greeting #chaiman figcaption {
	background: #56728a;
}
body.greeting #organizer figcaption {
	background: #b78225;
}
body.greeting main section p em {
    color: #005daa;
	font-weight: bold;
}

/* ==========================================================================================
	--MEMBER
========================================================================================== */
body.member .ttl_wrap {
    background: url(../img/member/ttl@2x.jpg) no-repeat center center;
    background-size: cover;
}
body.member .member_login {
	margin-top: 50px;
}
.member_login p {
	margin-bottom: 50px;
	text-align: center;
	line-height: 2;
}
.member_login dl {
	margin: 0 auto 2em;
	max-width: 600px;
}
.member_login dt {
	margin-bottom: .5em;
	font-weight: bold;
}
.member_login button,
.contact_form button {
    padding: 1em 2em;
    font-family: inherit;
    border: none;
    border-radius: 2px;
    cursor: pointer;
    transition: .5s;
}
.member_login button[type="submit"],
.contact_form button[type="submit"] {
    margin: 50px auto 0;
    width: 100%;
    max-width: 320px;
    color: #fff;
    font-size: 1.6rem;
    background: #d91b47;
    display: block;
}
.member_login button[type="submit"]:hover,
.contact_form button[type="submit"]:hover {
	background: #dc4568;
}

.member_list table {
	width: 100%;
}
.member_list table th,
.member_list table td {
	padding: 1em;
    border: 1px solid #bbc7d1;
}
.member_list table th {
	font-weight: bold;
	background: #eff5fa;
}
.member_list table th:first-of-type,
.member_list table th:nth-of-type(4) {
	width: 8.1em;
}
.member_list table th:nth-of-type(3) {
	width: 13.1em;
}
.member_list table td {
	vertical-align: top;
}
.member_list table td img {
	height: 1em;
	vertical-align: text-top;
}

/* ==========================================================================================
	--VOLUNTEER
========================================================================================== */
body.volunteer .ttl_wrap {
    background: url(../img/volunteer/ttl@2x.jpg) no-repeat center center;
    background-size: cover;
}
body.volunteer .volunteer_about {
	margin: 60px auto 147px;
	padding: 0;
	text-align: center;
	position: relative;
}
body.volunteer .volunteer_about div {
	margin: 0 auto;
	width: 100%;
	height: 50vw;
	max-height: 428px;
	max-width: 1080px;
}
body.volunteer .volunteer_about div a {
	height: 100%;
	background: url(../img/volunteer/about@2x.jpg) no-repeat center center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
}
body.volunteer .volunteer_about div a:before {
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .6);
    display: block;
    position: absolute;
    top: 0;
	left: 0;
    z-index: 1;
    transition: .5s;
}
body.volunteer .volunteer_about div a:hover:before {
    background: rgba(0, 0, 0, .3);
}
body.volunteer .volunteer_about div p {
	color: #fff;
	font-size: 2.2rem;
	font-weight: bold;
	letter-spacing: .1em;
	z-index: 1;
    transition: .5s;
}
body.volunteer .volunteer_about div p span {
	margin-top: 20px;
	font-family: 'Merriweather Sans';
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: normal;
	display: block;
}
body.volunteer .volunteer_about div a:hover p {
    transform: scale(1.2);
}
body.volunteer .volunteer_about .more {
	margin: 0 0 12px -35px;
    width: 70px;
	height: 70px;
    font-family: 'Merriweather Sans';
    font-size: 1.2rem;
    font-weight: 400;
    text-align: center;
	line-height: 1.2;
    letter-spacing: .1em;
	position: absolute;
	bottom: -47px;
	left: 50%;
	z-index: 1;
}
body.volunteer .volunteer_about .more a {
	width: 100%;
	height: 100%;
    color: #fff;
	background: #005daa;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
}
body.volunteer .volunteer_about .more a:hover {
    letter-spacing: .3em;
}
body.volunteer .volunteer_about .more a:after {
    content: '';
    width: 1px;
    height: 25px;
    background: #bbc7d1;
    display: block;
    position: absolute;
    bottom: -12px;
    left: 50%;
    transition: .5s;
    transform-origin: top;
}
body.volunteer .volunteer_about .more a:hover:after {
    transform: scaleY(1.5);
}

.report_list {
	margin: 0 -15px;
}
.report_list .post {
	border-bottom: 1px solid #dce1e5;
	position: relative;
}
.report_list .post .post_thumb {
    overflow: hidden;
    position: relative;
}
.report_list .post .post_thumb:before {
    content: '';
    padding-top: 56.25%;
    display: block;
}
.report_list .post .post_thumb img {
    margin: auto;
    width: 100%;
    height: 100%;
    background-position-x: center!important;
    background-position-y: center!important;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: 'object-fit: cover; object-position: 0 100%;';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}
.report_list .post a:hover .post_thumb img {
	opacity: 1;
	transform: scale(1.2);
}
.report_list .post .post_cat {
	padding: .5em .7em;
	color: #fff;
	font-size: 1.2rem;
	background: #0a7f39;
	position: absolute;
	top: 0;
	left: 0;
}
.post_cat.cat08 {
	background: #d91b5c!important;
}
.post_cat.cat09 {
	background: #7e9500!important;
}
.post_cat.cat10 {
	background: #005daa!important;
}
.post_cat.cat11,
.post_cat.cat12,
.post_cat.cat13,
.post_cat.cat14,
.post_cat.cat15,
.post_cat.cat18 {
	background: #6b4313!important;
}
.post_cat.cat16 {
	background: #0096bb!important;
}
.post_cat.cat17 {
	background: #e91600!important;
}
.report_list .post .post_text {
	padding: 25px 15px;
	font-weight: bold;
}
.report_list .post .post_time {
	margin-bottom: 1em;
	font-size: 1.2rem;
	color: #888;
}
.report_list .post .post_ttl {
	font-size: 1.8rem;
	white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

body.volunteer .volunteer_archive h2,
body.meeting .meeting_archive h2 {
	margin-bottom: 30px;
	color: #fff;
	font-size: 1rem;
	font-weight: normal;
	text-align: center;
}
body.volunteer .volunteer_archive h2 span,
body.meeting .meeting_archive h2 span {
	margin: 0 auto .5em;
	color: #fff;
	font-family: 'Merriweather Sans';
	font-size: 2rem;
	font-weight: 700;
}
.volunteer_archive ul,
.meeting_archive ul {
	margin-bottom: -10px;
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.volunteer_archive li,
.meeting_archive li {
	margin: 0 4% 10px 0;
	width: 48%;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
}
.volunteer_archive li:nth-of-type(even),
.meeting_archive li:nth-of-type(even) {
	margin-right: 0;
}
.volunteer_archive li a,
.meeting_archive li a {
	padding: 1em;
	background: #fff;
	display: block;
}
.volunteer_archive li a:hover,
.meeting_archive li a:hover {
	color: #fff;
	background: #005daa;
}

/* ==========================================================================================
	--VOLUNTEER ABOUT
========================================================================================== */
body.volunteer.about .ttl_wrap {
    background: url(../img/volunteer/about/ttl@2x.jpg) no-repeat center center;
    background-size: cover;
}
body.volunteer.about section > div {
    margin-bottom: 50px;
}
body.volunteer.about section > div p {
    line-height: 2;
}
.volunteer_service > div:first-of-type ul li {
	margin-bottom: 1em;
	line-height: 2;
}
.volunteer_service > div:first-of-type li:before {
	content: '・';
}
.volunteer_service > div:first-of-type li:last-of-type {
	margin-bottom: 0;
}
.volunteer_service > div:first-of-type li em {
	color: #005daa;
	font-size: 120%;
	font-weight: bold;
}
.volunteer_service .image,
.volunteer_youth .image {
	margin: 30px auto -13px;
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.volunteer_service .image li,
.volunteer_youth .image li {
	margin: 0 4% 13px 0;
	width: 48%;
}
.volunteer_service .image li:nth-of-type(even),
.volunteer_youth .image li:nth-of-type(even) {
	margin-right: 0;
}

/* ==========================================================================================
	--VOLUNTEER SINGLE
========================================================================================== */
body.volunteer .volunteer_post {
	margin-top: 50px;
}
.volunteer_post .post_time {
	color: #888;
	font-size: 1rem;
	font-weight: bold;
	text-align: right;
}
.volunteer_post .post_cat {
	margin-top: 10px;
	padding: .5em .7em;
	color: #fff;
	font-size: 1rem;
	background: #0a7f39;
	display: inline-block;
}
.volunteer_post .entry-header {
	margin-top: 25px;
}
.volunteer_post .entry-header h1 {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
}
.volunteer_post .entry-content {
	margin-top: 40px;
    line-height: 2;
	word-break: break-all;
}
.volunteer_post .entry-content a {
	color: #e50012;
	text-decoration: underline;
}
.volunteer_post .entry-content i,
.volunteer_post .entry-content em {
	font-style: italic;
}
.volunteer_post .entry-content b,
.volunteer_post .entry-content strong {
	font-weight: bold;
}
.volunteer_post .entry-content object,
.volunteer_post .entry-content embed,
.volunteer_post .entry-content video,
.volunteer_post .entry-content iframe,
.volunteer_post .entry-content canvas {
	max-width: 100%;
	height: auto;
}
.volunteer_post .entry-content h1,
.volunteer_post .entry-content h2,
.volunteer_post .entry-content h3,
.volunteer_post .entry-content h4,
.volunteer_post .entry-content h5,
.volunteer_post .entry-content h6 {
	font-weight: bold;
	text-align: left;
	letter-spacing: 0;
	display: block;
}
.volunteer_post .entry-content h1,
.volunteer_post .entry-content h2,
.volunteer_post .entry-content h3,
.volunteer_post .entry-content h4 {
	padding: 0 0 .5em 0;

}
.volunteer_post .entry-content h1,
.volunteer_post .entry-content h2 {
	border-bottom: 1px solid #ccc;
}
.volunteer_post .entry-content h3,
.volunteer_post .entry-content h4 {
	border-bottom: 1px solid #ddd;
}
.volunteer_post .entry-content h1 {
	margin: 2em 0 1em;
	font-size: 150%;
}
.volunteer_post .entry-content h2 {
	margin: 2em 0 1em;
	font-size: 137%;
}
.volunteer_post .entry-content h3 {
	margin: 1.5em 0 1em;
	font-size: 125%;
}
.volunteer_post .entry-content h4 {
	margin: 1.5em 0 1em;
	font-size: 112%;
}
.volunteer_post .entry-content h5 {
	margin: 1em 0 .5em;
	font-size: 100%;
}
.volunteer_post .entry-content h6 {
	margin: 1em 0 .5em;
	font-size: 85%;
}
.volunteer_post .entry-content blockquote,
.volunteer_post .entry-content table,
.volunteer_post .entry-content dl,
.volunteer_post .entry-content ul,
.volunteer_post .entry-content ol,
.volunteer_post .entry-content address,
.volunteer_post .entry-content pre {
	margin-bottom: 1.5em;
}
.volunteer_post .entry-content blockquote,
.volunteer_post .entry-content q,
.volunteer_post .entry-content var {
	color: #777;
	font-style: italic;
}
.volunteer_post .entry-content blockquote {
	padding: 1em 1.5em;
	border-left: 2px solid #ccc;
}
.volunteer_post .entry-content blockquote p {
	font-style: italic;
}
.volunteer_post .entry-content cite {
	color: #777;
	font-size: 85%;
	font-style: italic;
}
.volunteer_post .entry-content table {
	width: 100%;
	max-width: 100%;
	margin-bottom: 1.5em;
}
.volunteer_post .entry-content th,
.volunteer_post .entry-content td {
	line-height: 1.5;
	vertical-align: middle;
	border: 1px solid #ccc;
}
.volunteer_post .entry-content th {
	padding: .7em;
	font-weight: bold;
	text-align: center;
	background: #f2f2f2;
}
.volunteer_post .entry-content td {
	padding: 1em;
	font-size: 85%;
}
.volunteer_post .entry-content caption {
	margin-bottom: 1em;
	font-weight: bold;
}
.volunteer_post .entry-content dt {
	margin-bottom: .5em;
	font-weight: bold;
}
.volunteer_post .entry-content dd {
	margin-bottom: 1em;
	padding-left: 1em;
}
.volunteer_post .entry-content li {
	margin-bottom: .5em;
	list-style-position: inside;
}
.volunteer_post .entry-content ul li {
	list-style-type: disc;
}
.volunteer_post .entry-content ol li {
	list-style-type: decimal;
}
.volunteer_post .entry-content ul li ul,
.volunteer_post .entry-content ol li ol {
	margin-top: .5em;
	margin-bottom: 0;
	padding-left: 1.5em;
}
.volunteer_post .entry-content code,
.volunteer_post .entry-content kbd,
.volunteer_post .entry-content pre,
.volunteer_post .entry-content samp,
.volunteer_post .entry-content var,
.volunteer_post .entry-content output {
	font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Segoe UI', YuGothic, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Verdana, Meiryo, sans-serif;
}
.volunteer_post .entry-content code,
.volunteer_post .entry-content samp,
.volunteer_post .entry-content kbd {
	padding: .2em .5em .3em;
	font-size: 85%;
	line-height: 1;
	border-radius: 2px;
	display: inline-block;
}
.volunteer_post .entry-content code {
	background: #f2f2f2;
	border: 1px solid #ccc;
}
.volunteer_post .entry-content kbd {
	color: #eee;
	background: #222;
	white-space: nowrap;
}
.volunteer_post .entry-content pre {
	padding: 1em;
	line-height: 1.5;
	background: #f2f2f2;
	overflow: auto;
}
.volunteer_post .entry-content sub,
.volunteer_post .entry-content sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
}
.volunteer_post .entry-content sub {
	bottom: -.25em;
}
.volunteer_post .entry-content sup {
	top: -.5em;
}
.volunteer_post .entry-content img {
	width: auto;
}
.volunteer_post .entry-content img.alignleft {
	margin: 0 1em 1em 0;
	float: left;
}
.volunteer_post .entry-content img.alignright {
	margin: 0 0 1em 1em;
	float: right;
}
.volunteer_post .entry-content img.aligncenter {
	margin: 0 auto;
	display: block;
}
.volunteer_post .entry-content .blog-card {
	margin: 2em 0;
	padding: 1em;
	max-width: 500px;
	border: 1px solid #ccc;
	overflow: hidden;
}
.volunteer_post .entry-content .blog-card-thumbnail {
	margin-bottom: .5em;
	width: 100px;
	height: 100px;
	overflow: hidden;
    position: relative;
	float: left;
}
.volunteer_post .entry-content .blog-card-thumbnail a:before {
	content: '';
    padding-top: 100%;
    display: block;
}
.volunteer_post .entry-content .blog-card img.blog-card-thumb-image {
	margin: auto;
    width: 100%;
    height: 100%;
    background-position-x: center!important;
    background-position-y: center!important;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: 'object-fit: cover; object-position: 0 100%;';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}
.volunteer_post .entry-content .blog-card-content {
	padding-left: 110px;
}
.volunteer_post .entry-content .blog-card-title {
	margin-bottom: .5em;
	font-weight: bold;
}
.volunteer_post .entry-content .blog-card-title a {
	color: #222;
	text-decoration: none;
}
.volunteer_post .entry-content .blog-card-excerpt {
	font-size: 1.1rem;
	line-height: 1.5;
}
.volunteer_post .entry-content .blog-card-footer {
	font-size: 1rem;
	overflow: hidden;
	clear: both;
}
.volunteer_post .entry-content .blog-card-site {
	margin-right: 1em;
	color: #ccc;
	float: left;
}
.volunteer_post .entry-content .blog-card-hatebu {
	margin-right: 1em;
	float: left;
}

.volunteer_post .entry-nav {
	margin-top: 50px;
}
.volunteer_post .entry-nav p:nth-of-type(2) {
	border-top: 1px solid #bbc7d1;
}
.volunteer_post .entry-nav p a {
	padding: 1.5em 0;
	white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
	display: block;
	position: relative;
}
.volunteer_post .entry-nav .next {
	text-align: right;
}
.volunteer_post .entry-nav .prev a {
	padding-left: 1.5em;
}
.volunteer_post .entry-nav .next a {
	padding-right: 1.5em;
}
.volunteer_post .entry-nav .prev a:before,
.volunteer_post .entry-nav .next a:after {
	content: '';
	margin-top: -4px;
	width: 8px;
    height: 8px;
	transform: rotate(45deg);
	display: block;
	position: absolute;
	top: 50%;
}
.volunteer_post .entry-nav .prev a:before {
    border-bottom: 1px solid #666;
    border-left: 1px solid #666;
	left: 2px;
}
.volunteer_post .entry-nav .next a:after {
    border-top: 1px solid #666;
    border-right: 1px solid #666;
	right: 2px;
}

.volunteer_post .back {
	margin-top: 50px;
}
.volunteer_post .back a {
	padding: 1.2em;
	font-size: 1.2rem;
	background: #e9e9e9;
	display: inline-block;
}
.volunteer_post .back a:hover {
	color: #1b1b1b;
	background: #ddd;
}
.volunteer_post .back a:before,
.contact_form button[type="button"]:before {
	content: '';
	margin: -4px .5em 0 0;
	width: 8px;
    height: 8px;
	border-bottom: 1px solid #666;
    border-left: 1px solid #666;
	transform: rotate(45deg);
	display: inline-block;
}

/* ==========================================================================================
	--MEETING
========================================================================================== */
.meeting_list li {
	margin-bottom: 15px;
    text-align: center;
}
.meeting_list li a {
	border: 1px solid #bbc7d1;
}
.meeting_list li a:hover {
	border-color: #005daa;
}

/* ==========================================================================================
	--GALLERY
========================================================================================== */
.gallery_list {
	margin: 0 -1px;
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.gallery_list p {
	margin-bottom: 2px;
	padding: 0 1px;
	width: 33.3333%;
	width: calc(100% / 3);
}

/* ==========================================================================================
	--JOIN
========================================================================================== */
.join_fees p {
	text-align: center;
	line-height: 2;
}
.join_fees div div,
.contact_form .tel {
	margin: 30px auto 0;
	padding: 1.5em;
	max-width: 800px;
	border: 1px solid #e3e6e8;
}
body.join .join_fees div div h3,
.contact_form .tel h3 {
	margin-bottom: .5em;
	color: #1b1b1b;
	font-size: 1.6rem;
	text-align: center;
}
body.join .join_fees div div .btn,
.contact_form .tel .btn {
	margin: 1em auto 0;
	max-width: 320px;
	font-size: 1.4rem;
}
body.join .join_fees div div .btn a,
.contact_form .tel .btn a {
	padding: 1em;
    color: #fff;
    background: #005daa;
    display: block;
	border-radius: 2px;
}
body.join .join_fees div div .btn a:hover,
.contact_form .tel .btn a:hover {
	background: #1677c7;
}
body.join .join_fees div div .btn img,
.contact_form .tel .btn img {
	margin-right: .7em;
	width: auto;
	height: 1em;
	vertical-align: middle;
}
body.join .join_fees div div .btn a:hover img,
.contact_form .tel .btn a:hover img {
	opacity: 1;
}

/* ==========================================================================================
	--CONTACT
========================================================================================== */
.contact_form p:first-child,
.contact_form .tel p {
	text-align: center;
	line-height: 2;
}
.contact_form form {
	margin-top: 50px;
}
.contact_form dl {
	margin: 0 auto;
	max-width: 800px;
}
.contact_form dl:last-of-type {
	margin-bottom: 0;
	border-bottom: 1px solid #e6e6e6;
}
.contact_form dt,
.contact_form dd {
	padding: 1em;
	border: 1px solid #e6e6e6;
	border-bottom: none;
}
.contact_form dt {
	font-weight: bold;
	background: #f3f3f3;

}
.contact_form dt img {
	margin-left: .7em;
	width: 40px;
	height: 20px;
	vertical-align: text-bottom;
}
.contact_form dd {
	line-height: 1.5;
}
.contact_form button[type="button"] {
	margin-top: 50px;
    font-size: 1.2rem;
    background: #e9e9e9;
}
.contact_completion p {
	margin: 0 auto;
	max-width: 800px;
	line-height: 2;
}
.contact_completion .notice {
    margin: 30px auto 0;
    padding: 1em;
    max-width: 800px;
	font-size: 1.2rem;
	line-height: 1.7;
    border: 1px solid #e3e6e8;
}
.contact_completion .notice li {
    margin-bottom: 1em;
    padding-left: 1em;
    text-indent: -1em;
}
.contact_completion .notice li:last-of-type {
	margin-bottom: 0;
}
.contact_completion .notice em {
    color: #005daa;
    font-weight: bold;
}

/* ==========================================================================================
	--ERROR
========================================================================================== */
body.error main > section {
	margin-top: 50px;
}
body.error main > section p {
	text-align: center;
    line-height: 2;
}

/* ==========================================================================================
	--RAC FORM
========================================================================================== */
body.rac_form h1 {
	padding: 30px 0;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
}
body.rac_form .contact_form p:first-child {
	margin: 0 auto;
	max-width: 800px;
	text-align: left;
}

/* ==========================================================================================
	--RAC
========================================================================================== */
body.rac .about_nav li:nth-of-type(3) {
  width: 100%;
  border-right: none;
}
body.rac .about_nav li br {
  display: none;
}
body.rac #objective li {
  padding-left: 2em;
  text-indent: -2em;
  line-height: 1.5;
}
body.rac #objective li:not(:last-of-type) {
  margin-bottom: .5em;
}
body.rac #objective li::before {
  content: '1.';
  margin-right: .2em;
  color: #005daa;
  font-size: 2em;
  font-weight: bold;
}
body.rac #objective li:nth-of-type(2)::before {
  content: '2.';
}
body.rac #objective li:nth-of-type(3)::before {
  content: '3.';
}
body.rac #objective li:nth-of-type(4)::before {
  content: '4.';
}
body.rac #objective li:nth-of-type(5)::before {
  content: '5.';
}
body.rac #objective .image {
  margin: 30px auto -13px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
body.rac #objective .image p {
  margin-right: 4%;
  width: 48%;
}
body.rac #objective .image p:nth-of-type(even) {
  margin-right: 0;
}


@media screen and (max-width: 320px) {
	/* ==========================================================================================
		--TOP
	========================================================================================== */
	.index_policy .more a,
	.index_news .more a {
		padding: 0 20px;
	}

	/* ==========================================================================================
		--ABOUT
	========================================================================================== */
	.what_nav li,
	.about_nav li {
		font-size: 1.1rem;
	}
	body.about #about .btn {
		font-size: 1.4rem;
	}

	/* ==========================================================================================
		--JOIN
	========================================================================================== */
	.join_fees div div,
	body.join .join_fees div div h3,
	body.join .join_about .btn {
	    font-size: 1.4rem;
	}
}


/* tablet */
@media screen and (min-width: 560px) {
	/* ==========================================================================================
		--TOP
	========================================================================================== */
	body.index main > section {
		margin-bottom: 100px;
	}
	body.index h1 {
		margin-bottom: 60px;
		padding-left: 7vw;
		font-size: 1.6rem;
		position: relative;
	}
	body.index h1 span {
		font-size: 6.5rem;
	}
	body.index h1:after {
		content: '';
		margin: 0 1em .5em 0;
		width: 5.5vw;
		width: calc(7vw - 1em);
		height: 1px;
		background: #bbc7d1;
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
	}
	body.index .more {
		font-size: 1.6rem;
	}

	body.index .index_main {
    padding: 7vw;
		min-height: 66.66vw;
	}
	.index_main .image {
		width: 25%;
	}
	.index_main .image.d2024 {
		width: 60%;
	}
	.index_main .image.d20242 {
		background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1) 24% 76%, rgba(255, 255, 255, 0));
	}
	.index_main .image.d20242 img {
		width: 52%;
	}
	body.index .index_main h1 {
		margin-top: 20px;
		width: 60%;
	}
	body.index .index_main h1:after,
	body.index .index_gallery h1:after,
	body.index .index_support h1:after {
		display: none;
	}
	.index_main h2 {
		margin-top: 70px;
		font-size: 1.6rem;
	}
  .index_main .bnr {
    margin-top: 70px;
    width: 70%;
  }

	.index_policy {
		padding-top: 100px;
	}
	.index_policy:before {
		height: 92%;
		height: calc(100% - 70px);
	}
	.index_policy .more {
		padding-top: 70px;
		height: 140px;
		line-height: 70px;
	}
	.index_policy .more a:after {
		margin-top: -15px;
		height: 40px;
	}

	.index_news ul {
		margin-left: 7vw;
		padding: 0 30px 0 0;
	}
	.index_news li,
	.news_list li {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.index_news li .date,
	.news_list li .date {
		width: 8em;
		font-size: 1.4rem;
		line-height: 1.5;
	}
	.index_news li .txt,
	.news_list li .txt {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}
	.index_news .more {
		margin-top: 60px;
	    height: 70px;
    	line-height: 70px;
	}
	.index_news .more a {
		padding: 0 60px;
	}
	.index_news .more a:after {
		width: 70px;
		left: -50px;
	}

	body.index .index_menu {
		padding: 100px 0;
	}
	.index_menu ul {
		padding: 0 30px;
	}
	.index_menu li {
		margin-bottom: 20px;
	}
	.index_menu li a p {
		font-size: 1.2rem;
	}
	.index_menu li span {
		margin-bottom: 20px;
		font-size: 3.3rem;
	}
	.index_menu li .ico {
		width: 50px;
		height: 50px;
	}
	.index_menu li .ico:before {
	    border-width: 50px 50px 0 0;
	}

	.index_gallery {
		padding: 100px 0;
	}
	body.index .index_gallery h1 {
		padding-left: 0;
		font-size: 4.5rem;
	}
	.index_gallery div {
		margin: 0 -2px;
	}
	.index_gallery p {
	    margin-bottom: 8px;
    	padding: 0 4px;
	}
	body.index .index_gallery .more {
		font-size: 2rem;
	}
	.index_gallery .more a:after {
		height: 70px;
		bottom: -35px;
	}

	body.index .index_support h1 {
		padding-left: 0;
		font-size: 3.5rem;
		text-align: center;
	}
	.index_support p {
		margin: 0 30px 60px 30px;
	}
	.index_support p img {
		height: 50px;
	}

	/* ==========================================================================================
		--WHAT
	========================================================================================== */
	body.what #breadcrumb,
	body.about #breadcrumb {
		margin-bottom: 0;
	}
	.what_nav,
	.about_nav {
		margin: 0 auto 80px;
		padding: 15px 0;
	}
 	.what_nav ul,
	.about_nav ul {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
	}
  .what_nav li,
	.about_nav li {
		width: 25%;
		font-size: 1.3rem;
		font-weight: bold;
	}
	.what_nav li a,
	.about_nav li a {
		padding: 2em 1em;
		border-color: #eff5fa;
		border-bottom: none;
	}
	.what_nav li:nth-of-type(even) a,
	.about_nav li:nth-of-type(even) a {
		border-right: 1px solid #eff5fa;
	}
	.what_nav li:last-of-type a,
	.about_nav li:last-of-type a {
		border-right: none;
	}
	.what_nav li a:after,
	.about_nav li a:after {
		margin-top: 1.5em;
	}

	body.what #object li {
		margin-bottom: 40px;
	}
	body.what #object dt {
		font-size: 3.6rem;
	}
	body.what #object dd {
	    padding-left: 4em;
	    font-size: 1.8rem;
	}

	body.what #test .txt {
	    font-size: 2.2rem;
	}
	body.what #test ol {
		margin: 30px auto 0;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	body.what #test li {
		padding: 40px;
		width: 50%;
	}
	body.what #theme div div {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}
	body.what #theme .image {
		width: 37%;
	}
	body.what #theme div div p {
		margin-left: 6.5%;
		width: 56.5%;
	}

	/* ==========================================================================================
		--ABOUT
	========================================================================================== */
	body.about #slogan div {
		margin-top: -50px;
		padding: 100px 0;
	}
	body.about #slogan p {
		font-size: 4rem;
	}

	body.about #about dl:last-of-type,
  body.rac main section dl:last-of-type {
		margin-bottom: 40px;
	}
	body.about #about dl,
	body.about #sister li dl,
	body.join main section dl,
  body.rac main section dl {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	body.about #about dt,
	body.about #sister li dt,
	body.join main section dt,
  body.rac main section dt {
		width: 20%;
		min-width: 6em;
	}
	body.about #about dd,
	body.about #sister li dd,
	body.join main section dd,
  body.rac main section dd {
		margin-top: 0;
		font-size: 1.6rem;
	}
	body.about #about .btn,
	body.join .join_about .btn,
  body.meeting .meeting_list .btn {
		font-size: 2rem;
	}
	body.about #about .btn a:after,
	body.join .join_about .btn a:after,
  body.meeting .meeting_list .btn a:after {
		width: 60px;
		height: 1px;
		bottom: 50%;
		left: auto;
		right: -30px;
		transform-origin: left;
	}
	body.about #about .btn a:hover:after,
  body.join .join_about .btn a:hover:after,
  body.meeting .meeting_list .btn a:hover:after {
		transform: scaleY(1);
		transform: scaleX(1.5);
	}
	body.about #about .greeting {
	    margin: 250px -30px 0;
	}
	body.about #about .greeting:before {
		font-size: 8rem;
	    -webkit-writing-mode: rl;
		-ms-writing-mode: rl;
		writing-mode: rl;
		top: -.15em;
		left: 0;
	}
	body.about #about .greeting figcaption,
	body.greeting main section figcaption {
		padding: .7em 3em;
		font-size: 1.8rem;
	}
	body.about #about .greeting h2 {
		margin: 0 auto;
		font-size: 6rem;
	}
	body.about #about .greeting h2:after {
		display: none;
	}
	body.about #about .greeting .more {
		margin: 40px auto 20px;
	}
	body.about #about .greeting .more a:after {
		height: 30px;
		bottom: -20px;
	}
	body.about #about .greeting .chaiman {
		padding: 140px 0 150px;
	}
	body.about #about .greeting .chaiman figure {
		width: 40%;
		right: 4%;
	}
	body.about #about .greeting .chaiman figcaption {
		left: -2em;
	}
	body.about #about .greeting .chaiman div {
		margin-right: 44%;
	}
	body.about #about .greeting .organizer {
		padding: 100px 0;
	}
	body.about #about .greeting .organizer figure {
		width: 36%;
		left: 4%;
	}
	body.about #about .greeting .organizer figcaption {
		right: -2em;
	}
	body.about #about .greeting .organizer div {
		margin-left: 40%;
	}

	body.about #sister ul {
		margin-bottom: -60px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	body.about #sister li {
		margin: 0 4% 60px 0;
		width: 48%;
	}
	body.about #sister li:nth-of-type(even) {
		margin-right: 0;
	}
	body.about #sister h3:nth-of-type(n+2) {
		margin-top: 60px;
	}

	body.about #association > div {
		margin: 0 -30px;
	}
	body.about #association dt p {
		font-size: 4.2rem;
	}
	body.about #association dt p span {
		margin-top: 2em;
		font-size: 1.4rem;
	}
	body.about #association dt > span {
		width: 36px;
		height: 36px;
		right: 30px;
	}
	body.about #association dd ul {
		margin: 0 -4px;
	}
	body.about #association dd li {
		margin-bottom: 8px;
		padding: 0 4px;
	}

	body.about .about_info,
	body.volunteer .volunteer_archive,
	body.meeting .meeting_archive {
		padding: 60px 30px;
	}
	body.about .about_info h2 {
		margin-bottom: 50px;
		font-size: 3rem;
	}
	body.about .about_info h2:after {
		display: none;
	}
	body.about .about_info ul,
	.meeting_list ul {
		margin-bottom: -10px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	body.about .about_info li,
	.meeting_list li {
		margin: 0 2% 10px 0;
		width: 32%;
	}
	body.about .about_info li:nth-of-type(3n),
	.meeting_list li:nth-of-type(3n) {
		margin-right: 0;
	}
  .meeting_list .noflex li {
    margin-right: 0;
    width: 66%;
  }

  /* ==========================================================================================
		--HISTORY
	========================================================================================== */
  body.about #history li {
    font-size: 1.6rem;
  }

  /* ==========================================================================================
	  --PAST
  ========================================================================================== */
  body.about #past th,
  body.about #past td {
    padding: 1em;
    font-size: 1.6rem;
  }

	/* ==========================================================================================
		--GREETING
	========================================================================================== */
	body.greeting main section figure {
		margin-bottom: 50px;
		width: 40%;
	}
	body.greeting main section figcaption {
		left: -3em;
	}

	/* ==========================================================================================
		--MEMBER
	========================================================================================== */
	.member_list table {
		white-space: normal;
	}
	.member_list table td {
		line-height: 1.5;
	}

	/* ==========================================================================================
		--VOLUNTEER
	========================================================================================== */
	body.volunteer .volunteer_about {
		margin-bottom: 220px;
	}
	body.volunteer .volunteer_about div p {
		font-size: 4rem;
	}
	body.volunteer .volunteer_about div p span {
		margin-top: 30px;
		font-size: 1.4rem;
	}
	body.volunteer .volunteer_about .more {
		margin: 0 0 20px -50px;
		width: 100px;
		height: 100px;
		font-size: 1.6rem;
		bottom: -70px;
	}
	body.volunteer .volunteer_about .more a:after {
		height: 40px;
		bottom: -20px;
	}
	.report_list {
		margin: 0 0 -25px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.report_list .post {
		margin: 0 4% 25px 0;
		width: 48%;
	    border: 1px solid #dce1e5;
	}
	.report_list .post:nth-of-type(even) {
		margin-right: 0;
	}

	body.volunteer .volunteer_archive h2,
	body.meeting .meeting_archive h2 {
		margin-bottom: 50px;
    	font-size: 1.4rem;
	}
	body.volunteer .volunteer_archive h2 span,
	body.meeting .meeting_archive h2 span {
		font-size: 3rem;
	}
	.volunteer_archive ul,
	.meeting_archive ul {
		margin-bottom: -15px;
		padding: 0;
	}
	.volunteer_archive li,
	.meeting_archive li {
		margin: 0 2% 15px 0;
		width: 23.5%;
	}
	.volunteer_archive li:nth-of-type(even),
	.meeting_archive li:nth-of-type(even) {
		margin-right: 2%;
	}
	.volunteer_archive li:nth-of-type(4n),
	.meeting_archive li:nth-of-type(4n) {
		margin-right: 0;
	}

	/* ==========================================================================================
		--VOLUNTEER ABOUT
	========================================================================================== */
	body.volunteer.about section > div {
		margin-bottom: 70px;
	}
	.volunteer_service .image,
	.volunteer_youth .image {
		margin-bottom: -15px;
	}
	.volunteer_service .image li,
	.volunteer_youth .image li {
		margin: 0 2% 15px 0;
		width: 32%;
	}
	.volunteer_service .image li:nth-of-type(even),
	.volunteer_youth .image li:nth-of-type(even) {
		margin-right: 2%;
	}
	.volunteer_service .image li:nth-of-type(3n),
	.volunteer_youth .image li:nth-of-type(3n) {
		margin-right: 0;
	}

	/* ==========================================================================================
		--VOLUNTEER SINGLE
	========================================================================================== */
	.volunteer_post .post_time {
		font-size: 1.4rem;
	}
	.volunteer_post .post_cat {
		font-size: 1.4rem;
	}
	.volunteer_post .entry-header h1 {
		font-size: 3rem;
	}
	.volunteer_post .entry-content {
		margin-top: 60px;
		font-size: 1.6rem;
	}
	.volunteer_post .entry-nav {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.volunteer_post .entry-nav p {
		width: 50%;
		font-size: 1.6rem;
	}
	.volunteer_post .entry-nav p:nth-of-type(2) {
		border-top: none;
		border-left: 1px solid #bbc7d1;
	}
	.volunteer_post .entry-nav .prev {
		margin-right: auto;
	}
	.volunteer_post .entry-nav .next {
		margin-left: auto;
	}
	.volunteer_post .entry-nav .prev a {
		padding-right: 1em;
	}
	.volunteer_post .entry-nav .next a {
		padding-left: 1em;
	}
	.volunteer_post .entry-nav .prev a:before,
	.volunteer_post .entry-nav .next a:after {
		margin-top: -6px;
		width: 12px;
		height: 12px;
	}

	/* ==========================================================================================
		--GALLERY
	========================================================================================== */
	.gallery_list {
		margin: 0 -2px;
	}
	.gallery_list p {
		margin-bottom: 8px;
		padding: 0 4px;
		width: 25%;
	}

	/* ==========================================================================================
		--JOIN
	========================================================================================== */
	.join_fees p {
		font-size: 1.8rem;
	}
	.join_fees div div,
	.contact_form .tel {
	    padding: 2em;
	}
	body.join .join_fees div div h3,
	.contact_form .tel h3 {
	    font-size: 2rem;
	}

	/* ==========================================================================================
		--CONTACT
	========================================================================================== */
	.contact_form .tel p {
		font-size: 1.6rem;
	}
	.contact_form dl {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.contact_form dt {
		width: 37%;
		border-right: none;
	}
	.contact_form dd {
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}
	.contact_completion p {
		text-align: center;
	}
	.contact_completion .notice {
		padding: 1.5em;
	}

	/* ==========================================================================================
		--RAC FORM
	========================================================================================== */
	body.rac_form h1 {
		padding: 60px 0;
		font-size: 2.8rem;
	}

  /* ==========================================================================================
    --RAC
  ========================================================================================== */
  body.rac .about_nav li,
  body.rac .about_nav li:nth-of-type(3) {
    width: 33.3333%;
    width: calc(100% / 3);
  }
  body.rac .about_nav li br {
    display: block;
  }
  body.rac #objective li {
    font-size: 1.6rem;
  }
  body.rac #objective li::before {
    font-size: 2.4rem;
  }
}


@media screen and (min-width: 751px) {
	/* ==========================================================================================
		--TOP
	========================================================================================== */
	body.index .index_main {
	    background: url(../img/index/main.jpg) no-repeat center center;
		background-size: cover;
	}

	/* ==========================================================================================
		--WHAT
	========================================================================================== */
	body.what .ttl_wrap {
		background: url(../img/what/ttl.jpg) no-repeat center center;
		background-size: cover;
	}

	/* ==========================================================================================
		--ABOUT
	========================================================================================== */
	body.about .ttl_wrap,
	body.news .ttl_wrap,
	body.meeting .ttl_wrap,
	body.gallery .ttl_wrap,
	body.join .ttl_wrap,
	body.contact .ttl_wrap,
	body.error .ttl_wrap,
  body.rac .ttl_wrap {
		background: url(../img/about/ttl.jpg) no-repeat center center;
		background-size: cover;
	}
	body.about #association .drum dt {
		background: url(../img/about/association_drum.jpg) no-repeat center center;
		background-size: cover;
	}
	body.about #association .photo dt {
		background: url(../img/about/association_photo.jpg) no-repeat center center;
		background-size: cover;
	}
	body.about #association .baseball dt {
		background: url(../img/about/association_baseball.jpg) no-repeat center center;
		background-size: cover;
	}

	/* ==========================================================================================
		--GREETING
	========================================================================================== */
	body.greeting .ttl_wrap {
		background: url(../img/greeting/ttl.jpg) no-repeat center center;
		background-size: cover;
	}

	/* ==========================================================================================
		--MEMBER
	========================================================================================== */
	body.member .ttl_wrap {
		background: url(../img/member/ttl.jpg) no-repeat center center;
		background-size: cover;
	}

	/* ==========================================================================================
		--VOLUNTEER
	========================================================================================== */
	body.volunteer .ttl_wrap {
		background: url(../img/volunteer/ttl.jpg) no-repeat center center;
		background-size: cover;
	}
	body.volunteer .volunteer_about div a {
		background: url(../img/volunteer/about.jpg) no-repeat center center;
    	background-size: cover;
	}

	/* ==========================================================================================
		--VOLUNTEER ABOUT
	========================================================================================== */
	body.volunteer.about .ttl_wrap {
		background: url(../img/volunteer/about/ttl.jpg) no-repeat center center;
		background-size: cover;
	}
}

/* pc */
@media screen and (min-width:1025px) {
	/* ==========================================================================================
		--TOP
	========================================================================================== */
	body.index h1 {
		margin-bottom: 100px;
		padding-left: 20vw;
		font-size: 2rem;
	}
	body.index h1 span {
		font-size: 8.8rem;
	}
	body.index h1:after {
		width: 19vw;
		width: calc(20vw - 1em);
	}
	body.index .more {
		font-size: 2rem;
	}

	body.index header .logo {
		width: 180px;
	}
	body.index header .txt,
	body.index header nav {
		display: none;
	}

	body.index .index_main {
    padding-left: 8em;
    padding-right: 8em;
		height: 40vw;
    min-height: auto;
	}
	.index_main div {
		width: 100%;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}
	.index_main .image {
		margin: 0;
		width: 15%;
    max-width: 235px;
	}
	.index_main .image.d2024 {
		width: 35%;
		max-width: none;
	}
	.index_main .image.d20242 {
		margin: 0 -8em;
		max-width: none;
		background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1) 35% 65%, rgba(255, 255, 255, 0));
	}
	.index_main .image.d20242 img {
		width: 30%;
	}
	body.index .index_main h1 {
		margin: 0 0 0 2.5%;
		width: 37%;
    max-width: 615px;
	}
	.index_main h2 {
		margin-top: 35px;
		font-size: 3.2rem;
	}
  .index_main .bnr {
    margin-top: 35px;
    width: 50%;
  }

	.index_nav {
		margin-top: -58px;
		max-width: 100%;
		background: #005daa;
		border-radius: 2px 0 0 2px;
		display: block;
		position: absolute;
		top: 40vw;
		right: 0;
		z-index: 1;
	}
	.index_nav ul {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.index_nav li {
    font-size: 1.6rem;
		font-weight: bold;
		text-align: center;
		line-height: 1.5;
	}
	.index_nav li a {
		padding: 1em 2em;
		height: 116px;
		color: #fff;
		background: #005daa;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-line-pack: center;
    align-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
		-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
	}
	.index_nav li a:hover {
		background: #1677c7;
	}
	.index_nav li span {
		margin-bottom: .5em;
		height: 34px;
		line-height: 34px;
	}
	.index_nav li img,
	.index_nav li svg {
		width: 34px;
		vertical-align: middle;
	}
	.index_nav li a:hover img {
		opacity: 1;
	}
	.index_nav .contact a:hover {
		background: #d91b5c;
	}
	.index_nav .join a:hover {
		background: #f7a81b;
	}
  .index_nav .facebook a:hover {
		background: #1778f2;
	}
	.index_nav .join svg path {
		transition: .5s;
	}
	.index_nav .join a:hover svg path {
		fill: #fff;
	}

	.index_policy {
		padding-top: 200px;
	}
	.index_policy:before {
	    height: 75%;
		height: calc(100% - 250px);
	}
	.index_policy:after {
		width: 32%;
	}
	body.index .index_policy h1 {
		padding-left: 8vw;
	}
	body.index .index_policy h1:after {
		width: 7vw;
    	width: calc(8vw - 1em);
	}
	.index_policy .image {
		margin: -150px 8% 0 0;
		text-align: right;
	}
	.index_policy .image img {
		width: 62.5%;
	}
	.index_policy .more {
		margin: 0 0 50px 68%;
		padding-top: 0;
		width: 32%;
		height: 100px;
		line-height: 100px;
	}
	.index_policy .more a {
		padding: 0 60px;
	}
	.index_policy .more a:after {
		margin-top: -25px;
		height: 50px;
	}

	.index_news ul {
		margin-left: 20vw;
		padding: 0;
		width: 60vw;
		min-width: 1080px;
	}
	.index_news li,
	.news_list li {
		margin-bottom: 60px;
		font-size: 1.8rem;
	}
	.index_news li .date,
	.news_list li .date {
		width: 8em;
		font-size: 1.8rem;
	}
	.index_news .more {
	    margin: 80px 0 0 68%;
	    width: 32%;
	    height: 90px;
    	line-height: 90px;
	}
	.index_news .more a:after {
		width: 100px;
		left: -70px;
	}

	body.index .index_menu {
		padding: 150px 0;
	}
	.index_menu li {
		width: 32%;
		margin-right: 2%;
	}
	.index_menu li:nth-of-type(2n) {
		margin-right: 2%;
	}
	.index_menu li:nth-of-type(3n) {
		margin-right: 0;
	}
	.index_menu li a p {
		font-size: 1.6rem;
	}
	.index_menu li span {
		font-size: 4.4rem;
	}
	.index_menu li .ico {
		width: 66px;
		height: 66px;
	}
	.index_menu li .ico:before {
	    border-width: 66px 66px 0 0;
	}

	.index_gallery {
		padding: 150px 0;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}
	body.index .index_gallery h1 {
		margin: 0 4% 0 8%;
		font-size: 6.6rem;
	}
	.index_gallery div {
		margin: 0 -10px 0 0;
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}
	.index_gallery p {
		margin-bottom: 0;
		padding: 0 10px 0 0;
		width: 16.6666%;
    	width: calc(100% / 6);
	}
	body.index .index_gallery .more {
		font-size: 1.6rem;
	}

	body.index .index_support h1 {
		font-size: 5rem;
	}
	.index_support p {
		margin: 0 40px 80px 40px;
	}
	.index_support p img {
		height: 63px;
	}

	/* ==========================================================================================
		--WHAT
	========================================================================================== */
	.what_nav,
	.about_nav {
		margin-bottom: 120px;
		padding: 30px 10%;
	}
	.what_nav li,
	.about_nav li {
		font-size: 1.6rem;
	}
	.what_nav li a:after,
	.about_nav li a:after {
	    width: 8px;
    	height: 8px;
	}

	body.what #what > div,
	body.member main section > div,
	.meeting_list > div,
	body.gallery main section > div,
	.join_fees > div {
		margin-bottom: 100px;
	}
	body.what #what p,
	body.what #theme p,
	body.greeting main section p,
  body.rac main section p {
		font-size: 1.6rem;
	}

	body.what #object li {
		margin-bottom: 60px;
	}
	body.what #object dl {
		position: relative;
	}
	body.what #object dt {
		font-size: 5.4rem;
	}
	body.what #object dd {
		padding-left: 7em;
		font-size: 2.4rem;
	}
	body.what #object dl:after {
		content: '';
		width: 1px;
		height: 85%;
		height: calc(100% - 30px);
		background: #f7a81b;
		display: block;
		position: absolute;
		top: 5em;
		left: 6em;
	}

	body.what #test .txt {
		font-size: 2.8rem;
	}
	body.what #test ol {
		margin-top: 40px;
	}
	body.what #test dt {
		font-size: 5.8rem;
	}
	body.what #test dd {
		font-size: 2.8rem;
	}
	body.what #test dd span {
		font-size: 1.4rem;
	}

	body.what #theme h3 {
		margin-top: 60px;
		text-align: left;
	}
	body.what #theme div div p {
		font-size: 2rem;
	}

	/* ==========================================================================================
		--ABOUT
	========================================================================================== */
	body.about #slogan p {
		font-size: 4.8rem;
	}

	body.about #about dl,
	body.about #sister li dl,
	body.join main section dl,
  body.rac main section dl {
		 padding: 25px 0;
	}
	body.about #about dl:last-of-type,
  body.rac main section dl:last-of-type {
		margin-bottom: 60px;
	}
	body.about #about p:not(.btn) {
		font-size: 1.6rem;
	}
	body.about #about .btn,
	body.join .join_about .btn,
  body.meeting .meeting_list .btn {
		margin-top: 100px;
	}
	body.about #about .btn a:after,
	body.join .join_about .btn a:after,
  body.meeting .meeting_list .btn a:after {
		width: 80px;
		right: -40px;
	}
	body.about #about .greeting {
	    margin: 300px -10vw 0;
	}
	body.about #about .greeting:before {
		font-size: 11.6rem;
		left: 10vw;
	}
	body.about #about .greeting h2 {
		font-size: 7rem;
	}
	body.about #about .greeting .more {
		margin: 60px auto 30px;
		font-size: 1.6rem;
	}
	body.about #about .greeting .more a:after {
		height: 40px;
		bottom: -30px;
	}
	body.about #about .greeting .chaiman {
		padding-bottom: 200px;
	}
	body.about #about .greeting .chaiman figure {
		width: 25vw;
		right: 15vw;
	}
	body.about #about .greeting .chaiman div {
		margin: 0 40vw 0 10vw;
	}
	body.about #about .greeting .organizer figure {
		width: 22.5vw;
		left: 15vw;
	}
	body.about #about .greeting .organizer div {
		margin: 0 10vw 0 37.5vw;
	}

	body.about #association > div {
		margin: 0;
	}
	body.about #association dl {
		margin-bottom: 20px;
	}
	body.about #association dt > span {
		width: 48px;
		height: 48px;
		right: 60px;
	}
	body.about #association dd p {
		margin: 30px auto 40px;
		padding: 0;
		font-size: 1.6rem;
	}
	body.about #association dd ul {
		margin: 0 -15px;
	}
	body.about #association dd li {
		margin-bottom: 30px;
		padding: 0 15px;
	}

	body.about .about_info,
	body.volunteer .volunteer_archive,
	body.meeting .meeting_archive {
		padding-left: 10%;
		padding-right: 10%;
	}
	body.about .about_info ul,
	.meeting_list ul {
		margin-bottom: -20px;
	}
	body.about .about_info li {
		margin: 0 5% 20px 0;
		width: 30%;
		font-size: 1.8rem;
	}

  /* ==========================================================================================
		--HISTORY
	========================================================================================== */
  body.about #history ol::before {
    display: none;
  }
  body.about #history li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  body.about #history li:not(:last-of-type):not(:first-of-type) {
    margin-bottom: 0;
  }
  body.about #history li .date {
    padding: 3em 2em 0 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -ms-flex-preferred-size: 190px;
    flex-basis: 190px;
  }
  body.about #history li .date span {
    display: block;
  }
  body.about #history li .txt {
    padding: 3em 1em 3em 3em;
    width: 100%;
    border-left: 2px solid #cbd4db;
    position: relative;
  }
  body.about #history li .txt::before {
    content: '';
    margin-left: -9px;
    width: 16px;
    height: 16px;
    background: #005daa;
    border-radius: 50%;
    display: block;
    position: absolute;
    top: 3.5em;
    left: 0;
  }
  body.about #history li .number {
    margin: 0 0 3em auto;
    float: none;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    align-self: flex-end;
  }

	/* ==========================================================================================
		--GREETING
	========================================================================================== */
	body.greeting main section > div {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
	}
	body.greeting main section figure {
		width: 25vw;
	}
	body.greeting main section p {
		padding-left: 50px;
		-webkit-box-flex: 1;
		-ms-flex: 1;
		flex: 1;
	}

	/* ==========================================================================================
		--MEMBER
	========================================================================================== */
	body.member .member_login {
		margin-top: 100px;
	}
	.member_login p {
		margin-bottom: 100px;
		font-size: 1.8rem;
	}
	.member_login dt {
		font-size: 1.6rem;
	}

	.member_list table {
		font-size: 1.6rem;
	}
	.member_list table th:first-of-type,
	.member_list table th:nth-of-type(3) {
		 width: 23%;
	}
	.member_list table td {
		line-height: 1;
	}

	/* ==========================================================================================
		--VOLUNTEER
	========================================================================================== */
	body.volunteer .volunteer_about {
		margin-bottom: 295px;
	}
	body.volunteer .volunteer_about div p {
		font-size: 6rem;
	}
	body.volunteer .volunteer_about div p span {
		margin-top: 45px;
		font-size: 2rem;
	}
	body.volunteer .volunteer_about .more {
		margin: 0 0 25px -70px;
		width: 140px;
		height: 140px;
		font-size: 2rem;
		bottom: -95px;
	}
	body.volunteer .volunteer_about .more a:after {
		height: 50px;
		bottom: -25px;
	}
	.report_list .post {
		margin-right: 2%;
		width: 32%;
	}
	.report_list .post:nth-of-type(even) {
		margin-right: 2%;
	}
	.report_list .post:nth-of-type(3n) {
		margin-right: 0;
	}
	.report_list .post .post_text {
		padding: 30px 20px;
	}

	.volunteer_archive ul,
	.meeting_archive ul {
		margin-bottom: -20px;
	}
	.volunteer_archive li,
	.meeting_archive li {
		margin-bottom: 20px;
		width: 18.4%;
	}
	.volunteer_archive li:nth-of-type(4n),
	.meeting_archive li:nth-of-type(4n) {
		margin-right: 2%;
	}
	.volunteer_archive li:nth-of-type(5n),
	.meeting_archive li:nth-of-type(5n) {
		margin-right: 0;
	}

	/* ==========================================================================================
		--VOLUNTEER ABOUT
	========================================================================================== */
	body.volunteer.about section > div {
		margin-bottom: 100px;
	}
	.volunteer_service > div:first-of-type ul li,
	body.volunteer.about section > div p {
		font-size: 1.6rem;
	}
	.volunteer_service .image,
	.volunteer_youth .image {
		margin: 40px auto -20px;
	}
	.volunteer_service .image li,
	.volunteer_youth .image li {
		margin-bottom: 20px;
	}

	/* ==========================================================================================
		--VOLUNTEER SINGLE
	========================================================================================== */
	body.volunteer .volunteer_post {
		padding: 0;
		max-width: 800px;
	}
	.volunteer_post .post_time {
		font-size: 1.8rem;
	}
	.volunteer_post .post_cat {
		margin-top: 15px;
		font-size: 1.6rem;
	}
	.volunteer_post .entry-header {
		margin-top: 40px;
	}
	.volunteer_post .entry-header h1 {
		font-size: 3.8rem;
	}
	.volunteer_post .entry-content {
		margin-top: 100px;
		font-size: 1.8rem;
	}
	.volunteer_post .entry-nav {
		margin-top: 100px;
	}
	.volunteer_post .entry-nav p {
		font-size: 1.8rem;
	}

	.volunteer_post .back {
		margin-top: 100px;
	}
	.volunteer_post .back a {
		font-size: 1.4rem;
	}

	/* ==========================================================================================
		--MEETING
	========================================================================================== */
	.meeting_list li {
		margin-bottom: 20px;
		font-size: 1.8rem;
	}

	/* ==========================================================================================
		--GALLERY
	========================================================================================== */
	.gallery_list p {
		width: 20%;
	}

	/* ==========================================================================================
		--JOIN
	========================================================================================== */
	.join_fees p {
		font-size: 2rem;
	}
	.join_fees div div,
	.contact_form .tel {
		margin-top: 60px;
	    padding: 2.5em;
	}
	body.join .join_fees div div h3 {
		font-size: 2.4rem;
	}
	body.join .join_fees div div .btn,
	.contact_form .tel .btn {
		display: none;
	}

	/* ==========================================================================================
		--CONTACT
	========================================================================================== */
	.contact_form p:first-child,
	.contact_form dt,
	.contact_form dd,
	.contact_completion p {
		font-size: 1.6rem;
	}
	.contact_form .tel p {
		font-size: 1.8rem;
	}
	.contact_form button[type="button"] {
		margin-top: 100px;
	    font-size: 1.4rem;
	}
	.contact_completion .notice {
		padding: 2em;
		margin-top: 50px;
		font-size: 1.4rem;
	}

	/* ==========================================================================================
		--ERROR
	========================================================================================== */
	body.error main > section {
		margin-top: 100px;
	}
	body.error main > section p {
		font-size: 1.8rem;
	}

	/* ==========================================================================================
		--RAC FORM
	========================================================================================== */
	body.rac_form h1 {
		padding: 80px 0;
		font-size: 3.4rem;
	}

  /* ==========================================================================================
    --RAC
  ========================================================================================== */
  body.rac #objective li {
    font-size: 2rem;
  }
  body.rac #objective li:not(:last-of-type) {
    margin-bottom: 1em;
  }
  body.rac #objective li::before {
    font-size: 5rem;
  }
  body.rac #objective .image {
    margin-top: 40px;
  }
}


@media screen and (min-width:1536px) {
	/* ==========================================================================================
		--TOP
	========================================================================================== */
  .index_nav li:first-of-type a {
		padding-left: 50px;
	}
  .index_nav li a br {
    display: none;
  }
	body.index .index_gallery .more {
		font-size: 2rem;
	}
	.index_gallery .more a:after {
		height: 100px;
		bottom: -50px;
	}

	/* ==========================================================================================
		--WHAT
	========================================================================================== */
	.what_nav,
	.about_nav {
		padding-left: 20%;
		padding-right: 20%;
	}

	/* ==========================================================================================
		--ABOUT
	========================================================================================== */
	body.about #about .greeting {
	    margin-left: -20vw;
		margin-right: -20vw;
	}
	body.about #about .greeting:before {
		left: 24vw;
	}
	body.about #about .greeting figcaption,
	body.greeting main section figcaption {
		font-size: 2rem;
		bottom: 25px;
	}
	body.about #about .greeting .chaiman figure {
		width: 17.7vw;
		right: 25vw;
	}
	body.about #about .greeting .chaiman figcaption {
		left: -3em;
	}
	body.about #about .greeting .chaiman div {
		margin: 0 42.7vw 0 20vw;
	}
	body.about #about .greeting .organizer figure {
		width: 15.9vw;
		left: 25vw;
	}
	body.about #about .greeting .organizer figcaption {
		right: -3em;
	}
	body.about #about .greeting .organizer div {
		margin: 0 20vw 0 40.9vw;
	}

	body.about .about_info,
	body.volunteer .volunteer_archive,
	body.meeting .meeting_archive {
		padding-left: 20vw;
		padding-right: 20vw;
	}

	/* ==========================================================================================
		--GREETING
	========================================================================================== */
	body.greeting main section figure {
		width: 17.7vw;
	}
	body.greeting main section p {
		padding-left: 80px;
	}
}

@media screen and (min-width:1630px) {
  .index_main h2 {
    margin-top: 60px;
  }
  .index_main .bnr {
    margin-top: 60px;
  }
  .index_nav li {
    font-size: 1.8rem;
  }
}