@charset "utf-8";



/*--------------------------------------------
■［HOME］
--------------------------------------------*/

body.home div#splash {
	width: 100vw;
	height: 100vh;
	height: 100dvh;
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	background-color: var(--color-white);
	color: var(--color-def);
	z-index: 9999;
	display: flex;
	justify-content: center;
	align-items: center;
	pointer-events: none;
}
body.home div#splash div#counter {
	display: flex;
	gap: 1em;
	align-items: center;
	justify-content: center;
}
body.home div#splash div#counter h5 {
	font-weight: bold;
	font-size: 1.8em;
	letter-spacing: 0;
	opacity: 0;
	display: flex;
	gap: 1em;
	align-items: center;
	white-space: nowrap;
	width: 10em;
}
body.home div#splash div#counter h5 img {
	max-height: 120px;
}
body.home div#splash div#counter p {
	font-weight: bold;
	color: var(--color-purple1);
	font-size: 7em;
	text-align: center;
	opacity: 0;
	line-height: 1;
}
body.home div#splash div#counter p sub {
	margin: 0;
	font-size: 0.6em;
}

section#section-home article#article-mainvisual {
	width: 100%;
	position: relative;
	padding: 0;
	margin: 0;
	display: block;
	overflow: hidden;
}
/*@keyframes scroll-anim {
	100% {
		background-position: center -100%;
	}
}*/
/*section#section-home article#article-mainvisual.type2 {
	background-image: url(../img/mainvisual2.png);
	padding-top: 39vw;
}*/
section#section-home article#article-mainvisual div.slick-slide > div > li {
	position: relative;
	padding-top: 39vw;
	height: 0;
	overflow: hidden;
}
section#section-home article#article-mainvisual ul.slick-dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	text-align: center;
}
section#section-home article#article-mainvisual div.slick-slide > div > li p:first-child {
	margin: 0;
	padding: 0;
}
section#section-home article#article-mainvisual div.slick-slide > div > li p:first-child img {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	object-fit: cover;
	width: 100%;
	height: 100%;
}
section#section-home article#article-mainvisual div#mainvisual-counter {
	background-color: var(--color-white);
	border-radius: 0.3em;
	padding: 1em;
	position: absolute;
	right: 2vw;
	bottom: 2vw;
	display: flex;
	gap: 0;
	box-shadow: 0 0 3px 1px rgba(0, 0, 0, 0.5);
	line-height: 1;
	align-items: center;
	width: 240px;
	height: 240px;
	border-radius: 50%;
	background-color: var(--color-white);
	color: var(--color-def);
	flex-direction: column;
	justify-content:center;
}
section#section-home article#article-mainvisual div#mainvisual-counter:before {
	content: "";
	position: absolute;
	left: 5px;
	right: 5px;
	top: 5px;
	bottom: 5px;
	border: 2px dotted var(--color-purple1);
	border-radius: 50%;
}
section#section-home article#article-mainvisual div#mainvisual-counter h5 {
	font-weight: bold;
	text-align: center;
	display: flex;
	gap: 10px;
}
section#section-home article#article-mainvisual div#mainvisual-counter h5 img {
	height: 3.5em;
	width: auto;
	display: inline-block;
}
section#section-home article#article-mainvisual div#mainvisual-counter h5 span {
	display: block;
	font-size: 1.1em;
}
section#section-home article#article-mainvisual div#mainvisual-counter p {
	font-weight: bold;
	color: var(--color-purple1);
	font-size: 4em;
}
section#section-home article#article-mainvisual div#mainvisual-counter p sub {
	margin: 0;
	font-size: 0.6em;
}



section#section-home article#article-newsandcalendar {
	background-color: var(--color-lgray1);
	z-index: 1;
	position: relative;
}
section#section-home article#article-mainvisual.type1 + article#article-newsandcalendar:before {
	background-image: url(../img/newsandcalendar_bg_001.svg);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	height: 10vw;
}
section#section-home article#article-newsandcalendar div.main-container {
	display: flex;
	gap: 60px;
}
section#section-home article#article-newsandcalendar div.main-container > div {
	background-color: var(--color-white);
	padding: 40px;
	box-shadow: 10px 10px 0 0 var(--color-gray1);
	position: relative;
}
section#section-home article#article-newsandcalendar div.main-container > div#news {
	width: 40%;
}
/*section#section-home article#article-newsandcalendar div.main-container > div#news dl.dllist-001 {
	flex-direction: column;
}
section#section-home article#article-newsandcalendar div.main-container > div#news dl.dllist-001 dt {
	background-color: var(--color-gray1);
	color: var(--color-def);
	font-size: 0.86em;
}
section#section-home article#article-newsandcalendar div.main-container > div#news dl.dllist-001 dd {
	width: 100%;
	padding: 0;
	margin-bottom: 1.5em;
}*/
ul.newslist {
	display: flex;
	flex-direction: column;
	gap: 1em;
	margin-bottom: 2em;
}
ul.newslist > li {
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
}
section#section-home article#article-newsandcalendar ul.newslist > li {
	flex-direction: column;
	gap: 0.5em;
	border-top: 1px solid var(--color-gray1);
	padding-top: 1em;
	align-items: flex-start;
}
ul.newslist > li h5 {
	width: 16em;
	background-color: var(--color-lgray1);
	color: var(--color-def);
	padding: 0.75em 1.5em;
	border-radius: 2em;
	display: flex;
	font-size: 0.86em;
	align-items: center;
}
section#section-home article#article-newsandcalendar ul.newslist > li h5 {
	width: auto;
	background-color: transparent;
	padding: 0;
	border-radius: 0;
}
ul.newslist > li h5 span {
	color: var(--color-purple2);
}
ul.newslist > li h5 strong {
	background-color: var(--color-purple1);
	color: var(--color-white);
	font-size: 0.76em;
	padding: 0.5em;
	line-height: 1;
	margin-left: auto;
	width: 9em;
	text-align: center;
	border-radius: 0.2em;
	font-weight: normal;
}
section#section-home article#article-newsandcalendar ul.newslist > li h5 strong {
	margin-left: 1em;
}
ul.newslist > li[data-category="文化・環境"] h5 strong {
	background-color: var(--color-purple1);
}
ul.newslist > li[data-category="産業"] h5 strong {
	background-color: var(--color-orange1);
}
ul.newslist > li[data-category="観光"] h5 strong {
	background-color: var(--color-yellow1);
}
ul.newslist > li[data-category="いのち"] h5 strong {
	background-color: var(--color-green1);
}
ul.newslist > li[data-category="その他"] h5 strong {
	background-color: var(--color-blue1);
}
ul.newslist > li p {
	width: calc(100% - (16em + 1em));
	padding: 0.75em 0;
}
section#section-home article#article-newsandcalendar ul.newslist > li p {
	width: auto;
	padding: 0;
}

