@charset "utf-8";

/*------------------------------------------------
	共通
------------------------------------------------*/

::-webkit-input-placeholder {
    color:    #CCC;
}
:-moz-placeholder {
    color:    #CCC;
}

.page_top
{
	position		: fixed;
	right			: 20px;
	bottom			: 10px;
}
.ac_point
{
	padding-top 	: 149px;
	margin-top 		: -149px;
}





/*▼form--------------------------------------------------------------*/
/*form:inputとtextareaは#contact_form経由で使う*/

#contact_form input.input_area,
#contact_form textarea.input_area,
#contact_form select{
    font-size:14px;
    font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo;
    border: 1px solid #B9C9CE;
    border-radius:3px;
    padding: 7px 0.8em;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.2);
}

.form_name
{
	width			: 10em;
}
.form_tel
{
	width			: 15em;
}
.form_mail
{
	width			: 25em;
}
.form_add
{
	width			: 30em;
}
.form_team
{
	width			: 20em;
}
.form_other
{
	width			: 30em;
	height			: 10em;
}
.form_name_s
{
	width			: 10em;
}
.form_tel_s
{
	width			: 15em;
}
.form_mail_s
{
	width			: 16em;
}
.form_add_s
{
	width			: 16em;
}
.form_zip
{
	width			: 4em;
}


/*▼table--------------------------------------------------------------*/
.layout_table
{
	width			: 100%;
	border-collapse	: collapse;
	padding			: 0px;
	margin			: 0px;
}
.layout_table td,
.layout_table th
{
		padding:0;
}

.data_box table
{

	text-align      : left;
	width           : 95%;
	margin-left     : auto;
	margin-right    : auto;
	margin-bottom   : 15px;
}
.data_box th
{
	border-bottom	: 1px solid #ccc;
	border-right	: 1px solid #ccc;
	padding			: 10px 14px;
	background		: #f0f0f0;
	font-weight     : normal;
}
.data_box td
{
	border-bottom	: 1px solid #ccc;
	border-right	: 1px solid #ccc;
	padding			: 10px 14px;
	background		: #fff;
}



/*▼見出しタイトル--------------------------------------------------------------*/

.cate_header
{
	position: relative;
	width 			: 100%;
	padding-top 	: 140px; 
}

.cate_header:before
{
	content 			: "";
	display 			: block;
	height 				: 100%;
	width 				: 100%;
 	background: #00D1E4;
	background: linear-gradient(90deg,rgba(0, 209, 228, 1) 0%, rgba(0, 142, 180, 1) 100%);
	position: absolute;
	bottom 				: 0px;
	left 				: 0px;
	right 				: 0px; 
	
}
.cate_header .cate_title
{
	max-width 			: 620px;
	width 				: 90%; 
	margin 				: 0 auto;
	position 			: relative;
	z-index 			: 1;
	text-align 			: left;
	border-left 		: 8px solid #060e28;
	padding 			: 2rem 0px 2rem 3rem;
	line-height 		: 1.0;
	color 				: #FFF;
}
.cate_header .cate_title .en
{
	font-size 		: clamp(2.5rem, 6vw, 4.5rem);
	font-weight 	: 500;
	display 		: inline-block;
	margin-right 	: .5em; 
}
.cate_header .cate_title .jp
{
	font-size 		: clamp(2.3rem, 5vw, 3.8rem);
	font-weight 	: 900;
	display 		: inline-block;
}


.article_header
{
	border-left 		: 8px solid #060e28;
	padding 			: 2.5rem 0px 2rem 3rem;
	margin-bottom 		: 1.5rem; 
}


.article_header .sub_cate_title
{
	font-size 		: clamp(2.3rem, 4vw, 3.8rem);
	font-weight 	: 900;
	line-height 	: 1.3;
	margin 			: 0px; 
}
.article_header .sub_cate_title .num
{
	color 			: #009fc0;
	display 		: block;
	font-size 		: clamp(2.5rem, 5vw, 4.5rem);
	line-height 	: 1.0; 
}
.article_update
{
	width: fit-content;
	margin-left: auto;
	margin-bottom 	: 0px;
	background: url("../images/common/base/bg_pattern02.gif") 0 0 repeat;
	padding 		: .3rem 1.5rem;
	font-size 		: 1.4rem;
	margin-bottom:1.5rem;
}
.article_update i
{
	color:#CCC;
	margin-right:.5rem;
}

.article_main p
{
	margin-bottom 			: 2rem; 
}





/*▼汎用：見出しタイトル--------------------------------------------------------------*/

