@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;700&family=Zen+Kaku+Gothic+Antique:wght@400;500;700&display=swap');

*{
	margin: 0;
	padding: 0;
}

ul, li, ol {
	margin: auto;
	list-style: none;
	padding: 0;
}

p{
	margin: 0 auto 1.5rem;
	line-height: 160%;
}

html{
	margin: 0;
}

body{
	width: 100%;
	margin: auto;
	background: #ffffff;
    font-size: 18px;
    line-height: 150%;
	font-family: 'Oswald', 'Zen Kaku Gothic Antique', sans-serif;
}

.hentry{
	margin: 0;
}

#access .menu-header,
div.menu,
#colophon, #branding, #main, #wrapper{
	width: auto;
}

.front_area{
	position: relative;
}

.top_columns{
	display: block;
	overflow: hidden;
	position: relative;
	background:linear-gradient(45deg, #FFFFC999,#FFA01F99,#73FF5F99);/*グラデーションを定義*/
	background-size: 200% 200%;/*サイズを大きくひきのばす*/
	animation: bggradient 20s ease infinite;
}

@keyframes bggradient{
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}

.top_columns::before{
	content: "";
	position: absolute;
	right: 0;
	max-width: 1080px;
	width: 65%;
	height: 100%;
	transform: skewX(-45deg) translate(40%, 0px);
	z-index: 1;
	background: #ffffff;
}

.n2-section-smartslider {
	position: absolute;
	max-width: 1080px;
	width: 66.6%!important;
}

.lg_search_area{
	max-width: 960px;
	width: 50%;
	height: 480px;
	position: absolute;
	text-align: center;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	z-index: 2;
}

img.top_i{
	max-width: 1080px;
	width: 66.6%;
	max-height: 680px;
	min-height: 560px;
}

img.logo{
	max-width: 440px;
	width: 96%;
	margin: auto;
	margin-bottom: 20px;
}

.lg_search_area p{
	font-weight: 500;
	margin-bottom: 20px;
    line-height: 150%;
}

img.home{
	max-width: 120px;
}

.p-search-form{
	display: flex;
	justify-content: center;
	padding: 0 2%;
}

input#searchsubmit{
	width: 35px;
	height: 35px;
	content-visibility: hidden;
	box-sizing: border-box;
	background: #ffffff;
	position: relative;
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2023/12/search_b3.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 20px;
}

#s.widget_search{
	width: 100%;
	height: 35px;
	box-sizing: border-box;
	font-family: 'oswald', sans-serif;
	font-size: 18px;
	color: #333333;
	padding: 5px;	
	border: 2px solid #333333;	
	border-right: none;
	background: rgba(255,255,255,0.7);
}

.lg_search_area #s.widget_search{
	max-width: 400px;
	height: 55px;
}

.lg_search_area input#searchsubmit{
	width: 55px;
	height: 55px;
	background-size: 40px;
}

.lg_search_area div input{
	padding: 10px;
	font-size: 20px;
	border: 2px solid #000000;
	background: none;
}

#s.widget_search:focus{
	outline: none;
	cursor:text; /*カーソルの種類*/
}

#searchsubmit:focus{
	outline: none;
	cursor: pointer; /*カーソルの種類*/
}

.site_point{
	max-width: 890px;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	margin-top: -60px;
	margin-bottom: 0px!important;
}

.site_point li{
	width: calc((100% / 4) - 2%);
	box-sizing: border-box;
	margin: auto;
	margin-top: 0;
	margin-bottom: 20px;
	position: relative;
}

.cont_area.test .site_point{
	margin-top: auto;
	margin-bottom: 2.5rem!important;
}

.cont_area.test .site_point li{
	margin-bottom: 0;
}

.cont_area.mar60{
	margin-bottom: 3.75rem;
}

.hum{
	display: none;
}

.hum{
	cursor: pointer;
	width: 60px;
	height: 60px;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 10px;
	margin: auto;
}

.hum span{
	position: absolute;
	right: 0;
	left: 0;
	margin: auto;
	width: 40px;
	height: 4px;
	background-color: #ffffff;
}

.hum span:nth-child(1){
	top: 12px;
	transition: 0.3s;
}

.hum span:nth-child(2){
	top: 28px;
	transition: 0.5s;
}

.hum span:nth-child(3){
	top: 44px;
	transition: 0.5s;
}

.hum.active span:nth-child(1){
	top: 28px;
	transform: rotate(225deg);
	transition: 0.5s;
}

.hum.active span:nth-child(2){
	top: 28px;
	transform: rotate(315deg);
	transition: 0.5s;
}

.hum.active span:nth-child(3){
	top: 28px;
	transform: rotate(495deg);
	transition: 0.5s;
}

#primary,
#secondary{
	float:none;	
	width: 100%;
	margin-bottom: 20px;
}

#main {
	padding: 0;
}

.sub_c {
	display: flex;
	max-width: 1600px;
	width: calc(100% - 4rem);
	margin: auto;
	padding: 0;
}

#container.sub_c {
    max-width: 1500px;
	width: calc(100% - 4rem);
	margin: auto;
	padding: 0;
}

.sub_content{
	max-width: 1100px;
    width: calc(100% - 2rem);
    margin: auto;
	margin-top: 0;
	padding-top: 50px;
	padding-bottom: 100px;
}