section#section-home article#article-newsandcalendar div.main-container > div#calendar {
	width: 60%;
}
section#section-home article#article-newsandcalendar div.main-container > div h2 {
	margin-bottom: 1em;
}
section#section-home article#article-newsandcalendar div.main-container > div#news dl dd a {
	text-decoration: underline;
}
.fc .fc-button {
	font-size: 0.86em;
}
.fc .fc-toolbar.fc-header-toolbar {
	margin-bottom: 1em;
}
.fc .fc-button-primary {
	background-color: var(--color-purple1);
	border-color: var(--color-purple1);
}
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
	background-color: var(--color-purple2);
	border-color: var(--color-purple2);
}
.fc .fc-button-primary:disabled {
	background-color: var(--color-mute);
	border-color: var(--color-mute);
}
.fc .fc-toolbar-title {
	font-size: 1.3em;
	margin: 0 !important;
	color: var(--color-def);
	font-family: var(--font-ja);
	font-weight: 700;
}
.fc .fc-daygrid-day.fc-day-today {
	background-color: var(--color-lred1);
}
.fc a:not([href]):not(.fc-more-link):hover {
	color: var(--color-def);
	opacity: 1;
}
.fc a:after {
	display: none;
}
.fc a.fc-more-link {
	color: var(--color-purple1);
}
.fc thead th {
	position: relative;
	background-color: var(--color-lgray1);
}
.fc thead th.fc-day-sat,
.fc thead th.fc-day-sat a {
	background-color: var(--color-lblue1);
	color: var(--color-purple1);
}
.fc thead th.fc-day-sun,
.fc thead th.fc-day-sun a {
	background-color: var(--color-lred1);
	color: var(--color-red1);
}
.fc thead th + th:before {
	width: 1px;
	position: absolute;
	left: -1px;
	top: 0;
	bottom: 0;
	background-color: var(--color-gray1);
	content: "";
}
.fc th, .fc td {
	border-color: var(--color-gray1);
}
.fc .fc-event-time {
	display: none;
}
div#importcalendar h2.fc-toolbar-title {
	font-size: 1.2em;
	margin: 0;
	color: var(--color-purple2);
	font-family: var(--font-def);
}
section#section-home article#article-yumeshimanow {
	position: relative;
	overflow: hidden;
	padding: 0;
}
/*section#section-home article#article-yumeshimanow div.yumeshimanow-bg {
	position: absolute;
	background-repeat: no-repeat;
	background-size: contain;
	margin: auto;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-001 {
	background-image: url(../img/top_now_001.svg);
	background-position: left top;
	width: 35%;
	height: 70%;
	left: 0;
	top: 0;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-002 {
	background-image: url(../img/top_now_002.svg);
	background-position: center top;
	background-size: contain;
	width: 23%;
	height: 12%;
	right: 25%;
	top: 0;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-003 {
	background-image: url(../img/top_now_003.svg);
	background-position: right top;
	background-size: contain;
	width: 17%;
	height: 90%;
	right: 0;
	top: 0;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-004 {
	background-image: url(../img/top_now_004.svg);
	background-position: right bottom;
	background-size: contain;
	width: 20%;
	height: 37%;
	right: 0;
	bottom: 0;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-005 {
	background-image: url(../img/top_now_005.svg);
	background-position: center bottom;
	background-size: contain;
	width: 30%;
	height: 25%;
	left: 30%;
	bottom: 0;
}
section#section-home article#article-yumeshimanow div#yumeshimanow-bg-006 {
	background-image: url(../img/top_now_006.svg);
	background-position: left bottom;
	background-size: contain;
	width: 28%;
	height: 88%;
	left: 0%;
	bottom: 0;
}*/
section#section-home article#article-yumeshimanow div#yumeshimanow {
	position: relative;
	padding: 60px 3vw;
	/*background-image: url(../img/top_now_001.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;*/
}
section#section-home article#article-yumeshimanow div#yumeshimanow h2 {
	margin-bottom: 1em;
	color: var(--color-purple2);
}
section#section-home article#article-yumeshimanow div#yumeshimanow h2 span {
	color: var(--color-purple1);
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider {
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] {
	padding: 10px;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a {
	display: block;
	position: relative;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] p.image {
	padding: 0;
	background-color: var(--color-purple1);
	height: 0;
	overflow: hidden;
	padding-top: 100%;
	position: relative;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] p.image:after {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	height: 7em;
	content: "";
	background: linear-gradient(to bottom,  rgba(53,36,56,0) 0%,rgba(53,36,56,0.5) 100%);
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] p.image img {
	position: absolute;
	left: 10px;
	right: 10px;
	top: 10px;
	bottom: 10px;
	width: calc(100% - 20px);
	height: calc(100% - 20px);
	object-fit: cover;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info {
	position: absolute;
	left: 10px;
	bottom: 30px;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info h3 {
	background-color: var(--color-purple1);
	color: var(--color-white);
	font-weight: 500;
	display: inline-block;
	padding: 0.5em 1em;
	font-size: 1.1em;
	line-height: 1.3;
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info p.date,
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info p.caption {
	color: var(--color-white);
	margin: 0 0 0 1.1em;
	margin-top: 0.5em;
	line-height: 1.3;
	font-size: 0.86em;
	text-shadow: 0 0 3px var(--color-def);
}
section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info p.date:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "calendar_month";
	margin-right: 0.2em;
	line-height: 1;
	display: inline-block;
}
.slick-track {
	display: flex;
}
.slick-slide {
	height: auto !important;
}
ul.slick-dots {
	display: flex;
	justify-items: center;
	justify-content: center;
	align-items: center;
	margin-top: 0.5em;
}
ul.slick-dots {
	display: flex;
	justify-items: center;
	justify-content: center;
	align-items: center;
	gap: 10px;
}
ul.slick-dots li button {
	width: 14px;
	height: 0;
	padding: 0;
	padding-top: 14px;
	overflow: hidden;
	border-radius: 50%;
	background-color: var(--color-gray1);
}
ul.slick-dots li.slick-active button {
	background-color: var(--color-purple1);
}

section#section-home article#article-event {
	background-color: var(--color-gray1);
	padding: 0;
	z-index: 1;
}
section#section-home article#article-event div.main-container {
	display: flex;
	max-width: inherit;
	padding: 0 3vw;
}
section#section-home article#article-event div#event-navi {
	width: 300px;
	padding: 100px 50px 100px 0;
	display: flex;
	flex-direction: column;
}
section#section-home article#article-event div#event-navi h2 {
	text-align: left;
	flex-direction: column;
	line-height: 1.2;
	gap: 0.25em;
	margin-bottom: 1rem;
}
section#section-home article#article-event h2.sp-view {
	margin-bottom: 1rem;
}
section#section-home article#article-event div#event-navi ul {
	margin-top: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
}
section#section-home article#article-event div#event-navi ul > li button {
	width: 46px;
	height: 46px;
	border: 2px solid var(--color-def);
	background-color: var(--color-white);
	padding: 0;
	border-radius: 50%;
}
section#section-home article#article-event div#event-navi ol {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-top: 1em;
	font-family: var(--font-en);
}
section#section-home article#article-event div#event-navi ol > li {
}
section#section-home article#article-event div#event-navi ol > li:nth-child(1) {
	font-size: 1.4em;
	font-weight: 700;
}
section#section-home article#article-event div#event-navi ul > li button i {
	margin: 0;
	line-height: 1;
}
section#section-home article#article-event ul.eventlist {
	width: calc(100% - 300px);
	/*display: flex;
	flex-wrap: wrap;
	gap: 30px;*/
}
section#section-home article#article-event ul.eventlist button.slick-arrow {
	opacity: 0;
	position: absolute;
	left: 0;
	top: 0;
}
section#section-home article#article-event ul.eventlist div.slick-slide {
	padding: 100px 60px 50px 0;
	border-left: 1px solid var(--color-white);
}
section#section-home article#article-event ul.eventlist div.slick-slide a {
	display: block;
	position: relative;
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category] a:after {
	position: absolute;
	right: 10px;
	top: 10px;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	color: var(--color-white);
	background-color: var(--color-purple1);
	content: "";
	z-index: 1;
	font-size: 0.66rem;
	line-height: 70px;
	text-align: center;
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="文化・環境"] a:after {
	background-color: var(--color-purple1);
	content: "文化・環境";
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="産業"] a:after {
	background-color: var(--color-orange1);
	content: "産業";
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="観光"] a:after {
	background-color: var(--color-yellow1);
	content: "観光";
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="いのち"] a:after {
	background-color: var(--color-green1);
	content: "いのち";
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="その他"] a:after {
	background-color: var(--color-blue1);
	content: "その他";
}
section#section-home article#article-event ul.eventlist div.slick-slide p.image {
	box-shadow: 15px 15px 0 0 rgba(255, 255, 255, 1);
	margin-bottom: 30px;
	aspect-ratio: 5 / 3;
}
section#section-home article#article-event ul.eventlist div.slick-slide p.image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
section#section-home article#article-event ul.eventlist div.slick-slide h5 {
	display: inline;
	font-size: 1.2em;
	line-height: 1.7em;
	padding: 5px 10px 5px 15px;
	background: linear-gradient(transparent 0%, var(--color-purple1) 0%);
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	font-weight: 700;
	color: var(--color-white);
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="文化・環境"] h5 {
	background: linear-gradient(transparent 0%, var(--color-purple1) 0%);
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="産業"] h5 {
	background: linear-gradient(transparent 0%, var(--color-orange1) 0%);
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="観光"] h5 {
	background: linear-gradient(transparent 0%, var(--color-yellow1) 0%);
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="いのち"] h5 {
	background: linear-gradient(transparent 0%, var(--color-green1) 0%);
}
section#section-home article#article-event ul.eventlist div.slick-slide li[data-category="その他"] h5 {
	background: linear-gradient(transparent 0%, var(--color-blue1) 0%);
}
section#section-home article#article-event ul.eventlist li[data-preparation="1"] h5:before {
	content: "［準備中］";
}
section#section-home article#article-event ul.eventlist div.slick-slide p.date {
	color: var(--color-def);
	margin: 0 0 0 1.1em;
	margin-top: 1em;
	line-height: 1;
}
section#section-home article#article-event ul.eventlist div.slick-slide p.date:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "calendar_month";
	margin-right: 0.2em;
	line-height: 1;
	display: inline-block;
}
ul.eventlist ul.area {
	margin: 0.5em 0 0 1.1em;
	margin-top: 1em;
	line-height: 1;
	font-size: 0.76em;
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}
ul.eventlist ul.area > li {
	border: 1px solid var(--color-purple1);
	color: var(--color-purple1);
	padding: 0.5em;
	padding-bottom: 0.3em;
}
ul.eventlist ul.area > li:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "\e0c8";
	font-size: 1.2em;
	line-height: 1;
	display: inline-block;
	vertical-align: middle;
}

