@charset "utf-8";

/* ==========================================================
 背景色変更
========================================================== */
img{
	max-width: 100%;
}
a{
	text-decoration: none;
	color: #000;
	display: block;
	word-break: break-all;
}
a:hover{
	text-decoration: underline;
	color: #fe9500;
}
body {
	background: #fff8a9;
}

.hero-program-01 {
	background-color: #fee800;
}

/* 背景色を指定 */

.contents {
	background-color: #fff8a9;
    background-image: radial-gradient(#fff34d 10%, transparent 20%), radial-gradient(#fff34d 10%, transparent 20%);
    background-position: 0 0, 10px 10px;
    background-size: 20px 20px;
}

.sec-cmn-01 + .sec-cmn-01 {
    border-top: none !important;
}

.date{
	display: flex;
	flex-wrap: wrap;
}
.date dt{
	width: 35%;
}
.date dd{
	width: 65%;
}

.img_h{
	display: flex;
}

@media screen and (max-width: 768px) {
	.date{
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
	}
	.date dd {
		width: 100%;
	}
}
/* コンテンツ背景色変更（コンテンツ全面の場合）
------------------------------------------------ */

.contents-main .container {
	background: #fff;
	max-width: 1024px;
    margin-right: auto;
    margin-left: auto;
	padding: 2em;
}

.s-bg-gray .container {
  background-color: #ededed;
}


.sec-cmn-01 {
    padding-top: 40px;
    padding-bottom: 40px;
    background-color: #fff;
}
.h1{
position: relative;
    display: block;
    /* padding-left: 28px; */
    font-size: 24px;
    font-weight: bold;
    line-height: 1.4;
    color: #000;
}


/* ==========================================================
 hero-cmn
========================================================== */
.hero-cmn-subpage {
	background: #000;
}
.br-sp {
	display: none;
}
@media screen and (max-width: 767px) {
	.hero-cmn-subpage {
		background: #000;
	}
		.br-sp {
			display: block;
		}
}

@media screen and (max-width: 768px) {
	.inner figure img {
		width: 100%;
	}
}

/* ==========================================================
 contents
========================================================== */
h2 {
    position: relative;
    padding: 1rem 2rem calc(1rem + 10px);
    background: #fff175;
    margin-bottom: 2rem;
    font-weight: bold;
	width: fit-content;
    margin: 0 auto 2em;
}
h2::before {
    position: absolute !important;
    top: -7px !important;
    left: -7px !important;
    width: 100% !important;
    height: 100% !important;
    content: "" !important;
    border: 1px solid #000 !important;
	background-color: transparent!important;
}
.rekidai {
	position: relative !important;
    display: block !important;
    padding-left: 28px !important;
    font-size: 24px !important;
    font-weight: bold !important;
    line-height: 1.4 !important;
    color: #000 !important;
}
.rekidai::before{
    content: "" !important;
    position: absolute !important;
    top: 6px !important;
    left: 0 !important;
    width: 8px !important;
    height: 20px !important;
    background-color: #f8bc2c !important;
}
.ttl-cmn-section {
	margin-bottom: 5px;
}



.txt-areafull {
	width: 100%;
	padding: 1rem;
}

/* h1::before{
	display: none;
}  */
/* ==========================================================
24h用
========================================================== */
.spOnly {
	display: none;
}

.pcOnly {
	display: block;
}

.fRed {
	color: red;
}

.fontS {
	font-size: .9em;
}

.fontB {
	font-size: 1.2em;
	font-weight: bold;
}

.mBottom {
	margin-bottom: 3em !important;
}

.imgbottom {
	margin-bottom: 1em;
}

.table_kiseki {
	border: 1px #E3E3E3 solid;
	border-collapse: collapse;
	border-spacing: 0;
	background-color: #fff;
}

.table_kiseki tr th {
	padding: 10px;
	border: #E3E3E3 solid;
	border-width: 0 0 1px 1px;
	background: #F5F5F5;
	font-weight: bold;
	line-height: 120%;
	font-size: 18px;
}

.table_kiseki tr td {
	padding: 10px;
	border: 1px #E3E3E3 solid;
	border-width: 0 0 1px 1px;
	font-size: 18px;
}

.castBox {
	display: flex;
	width: 1000px;
	margin: 0 auto;
	flex-wrap: wrap;
	text-align: center;
}


.castBox figcaption {
	margin-top: .5em;
}

.castBox figure span {
	background-color: #fe9500;
	color: #fff;
	font-size: 1.2em;
	padding: .2em;
}

.cast1 {
	width: 400px;
	margin: 10px auto;
}

.castG {
	width: 900px;
	margin: 10px auto;
}

.cast1 img,
.castG img {
	width: 100%;
}

.areaTxt {
	position: relative;
	top: 0;
	left: 0;
	text-align: center;
	font-size: 1.4em;
	font-weight: bold;
	margin: 10px auto;
	width: 70%;
}

.areaTxt:before {
	content: "";
	display: block;
	border-top: solid 2px #fe9500;
	width: 100%;
	height: 2px;
	position: absolute;
	top: 50%;
	z-index: 1;

}

.areaTxt span {
	background: #fff8a9;
	padding: 0 20px;
	position: relative;
	z-index: 5;
}

.areaTxt.sides_left {
	text-align: left;
}

.areaTxt.sides_left span {
	padding-left: 0;
}

.areaTxt.sides_right {
	text-align: right;
}

.areaTxt.sides_right span {
	padding-right: 0;
}

.castTxt {
	text-align: center;
}

.seirikenTitle {
	font-size: 1.2em;
	color: red;
	text-align: center;
}

.seirikenInfo {
	text-align: center;
	margin-bottom: 2em;
}
.subLayoutBox div{
	width: 100%;
	word-
	eak: break-all;
	margin-right: 1em;
}
.subLayoutBox {
	display: flex;
	flex-wrap:nowrap;
	margin: 20px auto;
	justify-content: space-between;
}
.subLayoutBox {
position: relative;
padding: 1rem 2rem calc(1rem + 3rem) 1rem;
background: #ffd800;
margin-bottom: 4rem;
z-index: 0;
}
.subLayoutBox::before {
    position: absolute;
    top: -15px;
    left: -15px;
    width: 100%;
    height: 100%;
    content: "";
    border: 2px solid #000;
    background: #fff;
    z-index: -1;

}
.subLeftBox {
	width: 600px;
}


.subLayoutBox figcaption {
	text-align: left;
}

.subLayoutBox p,
.subLayoutOne p {
	width: 100%;
	margin: 2em auto;
	line-height: 2em;
}

.bokinDayInfo {
	font-size: 1.4em;
	font-weight: bold;
	text-decoration: underline;
}

.mapG {
	width: 800px;
	margin: 20px auto 0;
}

.stageEvent {
	width: 800px;
	margin: 20px auto 20px;
}

.stageInfo {
	width: 800px;
	margin: 20px auto 20px;
}

.photo400 {
	width: 400px;
}

.photo600 {
	width: 600px;
	margin: 0 auto;
}

.unicefLogo {
	width: 510px;
	margin: 0 10px 0 0;
}

.sinobyPhoto {
	width: 500px;
}


.photo400 img,
.photo600 img,
.sinobyPhoto img,
.unicefLogo img {
	width: 100%;
}

.subBox {
    position: relative;
    padding: 0.7rem 2rem;
    border-radius: 30rem;
    background-color: #fff34c;
    color: #212121;
    font-size: 1rem;
    font-weight: bold;
    text-align: center;
	border: 2px solid #fe9500;
    display: block;
    width: fit-content;
}

.subBoxTlong {
	background-color: #168e32;
	color: #fff;
	font-size: 1.1em;
	padding: .2em;
	min-width: 10em;
	border-radius: .2em;
	text-align: center;
	margin: .5em 0;
}

.subBoxTlong2 {
	width: 34em;
	text-align: left;
	background-color: #168e32;
	color: #fff;
	font-size: 1.1em;
	padding: .2em;
	min-width: 10em;
	border-radius: .2em;
	text-align: center;
	margin: .5em 0;
}

.subLayoutBox h6,
.subLayoutOne h6 {
	font-size: 1.2em;
	font-weight: bold;
	margin: 1em auto 0;
	line-height: 2;
}

.subLayoutCenter {
	width: 90%;
	display: flex;
	flex-wrap: wrap;
	margin: 20px auto;
	justify-content: space-between;
}

.subLayoutCenter figcaption {
	text-align: center;
}

.gourmetPhotoB {
	width: 400px;
}

.gourmetPhotoB img {
	width: 100%;
}

.gourmetPhotoW {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.gourmetPhotoW figure {
	width: 250px;
	margin: 5px;
}

.gourmetPhotoW figure img {
	width: 100%
}

.txtDecoBlue {
	margin-bottom: .25em;
	border-bottom: #fe9500 4px dotted;
}

.txtDecoYellow {
	margin-bottom: .25em;
	border-bottom: #fe9500 solid 2px;
}

.txtDecoRed {
	margin-bottom: .25em;
	border-bottom: #ea4609 solid 2px;
}

.birdGameBox {
	width: 600px;
	margin: 20px auto;
	background-color: #fff;
	font-size: 1.4em;
	font-weight: bold;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	border: #666 2px solid;
}

.birdImg {
	width: 600px;
	margin: 0 auto 20px;
}

.birdGameBox li {
	text-align: center;
	vertical-align: middle;
	padding: .25em 1em;
	background-color: #fff;

}

.gMenuBox {
	width: 520px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-content: flex-start;
}


.gMenuBoxS {
	width: 400px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-content: flex-start;
}

.gMenuBoxS dt {
	min-width: 250px;
}

.gMenuBox dt,
.gMenuBoxS dt {
	padding: .25em 1em;
}

.gMenuBox dd,
.gMenuBoxS dd {
	width: 7em;
	padding: .25em 1em;
}

.gName01 {
	width: 300px;
}

.gName02 {
	width: 300px;
	text-indent: 1em;
}

.gName03 {
	width: 300px;
}

.txtRight {
	text-align: right !important;
	padding-right: 2em;
}

.devirock {
	width: 400px;
	margin-left: 500px;
}

.devirock img {
	width: 100%;
}

.acMap {
	width: 800px;
	margin: 20px auto;
}

.btnPDF {
	width: 400px;
	margin: 20px auto;
}

.btnPDF img {
	width: 100%;
}

@media screen and (max-width: 1279px) {
	.contents {
		background: #fff8a9;
		width: 98%;
		margin: 0 auto;
	}

}

@media screen and (max-width: 896px) {
	.spOnly {
		display: block;
	}

	.pcOnly {
		display: none;
	}

	.table_kiseki tr th {
		font-size: 11px;
	}

	.table_kiseki tr td {
		font-size: 12px;
	}


	.castBox {
		display: flex;
		width: 100%;
		margin: 0 auto;
		flex-wrap: wrap;
		text-align: center;
	}


	.castBox figcaption {
		margin-top: .5em;
	}

	.cast1 {
		width: 70%;
		margin: 10px auto;
	}

	.castG {
		width: 100%;
		margin: 10px auto;
	}

	.subBox {
		min-width: 6em;
		margin: .5em auto;
	}

	.subBoxTlong2 {
		width: 24em;
		text-align: center;
		margin: .5em 0;
	}


.subLayoutBox{
	flex-wrap: wrap;
}
	.subLayoutBox p,
	.subLayoutOne p {
		width: 100%;
		margin: 1em auto;
		line-height: 1.6em;
	}

	.unicefLogo {
		width: 100%;
		margin: 0 0 1em 0;
	}

	.stageEvent {
		width: 100%;
		margin: 1em auto 1em;
	}

	.stageInfo {
		width: 100%;
		margin: 0em auto 1em;
	}


	.mapG {
		width: 100%;
		margin: 1em auto 0;
	}

	.mapG img,
	.stageEvent img,
	.stageInfo img,
	.photo400,
	.photo600,
	.sinobyPhoto {
		width: 100%;
		margin-bottom: 1em;
	}

	.subLeftBox {
		width: 100%;
	}

	.birdGameBox {
		width: 60%;
		margin: 2em auto;
		font-size: .9em;
		font-weight: bold;
		display: flex;
	}

	.birdImg {
		width: 100%;
		margin: 0 auto 2em;
	}

	.birdImg img {
		width: 100%;
	}

	.subLayoutCenter {
		width: 100%;
	}

	.gourmetPhotoB {
		width: 90%;
		margin: 0 auto;
	}


	.gourmetPhotoW figure {
		width: 100%;
		margin: 1em;
	}

	.gourmetPhotoW figure img {
		width: 100%
	}

	.gMenuBox,
	.gMenuBoxS {
		width: 65%;
	}

	.gMenuBox dt {
		padding: .25em 0em;
	}

	.gMenuBox dd {
		width: 6em;
		padding: .25em 0em;
	}

	.gName01 {
		width: 16em;
	}

	.gName02 {
		width: 15em;
		text-indent: 1em;
	}

	.gName03 {
		width: 100%;
	}

	.devirock {
		width: 100%;
		margin-left: 0px;
	}

	.devirock img {
		width: 100%;
	}


	.btnPDF {
		width: 50%;
		margin: 1rem auto;
	}

	.btnPDF img {
		width: 100%;
	}

}


@media screen and (max-width: 480px) {

	.contents {
		width: 100%;
	}

	.spOnly {
		display: block;
	}

	.pcOnly {
		display: none;
	}


	.castBox {
		display: flex;
		width: 100%;
		margin: 0 auto;
		flex-wrap: wrap;
		text-align: center;
	}


	.castBox figcaption {
		margin-top: .5em;
	}

	.cast1 {
		width: 70%;
		margin: 10px auto;
	}

	.castG {
		width: 100%;
		margin: 10px auto;
	}

	.subBox {
		width: fit-content;
		margin: 0 auto;
		display: block;
		padding: 0.7rem;
	}

	.subBoxTlong2 {
		width: 24em;
		text-align: center;
		margin: .5em auto;
	}


	.subLayoutBox p,
	.subLayoutOne p {
		width: 100%;
		margin: 1em auto;
		line-height: 1.6em;
	}

	.unicefLogo {
		width: 100%;
		margin: 0 0 1em 0;
	}

	.photo400,
	.photo600,
	.sinobyPhoto {
		width: 100%;
		margin-bottom: 1em;
	}

	.subLeftBox {
		width: 100%;
	}

	.birdGameBox {
		width: 100%;
		margin: 2em auto;
		font-size: .9em;
		font-weight: bold;
		display: flex;
	}

	.subLayoutCenter {
		width: 100%;
	}

	.gourmetPhotoB {
		width: 90%;
		margin: 0 auto;
	}


	.gourmetPhotoW figure {
		width: 100%;
		margin: 1em;
	}

	.gourmetPhotoW figure img {
		width: 100%
	}

	.gMenuBox,
	.gMenuBoxS {
		width: 100%;
	}

	.gMenuBox dt {
		padding: .25em 0em;
	}

	.gMenuBox dd {
		width: 6em;
		padding: .25em 0em;
	}

	.gName01 {
		width: 16em;
	}

	.gName02 {
		width: 15em;
		text-indent: 1em;
	}

	.gName03 {
		width: 100%;
	}

	.acMap {
		width: 100%;
		margin: 20px auto;
	}

	.acMap img {
		width: 100%;
	}

}

.s-cmn-protect {
	position: relative;
	display: inline-block;
}

.s-cmn-protect::after {
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background-color: transparent;
	position: absolute;
	top: 0;
	left: 0;
}

.txt-red {
		border: 3px solid red;
		padding: 15px;
		font-size: 14px;
		color: red;
}



.sellNone {

	/* ▼ 斜線はSVG画像を背景として設定 */
	background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJ3aWR0aDoxMDAlO2hlaWdodDoxMDAlOyI+PGxpbmUgeDE9IjEwMCUiIHkxPSIwJSIgeDI9IjAlIiB5Mj0iMTAwJSIgc3R5bGU9InN0cm9rZTogIzk5OTk5OTtzdHJva2Utd2lkdGg6IDE7Ij48L2xpbmU+PC9zdmc+');
}
.map{
	text-align: center;
	}
@media screen and (max-width: 768px) {
	.map iframe{
	width: 100%;
	}
}
@media print {
	.s-cmn-protect img {
		display: none;
	}
}

/* エリアマップ2023
------------------------------------------------ */

.area-map {
	width: 100%;
}

.area-map img {
	width: 100%;
}

/* アニメ用レイアウト2024
------------------------------------------------ */
.anime_box{
	display: flex;
}
.img_right{
	margin-left: auto;
}
@media screen and (max-width: 768px) {
.anime .photo400, .photo600{
	margin: 0 auto;
}
.anime_box{
	display: flex;
	flex-direction: column;
}
}

/* =====================================================================
*    注意書き　
* =================================================================== */

.attention {
	/* background-color: #fff7d9; */
	max-width: 1024px;
    margin: 0 auto;
  }

  .attention .inner {
	padding: calc(60 / 750 * 100%) 0;
  }

  .attention p {
	background-color: #ffffff;
	border: 2px solid #000000;
	padding: 1em 2em;
	text-align: left;
  }

  .text_red {
	color: #ff0000;
	font-weight: bold;
  }

  @media screen and (min-width: 768px) {
	.attention .inner {
		padding: calc(80 / 1920 * 100%) calc(30 / 1400 * 100%) calc(105 / 1920 * 100%);
	}
  }
