@charset 'utf-8';

/* reset
------------------------------------------------ */
body,div,pre,p,a,img,form,fieldset,input,textarea,select,option,
dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,table,th,td,embed,object,
figure,figcaption {
	margin: 0;
	padding: 0;
}
html { height: 100%; font-size: 62.5%; }
body {
	width: 100%;
	height: 100%;
	background: #fff;
	-webkit-text-size-adjust: 100%;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif;
	font-size: 1rem;
	line-height: 1.6;
	color: #282A2C;
}

*,
*:before,
*:after { -webkit-box-sizing: border-box; box-sizing: border-box; }

.fOswald { font-family: 'Oswald', sans-serif; }

ul,ol { list-style: none; }
img { width: auto; height: auto; max-width: 100%; border: none; vertical-align: top; }
a { text-decoration: none; color: #282A2C; }
a:hover { text-decoration: none; }
.device_click a,
.device_click input[type=image],
.device_click input[type=submit] { transition: ease .3s; }
.device_click a:hover,
.device_click input[type=image]:hover,
.device_click input[type=submit]:hover { opacity: .8; }

/* clearfix
------------------------------------------------ */
.clearfix { clear: both; }
.clearfix:before,.clearfix:after { content: ' '; display: table; }
.clearfix:after { clear: both; }

/* container
------------------------------------------------ */
#container { position: relative; width: 100%; }
.wrap { position: relative; margin: 0 auto; max-width: 1200px; }

@media only screen and (min-width: 769px) {
	.pc { display: block !important; }
	.sp { display: none !important; }
}

@media only screen and (max-width: 1200px) {
	.wrap { padding: 0 20px; }
}

@media only screen and (max-width: 768px) {
	.pc { display: none !important; }
	.sp { display: block !important; }

	.wrap { padding: 0; }
}

/* header
------------------------------------------------ */
#header { position: relative; width: 100%; z-index: 10; }
#header--top { position: relative; width: 100%; height: 100px; background: #003884; }
#header--top .wrap { height: 100%; }

.header--logo { position: absolute; top: 30px; left: 0; width: 240px; }
.header--logo a { display: block; width: 100%; }
.header__bnr { display: flex; position: absolute; top: 40px; left: 260px; }
.header__bnr--item { margin-left: 10px; }
.header__bnr--item:first-child { margin-left: 0; }
.header__bnr--item a { display: block; width: 100%; }
.header__bnr--nadeshikoleague { width: 160px; }
.header__bnr--jfa { width: 98px; }
.header--emblem { position: absolute; top: 6px; left: 540px; width: 75px; }
.header--emblem a { display: block; width: 100%; }
#gnav { position: absolute; top: 8px; right: 0; }
.gnav__lists--item { position: relative; font-size: 2.4rem; }
.gnav__lists--item a { position: relative; color: #fff; }
.gnav__lists--item > a { font-family: 'Oswald', sans-serif; letter-spacing: .04em; }
.gnav__sub--item { font-size: 1.5rem; }

.body--header--fixed #header { position: fixed; top: 0; left: 0; }

@media only screen and (min-width: 769px) {
	#gnav { display: block !important; width: 420px; }
	#gnav .frame { height: auto !important; }
	.gnav__lists--item { float: left; padding: 0 20px; width: 33.3333%; text-align: center; z-index: 1; }
	.gnav__lists--item:nth-of-type(-n+3) { z-index: 2; }
	.gnav__lists--item:before { content: '/'; position: absolute; top: 0; left: 0; font-family: 'Oswald', sans-serif; color: #fff; }
	.gnav__lists--item:nth-of-type(3n+1):before { display: none; }
	.gnav__lists--item:nth-of-type(n+4),
	.gnav__lists--item:nth-of-type(n+4):before,
	.gnav__lists--item:nth-of-type(n+4) > a { color: #0cf; }
	.gnav__sub { display: none; position: absolute; top: 58px; left: 50%; margin-left: -80px; padding: 20px 15px; width: 160px; background: #fff; text-align: left; }
	.gnav__sub:before { content: ' '; position: absolute; top: -20px; left: 50%; margin-left: -20px; border-style: solid; border-color: transparent; border-width: 20px; border-bottom-color: #fff; border-top: none; }
	.gnav__sub--item { margin-top: 15px; text-align: center; white-space: nowrap; }
	.gnav__sub--item:first-child { margin-top: 0; }
	.gnav__sub--item a { color: #003884; }
	.gnav--emblem { display: none; }
	.header--menu { display: none; }
}

@media only screen and (max-width: 1200px) and (min-width: 769px) {
	.header--logo { left: 20px; width: 20vw; }
	.header__bnr { left: calc(21.6666666667vw + 20px); }
	.header__bnr--nadeshikoleague { width: 13.3333333333vw; }
	.header__bnr--jfa { width: 8.16666666667vw; }
	.header--emblem { top: 50%; left: calc(45vw + 20px); transform: translateY(-50%); width: 6.25vw; }
	#gnav { top: 50%; right: 20px; transform: translateY(-50%); width: 35%; }
	.gnav__lists--item { padding: 0 2.5vw; font-size: 2vw; }
}

@media only screen and (max-width: 768px) {
	#header--top { height: 50px; }
	.header--logo { top: 14px; left: 5px; width: 100px; }
	.header__bnr { top: 12px; left: 115px; }
	.header__bnr--item { height: 26px; }
	.header__bnr--nadeshikoleague { width: 104px; }
	.header__bnr--jfa { width: 64px; }
	.header--emblem { display: none; }

	#gnav { display: none; top: 50px; right: auto; left: 0; width: 100%; background: #282A2C; }
	#gnav .frame { position: relative; width: 100%; height: calc(100vh - 50px); -webkit-overflow-scrolling: touch; overflow: auto; }
	.gnav__lists { padding: 30px 20px; }
	.gnav__lists--item { margin-top: 30px; font-size: 2.8rem; }
	.gnav__lists--item:first-child { margin-top: 0; }
	.gnav__lists--item a { display: block; }
	.gnav__sub { display: block !important; border-bottom: solid #fff 1px; }
	.gnav__sub--item { border-top: solid #fff 1px; font-size: 1.4rem; }
	.gnav__sub--item a { padding: 12px 15px; }
	.gnav--emblem { margin: 0 auto; padding-bottom: 20px; width: 80px; }
	.gnav--emblem a { display: block; width: 100%; }

	.header--menu { position: absolute; top: 50%; right: 20px; margin-top: -14px; width: 32px; height: 28px; }
	.header--menu a,
	.header--menu span { display: block; position: relative; width: 100%; height: 100%; }
	.header--menu span { text-indent: -9999px; white-space: nowrap; overflow: hidden; }

	.header--menu a:after,
	.header--menu span:before,
	.header--menu span:after { content: ' '; position: absolute; left: 0; transition: ease .3s; width: 100%; height: 3px; background: #fff; }
	.header--menu a:after { top: 0; }
	.header--menu span:before { top: 12px; }
	.header--menu span:after { top: 24px; }
	.header--menu a.on:after { display: none; }
	.header--menu a.on span:before { top: 12px; transform: rotate(45deg); }
	.header--menu a.on span:after { top: 12px; transform: rotate(-45deg); }

	.body--gnav--open { position: fixed; top: 0; left: 0; }
	.body--gnav--open #header { position: fixed; top: 0 !important; left: 0; }

}

@media only screen and (max-width: 320px) {
	.header--logo { top: 16px; width: 80px; }
	.header__bnr { top: 14px; left: 95px; }
	.header__bnr--item { height: 22px; }
	.header--menu { right: 10px; }
}

/* main
------------------------------------------------ */
#main { display: block; position: relative; width: 100%; }

/* title */
.title--1 { font-family: 'Oswald', sans-serif; font-size: 4rem; font-weight: 600; letter-spacing: .05em; color: #003884; }
.title--2 { position: relative; margin-bottom: 28px; padding-bottom: 14px; border-bottom: solid #707070 1px; font-size: 2.4rem; font-weight: 600; letter-spacing: .05em; color: #003884; }

/* page__title */
.page__title { position: relative; margin-bottom: 80px; padding-bottom: 23.4260614934%; width: 100%; height: 0; background-position: center center; background-repeat: no-repeat; background-size: cover; overflow: hidden; }
.page__title:before,
.page__title:after { content: ' '; position: absolute; transform-origin: top left; transform: rotate(45deg); padding-bottom: 32.9428989751%; width: 32.9428989751%; height: 0; background: #002D6A; overflow: hidden; }
.page__title:before { top: -100%; left: 0; }
.page__title:after { top: 0; right: -32.9428989751%; }
.page__title--name { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); white-space: nowrap; font-family: 'Oswald', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif; font-size: 6.2rem; font-weight: 600; color: #fff; }

/* cat */
.cat--icon { background: #282A2C; color: #fff; }
.cat--icon--team { background: #003884; }
.cat--icon--game { background: #C60000; }
.cat--icon--event { background: #4E9114; }
.cat--icon--reserve { background: #CE740C; }

/* comingsoon */
.comingsoon { padding: 22vh 0 14vh; text-align: center; font-family: 'Oswald', sans-serif; font-size: 6rem; font-weight: 600; letter-spacing: .05em; color: #003884; }

@media only screen and (max-width: 768px) {
	.title--1 { font-size: 2.4rem; letter-spacing: .025em; }
	.title--2 { margin-bottom: 12px; padding-bottom: 6px; font-size: 1.4rem; letter-spacing: 0; }

	.page__title { margin-bottom: 40px; padding-bottom: 46.875%; }
	.page__title:before,
	.page__title:after { padding-bottom: 33.125%; width: 33.125%; }
	.page__title:before { top: -50%; }
	.page__title:after { top: 50%; right: -33.125%; }
	.page__title--name { font-size: 2.6rem; }
}

/* footer
------------------------------------------------ */
#footer { position: relative; margin-top: 100px; }
#footer--top { position: relative; padding: 62px 0 10px; background: #000; }
#footer--top .wrap { max-width: 852px; }

.footer__bnr--item a { display: block; }
.footer__links { position: relative; margin-top: 65px; color: #fff; }
.footer__links a { display: inline-block; vertical-align: top; color: #fff; }
.footer__nav { float: left; width: 82.1596244131%; }
.footer__nav--item { float: left; margin-left: 1.33333333333%; width: 24%; }
.footer__nav--item:first-child { margin-left: 0; }
.footer__nav--title { font-family: 'Oswald', sans-serif; font-size: 1.8rem; }
.footer__nav__content { margin-top: 18px; }
.footer__nav__content + .footer__nav--title { margin-top: 30px; }
.footer__nav__lists { padding-left: 18px; border-left: solid #fff 1px; }
.footer__nav__lists--item { margin-top: 14px; font-size: 1.4rem; }
.footer__nav__lists--item:first-child { margin-top: 0; }
.footer__sub { float: right; width: 15.4929577465%; }
.footer__sub--item { margin-top: 30px; font-size: 1.4rem; }
.footer__sub--item:first-child { margin-top: 0; }
.footer--copyright { margin-top: 48px; text-align: center; font-size: 1.6rem; color: #fff; }
.footer--copyright small { font-size: inherit; }

@media only screen and (min-width: 769px) {
	.footer__bnr { display: flex; flex-wrap: wrap; }
	.footer__bnr--item { margin: 30px 11.2676056338% 0 0; width: 25.8215962441%; }
	.footer__bnr--item:nth-of-type(-n+3) { margin-top: 0; }
	.footer__bnr--item:nth-of-type(3n) { margin-right: 0; }
}

@media only screen and (max-width: 768px) {
	#footer { margin-top: 50px; }
	#footer--top { padding: 24px 0 8px; }
	.footer__bnr { margin: 0 auto; width: 46.875%; }
	.footer__bnr--item { margin-top: 15px; width: 100%; }
	.footer__bnr--item:first-child { margin-top: 0; }
	.footer__links { margin: 32px auto 0; width: 46.875%; }
	.footer__nav { display: none; }
	.footer__sub { display: flex; justify-content: space-between; flex-wrap: wrap; float: none; width: auto; }
	.footer__sub--item { margin: 0 0 10px; font-size: 1.1rem; }
	.footer--copyright { margin-top: 6px; font-size: .7rem; }
}

/* sns__floating
---------------------------------*/
.sns__floating { position: fixed; top: 50%; right: 0; transform: translateY(-50%); padding: 20px 0; width: 60px; background: rgba(255,255,255,.8); border-radius: 8px 0 0 8px; z-index: 8; }
.sns__floating--item { margin: 20px auto 0; width: 40px; }
.sns__floating--item:first-child { margin-top: 0; }
.sns__floating--item a { display: block; }

@media only screen and (max-width: 768px) { 
	.sns__floating { padding: 10px 0; width: 40px; border-radius: 4px 0 0 4px; }
	.sns__floating--item { margin-top: 10px; width: 30px; }
}

/* sns__live
---------------------------------*/
.sns__live { position: fixed; bottom: 0; left: 0; padding: 20px; background: rgba(0,56,132,.8); border-radius: 0 8px 0 0; z-index: 8; }
.sns__live--text { font-size: 1.4rem; font-weight: bold; color: #fff; }
.sns__live--btn { margin: 16px auto 0; width: 80px; }
.sns__live--btn a { display: block; }

@media only screen and (max-width: 768px) { 
	.sns__live { padding: 10px; border-radius: 0 4px 0 0; }
	.sns__live--text { font-size: 1rem; }
	.sns__live--btn { margin-top: 10px; width: 60px; }
}

/* pagination
---------------------------------*/
.pagination li + li { margin-left: 20px; }
.pagination--num { display: inline-block; font-size: 2.3rem; font-family: 'Oswald', sans-serif; font-weight: bold; color:#003884; vertical-align: top; }
.pagination--num a { display: block; min-width: 20px; text-align: center; border-bottom:1px solid transparent; color:#003884; }
.pagination--num a:hover, .pagination--num .active { border-bottom: 1px solid #003884 }
.pagination--prev a,
.pagination--next a { text-indent: -9999px; white-space: nowrap; overflow: hidden; }
.pagination--prev a { width: 20px; height: 37px; background: url(../img/icon/arrow3.png) no-repeat left 8px / auto 20px; }
.pagination--next a { width: 20px; height: 37px; background: url(../img/icon/arrow2.png) no-repeat right 8px / auto 20px; }
@media only screen and (max-width: 768px) { 
	.pagination--num { font-size: 1.6rem; }
	.pagination li + li { margin-left: 17px; }
	.pagination--prev a { height: 26px; background: url(../img/icon/arrow3.png) no-repeat left 5px / auto 16px; }
	.pagination--next a { height: 26px; background: url(../img/icon/arrow2.png) no-repeat right 5px / auto 16px;}
}

/* pagination__detail
---------------------------------*/
.pagination__detail{ margin-top: 20px; display: table; width: 100%; }
.pagination__detail li{ display: table-cell; width: 33.33%; vertical-align: middle; }
.pagination__detail li a { display: inline-block; font-size: 1.6rem; color:#003884; }
.pagination__detail--prev a{ padding-left: 35px; text-align: left; background:url(../img/icon/arrow3.png) no-repeat left center / auto 16px; }
.pagination__detail--next a{float: right; padding-right: 35px; text-align: right; background:url(../img/icon/arrow2.png) no-repeat right center / auto 16px; }
.pagination__detail--top { text-align: center; }

/* aside
---------------------------------*/
.aside--title { margin-bottom: 20px; font-size: 2rem; font-family: 'Oswald', sans-serif; letter-spacing: 0.05em; color:#003884; line-height: 1.5rem; font-weight: bold; }
.aside__calendar--table { margin-bottom: 50px; width: 100%; border:none; text-align: center; border-collapse: collapse; }
.aside__calendar--head { background-color: #003884; }
.aside__calendar--head th { width: 14.28%; height: 32px; font-size: 1.6rem; color:#fff; }
.aside__calendar--body td { padding-top: 20px; font-size: 1.6rem; color: #282A2C; }
.aside--form { font-size: 1.6rem; color:#282A2C; }
.aside--select { width: 100%; height: 40px; padding: 0 25px; letter-spacing: 0.05em; -webkit-appearance: none; -moz-appearance: none; appearance: none; background: url(../img/icon/arrow5.png) no-repeat calc(100% - 25px) center; background-size: 12px; border: 1px solid #707070; }
.aside--select option { font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif; }
.aside__calendar--body td a { text-decoration: underline; color:#003884; }
.device_click .aside__calendar--body td a:hover { text-decoration: none; }

@media only screen and (min-width: 769px) {
	.content--col { width: calc( 100% - 324px); max-width: 800px; float:left; }
	.aside { width: 260px; float: right; }
}

@media only screen and (max-width: 768px) {
	.content--col { margin-bottom: 55px; }
	.aside--title { font-size: 1.6rem; margin-bottom: 12px; }
	.aside__calendar--body td { padding-top: 14px; }
	.aside--select { font-size: 1.4rem; }
	.aside__calendar--table { margin-bottom: 45px; }
}

/* socail
---------------------------------*/
.socail{ display: flex; align-items: center; padding: 15px 0; border-top:1px dashed #707070; border-bottom:1px dashed #707070; }
.socail--share { padding: 4px 0; width: 142px; background: #003884; text-align: center; font-family: 'Oswald', sans-serif; font-size: 1.6rem; color: #fff; }
.socail__links { display: flex; }
.socail--icon { display: inline-block; vertical-align: middle; }
.socail--icon a { display: inline-block; vertical-align: top; }
.socail--tw {  padding:0 50px; background:url(../img/icon/back.png) no-repeat right center; }
.socail--fb { padding-left: 50px; }

@media only screen and (max-width: 768px) {
	.socail--share { width: 85px; }
	.socail--tw { padding: 0 30px; }
	.socail--fb { padding-left: 30px; }
	.socail { padding: 12px 0; }
	.pagination__detail { margin-top: 27px; }
	.pagination__detail li a { font-size: 1.2rem; }
	.pagination__detail--prev a { padding-left: 18px; background: url(../img/icon/arrow3.png) no-repeat left center / auto 12px; }
	.pagination__detail--next a { padding-right: 18px; background: url(../img/icon/arrow2.png) no-repeat right center / auto 12px; }
}

/* modal
---------------------------------*/
.modal-image-content { display: none; position: fixed; top: 32px; left: 50%; transform: translateX(-50%); height: calc(100dvh - 64px); z-index: 101; }
.modal-image-content--image { display: flex; justify-content: center; align-items: center; height: 100%; }
.modal-image-content--image img { max-height: 100%; }
.modal-image-close { display: none; position: fixed; top: 32px; right: 32px; width: 30px; height: 30px; text-indent: -9999px; white-space: nowrap; overflow: hidden; z-index: 101; }
.modal-image-close::before,
.modal-image-close::after { content: ''; position: absolute; top: 50%; left: 0; width: 30px; height: 2px; background-color: #fff; }
.modal-image-close::before { transform: rotate(45deg); }
.modal-image-close::after { transform: rotate(-45deg); }
.modal-image-overlay { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.8); z-index: 100; }

@media only screen and (max-width: 768px) {
	.modal-image-close { top: 16px; right: 16px; }
}

/* wp-block
---------------------------------*/
body {
	--wp--preset--font-size--large: 2rem;
	--wp--style--gallery-gap-default: 10px;
}

.wp-content * + * { margin-top: 20px; }
.wp-block-heading { margin-bottom: 10px; font-size: 1.6rem; line-height: 1.4; color: #003884; }
.has-large-font-size { margin-top: 60px; padding-bottom: 0.4em; border-bottom: 3px solid #003884; line-height: 1.4; color: #000; }
.has-large-font-size:first-child { margin-top: 0; }
.wp-block-columns.is-layout-flex { gap: 40px; }
.wp-block-table { font-size: 1.2rem; }
.wp-block-table th,
.wp-block-table td { padding: 0.6em 1em; border: 1px solid #000; }
.wp-block-table th.has-text-align-center,
.wp-block-table td.has-text-align-center { padding-right: 0.2em; padding-left: 0.2em; }
.wp-block-table th { font-weight: bold; }
.wp-block-table thead { border: 2px solid #000; }
.wp-block-table thead th,
.wp-block-table thead td { border-width: 2px; border-color: #000; }
.wp-block-table thead th { font-size: 1.4rem; }
.wp-block-buttons .wp-block-button__link { background-color: #fff; border: 1px solid #003884; border-radius: 0; text-decoration: none; font-size: 1.4rem; font-weight: bold; color: #003884; }
.wp-block-buttons .wp-block-button__link::after { content: ''; display: inline-block; margin-left: 10px; width: 5px; height: 10px; background: url(../img/icon/arrow2.png) no-repeat center center; background-size: 100% 100%; vertical-align: middle; }
.device_click .wp-block-buttons .wp-block-button__link:hover { background-color: #003884; color: #fff; opacity: 1; }
.device_click .wp-block-buttons .wp-block-button__link:hover::after { background-image: url(../img/icon/arrow1.png); }

@media only screen and (max-width: 768px) {
}

@media only screen and (min-width: 769px) {
	body {
		--wp--preset--font-size--large: 2.4rem;
		--wp--style--gallery-gap-default: 15px;
	}

	.wp-content * + * { margin-top: 40px; }
	.wp-block-heading { margin: 20px 0 15px; font-size: 2rem; }
	.has-large-font-size { margin-top: 100px; }
	.wp-block-columns.is-layout-flex { gap: 40px; }
	.wp-block-columns .wp-block-column p { font-size: 1.4rem; }
	.wp-block-table { font-size: 1.4rem; }
	.wp-block-table thead th { font-size: 1.6rem; }
	.wp-block-buttons .wp-block-button__link { font-size: 1.6rem; }
	.wp-block-buttons .wp-block-button__link::after { margin-left: 16px; width: 6px; height: 12px; }
}

/* print
---------------------------------*/
@media print {
	.body--header--fixed #header { position: relative; }
	#gnav { display: none; }
}