section#section-home article#article-report {
	background-color: var(--color-lgray1);
	position: relative;
}
section#section-home article#article-report h2 {
	margin-bottom: 1em;
}
section#section-home article#article-report ul.reportlist {
	display: flex;
	gap: 30px;
}
section#section-home article#article-report ul.reportlist > li {
	width: 100%;
}
section#section-home article#article-report ul.reportlist > li a {
	display: block;
	background-color: var(--color-white);
	padding: 15px;
	padding-left: 135px;
	position: relative;
	height: 100%;
	box-shadow: 10px 10px 0 0 var(--color-gray1);
}
section#section-home article#article-report ul.reportlist > li a p.image {
	position: absolute;
	left: 15px;
	top: 15px;
	bottom: 15px;
	width: 110px;
}
section#section-home article#article-report ul.reportlist > li a p.image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
section#section-home article#article-report ul.reportlist > li a h5 {
	color: var(--color-purple2);
	font-weight: bold;
	margin-bottom: 0.5em;
	line-height: 1.3;
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
section#section-home article#article-report ul.reportlist > li a:before {
	display: block;
	font-size: 0.76em;
}
section#section-home article#article-report ul.reportlist > li[data-category="culture"] a:before {
	color: var(--color-purple1);
	content: "文化・環境";
}
section#section-home article#article-report ul.reportlist > li[data-category="industry"] a:before {
	color: var(--color-orange1);
	content: "産業";
}
section#section-home article#article-report ul.reportlist > li[data-category="tourism"] a:before {
	color: var(--color-yellow1);
	content: "観光";
}
section#section-home article#article-report ul.reportlist > li[data-category="life"] a:before {
	color: var(--color-green1);
	content: "いのち";
}
section#section-home article#article-report ul.reportlist > li[data-category="other"] a:before {
	color: var(--color-blue1);
	content: "その他";
}
section#section-home article#article-report ul.reportlist > li a p.date:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "calendar_month";
	margin-right: 0.2em;
	line-height: 1;
	display: inline-block;
}
section#section-home article#article-report ul.reportlist > li a p.date {
	color: var(--color-def);
	margin-bottom: 0.5em;
	line-height: 1;
	font-size: 0.76em;
}
section#section-home article#article-report ul.reportlist ul.area {
	margin: 0;
	line-height: 1;
	font-size: 0.66em;
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}
section#section-home article#article-report ul.reportlist ul.area > li {
	border: 1px solid var(--color-def);
	color: var(--color-def);
	padding: 0.3em;
	padding-bottom: 0.2em;
}
section#section-home article#article-report ul.reportlist ul.area > li:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "\e0c8";
	font-size: 1.2em;
	line-height: 1;
	display: inline-block;
	vertical-align: middle;
	margin-top: -0.4em;
}

