@charset "utf-8";
/*
Theme Name: geogashi
Theme URI:
Description: geogashi
Version: 1.0
*/

/* =========================================================
 * common
========================================================= */
body {
  height: 100%;
	font-size:14px;bt
	font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "MS PGothic", sans-serif;
	line-height: 1.4;
	color: #212121;
	background:#fff;
	position:relative;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
}
p{
  line-height: 2.4;
}

a {
  color: #000000;
  text-decoration: none;
}

/*
.overlay{
	background:url(../images/test-fieldworks.jpg) no-repeat center top;
	height:8000px;
	width:1440px;
	position:absolute;
	margin:auto;
	top:0;
	left:0;
	right:0;
	z-index:100;
	opacity:0.3;
}
*/

/* =========================================================
 * font
========================================================= */
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W0); font-weight: 100;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W1); font-weight: 200;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W2); font-weight: 300;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W3); font-weight: 400;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W4); font-weight: 500;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W5); font-weight: 600;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W6); font-weight: 700;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W7); font-weight: 800;}
@font-face { font-family: "Hiragino Sans"; src: local(HiraginoSans-W8); font-weight: 900;}
@font-face { font-family: "Hiragino Sans W9"; src: local(HiraginoSans-W9); font-weight: 900;}
/*div { font-family: "Hiragino Sans";}*/
*{
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-kerning:normal;
  -moz-font-feature-settings:"palt" 1;
  -webkit-font-feature-settings:"palt" 1;
  font-feature-settings:"palt" 1;
}
@font-face {
  font-family: 'geo';
  src: url('../font/geo.eot?53520861');
  src: url('../font/geo.eot?53520861#iefix') format('embedded-opentype'),
     url('../font/geo.woff?53520861') format('woff'),
     url('../font/geo.ttf?53520861') format('truetype'),
     url('../font/geo.svg?53520861#geo') format('svg');
  font-weight: normal;
  font-style: normal;
}
.icon{
  font-family: geo;
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  font-size: 16px;
}
.icon-back{content:&#xe800;}
.icon-geo{content:&#xe801;}
.icon-info{content:&#xe802;}
.icon-left{content:&#xe803;}
.icon-mail{content:&#xe804;}
.icon-menu{content:&#xe805;}
.icon-more{content:&#xe806;}
.icon-point{content:&#xe807;}
.icon-right{content:&#xe808;}
.icon-top{content:&#xe809;}

.svg{
  display: inline-block;
  vertical-align: middle;
}


/*font-family: 'Montserrat', sans-serif;*/

/*==============================================================
// header
==============================================================*/
header{
  position: fixed;
  z-index:100;
  background: #fff;
  width: 100%;
}
.header{
  height: 125px;
}
.header_top{
  padding: 20px  45px 44px 60px;
}
.section{
  max-width:1400px;
  margin: auto;
}

.logo{
  float: left;
}
.logo a{
  background: url("../images/svg/logomark.svg") no-repeat;
  width: 160px;
  height: 24px;
}
.menu_sub{
  float: right;
  font-family: 'Montserrat', sans-serif;
}
.icon-geogashi{
  background: url("../images/svg/geogashi-r.svg") no-repeat;
  background-size: 20px 24px;
  width: 20px;
  height: 24px;
  vertical-align: -8px;
  margin-right: 10px;
}
.onlineshop{
  color:#DD3300;
  width: 131px;
  display: inline-block;
}
.menu_lang{
  display: inline-block;
  border-left:solid 1px #eeeeee;
  line-height: 1;
  padding: 6px 15px 0 20px;
  height: 24px;
}
.menu_lang a{
  margin-right: 16px;
  color: #999;
}
.menu_lang a:last-child{
  margin-right: 0;
}
.menu_lang a.active{
  color: #000;
  border-bottom: solid 2px #000;
}

menu{
  clear:both;
  border-top:solid 1px #eeeeee;
  text-align: center;
  padding: 20px 0 16px;
  border-bottom: solid 5px #eeeeee;
    font-weight: 900;
}
menu a:not(:last-child){
  margin-right: 30px;
}
/*==============================================================
// footer
==============================================================*/
footer{
  overflow-x:hidden;
}
.footer_wrap{
  clear: both;
  text-align: center;
  background:url(../images/svg/footer-element.svg) no-repeat;
  background-size: 110vw auto;
  background-position: left 20px;
  margin: 0 -10px;
}
.footer_menu {
  padding-bottom: 68px;
}
.footer_menu a,
.footer_menu p{
  display: inline-block;
}
.footer_menu a{
  margin-right: 40px;
  font-weight: 700;
}
.footer_menu p{
  padding-left: 40px;
  border-left: solid 1px #eee;
}
.footer_bottom{
  position: relative;
  width: 100vw;
}
.footer_bottom a{
  color: #fff;
}
.footer_sns a:not(:last-child){
  margin-right: 16px;
}
.footer_bottom_inner{
  padding: 38px 0 44px;
}
.footer_bottom .copyright{
  position: absolute;
  left:85px;
  top:30px;
  color:#999999;
  font-weight: 500;
}
.footer .pagetop{
  background: url(../images/svg/pagetop.svg) no-repeat;
  width:40px;
  height:40px;
  display: block;
  position: absolute;
  right:90px;
  top:20px;
  background-size: 40px 40px;
}
/*==============================================================
// common
==============================================================*/
.is_pc{
  display: block;
}
.is_mobile{
  display: none;
}
.body{
  box-sizing: border-box;
}
.main_visual{
  position: relative;
  width: 100%;
  height: calc(100vh - 125px);
  margin: auto;
}
.main_visual .main_visual_image{
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/home-main.jpg) no-repeat;
  background-size: cover;
  background-position: center center;
}
.main_visual .scroll{
  position: absolute;
  right:60px;
  bottom:60px;
}
.icon_geo{
  display: block;
  width: 41px;
  height: 51px;
  background: url("../images/svg/geogashi-r.svg") no-repeat;
  background-size: 41px 51px;
  position: absolute;
  bottom:-60px;
  left:60px;
}
.scroll{
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/svg/scroll-down.svg) no-repeat;
  background-size: 40px 40px;
}
.content{
  padding-top: 125px;
}
.articles,
.content_header{
  max-width: 1440px;
  margin: auto;
}
.content_header{
  height: 325px;
  position: relative;
}
.content_header.nofix{
  height: auto;
}
.content_header.nofix p{
  max-width: 700px;
  height: 240px;
  margin: -70px auto 0;
  font-size: 20px;
  line-height: 38px;
}
.content_header .icon_geo{
  bottom:-30px;
  left:80px;
  z-index: 10;
}
.content_header h2{
  text-align: center;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro";
  height: 330px;
  display: table;
  width: 100%;
    font-size: 48px;
}
.content_header h2 span{
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle;
}
.articles{
  overflow: hidden;
  padding: 0 20px;
  margin: 0 auto;
}
.article_thumb{
  /*width: 453px;*/
  width: calc(33.3% - 20px);
  float: left;
  padding:0 10px;
  margin-bottom: 50px;
}
.articles_mv{
  overflow: hidden;
  padding: 0 20px;
  margin: -120px auto 0 auto;
}
.lead_mv{
  /*width: 453px;*/
  width: calc(33.3% - 10px);
  float: none;
  padding:0;
  margin: 0 auto 100px auto;
}
article:nth-of-type(3n) .article_thumb{
  margin-right: 0;
}
.article_img{
  width:100%;
  /*height: 284px;*/
  position: relative;
  display: block;
  overflow: hidden;
  background: #ccc;
}
.article_img:before {
  content:"";
  display: block;
  padding-top: 56.25%;
}
.article_img img{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width:120%;
  margin: 0 0 0 -10%;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -ms-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}

.article_img iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

.article_title{
  text-align: center;
  font-weight: 700;
  height: 80px;
  line-height: 100px;
    font-size: 20px;
}
.single_subtitle,
.article_subtitle{
  text-align: center;
  color:#dd3300;
  font-weight: 700;
    font-size: 16px;
}
.article_subtitle{
  height:50px;
}
.article_desc{
  overflow: hidden;
  margin-bottom: 10px;
  height:76px;
}
.article_desc p{
  text-align: justify;
  font-weight: 500;
  padding: 0 60px;
  line-height: 28px;
  display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.frame_wrap{
  max-width: 1280px;
  margin: auto;
}
/*==============================================================
// btn
==============================================================*/
.btn_box{
  clear: both;
  display: block;
  text-align: center;
  padding: 30px 0;
}
.btn_box a{
  display: inline-block;
  border: solid 3px #eeeeee;
  border-radius: 30px;
  height: 60px;
  width: 161px;
  line-height: 60px;
}

.single_body_header .btn_box.single_onlineshop{
  width: 700px;
  margin:  0 auto;
  position: relative;
}

.btn_box.single_onlineshop a span::before,
.btn_box a span::before{
  display: inline-block;
  content: "";
}
.btn_box a span::before{
  background: url(../images/btn-icon-detail.png) no-repeat;
  width: 13px;
  height: 13px;
  margin-right: 11px;
  vertical-align: -1px;
}

.btn_box a:hover span::before{
  background: url(../images/btn-icon-detail-hover.png) no-repeat;
}
.btn_box.single_contact a,
.btn_box.single_onlineshop a {
  width:100%;
    font-size:20px;
}
.btn_box.single_onlineshop a{
  font-family: 'Montserrat', sans-serif;
  color: #dd3300;
  border-color:#dd3300;
}
.btn_box.single_contact {
  padding-bottom: 10px;
}
.btn_box.single_contact a{
  color: #3399ff;
  border-color:#3399ff;
  font-weight: 700;
}

.btn_box.single_contact a span{
    font-size: 20px;
}
.btn_box.single_onlineshop a span::before{
  background: url(../images/svg/geogashi-r.svg) no-repeat;
  background-size: 26px 32px;
  width: 26px;
  height: 32px;
  vertical-align: middle;
}

.btn_box.back a{
  font-weight: 500;
    font-size: 14px;
}
.btn_box.back a span{
    margin-right: 12px;
}
.btn_box.privacy a span,
.btn_box.single_contact a span{
    margin-right: 8px;
}
.btn_box.privacy a span,
.btn_box.back a span{
    font-size: 12px;
}

.btn_box.privacy a {
  width:224px;
}

.btn_box.privacy a span:before,
.btn_box.single_contact a span:before,
.btn_box.back a span:before{
  display: none;
}

.single-blog .btn_box.back ,
.single-fieldworks .btn_box.back ,
.single-geogashi .btn_box.back {
  margin-bottom: 80px;
}
/*==============================================================
// top
==============================================================*/
.main_visual_logo{
  display: block;
  width: 700px;
  height: 105px;
  background: url(../images/logomark.png) no-repeat;
  position: absolute;
  right:0;
  bottom:0;
  left:0;
  top:-10px;
  margin: auto;
}
.single_title,
.top_message,
.top_h2{
  clear: both;
  text-align: center;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro";
  font-size: 32px;
}
.top_h2{
  line-height: 390px;
  height: 390px;
}
.top_about {
  padding: 147px 0 70px;
}
.top_about h3{
  margin-bottom: 67px;
  text-align: center;
  font-weight: 700;
    font-size: 20px;
}
.top_about p{
  max-width: 970px;
  margin: auto;
  text-align: justify;
  line-height: 36px;
    font-size: 18px;
}

.top_about_columns{
  width: 699px;
  margin: auto;
}
.top_about_column{
  float: left;
  width: 203px;
  text-align: center;
}
.top_about_column:not(:last-child){
  margin-right: 45px;
}
.top_about_column strong{
  display: block;
  line-height: 100px;
  height: 93px;
    font-size: 20px;
}
.top_about_column p{
  text-align: justify;
  line-height: 28px;
}
.top_about_column img{
  width:180px;
  height: 175px;
}
.top_message{
  line-height: 410px;
  height: 540px;
}
.top_message strong{
  font-weight: 400;
}

.page-top .article_title{
  text-align: center;
  font-weight: 700;
  height: 95px;
  line-height: 100px;
    font-size: 20px;
}
.page-top .articles{
  padding: 0;
}

/*==============================================================
// geogashi
==============================================================*/
.page-fieldworks footer,
.page-geogashi footer{
  margin-top: 100px;
}
/*==============================================================
// fieldworks
==============================================================*/
.fieldworks_article{
  max-width: 1280px;
  margin: auto;
  text-align: center;
  margin-bottom: 53px;
    font-size: 16px;
}
.fieldworks_title,
.fieldworks_area,
.fieldworks_status{
  font-weight: 700;
}
.fieldworks_status,
.fieldworks_desc{
  width: 700px;
  margin: auto;
}
.fieldworks_img img{
  margin-bottom: 45px;
  width: 100%;
}
.fieldworks_title{
  margin-bottom: 15px;
    font-size: 20px;
}
.fieldworks_area{
  color: #999;
  margin-bottom: 35px;
}
.fieldworks_status{
  color: #fff;
  margin-bottom: 30px;
  text-align: center;
    font-size: 16px;
}
.fieldworks_status span{
  display: block;
  height: 78px;
  line-height: 78px;
}
.choices_1{
  background: #3399ff;
}
.choices_2{
  background: #dd3300;
}
.choices_3{
  background: #bbbbbb;
}
.fieldworks_desc p{
  text-align: left;
  line-height: 32px;
}
.single-fieldworks .single_subtitle{
  color: #999;
}
/*==============================================================
// page navi
==============================================================*/
.page_navi,
.single_page_navi{
  max-width: 1280px;
  margin: auto;
}
.page_navi,
.single_page_navi,
.single_header{
  height: 76px;
  display:flex;
  justify-content: center;
  clear: both;
}
.single_page_navi,
.single_header{
  display:flex;
  justify-content: center;
}
.page_navi_previous,
.page_navi_next,
.page_navi_center,
.page_navi .single_page_navi_previous,
.page_navi .single_page_navi_next,
.single_page_navi div,
.single_header div{
  font-weight: 500;
  display: table;
  height: 100%;
}
.single_page_navi .single_page_navi_previous a i,
.single_page_navi .single_page_navi_next a i{
  font-style: normal;
}
.single_page_navi div,
.single_header div{
  width:calc(100% / 3);
}
.page_navi_previous,
.single_page_navi_previous,
.single_header_number{
  text-align: left;
}
.page_navi_center,
.single_page_navi_title,
.single_header_title{
  text-align: center;
}
.wp-pagenavi,
.page_navi_center span,
.single_page_navi_title span,
.single_header_title span{
  display: table-cell;
  height: 100%;
  vertical-align: middle;
}
.single_page_navi_next,
.single_header_address{
  text-align: right;
}
.page_navi_next .icon-right{
  float: right;
  padding-top: 17px;
}
.page_navi .page_navi_center .wp-pagenavi span,
.page_navi .page_navi_center .wp-pagenavi a{
  display: inline;
  margin: 20px;
}
.page_navi_center{
  width: 50%;
    font-family: 'Montserrat', sans-serif;
}
.page_navi_previous,
.page_navi_next{
  width: 25%;
}
.page_navi,
.single_page_navi{
  border-top: solid 1px #eeeeee;
  border-bottom: solid 3px #eeeeee;
  margin-bottom: 160px;
}
.page_navi div a,
.single_page_navi div a{
  font-weight: 700;
  display: table-cell;
  width: 90%;
  height: 100%;
  vertical-align: middle;
}
.single_header_number span,
.single_header_address span,
.page_navi_next span,
.page_navi_previous span,{
  vertical-align: middle;
  display: table-cell;
  height: 100%;
}
.page_navi_next span,
.page_navi_previous span,
.single_page_navi .single_page_navi_previous span,
.single_page_navi .single_page_navi_next span{
  font-size: 30px;
}
.single_header_number span,
.page_navi_previous span,
.single_page_navi .single_page_navi_previous span{
  padding-left: 40px;
}
.single_header_address span,
.page_navi_next span,
.single_page_navi .single_page_navi_next span{
  padding-right: 40px;
}
.single_header_number span,
.single_header_address span{
	display:table-cell;
	vertical-align:middle;
}
.page_navi .page_navi_center div a,
.page_navi .page_navi_center div span{
  width: 60px;
  display: inline-block;
  font-weight: 500;
    font-size: 32px;
}
.page_navi .page_navi_center{
  text-align: center;
}
.page_navi_center div span{
  color: #cccccc;
}
.single_page_navi .single_page_navi_previous i,
.single_page_navi .single_page_navi_previous span,
.single_page_navi .single_page_navi_next i,
.single_page_navi .single_page_navi_next span{
	display:inline;
}
.single_page_navi .single_page_navi_next{
	text-align:right;
}
.single_page_navi .single_page_navi_previous span,
.single_page_navi .single_page_navi_next span{
	vertical-align: -5px;
}

	
/*==============================================================
// single content link
==============================================================*/
.links span a,
.single_content p a{
  border-bottom:2px solid #222;
  padding-bottom: 2px;
}

/*==============================================================
// single content
==============================================================*/
.single-geogashi .main_visual,
.single-fieldworks .main_visual,
.single-blog .main_visual{
  height: calc(100vh - 125px - 76px);
}
.single_content p iframe,
.single_content p img{
  width: 700px;
}
.single_content ul,
.single_content ol,
.single_content dl{
  margin-bottom: 80px;
  text-align: left;
}
.single_content ul,
.single_content ol{
    font-size: 20px;
}
.single_content ol li,
.single_content ul li,
.single_content dl dd{
  padding: 20px 0;
  border-bottom: solid 1px #eeeeee;
}
.single_content ol{
  counter-reset:number;
  list-style:none;
  padding:0;
}
.single_content ol li:before{
  counter-increment: number;
  content: counter(number);
  font-weight: 900;
  margin-right: 10px;
    font-family: 'Montserrat', sans-serif;
}
.single_content dl dd p{
  margin-bottom: 0;
}
.single_content dl dd span{
  display: inline-block;
  width:168px;
}
.single_content blockquote{
  padding: 40px;
  background: #f7f7f7;
  margin-bottom: 40px;
}
.single_content p img,
.single_content blockquote p:last-child{
  margin-bottom: 0;
}
/*==============================================================
// fieldworks single
==============================================================*/
.single-fieldworks .single_lede{
  padding-top: 80px;
}
.single-fieldworks .fieldworks_status{
  padding-top: 100px;
}
/*==============================================================
// geogashi single
==============================================================*/
.single-geogashi .main_visual,
.single-geogashi .main_visual_image{
  height: calc(100vh - 201px);
}
.icon-point{
  color: #dd3300;
  margin-right: 6px;
}
.single_body_header{
  padding-top: 90px;
}
.single_body{
  max-width: 700px;
  margin: auto;
  border-top: solid 1px #eee;
}
.single_title{
  margin-bottom: 28px;
    font-size: 48px;
}
.single_subtitle{
  padding-bottom: 36px;
}
.single_quarity {
  padding-top: 40px;
}
.single_quarity p{
  padding: 0 40px 32px;
  border-bottom: solid 1px #eee;
  line-height: 28px;
}
.single_quarity p:before{
  content: "";
  display: block;
  margin: auto;
  width: 62px;
  height: 27px;
  background: url(../images/svg/detail-JP.svg) no-repeat;
  background-size: 62px 27px;
  margin-bottom: 24px;
}
.single_lede p,
.single_content p{
  line-height: 40px;
  text-align: justify;
    font-size: 20px;
}
.single_lede{
  padding: 90px 0 60px;
}
.single_content p,
.single-geogashi .single_content p img{
  margin-bottom: 60px;
}
.single_map{
  margin-bottom: 60px;
}
#map_canvas{
  height: 600px;
  width: 100%;
}
.sns_box {
  text-align: center;
}
.sns_box .sns{
  display: inline-block;
}
.sns_box .sns > * {
	vertical-align: bottom !important;
}
/*==============================================================
// blog
==============================================================*/
.frames{
  float:right;
}
.frame_left,
.frame_right{
  width:25%;
}
.frame_center{
  width:50%;
}
.frame_right{
  float:left;
}
.frame_left{
  height: 100px;
}
.side{
  padding: 325px 40px 0;
}
.side_list{
  padding:40px 20px 0;
  font-weight: 900;
  border-top: solid 5px #eee;
}
.side_list li{
  margin-bottom: 40px;
  list-style: none;
}
.blog_articles{
  margin-bottom: 160px;
}
.blog_article{
  text-align: center;
  padding: 40px 0 60px;
  border-top: solid 5px #eee;
}
.blog_article.noentry{
	padding-top:100px;
	padding-bottom:100px;
}
.blog_img img{
  width: 100%;
  max-width: 700px;
}
.blog_title{
  font-weight: 900;
  margin-bottom: 20px;
    font-size: 20px;
}
.blog_category{
  font-weight: 900;
  color: #999;
  margin-bottom: 40px;
    font-size: 16px;
}
.blog_time{
  font-family: 'Montserrat', sans-serif;
  height: 90px;
  color: #999;
  line-height: 90px;
    font-size: 14px;
}
.blog_desc{
  text-align: left;
  line-height: 32px;
    font-size: 16px;
}
.single-blog .tags{
  margin-bottom: 60px;
}
/*==============================================================
// tag links
==============================================================*/
.tags{
  text-align: left;
}
.tags li {
  display: inline-block;
  margin: 0 30px 20px 0;
}
.tags li a{
  display: inline-block;
  background:#eeeeee;
  border-radius: 30px;
  height: 54px;
  line-height: 54px;
  padding: 0 30px;
}

.links {
  margin-bottom: 80px;
}
.links ul{
  border-top: solid 1px #eee;
  text-align: left;
}
.links li{
  padding: 30px 0;
  border-bottom: solid 1px #eee;
}
.links li span,
.links li strong{
  display: inline-block;
  width: 49.5%;
  vertical-align: middle;
}
.links li strong{
  text-align: left;
}
.links li span{
  text-align: right;
}
/*==============================================================
// classrooms
==============================================================*/
.page-classrooms .side{
  padding-top: 500px;
}
.page-classrooms .single_content p,
.page-classrooms .single_content dl {
  font-size: 16px;
}
.page-classrooms .single_content dl dt,
.page-classrooms .single_content .hr{
  display: block;
  text-align: left;
  font-weight: 700;
  padding: 20px 0;
    font-size: 16px;
}
.page-classrooms .single_content dl dd{
  padding: 20px 0;
}
.page-classrooms .single_content dl dt{
  border-bottom: solid 1px #eeeeee;
}
.page-classrooms .development .single_content ul {
  padding: 20px 0;
  margin-bottom: 0;
  border-top: solid 1px #eeeeee;
}
.page-classrooms .development .single_content ul li{
  border-bottom: none;
  padding: 6px 0;;
    font-size: 16px;
}
.page-classrooms .development .single_content ul li span{
  display: inline-block;
  width:168px;
}
.page-classrooms .development .single_content ul li img{
  margin-bottom: 0;
}
.page-classrooms .single_content img{
  margin-bottom: 80px;
  width: 100%;
}

/*==============================================================
// about
==============================================================*/
.page-about .side{
  padding-top: 500px;
}
.page-about .blog_articles{
  border-top: solid 5px #eee;
}
.page-about .blog_articles:not(:last-child){
  margin-bottom: 0;
}
.page-about .blog_articles h3{
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  padding: 40px 0;
}
.page-about .blog_article{
  border-top: solid 1px #eee;
}
.page-about .blog_article h1{
  font-size: 16px;
}
.page-about .blog_article .single_content p{
  font-size: 16px;
  line-height: 32px;
}
.page-about .blog_article .blog_img{
  margin-bottom: 50px;
}
#about3 .blog_article,
#about3 .blog_article .blog_img{
  margin-bottom: 0;
}
#about2 .blog_article {
  padding-bottom: 0;
}

/*==============================================================
// contact
==============================================================*/
.page-contact .single_body{
  padding-top: 0;
}
.page-contact .btn_box{
  padding: 0 0 80px;
}
.page-contact .text{
  font-size: 16px;
  line-height: 32px;
  margin-bottom: 80px;
}
.page-contact .privacypolicy{
  padding: 80px 0 140px;
  border-top:solid 1px #eee;
}
.page-contact .privacypolicy h3{
  font-weight: 700;
  text-align: center;
  margin-bottom: 40px;
}
.page-contact .privacypolicy p{
  font-size: 14px;
}
/*==============================================================
// category tag
==============================================================*/
.page-cagtgrory .side{
  padding-top: 466px;
}
.page-cagtgrory .content_header{
  padding-top: 140px;
  text-align: center;
}
.page-cagtgrory .content_header h2{
  line-height: 1;
}
.page-cagtgrory .blog_subtitle{
	position:absolute;
	top: 0;
	right: 0;
	left: 0;
	margin: auto;
	padding-top: 190px;
}
.page-cagtgrory .closs span::before,
.page-cagtgrory .closs span::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 220px auto 0;
  width: 44px;
  height: 2px;
  content: "";
  background-color: #333;
  transition: all 0.8s ease-in-out;
}

.page-cagtgrory .closs span::before {
  top: 0;
  transform: rotate(315deg);
}

.page-cagtgrory .closs span::after {
  top: 0;
  transform: rotate(-315deg);
}
.page-cagtgrory .blog_subtitle .hr{
  padding: 68px 0 10px;
  font-family: 'Montserrat', sans-serif;
}
.page-cagtgrory .blog_subtitle .hr,
.page-cagtgrory .blog_subtitle .blog_category{
  color:#dd3300;
}
.page-tag .blog_subtitle .hr,
.page-tag .blog_subtitle .blog_category{
  color:#3399ff;
}
.page-cagtgrory .blog_subtitle .blog_category{
  font-size: 32px;
  font-weight: 500;
}


/*---------------------------------------------------------------------------------------------------
// for PC
---------------------------------------------------------------------------------------------------*/
@media only screen and (min-width: 1170px) {
}

/*---------------------------------------------------------------------------------------------------
// for PC AND TABLET
---------------------------------------------------------------------------------------------------*/
@media only screen and (min-width: 768px) {

  a {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
  }
  .footer_menu a:hover,
  .header a:hover{
      color: #dd3300;
      font-weight: 900;
  }
  .footer_sns a:hover{
    border-bottom:solid 1px #fff;
      -webkit-transition: all 0s;
      -moz-transition: all 0s;
      -ms-transition: all 0s;
      -o-transition: all 0s;
      transition: all 0s;
  }
  a.article_img:hover img{
    -webkit-transform: scale(1.3);
    -moz-transform: scale(1.3);
    -o-transform: scale(1.3);
    -ms-transform: scale(1.3);
    transform: scale(1.3);
  }
  .btn_box a:hover{
    background: #222;
    color: #fff;
    border-color:#222;
  }
  .btn_box.single_contact a:hover{
    background: #3399ff;
    border-color:#3399ff;
    color: #fff;
  }
  .btn_box.single_onlineshop a:hover{
    background: #dd3300;
    border-color:#dd3300;
    color: #fff;
  }
  .links span a:hover,
  .single_content p a:hover{
    border-bottom:2px solid #dd3300;
    color:#dd3300;
  }
  .tags li a:hover{
    color: #fff;
    background: #333;
  }

  .page-blog .content,
  .page-classrooms .content,
  .page-about .content{
    overflow: hidden;
  }
}

/*---------------------------------------------------------------------------------------------------
// for TABLET
---------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 1169px) and (min-width: 768px) {
}

/*---------------------------------------------------------------------------------------------------
// for SMARTPHONE
---------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 767px) {

  body{
    font-size: 24px;
  }
  .is_mobile{
    display: block;
  }
  .is_pc,
  .frame_left{
    display: none;
  }
  .frame_center{
    width: 90%;
    margin: auto;
    float: none;
  }


  /********************************************
  // font
  ********************************************/
  .single_title,
  .content_header h2{
    font-size: 60px;
  }
  .page-cagtgrory .blog_subtitle .blog_category,
  .page_navi .page_navi_center div a,
  .page_navi .page_navi_center div span,
  .single_title,
  .top_message,
  .top_h2{
    font-size: 48px;
  }
  .page_navi_next span,
  .page_navi_previous span,
  .single_page_navi .single_page_navi_previous span,
  .single_page_navi .single_page_navi_next span{
    font-size: 45px;
  }
  .page-about .blog_articles h3{
    font-size: 34px;
  }
  .content_header.nofix p,
  .page-about .blog_articles h3,
  .blog_title,
  .single_lede p,
  .single_content p,
  .single_content ul,
  .single_content ol,
  .fieldworks_title,
  .page-top .article_title,
  .top_about h3,
  .top_about_column strong,
  .btn_box.single_contact a span,
  .btn_box.single_contact a,
  .btn_box.single_onlineshop a,
  .article_title{
    font-size: 30px;
  }
  .fieldworks_article,
  .top_about p{
    font-size: 27px;
  }
  .page-about .blog_article h1,
  .page_navi .page_navi_center div a,
  .page_navi .page_navi_center div span,
  .blog_desc p,
  .fieldworks_area,
  .single_subtitle,
  .article_subtitle,
  .page-contact .text,
  .page-about .blog_article .single_content p,
  .page-about .blog_article h1,
  .page-classrooms .development .single_content ul li,
  .page-classrooms .single_content dl dt,
  .page-classrooms .single_content .hr,
  .page-classrooms .single_content p,
  .page-classrooms .single_content dl,
  .blog_category,
  .fieldworks_status{
    font-size: 24px;
  }
  .page-about .blog_article .single_content p{
    font-size: 21px;
  }
  .blog_desc,
  .blog_time,
  .btn_box.back a{
    font-size: 21px;
  }

  .page-classrooms .single_content dl,
  .page-classrooms .single_content dl dt,
  .page-classrooms .single_content .hr{
    font-size: 19px;
  }
  .top_about_column p,
  .page-contact .privacypolicy p,
  .btn_box.privacy a span,
  .btn_box.back a span{
    font-size: 18px;
  }
  .btn_box.back a,
  .btn_box.privacy a span,
  .btn_box.back a span,
  .fieldworks_status,{
    font-size: 16px;
  }

  .content_header.nofix p,
  .single_lede p,
  .single_content p,
  .article_desc p{
    line-height: 54px;
  }
  .top_about p,
  .fieldworks_desc p,
  .page-about .blog_article .single_content p{
    line-height: 48px;
  }
  .single_quarity p{
    line-height: 42px;
  }

  /***************************/
  .header_menu_mobile a{
    font-size: 40px;
  }
  .btn_box.single_contact a,
  .btn_box.single_onlineshop a{
    font-size: 32px;
  }
  .btn_box a{
    font-size: 24px;
  }
  .single_page_navi_title,
  .single_page_navi_next,
  .single_page_navi_previous,
  .single_header_number,
  .single_header_title,
  .single_header_address{
    font-size: 16px;
  }


  .single_quarity p:before{
    width: 80px;
    height: 34px;
    background-size: 80px 34px;
  }

  /********************************************
  // content
  ********************************************/
  .btn_box a{
    border-radius: 40px;
    height: 80px;
    line-height: 74px;
  }
  .scroll{
    width: 80px;
    height: 80px;
    background-size: 80px 80px;
  }
  .icon_geo{
    width: 72px;
    height: 90px;
    background-size: 72px 90px;
  }
  .footer .pagetop{
    width: 80px;
    height: 80px;
    background-size: 80px 80px;
    right: 40px;
  }
  .page_navi,
  .single_page_navi{
    margin: 0 0 80px;
  }
  .page_navi_next .icon-right{
    padding-top: 7px;
  }
  .links li span,
  .links li strong{
      width: 49%;
      text-align: left;
  }
  .content_header.nofix p{
    height: auto;
    margin-bottom: 40px;
  }
  .fieldworks_status span{
    height: 100px;
    line-height: 100px;
  }
  .onlineshop{
    width: 185px;
  }
  .content{
    padding-top: 84px;
  }
	
  .articles_mv{
    overflow: hidden;
    padding: 0;
    margin: -100px auto 0 auto;
  }
  .lead_mv{
    width: 100%;
    float: none;
    padding:0;
    margin: 0 auto 150px auto;
  }
	
  .articles{
    margin: 0;
    padding: 0 40px;
  }
  .article_thumb{
    width: auto;
    float: none;
    padding: 0;
  }
  .article_desc{
    height: auto;
  }
  .article_desc p{
    line-height: 36px;
    display: block;
    -webkit-box-orient: inline-axis;
    -webkit-line-clamp: 10;
  }
  .btn_box a{
    width: 240px;
  }
  .btn_box a span::before{
    vertical-align: 2px;
  }
  .btn_box.back a,
  .btn_box.privacy a span, .btn_box.back a span{
    vertical-align: 2px;
  }
  .btn_box.privacy a{
    width: 360px;
  }
  .single_page_navi .single_page_navi_previous a i,
  .single_page_navi .single_page_navi_next a i{
    display: none;
  }
  .single_header_address span,
  .page_navi_next span,
  .single_page_navi .single_page_navi_next span{
    padding-right: 33px;
  }
  .single_header_number span,
  .page_navi_previous span,
  .single_page_navi .single_page_navi_previous span{
    padding-left: 33px;
  }
  /********************************************
  // header
  ********************************************/
  .header{
    height: 84px;
    position: relative;
    width: 100vw;
  }
  .logo a{
    width:266px;
    height:40px;
    background-size: 266px 40px;
  }
  .menu_btn{
    position: absolute;
    right:20px;
    top:20px;
    z-index:100;
  }
  menu{
    padding-top: 16px;
  }
  .header_top{
    padding: 20px 20px 56px;
    position: absolute;
    top:0;
    z-index:0;
    width: 100vw;
  }
  .menu-trigger,
  .menu-trigger span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
  }
  .menu-trigger {
    position: relative;
    width: 50px;
    height: 44px;
  }
  .menu-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #000;
    border-radius: 4px;
  }
  .menu-trigger span:nth-of-type(1) {
    top: 0;
  }
  .menu-trigger span:nth-of-type(2) {
    top: 20px;
  }
  .menu-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  .menu-trigger.active span{
    background: #fff;
  }
  .menu-trigger.active span:nth-of-type(1) {
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(20px) rotate(-45deg);
  }
  .menu-trigger.active span:nth-of-type(2) {
    opacity: 0;
  }
  .menu-trigger.active span:nth-of-type(3) {
    -webkit-transform: translateY(-20px) rotate(45deg);
    transform: translateY(-20px) rotate(45deg);
  }
  .header_menu_mobile{
    position: fixed;
    height: 100vh;
    width: 100vw;
    background: url(../images/bg-black.png);
    z-index:90;
    display: none;
  }
  .header_menu_mobile a{
    color: #fff;
    display: block;
  }
  .header_menu_mobile .header_menu_inner{
    padding: 100px 80px 0;
  }
  .header_menu_mobile li{
    padding: 30px 0;
    border-bottom: solid 2px #222;
  }
  .menu_lang {
    border: none;
    height: auto;
    padding: 0;
  }
  .header_menu_mobile .menu_lang li{
    display: inline-block;
    border: none;
    margin-right: 20px;
  }
  .header_menu_mobile .menu_lang a{
    color: #666;
    font-family: 'Montserrat', sans-serif;
  }
  .header_menu_mobile .menu_lang a.active{
    color: #fff;
    border-color: #fff;
  }
  .header_menu_mobile .onlineshop{
    width: auto;
    color: #DD3300;
    font-family: 'Montserrat', sans-serif;
  }
  .header_menu_mobile .onlineshop .icon-geogashi{
    width: 32px;
    height: 40px;
    background-size: 32px 40px;
  }
  /********************************************
  // footer
  ********************************************/
  .footer_wrap{
    background-position: left 140px;
  }
  .footer_menu{
    padding-top: 28px;
  }
  .footer_menu a{
    font-feature-settings:normal;
  }
  .footer_menu a:after {
    content: '';
    margin-right: 1px;
    float: right;
  }
  .footer_menu a:nth-of-type(2){
    margin-right: 0;
  }
  .footer_menu p{
    padding: 10px 0 0;
    border: none;
  }
  .footer_bottom_inner{
    padding: 18px 0 284px;
  }
  .footer_bottom .copyright{
    left: 0;
    right: 0;
    top: 80px;
  }
  .footer .pagetop{
    right: 0;
    left: 0;
    bottom: 80px;
    top: 0;
    margin: auto auto 0;
  }
  /********************************************
  // page
  ********************************************/

  .page-top .content{
    padding-top: 84px;
  }
  .single-blog .main_visual,
  .single-blog .main_visual_image,
  .single-fieldworks .main_visual,
  .single-fieldworks .main_visual_image,
  .single-geogashi .main_visual,
  .single-geogashi .main_visual_image{
    height: calc(100vh - 160px - 138px);
  }
  .page-top .main_visual,
  .page-top .main_visual_image{
    height: calc(100vh - 84px - 138px);
  }
  .main_visual{
    height: 100vh;
  }
  .main_visual_logo{
    width: 650px;
    height: 98px;
    background-size: 650px 98px;
  }
  .top_about p{
    width: auto;
    padding: 0 60px;
  }
  .side{
    padding: 0 40px !important;
  }
  .side .side_list{
    margin-bottom: 80px;
    border-bottom: solid 5px #eee;
  }
  .frame_right + .page_navi{
    margin-top: -80px;
    border-top: none;
  }
  .frame_right{
    display: block;
    float: none;
    width: 100%;
  }
  .single_page_navi,
  .page_navi{
    margin: 0 0 80px;
    border-bottom: solid 5px #eee;
    border-top: solid 5px #eee;
  }
  .single-blog .single_page_navi,
  .page-blog .page_navi{
    margin-left:40px;
    margin-right: 40px;
  }
  .single_body .content_header,
  .frame_center .content_header{
    padding: 0;
  }
  .content_header{
    padding: 0 40px;
  }
  .content_header.nofix,
  .content_header.nofix p,
  .fieldworks_status,
  .fieldworks_desc{
    width: auto;
    max-width:auto;
  }

  .page-blog .frame_right .side{
    padding: 0 40px;
  }
  .page-cagtgrory .closs span::before,
  .page-cagtgrory .closs span::after{
    margin-top: 180px;
  }
  .page-cagtgrory .content_header{
    padding-top: 80px;
  }

  .single_body{
    max-width: 670px;
  }
	
  .single_body_header .btn_box.single_onlineshop{
    max-width: 670px;
  }

  .sns_box{
    padding-bottom: 60px;
  }
  .sns_box .sns{
    -webkit-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -o-transform: scale(1.5);
    -ms-transform: scale(1.5);
    transform: scale(1.5);
  }
  .sns_box .sns:first-child{
    margin-right: 55px;
  }

}
