@charset "utf-8";

/* =Reset default browser CSS.
Based on work by Eric Meyer:http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td{border:0;font-family:inherit;font-size:100%;font-style:inherit;font-weight:inherit;margin:0;outline:0;padding:0;vertical-align:baseline;}
:focus{outline:0;}

ol, ul{list-style:none;}
table{border-collapse:separate;border-spacing:0;}
caption, th, td{font-weight:normal;text-align:left;}
blockquote:before, blockquote:after,q:before, q:after{content:"";}
blockquote, q{quotes:"" "";}
a img{border:0;}
figure{margin:0}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section{display:block;}
/* -------------------------------------------------------------- */

html{
   /* font-size: 62.5%;これだと10ptを基準にできる*/
    font-size: 55%;
}

body{
color:#555;
font-size:13px;
font-family:verdana,"source-han-sans-japanese", "ヒラギノ丸ゴ ProN W4","Hiragino Maru Gothic ProN","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
line-height:1.5;
-webkit-text-size-adjust:100%;
    font-size:1.6rem;/* 16px*/
line-height: 2;

}


/* リンク設定
------------------------------------------------------------*/
a{color:#6caefe;text-decoration:none;}
a:hover{color:#488fdd;}
a:active, a:focus {outline:0;}


/* 全体
------------------------------------------------------------*/
#wrapper{
margin:0 auto;
padding:0 1%;
width:98%;
position:relative;
}

.inner{
margin:0 auto;
width:100%;
}


/*************
/* ヘッダー
*************/
#header{
height:130px;
}

#header h1{
padding:5px 0 10px;
font-size:12px;
font-weight:normal;
}



/*************
/* ロゴ
*************/
.logo{
float:left;
}

.logo a{
color:#555;
}

.logo p{float:left;}

.logo span{display:block;}


/*************
/* 電話番号
*************/
.info{
float:right;
padding-right:20px;
text-align:right;
}

.info .open{font-size:11px;}


/*************
/* ロゴ+電話番号
*************/
.logo,.info .tel{
margin-top:6px;
font-size:20px;
font-weight:bold;
}

.logo span,.info span{
font-size:.6em;
font-weight:normal;
}


/**************************
/* メイン画像（トップページ+サブページ）
**************************/
#mainBanner{
clear:both;
margin:25px auto 40px;
padding:0;
position:relative;
text-align:center;
    padding-top: 20px;
}
#mainBanner .inner{position:relative;}

#mainBanner img{
max-width:100%;
height:auto;
}

.slogan{
color:#fff;
font-weight:bold;
position:absolute;
max-width:100%;
height:auto;
bottom:42%;
left:40px;
padding:5px 10px;
line-height:1.4;
text-align:left;
}

.slogan h2{
padding-bottom:5px;
font-size:22px;
}


/**************************
/* グリッド
**************************/
.gridWrapper{
clear:both;
padding-bottom:20px;
overflow:hidden;
}
.gridWrapper1{
clear:both;
padding-bottom:20px;
overflow:hidden;
background: #eee;
}

* html .gridWrapper{height:1%;}
	
.grid{
overflow:hidden;
}

.box{
padding:10px;
}

.box img{
max-width:100%;
height:auto;
}

.box3{
	text-align:left;
}

.box4{
	text-align:center
}

.box5{
 display: -webkit-flex;
 display: flex;
 -webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
 align-items: center; /* 縦方向中央揃え */}

.box6{
	text-align:left;
}

/*写真の左横にテキスト、縦に中央ぞろえ ここから
div.box5 p {
	display: table-cell;
	vertical-align: middle;
	margin: 0;
}

for IE6
* html .box5 p {
	display: inline;
	zoom: 1;
}

for IE7
*:first-child+html .box5 p {
	display: inline;
	zoom: 1;
}
写真の横にテキスト、縦に中央ぞろえ ここまで*/


.box h3{
font-size:16px;
padding:10px 0 15px;
}

.box h3, .box p{text-align:left;}

.box p.readmore{
padding:10px 5px 5px;
text-align:right;
}

.box p.readmore a{
padding:3px 7px;
border-radius:3px;
}


/*************
メイン コンテンツ
*************/
section.content article{
padding:30px 0 20px 0;
margin-bottom:10px;
overflow:hidden;
}

section.toppage article,section.content .archive{border:0;}


/* アーカイブページ */
section.content .archive{
padding:0;
border-bottom:1px dotted #ccc;
}

section.content p{margin-bottom:5px;}

/* 見出しのH3 */
h3.heading{
font-size:16px;
font-weight:normal;
padding:15px 0;
margin-bottom:5px;
border-top:2px solid #ebebeb;
border-bottom:2px solid #ebebeb;
}


section.content img{
max-width:90%;
height:auto;
}

.alignleft{
float:left;
clear:left;
margin:3px 10px 10px 0;
}

.alignright{
float:right;
clear:right;
margin:3px 0 10px 10px;
}


/*************
/* サイドバー
*************/
#sidebar article{
clear:both;
margin-bottom:20px;
}

#sidebar ul{padding:15px 0;}

#sidebar li{
margin-bottom:10px;
padding-bottom:10px;
list-style:none;
border-bottom:1px dashed #ebebeb;
}