.side_area {
	display: table-cell;
	max-width: 400px;
	min-width: 240px;
	width: 100%;
	padding: 20px;
	margin: 20px;
    margin-top: 50px;
	position: static;
	box-sizing: border-box;
	text-align: left;
	background: #FFFFFF;
	border: 1px solid #cdcdcd;
	border-radius: 12px;
	filter: drop-shadow(0px 0px 2px #cccccc);
}
.side_area ul.xoxo ul{
	list-style: none;
	margin-left: 0;
}

.side_area ul.xoxo li {
	margin-bottom: 10px;
	border-bottom: 1px solid #ffffff; 
}

.side_area ul.xoxo li h3{
	font-size: 24px;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 1px dashed #ffffff;
}

.side_area ul.xoxo li:last-child{
	border-bottom: none;
}

.side_area ul.xoxo li a{
	display: block;
	padding: 5px 10px;
	text-decoration: none;
	color: #ffffff;
}

h3.side_title{
	font-size: 22px;
	color: #000000;
	margin-bottom: 20px;
	padding: 10px 0;
	border-bottom: 1px dashed #cccccc;
}

ul.side_list{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 20px;
}

ul.side_list li{
	margin-bottom: 10px;
	width: calc((100% / 2) - 2%);
}

ul.side_list li a{
	display: flex;
	align-items: center;
	background: #ffffff;
	position: relative;
}

ul.side_list li a:hover{
	text-decoration: none;
	color: #000000;
	filter: brightness(80%);
}

ul.side_list li a img{
	max-width: 180px;
	width: 100%;
	box-sizing: border-box;
	object-fit: cover;
	aspect-ratio: 1 / 1;
	border: 2px solid #555555;
}
ul.side_list li a span{
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 10px;
	font-size: 16px;
	font-weight: 700;
	color: #FFFFFF;
	background: rgba(0,0,0,0.5);
	text-decoration: none;
	position: absolute;
	bottom: 0;
}

.top_menu{
	display: flex;
	width: 100%;
	padding: 20px 2%;
	box-sizing: border-box;
	background: #ED7100;
	font-size: 20px;
	align-items: center;
	justify-content: space-between;
}

.top_menu ul{
	list-style: none;
	display: flex;
	margin: 0;
	color: #000000;
	font-weight: 700;
}

.top_menu ul li a{
	display: block;
	text-decoration: none;
	color: #000000;
	padding: 20px;
}

.top_menu ul li a:hover{
	color: #ffffff;
}

.top_menu ul li.arrow{
	position: relative;
	padding: 20px;
	padding-right: 40px;
}

.top_menu ul li.arrow::before{
	content: "";
	position: absolute;
	width: 8px;
	height: 8px;
	border-top: 2px solid #000000;
	border-right: 2px solid #000000;
	transform: rotate(135deg);
	right: 10px;
	top: 0;
	bottom: 0;
	margin: auto;
}

.top_menu ul li ul{
	position: absolute;
	display: none;
	width: 100%;
	font-size: 16px;
	opacity: 0;
	margin: 0;
	top: 50px;
    left: 0;
	z-index: 3;
}

.top_menu ul li:hover ul{
	display: block;
	opacity: 1;
}

.top_menu ul li ul li{
	background: #ED7100;
	border-bottom: 1px solid #000000;
}

.top_menu ul li ul li:last-child{
	border-bottom: none;
}

#content{
	margin: auto;
	margin-top: 0;
}

.entry-content, .entry-summary {
	padding-top: 0;
}

#container{
	float: none;
	margin: auto;
	width: 100%;
	text-align: center;
	padding: 110px 0;
}

.cont_area{
    max-width: 1500px;
    width: calc(100% - 4rem);
    margin: auto;
	margin-bottom: 120px;
}

.site-col2{
	display: flex;
	align-items: center;
	text-align: left;
	margin: 0 auto 5rem;
}

.site-col2 .l-box{
	max-width: 800px;
	width: 100%;
	color: #ED7100;
	font-weight: 700;
	padding: 1.25rem;
	box-sizing: border-box;

	border: 2px solid #ED7100;
	border-radius: 1rem;
}

.site-col2 .l-box p:last-child{
	margin-bottom: 0;
}

.site-col2 .r-box{
	max-width: 400px;
	width: 100%;
	padding: 1.25rem;
	box-sizing: border-box;
}

.site-col2 .r-box img{
	display: block;
	width: 100%;
}

h3.orange_btm{
	display: block;
	max-width: 440px;
	width: 100%;
	min-height: 6.25rem;
	align-content: center;
	padding-bottom: 0;
	box-sizing: border-box;
	padding-left: 10px;
	margin-left: 0;
	margin-bottom: 50px!important;
	text-align: left;
	font-size: 36px;
	font-weight: 700;
	border-bottom: 4px solid #ED7100;
	position: relative;
	z-index: 1;
}

h3.orange_btm::before{
	content: "";
	position: absolute;
	width: 36px;
	height: 4px;
	background: #000000;
	left: 0;
	bottom: -4px;
	z-index: 2;
}

.about_area{
	position: relative;
	max-width: 1200px;
	margin: 0 auto 2.5rem;
	padding: 2rem;
	padding-left: 30rem;
	box-sizing: border-box;
	text-align: left;
	word-break: auto-phrase;
	background: #FFF9E9;
	border-radius: 2.5rem;
}

.about_area .img-box{
	position: absolute;
	max-width: 400px;
	left: 2.5rem;
	bottom: 2rem;
}

.about_area h4{
	font-size: 1.25rem;
	padding-bottom: 1rem;
	margin-bottom: 1rem;
	border-bottom: 1px solid #ED7100;
}

.about_area p{
	margin-bottom: 0;
	line-height: 160%;
}