section#section-home article#article-pickup {
	position: relative;
	background-color: var(--color-purple1);
	color: var(--color-white);
}
/*section#section-home article#article-support:before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	background-color: rgba(255, 255, 255, 0.6);
	pointer-events: none;
}*/
section#section-home article#article-pickup h2 {
	color: var(--color-white);
	margin-bottom: 1em;
}
section#section-home article#article-pickup h2 strong {
	color: var(--color-white);
}
section#section-home article#article-pickup ul.eventlist {
	color: var(--color-white);
	display: flex;
	gap: 60px;
}
section#section-home article#article-pickup ul.eventlist > li {
	width: calc(50% - 30px);
}
section#section-home article#article-pickup ul.eventlist > li a {
	display: block;
	position: relative;
}
section#section-home article#article-pickup ul.eventlist > li a p.thumb {
	display: block;
	position: relative;
	aspect-ratio: 5 / 3;
	box-shadow: 15px 15px 0 0 var(--color-lpurple1);
}
section#section-home article#article-pickup ul.eventlist > li a p.thumb:before {
	background: linear-gradient(to bottom,  rgba(53,36,56,0) 0%,rgba(53,36,56,0.75) 70%,rgba(53,36,56,0.75) 100%);
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	mix-blend-mode: multiply;
}
section#section-home article#article-pickup ul.eventlist > li a p.thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
section#section-home article#article-pickup ul.eventlist > li a div.info {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	padding: 20px;
	color: var(--color-white);
}
section#section-home article#article-pickup ul.eventlist > li a div.info h5 {
	margin-left: -20px;
	font-size: 1.2em;
	font-weight: 700;
	display: inline;
	padding: 5px 10px 5px 15px;
	box-decoration-break: clone;
	color: var(--color-white);
}
section#section-home article#article-pickup ul.eventlist > li[data-category="文化・環境"] a div.info h5 {
	background-color: var(--color-purple1);
}
section#section-home article#article-pickup ul.eventlist > li[data-category="産業"] a div.info h5 {
	background-color: var(--color-orange1);
}
section#section-home article#article-pickup ul.eventlist > li[data-category="観光"] a div.info h5 {
	background-color: var(--color-yellow1);
}
section#section-home article#article-pickup ul.eventlist > li[data-category="いのち"] a div.info h5 {
	background-color: var(--color-green1);
}
section#section-home article#article-pickup ul.eventlist > li[data-category="その他"] a div.info h5 {
	background-color: var(--color-blue1);
}
section#section-home article#article-pickup ul.eventlist > li[data-preparation="1"] h5:before {
	content: "［準備中］";
}
section#section-home article#article-pickup ul.eventlist > li a div.info p.date {
	margin: 1em 0 0 0;
	line-height: 1;
}
section#section-home article#article-pickup ul.eventlist > li a div.info p.date:empty {
	display: none;
}
section#section-home article#article-pickup ul.eventlist > li a div.info p.date:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "calendar_month";
	margin-right: 0.2em;
	line-height: 1;
	display: inline-block;
}
section#section-home article#article-pickup ul.eventlist ul.area > li {
	border: 1px solid var(--color-white);
	color: var(--color-white);
}

/*section#section-home article#article-pickup ul#supportslider {
	display: flex;
	gap: 50px;
}
section#section-home article#article-support ul#supportslider > li {
	width: 100%;
}
section#section-home article#article-support ul#supportslider > li:nth-child(1) {
	margin-top: 1em;
}
section#section-home article#article-support ul#supportslider > li:nth-child(2) {
	margin-top: 4em;
}
section#section-home article#article-support ul#supportslider > li:nth-child(3) {
	margin-top: 6em;
}
section#section-home article#article-support ul#supportslider > li:nth-child(4) {
	margin-top: 0;
}
section#section-home article#article-support ul#supportslider > li a {
	display: block;
	position: relative;
}
section#section-home article#article-support ul#supportslider > li a:before {
	background-color: var(--color-lpurple1);
	position: absolute;
	left: 15px;
	right: -15px;
	top: 15px;
	bottom: -15px;
	content: "";
	background-image: url(../img/bg_dot_001.svg);
	background-size: 35px auto;
	opacity: 0.5;
}
section#section-home article#article-support ul#supportslider > li a p.image {
	height: 0;
	padding-top: 175%;
	overflow: hidden;
	position: relative;
}
section#section-home article#article-support ul#supportslider > li a p.image:after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(to bottom,  rgba(53,36,56,0) 0%,rgba(53,36,56,0.75) 100%);
	content: "";
	opacity: 0.5;
	height: 50%;
}
section#section-home article#article-support ul#supportslider > li a p.image img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	object-fit: cover;
}
section#section-home article#article-support ul#supportslider > li a p.caption {
	position: absolute;
	line-height: 1.6;
	bottom: 7em;
	left: 20px;
	right: 20px;
	color: var(--color-white);
	text-shadow: 0 0 3px var(--color-purple2);
}
section#section-home article#article-support ul#supportslider > li a h5 {
	position: absolute;
	bottom: 30px;
	left: 0;
	background-color: var(--color-white);
	color: var(--color-purple1);
	font-size: 1.4em;
	font-weight: 700;
	padding: 0.5em 20px;
	line-height: 1.3;
}
section#section-home article#article-support ul#supportslider > li a h5 strong {
	font-weight: 400;
	font-size: 0.86rem;
	display: block;
	color: var(--color-def);
}*/
/*section#section-home article#article-related {
	background-color: var(--color-lgray1);
}
section#section-home article#article-related ul {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	justify-content: center;
}
section#section-home article#article-related ul li {
	width: calc(25% - ((30px * 3) / 4));
}

article#article-sns ul#sns-titmeline {
	display: flex;
	gap: 60px;
}
article#article-sns ul#sns-titmeline > li {
	width: calc(50% - ((60px / 1) / 2));
}
.fb_iframe_widget {
	min-width: 100%;
}
.fb_iframe_widget span {
	min-width: 100%;
	min-height: 100%;
}*/
section#section-home article#article-relations {
	position: relative;
	padding: 70px 3vw;
}
section#section-home article#article-relations:before {
	background-color: var(--color-lgray1);
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 50vw;
	content: "";
}
section#section-home article#article-relations div.main-container {
	display: flex;
}
section#section-home article#article-relations div#related {
	width: 44%;
}
section#section-home article#article-relations div#related ul {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	justify-content: center;
}
section#section-home article#article-relations div#related ul + ul {
	margin-top: 30px;
}
section#section-home article#article-relations div#related ul.textlink a {
	border: 1px solid var(--color-lpurple1);
	color: var(--color-purple2);
	padding: 1em;
	line-height: 26px;
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
	line-height: 1.3;
	background-color: var(--color-white);
}
section#section-home article#article-relations div#related ul.textlink a:after {
	position: absolute;
	font-size: 0.66rem;
	right: 3px;
	top: 3px;
	line-height: 1;
}
section#section-home article#article-relations div#related ul li {
	width: calc(50% - ((15px / 1) / 2));
}
section#section-home article#article-relations div#sns {
	width: 44%;
	margin-left: auto;
}
section#section-home article#article-relations h2 {
	margin-bottom: 1em;
}
section#section-home article#article-relations div#sns div#snscnt {
	display: flex;
	gap: 40px;
}
section#section-home article#article-relations div#sns div#snscnt div#sns-facebook {
	width: 360px;
}
.fb_iframe_widget {
	min-width: 100%;
}
.fb_iframe_widget span {
	min-width: 100%;
	min-height: 100%;
}
section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk {
	width: calc(100% - (360px + 30px));
	display: flex;
	flex-direction: column;
	gap: 15px;
	line-height: 1;
}
section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk li a {
	border: 1px solid var(--color-lpurple1);
	color: var(--color-purple2);
	display: block;
	padding: 0.5em 1em;
	line-height: 26px;
	position: relative;
}
section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk li a:after {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "\e89e";
	position: absolute;
	width: 1em;
	height: 1em;
	font-size: 0.66rem;
	right: 5px;
	top: 5px;
	line-height: 1;
}
section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk li a img {
	width: 26px;
	height: 26px;
	object-fit: contain;
	display: inline-block;
	margin-right: 0.5em;
	vertical-align: middle;
}

