@charset "utf-8";

:where(#mainvisual, #main, #mainvisual *, #main *) {
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	letter-spacing: 0;
	line-height: 1;
}
:where(#mainvisual :is(h1, h2, h3, h4, h5, h6, p, dl, dd), #main :is(h1, h2, h3, h4, h5, h6, p, dl, dd)) {
	margin: 0;
}
:where(#mainvisual :is(ul, ol), #main :is(ul, ol)) {
	list-style: none;
	padding: 0;
	margin: 0;
}
:where(#mainvisual img, #main img) {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
:where(#mainvisual button, #main button) {
	text-align: left;
	padding: 0;
	margin: 0;
	border: none;
	background: none;
}

/* トップページ */
:root {
	scroll-padding-top: var(--floating-header-height);
}

.tpl_top_index #mymainback {
	display: block;
	width: auto;
	padding: 0;
	margin: 0;
}

/* 非表示 */
.tpl_top_index #footstep_wrap {
	display: none !important;
}

/* ----------------------------------------
メインロゴ
---------------------------------------- */
#mainlogo {
	position: absolute;
	top: 0;
	right: calc(50% + 363px);
	z-index: 2;
	width: 100vw;
	min-width: var(--content-width);
	height: 707px;
	background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(transparent));
	background: linear-gradient(to bottom, #fff, transparent);
}
#mainlogo img {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	margin: 104px 53px 0 auto;
}

/* -----------------------------------------
メインビジュアル
----------------------------------------- */
#mainvisual {
	position: relative;
	min-height: calc(720px + 240px);
	padding: 0 0 240px;
	background: #f6f6f6;
	margin: 0 0 calc(-240px - 138px);
}
#mainvisual + #mymainback_bg,
#mainvisual + #mymainback {
	position: relative;
	z-index: 10;
}
#mainvisual::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100px;
	background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(transparent));
	background: linear-gradient(to bottom, #fff, transparent);
}
#top_photo_wrap {
	-webkit-mask-image:	-webkit-gradient(linear, left top, left bottom, from(#f6f6f6), to(#f6f6f6)), url(/img/top/mask.png);
	-webkit-mask-image:	linear-gradient(#f6f6f6, #f6f6f6), url(/img/top/mask.png);
	        mask-image:	-webkit-gradient(linear, left top, left bottom, from(#f6f6f6), to(#f6f6f6)), url(/img/top/mask.png);
	        mask-image:	linear-gradient(#f6f6f6, #f6f6f6), url(/img/top/mask.png);
	-webkit-mask-position: center top, center bottom;
	        mask-position: center top, center bottom;
	-webkit-mask-size: 100% calc(100% - 70px), 2000px 70px;
	        mask-size: 100% calc(100% - 70px), 2000px 70px;
	-webkit-mask-repeat: no-repeat;
	        mask-repeat: no-repeat;
}
#top_photo {
	position: relative;
}
#top_photo_control {
	position: absolute;
	bottom: 186px;
	right: calc(50% - var(--content-width) / 2);
	z-index: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 18px;
}

.photo_box {
	display: block;
	max-width: 2000px;
	height: 720px;
	margin: 0 auto;
}
.photo_box img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	   object-fit: cover;
}

/* ----------------------------------------
スライドパーツ
---------------------------------------- */
button[class^="slide_control_"] {
	display: inline-block;
	width: 30px;
	height: 30px;
	padding: 0;
	border: none;
	margin: 0;
	border-radius: 100%;
	background: rgb(255 255 255 / .8);
	background-repeat: no-repeat;
	background-position: center;
	background-size: 9px 14px;
}
button.slide_control_prev,
button.slide_control_next {
	background-image: url(/img/top/slide_arrow.png);
}
button.slide_control_prev {
	rotate: 180deg;
}
button.slide_control_stop.is-active,
button.slide_control_play.is-active {
	display: none;
}
button.slide_control_stop {
	background-image: url(/img/top/slide_stop.png);
}
button.slide_control_play {
	background-image: url(/img/top/slide_start.png);
	background-size: 12px 13px;
	background-color: #96f088;
}

/* ----------------------------------------
レイアウト
---------------------------------------- */
.ly_section > [class*="top_"] {
	max-width: var(--content-width);
	margin-inline: auto;
}

/* info */
.ly_section.ly_section__info {
	padding-top: 0;
	padding-bottom: 60px;
}
.ly_section.ly_section__info > .top_bousai {
	margin-bottom: 60px;
}
.ly_section.ly_section__info > .top_bousai:has(.emer_title_open) {
	margin-bottom: 0;
}

/* news */
.ly_section.ly_section__news {
	position: relative;
	padding-top: 0;
	padding-bottom: 60px;
	overflow-x: hidden;
}
.ly_section.ly_section__news > .ly_news {
	position: relative;
	z-index: 1;
	max-width: var(--content-width);
	margin-inline: auto;
}
.ly_section.ly_section__news > .ly_news_bg {
	position: absolute;
	top: 0;
	z-index: 0;
	width: 187px;
	height: 100%;
	background-repeat: no-repeat;
	background-position-y: top;
	background-size: 100% auto;
}
.ly_section.ly_section__news > .ly_news_bg.ly_news_bg__1 {
	right: calc(50% + 503px);
	background-position-x: right;
}
.ly_section.ly_section__news > .ly_news_bg.ly_news_bg__2 {
	left: calc(50% + 503px);
	background-position-x: left;
}
.ly_news {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 60px 40px;
}
.ly_news > .top_topics {
	width: 100%;
}
.ly_news > .top_news {
	width: calc(100% / 2 - 40px / 2);
}

/* search */
.ly_section.ly_section__search {
	padding-block: 60px;
	background-color: #e1fadd;
}

/* about */
.ly_section.ly_section__about {
	position: relative;
	padding-top: 38px;
	padding-bottom: 60px;
	min-height: 1469px;
}
.ly_section.ly_section__about > .ly_about {
	position: relative;
	z-index: 1;
	max-width: var(--content-width);
	margin-inline: auto;
}
.ly_section.ly_section__about > .ly_about_bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: auto;
}
.ly_section.ly_section__about> .ly_about_bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, #fff calc(100% - 1171px), transparent calc(100% - 40px));
}
.ly_about {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 1fr 40px 1fr;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
}
.ly_about > .top_ttl {
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column: 1 / 3;
	margin-bottom: 5px;
}
.ly_about > .top_card {
	-ms-grid-column: 1;
	-ms-grid-column-span: 1;
	grid-column: 1 / 2;
}
.ly_about > .top_jinkou {
	-ms-grid-column: 1;
	-ms-grid-column-span: 1;
	grid-column: 1 / 2;
	padding: 27px 39px;
	border: 1px solid #d8d8d8;
	border-radius: 10px;
	background-color: #fff;
}
.ly_about > .top_koho {
	-ms-grid-column: 2;
	-ms-grid-column-span: 1;
	grid-column: 2 / 3;
	-ms-grid-row: 2;
	-ms-grid-row-span: 2;
	grid-row: 2 / 4;
	padding: 55px 39px 30px;
	border: 1px solid #d8d8d8;
	border-radius: 10px;
	background-color: #fff;
}
.ly_about > .top_sns {
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column: 1 / 3;
	padding: 39px;
	border: 1px solid #d8d8d8;
	border-radius: 10px;
	background-color: #fff;
}
.ly_about > .top_link {
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column: 1 / 3;
	padding: 37px 39px;
	border: 1px solid #d8d8d8;
	border-radius: 10px;
	background-color: rgb(255 255 255 / .9);
}
.ly_about > .top_pr {
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column: 1 / 3;
	padding: 40px;
	border-radius: 10px;
	background-color: rgb(225 250 221 / .9);
}