.kiyaku_area{
	max-width: 1200px;
	margin: auto;
	padding: 20px;
	box-sizing: border-box;
	text-align: left;
	position: relative;
	padding-right: 420px;
	border: 2px solid #ED7100;
	border-radius: 5px;
}

.kiyaku_area img{
	position: absolute;
	max-width: 400px;
	width: 100%;
	margin: 25px;
	right: 0;
	bottom: 0;
}

.kiyaku_area h4{
	font-size: 20px;
	padding-bottom: 20px;	
	margin-bottom: 1.25rem;
	border-bottom: 1px dashed;
}

.more_kiyaku{
	text-align: center;
}

.more_kiyaku a{
	display: inline-block;
	text-decoration: none;
	padding: 20px;
	padding-right: 40px;
	border-radius: 5px;
	color: #000000;
	font-weight: 500;
	background: #ED7100;
	position: relative;
}

.more_kiyaku a::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	border-top: 2px solid #000000;
	border-right: 2px solid #000000;
	transform: rotate(45deg);
	right: 15px;
	top: 0;
	bottom: 0;
	margin: auto;
}

.more_kiyaku a:hover{
	opacity: .8;
}

h3.orange_btm span{
	font-size: 18px;
	color: #ED7100;
	margin-left: 20px;
}

.illust_list,
.connection_list{
	display: flex;
	list-style: none;
	flex-wrap: wrap;
	margin: auto;
	margin-bottom: 60px;
}

.connection_list{
	margin-bottom: 0;	
}

.illust_list .list_area,
.connection_list .list_area{
	width: calc((100% / 4) - 2%);
	text-align: left;
	margin: 0 1% 20px;
	padding: 10px;
	box-sizing: border-box;
	filter: drop-shadow(0 0 2px rgba(0,0,0,0.4));
	background: #ffffff;
	border-radius: 10px;
}

.illust_list .list_area.col3{
	width: calc((100% / 3) - 2%);
}

.connection_list .list_area{
	width: calc((100% / 4) - 6px);
	padding: 0;
	border-radius: 3px;
	margin: 0 3px 6px;
}

.illust_list .list_area a,
.connection_list .list_area a{
	display: block;
	text-decoration: none;
	color: #000000;
	border-radius: 10px;
}

.connection_list .list_area a{
	position: relative;
}

.illust_list .list_area a img,
.connection_list .list_area a img{
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	aspect-ratio: 1 / 1;
}

.connection_list .list_area a img{
	border-radius: 3px;
}

.illust_list .list_area a:hover img,
.connection_list .list_area a:hover img{
	opacity: .7;
}

.illust_list .list_area a span{
	display: block;
}

.illust_list .list_area a span.title_area,
.connection_list .list_area a span.title_area{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	margin-bottom: 10px;
	border-bottom: 1px solid #5e5e5e;
}

.connection_list .list_area a span.title_area{
	position: absolute;
	width: 100%;
	box-sizing: border-box;
	padding: 5px;
	border-bottom-left-radius: 3px;
	border-bottom-right-radius: 3px;
	background: #000000cc;
	color: #ffffff;
	bottom: 0;
	margin-bottom: 0;
	border-bottom: none;	
}

.illust_list.popular .list_area a span.title_area{
	margin-bottom: 0;
	border-bottom: none;
}

.il_name{
	font-size: 18px;
	font-weight: 700;
}

.connection_list .list_area a span.title_area .il_name{
	font-size: 14px;
	font-weight: 700;
}

.wpp-shortcode .il_name{
	display: inline-block;
	width: 100%;
}

.wpp-thumbnail{
	float: none;
	margin: 0;
}

.illust_list .list_area ul.tag_list{
	margin-top: 0;
	margin: auto;
}

/* 最初は31個目以降を隠す */
.tag_list li:nth-child(n+31) {
	display: none;
}

.tag_list.is-open li {
	display: inline-block;
}

.readmore_btn_wrap {
	text-align: center;
	margin-top: 20px;
}

.btn_tag_more {
	max-width: 320px;
	width: 100%;
	min-height: 60px;
	font-size: 1.25rem;
	font-weight: 700;
	color: #ffffff;
	background: #ED7100;
	border: none;
	cursor: pointer;
	border-radius: 1.875rem;
	transition: 0.3s;
}

#secondary .btn_tag_more {
	max-width: 280px;
	width: 100%;
	min-height: 40px;
	font-size: 1rem;
}

.btn_tag_more:hover {
	background: #e0e0e0;
	color: #333333;
}

.more_area a.more{
	display: inline-block;
	font-size: 20px;
	font-weight: 700;
	text-decoration: none;
	color: #ffffff;
	padding: 25px;
	padding-right: 60px;
	position: relative;
	background: #ED7100;
}

.more_area a.more::before{
	content: "";
	position: absolute;
	width: 15px;
	height: 15px;
	border-top: 2px solid #ffffff;
	border-right: 2px solid #ffffff;
	transform: rotate(45deg);
	right: 25px;
	top: 0;
	bottom: 0;
	margin: auto;
}

h2.head_area{
	font-size: 40px;
	padding: 50px 1%;
	border-top: 2px solid #ED7100;
	border-bottom: 40px solid #ED7100;
}

h2.head_area span{
	display: block;
	font-size: 24px;
	color: #ED7100;
}

ul.column2{
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin-top: 60px;
	margin-bottom: 60px;
}

ul.column2 li{
	width: calc((100% / 2) - 40px);
	margin: 20px;
}

ul.column2.categories li{
	display: grid;
	min-height: 300px;
	box-sizing: border-box;
	border: 4px solid #666666;
}

