@charset "UTF-8";
/*
Theme Name: 岩国eスポーツフェスティバル
Theme URI: https://example.com
Author: コトカタデザイン
Author URI: https://koto-kata.design/
Description: 岩国eスポーツフェスティバル公式サイト用テーマ
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: esportsfestival
*/
* {
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
}
img {
    width: 100%;
}
body {
}
main {
    background: url("../../assets/images/bg.jpg") no-repeat top center / 3000px;;
	padding: 50px 0 0;
}
.fv {
    display: flex;
    justify-content: center;
}
.fv .grid-container {
    width: 100%;
    max-width: 960px;
    display: grid;
    grid-template-columns: 600px 280px;
    grid-template-rows: 300px 150px;
}
.fv picture {
    width: 100%;
}
#gi1 {
}
#gi2 {
    display: flex;
    align-items: flex-end;
}
#gi3 {
    grid-column: 2 / 4;
    grid-row: 1 / 3;
    display: flex;
    justify-content: center;
}
#gi3 img {
    width: 280px;
}
.information {
    width: 960px;
	margin: 100px auto 70px;
}
.information .news {
	width: 820px;
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
	padding: 30px 0 20px;
}
.information .news p {
	color: #fff;
	font-size: 16px;
	line-height: 2;
	margin: 20px 0 0;
}
.information .news p span.date {
	padding: 0 20px 0 0;
}
.information .news p a {
	color: #fff;
	text-decoration: underline;
}
.join {
    width: 960px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 820px;
}
.join > div {
    margin: 0 0 30px;
}
.entry {
    border: 2px solid #fff;
    display: grid;
    grid-template-columns: 340px 480px;
}
.entry > div {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 30px;
}
.entry div img {
    margin: 20px 0;
}
.entry div p a {
    font-size: 16px;
    color: #fff;
    text-decoration: underline;
}
.regulation {
    font-size: 16px;
}
.regulation dt {
    margin: 20px 0;
    line-height: 1.6;
}
.regulation dd,
.regulation li {
    line-height: 1.6;
    margin: 0 0 0 16px;
}
.regulation li {
    list-style: disc;
}
footer div {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding: 20px 0;
}
footer div p {
    line-height: 2;
    font-size: 14px;
}
footer div p span {
    height: 13px;
    width: 50px;
    background: url("../../assets/images/jesu-logo-black.svg") no-repeat center center / cover;
    display: inline-flex;
    margin: 0 5px;
}
section.program {
    background: #fff;
}
.program-bg {
	display: flex;
	justify-content: center;
    background: url("../../assets/images/program-bg.jpg") no-repeat top center / 3000px;
	padding: 0 0 50px;
}
.program-bg img {
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
	display: block;
}
.regulation {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 1000;
    height: 100vh;
    justify-content: center;
    padding: 30px 0;
}

.regulation.show {
    display: inline-grid;
}

.regulation > dl, 
.regulation > h2 {
    background: #fff;
    padding: 2rem;
    max-height: 80vh;
    overflow-y: auto;
    width: 100%;
    max-width: 600px;
}
.regulation > dl {
    padding-top: 0;
}
.regulation > h2 {
    padding-bottom: 0;
}