section#section-home article#article-related {
	position: relative;
	padding: 70px 3vw;
}
section#section-home article#article-related h2 {
	margin-bottom: 1em;
}
section#section-home article#article-related div#related div#link {
	display: flex;
}
section#section-home article#article-related div#related ul {
	display: flex;
}
section#section-home article#article-related div#related ul.bannerlink {
	width: 38%;
	flex-wrap: wrap;
	gap: 10px;
}
section#section-home article#article-related div#related ul.bannerlink > li a:after {
	display: none;
}
section#section-home article#article-related div#related ul.textlink {
	width: 58%;
	margin-left: auto;
	flex-wrap: wrap;
	gap: 10px;
}
section#section-home article#article-related div#related ul.textlink > li {
	width: calc(33.333% - ((10px * 2) / 3));
}
section#section-home article#article-related div#related ul.textlink > li a {
	border: 1px solid var(--color-lpurple1);
	color: var(--color-purple2);
	padding: 1em;
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
	line-height: 1.3;
	background-color: var(--color-white);
}
section#section-home article#article-related div#related ul.textlink > li a:after {
	position: absolute;
	font-size: 0.66rem;
	right: 3px;
	top: 3px;
	line-height: 1;
}

article#article-sns {
	position: relative;
	padding: 70px 3vw;
	background-color: var(--color-lgray1);
}
article#article-sns h2 {
	margin-bottom: 1em;
}
article#article-sns div#snscnt {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
article#article-sns div#snscnt > div {
	width: calc(25% - ((20px * 3) / 4));
	max-height: 500px;
}
article#article-sns div#snscnt > div h3 {
	border-bottom: 2px solid var(--color-def);
	padding-bottom: 10px;
	font-weight: bold;
	font-size: 1.2em;
}
article#article-sns div#snscnt > div h3 img {
	height: 46px;
	width: auto;
	display: inline-block;
	vertical-align: middle;
}
article#article-sns div#snscnt > div#sns-instagram ul {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-top: 5px;
	max-height: calc(400px - 58px);
	overflow-y: auto;
}
article#article-sns div#snscnt > div#sns-instagram ul li {
	width: calc(33.333% - ((5px * 2) / 3));
}
article#article-sns div#snscnt > div#sns-instagram ul li a {
	display: block;
	position: relative;
}
article#article-sns div#snscnt > div#sns-instagram ul li a:after {
	position: absolute;
	right: 3px;
	top: 3px;
	margin: 0;
	background-color: var(--color-white);
}
article#article-sns div#snscnt > div#sns-instagram ul li a p.thumb {
	width: 100%;
	height: 0;
	padding-top: 100%;
	overflow: hidden;
	position: relative;
}
article#article-sns div#snscnt > div#sns-instagram ul li a p.thumb img {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	margin: auto;
	object-fit: cover;
}
article#article-sns div#snscnt > div#sns-instagram p {
	max-height: calc(400px - 58px);
	overflow-y: auto;
}
article#article-sns div#snscnt > ul#sns-lisk {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-items: center;
	gap: 20px;
}
article#article-sns div#snscnt > ul#sns-lisk > li {
	width: calc(25% - ((20px * 3) / 4));
}
article#article-sns div#snscnt > ul#sns-lisk > li a {
	border: 1px solid var(--color-lpurple1);
	color: var(--color-purple2);
	padding: 1em;
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
	line-height: 1.3;
	background-color: var(--color-white);
}
article#article-sns div#snscnt > ul#sns-lisk > li a:after {
	position: absolute;
	font-size: 0.66rem;
	right: 3px;
	top: 3px;
	line-height: 1;
}
article#article-sns div#snscnt > ul#sns-lisk > li a img {
	height: 36px;
	width: auto;
	display: inline-block;
	margin-right: 0.5em;
	vertical-align: middle;
}

section#section-home article#article-area {
	position: relative;
	padding: 0 3vw 70px 3vw;
	background-color: var(--color-gray1);
}
section#section-home article#article-area h2 {
	margin-bottom: 1em;
	font-size: 28px;
}
section#section-home article#article-area h2 strong {
	margin-top: 1em;
}
section#section-home article#article-area div#areamap {
	display: flex;
	align-items: center;
}
section#section-home article#article-area div#areamap div#map {
	width: 28%;
	position: relative;
}
section#section-home article#article-area div#areamap div#map div.svg-import {
}
section#section-home article#article-area div#areamap div#map p {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 50%;
}
section#section-home article#article-area div#areamap div#arealist {
	width: 68%;
	margin-left: auto;
}
section#section-home article#article-area div#areamap div#arealist ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
section#section-home article#article-area div#areamap div#arealist ul li {
	width: calc(33.333% - ((10px * 2) / 3));
}
section#section-home article#article-area div#areamap div#arealist ul li a {
	display: block;
	height: 100%;
	border: 1px solid var(--color-purple1);
	background-color: var(--color-white);
	padding: 1em;
	position: relative;
}
section#section-home article#article-area div#areamap div#arealist ul li a:after {
	content: "";
	color: var(--color-purple1);
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "\e409";
	width: 1em;
	height: 1em;
	line-height: 1;
	position: absolute;
	right: 0.5em;
	top: 0;
	bottom: 0;
	margin: auto;
}
section#section-home article#article-about {
	position: relative;
	padding: 70px 3vw;
	background-color: var(--color-def);
	color: var(--color-white);
}
section#section-home article#article-about h2 strong,
section#section-home article#article-about h2 {
	color: var(--color-white);
}

section#section-home article#article-apcy {
	background-color: var(--color-lgray1);
	padding: 70px 3vw;
}
section#section-home article#article-apcy h2 {
	margin-bottom: 1em;
}
section#section-home article#article-calendar {
	padding: 70px 3vw;
}
section#section-home article#article-calendar div.fc-view-harness {
	background-color: var(--color-white);
}


/*--------------------------------------------
■［イベント情報］
--------------------------------------------*/

section#section-event ul.eventlist {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	margin-bottom: 2em;
}
section#section-event ul.eventlist > li {
	width: calc(33.333% - ((40px * 2) / 3));
}
section#section-event ul.eventlist > li a {
	display: block;
	color: var(--color-def);
	height: 100%;
	padding: 20px;
	background-color: var(--color-lgray1);
	position: relative;
}
section#section-event ul.eventlist > li[data-pickup="1"][data-category="文化・環境"] a {
	background-color: var(--color-purple1);
	color: var(--color-white);
}
section#section-event ul.eventlist > li[data-pickup="1"][data-category="産業"] a {
	background-color: var(--color-orange1);
	color: var(--color-white);
}
section#section-event ul.eventlist > li[data-pickup="1"][data-category="観光"] a {
	background-color: var(--color-yellow1);
	color: var(--color-white);
}
section#section-event ul.eventlist > li[data-pickup="1"][data-category="いのち"] a {
	background-color: var(--color-green1);
	color: var(--color-white);
}
section#section-event ul.eventlist > li[data-pickup="1"][data-category="その他"] a {
	background-color: var(--color-blue1);
	color: var(--color-white);
}
ul.eventlist li[data-category] a:after {
	position: absolute;
	right: 10px;
	top: 10px;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	color: var(--color-white);
	background-color: var(--color-purple1);
	content: "";
	z-index: 1;
	font-size: 0.66rem;
	line-height: 70px;
	text-align: center;
}
ul.eventlist li[data-category="文化・環境"] a:after {
	background-color: var(--color-purple1);
	content: "文化・環境";
}
ul.eventlist li[data-category="産業"] a:after {
	background-color: var(--color-orange1);
	content: "産業";
}
ul.eventlist li[data-category="観光"] a:after {
	background-color: var(--color-yellow1);
	content: "観光";
}
ul.eventlist li[data-category="いのち"] a:after {
	background-color: var(--color-green1);
	content: "いのち";
}
ul.eventlist li[data-category="その他"] a:after {
	background-color: var(--color-blue1);
	content: "その他";
}