ul.column2.categories li a{
	position: relative;
	text-decoration: none;
	color: #000000;
}

ul.column2.categories li a::before{
	content: '';
	position: absolute;
	background-position: right bottom;
	background-size: contain;
	background-repeat: no-repeat;
	width: 100%;
	height: 100%;
	left: 0;
	aspect-ratio: 4 / 3;
	z-index: -1;
}

ul.column2.categories li.business {
	border: 4px solid #0768AB;
}

ul.column2.categories li.business a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_business.png);
}

ul.column2.categories li.season {
	border: 4px solid #6AA55F;
}

ul.column2.categories li.season a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_season.png);
}

ul.column2.categories li.day_life {
	border: 4px solid #EEB033;
}

ul.column2.categories li.day_life a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_daylife.png);
}

ul.column2.categories li.architect {
	border: 4px solid #0A7C30;
}

ul.column2.categories li.architect a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_architect.png);
}

ul.column2.categories li.welfare {
	border: 4px solid #FFCCCC;
}

ul.column2.categories li.welfare a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_welfare.png);
}

ul.column2.categories li.sports {
	border: 4px solid #D94D2A;
}

ul.column2.categories li.sports a::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2024/02/cat_sports.png);
}

ul.column2.categories li a span.c_tit{
	display: block;
	text-align: left;
	padding: 10px;
	padding-top: 0;
	line-height: 1.5em;
	font-size: 32px;
	font-weight: 700;	
	filter: drop-shadow(0px 0px 2px #ffffff) drop-shadow(0px 0px 1px #ffffff);
}

ul.column2.categories li a span.c_tit span.eng_cat{
	border-top: 1px dashed;
	display: inline-block;
	padding: 10px 5px;
	line-height: 1;
	font-size: 24px;
}

ul.column2.categories li a span.cat_detail{
	display: block;
	width: 100%;
	text-align: left;
	padding: 10px;
	font-size: 14px;
	font-weight: 700;
	position: absolute;
	box-sizing: border-box;
	background-color: #000000bb;
	color: #ffffff;
	bottom: 0;
}

ul.column2 li a:hover{
	opacity: .8;
}

ul.tag_list{
	display: inline-flex;
	max-width: 1400px;
	list-style: none;
	flex-wrap: wrap;
	margin: auto;
	margin-bottom: 0!important;
}

ul.tag_list li{
	margin: auto 10px;
	margin-bottom: 20px;
}

.illust_list .list_area ul.tag_list li,
.side_area ul.tag_list li{
	margin: auto 5px;
	margin-bottom: 10px;
}

ul.tag_list li a,
.illust_list .list_area ul.tag_list li a{
	display: block;
	padding: 5px 15px;
	border-radius: 20px;
	text-decoration: none;
	color: #000000;
	font-weight: 500;
	background: #FFD080;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
}

ul.tag_list li a:hover,
.illust_list .list_area ul.tag_list li a:hover{
	border-bottom: none;
	opacity: .8;
}
.illust_list .list_area ul.tag_list li a,
.side_area ul.tag_list li a{
	font-size: 13px;
    line-height: 100%;
	padding: 5px 10px;
}

.wpp-post-title{
	padding: 10px;
	padding-bottom: 0;
}

ul.tag_list li a span.counter{
	font-size: .8em;
}

.tag_area{
	margin-bottom: 40px;
}

.tag_area p{
	margin-right: 0!important;
}

h4.con_tx{
	border-left: 5px solid;
	border-bottom: 1px solid;
	font-size: 20px;
	padding: 10px;	
	margin-bottom: 30px;
}

#footer{
	margin-bottom: 0;
	background: #ED7100;
	display: flex;
	padding: 70px 2% 100px;
	box-sizing: border-box;
	justify-content: center;
	align-items: start;
	color: #000000;
	font-weight: 700;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 18px;
}

#footer div{
	width: 50%;
}

#footer .f_menu{
	display: flex;
}

#footer .f_menu .m_area{
	padding: 0 25px;
	width: 100%;
}

#footer .f_menu .m_area h4{
	padding: 15px 10px;
	font-size: 22px;
	border-bottom: 1px dotted #ffffff;
}

#footer .f_menu .m_area ul{
	list-style: none;
	margin: 0;
	padding: 10px;
}

#footer .f_menu .m_area ul li{
	padding: 0 10px 10px;
}

#footer .f_menu .m_area ul li a{
	text-decoration: none;
	color: #000000;
}

#footer .f_menu .m_area ul li a:hover{
	color: #FFFFFF;
}

.copyright{
	text-align: center;
	padding: 10px;
	width: 100%;
	font-size: 14px;
	box-sizing: border-box;
	background: #ED7100;
	color: #000000;
}

.copyright p{
	margin-bottom: 0;
	font-weight: 500;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
}

/***サブページ***/

.k_area{
	text-align: center;
	margin: auto;
	margin-top: 60px;
	margin-bottom: 60px;
}

.k_area img{
	max-width: 96%;
	height: auto;
	margin: auto;
}

.sub_cont{
	max-width: 1300px;
	width: calc(100% - 4rem);
	padding: 50px 0;
	margin: auto;
	box-sizing: border-box;
}

h2.entry-title{
	width: 100%;
	text-align: left; 
	padding: 30px;
	box-sizing: border-box;
	background: #ED7100;
	font-size: 28px;
	color: #000000!important;
	border-radius: 15px;
	margin-bottom: 1.5rem;
}

h2.cat_type{
	line-height: 1.2em;
	margin-bottom: 40px;
	padding: 20px 20px;
	border-left: 6px solid #ED7100;
	border-bottom: 1px solid #000000;
}