/* banner */
.ly_section.ly_section__banner {
	padding-block: 50px;
}

/* ----------------------------------------
防災無線放送
---------------------------------------- */
.top_bousai_container {
	padding: 30px 40px;
	outline: 3px solid #ff9600;
	outline-offset: -3px;
	border-radius: 10px;
	background: rgb(255 255 255 / .9);
}
.top_bousai_ttl {
	color: #9a6d00;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .1em;
	padding: 8px 0 8px calc(40px + 12px);
	background: url(/img/top/icon_emergency.png) no-repeat left top / 40px 40px;
	margin: 0 0 25px;
}
.top_bousai_list ul {
	padding: 0 10px;
}
.top_bousai_list ul li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	gap: 35px;
}
.top_bousai_list ul li + li {
	margin-top: 10px;
}
.top_bousai_list ul li span[class^="emer_"] {
	display: block;
	line-height: 2.8rem;
}
.top_bousai_list ul li span.emer_date {
	width: 12em;
	font-size: 1.6rem;
}
.top_bousai_list ul li span.emer_title {
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
	font-size: 1.8rem;
	letter-spacing: .05em;
	overflow: hidden;
	height: 2.8rem;
}
.top_bousai_list ul li.emer_title_open span.emer_title {
	height: auto;
}
.top_bousai_list ul li span.emer_title[tabindex] {
	cursor: pointer;
	text-decoration: underline;
}
.top_bousai_list ul li.emer_title_open span.emer_title[tabindex],
.top_bousai_list ul li span.emer_title[tabindex]:hover {
	text-decoration: none;
}
.top_bousai_btn {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 30px;
	margin: 25px 0 0;
}
button.top_bousai_cls,
button.top_bousai_all {
	font-size: 1.6rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 15px;
}
button.top_bousai_cls::after,
button.top_bousai_all::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 1px solid #ff9600;
	border-radius: 100%;
	background: url(/img/common/arrow_yellow.png) no-repeat center / 7px 10px #fff;
	margin: 0 0 0 auto;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
button.top_bousai_cls {
	display: none;
}

