@charset "UTF-8";

/*================================================================
# 共通スタイル
================================================================ */
.sp {
	display: none;
}

@media screen and (max-width: 640px) {
	.pc {
		display: none;
	}

	.sp {
		display: block;
	}
}

/*================================================================
# 特集1
================================================================ */
.toku01 .list li::marker {
	color: #751485;
}

.toku01 .container {
	margin: 20px 0 0;
	display: flex;
	align-items: center;
	gap: 24px;
}

@media screen and (max-width: 640px) {
	.toku01 .container {
		align-items: flex-start;
		flex-direction: column;
		gap: 8px;
	}
}

/*================================================================
# 特集2
================================================================ */
.toku02 .center {
	text-align: center;
}

.toku02 .title-img {
	text-align: center;
}

.toku02 .introduction {
	text-align: center;
}

.toku02 .schedule {
	margin: 32px 0 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.toku02 .schedule .ttl {
	width: 100%;
	margin: 0 0 16px;
	font-size: 16px;
}

.toku02 .schedule ul {
	margin: 0;
	padding: 0 0 16px;
	list-style: none;
	border-bottom: 2px solid #ccc;
}

.toku02 .schedule li {
	margin: 8px 0 0;
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 18px;
}

.toku02 .schedule li span {
	font-size: 28px;
	font-weight: 600;
}

.toku02 .schedule li .time {
	font-size: 16px;
}

.toku02_enter {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: #71598c;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}

.toku02_enter span {
	font-size: 0.9em;
	line-height: 1.2;
	color: #fff;
	text-align: center;
}

.toku02 .img.center {
	text-align: center;
}

.toku02 .container {
	display: flex;
	gap: 24px;
}

.toku02 .popup {
	margin: 16px 0 0;
}

.toku02 .popup span {
	padding: 0 24px;
	position: relative;
	font-size: 20px;
	font-weight: 600;
}

.toku02 .popup span::before {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #000;
	position: absolute;
	content: "";
	bottom: 8px;
	left: 0;
	display: block;
	transform: rotate(50deg);
}

.toku02 .popup span::after {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #000;
	position: absolute;
	content: "";
	right: 0;
	bottom: 8px;
	display: block;
	transform: rotate(-50deg);
}

/*================================================================
# クローズアップ京都府
================================================================ */
.close_up .col2_txt {
	padding: 0;
}

.close_up .close_up_h2 a {
	text-decoration: none;
}

.close_up .container {
	margin: 30px 0 0;
	display: flex;
	gap: 16px;
}

@media screen and (max-width: 640px) {
	.close_up .container {
		margin: 20px 0 0;
		flex-direction: column;
	}
}

.close_up .grid {
	margin: 30px 0 0;
	display: grid;
	grid-template-columns: repeat(3, 182px);
	gap: 16px;
}

@media screen and (max-width: 640px) {
	.close_up .grid {
		justify-content: center;
		gap: 10px;
		grid-template-columns: repeat(3, 1fr);
	}
}

.close_up .popup {
	margin: 40px 0 0;
}

.close_up .popup span {
	padding: 0 24px;
	position: relative;
	font-size: 20px;
	font-weight: 600;
}

.close_up .popup span::before {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #000;
	position: absolute;
	content: "";
	bottom: 8px;
	left: 0;
	display: block;
	transform: rotate(50deg);
}

.close_up .popup span::after {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #000;
	position: absolute;
	content: "";
	right: 0;
	bottom: 8px;
	display: block;
	transform: rotate(-50deg);
}

/*================================================================
# 気になる地域HOT情報
================================================================ */
@media screen and (min-width: 769px) {
	.event_box {
		display: flex;
		align-items: center;
	}

	.event_box .img_cap:nth-child(1) {
		margin-left: 0;
	}

	.event_box .img_cap {
		margin-left: 30px;
	}
}

@media screen and (max-width: 640px) {
	.event_box .img_cap {
		margin-bottom: 30px;
	}

	.event_box .img_cap img {
		width: 100%;
	}

	.col2_73.toku01_flex .txt,
	.inner_box .col2_73.toku01_flex .img {
		width: 100%;
	}

	.col2_73.toku02_flex .txt,
	.inner_box .col2_73.toku02_flex .img {
		width: 100%;
	}

	.col2_73.toku02_flex .txt {
		margin-top: 5%;
		margin-left: 0px;
	}

	.flex.flex2 {
		display: flex;
		align-items: flex-start;
		flex-direction: column-reverse;
	}

	.flex.flex2 .img {
		margin-left: 0px;
	}

	.flex.flex3 {
		display: flex;
		align-items: flex-start;
		flex-direction: column;
	}
}

/*================================================================
# 府警あんぜん広場
================================================================ */
.ttl_u_bar .sub {
	display: block;
	font-size: clamp(1.8rem, 2vw, 2.2rem);
	letter-spacing: 0.08em;
}

.fukei .ttl_bg_gy span {
	position: relative;
}

.fukei .label {
	width: 58px;
	height: 58px;
	margin: auto;
	border: 1px solid #006b3f;
	border-radius: 9999px;
	background-color: #fff100;
	position: absolute;
	top: 0;
	right: -64px;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 20px;
	font-weight: 600;
	line-height: 1;
	color: #006b3f;
}

.fukei .cap strong {
	color: #006b3f;
}

.fukei .mail {
	font-size: 20px;
	font-weight: 600;
}

/*================================================================
# 暮らしガイド
================================================================ */
.kurashi_box .container {
	display: flex;
	gap: 24px;
}

.kurashi_box.gekkan .toi {
	margin: 10px 0 0;
}

.tag .info {
	padding: 0;
	background: transparent;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #da4444;
}

.kurashi_h1 {
	border-bottom: 1px solid #4c912b;
	font-size: 3rem;
	font-weight: bold;
	color: #4c912b;
	letter-spacing: 0.2em;
}

.featured-content .kurashi_h1 a::after {
	content: "";
    background: url(../images/n_link_mark_kurashi.svg) no-repeat;
    width: 25px;
    height: 25px;
    background-size: contain;
    display: inline-block;
    margin: 5px 0 0 5px;
}

.kurashi_h1>span {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 0 10px;
	display: block;
	letter-spacing: 0.2em;
}

.kurashi_box .ttl_u_bar>span {
	padding: 0 0 10px;
}

@media screen and (max-width: 640px) {
	.kurashi_h1 {
		font-size: 2.4rem;
	}
}

.kurashi_box.tv .ttl_u_bar {
	margin: 8px 0 16px;
}

.kurashi_box.tv .ttl_left_bar {
	border-left-color: #751485;
}

.kurashi_box.tv .ttl_left_yoko::before {
	background-color: #751485;
}

.n_kurashi_event_illust01 {
	max-width: 1050px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.n_kurashi_event_illust01 img {
		width: 100%;
		height: auto;
	}
}

.kurashi_box .popup {
	max-width: 1000px;
	margin: 16px auto 0;
}

.kurashi_box .popup span {
	padding: 0 24px;
	position: relative;
	font-size: 20px;
	font-weight: 600;
	color: #4c912b;
}

.kurashi_box .popup span::before {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #4c912b;
	position: absolute;
	content: "";
	bottom: 8px;
	left: 0;
	display: block;
	transform: rotate(50deg);
}

.kurashi_box .popup span::after {
	width: 1em;
	height: 2px;
	border-radius: 9999px;
	background-color: #4c912b;
	position: absolute;
	content: "";
	right: 0;
	bottom: 8px;
	display: block;
	transform: rotate(-50deg);
}

.featured-content02 .kurashi_h2 {
	margin: 10px auto 40px;
}

/*================================================================
# その他のお知らせ
================================================================ */
.mgt0 {
	margin-top: 0;
}

.other-notice.pickup p {
	color: #751485;
}

.other-notice.pickup p::before {
	background-color: #751485;
}

.other-notice.pickup p::after {
	background-color: #751485;
}