#sidebar li:last-child{
border:0;
margin-bottom:0px;
}

#sidebar li a{
color:#555;
font-size:12px;
display:block;
}

#sidebar li a:hover{
color:#999;
font-size:12px;
display:block;
}


/*************
/* フッター
*************/
#footer{
clear:both;
}

#footer a{
color:#555;
}

#footer a:hover{
color:#999;
}

#footer .inner{
padding:40px 0;
overflow:hidden;
}

#footer .grid{
margin:0;
}

#footer #info{float:left;}

#footer #info .info{float:none;}

#footer #info .info{
clear:both;
padding:5px 0 0;
text-align:left;
}

#footer .logo{font-size:18px;}

#footer .info .tel,#footer .info .tel span,#footer #info .open{
font-size:12px;
}

ul.footnav{
float:right;
width:620px;
padding:10px 0;
}
ul.footnav ul{display:none;}

ul.footnav li{
float:left;
margin:10px 0 10px 0;
padding:0 7px 0 8px;
border-right:1px solid #ebebeb;
}

#copyright{
clear:both;
padding:20px 0 10px 0;
text-align:center;
font-style:normal;
font-size:10px;
color:#555;
}


/* page navigation
------------------------------------------------------------*/
.pagenav{
clear:both;
width:100%;
height:30px;
margin:5px 0 20px;
}

.prev{float:left}
.next{float:right;}

#pageLinks{
clear:both;
text-align:center;
}


/* タイポグラフィ
*****************************************************/
.dateLabel{
margin:0 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post p{padding-bottom:10px;}

.post ul{margin:0 0 10px 10px;}

.post ul li{
margin-bottom:5px;
padding-left:15px;
background:url(images/bullet.png) no-repeat 0 8px;
}

.post ol{margin:0 0 10px 30px;}

.post ol li{list-style:decimal;}


.post h1{
margin:20px 0;
padding:5px 0;
font-size:150%;
color:#000;
/*border-bottom:3px solid #cf6a88;*/
}

.post h2{
margin:10px 0;
padding-bottom:2px;
font-size:150%;
font-weight:bold;
color:#333;
/*border-bottom:2px solid #cf6a88;*/
}


/* 見出し通常 */
.post h3{
margin:10px 0 25px 0;
padding:30px 0 10px 0;
font-size:140%;
font-weight:bold;
border-top:1px solid #ddd;
	text-align: center;
}
/* 見出し通常 What is the difference from others?*/
.difference{
    color:#ffffff;
margin:10px 0 100px 0;
padding:30px 0 100px 0;
font-size:140%;
font-weight:bold;
border-top:2px solid #ffffff;
	text-align: center;
}

.white{color:white;}

.post blockquote{
clear:both;
padding:10px 0 10px 15px;
margin:10px 0 25px 30px;
border-left:5px solid #ccc;
}
 
.post blockquote p{padding:5px 0;}
/*表のプロパティ
.post table{
border-collapse:collapse;
margin:5px auto 15px auto;
}


.post table td{
border-collapse:collapse;
background-color:#fff;
text-align:left;
padding:8px;
border:1px solid #D6D6D6;
line-height:20px;
}

.post table th{
background-color:#F5F5F5;
text-align:right;
padding:8px;
white-space:nowrap;
color: #151515;
border-top:1px solid #D4D4D4;
border-right:4px solid #D4D4D4;
border-bottom:1px solid #D4D4D4;
border-left:1px solid #D4D4D4;
font-size:13px;
font-weight:normal;
letter-spacing:1px;
background-repeat:repeat-x;
background-position:top;
}


.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}
表のプロパティここまで*/

.post img{max-width:100%;height:auto;}

		.box3 h3{
font-weight: bold; 
}

.days{
font-family: 'Crimson Text', serif;
font-size:14px;/* IE8以下とAndroid4.3以下用フォールバック */
font-size: calc(1.4rem + ((1vw - 0.64rem) * 0.7143));/* 20px~24pxで可変*/
/*line-height: 1.3;*/
float: left;
    display: block;
    width: 80px;                 /* 幅指定 */
    color: #fff;                   /* 文字色指定 */
    text-align: center;
    border-radius: 2px;
    background: #1F8A76;        /* 背景色指定 */
	margin-right:3px;                /* 余白指定 */
    padding: 3px;
}

.daysimg{
    vertical-align:middle;
margin-right: 10px;}

.daysline{
    border-bottom: 1px dashed #1F8A76;
}

/* 見出しを中央に */
.midashiCenter{
    text-align:center;
    background-image: url("img/bg_img.png");
    background-repeat: no-repeat;
    background-size: 110%;
    font-weight:bold;
    font-size:160%;
    color: #1A8F76;
    padding-bottom:100px;
    padding-top:100px;
}

.bg_feature{
    /*background-color: #CFE6E5;*/
    background-color: #1A8F76;
}



.midashi2{
    padding: 0.5em 1em;
    margin: 2em 0;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f0fff7, #f0fff7 3px,#e9ffe0 3px, #e9ffe0 7px);
}
.midashi2 p {
    margin: 0; 
    padding: 0;
    font-weight: bold;
}

.midashi3{
    padding: 0.5em 1em;
    margin: 2em 0;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
}
.midashi3 p {
    margin: 0; 
    padding: 0;
}
.midashi4{
    padding: 0.5em 1em;
    margin: 2em 0;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f7f7f7, #f7f7f7 3px,#f0f0f0 3px, #f0f0f0 7px);
}
.midashi4 p {
    margin: 0; 
    padding: 0;
}


img.aligncenter{
display:block;
margin:5px auto;
}

img.alignright, img.alignleft{
padding:4px;
margin:0 0 2px 7px;
display:inline;
}

img.alignleft{margin:0 7px 2px 0;}

.alignright{float:right;}
.alignleft{float:left;}

.grid2{
	margin : 3em 20em 1.5em ;
    padding : 1em 1em ;
    /* border : dashed 1px #eb5e34 ;--*/
}
/* （上　左右　下）（上下　左右）-----*/
.grid2 h3{
	font-weight:bold;
}

/* featureの項目インデント-----*/
.indent2{margin-left: 1em;
}
.indent3{margin-left: 2em;
}


.clearBoth{clear:both;}

/*文字を中央に*/
.centerText{
text-align:center}


/* PC用
------------------------------------------------------------*/
@media only screen and (min-width:960px){
	nav div.panel{
	display:block !important;
	float:left;
	}

	a#menu{display:none;}
	
  #mainNav{
	clear:both;
	z-index:200;
	position:relative;
	}

	#mainNav li{
	float:left;
	position:relative;
	}

	/* メインナビのデザインの設定 日本語
     -----------------------------------*/
	#mainNav li a{
	color:#555;
	display: block;
	text-align: center;
	_float:left;
	font-size:13px;
	width:160px;
	height:30px;
	padding:10px 0 42px;
	border-top:2px solid #ebebeb;
	border-bottom:2px solid #ebebeb;
    font-size:1.0em;
    font-weight: 700;
	}

	#mainNav li a span,#mainNav li a strong{display:block;}

	#mainNav li a span{
	color:#bababa;
	font-size:10px;
	}
	
	#mainNav ul ul{width:160px;background:#fff;}
	#mainNav li ul{display:none;}

	#mainNav li:hover ul{
	display:block;
	position:absolute;
	top:52px;
        /*top:64px;*/
	z-index:500;
	}
	
	#mainNav li li{
	margin:0;
	float:none;
	width:160px;
	border:0;
	}
  #mainNav li li:last-child{border:0;}
	
	#mainNav li li a{
	width:auto;
	height:auto;
	padding:10px;
	font-size:95%;
	text-align:left;
	border:0;
	}

	#mainNav li li span{padding:0 10px;}
	
	#mainNav li.current-menu-item a{
	border-color:#555;
	}

	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item li a:hover{
	color:#999;
	}

	#header,#wrapper,.inner{
	width:960px;
	padding:0;
	margin:0 auto;
	}
	
	#wrapper{clear:both;padding:20px 0;}
	
	#main{
	float:right;
	width:680px;
	padding:15px 0 0 0;
	}
	
	#sidebar{
	float:left;
	width:250px;
	padding:15px 0;
	overflow:hidden;
	}
	
	#sidebar article{
	margin-bottom:20px;
	overflow:hidden;
	}
	
	.logo{width:500px;}
	
	/* グリッド全体 */
	.gridWrapper{
	display:table;
	border-collapse:separate;
	border-spacing:0px;
	}

	
	/* グリッド */
	.grid{
	width:320px;
	display:table-cell;
	}
	.grid1{
	width:25%;
	display:table-cell;
	}
	.grid2{
	width:20%;
	display:table-cell;
	}
      .sp_br{
    display: none;
  }
    
    /* 見出しを中央に */