section#section-event ul.eventlist > li a p.thumb {
	aspect-ratio: 6 / 4;
	margin: -20px;
	margin-bottom: 1em;
}
section#section-event ul.eventlist > li a p.thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
section#section-event ul.eventlist > li a h5 {
	font-size: 1.1em;
	font-weight: 700;
	margin-bottom: 0.5em;
	color: var(--color-purple2);
}
section#section-event ul.eventlist > li[data-preparation="1"] a h5:before {
	content: "［準備中］";
}
section#section-event ul.eventlist > li a p.copy {
	color: var(--color-purple1);
	margin-bottom: 1em;
	font-size: 0.86em;
}
section#section-event ul.eventlist > li[data-pickup="1"] a h5,
section#section-event ul.eventlist > li[data-pickup="1"] a p.copy {
	color: var(--color-white);
}
section#section-event ul.eventlist > li a dl.spec {
	display: flex;
	gap: 5px;
	flex-wrap: wrap;
	align-items: flex-start;
	font-size: 0.76em;
	line-height: 1.3;
	
}
section#section-event ul.eventlist > li a dl.spec dt {
	background-color: var(--color-mute);
	color: var(--color-white);
	width: 6em;
	padding: 0.3em;
	padding-bottom: 0.4em;
	text-align: center;
	border-radius: 1.5em;
}
section#section-event ul.eventlist > li a dl.spec dt + dd {
	width: calc(100% - (6em + 5px));
	padding-top: 0.3em;
}
h4.accordion {
	font-size: 1.2em;
	font-weight: bold;
	color: var(--color-purple2);
	padding: 0.5em;
	background-color: var(--color-purple1);
	color: var(--color-white);
	border-radius: 0.2em;
}
h4.accordion.active {
	background-color: var(--color-purple2);
	border-radius: 0.2em 0.2em 0 0;
}
dl#filter {
	margin-bottom: 2em;
	display: flex;
	flex-wrap: wrap;
	padding: 10px;
	background-color: var(--color-lgray1);
	border-radius: 0 0 0.2em 0.2em;
}
dl#filter > dt {
	width: 10em;
	padding: 1em;
	border-radius: 0.3em 0 0 0.3em;
	background-color: var(--color-purple1);
	color: var(--color-white);
	text-align: center;
	margin-bottom: 5px;
}
dl#filter > dt + dd {
	width: calc(100% - 10em);
	padding: 1em;
	border-radius: 0 0.3em 0.3em 0;
	border: 1px solid var(--color-purple1);
	background-color: var(--color-white);
	margin-bottom: 5px;
}
dl#filter ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25em 1em;
}
/*dl#filter ul input[name="organizer"][value="all"]:checked + span,
dl#filter ul input[name="category"][value="all"]:checked + span {
	color: var(--color-def);
}
dl#filter ul input[name="category"][value="文化・環境"]:checked + span {
	color: var(--color-orange1);
}
dl#filter ul input[name="category"][value="産業"]:checked + span {
	color: var(--color-yellow1);
}
dl#filter ul input[name="category"][value="観光"]:checked + span {
	color: var(--color-green1);
}
dl#filter ul input[name="category"][value="万博京都ブース"]:checked + span {
	color: var(--color-purple1);
}*/
/*dl#filter ul input[name="category"][value="new"]:checked + span {
	color: var(--color-lpurple1);
}*/
section#section-event article#article-eventdetail ul.slider .slick-slide img {
	display: block;
	width: 100%;
}
section#section-event article#article-eventdetail div#info h3 {
	font-size: 1.8em;
	text-align: left;
	margin: 0 0 0.5em 0;
	font-weight: bold;
	color: var(--color-purple2);
	padding-bottom: 1em;
	border-bottom: 3px solid var(--color-purple1);
}
div.main-container h3 + ul.spec {
	display: flex;
	gap: 1em;
	margin-bottom: 2em;
	font-size: 0.86em;
	margin-bottom: 2em;
	flex-wrap: wrap;
}
div.main-container h3 + ul.spec li.date {
	margin-left: auto;
	color: var(--color-mute);
}
div.main-container h3 + ul.spec li.area:before,
div.main-container h3 + ul.spec li.type:before,
div.main-container h3 + ul.spec li.frame:before,
div.main-container h3 + ul.spec li.date:before,
div.main-container h3 + ul.spec li.organizer:before,
div.main-container h3 + ul.spec li.category span:before {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	display: inline-block;
	margin-right: 0.2em;
	font-size: 1.2em;
	line-height: 1;
	vertical-align: middle;
	margin-top: -0.2em;
}
div.main-container h3 + ul.spec li.category span:before {
	content: "\e2c7";
}
div.main-container h3 + ul.spec li.organizer:before {
	content: "\e0af";
}
div.main-container h3 + ul.spec li.date:before {
	content: "\ebcc";
}
div.main-container h3 + ul.spec li.frame:before {
	content: "\e5c3";
}
div.main-container h3 + ul.spec li.type:before {
	content: "\e1bd";
}
div.main-container h3 + ul.spec li.area:before {
	content: "\e0c8";
}
div.main-container h3 + ul.spec li.category span.culture {
	color: var(--color-purple1);
}
div.main-container h3 + ul.spec li.category span.industry {
	color: var(--color-orange1);
}
div.main-container h3 + ul.spec li.category span.tourism {
	color: var(--color-yellow1);
}
div.main-container h3 + ul.spec li.category span.life {
	color: var(--color-green1);
}
div.main-container h3 + ul.spec li.category span.other {
	color: var(--color-blue1);
}
div.main-container h3 + ul.spec li.category span.new {
	color: var(--color-purple2);
}
section#section-event article#article-eventdetail div#info h4 {
	font-size: 1.2em;
	color: var(--color-purple1);
	font-weight: 700;
	margin-bottom: 2em;
}
section#section-home article#article-sns,
section#section-home article#article-related {
	padding: 5vw 3vw;
}

section#section-event article#article-eventdetail div#report h4 {
	font-size: 1.3em;
	color: var(--color-purple2);
	font-weight: 700;
	margin-bottom: 1em;
	background-color: var(--color-lgray1);
	padding: 0.5em;
	border-radius: 0.2em;
}
section#section-event article#article-eventdetail div#report h4 i {
	vertical-align: middle;
	line-height: 1;
	margin-top: -0.4em;
}

/*--------------------------------------------
■［イベントカレンダー］
--------------------------------------------*/