/* モーダル */
.top_bousai:has(li.emer_title_open) {
	position: fixed;
	inset: 0;
	z-index: 100;
	width: auto;
	height: auto;
	max-width: none;
	max-height: none;
	background: rgb(0 0 0 / .75);
	overflow: auto;
	-ms-scroll-chaining: none;
	    overscroll-behavior: none;
	-ms-overflow-style: none;
	scrollbar-width: none;
}
.top_bousai:has(li.emer_title_open)::-webkit-scrollbar {
	display: none;
}
.top_bousai:has(li.emer_title_open) .top_bousai_container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	width: 100%;
	height: calc(100vh + 1px);
	height: calc(100dvh + 1px);
	padding: 0;
	border: none;
	outline: none;
	margin: 0;
	background: none;
}
.top_bousai:has(li.emer_title_open) .top_bousai_ttl {
	display: none;
}
.top_bousai:has(li.emer_title_open) .top_bousai_list {
	width: 100%;
	max-width: var(--content-width);
	margin: auto;
	padding: 38px;
	border: 2px solid #ff9600;
	border-radius: 10px;
	background-color: #fff;
}
.top_bousai:has(li.emer_title_open) .top_bousai_list ul li:not(.emer_title_open) {
	display: none;
}
.top_bousai:has(li.emer_title_open) .top_bousai_list ul li.emer_title_open {
	pointer-events: none;
}
.top_bousai:has(li.emer_title_open) button.top_bousai_cls {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.top_bousai:not(:has(li:not(.emer_title_open))) button.top_bousai_all {
	display: none;
}

/* ----------------------------------------
トップページ ナビ
---------------------------------------- */
.top_navi .gnav {
	padding: 27px 0 17px;
	border-radius: 30px;
	background-color: rgb(255 255 255 / .9);
	margin: 0 0 10px;
}
.top_navi .gnav_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
}
.top_navi .gnav_i {
	width: 100%;
}
.top_navi .gnav_i + .gnav_i {
	background: -webkit-gradient(linear, left top, left bottom, from(#c9c8c8), to(#c9c8c8)) no-repeat top 35px left / 1px 30px;
	background: linear-gradient(to bottom, #c9c8c8, #c9c8c8) no-repeat top 35px left / 1px 30px;
}
.top_navi .gnav_i a {
	position: relative;
	color: inherit;
	text-decoration: none;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2rem;
	letter-spacing: .05em;
	text-align: center;
	display: block;
	padding: 0 0 calc(9px + 3px);
}
.top_navi .gnav_i a::before {
	content: "";
	display: block;
	width: 74px;
	height: 74px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	margin: 0 auto 15px;
}
.top_navi .gnav_i.gnav_i__1 a::before {
	background-image: url(/img/common/icon_gnav01.png);
}
.top_navi .gnav_i.gnav_i__2 a::before {
	background-image: url(/img/common/icon_gnav02.png);
}
.top_navi .gnav_i.gnav_i__3 a::before {
	background-image: url(/img/common/icon_gnav03.png);
}
.top_navi .gnav_i.gnav_i__4 a::before {
	background-image: url(/img/common/icon_gnav04.png);
}
.top_navi .gnav_i.gnav_i__5 a::before {
	background-image: url(/img/common/icon_gnav05.png);
}
.top_navi .gnav_i.gnav_i__6 a::before {
	background-image: url(/img/common/icon_gnav06.png);
}
.top_navi .gnav_i a::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 20px;
	display: block;
	width: calc(100% - 20px * 2);
	height: 3px;
	scale: 0 1;
	background: #ff9600;
}
@media (hover: hover) {
	.top_navi .gnav_i a::before {
		-webkit-transition: .3s translate;
		transition: .3s translate;
	}
	.top_navi .gnav_i a:hover::before {
		translate: 0 -5px
	}
	.top_navi .gnav_i a::after {
		-webkit-transform-origin: right center;
		        transform-origin: right center;
		-webkit-transition: .3s scale;
		transition: .3s scale;
	}
	.top_navi .gnav_i a:hover::after {
		-webkit-transform-origin: left center;
		        transform-origin: left center;
		scale: 1 1;
	}
}

/* ----------------------------------------
重要なお知らせ
---------------------------------------- */
.top_important_container {
	padding: 30px 40px;
	outline: 3px solid #cc0000;
	outline-offset: -3px;
	border-radius: 10px;
	background: rgb(255 255 255 / .9);
	margin-top:50px;
}
.top_important_ttl {
	color: #cc0000;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .1em;
	padding: 8px 0 8px calc(40px + 12px);
	background: url(/img/top/icon_important.png) no-repeat left top / 40px 40px;
	margin: 0 0 25px;
}
.top_important_list ul {
	padding: 0 10px;
}
.top_important_list ul li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	gap: 35px;
}
.top_important_list ul li + li {
	margin-top: 10px;
}
.top_important_list ul li span[class^="article_"] {
	display: block;
	line-height: 2.8rem;
}
.top_important_list ul li span.article_date {
	width: 10em;
	font-size: 1.6rem;
}
.top_important_list ul li span.article_title {
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
	font-size: 1.8rem;
}
.top_important_list ul li span.article_title a {
	color: inherit;
	font-size: inherit;
	letter-spacing: .05em;
}
.top_important_link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 30px;
	margin: 25px 0 0;
}
.top_important_link span[class^="link_"] a {
	color: inherit;
	text-decoration: none;
	font-size: 1.6rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 15px;
}
.top_important_link span[class^="link_"] a::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 1px solid #cc0000;
	border-radius: 100%;
	background: url(/img/common/arrow_red.png) no-repeat center / 7px 10px #fff;
	margin: 0 0 0 auto;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.top_important_menu {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 20px;
}
.top_important_link + .top_important_menu {
	margin-top: 30px;
}
.top_important_menu li {
	width: calc(100% / 4 - 20px * 3 / 4);
}
.top_important_menu li a {
	color: #cc0000;
	text-decoration: none;
	font-size: 1.8rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
	min-height: 60px;
	height: 100%;
	padding: 10px 20px;
	border-radius: 5px;
	background: #f5e5e5;
}
.top_important_menu li a::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 7px;
	height: 10px;
	background: url(/img/common/arrow_red.png) no-repeat center / contain;
	margin: 0 0 0 auto;
}