.midashiCenter{
    text-align:center;
    background-image: url("img/bg_img.png");
    background-repeat: no-repeat;
    background-size: 125%;
    font-weight:bold;
    font-size:160%;
    color: #1A8F76;
    padding-bottom:100px;
    padding-top:100px;
}

}



@media only screen and (min-width:768px) and ( max-width:959px){
	*{
    -webkit-box-sizing:border-box;
       -moz-box-sizing:border-box;
         -o-box-sizing:border-box;
        -ms-box-sizing:border-box;
            box-sizing:border-box;
	}
	
	#mainNav{
	clear:both;
	width:100%;
	margin:0 auto;
	padding:0;
  border:1px solid #e4e4e4;
	border-left:0;
	border-right:0;
	}

	#mainNav a.menu{
	color:#555;
	width:100%;
	display:block;
	height:40px;
	line-height:40px;
	font-weight: bold;
	text-align:left;
	}

	#mainNav a#menu span{
	padding-left:10px;
	}
	#mainNav a.menu span:before{content:"≡ ";}
	#mainNav a.menuOpen span:before{content:"× ";}

	#mainNav a#menu:hover{cursor:pointer;}

	nav .panel{
	display:none;
	width:100%;
	position:relative;
	right:0;
	top:0;
	z-index:1;
	}
	
	#mainNav ul{margin:0;padding:0;}

  #mainNav li{
	float:none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	}

	#mainNav li a,#mainNav li.current-menu-item li a{
	color:#555;
	display: block;
	padding:15px 10px;
	text-align:left;
	border-bottom:1px dashed #ccc;
	}
	
 	#mainNav li a span{padding-left:10px;}
	
	
	#mainNav ul > li:last-child a{border:0;}
	#mainNav li li:last-child a{border-bottom:1px dashed #ccc;}
 
	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item a,#mainNav li a:active, #mainNav li li.current-menu-item a, #mainNav li.current-menu-item li a:hover, #mainNav li.current-menu-item li a:active{
	color:#555;
	}

	#mainNav li li{
	float:left;
	border:0;
	}

	#mainNav li li a, #mainNav li.current-menu-item li a, #mainNav li li.current-menu-item a{
	padding-left:40px;
	background:url(images/sub1.png) no-repeat 20px 18px;
	}

	#mainNav li li.current-menu-item a,#mainNav li li a:hover, #mainNav li.current-menu-item li a:hover{background:url(images/sub1.png) no-repeat 20px -62px;}

	#mainNav li li:last-child a{background:url(images/subLast.png) no-repeat 20px 20px;}
	#mainNav li li:last-child.current-menu-item a,#mainNav li li:last-child a:hover,#mainNav li.current-menu-item li:last-child a:hover{background:url(images/subLast.png) no-repeat 20px -65px;}

	nav div.panel{float:none;}
	
	#header{padding-left:10px;}
	
	#main{padding-top:15px;}
	section.toppage{margin:0;}
	#sidebar{padding-bottom:15px;}
	#sidebar article{padding:7px 8px;}
	
	#footer .grid,#footer ul.footnav{float:none;width:100%;text-align:center;}
	ul.footnav li{float:none;display:inline-block;}
	
	.box3 img{
max-width:100%;
}

		.box4 img{
	max-width:100%;
}
    		#topics20{
	           margin:100px 0 0 100px;
}
	
	.grid{
	float:left;
	width:32%;
	margin:10px 0 0 1%;
	}
	.grid1{
	float:left;
	width:25%;
	margin:10px 0 0 1%;
	}
	.grid2{
	float:left;
	width:49%;
	margin:10px 0 0 1%;
	}
    
    /* 見出しを中央に */