.article_main h2
{
	font-size 		: clamp(2.3rem, 3.5vw, 3.4rem);
	margin 			: 0px;
	line-height 	: 1.3;
	margin-top 		: 5rem; 
}
.article_main h2:first-child
{
	margin-top 		: 0; 
}
.article_main h2:after
{
	content 		: "";
	display 		: block;
	height 			: 6px;
	width 			: 30%;
	background 		: #00c0d8;
	margin-top 		: 2.5rem;
	margin-bottom 	: 2.5rem; 
}
.article_main h3
{
	margin 			: 0px;
	padding 		: 0px;
	line-height 	: 1.3;
	border-top 		: 10px solid #f7f7f7;
	border-bottom 	: 10px solid #f7f7f7;
	font-size 		: clamp(2rem, 3vw, 2.6rem);
	padding 		: .3em 0 .3em 1.8em;
 	margin 			: 3.5rem 0 2.5rem;
	position 		: relative;
}
.article_main h3:before
{
	content 		: ""; 
	display 		: block;
	width 			: .4em;
	height 			: .4em;
	border 			: .3em solid #009fc0;
	border-radius 	: 50%;
	position 		: absolute;
	left 			: .5em;
	top 			: .5em; 
}
.article_main h4
{
	margin 			: 0px;
	padding 		: 0px;
	line-height 	: 1.3; 
	font-size 		: clamp(2rem, 2.8vw, 2.2rem);
	border-left 	: .3em solid #009fc0;
	padding 		: .1em 0 .1em .5em;
 	margin 			: 3rem 0 2rem;
}

.article_main h4.icon_title
{
	border-left 	: none;
	padding 		: 0px;
	display 		: flex;
	gap 			: .3em;
 	margin 			: 3rem 0 2rem;
}

.article_main h4.icon_title i
{
	color 			: #009fc0;
	margin-top 		: .2em; 
}
.article_main .comment_title
{
	color		: #009fc0;
	font-weight : bold;
	border-bottom: 1px #CCC dashed;
	padding-bottom: .5rem;
	margin-bottom 	: .5rem; 
}



.des_title
{
	background 		: url("../images/common/base/bg_pattern02.gif") 0 0 repeat;
	padding 		: 1.5rem;
	display 		: flex;
	align-items 	: center;
	gap 			: 1rem;
	border-top 		: 3px solid #009fc0;
 	margin 			: 3.5rem 0 2.5rem;
	font-size 		: clamp(1.8rem, 3vw, 2rem);
}
.des_title .text
{
	margin 			: 0px;
	font-weight 	: bold;
	line-height 	: 1.4; 
}


.des_title .icon
{
	width 			: 66px;
	height 			: 66px;
	flex 			: 0 0 66px; 
	border-radius 	: 50%;
 	background: #00D1E4;
	background      : linear-gradient(90deg,rgba(0, 209, 228, 1) 0%, rgba(0, 142, 180, 1) 100%);
	display 		: flex;
	justify-content: center;
	align-items: center;
	line-height 		: 1.0;
	color 				: #FFF;
	flex-flow: column wrap;
	font-size 			: 1.2rem; 
}
.des_title .icon i
{
	font-size 		: clamp(2.8rem, 4vw, 3.8rem);
	display 		: block;
	margin-bottom 	: .3rem; 
}

.comment_block
{
	display 		: flex;
	gap 			: 15px;
 	margin 			: 3.5rem 0 2.5rem;
}
.comment_block .ab_icon
{
	flex 			: 0 0 66px;
	position 		: relative;
}
.comment_block .ab_icon:before
{
	content 		: "";
	background 		: url("../images/common/base/arrow.png") 0 0/cover no-repeat;
	width 			: 18px;
	height 			: 27px;
	display 		: block;
	position 		: absolute;
	right 			: 0px;
	top 			: 20px;
	transform 		: translateX(100%);
	z-index 		: 50; 
}
.comment_block .ab_icon img
{
	border-radius 	: 50%;
	border 			: 1px #EEE solid; 
}
.comment_block .fuki_box
{
	border-radius 		: 30px;
	border 				: 1px  #CCC solid;
	padding 			: 2rem; 
}
.mov_box
{
	background 			: #f7f7f7;
	padding 			: 1.5rem; 
}
.mov_box .mov_cap
{
	padding 			: .5rem 0 .5rem 1rem;
	border-left 		: 4px solid #009fc0;
	margin-top 			: 1rem;
	margin-bottom 		: 0px; 
}
.mov_box_inner
{
  position: relative;
  width: 100%;
  padding-top: 56.25%;

}
.mov_box_inner iframe 
{
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
  border-radius 		: 15px; 
}
.col_layout
{
	display: flex;
	flex-flow: row wrap;
	gap 	: 2rem;
}
.col_layout > div
{
	flex:1 1 min(100%, 300px);
}
.point_box
{
	border-radius 		: 0px;
	border 				: 1px #CCC solid;
	padding 			: 2.5rem 1.5rem 2rem;
	position 			: relative;
 	margin 				: 3rem 0 2rem;
}
.point_box .point_box_title
{
	position 			: absolute;
	left 				: 1em;
	top 				: 0;
	width 				: fit-content;
	background 			: #009fc0;
	border-radius 		: 20px;
	padding 			: 0em 2em;
	color 				: #FFF;
	transform 			: translate(0,-50%);
	font-weight 		: 500;
}
.point_box .point_box_title i
{
	margin-right 		: .5em; 
}

