@charset "UTF-8";
/* CSS Document */


/*layout
------------------------------------------------------*/
body {
	color: #666;
	background: #fff;
	font-size: 1.4rem;
	font-family: 'Montserrat', 'Noto Sans JP', "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
.themify {
	font-family: 'themify2' !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.font_dance {
	font-family: 'Dancing Script', cursive;
}
.font_Montserrat {
	font-family: 'Montserrat';
 font-weight: 200;
}
/*layout-responsive
------------------------------------------------------*/
html, body {
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
}
#main {
    position: relative;
    top: 0;
    margin-top: 70px;
}
#index #main {
	top: 100%;
	margin-top: 0;
}
article {
	background: #fff;
	padding: 0 0 50px 0;
	line-height: 1.6;
}
.container100 {
	width: 100%;
	padding-right: 15px;
padding-left: 15px;
}
article section {
	padding: 30px 0 0 0;
}

@media (min-width: 960px) {
#main {
	margin-bottom: 80px;
}
article {
	padding: 20px 0 100px 0;
	}
article section {
	padding: 50px 0 0 0;
}
.container100 {
padding-right: 20px;
padding-left: 30px;
}
}

@media screen and (max-width: 959px) {
h1.logo {
	margin: 0;
	padding: 0;
}
}
/*header
------------------------------------------------------*/
.bg_wrapper {
	background-image: url(../images/main_bg1.jpg?2);
	background-size: cover;
	background-position: 60% 0;
	background-repeat: no-repeat;
	position: fixed;
	height: 100%;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;	
	overflow: hidden;
}
.bg_wrapper:before{
  content: '';
  background: inherit;/*.bgImageで設定した背景画像を継承する*/
  -webkit-filter: blur(10px);
  -moz-filter: blur(10px);
  -o-filter: blur(10px);
  -ms-filter: blur(10px);
  filter: blur(10px);
  position: absolute;
  /*ブラー効果で画像の端がボヤけた分だけ位置を調整*/
  top: -10px;
  left: -10px;
  right: -10px;
  bottom: -10px;
  z-index: -1;/*重なり順序を一番下にしておく*/
}
#index .bg_wrapper:before{
	display: none;
}
/*.bg_inner {
	background: rgba(70, 23, 0, 0.15);
	text-align: center;
	position: absolute;
	color: #FFFFFF;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
}*/
#index .bg_wrapper {
	background-image: url(../images/main_bg1.jpg?2);
	background-size: cover;
	background-position: 60% 0;
	background-repeat: no-repeat;
	position: fixed;
	height: 100%;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
}
#index figure .bg_img {
	background-image: url(../images/main_bg1.jpg?2);
	background-size: cover;
	background-position: 60% 0;
	background-repeat: no-repeat;
	position: fixed;
	height: 100%;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
	opacity: 0;
	-webkit-backface-visibility: hidden;
	-webkit-filter: blur(16px);
	filter: blur(16px);
}
#index .bg_inner {
	background: rgba(70, 23, 0, 0.15);
	text-align: center;
	position: absolute;
	color: #FFFFFF;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
}
.head_nav {
    position: absolute;
    right: 0;
    left: 0;
    bottom: auto;
    top: 0;
}
.head_on {
	width: 80%;
	margin: 0 auto;
	position: absolute;
	margin-top: -8em;
	right: 0;
	left: 0;
	top: 48%;
	text-align: center;
}
.catch {
	font-size: 22px;
	margin-top: 18px;
	color: #fff;
	font-family: 'Dancing Script', cursive;
}
/* スクロールクリックで下のコンテンツへ　------*/
.scroll_dawn {
	position: absolute;
	bottom: 30px;
	left: 50%;
	z-index: 2;
	display: inline-block;
	-webkit-transform: translate(0, 134%);
	transform: translate(0, 134%);
	text-decoration: none;
	padding-top: 70px;
	color: #fff;
	font-family: 'Dancing Script', cursive;
}
.scroll_dawn:hover {
	text-decoration: none;
}
.scroll_dawn span {
	position: absolute;
	top: 0;
	left: 50%;
	width: 20px;
	height: 20px;
	margin-left: -10px;
	border-left: 1px solid #fff;
	border-bottom: 1px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	-webkit-animation: sdb 1.5s infinite;
	animation: sdb 1.5s infinite;
	box-sizing: border-box;
}
@-webkit-keyframes sdb {
 0% {
 -webkit-transform: rotate(-45deg) translate(0, 0);
 opacity: 0;
}
 50% {
 opacity: 1;
}
 100% {
 -webkit-transform: rotate(-45deg) translate(-20px, 20px);
 opacity: 0;
}
}
@keyframes sdb {
 0% {
 transform: rotate(-45deg) translate(0, 0);
 opacity: 0;
}
 50% {
 opacity: 1;
}
 100% {
 transform: rotate(-45deg) translate(-20px, 20px);
 opacity: 0;
}
}
/* スクロールクリックで下のコンテンツへ　　ここまで------*/