.midashiCenter{
    text-align:center;
    background-image: url("img/bg_img.png");
    background-repeat: no-repeat;
    background-size: 130%;
    font-weight:bold;
    font-size:160%;
    color: #1A8F76;
    padding-bottom:80px;
    padding-top:80px;
}

	#footer .grid img,#footer .info{float:none;}
	#footer .grid p{display:block;}
	#footer #info .info{float:none;text-align:center;}
	#footer.logo,#footer .info{width:100%;float:none;}
	#footer .logo p{float:none;display:block;	}
	#footer .logo img{float:none;padding:0;}
    
  .sp_br{
    display: none;
  }

}


@media only screen and (min-width:481px) and ( max-width:767px){
	#header{height:auto;padding-bottom:20px;}
	
	#header h1,.logo,.info{text-align:center;}
	
	.logo,.info{clear:both;width:100%;float:none;}
	
	.logo p{float:none;display:block;}
	.logo img{float:none;padding:0;}
	
    #mainNav{
	clear:both;
	width:100%;
	margin:0 auto;
	padding:0;
  border:1px solid #e4e4e4;
	border-left:0;
	border-right:0;
	}

	#mainNav a.menu{
	color:#555;
	width:100%;
	display:block;
	height:40px;
	line-height:40px;
	font-weight: bold;
	text-align:left;
	}

	#mainNav a#menu span{
	padding-left:10px;
	}
	#mainNav a.menu span:before{content:"≡ ";}
	#mainNav a.menuOpen span:before{content:"× ";}

	#mainNav a#menu:hover{cursor:pointer;}

	nav .panel{
	display:none;
	width:100%;
	position:relative;
	right:0;
	top:0;
	z-index:1;
	}
	
	#mainNav ul{margin:0;padding:0;}

  #mainNav li{
	float:none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	}

	#mainNav li a,#mainNav li.current-menu-item li a{
	color:#555;
	display: block;
	padding:15px 10px;
	text-align:left;
	border-bottom:1px dashed #ccc;
	}
	
 	#mainNav li a span{padding-left:10px;}
	
	
	#mainNav ul > li:last-child a{border:0;}
	#mainNav li li:last-child a{border-bottom:1px dashed #ccc;}
 
	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item a,#mainNav li a:active, #mainNav li li.current-menu-item a, #mainNav li.current-menu-item li a:hover, #mainNav li.current-menu-item li a:active{
	color:#555;
	}

	#mainNav li li{
	float:left;
	border:0;
	}

	#mainNav li li a, #mainNav li.current-menu-item li a, #mainNav li li.current-menu-item a{
	padding-left:40px;
	background:url(images/sub1.png) no-repeat 20px 18px;
	}

	#mainNav li li.current-menu-item a,#mainNav li li a:hover, #mainNav li.current-menu-item li a:hover{background:url(images/sub1.png) no-repeat 20px -62px;}

	#mainNav li li:last-child a{background:url(images/subLast.png) no-repeat 20px 20px;}
	#mainNav li li:last-child.current-menu-item a,#mainNav li li:last-child a:hover,#mainNav li.current-menu-item li:last-child a:hover{background:url(images/subLast.png) no-repeat 20px -65px;}

	nav div.panel{float:none;}
    
	.box img{
	float:left;
	margin-right:5px;
	}
	
	.box h3{padding-top:0;}
    
    .box3 img{
	float:left;
	margin-right:10px;
    margin-bottom: 50px;
}
	
	.box4 img{
	max-width:100%;
}

  .alignleft,.alignright,img.alignleft,img.alignright{
      float:none;
      display:block;
      margin:0 auto 10px;
    }
    
    /* 見出しを中央に */