/*--------------------------------------------
■［新着情報］
--------------------------------------------*/
section#section-news article#article-newsdetail h3 {
	font-size: 1.4em;
	text-align: left;
	margin: 0 0 0.5em 0;
	font-weight: bold;
	color: var(--color-purple2);
	padding-bottom: 1em;
	border-bottom: 3px solid var(--color-purple1);
}

/*--------------------------------------------
■［関連サイト］
--------------------------------------------*/
section#section-link article h3 {
	font-size: 1.4em;
	text-align: left;
	margin: 0 0 0.5em 0;
	font-weight: bold;
	color: var(--color-purple2);
	padding-bottom: 1em;
	border-bottom: 3px solid var(--color-purple1);
}
section#section-link ul.linklist {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}
section#section-link ul.linklist > li {
	width: calc(33.333% - ((20px * 2) / 3));
}
section#section-link ul.linklist > li a {
	border: 1px solid var(--color-lpurple1);
	color: var(--color-purple2);
	padding: 1em;
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
	line-height: 1.3;
	background-color: var(--color-white);
}
section#section-link ul.linklist > li a::after {
	position: absolute;
	font-size: 0.66rem;
	right: 3px;
	top: 3px;
	line-height: 1;
}
section#section-link ul.linklist > li a[href^="http"]::after {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	content: "open_in_new";
	font-size: 0.68em;
	vertical-align: super;
	line-height: 1;
	margin: 0 0.2em;
	color: var(--color-purple1);
	text-decoration: none !important;
}


/*--------------------------------------------
■［認証事業］
--------------------------------------------*/
section#section-grouplist ul.grouplist {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
}
section#section-grouplist ul.grouplist > li {
	width: calc(50% - ((40px * 1) / 2));
	display: flex;
}
section#section-grouplist ul.grouplist > li p.thumb {
	width: 180px;
}
section#section-grouplist ul.grouplist > li p.thumb img {
	width: 100%;
	height: 180px;
	object-fit: cover;
}
section#section-grouplist ul.grouplist > li p.thumb span {
	display: block;
}
section#section-grouplist ul.grouplist > li p.thumb span sub {
	font-size: 0.86em;
	display: block;
}
section#section-grouplist ul.grouplist > li div {
	width: calc(100% - 180px);
	margin-left: 25px;
}
section#section-grouplist ul.grouplist > li div h5 {
	margin-bottom: 0.5em;
	border-bottom: 2px solid var(--color-purple2);
	line-height: 1.4;
}
section#section-grouplist ul.grouplist > li div h5 span,
section#section-grouplist ul.grouplist > li div h5 a {
	display: flex;
	gap: 10px;
	align-items: center;
	min-height: 60px;
}
section#section-grouplist ul.grouplist > li div h5 strong {
	font-weight: 700;
	font-size: 1.2em;
}
section#section-grouplist ul.grouplist > li div h5 img {
	width: 60px;
	height: 60px;
	object-fit: contain;
}
section#section-grouplist ul.grouplist > li div p.message {
	/*display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 5;
	overflow: hidden;
	position: relative;*/
	line-height: 1.5;
}
/*section#section-grouplist ul.grouplist > li div p.message.show {
	-webkit-line-clamp: inherit;
	overflow: visible;
}
section#section-grouplist ul.grouplist > li div p.message.overflow:after {
	content: "";
	background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
	height: 2em;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
}
section#section-grouplist ul.grouplist > li div p.more {
	text-align: right;
	margin-top: 0.5em;
	display: none;
}
section#section-grouplist ul.grouplist > li div p.message.overflow + p.more {
	display: block;
}
section#section-grouplist ul.grouplist > li div p.more button {
	padding: 0.5em 1em;
}*/



/*--------------------------------------------
■［認証申請］
--------------------------------------------*/
article#article-form h4 {
	font-size: 1.4em;
	font-weight: bold;
	padding-bottom: 0.5em;
	margin: 2.5em 0 1.5em 0;
	color: var(--color-purple2);
	border-bottom: 2px solid var(--color-purple1);
}
article#article-form dd p {
	position: relative;
}
article#article-form dd p input[type="file"] + button[name="clear"] {
	position: absolute;
	right: 0;
	top: 0.2em;
	color: var(--color-mute);
}



/*--------------------------------------------
■［レスポンシブ］
--------------------------------------------*/

@media screen and (max-width: 1104px) {
	section#section-home article#article-event {
		padding: 5vw 3vw;
	}
	section#section-home article#article-event div#event-navi h2 {
		display: none !important;
	}
	section#section-home article#article-event div#eventreport >  h2 {
		display: block !important;
		margin-bottom: 1em;
	}
	section#section-home article#article-event > h2 {
		text-align: center;
		display: block !important;
	}
	section#section-home article#article-event div.main-container {
		flex-direction: column-reverse;
	}
	section#section-home article#article-event div#event-navi {
		width: auto;
		padding: 0;
		display: flex;
		flex-direction: column;
	}
	section#section-home article#article-event div.main-container > h2 strong {
		font-family: var(--font-ja);
		color: var(--color-purple2);
		font-weight: 500;
		display: block;
		font-size: 1rem;
		line-height: 1;
	}
	section#section-home article#article-event ul.eventlist {
		width: 100%;
	}
	section#section-home article#article-event ul.eventlist div.slick-slide {
		padding: 30px 3vw 30px 0;
	}
	section#section-home article#article-event ul.eventlist div.slick-slide p.image {
		box-shadow: 1.5vw 1.5vw 0 0 rgba(255, 255, 255, 1);
	}
	section#section-home article#article-report div#report ul.reportlist > li:nth-child(3) {
		display: none;
	}
	section#section-home article#article-support ul#supportslider > li a p.caption {
		display: none;
	}
	section#section-home article#article-relations div#sns div#snscnt {
		display: flex;
		gap: 3vw;
		flex-direction: column;
	}
	section#section-home article#article-relations div#sns div#snscnt div#sns-facebook {
		margin: 0 auto;
	}
	section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		flex-direction: row;
		gap: 10px;
	}
	section#section-home article#article-relations div#sns div#snscnt ul#sns-lisk li {
		width: calc(50% - 5px);
	}
	section#section-home article#article-related div#related div#link {
		display: block;
	}
	section#section-home article#article-related div#related ul.bannerlink {
		width: auto;
		margin-bottom: 1.5em;
	}
	section#section-home article#article-related div#related ul.textlink {
		width: auto;
	}

	/*--------------------------------------------
	■［イベント情報］
	--------------------------------------------*/
	h4.accordion {
		margin-top: 0;
	}
	section#section-event ul.eventlist > li {
		width: calc(50% - ((40px * 1) / 2));
	}
}