/* -----------------------------------------
トピックス
----------------------------------------- */
.top_topics_ttl {
	font-size: 3.2rem;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1;
	text-align: center;
	padding: calc(52px + 14px) 0 0;
	background: url(/img/top/icon_fukidashi.png) no-repeat center top / auto 52px;
	margin: 0 0 40px;
}
.top_topics_wrap {
	position: relative;
}
a.top_topics_box {
	color: inherit;
	text-decoration: none;
}
.top_topics_box {
	display: block;
	border: 2px solid #69d359;
	border-radius: 10px;
	background: #fff;
	overflow: hidden;
}
.top_topics_img {
	display: block;
	aspect-ratio: 330 / 200;
	overflow: hidden;
}
.top_topics_img img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	   object-fit: cover;
}
.top_topics_txt {
	font-size: 2rem;
	font-weight: bold;
	line-height: 3rem;
	letter-spacing: .05em;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	min-height: 98px;
	padding: 0 18px;
}
.top_topics_control {
	position: static;
}
#top_topics_prev {
	position: absolute;
	top: 50%;
	left: 0;
	z-index: 1;
	translate: -50% -50%;
}
#top_topics_next {
	position: absolute;
	top: 50%;
	right: 0;
	z-index: 1;
	translate: 50% -50%;
}
#top_topics_stop,
#top_topics_play {
	position: absolute;
	top: 50%;
	right: 0;
	z-index: 1;
	translate: 50% calc(50% + 10px);
}

/* -----------------------------------------
新着情報・イベント募集
----------------------------------------- */
.top_news {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	border: 3px solid #e1fadd;
	border-radius: 10px;
	background: #fff;
	overflow: hidden;
}
.top_news_ttl {
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 3.6rem;
	letter-spacing: .05em;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	padding: 3px 17px;
	min-height: 78px;
	background: #e1fadd;
}
.top_news_box {
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	gap: 35px;
	padding: 37px;
}
.top_news_list li {
	padding: 14px 20px;
	border-radius: 5px;
}
.top_news_list li:nth-child(2n) {
	background-color: #f6f6f6;
}
.top_news_date {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
	font-size: 1.4rem;
	line-height: 2rem;
}
.top_news_icon {
	-ms-flex-negative: 0;
	    flex-shrink: 0;
}
.top_news_info {
	display: block;
	font-size: 1.8rem;
	line-height: 2.8rem;
	margin: 4px 0 0;
}
.top_news_info a {
	color: inherit;
	letter-spacing: .05em;
}
.top_news_linkUnit {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	gap: 20px;
	margin: auto 0 0;
}
.top_news_link {
	display: block;
	width: calc(100% / 2 - 20px / 2);
}
a.top_news_btn {
	color: inherit;
	text-decoration: none;
}
.top_news_btn {
	font-size: 1.6rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
	min-height: 60px;
	padding: 10px 20px;
	border-radius: 5px;
	background: #e1fadd;
}
.top_news_btn::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 7px;
	height: 10px;
	background: url(/img/common/arrow.png) no-repeat center / contain;
	margin: 0 0 0 auto;
}
.top_news_btn.top_news_btn__em {
	background-color: #f7e2a3;
}

/* ----------------------------------------
検索
---------------------------------------- */
.top_search_ttl {
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .05em;
	text-align: center;
	padding: calc(51px + 10px) 0 0;
	background: url(/img/common/icon_s_search.png) no-repeat center top / 51px 51px;
	margin: 0 0 40px;
}

/* -----------------------------------------
タイトル
----------------------------------------- */
.top_ttl {
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .1em;
	text-align: center;
}
.top_ttl.top_ttl__about {
	padding-top: calc(68px + 17px);
	background: url(/img/top/icon_flower.png) no-repeat center top / auto 68px;
}

/* -----------------------------------------
カード型リンク
----------------------------------------- */
.top_card_unit {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: stretch;
	    -ms-flex-align: stretch;
	        align-items: stretch;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 40px;
}
.top_card_item {
	width: calc(100% / 2 - 40px / 2);
	border: 2px solid #96f088;
	border-radius: 10px;
	background: #fff;
	overflow: hidden;
}
a.top_card_box:-webkit-any-link {
	color: inherit;
	text-decoration: none;
}
a.top_card_box:-moz-any-link {
	color: inherit;
	text-decoration: none;
}
a.top_card_box:any-link {
	color: inherit;
	text-decoration: none;
}
.top_card_box {
	display: block;
}
.top_card_img {
	display: block;
	aspect-ratio: 240 / 140;
	overflow: hidden;
}
.top_card_img img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	   object-fit: cover;
}
.top_card_txt {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	min-height: 58px;
	font-size: 2rem;
	font-weight: bold;
	line-height: 2.5rem;
	padding: 4px 18px;
}

/* -----------------------------------------
人口・世帯数
----------------------------------------- */
.top_jinkou_head {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 0 25px;
}
.top_jinkou_ttl {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .05em;
}
.top_jinkou_date {
	font-size: 1.6rem;
	line-height: 2rem;
}
.top_jinkou_body {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 1fr 30px 1fr;
	grid-template-columns: 1fr 1fr;
	gap: 20px 30px;
	margin: 20px 0 0;
}
.top_jinkou_dl {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
}
.top_jinkou_dl dt {
	font-size: 1.6rem;
	line-height: 2rem;
}
.top_jinkou_dl dd {
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2rem;
}
.top_jinkou_link {
	-ms-grid-column: 2;
	-ms-grid-column-span: 1;
	grid-column: 2 / 3;
	-ms-grid-row: 2;
	-ms-grid-row-span: 2;
	grid-row: 2 / 4;
}
.top_jinkou_link a {
	color: inherit;
	text-decoration: none;
	font-size: 1.8rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
	min-height: 60px;
	padding: 10px 20px;
	border-radius: 5px;
	background: #96f088;
}
.top_jinkou_link a::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 7px;
	height: 10px;
	background: url(/img/common/arrow.png) no-repeat center / contain;
	margin: 0 0 0 auto;
}