.midashiCenter{
    text-align:center;
    background-image: url("img/bg_img.png");
    background-repeat: no-repeat;
    background-size: 200%;
    font-weight:bold;
    font-size:160%;
    color: #1A8F76;
    padding-bottom:70px;
    padding-top:70px;
}

    #footer.inner{
        clear: both;
        padding:5px 0;
    }

    .cb{
  clear: both;
}
    #footer .grid,#footer ul.footnav{float:none;width:100%;text-align:center;}
    	ul.footnav li{float:none;display:inline-block;}
}



@media only screen and (max-width:480px){
    	#header{height:auto;padding-bottom:20px;}
	
	#header h1,.logo,.info{text-align:center;}
	
	.logo,.info{clear:both;width:100%;float:none;}
	
	.logo p{float:none;display:block;}
	.logo img{float:none;padding:0;}
    
    #mainNav{
	clear:both;
	width:100%;
	margin:0 auto;
	padding:0;
  border:1px solid #e4e4e4;
	border-left:0;
	border-right:0;
	}

	#mainNav a.menu{
	color:#555;
	width:100%;
	display:block;
	height:40px;
	line-height:40px;
	font-weight: bold;
	text-align:left;
	}

	#mainNav a#menu span{
	padding-left:10px;
	}
	#mainNav a.menu span:before{content:"≡ ";}
	#mainNav a.menuOpen span:before{content:"× ";}

	#mainNav a#menu:hover{cursor:pointer;}

	nav .panel{
	display:none;
	width:100%;
	position:relative;
	right:0;
	top:0;
	z-index:1;
	}
	
	#mainNav ul{margin:0;padding:0;}

  #mainNav li{
	float:none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	}

	#mainNav li a,#mainNav li.current-menu-item li a{
	color:#555;
	display: block;
	padding:15px 10px;
	text-align:left;
	border-bottom:1px dashed #ccc;
	}
	
 	#mainNav li a span{padding-left:10px;}
	
	
	#mainNav ul > li:last-child a{border:0;}
	#mainNav li li:last-child a{border-bottom:1px dashed #ccc;}
 
	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item a,#mainNav li a:active, #mainNav li li.current-menu-item a, #mainNav li.current-menu-item li a:hover, #mainNav li.current-menu-item li a:active{
	color:#555;
	}

	#mainNav li li{
	float:left;
	border:0;
	}

	#mainNav li li a, #mainNav li.current-menu-item li a, #mainNav li li.current-menu-item a{
	padding-left:40px;
	background:url(images/sub1.png) no-repeat 20px 18px;
	}

	#mainNav li li.current-menu-item a,#mainNav li li a:hover, #mainNav li.current-menu-item li a:hover{background:url(images/sub1.png) no-repeat 20px -62px;}

	#mainNav li li:last-child a{background:url(images/subLast.png) no-repeat 20px 20px;}
	#mainNav li li:last-child.current-menu-item a,#mainNav li li:last-child a:hover,#mainNav li.current-menu-item li:last-child a:hover{background:url(images/subLast.png) no-repeat 20px -65px;}

	nav div.panel{float:none;}
    
	.grid{width:100%;margin:10px 0;}
	.grid1{width:100%;margin:10px 0;}
	.grid2{width:100%;margin:10px 0;}
	.box img{max-width:100px;}
	.box4 img{max-width:100%;}
	#mainBanner h2,#mainBanner p{font-size:80%;}
            /* 見出しを中央に */
.midashiCenter{
    text-align:center;
    background-image: url("img/bg_img.png");
    background-repeat: no-repeat;
    background-size: 300%;
    font-weight:bold;
    font-size:160%;
    color: #1A8F76;
    padding-bottom:70px;
    padding-top:70px;
}
         /*ハートの後の改行*/
    
      .alignleft,.alignright,img.alignleft,img.alignright{
      float:none;
      display:block;
      margin:0 auto 10px;
    }
    .box3 img{
    width: 100%;}
    
    ul.footnav{
float:left;
width:480px;
padding:5px 0;
}
 
    /* フッターのナビゲーション用
------------------------------------------------------------*/
    #footer.inner{
        clear: both;
        text-align: center;
        padding:5px 0;
    }

/*  -----フッターのナビゲーション用　折り返し------------------------*/
    .cb{
        clear: both;
    }
    #footer .grid,#footer ul.footnav{float:none;width:100%;text-align:center;}
    ul.footnav li{float:none;display:inline-block;}
}




/* 追加
------------------------------------------------------------*/
/* 新着情報の見出し
------------------------------------------------------------*/
.topics_semi {
    float: left;
    display: block;
    width: 95px;
    color: #fff;
    text-align: center;
    font-size: 10px;
    border-radius: 2px;
background: #1a8f76;
	margin-right:3px;
}