.close-btn {
    display: block;
    margin-left: auto;
    background: #f44336;
    color: #fff;
    border: none;
    padding: 0.5em 1em;
    font-size: 1rem;
    cursor: pointer;
    border-radius: 6px;
    height: 25px;
}
.sponsors {
	background: #fff;
	padding: 0 20px;
}
.sponsors-wrap {
	width:100%;
	max-width:960px;
	margin:0 auto;
	border: 3px solid #004385;
	border-radius: 10px
}
.sponsors-title {
	background:#004385;
	padding: 20px;
}
.logo-list {
	display:flex;
	flex-wrap: wrap;
	justify-content:space-between;
	padding: 20px;
}
.logo-list li {
	margin: 10px 20px;
}
.sponsors-title div {
	display: flex;
	justify-content: space-between;
	margin: 0 0 10px;
	flex-wrap: wrap;
}
img.sponsor-esport {
    width: 430px;
}
img.sponsor-title {
    width: 470px;
}
img.sponsor-notes {
    width: 340px;
    margin: 0 0 0 auto;
    display: block;
}
@media (max-width: 960px) and (min-width: 768px) {
    main {
        background: url("../../assets/images/bg-tb.jpg") no-repeat top center;
		padding: 50px 0 0;
		overflow: hidden;
    }
	.join,
	.fv,
	.information,
	.program {
		padding: 0 20px;
	}
    .join {
        grid-template-columns: 100%;
		width: 100%;
    }
	.fv .grid-container {
		width: 100%;
		grid-template-columns: 70% 20%;
	}
	.entry {
		grid-template-columns: 35% 65%;
	}
    footer div {
        padding: 20px 0 20px 50px;
    }
	.information {
		width: 100%;
		margin: 50px auto 70px;
	}
	.information .news {
		width: 100%;
	}
	#gi2 {
		display: flex;
		align-items: center;
	}
	#gi3 {
		align-items: baseline;
	}
	section.program {
		background: #fff;
		width: calc(100% + 40px);
		margin: 0 0 0 -20px;
	}
	.program-bg img {
		padding: 0 20px;
	}
	img.sponsor-esport {
		width: 40%;
	}
	img.sponsor-title {
		width: 59%;
		margin: 0 0 0 1%;
	}
	img.sponsor-notes {
		width: 35%;
	}
	.logo-list li img {
		height: 30px;
	}
	footer div {
        padding: 20px;
    }
	.logo-list li img {
        height: 45px;
    }
}
@media (max-width: 767px) {
    body {
        background: none;
    }
    .gradient-diagonal {
        background: linear-gradient(45deg, #f7b400, #ffe200);
    }
    main {
        padding: 0;
    }
    .fv {
        margin: 0;
        padding: 20px 20px 0 20px;
        background: url("../../assets/images/bg-sp-fv.jpg") no-repeat top center / cover;
    }
    .fv .grid-container {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: space-between;
		margin: 0 0 20px;
    }
    #gi1 {
        margin: 0 0 20px;
    }
    #gi2 {
        width: 65%;
    }
    #gi3 {
        width: 30%;
    }
    .join,
    .entry {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        padding: 20px;
        margin: 0;
    }
    .join {
        background: url("../../assets/images/bg-sp-join.jpg") no-repeat top center / cover;
    }
    .regulation {
        padding: 40px;
    }
    .join > div {
        width: 100%;
    }
    .entry {
        padding: 10px 10px 100px;
        justify-content: space-between;
        position: relative;
    }
    .entry > div {
        width: calc(50% - 5px);
        padding: 0;
        align-items: flex-start;
    }
    .entry div p a {
        font-size: 14px;
        text-align: center;
        width: 100%;
        display: block;
    }
    .entry div img {
        margin: 20px 0;
    }
    #puyopuyo-cta,
    #tekken-cta {
        position: absolute;
        left: calc(50% - 150px);
        bottom: 20px;
        width: 300px;
    }
    footer div {
        padding: 20px;
    }
    footer div p {
        font-size: 12px;
        color: #000;
        line-height: 1.6;
    }
    footer div p span {
        height: 12px;
        width: 50px;
        background: url("../../assets/images/jesu-logo-black.svg") no-repeat center center / cover;
        margin: 0 5px;
    }
	.information {
		background: #004485;
		width: 100%;
		padding: 0 20px 30px 20px;
		margin: 0;
	}
	.information .news {
		width: 100%;
	}
	.program-bg {
		padding: 50px 20px 20px;
	}
	.logo-list li {
		margin: 10px;
	}
	.logo-list li img {
        height: 30px;
		width: auto;
    }

}