#navbar-main {
	position: relative;
}
.navbar-brand {
	float: left;
	padding: 12px 0;
	display: block;
}
.navbar-brand img {
	height: 32px;
	margin: 0 auto;
}
.navbar-nav > li > a {
	text-decoration: none;
}
.navbar-toggle {
	top: 0;
	right: 0;
	padding: 6px;
	margin-top: 18px;
	background-color: rgba(255,255,255,0);
	border: none;
}
.navbar-default .navbar-nav > li > a {
	-webkit-transition-property: none;
	-o-transition-property: none;
	transition-property: none;
	color: #ff9000;
/*	font-family: 'Dancing Script', cursive;*/
	background-color: rgba(255,255,255,0.9);
 font-weight: 200;
}
.navbar-default .navbar-nav > li > a:hover, .navbar-default .navbar-nav > li > a:focus {
	background-color: rgba(255,255,255,0.7);
	color: #ff9000;
	border-bottom: 1px solid #ffbe40;
}
.navbar-default .navbar-toggle .icon-bar {
	background-color: #ff9000;
}
.navbar-toggle .icon-bar + .icon-bar {
	margin-top: 6px;
}
.navbar-toggle .icon-bar {
	width: 24px;
}
.navbar-collapse {
	border: none;
}
.down a:hover {
	text-decoration: none;
}
#index .navbar-header .logo_sm {
	display: none;
}
.navbar-header .logo_sm {
	padding-top: 13px;
	padding-left: 13px;
}
.navbar-header .logo_sm img {
	height: 40px;
}

@media screen and (max-width: 959px) {
.head_nav {
	top: 0;
}
.head_nav .container {
	padding: 0;
}
.scroll_dawn {
	left: 47%;
}
.navbar {
	margin-bottom: 0;
}
#navbar-main {
	float: right;
	width: 100%;
	margin-right: 0;
	padding: 0;
	position: fixed;
	top: 70px;
}
.navbar-brand {
	margin-left: 10px;
	padding-top: 13px;
}
.navbar-toggle {
	position: fixed;
}
.nav > li {
	border: none;
}
.nav > li a {
	border-bottom: 1px solid #ffbe40;
	color: #ff9000;
}
.nav .col-sm-3 {
	padding: 0;
}
#thanks header {
	height: 60px;
}
}

@media screen and (min-width: 960px) {
#main {
    margin-top: 90px;
}
#index .head_nav {
	bottom: 2%;
	top: auto;
}
.logo img {
	max-width: 500px;
}
.logo_sm {
		display: none;
	}
.navbar {
	padding: 10px 0;
	margin-bottom: 0px;
}
.catch {
	font-size: 34px;
	margin-top: 20px;
}
.nav {
	padding-top: 14px !important;
 display: flex;
 justify-content: space-between;
}
.nav > li {
	border: none;
	/*float: left;
	text-align: right;
	width: 16.666%;*/
}
.nav > li a {
	text-align: center;
	font-size: 1.6rem;
	background: none;
}
.navbar-default .navbar-nav > li > a {
	background: none;
	color: #fff;
}
.navbar-default .navbar-nav > li > a:hover, .navbar-default .navbar-nav > li > a:focus {
	background: none;
	color: #ff9000;
	border-bottom: 1px solid #ff9000;
	margin-bottom: -1px;
}
.navbar-brand img {
	height: 38px;
}
}
/*footer
------------------------------------------------------*/
.copy {
	padding: 0 0 15px 0;
	color: #fff;
	text-align: center;
	line-height: 2;
	font-size: 12px;
	clear: both;
}