/*コメント*/
.comments-area {
	margin-top 		: 5rem;
}

.comment-list {
    list-style: none;
    padding: 0;
}

.comment-list li {
    padding: 15px;
    border-bottom: 1px solid #eee;
}

.comment-list .comment-author {
    font-weight: bold;
}

.comment-list .comment-meta {
    font-size: 0.9em;
    color: #666;
}

.comment-respond {
    margin-top: 20px;
}

.comment-form {
    display: flex;
    flex-direction: column;
}

.comment-form input,
.comment-form textarea {
    width: 100%;
    padding: 10px;
    margin-top: 5px;
    border: 1px solid #ccc;
    border-radius: 4px;
	font-size:1.6rem;
}

.comment-form .form-submit {
    margin-top: 10px;
    text-align: right;
}

.comment-list {
    list-style: none;
    padding: 0;
}

.comment-list li {
    padding: 15px;
    border-bottom: 1px solid #eee;
}

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

.comment-pagination ul {
    display: flex;
    justify-content: center;
    list-style: none;
    padding: 0;
}

.comment-pagination li {
    margin: 0 5px;
}

.comment-pagination a {
    display: block;
    padding: 8px 12px;
    background: #f4f4f4;
    border-radius: 5px;
    text-decoration: none;
}

.comment-pagination a:hover {
    background: #ddd;
}
ol.commentlist,
ol.commentlist li,
ol.commentlist li ul
{
	margin:0px;
	padding:0px;
	list-style:none;
}
.commentlist> li.comment
{
	background:#FFF;
	border:1px #CCC solid;
	border-radius:3px;
	padding:2rem;
	margin-bottom:1.5rem;
}

.comment-respond
{
		background:#f7f7f7;
	padding:2rem;
	border-radius:3px;
}
.comment-respond .comment-reply-title
{
	font-size:2rem;
	border-left:none;
	display:flex;
	align-items:center;
	gap:.8rem;
	border-bottom:1px #CCC solid;
	padding:0px 0px 1rem;
	margin:0px 0px; 1rem;
	flex-flow:row wrap;
}

.comment-respond .comment-reply-title:before {
  font-family: "Font Awesome 6 free";
  font-weight: 900; 
  content: '\f27a';
  font-size: 1.3em;
  color:  #00c0d8;
}
.comment-form .form-submit
{
		margin-top:0px;
}
.comment-form .form-submit input#submit
{
	font-size:1.8rem;
	background:#FFF;
	padding:1.5rem;
	color:#0078bc;
	font-weight:bold;
    transition: all 0.5s ease;
}
.comment-form .form-submit input#submit:hover
{
	background:#EEE;
}
h3#comments
{
		font-size:1.8rem;
	    background: url(../images/common/base/pt_img01.gif) 0 0 repeat;
	padding:1rem 2rem;
	border-radius:3px;
	margin-bottom:3rem;
	border-left:none;
}
ol.commentlist li ul
{
		border-top:1px #CCC solid;
		padding-top:2rem;
		margin-top:2rem;
}
.comment-author 
{
		display:flex;
	gap:1rem;
	align-items:center;
}
.comment-reply-link
{
	background:#f7f7f7;
	display:block;
	border-radius:3px;
	padding:.3rem 3rem;
	width:fit-content;
	text-decoration:none!important;
	margin-left: auto;
    transition: all 0.5s ease;
}
.comment-reply-link:hover
{
		background:#EEE;
}
.comment-reply-link:before
{
  font-family: "Font Awesome 6 free";
  font-weight: 900; 
  content: '\f3e5';
  font-size: 1.3em;
  color:  #CCC;
	margin-right:1rem;
}
.commentlist
{
		margin-bottom:5rem;
}



/*1024以下の指定（タブレット）*/
@media screen and (max-width: 1024px) {


.cate_header
{
	padding-top 		: 100px; 
}
.article_header,
.cate_header .cate_title
{
	padding-left 		: 2rem;
	border-left 		: 5px solid #060e28;
}




.ac_point
{
	padding-top 	: 70px;
	margin-top 		: -70px;
}

.page_top
{
	width 			: 40px;
	height 			: auto;
}
.page_top img
{
	width		: 100%;
	height  		: auto;
}

}






/*767以下の指定（スマホ横)*/
@media screen and (max-width: 767px) {

.article_main h2:after
{
	margin 			: 1.5rem 0; 
}


}
/*320以下の指定（スマホ縦)*/
@media screen and (max-width: 320px) {
}










/*---------------------------------------------------------*/
/*    copyright(C) CloudWorks.All rights reserved. Ver1.0    */
/*---------------------------------------------------------*/