/* -----------------------------------------
広報
----------------------------------------- */
.top_koho {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 1fr 30px 230px;
	grid-template-columns: 1fr 230px;
	gap: 50px 30px;
}
.top_koho_ttl {
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .1em;
	text-align: center;
	padding: calc(61px + 13px) 0 0;
	background: url(/img/top/icon_book.png) no-repeat center top / auto 61px;
}
.top_koho_link + .top_koho_link {
	margin-top: 10px;
}
.top_koho_link a {
	color: inherit;
	text-decoration: none;
	font-size: 1.8rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
	min-height: 60px;
	padding: 10px 20px;
	border-radius: 5px;
	background: #96f088;
}
.top_koho_link a::after {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 7px;
	height: 10px;
	background: url(/img/common/arrow.png) no-repeat center / contain;
	margin: 0 0 0 auto;
}
.top_koho_img {
	-ms-grid-column: 2;
	-ms-grid-column-span: 1;
	grid-column: 2/3;
	-ms-grid-row: 1;
	-ms-grid-row-span: 2;
	grid-row: 1/3;
}
.top_koho_img img {
	width: 100%;
}

/* -----------------------------------------
公式SNS
----------------------------------------- */
.top_sns {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 50px;
}
.top_sns_ttl {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .05em;
}
.top_sns_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 32px;
}
.top_sns_list li img {
	display: block;
}

/* -----------------------------------------
リンク
----------------------------------------- */
.top_link_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 26px 12px;
}
.top_link_list li {
	width: calc(100% / 4 - 12px * 3 / 4);
	font-size: 1.8rem;
	line-height: 2rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	gap: 20px;
}
.top_link_list li::before {
	content: "";
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	display: inline-block;
	width: 10px;
	height: 10px;
	margin: 5px 0;
	border-radius: 100%;
	background: #69d359;
}
.top_link_list li a {
	color: inherit;
	text-decoration: none;
	font-size: inherit;
	letter-spacing: .05em;
	line-height: 2rem;
}

/* -----------------------------------------
岩出市の魅力
----------------------------------------- */
.top_pr_ttl {
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: .1em;
	text-align: center;
	margin: 0 0 40px;
}
.top_pr_box {
	display: block;
	aspect-ratio: 230 / 140;
	border-radius: 10px;
	overflow: hidden;
}
.top_pr_box img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	   object-fit: contain;
}
.top_pr_control {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 11px 27px;
	margin: 20px 0 0;
}
#top_pr_pagination {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 7px 14px;
	width: auto;
}
#top_pr_pagination .swiper-pagination-bullet {
	width: 16px;
	height: 16px;
	padding: 0;
	border: 3px solid #fff;
	border-radius: 100%;
	background: #dcdcdc;
	margin: 0;
	opacity: 1;
}
#top_pr_pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #757575;
}
.top_pr_control button[id^="top_pr_"] {
	border: 1px solid #69e856;
}

/* -----------------------------------------
バナー広告
----------------------------------------- */
.top_banner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	gap: 60px;
}
.top_banner_head {
	-ms-flex-negative: 0;
	    flex-shrink: 0;
}
.top_banner_ttl {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1;
}
.top_banner_link {
	font-size: 1.4rem;
	margin: 26px 0 0;
}
.top_banner_link a {
	color: inherit;
	font-size: inherit;
	text-decoration: none;
}
.top_banner_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	gap: 18px 36px;
}
.top_banner_list li {
	width: 150px;
}
.top_banner_list li a img {
	display: block;
	width: 100%;
}

/* ----------------------------------------
マウスオーバー
---------------------------------------- */
@media (hover: hover) {
	button.top_bousai_all:hover,
	button.top_bousai_cls:hover,
	.top_important_link span[class^="link_"] a:hover,
	.top_important_menu li a:hover,
	a.top_topics_box:hover .top_topics_txt,
	a.top_news_btn:hover,
	a.top_card_box:hover .top_card_txt,
	.top_jinkou_link a:hover,
	.top_koho_link a:hover,
	.top_link_list li a:hover,
	.top_banner_link a:hover {
		text-decoration: underline;
	}
	a.top_topics_box img,
	a.top_card_box img,
	a.top_pr_box img {
		-webkit-transition: .5s scale;
		transition: .5s scale;
	}
	a.top_topics_box:hover img,
	a.top_card_box:hover img,
	a.top_pr_box:hover img {
		scale: 1.1;
		opacity: 1;
	}
	button[class^="slide_control_"],
	#top_pr_pagination .swiper-pagination-bullet {
		-webkit-transition: .5s opacity;
		transition: .5s opacity;
	}
	button[class^="slide_control_"]:hover,
	#top_pr_pagination .swiper-pagination-bullet:hover {
		opacity: .6;
	}
}