/* サービスの見出し
------------------------------------------------------------*/
.service H4{
    font-size: 1.3em;
    font-style: oblique;
    margin-bottom: 1pt;
}


/* お問合せボタンmidashi
------------------------------------------------------------*/
.btn-square-soft {
  display: inline-block;
  position: relative;
  text-decoration: none;
  color: #636363;
  width: 240px;
  height: 50px;
  line-height: 50px;
  border-radius: 5px;
  text-align: center;
  overflow: hidden;
  font-weight: bold;
  background: linear-gradient(#ededed 0%, #d6d6d6 100%);
  text-shadow: 1px 1px 1px rgba(255, 255, 255, 0.66);
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

.btn-square-soft:active {
  /*押したとき*/
  -webkit-transform: translateY(2px);
  transform: translateY(2px);/*沈むように*/
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.15);
  background-image: linear-gradient(#64C0AB 0%, #b3ffed 100%);/*グラデーションを明るく*/
}

/* サービスメニューのセミナー 見出し
------------------------------------------------------------*/
.seminer_title{
    float: left;
    display: block;
    width: 200px;
    color: #fff;
    text-align: center;
    font-size: 14px;
    border-radius: 2px;
background: #eb5e34;
	margin-right:10px;
}

.seminer_img{float: left;}

/* 会社情報 見出し
------------------------------------------------------------*/
.company_title{
    float: left;
    display: block;
    width: 200px;
    color: #fff;
    text-align: center;
    font-size: 14px;
    border-radius: 2px;
background: #eb5e34;
	margin-right:3px;
}

/* 見出し文字
------------------------------------------------------------*/
h4{
font-size:18px;
font-weight:bold;
padding:0px 0;
margin-bottom:5px;
}

/* 見出し文字 プライバシーポリシー
------------------------------------------------------------*/
.midashi5{
font-size:18px;
font-weight:bold;
padding:0px 0;
margin-bottom:5px;
}

.midashi6{
font-size:14px;
font-weight:bold;
padding:0px 0;
margin-bottom:5px;
}

/* プライバシーポリシー 表
------------------------------------------------------------*/
.n_poricy table {
    border: 0px none;
    width:90%;
}
.n_poricy table td.koumoku {width:70px;}

/* hrの装飾
------------------------------------------------------------*/
hr.style1{
	border-top: 5px solid #eeeeee;
}

.feature img{float:right;padding:0 0 0 20px;}

/* 画面上部へ戻る
------------------------------------------------------------*/
h2{
  text-align: center;
  margin-bottom: 30px;
}
#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 0;
  bottom: 50px;
  background: #64C0AB;
  opacity: 0.6;
  border-radius: 50%;
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -5px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}


/* お問合せを中央にする
------------------------------------------------------------*/
.contact{text-align: center}

/* サービスメニュー　コンサルティング
------------------------------------------------------------*/
/* 画像を中央に
------------------------------------------------------------*/
#n_consulting .kaisetsu{text-align: center}

#n_consulting .kaisetsu{margin:0 10px 10px 0}


.consulting04_c h4{
	border-left: solid 11px #eb5e34;
	padding:0 0 0 7px;	
}


/* 事例紹介
------------------------------------------------------------*/
/* 見出し
------------------------------------------------------------*/
.works_midashi{
    float: left;
    display: block;
    width: 100%;
    color: #eb5e34;
    text-align: center;
    font-size: 14px;
    border-radius: 2px;
background: #eeeeee;
	margin:20px 0 10px 0 ;
}

/* 書体
------------------------------------------------------------*/
/* Source Han Sans JP Bold　源の角ゴシック
------------------------------------------------------------*/
.title_bold_ja {font-family: source-han-sans-japanese, sans-serif;
font-weight: 700;
    font-style: normal;}

#maintitle h2{font-size: 2em;}

/* Source Han Sans JP Regular　源の角ゴシック
------------------------------------------------------------*/
.title_regular_ja {font-family: source-han-sans-japanese, sans-serif;
font-weight: 400;
    font-style: normal;}

#maintitle h3{font-size: 1.3em;}

/* 文字協調
------------------------------------------------------------*/
.title_topics20{
    font-weight:600 ;
    color: cadetblue;
    font-size:120%;}

.title_topics20BK{
    font-weight:600 ;
    color: #000000;
    font-size:120%;}


/* クレセントF概要紹介
------------------------------------------------------------*/
/* 背景に色
------------------------------------------------------------*/
#n_about{background-color:#eeeeee;}




/* 横並びの画像　レスポンシブル
------------------------------------------------------------*/
/* フレックスボックスの基本設定 等間隔（両端揃え）折返しあり */
[class^="flex-col"] {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

/* コンテンツ下のマージン */
.flex-child { margin-bottom: 10px; 
    display: -webkit-flex;
 display: flex;
 -webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
 align-items: center; /* 縦方向中央揃え */
}

.flex-child .img-center{text-align: center;}

/* 各カラム毎のコンテンツと疑似要素の横幅 */
.flex-col2 .flex-child { width: calc( (100% - 10px) / 2 ); }

.flex-col3::after,
.flex-col3 .flex-child { width: calc( (100% - 20px) / 3 ); }

.flex-col4::before,
.flex-col4::after,
.flex-col4 .flex-child { width: calc( (100% - 30px) / 4 ); }
	
/* 最終行は両端揃えにしない */
.flex-col3::after,
.flex-col4::before,
.flex-col4::after { content: ""; }

.flex-col4::before { order: 1; }

/* サービスに枠を付ける用 */
#n_service .flex-child{ 
    padding: 2em 2em;
    border: solid 1px #000000;}

/* ソリューションに枠を付ける用 */
#n_solution .flex-child{ 
    padding: 2em 2em;
    border: solid 1px #000000;}

/* レスポンシブ対応 */

/* 991px以下で4列 → 3列 */
@media screen and (max-width: 991px) {
	.flex-col4::after,
	.flex-col4 .flex-child { width: calc( (100% - 20px) / 3 ); }
    
    /* サービスに枠を付ける用 */
#n_service .flex-child{ 
    padding: 2em 2em;
    border: solid 1px #000000;}
}

/* 767px以下で4列・3列 → 2列 */
@media screen and (max-width: 767px) {
	.flex-col3 .flex-child,	
	.flex-col4 .flex-child { width: calc( (100% - 10px) / 2 ); }
}

/* 575px以下で全て1列 */
@media screen and (max-width: 575px) {
	.flex-col2 .flex-child,
	.flex-col3 .flex-child,
	.flex-col4 .flex-child { width: 100%; }
    
    /* サービスに枠を付ける用 */
#n_service .flex-child{ 
    padding: 2em 2em;
    border: solid 1px #000000;}
}
/* 横並びの画像　レスポンシブル　ここまで
------------------------------------------------------------*/

/* ビデオ用
------------------------------------------------------------*/



/* 動画を含むコンテナ */
@media screen and (min-width: 641px) {
/* 動画を含むコンテナ */
.video-container {
  position: relative;
  width: 100vw; /* 画面幅いっぱい */
  height: auto; /* 高さを自動調整 */
  max-width: 1913px; /* 最大幅 */
  aspect-ratio: 1913 / 712; /* 背景画像の縦横比を保持 */
  background: url(/jp/img/mainimage_nbcc_bg.png) no-repeat left center;
  background-size: cover; /* 画面いっぱいにフィット */
  overflow: hidden; /* はみ出し防止 */
}

/* 動画のスタイル */
#main_mov {
  position: absolute;
  right: 0; /* 右端に固定 */
  top: 0; /* 上端に固定 */
  width: 65%; /* 横幅は背景画像の高さに対して約65% */
  height: 100%; /* 背景画像と高さを合わせる */
  object-fit: contain; /* トリミングせずに表示 */
}

















#AboutCrescentF_mov{
    width: 50%; 
    height: auto; 
    margin:20px 25% 0px 25%;
}
}