h3.illust-title,
h3.result_title{
	text-align: left;
	font-size: 24px;
	padding: 20px;
	border-left: 5px solid #ED7100;
	border-bottom: 1px solid #000000;
	margin-bottom: 40px!important;
}

.illust_detail{
	text-align: left;
}

.illust_detail .illust_area {
	margin-bottom: 20px;
	position: relative;
}

.illust_detail .illust_area a {
	transition: .7s;
}

.illust_detail .illust_area a span {
	opacity: 0;
	display: inline-table;
	width: 240px;
	height: 0px;
	padding: 20px;
	position: absolute;
	background: #1F5793;
	text-align: center;
	text-decoration: none;
	color: #ffffff;
	font-weight: 700;
	font-size: 20px;
	border-radius: 10px;
	right: 0;
	left: 0;
	bottom: 0;
	top: 0;
	margin: auto;
	z-index: 2;
	transition: .7s;
}

.illust_detail .illust_area a:hover img {
	opacity: .8;
	transition: .3s;
}

.illust_detail .illust_area a:hover span{
	opacity: 1;
	transition: .3s;
}

.illust_detail .illust_area img{
	display: block;
	width: 100%;	
	height: auto;
	position: relative;
	transition: .7s;
	z-index: 1;
}

.category_area{
	display: flex;
	margin-bottom: 20px;
	align-items: center;
}

.category_area p,
.tag_area p{
	padding: 5px 10px;
	border-radius: 5px;
	font-weight: 700;
	background: #ED7100;
	color: #000000;
	margin-right: 10px;
}

.category_area p{
	margin-left: 0;
	margin-bottom: 0!important;
}

.entry-page{
	padding: 0;
	text-align: left;
}

.entry-page a{
	text-decoration: none;
}

.attention{
	color: #DD0000;
	font-weight: 500;
}

.poricy_area{
	padding: 20px;
	background: #ededed;
	border-radius: 10px;
	margin-bottom: 40px;
}

.poricy_area h3{
	font-size: 24px;
	margin-bottom: 20px;
}

.poricy_area h4{
	font-size: 20px;
	padding-bottom: 20px;
	margin-bottom: 10px;
	border-bottom: 1px dashed #fefefe;
}

.poricy_area ul{
	list-style: none;
}

.poricy_area .ok_area,
.poricy_area .ng_area{
	font-weight: 500;
	padding: 20px;
	border-radius: 10px;
	margin-bottom: 30px;
}

.poricy_area .ok_area{
	background: rgba(51, 156, 208, 0.25);
}

.poricy_area .ng_area{
	background: rgba(183, 28, 37, 0.25);
}

.poricy_area .ok_area p,
.poricy_area .ng_area ul li{
	padding-left: 20px;
	position: relative;
}

.poricy_area .ng_area ul li{
	margin-bottom: 10px;
}

.poricy_area .ok_area p::before,
.poricy_area .ng_area ul li::before,
.poricy_area .ng_area ul li::after{
	content: "";
	position: absolute;
	width: 14px;
	height: 14px;
	left: 0px;
	top: 4px;
}

.poricy_area .ok_area p::before{
	border: 2px solid #0000C6;
	border-radius: 16px;
}

.poricy_area .ng_area ul li::before{
	border-left: 2px solid #C60000;
	transform: translate(7px,7px) rotate(45deg);
}

.poricy_area .ng_area ul li::after{
	border-left: 2px solid #C60000;
	transform: translate(7px,-3px) rotate(-45deg);
}

#nav-below {
	margin: auto;
	display: flex;
	margin-bottom: 50px;
}

.nav-previous,
.nav-next {
	float: none;
	text-align: center;
	font-size: 16px;
}

.nav-previous a,
.nav-next a{
	display: inline-block;
	padding: 8px 15px;
	background: #2743A8;
	color: #ffffff;
	border-radius: 8px;
}

.navigation a:link, .navigation a:visited{
	color: #ffffff;
	text-decoration: none;
}

.navigation.pagination .nav-links a{
	color: #666666;
}

.navigation.pagination{
	margin:40px 0 0;
}

.navigation.pagination .page-numbers{
	display:inline-block;
	margin-right:20px;
	padding:10px 15px;
	color:#333;
	border-radius:2px;
	border: 2px solid #000044;
	background:#fff;
}
.navigation.pagination .current{
	padding:10px 15px;
	background:#ED7100;
	color:#fff;
}
.navigation.pagination .prev,
.navigation.pagination .next{
	background:transparent;
	box-shadow:none;
	color:#69a4db;
}
.navigation.pagination .dots{
	background:transparent;
	box-shadow:none;
}

.col2{
	display: flex;
	margin-bottom: 40px;
}

.col2.rev{
	flex-direction: row-reverse;
}

.col2 div{
	width: 48%;
	margin: auto 1%;
}

.col2 .left_box h4{
	font-size: 22px;
	padding: 10px;
	margin: auto!important;
	border-bottom: 1px dashed #3c3c3c;
}

.col2 .left_box p{
	padding: 20px;
}

.tx_blue{
	color: #0000dd;
	font-weight: 700;
}

.tx_red{
	color: #DD0000;
	font-weight: 700;
}
table.com_detail{
	width: 100%;
	border-collapse: collapse;
	border: none!important;
	margin: 0!important;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
}

table.com_detail tr th,
table.com_detail tr td{
	box-sizing: border-box;
	border: 2px solid #ED7100!important;
	font-size: 18px!important;
	padding: 10px 15px!important;
}