/* ----------------------------------------
背景色変更
---------------------------------------- */
.color_change {
	#floating_header_logo img {
		-webkit-filter: drop-shadow(0 0 1px #fff)  drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff);
		        filter: drop-shadow(0 0 1px #fff)  drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff) drop-shadow(0 0 1px #fff);
	}
	#mainlogo,
	#mainlogo img,
	#top_photo_control,
	.top_bousai_ttl,
	.top_important_ttl,
	button.top_bousai_cls,
	button.top_bousai_all,
	.top_topics_ttl,
	.top_search_ttl,
	.top_ttl,
	.top_jinkou_ttl,
	.top_koho_ttl,
	.top_sns_ttl,
	.top_pr_ttl,
	.top_banner_ttl,
	#floating_header_logo img {
		background-color: transparent !important;
	}
	button.slide_control_prev,
	button.slide_control_next,
	button.slide_control_stop,
	button.slide_control_play {
		background-color: #fff !important;
	}

	.top_bousai_container,
	.top_important_container {
		outline-color: inherit;
	}
	button.top_bousai_cls::after,
	button.top_bousai_all::after,
	.top_important_link span[class^="link_"] a::after,
	.top_navi .gnav_i a::before,
	.top_navi .gnav_i a::after,
	.top_important_menu li a::after,
	.ly_news_bg,
	.top_news_btn::after,
	.ly_about_bg,
	.top_jinkou_link a::after,
	.top_koho_link a::after {
		display: none !important;
	}
	.top_important_menu li a,
	.top_news_btn,
	.top_jinkou_link a,
	.top_koho_link a {
		border: 1px solid;
	}
	.top_link_list li::before,
	#top_pr_pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
		background-color: currentcolor !important;
	}
}
.color_black {
	#mainlogo {
		background: -webkit-gradient(linear, left top, left bottom, from(#000), to(transparent));
		background: linear-gradient(to bottom, #000, transparent);
	}
}
.color_blue {
	#mainlogo {
		background: -webkit-gradient(linear, left top, left bottom, from(#00f), to(transparent));
		background: linear-gradient(to bottom, #00f, transparent);
	}
}

/* ==================================================
スマートフォン
================================================== */
@media screen and (max-width: 1080px) {

	/* トップページ */
	:root {
		scroll-padding-top: 0;
	}

	/* ----------------------------------------
	メインロゴ
	---------------------------------------- */
	#mainlogo {
		right: auto;
		left: 0;
		width: 124px;
		min-width: auto;
		height: 387px;
	}
	#mainlogo img {
		width: 56px;
		margin: 21px auto 0;
	}

	/* -----------------------------------------
	メインビジュアル
	----------------------------------------- */
	#mainvisual {
		min-height: auto;
		margin-bottom: calc(-240px + 13px);
	}
	#mainvisual::before {
		height: 35px;
	}
	#top_photo_wrap {
		-webkit-mask-size: 100% calc(100% - 13px), 100% 14px;
		        mask-size: 100% calc(100% - 13px), 100% 14px;
	}
	#top_photo_control {
		bottom: 21px;
		right: 16px;
	}
	.photo_box {
		max-width: none;
		height: auto;
		aspect-ratio: 375 / 250;
	}

	/* ----------------------------------------
	レイアウト
	---------------------------------------- */
	.ly_section > [class*="top_"] {
		max-width: none;
		margin-inline: 20px;
	}

	/* info */
	.ly_section.ly_section__info {
		padding-bottom: 20px;
	}
	.ly_section.ly_section__info > .top_bousai {
		margin-bottom: 20px;
	}

	/* news */
	.ly_section.ly_section__news {
		padding-bottom: 20px;
	}
	.ly_section.ly_section__news > .ly_news {
		max-width: none;
		margin-inline: 20px;
	}
	.ly_section.ly_section__news > .ly_news_bg {
		top: -3px;
		width: 120px;
	}
	.ly_section.ly_section__news > .ly_news_bg.ly_news_bg__1 {
		right: calc(100% - 120px);
	}
	.ly_section.ly_section__news > .ly_news_bg.ly_news_bg__2 {
		left: calc(100% - 120px);
	}
	.ly_news {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		-webkit-box-pack: start;
		    -ms-flex-pack: start;
		        justify-content: flex-start;
		-ms-flex-wrap: nowrap;
		    flex-wrap: nowrap;
		gap: 20px;
	}
	.ly_news > .top_news {
		width: 100%;
	}

	/* search */
	.ly_section.ly_section__search {
		position: fixed;
		top: 100%;
		left: 0;
		z-index: 100;
		width: 100%;
		height: 100vh;
		height: 100dvh;
		padding-block: 0;
		overflow: auto;
		-ms-scroll-chaining: none;
		    overscroll-behavior: none;
		-webkit-transition: .5s translate;
		transition: .5s translate;
	}
	.spm_search_open .ly_section.ly_section__search {
		translate: 0 -100%;
	}
	.ly_section.ly_section__search > .top_search {
		padding-top: 40px;
		padding-bottom: calc(100px + 70px);
		margin-inline: 0;
	}

	/* about */
	.ly_section.ly_section__about {
		padding-top: 20px;
		padding-bottom: 40px;
		min-height: auto;
	}
	.ly_section.ly_section__about > .ly_about {
		max-width: none;
		margin-inline: 20px;
	}
	.ly_section.ly_section__about> .ly_about_bg::after {
		background-image: -webkit-gradient(linear, left top, left bottom, from(#fff) , to(transparent));
		background-image: linear-gradient(to bottom, #fff calc(100% - 191.2vw) , transparent);
	}
	.ly_about {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		-webkit-box-pack: start;
		    -ms-flex-pack: start;
		        justify-content: flex-start;
		-webkit-box-align: stretch;
		    -ms-flex-align: stretch;
		        align-items: stretch;
		gap: 20px;
	}
	.ly_about > .top_ttl {
		margin-bottom: 0;
	}
	.ly_about > .top_jinkou {
		padding: 19px;
	}
	.ly_about > .top_koho {
		padding: 39px;
	}
	.ly_about > .top_sns {
		padding: 19px;
	}
	.ly_about > .top_link {
		padding: 15px 19px;
	}
	.ly_about > .top_pr {
		padding: 40px;
	}

	/* banner */
	.ly_section.ly_section__banner {
		padding-block: 40px;
	}

	/* ----------------------------------------
	防災無線放送
	---------------------------------------- */
	.top_bousai_container {
		padding: 20px;
		outline-width: 2px;
		outline-offset: -2px;
	}
	.top_bousai_ttl {
		font-size: 1.8rem;
		padding-block: 7px;
		padding-left: calc(32px + 10px);
		background-size: 32px 32px;
		margin-bottom: 20px;
	}
	.top_bousai_list ul {
		padding-inline: 0;
	}
	.top_bousai_list ul li {
		display: block;
	}
	.top_bousai_list ul li + li {
		margin-top: 16px;
	}
	.top_bousai_list ul li span.emer_date {
		width: auto;
		font-size: 1.4rem;
		line-height: 1;
	}
	.top_bousai_list ul li span.emer_title {
		font-size: 1.6rem;
		line-height: 2.4rem;
		height: 2.4rem;
		margin-top: 6px;
	}
	.top_bousai_btn {
		gap: 10px;
		margin-top: 16px;
	}
	button.top_bousai_cls,
	button.top_bousai_all {
		font-size: 1.4rem;
		line-height: 1.6rem;
		gap: 10px;
	}
	button.top_bousai_cls::after,
	button.top_bousai_all::after {
		width: 32px;
		height: 32px;
		background-size: 5px 8px;
	}

	/* モーダル */
	.top_bousai:has(li.emer_title_open) {
		margin-inline: 0;
	}
	.top_bousai:has(li.emer_title_open) .top_bousai_container {
		padding-top: 20px;
		padding-bottom: calc(20px + 70px);
		overflow: auto;
	}
	.top_bousai:has(li.emer_title_open) .top_bousai_list {
		max-width: none;
		margin-inline: 20px;
		padding: 18px;
	}

	/* ----------------------------------------
	トップページ ナビ
	---------------------------------------- */
	#top_navi {
		margin: 0;
	}
	.top_navi {
		position: fixed;
		top: 100%;
		left: 0;
		z-index: 100;
		width: 100%;
		height: 100vh;
		height: 100dvh;
		background: #fff;
		overflow: auto;
		-ms-scroll-chaining: none;
		    overscroll-behavior: none;
		-webkit-transition: .5s translate;
		transition: .5s translate;
	}
	.spm_menu_open .top_navi {
		translate: 0 -100%;
	}
	.top_navi .gnav {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		height: 100%;
		padding: 0;
		border-radius: 0;
		background: none;
		margin-bottom: 0;
	}
	.top_navi .gnav_list {
		display: block;
		width: 100%;
		padding: 15px 20px calc(30px + 70px);
		margin: auto;
	}
	.top_navi .gnav_i {
		width: auto;
	}
	.top_navi .gnav_i + .gnav_i {
		background: none;
	}
	.top_navi .gnav_i a {
		position: static;
		font-size: 1.6rem;
		text-align: left;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		    -ms-flex-pack: start;
		        justify-content: flex-start;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		gap: 10px;
		padding-block: 15px;
		border-bottom: 1px solid #c9c8c8;
	}
	.top_navi .gnav_i a::before {
		width: 58px;
		height: 58px;
		margin: 0;
	}
	.top_navi .gnav_i a::after {
		content: none;
	}

	/* ----------------------------------------
	重要なお知らせ
	---------------------------------------- */
	.top_important_container {
		padding: 20px;
		outline-width: 2px;
		outline-offset: -2px;
		margin-top:0px;
	}
	.top_important_ttl {
		font-size: 1.8rem;
		padding-block: 7px;
		padding-left: calc(32px + 10px);
		background-size: 32px 32px;
		margin-bottom: 20px;
	}
	.top_important_list ul {
		padding-inline: 0;
	}
	.top_important_list ul li {
		display: block;
	}
	.top_important_list ul li + li {
		margin-top: 16px;
	}
	.top_important_list ul li span.article_date {
		width: auto;
		font-size: 1.4rem;
		line-height: 1;
	}
	.top_important_list ul li span.article_title {
		font-size: 1.6rem;
		line-height: 2.4rem;
		margin-top: 6px;
	}
	.top_important_link {
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		gap: 20px;
		margin-top: 16px;
	}
	.top_important_link span[class^="link_"] a {
		font-size: 1.4rem;
		line-height: 1.6rem;
		gap: 5px;
	}
	.top_important_link span[class^="link_"] a::after {
		width: 32px;
		height: 32px;
		background-size: 5px 8px;
	}
	.top_important_menu {
		gap: 10px;
	}
	.top_important_link + .top_important_menu {
		margin-top: 20px;
	}
	.top_important_menu li {
		width: calc(100% / 2 - 10px / 2);
	}
	.top_important_menu li a {
		font-size: 1.6rem;
		line-height: 2.4rem;
		padding: 6px 10px;
		gap: 20px;
	}

	/* -----------------------------------------
	トピックス
	----------------------------------------- */
	.top_topics_ttl {
		font-size: 2.4rem;
		padding-top: calc(42px + 10px);
		background-size: auto 42px;
		margin-bottom: 20px;
	}
	.top_topics_wrap {
		max-width: 330px;
		margin-inline: auto;
	}

	/* -----------------------------------------
	新着情報・イベント募集
	----------------------------------------- */
	.top_news {
		display: block;
		border-width: 2px;
	}
	.top_news_ttl {
		font-size: 2.2rem;
		line-height: 3.2rem;
		padding-block: 7px;
	}
	.top_news_box {
		display: block;
		padding: 20px 18px 18px;
	}
	.top_news_list li {
		padding: 10px 10px 6px;
	}
	.top_news_date {
		font-size: 1.2rem;
		line-height: 1.6rem;
	}
	.top_news_icon {
		width: 32px;
		height: auto;
	}
	.top_news_info {
		font-size: 1.6rem;
		line-height: 2.4rem;
	}
	.top_news_linkUnit {
		display: block;
		margin-top: 20px;
	}
	.top_news_link {
		width: auto;
	}
	.top_news_link + .top_news_link {
		margin-top: 10px;
	}
	.top_news_btn {
		font-size: 1.4rem;
	}

	/* ----------------------------------------
	検索
	---------------------------------------- */
	.top_search_ttl {
		font-size: 2.4rem;
		padding-top: calc(41px + 9px);
		background-size: 41px 41px;
		margin-bottom: 20px;
	}

	/* -----------------------------------------
	タイトル
	----------------------------------------- */
	.top_ttl {
		font-size: 2.4rem;
	}
	.top_ttl.top_ttl__about {
		padding-top: calc(58px + 10px);
		background-size: 58px;
	}

	/* -----------------------------------------
	カード型リンク
	----------------------------------------- */
	.top_card_unit {
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		gap: 20px;
	}
	.top_card_item {
		width: 240px;
		max-width: 100%;
	}
	.top_card_txt {
		font-size: 1.8rem;
	}

	/* -----------------------------------------
	人口・世帯数
	----------------------------------------- */
	.top_jinkou_head {
		gap: 0;
	}
	.top_jinkou_ttl {
		font-size: 1.8rem;
		width: 50%;
	}
	.top_jinkou_date {
		font-size: 1.2rem;
		line-height: 1.8rem;
		width: 50%;
	}
	.top_jinkou_body {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
		gap: 20px;
	}
	.top_jinkou_dl {
		display: block;
		width: calc(100% / 2 - 20px / 2);
	}
	.top_jinkou_dl dt {
		line-height: 1;
	}
	.top_jinkou_dl dd {
		line-height: 1;
		margin-top: 10px;
	}
	.top_jinkou_link {
		width: 100%;
		max-width: 205px;
		margin-inline: auto;
	}
	.top_jinkou_link a {
		font-size: 1.6rem;
	}

	/* -----------------------------------------
	広報
	----------------------------------------- */
	.top_koho {
		display: block;
	}
	.top_koho_ttl {
		font-size: 1.8rem;
		padding-top: calc(48px + 11px);
		background-size: auto 48px;
	}
	.top_koho_linkList {
		margin-top: 13px;
	}
	.top_koho_link {
		max-width: 230px;
		margin-inline: auto;
	}
	.top_koho_link a {
		font-size: 1.6rem;
	}
	.top_koho_img {
		max-width: 230px;
		margin-inline: auto;
		margin-top: 20px;
	}

	/* -----------------------------------------
	公式SNS
	----------------------------------------- */
	.top_sns {
		display: block;
	}
	.top_sns_ttl {
		font-size: 1.8rem;
		text-align: center;
	}
	.top_sns_list {
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		gap: 20px 28px;
		margin-top: 20px;
	}
	.top_sns_list li {
		width: 40px;
	}

	/* -----------------------------------------
	リンク
	----------------------------------------- */
	.top_link_list {
		gap: 13px 0px;
	}
	.top_link_list li {
		width: 50%;
		font-size: 1.4rem;
		line-height: 2.1rem;
		gap: 10px;
		padding-right: 5px;
	}
	.top_link_list li a {
		line-height: 2.1rem;
	}

	/* -----------------------------------------
	岩出市の魅力
	----------------------------------------- */
	.top_pr_ttl {
		font-size: 2.4rem;
		margin-bottom: 20px;
	}
	.top_pr_container {
		max-width: 230px;
		margin-inline: auto;
	}
	.top_pr_control {
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		max-width: 230px;
		margin-inline: auto;
	}
	#top_pr_pagination {
		display: none !important;
		width: 100%;
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
	}

	/* -----------------------------------------
	バナー広告
	----------------------------------------- */
	.top_banner {
		display: block;
		container-type: inline-size;
	}
	.top_banner_head {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		    -ms-flex-pack: start;
		        justify-content: flex-start;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		gap: 16px;
	}
	.top_banner_ttl {
		font-size: 1.6rem;
	}
	.top_banner_link {
		font-size: 1.2rem;
		margin-top: 0;
	}
	.top_banner_link a {
		line-height: 1.6rem;
	}
	.top_banner_list {
		width: calc(150px * 5 + 10px * 4);
		max-width: 100%;
		gap: 10px;
		margin-top: 20px;
		margin-inline: auto;
	}
	.top_banner_list li {
		width: 150px;
		max-width: 100%;
	}
	@container (max-width: 800px) {
		.top_banner_list {
			width: calc(150px * 4 + 10px * 3);
		}
	}
	@container (max-width: 640px) {
		.top_banner_list {
			width: calc(150px * 3 + 10px * 2);
		}
	}
	@container (max-width: 480px) {
		.top_banner_list {
			width: calc(150px * 2 + 10px);
		}
		.top_banner_list li {
			width: calc(50% - 5px);
		}
	}
}
/*優しい日本語対応*/
.tsutaeru-toolbar-message-active #floating_header .gnav_i a,
.tsutaeru-toolbar-message-active #floating_header .top_topics_txt,
.tsutaeru-toolbar-message-active #floating_header .top_news_btn,
.tsutaeru-toolbar-message-active .f_menu_i a,
.tsutaeru-toolbar-message-active .top_koho_link a,
.tsutaeru-toolbar-message-active .top_news_btn,
.tsutaeru-toolbar-message-active .top_topics_txt {
	flex-wrap: wrap;
}
.tsutaeru-toolbar-message-active .top_important_menu li a{
	flex-wrap: wrap;
	align-content: center;
}