@media screen and (max-width: 575px) {
  /* 動画を含むコンテナ */
.video-container {
  position: relative;
  width: 100vw; /* 画面幅いっぱい */
  height: auto; /* 高さを自動調整 */
  max-width: 1913px; /* 最大幅 */
  aspect-ratio: 1913 / 712; /* 背景画像の縦横比を保持 */
  background: url(/jp/img/mainimage_nbcc_bg.png) no-repeat left center;
  background-size: cover; /* 画面いっぱいにフィット */
  overflow: hidden; /* はみ出し防止 */
}

/* 動画のスタイル */
#main_mov {
  position: absolute;
  right: 0; /* 右端に固定 */
  top: 0; /* 上端に固定 */
  width: 65%; /* 横幅は背景画像の高さに対して約65% */
  height: 100%; /* 背景画像と高さを合わせる */
  object-fit: contain; /* トリミングせずに表示 */
}


#AboutCrescentF_mov{
    width: 100%; 
    height: auto; 
    margin:3px 0px 0px 0px;
    }}

/* youtubeミュート用
------------------------------------------------------------*/
.youtube {
     width: 60%;
     margin: 0 auto;
}

.youtube-area {
  position: relative;
  width: 100%; 
  padding-top: 56.25%;
}
.youtube-area iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

@media screen and (max-width: 575px) {
    .youtube {
     width: 100%;
     margin: 0 auto;
}
.youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube-area iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
    .youtube2 {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube2 iframe {
  width: 100%;
  height: 100%;
}
}


/* トップページボタン用
------------------------------------------------------------*/
*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 62.5%;
}