@media screen and (min-width: 768px) {
footer {
	padding: 5px 15px;
}
}

@media screen and (min-width: 960px) {
footer {
	padding-left: 2%;
	padding-right: 2%;
	padding-top: 10px;
	padding-bottom: 10px;
}
}
/*common setting 
------------------------------------------------------*/
.clear {
	clear: both;
}
a {
	color: #ff7800;
}
a.normal_link {
	color: #666;
	text-decoration: underline;
}
a:hover {
	text-decoration: underline;
}
a:hover img {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
}
.content {
	margin: 0 0 10px 0;
	clear: both;
}
.under {
	margin-bottom: 80px;
}
.center {
	text-align: center;
}
table {
	background: #fff;
	width: 100%;
	margin-bottom: 20px;
}
th {
	padding: 8px 15px;
	background: #f2f2f2;
	font-weight: normal;
	border: 1px solid #ddd;
}
td {
	padding: 8px 15px;
	border: 1px solid #ddd;
}
p {
	line-height: 2;
}
.orange {
	color: #ff7800;
}
.flo-l {
	float: left;
	margin: 0 20px 20px 0;
}
.flo-r {
	float: right;
	margin: 0 0 20px 20px;
}
dt {
	padding: 5px 8px;
	margin: 0 10px 10px 0;
	float: left;
}
dd {
	margin-bottom: 10px;
	padding: 5px 8px;
}
.width-auto {
	width: auto;
}
.w90 {
	width: 90%;
}
.w80 {
	width: 80%;
}
.mb0 {
	margin-bottom: 0 !important;
}
.mb5 {
	margin-bottom: 5px !important;
}
.mb10 {
	margin-bottom: 10px !important;
}
.mb15 {
	margin-bottom: 15px !important;
}
.mb20 {
	margin-bottom: 20px !important;
}
.mb25 {
	margin-bottom: 25px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mb35 {
	margin-bottom: 35px !important;
}
.mb40 {
	margin-bottom: 40px !important;
}
.mb45 {
	margin-bottom: 45px !important;
}
.mb50 {
	margin-bottom: 50px !important;
}
.mb55 {
	margin-bottom: 55px !important;
}
.mb60 {
	margin-bottom: 60px !important;
}
.m-auto {
	margin: 0 auto;
}
article ul, article ol {
	margin: 0 0 10px 0;
	padding: 0;
}
article ul li {
	list-style-type: none;
	margin: 0 0 8px 0;
}
article ol li {
	margin: 0 0 8px 20px;
}
.ul_style1 {
 padding-left: 20px;
}
.ul_style1 li {
    list-style-type: none; /*点を非表示*/
    position: relative; /*基準位置*/
    padding-left: 1em;
    }
.ul_style1 li:before {
    border-radius: 50%; /*丸くする*/
    width: 5px; /*点の幅*/
    height: 5px; /*点の高さ*/
    display: block;
    position: absolute; /*絶対配置*/
    left: 0; /*点の位置*/
    top: 0.6em; /*点の位置*/
    content: "";
    background: #FFB14C; /*点の色*/
    }
.text-under {
	text-decoration: underline;
}
.a_link {
	margin-top: -84px;
	padding-top: 84px;
}

.title1 {
	font-size: 2.6rem;
 padding-top: 30px;
 margin-bottom: 25px;
/*	font-family: 'Dancing Script', cursive;*/
	text-align: center;
 font-weight: 300;
}
.title2 {
	font-size: 2.4rem;
	margin-bottom: 15px;
	padding-bottom: 10px;
	text-align: center;
	border-bottom: 1px solid #ddd;
}
.title3 {
 font-size: 1.8rem;
	margin-bottom: 15px;
}
.box_title {
	border: 1px solid #ffc67b;
 padding: 18px 20px;
 color: #FFB14C;
 font-weight: 400;
 margin-bottom: 20px;
 font-weight: 300;
}
.text_strong {
 font-size: 1.8rem;
 line-height: 2;
 margin-bottom: 20px;
}
.highlight {
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.2em; /* 線の太さ */
  text-decoration-color: #FFD073; /* 線の色 */
  text-underline-offset: 0.3em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}
.mv .title1 {
 margin-bottom: 15px;
}
.d-none {
 display: none;
}
@media screen and (min-width: 768px) {
 .mv p {
  text-align: center;
 }
  .d-md-block {
   display: block;
  }
}
@media screen and (min-width: 960px) {
	.title1 {
  font-size: 3rem;
 padding-top: 60px;
 margin-bottom: 40px;
	}
.title2 {
	margin-bottom: 20px;
	padding-bottom: 15px;
	text-align: left;
}
.title3 {
 font-size: 2rem;
	margin-bottom: 15px;
}
.mv .title1 {
 margin-bottom: 20px;
}
.text_strong {
 font-size: 2.4rem;
 line-height: 2;
}
}

/*Works list
------------------------------------------------------*/
.works_list_wrap {
	margin: 0 -10px 20px 0px;
	clear: both;
}
.works_list_flex {
 display: flex;
 flex-wrap: wrap;
}
.works_list {
	width: 50%;
	float: left;
	padding-right: 10px;
	margin-bottom: 10px;
}
.tab_parent {
	display: block;
	width: 100%;
	margin: 0;
	padding: 5px 8px;
}
.tab_cat {
	clear: both;
	margin: 0;
	padding: 0;
}
.tab_cat li {
	display: block;
	width: 100%;
	margin: 0;
	padding: 5px 8px;
}
.tab_cat a {
	display: block;
	width: 100%;
	margin: 0;
	padding: 0;
	color: #666;
}
.tab_cat .select {
	background: #f2f2f2;
}
.link_box figure {
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    background: #000;
	box-shadow: 0px 0px 10px rgba(0,0,0,0.1);
}
.link_box img {
    transition: all 0.4s ease-out 0.1s;
}
.link_box figure:hover img {
    opacity: .6;
    transform: scale(1.2);
}
.link_box figcaption {
    color: #fff;
    /*background: rgba(0,0,0,.7);*/
    position: absolute;
	top: 45%;
    bottom: 0;
	left: 0;
	right: 0;
    width: 100%;
    height: 100%;
    padding: 0px 10px;
    line-height: 1.4;
	text-align: center;
 
    /* 1行で納める */
    /*overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;*/
 
    transition: all 0.2s ease-in 0.3s;
	opacity: 0;
}
.link_box figure:hover figcaption {
	opacity: 1;
}
.tab_area {
 font-weight: 200;
}

@media screen and (min-width: 960px) {
.tab_parent {
	display: none;
	}
.tab_nav_wrap {
text-align: center;
margin: 0 auto;
width: 100%;
}
.tab_nav {
	display:  inline-block;
	margin: 0px 0 40px;
}
.tab_cat li {
	float: left;
	margin: 0 10px;
	padding: 5px 15px;
	width: auto;
}
.works_list_wrap {
	margin: 0 -20px 30px 0px;
}
.works_list {
	width: 25%;
	float: left;
	padding-right: 30px;
	margin-bottom: 30px;
}
 .works_list_flex {
 justify-content: center;
}
.works_list_flex .works_list {
	width: 33.333%;
 }
}
/*Works detail
------------------------------------------------------*/
.works_title {
	padding: 15px 0;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	text-align: center;
 font-size: 1.8rem;
}
.projects_title {
	padding: 15px 0;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	text-align: center;
 font-size: 1.8rem;
}
.works_info {
	padding: 20px 0 0;
	text-align: center;
	font-size: 1.3rem;
	color: #999;
}
.projects_info {
	font-size: 1.3rem;
	color: #999;
 line-height: 1.6
}
.works_info a,
.projects_info a {
	color: #999;	
}
.works_detail  {
	margin-bottom: 20px;
}
.works_img_top {
	margin-top: 30px;
	margin-bottom: 30px;
	text-align: center;
}
.works_img {
	margin-bottom: 30px;
	text-align: center;
}
.works_text {
	margin-bottom: 50px;
	text-align: center;
}
.works_text p {
	margin-bottom: 30px;
}
.works_related {
	margin-bottom: 30px;
 margin-top: 40px;
}
.related {
	font-size: 18px;
	margin-bottom:  15px;
}
.works_caption {
	font-size: 16px;
	margin-bottom: 15px;
}
.project_type {
 margin-top: 20px;
 text-align: center;
}
.project_detail {
 margin-top: 40px;
 margin-bottom: 40px;
}
.projects_sec {
 margin-bottom: 60px;
}
.project_text {
 margin-bottom: 20px;
}
.project_text2 {
 margin-rop: 20px;
}
.to_projects {
 margin: 40px 0 20px;
}
@media screen and (min-width: 960px) {
	.works_title {
    padding: 20px 0;
		margin-top: 30px;
		font-size: 2rem;
	}
 .projects_title {
	padding: 20px 0;
 font-size: 2rem;
}
.works_img_top {
	margin-top: 50px;
	margin-bottom: 50px;
	}
.works_img_top img {
	max-width: 900px;
	}
.works_img {
	margin-bottom: 50px;
	}
	.works_img img {
	max-width: 900px;
	}
.works_text {
	margin-bottom: 70px;
	}
.project_detail {
 margin-top: 60px;
 margin-bottom: 40px;
}
.projects_sec {
 margin-bottom: 80px;
}
.project_text {
 margin-bottom: 30px;
}
.project_text2 {
 margin-top: 30px;
}
}
/*Contact
------------------------------------------------------*/
#contact {
	padding: 50px 0 30px;
}
.contact_confirm #contact {
	padding: 30px 0 30px;
}
#contact .title1 {
 padding-top: 0;
}
#contact .title1,
#contact dt, 
#contact p {
	color: #fff;	
}
input[type="text"], textarea, input[type="tel"] {
  width:100% !important;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
#contact p.form_btn {
	text-align: center;
	color: #666;
}
.form_btn input {
	margin:  0 10px;
}
#formWrap h3 {
	color: #fff;
	text-align: center;
	margin-bottom: 15px;
}
input.form_btn {
	color: #666;
	margin:  0 10px;
}
@media screen and (min-width: 960px) {
 #contact .title1 {
 margin-bottom: 20px;
}
.mailform, .formTable {
	width: 600px;
	margin: 0 auto 30px;
}
}