table.com_detail tr th{
	width: 160px;
	color: #ED7100!important;
}

ul.cat_col2{
	display: flex;
	flex-wrap: wrap;
	list-style: none;
}

ul.cat_col2 li{
	width: calc((100% / 2) - 2%);
	padding: 20px;
	background: #ffffff;
	box-sizing: border-box;
	border: 1px solid #cccccc;
	border-radius: 15px;
	filter: drop-shadow(0 0 2px #cccccccc);
	margin: 0 1%;
	margin-bottom: 30px;
}

ul.cat_col2 li img{
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	aspect-ratio: 1 / 1;
}

.cat_list a{
	text-decoration: none;
	position: relative;
	color: #000000;
}

.cat_title{
	position: absolute;
	display: block;
	width: 100%;
	font-size: 20px;
	color: #ffffff;
	font-weight: 700;
	padding: 15px;
	box-sizing: border-box;
	background: #00000099;
	bottom: 0;
}

p.cat_detail{
	padding: 10px;
	margin-bottom: 0!important;
}

.inner.policy h3{
	padding: 0.75rem;
	margin-bottom: 1rem;
	border-bottom: 1px dotted #000000;
}

.inner.policy p{
	padding: 0 1rem 1.5rem;
	margin: auto;
}

.inner.policy ul{
	padding: 0 1rem;
}

.inner.policy ul li{
	position: relative;
	padding-left: 1.25rem;
	margin-bottom: 0.5rem;
}

.inner.policy ul li::before{
	content: "";
	position: absolute;
	width: 1rem;
	height: fit-content;
	aspect-ratio:1 / 1;
	background: #ED7100;
	left: 0;
	top: 5px;
}

.one-column #content {
	margin: 0 auto;
	max-width: 1500px;
	width: calc(100% - 4rem);
}

#container.one-column{
	padding: 5rem 0 10rem;
}

.inner.form {
	max-width: 1200px;
	width: 100%;
	margin: auto;
}

ul.category-area{
	max-width: 1200px;
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	margin-bottom: 2.5rem;
	justify-content: space-between;
}

ul.category-area li{
	width: calc((100% / 8) - 1rem);
}

ul.category-area li a{
	position: relative;
	display: block;
	text-decoration: none;
	aspect-ratio: 3 / 4;
	color: #000000;
	background: #ffffff;
	border-radius: 1rem;
	filter: drop-shadow(0 0 2px #ABABAB);
	transition: 0.3s;
	z-index: 1;
}

ul.category-area li.soon a{
	background: #cdcdcd;
	color: #666666;
}

ul.category-area li a::before{
	content: "";
	position: absolute;
	max-width: 90px;
	width: calc(100% - 0.5rem);
	height: fit-content;
	aspect-ratio: 1 / 1;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100% auto;
	filter: brightness(0);
	bottom: 10px;
	left: 0;
	right: 0;
	margin: auto;
	transition: .5s;
}

ul.category-area li a[href*="business"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-business.png?2026);
}

ul.category-area li a[href*="season"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-season.png);
}

ul.category-area li a[href*="sports"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-sports.png);
}

ul.category-area li a[href*="welfare"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-welfare.png);
}

ul.category-area li a[href*="architect"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-architect.png);
}

ul.category-area li a[href*="day_life"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-daylife.png);
}

ul.category-area li a[href*="emotion"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-emotion.png);
}