.btn,
a.btn,
button.btn {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

.btn--orange,
a.btn--orange {
  color: #fff;
  background-color: #108b96;
}

.btn--orange:hover,
a.btn--orange:hover {
  color: #fff;
  background: #3aa1d5;
}

a.btn--radius {
  border-radius: 100vh;
}

.btn {margin-bottom: 10px;}

.btn span{
  color: #FFF;
  position: relative;
  padding-left: 30px;
}
.btn span::before{
  content: "";
  position: absolute;
  top: 60%;
  left: 0;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  margin-top: -5px;
}

/* 画像並べる用　トップページのポイント、img_foodはソリューション全部で使用
------------------------------------------------------------*/
.img_point img{padding: 5px;
width: 200px;}

.img_food img{padding: 5px;
width: 45%;}

@media screen and (max-width: 575px) {
  .img_point img{
      padding: 5px;
      width: 45%;
    }  
      .img_food img{
      padding: 5px;
      width: 90%;
    } 
}

/* プレスリリース,ニュースリリース用
------------------------------------------------------------*/
.NewsRelease h3{
    font-size:18px;
    font-weight: bold; 
padding:10px 0 15px;
}

.NewsRelease{
    border: solid 1px #000000;
margin: 0px 0px 25px 0px;
padding: 20px;}

.NewsRelease .sage{margin-left: 20px;}

.news_dot li{
    list-style: disc;
    margin-left: 40px;
}

/*.news_dot ul{    padding-top:10px;
  padding-bottom:30px;}---*/


/* トライアル
------------------------------------------------------------*/
.trial_bg{
    background-color: #eeeeee;
    margin-bottom: 20px;
    margin-top: 20px;
    padding: 30px;
}

.trial_bg2{
    background-color: #108b96;
    margin-bottom: 20px;
    margin-top: 20px;
    padding: 30px;
    color: #FFF;
}
.trial_bg2 h3{font-size: 1.3em;}

.number{
    font-size: 2.5em;
    color: #999999;
}

.triangle-bottom {
  display: inline-block;
  border-style: solid;
  border-width: 50px 120px 0 120px;
  border-color: #999999 transparent transparent transparent;
}

.traial_line {
   border-bottom: 1px solid #999;
   margin-top: 0px;       /* 上線の外側の余白はナシ */
   padding-top: 0px;      /* 上線の内側の余白はナシ */
   margin-bottom: 0.3em;  /* 下線の外側の余白量 */
   padding-bottom: 0.3em; /* 下線の内側の余白量 */
}

.font_red{
    font-size: 20px;    /* 文字サイズ指定 */
    color: #e83820;     /* 文字色指定 */
}


/* 製品情報
------------------------------------------------------------*/
/* 製品情報 の表
------------------------------------------------------------*/


table {
  border-collapse: collapse;
  width: 100%;
}

th, td {
  border: 1px solid #bbb;
  padding: 8px;
  text-align: center;
}

th:first-child,
td:first-child {
  background-color: #eee;
  color: #000;
}

/* クレセントベースの表は横幅１４０％に設定 */
.item_list_cb table {
  border-collapse: collapse;
  width: 140%;
}



/* 画面に入りきらない場合スクロールバーを表示する　ここから*/
.table-wrapper {
 overflow-x: auto;  /* 横方向のスクロールバーを表示するために必要 */
  max-width: 100%; /* 横幅が親要素に収まるように制約を設ける */
}
/* 画面に入りきらない場合スクロールバーを表示する　ここまで　*/

/* 製品情報 の表ここまで
------------------------------------------------------------*/








/* 製品情報 クレセントベースの「ポイント」部分のリストの書式
------------------------------------------------------------*/
item_cb_ul ul {
            list-style: disc !important;
            margin: 0 0 10px 20px;
        }

item_cb_ul li {
            margin: 5px 0;
        }

.show-marker {
    list-style: disc; /* 特定のクラスに対してリストマーカーを表示 */
    margin-left: 20px; /* マーカーの左側にスペースを設ける場合 */
}


/* 製品情報 通常2カラムだが画面サイズが小さいと1カラムになる
------------------------------------------------------------*/
    .container {
      max-width: 1400px; /* 最大幅を設定して画面が広い場合はコンテンツを中央寄せにする */
      margin: 0 auto;
      display: flex;
      flex-wrap: wrap;
    }

    .column {
      box-sizing: border-box;
      padding: 10px;
    }

    /* 画面幅が700px以上の場合 */
    @media (min-width: 700px) {
      .column {
        width: 50%; /* 2カラムの場合は幅を50%にする */
      }
    }

    /* 画面幅が700px以下の場合 */
    @media (max-width: 700px) {
      .column {
        width: 100%; /* 1カラムの場合は幅を100%にする */
      }
    }

    /* 文字を太字に */
  .bold-first-line {
    font-weight: bold;
  }
  .font-large {
font-size: 1.4em;
        }

/* メルマガ
------------------------------------------------------------*/
  .text-bold {font-weight:bold;}


/* メディア情報 通常３カラムだが画面サイズが小さいと1カラムになる
------------------------------------------------------------*/
/* グリッド3カラム 自動配置 */
.contents_three {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  width: 100%;
  max-width: 100%;
}
 
.contents_three article {
  background-color: #eee;
  padding: 10px;
}
 
.contents_three img {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 999px) {
  .contents_three {
      grid-template-columns: 1fr;
  }
}

 /* 会社概要　メディア情報へのボタン
------------------------------------------------------------*/
.custom-button {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  border: 1px solid #ddd;
  border-radius: 25px;
  background-color: white;
  font-size: 16px;
  color: #333;
  text-decoration: none;
  font-weight: normal;
  transition: all 0.3s ease;
}

.custom-button:hover {
  background-color: #f5f5f5;
}

.custom-button .arrow {
  margin-left: 8px;
  color: #c00;
  font-size: 18px;
}