/*Service
------------------------------------------------------*/
.service_text {
	margin-top: 15px;
	text-align: center;
}
#profile {
	margin-bottom: 30px;
}
.about {
	margin-top: 30px;
}
.profile_photo {
	width: 80%;
	padding: 15px 0;
	margin: 0 auto;
	text-align: center;
}
.service_list2 {
 display: flex;
 flex-direction: column;
 margin-bottom: 40px;
}
.service_cont1 .box_title {
 text-align: center; 
}
.service_cont2 { 
 text-align: center;
 padding: 15px;
}
@media screen and (min-width: 768px) {
	.profile_photo {
	width: 50%;
	}
}
@media screen and (min-width: 960px) {
.service_list2 {
 display: flex;
 flex-direction: row;
 justify-content: space-between;
}
.service_cont1 {
 flex-basis: 45%;
}
.service_cont2 { 
flex-basis: 10%;
 text-align: center;
 padding: 0 15px;
}
.service_cont1 .box_title {
 text-align: left; 
}
.service_title {
	width: 200px;
  height: 200px;
	}
.service_title span {
	padding: 0;
	}
#profile {
	margin-bottom: 40px;
}
.about {
	margin-top: 40px;
}
	.profile_cont {
		float: left;
		width: 75%;
	}
	.profile_photo {
		float: right;
	width: 23%;
		padding: 0 2%;
	}
}