@media screen and (max-width: 810px) {
	section#section-home article#article-mainvisual div.slick-slide > div > li {
		padding-top: 94vw;
	}
	section#section-home article#article-newsandcalendar {
		padding-top: 10vw;
		padding-bottom: 10vw;
	}
	section#section-home article#article-newsandcalendar div.main-container {
		flex-direction: column;
		gap: 5vw;
	}
	section#section-home article#article-newsandcalendar div.main-container > div {
		padding: 5vw;
	}
	section#section-home article#article-newsandcalendar div.main-container > div#calendar,
	section#section-home article#article-newsandcalendar div.main-container > div#news {
		width: 100%;
	}
	.fc .fc-button {
		padding: .3em .5em;
	}
	.fc-direction-ltr .fc-toolbar > * > :not(:first-child) {
		margin-left: .3em;
	}
	.fc table {
		font-size: 2.6vw;
		line-height: 1;
	}
	section#section-home article#article-yumeshimanow div#yumeshimanow {
		padding: 5vw 3vw;
	}
	section#section-home article#article-report div#report ul.reportlist {
		flex-direction: column;
	}
	section#section-home article#article-report div#report ul.reportlist > li:nth-child(3) {
		display: inherit;
	}
	section#section-home article#article-support {
		padding: 5vw 3vw;
	}
	section#section-home article#article-support ul#supportslider {
		gap: 30px;
	}
	section#section-home article#article-support ul#supportslider > li a h5 {
		font-size: 1.1em;
	}
	section#section-home article#article-support ul#supportslider > li a h5 strong {
		font-size: 0.76rem;
	}
	section#section-home article#article-relations {
		padding: 0;
	}
	section#section-home article#article-relations:before {
		display: none;
	}
	section#section-home article#article-relations div.main-container {
		flex-direction: column;
	}
	section#section-home article#article-relations div#related,
	section#section-home article#article-relations div#sns {
		width: 100%;
		padding: 5vw 3vw;
	}
	section#section-home article#article-relations div#related {
		background-color: var(--color-lgray1);
	}
	section#section-home article#article-relations div#related ul {
		gap: 10px;
	}
	section#section-home article#article-relations div#related ul li {
		width: calc(50% - ((10px / 1) / 2));
	}
	article#article-sns div#sns {
		padding: 5vw 3vw;
	}
	article#article-sns div#sns h2 {
		margin-bottom: 1em;
	}
	article#article-sns div#snscnt {
		flex-direction: column;
	}
	article#article-sns div#snscnt > div:not(#sns-instagram) {
		width: auto;
		overflow-y: auto;
		max-height: 100vw;
	}
	article#article-sns div#snscnt > div#sns-instagram {
		width: 100%;
		display: block;
	}
	article#article-sns div#snscnt > ul#sns-lisk {
		gap: 10px;
	}
	article#article-sns div#snscnt > ul#sns-lisk > li {
		width: calc(50% - ((10px * 1) / 2));
	}
	section#section-home article#article-pickup ul.eventlist {
		flex-direction: column;
		gap: 30px;
	}
	section#section-home article#article-pickup ul.eventlist > li {
		width: 100%;
	}
	section#section-home article#article-area {
		padding:  5vw 3vw;
	}
	section#section-home article#article-area div#areamap {
		flex-direction: column-reverse;
		gap: 20px;
	}
	section#section-home article#article-area div#areamap div#arealist,
	section#section-home article#article-area div#areamap div#map {
		width: 100%;
	}
	section#section-home article#article-about,
	section#section-home article#article-calendar,
	section#section-home article#article-apcy {
		padding: 5vw 3vw;
	}
	
}
@media screen and (max-width: 767px) {

	/*--------------------------------------------
	■［HOME］
	--------------------------------------------*/
	body.home div#splash div#counter h5 {
		font-size: 4vw;
	}
	body.home div#splash div#counter h5 img {
		max-height: 16vw;
	}
	body.home div#splash div#counter p {
		font-size: 17vw;
	}

	section#section-home article#article-mainvisual div#mainvisual-counter {
		width: 30vw;
		height: 30vw;
	}
	section#section-home article#article-mainvisual div#mainvisual-counter h5 {
		font-size: 2vw;
		gap: 5px;
	}
	section#section-home article#article-mainvisual div#mainvisual-counter p {
		font-size: 7vw;
	}
	section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider {
		display: block;
	}
	section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] {
		width: 100%;
	}
	section#section-home article#article-yumeshimanow div#yumeshimanow ul.slider li[data-category] a div.info p.caption {
		display: none;
	}
	section#section-home article#article-support ul#supportslider {
		gap: 30px;
		flex-wrap: wrap;
	}
	section#section-home article#article-support ul#supportslider > li {
		width: calc(50% - 15px);
	}
	section#section-home article#article-support ul#supportslider > li:nth-child(1),
	section#section-home article#article-support ul#supportslider > li:nth-child(2),
	section#section-home article#article-support ul#supportslider > li:nth-child(3),
	section#section-home article#article-support ul#supportslider > li:nth-child(4) {
		margin-top: 0;
	}
	section#section-home article#article-support ul#supportslider > li a:before {
		left: 10px;
		right: -10px;
		top: 10px;
		bottom: -10px;
	}
	section#section-home article#article-support ul#supportslider > li a p.image {
		padding-top: 125%;
	}
	section#section-home article#article-support ul#supportslider > li a p.image img {
		object-position: center top;
	}
	section#section-home article#article-related div#related ul.textlink > li {
		width: calc(50% - ((10px * 1) / 2));
	}



	/*--------------------------------------------
	■［イベント情報］
	--------------------------------------------*/
	section#section-event article#article-eventdetail div#info h3 {
		font-size: 1.3em;
	}
	section#section-event article#article-eventdetail div#info h4 {
		font-size: 1.1em;
	}
	dl#filter > dt {
		width: 100%;
		padding: 3vw;
		border-radius: 0.3em 0.3em 0 0;
		margin-bottom: 0;
	}
	dl#filter > dt + dd {
		width: 100%;
		border-radius: 0 0 0.3em 0.3em;
		padding: 3vw;
		margin-bottom: 5px;
	}
	section#section-event ul.eventlist {
		flex-direction: column;
	}
	section#section-event ul.eventlist > li {
		width: 100%;
	}
	dl#filter ul {
		gap: 0.25em 0.5em;
	}

	/*--------------------------------------------
	■［新着情報］
	--------------------------------------------*/
	ul.newslist {
		gap: 1.5em;
	}
	ul.newslist > li {
		flex-direction: column;
		gap: 0.5em;
	}
	ul.newslist > li h5 {
		width: auto;
	}
	ul.newslist > li p {
		width: auto;
		padding: 0;
	}

	/*--------------------------------------------
	■［関連サイト］
	--------------------------------------------*/
	section#section-link ul.linklist {
		flex-direction: column;
		gap: 10px;
	}
	section#section-link ul.linklist > li {
		width: 100%;
	}
	article#article-sns {
		padding: 0;
	}


	/*--------------------------------------------
	■［認証事業］
	--------------------------------------------*/
	section#section-grouplist ul.grouplist {
		flex-direction: column;
	}
	section#section-grouplist ul.grouplist > li {
		width: 100%;
	}
	section#section-grouplist ul.grouplist > li p.thumb {
		width: 120px;
	}
	section#section-grouplist ul.grouplist > li p.thumb img {
		height: 120px;
	}
	section#section-grouplist ul.grouplist > li div {
		width: calc(100% - 120px);
		margin-left: 3vw;
	}
	section#section-grouplist ul.grouplist > li div h5 span,
	section#section-grouplist ul.grouplist > li div h5 a {
		min-height: 50px;
	}
	section#section-grouplist ul.grouplist > li div h5 img {
		width: 50px;
		height: 50px;
	}

}