ul.category-area li a[href*="request"]::before{
	background-image: url(https://kj-illust.net/wp/wp-content/uploads/2026/04/category-request.png);
}

ul.category-area li a:hover{
	transform: scale(1.1);
}

ul.category-area li.soon a:hover{
	transform: scale(1);
}


ul.category-area li a[href*="business"]:hover{
	color: #0768AB;
	filter: drop-shadow(0 0 2px #0768AB);
}

ul.category-area li a[href*="season"]:hover{
	color: #6AA55F;
	filter: drop-shadow(0 0 2px #6AA55F);
}

ul.category-area li a[href*="sports"]:hover{
	color: #D94D2A;
	filter: drop-shadow(0 0 2px #D94D2A);
}

ul.category-area li a[href*="welfare"]:hover{
	color: #FFCCCC;
	filter: drop-shadow(0 0 2px #FFCCCC);
}

ul.category-area li a[href*="architect"]:hover{
	color: #0A7C30;
	filter: drop-shadow(0 0 2px #0A7C30);
}

ul.category-area li a[href*="day_life"]:hover{
	color: #EEB033;
	filter: drop-shadow(0 0 2px #EEB033);
}

ul.category-area li a[href*="emotion"]:hover{
	color: #00D6AD;
	filter: drop-shadow(0 0 2px #00D6AD);
}

ul.category-area li a[href*="request"]:hover{
	color: #C95FC1;
	filter: drop-shadow(0 0 2px #C95FC1);
}

ul.category-area li.soon a:hover{
	color: #666666;
	filter: drop-shadow(0 0 2px #ABABAB);
}

ul.category-area li a:hover::before{
	filter: brightness(100%);
}

ul.category-area li.soon a:hover::before{
	filter: brightness(0);
}

ul.category-area li a .tx-box{
	display: block;
	padding: 1rem 0.25rem;
	font-size: 1.25rem;
	font-weight: 700;
}

ul.category-area li a .tx-box small{
	display: block;
	font-size: 1rem;
}

.form-midasi{
	margin-bottom: 2.5rem;
}

.form-midasi h2{
	position: relative;
	max-width: 640px;
	width: 100%;
	font-size: 1.75rem;
	line-height: 150%;
	text-align: center;
	margin: 0 auto 2.5rem;
	padding: 1rem;
	box-sizing: border-box;
	background: #ffffff;
	filter: drop-shadow(1px 1px 2px #1F5793);
	border: 4px solid #1F5793;
	border-radius: 1rem;
}

.form-midasi p{
	text-align: center;
	margin-bottom: 0;
}

table.request-table {
	max-width: 1200px;
	border: 1px solid #e7e7e7;
	border: none;
	margin: 0 auto 2.5rem;
}

table.request-table th,
table.request-table td{
	padding: 1rem;
	border-bottom: 1px solid #cccccc;
	font-size: 1rem;
	align-content: center;
}

table.request-table th {
	position: relative;
	width: 240px;
}

table.request-table th .require{
	position: absolute;
	height: fit-content;
	width: 2.5rem;
	font-size: 0.75rem;
	text-align: center;
	align-content: center;
	color: #ffffff;
	padding: 5px;
	background: #CC0000;
	border-radius: 5px;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}

table.request-table td{
	border-top: none;
}

table.request-table td input[type="text"],
table.request-table td input[type="email"],
table.request-table td select,
table.request-table td textarea{
	width: 100%;
	padding: 10px 5px;
	font-size: 1rem;	
	font-family: 'Oswald', 'Zen Kaku Gothic Antique', sans-serif;
    box-sizing: border-box;
}

table.request-table p{
	margin: 0;
}

.wpcf7-list-item{
	margin-left: 0;
	margin-right: 1rem;
}

.check-area{
	width: fit-content;
	margin: 0 auto 1.5rem;
}

.check-area p{
	margin: 0;
}

.privacy-box{
	max-width: 1200px;
	margin: auto;
	max-height: 360px;
	overflow-y: scroll;
	padding: 1.25rem;
	margin-bottom: 1.25rem;
	box-sizing: border-box;
	background: #F0F0F0;
	border-radius: 0.625rem;
}

.btn-sub{
	max-width: 300px;
	margin: auto;
}

.btn-sub p{
	margin: 0;
}

.btn-sub input {
	width: 100%;
	min-height: 60px;
	color: #ffffff;
    font-size: 1.125rem;
	background: #1F5793;
	border: none;
	border-radius: 30px;
	cursor: pointer;
}

.btn-sub input:hover {
	filter: brightness(130%);
}

.wpcf7-spinner{
	display: none!important;
}

.form-btn-box{
	max-width: 360px;
	margin: 0 auto 5rem;
}

.form-btn-box a{
	display: block;
	position: relative;
	width: 100%;
	min-height: 80px;
	text-align: center;
	text-decoration: none;
	font-size: 1.25rem;
	font-weight: 700;
	color: #ffffff;
	align-content: center;
	background: #1F5793;
	border-radius: 40px;
	transition: .5s;
}

.form-btn-box a:hover{
	background: #4F87C3;
}

#char-counter-wrapper {
    text-align: right;
    font-size: 0.9em;
    color: #666;
    margin-top: 5px;
}

.count-error {
    color: #ff4d4d; /* Xのような赤色 */
    font-weight: bold;
}

.textarea-error {
    border: 2px solid #ff4d4d !important;
}

.btn-sub input:disabled {
    background-color: #ccc !important;
    border-color: #ccc !important;
    cursor: not-allowed;
    opacity: 0.6;
}

@media screen and (max-height: 860px){

	.n2-section-smartslider {
		height: 70vh;
	}

	img.logo{
		max-width: 330px;
	}
}

@media screen and (max-width: 1440px) {
	.side_area {
		max-width: 240px;
	}

	ul.side_list{
		display: block;
	}

	ul.side_list li{
		width: calc(100% - 2%);
	}

	ul.side_list li a img{
		max-width: 200px;
	}
}

@media screen and (max-width: 1200px) {

	.n2-section-smartslider{
		max-width: none;
		width: 100%!important;
	}

	.top_columns::before {
		max-width: none;
		transform: none;
		width: 100%!important;
		z-index: 1;
		background: #ffffffcc;
	}

	.lg_search_area {
		max-width: none;
		width: auto;
		top: 10%;
		right: 0;
		left: 0;
		margin: auto;
	}

	.illust_list .list_area{
		width: calc((100% / 3) - 2%);
	}

	.sub_cont {
		width: auto;
		box-sizing: none;
	}

	#footer{
		display: block;
		padding: 50px 2%;
	}

	#footer div{
		width: 96%;
		margin: auto;
	}

	#footer .f_menu{
		display: block;
	}

	#footer .f_menu .m_area{
		padding: 0;
		width: 100%;
	}

	#footer .f_menu .m_area h4{
		padding: 15px 10px;
		font-size: 22px;
		font-weight: 700;
		border-bottom: 1px dotted #ffffff;
	}

	#footer .f_menu .m_area ul{
		list-style: none;
		margin: 0;
		padding: 10px;
		padding-bottom: 30px;
	}

	ul.category-area li{
		width: calc(25% - 1.25rem);
		margin-bottom: 1.25rem;
	}

	ul.category-area li a{		
		min-height: 240px;
		aspect-ratio: auto;
	}

	ul.category-area li a::before{
		max-width: 160px;
	}
}

@media screen and (max-width: 1024px) {

	.hum{
		display: block;
	}

	.top_menu form{
		position: absolute;
		display: inline-flex;
		width: 320px;
		left: 0;
		right: 0;
		margin: auto;
	}	

	ul.nav{
		position: fixed;
		left: 0;
		right: 0;
		transform: translatey(-50em);
		z-index: 50;
		transition: 0.3s;
	}

	ul.nav.active{
		transform: translatey(40px);
		z-index: 50;
		transition: 0.3s;
	}

	ul.nav li{
		width: 100%;
		color: #666666;
		background-color: #ffffffee;
		border-bottom:1px solid #888888;
		margin: auto;
	}

	ul.nav li a{
		text-decoration: none;
		color: #000000;
		display: block;
		padding: 20px;
	}

	.top_menu ul{
		display: block;
	}

	.top_menu ul li.arrow {
		padding-right: 0;
		padding: 20px 0 0;
		box-sizing: border-box;
		text-indent: 20px;
	}

	.top_menu ul li.arrow::before {
		display: none;
	}

	.top_menu ul li ul {
		position: static;
		display: block;
		font-size: 20px;
		text-indent: 0;
		opacity: 1;
		margin-top: 20px;
	}

	.top_menu ul li ul li {
		background: transparent;
		border-bottom: 1px solid #888888;
	}

	.top_menu{
		position: fixed;
		height: 80px;
		top: 0;
		z-index: 100;
	}

	.sub_c{
		display: block;
		padding-top: 80px;
	}

	.side_area {
		display: block;
		max-width: none;
		width: 96%;
		margin: 2%;
	}

	ul.side_list{
		display: flex;
	}

	ul.side_list li{
		width: calc((100% / 3) - 2%);
	}

	ul.side_list li a img {
		max-width: none;
	}

	.illust_list .list_area,
	.illust_list .list_area.col3{
		width: calc((100% / 2) - 2%);
	}

	.front_area,
	#container.sub_c{
		padding-top: 80px;
	}

	ul.point li {
		width: calc((100% / 2) - 2%);
	}

	.about_area{
		padding: 1.5rem;
		padding-left: 23.5rem;
	}

	.about_area .img-box {
		position: absolute;
		max-width: 320px;
		left: 1.5rem;
		bottom: 1.5rem;
	}
}

@media screen and (max-width:768px){
	ul.column2{
		display: block;
	}

	ul.column2 li{
		width: calc(100% - 40px);
	}

	.about_area {
		padding-left: 2rem;
	}

	.about_area .img-box {
		display: none;
	}

	.kiyaku_area{
		padding-right: 20px;
	}

	.kiyaku_area img{
		display: none;
	}	
	.connection_list .list_area{
		width: calc((100% / 2) - 6px);
	}

	ul.category-area {
		max-width: 640px;
	}

	ul.category-area li {
		width: calc(50% - 1.25rem);
	}

	.form-midasi h2 {
		max-width: 420px;
		font-size: 1.375rem;
	}

	.form-midasi p {
		text-align: left;
	}

	.form-midasi p br{
		display: none;
	}

	table.request-table th,
	table.request-table td{
		display: block;
		width: 100%;
		box-sizing: border-box;
		border-bottom: none;
	}

	table.request-table th{
		background: #dcdcdc;
	}

	table.request-table th .require{
		right: 0.75rem;
	}

	table.request-table td{
		border-bottom: 1px dotted;
		margin-bottom: 1rem;
	}
}
@media screen and (max-width:640px){
	.lg_search_area{
		top: 20%;
	}

	img.logo{
		max-width: 330px;		
		height: auto;
	}


	.top_menu form{
		display: none;
	}

	ul.side_list li {
		width: calc((100% / 2) - 2%);
	}

	.col2{
		display: block;
	}

	.col2 div{
		width: 100%;
		margin: auto;
	}

	table.com_detail tr th,
	table.com_detail tr td{
		display: flex;
		width: 100%;
		border: none!important;
	}

	table.com_detail tr th{
		background: #ED7100;
		color: #ffffff!important;
	}

	table.com_detail tr td{
		margin-bottom: 20px;
	}

	ul.cat_col2 li{
		width: 100%;
		margin: auto;
		margin-bottom: 30px;
	}

	h2.cat_type {
		font-size: 20px;
	}

}
@media screen and (max-width:540px){

	h3.orange_btm {
		line-height: 1.2em!important;
		font-size: 32px;
	}

	h3.orange_btm span {
		margin: auto;
		display: block;
	}

	.illust_list .list_area,
	.illust_list .list_area.col3 {
		width: calc((100% / 2) - 5px);
		padding: 0;
		border-radius: 3px;
		filter: none;
		border: 1px solid #cdcdcd;
		margin: 0 2.5px 5px;
	}

	.illust_list .list_area a {
		display: block;
		position: relative;
	}

	.illust_list .list_area a span.title_area {
		display: block;
		position: absolute;
		width: 100%;
		padding: 5px;
		box-sizing: border-box;
		background: #ffffffcc;
		bottom: 0;
		margin: 0;
		border-bottom: 0;
	}

	ul.point li{
		width: calc(100% - 2%);
	}

	.il_name {
		font-size: 14px;
	}

	.illust_list .list_area a span.title_area .append_day{
		text-align: right;
		display: none;
	}

	.illust_list .list_area ul.tag_list {
		display: none;
	}

	.illust_list .list_area a img {
		display: block;
		width: 100%;
		object-fit: cover;
		aspect-ratio: 1 / 1;
	}

	ul.tag_list li {
		margin: auto 5px;
		margin-bottom: 10px;
	}
}
@media screen and (max-width:540px){
	.site_point li {
		width: calc((100% / 2) - 2%);
	}

	.form-midasi h2 {
		max-width: 340px;
		font-size: 1.125rem;
	}
}