@charset "UTF-8";

/* CSS Document */

/*------------------------------------------------------------------


/*-----------------------------------
    1. Body / Typography 
-----------------------------------*/

html {
  scroll-behavior:smooth;
}

body {font-size: 16px;
    background-color: #fff;
    color: #5d5c59;
	font-family:"ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro",  游ゴシック体, "Yu Gothic", YuGothic,  メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    /*font-family: 'Roboto', sans-serif;*/
    line-height: 28px;
    font-weight: 300; }

.sp{display: none}
.pc{display: block}
pc{display:block}
sp{display:none}

h1, h2, h3, h4, h5, h6 { margin: 0; padding: 0; margin-bottom: 10px; color: #18150d; font-weight: 400; 
    font-family: "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro",游ゴシック体, "Yu Gothic", YuGothic;
     -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
h1 { font-size: 32px; line-height: 42px; }
h2 { font-size: 24px; line-height: 32px; color:#0457CC; }
h3 { font-size: 18px; line-height: 28px; }
h4 { font-size: 16px; line-height: 24px; margin-bottom: 10px; }
h5 { font-size: 14px; }
h6 { font-size: 12px; }
p { margin: 0 0 20px; }
p:last-child { margin-bottom: 0px; }
ul, ol { margin: 0; }
ul li, ol li { }
a { color: #0457CC; text-decoration: none; -webkit-transition: all 0.3s; -moz-transition: all 0.3s; transition: all 0.3s; }
a:focus, a:hover { text-decoration: none; color: #1fb4ff; }
 
b, strong {
    font-weight: 400;
}
.listnone {text-align: center; list-style: none; padding: 0px;display: inline-flex;margin: 0 auto}
.listnone li{margin: 0 15px}
.lead { font-size: 21px; color: #3c3c3c; font-weight: 400; }
.italic { font-style: italic; }
.small-text { color: #b4b1ac; font-size: 12px; }
.text-caps { text-transform: uppercase; letter-spacing: 2px; }
::selection { background: #a8cbfd; color: #333; }
h3 small { font-weight: 400; line-height: 1; color: #0457CC; font-size: 14px; }
 
hr { margin-top: 20px; margin-bottom: 20px; border: 0; border-top: 1px solid #f1f3f8; }
blockquote { padding: 10px 20px; margin: 0px; font-size: 21px; line-height: 32px; color: #3c3c3c; font-style: italic; border-left: 5px solid #0457CC; }

.common-text{margin-top: 15px; font-size: 16px;line-height: 26px}





/*-------------- align ------------*/

/* =WordPress Core
-------------------------------------------------------------- */

.alignnone { margin: 5px 20px 20px 0; }
.aligncenter, div.aligncenter { display: block; margin: 5px auto 5px auto; }
.alignright { float: right; margin: 0px 0 30px 30px;  }
.alignleft { float: left; margin: 0px 30px 0px 0;   }
a img.alignright { float: right; margin: 0px 0 30px 30px; }
a img.alignnone { margin: 5px 20px 20px 0; }
a img.alignleft { float: left; margin: 5px 20px 20px 0; }
a img.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption { background: #fff; border: 1px solid #f0f0f0; max-width: 96%;    /* Image does not overflow the content area */ padding: 5px 3px 10px; text-align: center; }
.wp-caption.alignnone { margin: 5px 20px 20px 0; }
.wp-caption.alignleft { margin: 5px 20px 20px 0; }
.wp-caption.alignright { margin: 5px 0 20px 20px; }
.wp-caption img { border: 0 none; height: auto; margin: 0; max-width: 98.5%; padding: 0; width: auto; }
.wp-caption p.wp-caption-text { font-size: 11px; line-height: 17px; margin: 0; padding: 0 4px 5px; }

/*-----------------------------------
    2. Form css 
-----------------------------------*/
label { }
.control-label { color: #474747; font-weight: 700; font-size: 14px; text-transform: uppercase; }
.form-control { width: 100%; height: 50px; padding: 6px 12px; 
    font-size: 16px; line-height: 1.42857143; color: #333; background-color: #fff; border: 1px solid #dcd9d3; 
    background-image: none; border-radius: 10px; -webkit-box-shadow: inset 0 0px 0px rgba(255, 255, 255, .075); 
    box-shadow: inset 3px 3px 3px rgba(255, 255, 255, .075); margin-bottom: 15px; }
.form-control:focus { border-color: #bab6ae;
    outline: 0;
    -webkit-box-shadow: inset 0 1px 1px rgba(255, 255, 255, .075), 0 0 8px rgba(255, 255, 255, .6);
    box-shadow: inset 0 3px 3px rgba(255, 255, 255, .075), 0 0 8px rgba(235, 237, 238, .6);
    background-color: #fffefd; }
.textarea.form-control { background-color: #f6f8f9; height: auto; }
.required { }
.form-news-letter .form-control { float: left; width: 75%; margin-right: 10px; }
.form-group { margin-bottom: 10px; }
.get-in-touch { }
.get-in-touch .form-control { margin-bottom: 10px; }

/*-----------------------------------
    3. Buttons 
-----------------------------------*/
.btn { display: inline-block; padding: 14px 30px; margin-bottom: 0; font-size: 13px; font-weight: 800; 
    letter-spacing: 1px; line-height: 1.42857143; text-align: center; border: none; 
    text-transform: uppercase; border-radius: 100px;font-family: 'Montserrat', sans-serif; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;}
.btn-default { color: #fff; background-color: #0457CC; }
.btn-default:hover { color: #fff; background-color: #1fb4ff; border-color: #1fb4ff; }
.btn-default.focus, .btn-default:focus { color: #fff; background-color: #1fb4ff; border-color: #1fb4ff; }
.btn-primary { background-color: #2d281a; color: #fff; }
.btn-primary:hover { background-color: #18150d; color: #fff; }
.btn-primary.focus, .btn-primary:focus { }
.btn-white { color: #0457CC; background-color: #fff; border: 1px solid #fff; }
.btn-white:hover { background-color: #1fb4ff; border-color: #1fb4ff; color: #fff; }
.btn-white.focus, .btn-white:focus { background-color: #1fb4ff; border-color: #1fb4ff; color: #fff; }
.btn-link { color: #98989c; text-transform: uppercase; font-size: 12px; font-weight: 700; letter-spacing: 2px; border-bottom: 1px solid #98989c; padding-bottom: 2px; }
.btn-link:hover { color: #0457CC; font-weight: 700; text-decoration: none; border-bottom: 1px solid #0457CC; }
.btn-lg { font-size: 14px; padding: 20px 30px; }
.btn-sm { font-size: 12px; padding: 5px 10px; }
.btn-xs { font-size: 12px; padding: 5px 7px; }

.btn-line{width: 100%;margin: 0 auto;text-align: center;margin-top: 20px;font-size: 20px;color:#000;font-weight: bold;border: solid 4px #A4E4B9;padding: 10px;border-radius: 30px;box-sizing: border-box}
.btn-line:hover{opacity: .5}

/*-----------------------------------
    4. General / Elements 
-----------------------------------*/

/*----------------------- 
    4.1 Section space :
-------------------------*/

/*Note: Section space help to create top bottom space;*/

.space-s-small { padding-top: 8px; padding-bottom: 8px; }
.space-small { padding-top: 15px; padding-bottom: 15px; }
.space-medium { padding-top: 30px; padding-bottom: 30px; }
.space-large { padding-top: 120px; padding-bottom: 120px; }
.space-ex-large { padding-top: 140px; padding-bottom: 140px; }

.space1{margin: 10px}
.space2{margin: 20px}
/*----------------------
   4.2 Margin Space
-----------------------*/
.mb0 { margin-bottom: 0px; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb35 { margin-bottom: 35px; }
.mb40 { margin-bottom: 40px; }
.mb60 { margin-bottom: 60px; }
.mb80 { margin-bottom: 80px; }
.mb100 { margin-bottom: 100px; }
.mt0 { margin-top: 0px; }
.mt10 { margin-top: 10px; }
.mt20 { margin-top: 20px; }
.mt30 { margin-top: 30px; }
.mt40 { margin-top: 40px; }
.mt60 { margin-top: 60px; }
.mt70 { margin-top: 70px; }
.mt80 { margin-top: 80px; }
.mt100 { margin-top: 100px; }

/*----- less margin space from top --*/
.mt-20 { margin-top: -20px; }
.mt-40 { margin-top: -40px; }
.mt-60 { margin-top: -60px; }
.mt-80 { margin-top: -80px; }

/*-----------------------
   4.3 Padding space
-------------------------*/
.nopadding { padding: 0px; }
.nopr { padding-right: 0px; }
.nopl { padding-left: 0px; }
.pinside10 { padding: 10px; }
.pinside20 { padding: 20px; }
.pinside30 { padding: 30px; }
.pinside40 { padding: 40px; }
.pinside50 { padding: 50px; }
.pinside60 { padding: 60px; }
.pinside80 { padding: 80px; }
.pinside130 { padding: 130px; }
.pdt10 { padding-top: 10px; }
.pdt20 { padding-top: 20px; }
.pdt30 { padding-top: 30px; }
.pdt40 { padding-top: 40px; }
.pdt60 { padding-top: 60px; }
.pdt80 { padding-top: 80px; }
.pdb10 { padding-bottom: 10px; }
.pdb20 { padding-bottom: 20px; }
.pdb30 { padding-bottom: 30px; }
.pdb40 { padding-bottom: 40px; }
.pdb60 { padding-bottom: 60px; }
.pdb80 { padding-bottom: 80px; }
.pdl10 { padding-left: 10px; }
.pdl20 { padding-left: 20px; }
.pdl30 { padding-left: 30px; }
.pdl40 { padding-left: 40px; }
.pdl60 { padding-left: 60px; }
.pdl80 { padding-left: 80px; }
.pdr10 { padding-right: 10px; }
.pdr20 { padding-right: 20px; }
.pdr30 { padding-right: 30px; }
.pdr40 { padding-right: 40px; }
.pdr60 { padding-right: 60px; }
.pdr80 { padding-right: 80px; }

/*--------------------------------
4.4 Background & Block color 
----------------------------------*/
.bg-light { background-color: #F7F7F8; }
.bg-primary { background-color: #0457CC; }
.bg-default { }
.bg-white { background-color: #fff; }
.outline { border: 1px solid #e5e7ec; }
.section-title { }
.title { color: #18150d; }
.small-title{color: #84837f; font-size: 13px; letter-spacing: 1px; margin-bottom: 20px;}
.text-white { color: #fff; }
.primary-sidebar { }
.secondary-sidebar { }
.well-block{background-color: #fff;padding: 40px 7%;}

/*--------------------------------
4.5 Features Block 
----------------------------------*/
.feature { }
.feature-icon { margin-bottom: 20px; }
.feature-left { }
.feature-left .feature-icon { float: left; }
.feature-left .feature-content { padding-left: 80px; }
.feature-center { }
.feature-center .feature-icon { }
.feature-center .feature-content { }
.feature-inner { }
.feature-outline { }
.thumbnail-block { }
.thumbnail-img { }
.thumbnail-content { }
.thumbnail-inner { }
.thumbnail-outline { }

/*----------------- video ---------------*/
.video-section { position: relative; }
.video-img { position: relative; }
.video-img img { width: 100%; }
.video-action { position: absolute; top: 40%; left: 47%; }

/*--------------------------------
4.6 Bullet 
----------------------------------*/
.bullet { position: relative; padding-left: 15px; color: #78807e; line-height: 32px; }
.bullet-double-right li:before { font-family: FontAwesome; display: block; position: absolute; left: 0; width: 13px; font-size: 14px; color: #78807e; content: "\f101"; }

/*--------------------------------
4.7 Call to actions 
----------------------------------*/
.cta-block { }
.cta-title { font-size: 32px; font-weight: 700; letter-spacing: -1px; color: #fff; margin-bottom: 10px; }
.cta-text { font-size: 18px; color: #a2fed4; }
.cta-content { }
.cta-call, .cta-mail { }


.cta-section { 
    padding-top: 140px; padding-bottom: 140px; 
    background: linear-gradient(rgba(30, 28, 24, 0.8), rgba(30, 28, 24, 0.8)), rgba(30, 28, 24, 0.8) url(../images/cta-section-img.jpg) no-repeat center; background-size: cover; }
.cta-caption {  }
.cta-title { font-size: 36px; color: #fff; line-height: 58px; font-weight: 600; margin-bottom: 10px; letter-spacing: -1px; }
.cta-text { font-size: 18px; color: #fff; margin-bottom: 30px; }

/*--------------------------------
4.8 Image Hover Effect 
----------------------------------*/
.imghover { display: block; position: relative; max-width: 100%; }
.imghover::before, .imghover::after { display: block; position: absolute; content: ""; text-align: center; opacity: 0; }
.imghover::before { top: 0; right: 0; bottom: 0; left: 0; }
.imghover::after { top: 50%; left: 50%; width: 50px; height: 50px; line-height: 50px; margin: -25px 0 0 -25px; content: "\f2a8"; font-family: "FontAwesome"; font-size: 36px; }
.imghover:hover::before, .imghover:hover::after { opacity: 1; }
.imghover:hover::before { background: rgba(212, 27, 44, .55); }
.imghover:hover::after { color: #FFFFFF; }
[class^='imghvr-'], [class*=' imghvr-'] { background: rgba(211, 0, 80, .55); }

/*--------------------------------
4.9 Icon 
----------------------------------*/
.icon { }
.icon-1x { font-size: 18px; }

/* default icon size of font*/
.icon-2x { font-size: 38px; }
.icon-4x { font-size: 65px; }
.icon-6x { font-size: 88px; }
.icon-8x { font-size: 108px; }
.icon-default { color: #0457CC; }
.icon-primary { color: #474954; }
.icon-secondary { color: #fff; }
.icon-white { color: #fff; }

/*--------------------------------
5 Header / Navigations 
----------------------------------*/

/*--------------------
    5.1 Header Regular 
   ----------------------*/

.logo {width:260px; position: absolute; top:20px;z-index: 999}
.header { background-color: #fff; z-index: 9999; position: relative; padding-top: 0px; padding-bottom: 10px; height: 90px;opacity: .9}
.top-text { text-align: right; }
.top-text .text-block { padding-left: 20px; color: #fff; line-height: 18px; }
.call-block { }
.call-no { }
.mail-block { }
.mail-text { }
.time-block { }
.time-text { }


/*--------------------------
    5.2 Navigations Regular
   ----------------------------*/
.hero-section {width: 100%; text-align: center; padding-top: 30px; padding-bottom: 10px; margin: 0 auto;}
.hero-caption { padding-top: 100px; padding-bottom: 100px; }
.hero-title {text-align: center; font-size: 20px; color: #000; line-height: 58px; font-weight: 100; margin-bottom: 30px; letter-spacing: 2px; margin: 0 auto}
.hero-text {text-align: center; font-size: 43px; color: #000; line-height: 58px; font-weight: bold; letter-spacing: -1px; margin: 0 auto;margin-bottom: 30px;margin-top: 40px}
.under {
  background: linear-gradient(transparent 50%, #A4E4B9 50%);
}

.navigation {margin-top: 30px; float: right; }
.is-sticky .header {}
#navigation, #navigation ul, #navigation ul li, #navigation ul li a, #navigation #menu-button { margin: 0; padding: 0; border: 0; list-style: none; line-height: 1; display: block; position: relative; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
#navigation:after, #navigation > ul:after { content: "."; display: block; clear: both; visibility: hidden; line-height: 0; height: 0; }
#navigation #menu-button { display: none; }
#navigation {font-family: sans-serif; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;}
#navigation > ul > li { float: left; }
#navigation.align-center > ul { font-size: 0; text-align: center; }
#navigation.align-center > ul > li { display: inline-block; float: none; }
#navigation.align-center ul ul { text-align: left; }
#navigation.align-right > ul > li { float: right; }
#navigation > ul > li > a { padding: 15px; font-size: 17px; color: #18150d; text-decoration: none; font-weight: ; text-transform: uppercase; }
#navigation > ul > li:hover > a { color: #FBB03B; background-color:; }
#navigation > ul > li.has-sub > a { padding-right: 32px; }

/*#navigation > ul > li.has-sub > a:after {
 position: absolute;
 top: 22px;
 right: 11px;
 width: 8px;
 height: 2px;
 display: block;
 background: #dddddd;
 content: '';
}*/
#navigation > ul > li.has-sub > a:before { position: absolute; right: 14px; font-family: FontAwesome; content: "\f107"; -webkit-transition: all .25s ease; -moz-transition: all .25s ease; -ms-transition: all .25s ease; -o-transition: all .25s ease; transition: all .25s ease; }

/*#navigation > ul > li.has-sub:hover > a:before {
 top: 23px;
 height: 0;
}*/
#navigation ul ul { position: absolute; left: -9999px; }
#navigation.align-right ul ul { text-align: right; }
#navigation ul ul li { height: 0; -webkit-transition: all .25s ease; -moz-transition: all .25s ease; -ms-transition: all .25s ease; -o-transition: all .25s ease; transition: all .25s ease; }
#navigation li:hover > ul { left: auto; }
#navigation.align-right li:hover > ul { left: auto; right: 0; }
#navigation li:hover > ul > li { height: 46px; }
#navigation ul ul ul { margin-left: 100%; top: 0; }
#navigation.align-right ul ul ul { margin-left: 0; margin-right: 100%; }
#navigation ul ul li a { padding: 16px; width: 170px; font-size: 13px; text-decoration: none; color: #fff; font-weight: 500; background: #0457CC; text-transform: uppercase; border-bottom: 1px solid #987e2e; }
#navigation ul ul li:last-child > a, #navigation ul ul li.last-item > a { border-bottom: 0; }
#navigation ul ul li:hover > a, #navigation ul ul li a:hover { color: #ffffff; background-color: #0457CC; }
#navigation ul ul li.has-sub > a:after { position: absolute; top: 16px; right: 11px; width: 8px; height: 2px; display: block; background: #dddddd; content: ''; }
#navigation.align-right ul ul li.has-sub > a:after { right: auto; left: 11px; }
#navigation ul ul li.has-sub > a:before { position: absolute; top: 13px; right: 14px; display: block; width: 2px; height: 8px; background: #dddddd; content: ''; -webkit-transition: all .25s ease; -moz-transition: all .25s ease; -ms-transition: all .25s ease; -o-transition: all .25s ease; transition: all .25s ease; }
#navigation.align-right ul ul li.has-sub > a:before { right: auto; left: 14px; }
#navigation ul ul > li.has-sub:hover > a:before { top: 17px; height: 0; }
#navigation.small-screen { width: 100%;}
#navigation.small-screen ul {margin-top: 30px; width: 100%; display: none; }
#navigation.small-screen.align-center > ul { text-align: left; }
#navigation.small-screen ul li { width: 100%; border-top: 1px solid #474747; }
#navigation.small-screen ul ul li, #navigation.small-screen li:hover > ul > li { height: auto; }
#navigation.small-screen ul li a, #navigation.small-screen ul ul li a { width: 100%; border-bottom: 0; padding: 20px 15px; }
#navigation.small-screen > ul > li { float: none; }
#navigation.small-screen ul ul li a { padding-left: 25px; }
#navigation.small-screen ul ul ul li a { padding-left: 35px; }
#navigation.small-screen ul ul li a { color: #474747; background: none; }
#navigation.small-screen ul ul li:hover > a, #navigation.small-screen ul ul li.active > a { color: #474747; }
#navigation.small-screen ul ul, #navigation.small-screen ul ul ul, #navigation.small-screen.align-right ul ul { position: relative; left: 0; width: 100%; margin: 0; text-align: left; }
#navigation.small-screen > ul > li.has-sub > a:after, #navigation.small-screen > ul > li.has-sub > a:before, #navigation.small-screen ul ul > li.has-sub > a:after, #navigation.small-screen ul ul > li.has-sub > a:before { display: none; }
#navigation.small-screen #menu-button {margin-top: 10px; display: block; padding: 15px; color: #474747; cursor: pointer; font-size: 12px;
   text-transform: uppercase; font-weight: 700; }
#navigation.small-screen #menu-button:after { position: absolute; top: 16px; right: 17px; display: block; height: 12px; width: 20px; border-top: 2px solid #474747; border-bottom: 2px solid #474747; content: ''; }
#navigation.small-screen #menu-button:before { position: absolute; top: 21px; right: 17px; display: block; height: 2px; width: 20px; background: #474747; content: ''; }
#navigation.small-screen #menu-button.menu-opened:after { top: 23px; border: 0; height: 2px; width: 15px; background: #474747; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }
#navigation.small-screen #menu-button.menu-opened:before { top: 23px; background: #474747; width: 15px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }
#navigation.small-screen .submenu-button { position: absolute; z-index: 99; right: 0; top: 0; display: block; border-left: 1px solid #474747; height: 53px; width: 53px; cursor: pointer; }
#navigation.small-screen .submenu-button.submenu-opened { }
#navigation.small-screen ul ul .submenu-button { height: 34px; width: 34px; }
#navigation.small-screen .submenu-button:after { position: absolute; top: 22px; right: 20px; width: 8px; height: 2px;
 display: block; background: #474747; content: ''; }
#navigation.small-screen ul ul .submenu-button:after { top: 15px; right: 13px; }
#navigation.small-screen .submenu-button.submenu-opened:after { background: #474747; }
#navigation.small-screen .submenu-button:before { position: absolute; top: 19px; right: 23px; display: block;
 width: 2px; height: 8px; background: #474747; content: ''; }
#navigation.small-screen ul ul .submenu-button:before { top: 12px; right: 16px; }
#navigation.small-screen .submenu-button.submenu-opened:before { display: none; }
#navigation.small-screen.select-list { padding: 5px; }



/*-----------------------------------
   opening
-------------------------------------*/

.logo_fadein{
	background: #FFF;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 99999;
}
.logo_fadein p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 99999;
}



/*-----------------------------------
8. Footer 
-------------------------------------*/
.footer { background-color: #f2f2f2; padding-top: 10px; padding-bottom: 30px;margin-top: 30px }
.footer-block{}
.footer-widget p { color: #747474; }
.footer-widget .widget-title { color: #fff; font-weight: 600; padding-bottom: 20px; margin-bottom: 30px; }
.footer-widget .widget-title  img {
	width:180px;
}
.footer-widget {text-align: center; margin: 0 auto}
.footer-widget ul { }
.footer-widget li { }
.footer-widget li a { color: #747474; line-height: 34px; }
.footer-widget li a:hover { color: #0457CC; }
.footer-link { }
.footer-social { }
.footer-social ul { }
.footer-social ul li { }
.footer-social ul li a i { padding-right: 10px; width: 30px; }
.footer-social ul li a:hover i { color: #0457CC; }
.footer .contact li { position: relative; padding-left: 40px; display: block; '
margin-bottom: 8px; padding: 0 0 8px 0px; color: #747474; }

.widget-newsletter .form-control { height: 48px; color: #eee; background-color: #393836; border: none; box-shadow: none; 
    font-size: 14px; border-radius: 30px 0px 0px 30px;}
.widget-newsletter button { height: 48px; }

/*-------------- tiny footer ------------*/
.tiny-footer {  padding-top: 19px; padding-bottom: 9px; font-size: 12px; 
    color: #56575e; text-align: left; text-transform: uppercase; text-align: center; }
.copyright-content { padding: 1px; color: #747474; }




/*-------------------------
 9.2  Service / single / sidebar
--------------------------*/

/* service section */
#service{margin-top: 135px}
.service-menu{margin: 0 auto}
.service-block{height:  300px;margin-top: 45px}
.service-img {margin: 0 auto;text-align: center;
    width:280px; 
 margin:0 auto; 
 overflow:hidden; }
.service-img img{transition:.5s all;}
.service-img img:hover{  transform:scale(1.2,1.2);}
.service-content{padding: 0 10%;margin: 0 auto;text-align: center;
font-size:30px;line-height: 38px }

.service-content h2{color: #000;font-weight: bold}
.service-ttl{text-align: center;font-size: 20px;color: #000}

/*-------------------------
works
--------------------------*/
.works-ph{width: 100%;margin-top: 0}
#works{margin-top: 135px}
.service-menu{margin: 0 auto}
.works-block{margin-top: 35px}
.works-img {margin: 0 auto;text-align: center;
    width:280px; 
 margin:0 auto; 
 overflow:hidden; }
.works-img img{
 transition:.5s all;
}
.works-img img:hover{  transform:scale(1.2,1.2);}
.service-content{padding: 0 10%;margin: 0 auto;text-align: center;
font-size:30px;line-height: 38px }
.service-content h2{color: #000;font-weight: bold}
.works-ttl{text-align: center;font-size: 14px;margin-bottom: 5px; color: #000}
.works-name{text-align: center;font-size: 18px;margin-bottom: 5px; color: #000}
.ttl-line{width: 100px;height: 3px;background: #000;text-align: center;margin: 0 auto}


/*-------------------------
banner
--------------------------*/
.banner-box{width: 100%;margin: 10px auto 0;text-align: center}
.banner-box:hover{opacity: .8}
.banner-img{width: 100%;margin: 0 auto}


/*-------------------------
profile
--------------------------*/
.profile-ph{width: 95%;margin: 20px auto 0;}
.profile-txt{margin-top: 20px;text-align: justify;font-size: 15px;font-weight: 300;line-height: 25px;color: #000}
.profile-txt2{margin-top: 20px;text-align: justify;font-size: 15px;font-weight: 300;line-height: 25px;color: #000}
.profile-txt2:hover{opacity: .5;color: #000}

/*--------------------------
  9.4  common
---------------------------*/
.common-ttl{font-family: 'Oswald'; margin-top: 40px; font-size: 35px; font-weight: ;color: #FBB03B; text-align: center; }
.common-sub:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -10px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 4px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #FBB03B;;/*線の色*/
  
}

.common-sub{margin-top:-5px; font-size: 16px; font-weight: ;color: #999999; text-align: center; position: relative}
.padding-box{padding:5%}

/*-------------------------
product
--------------------------*/


.top-img{width: 100%;margin: 10px auto 0;}
.item-block{
  margin-top: 45px; 
  margin: 45px auto 0;
  text-align: center;
  }
  
  .item-img{
    margin: 0 auto;text-align: center;
    width:600px; 
  margin:0 auto; 
  }
  .item-img img{width:100%;transition:.5s all;}

  .product-ttl{
    text-align: center;font-size: 23px;color: #000;
    margin: 0 auto;font-weight: 600;
  }

.product-block{
  display: block;
  margin: 45px auto 0;
  text-align: center;
  }
.product-img{
  margin: 0 auto;text-align: center;
  width:; 
margin:0 auto; 
}
.product-img img{width:100%;transition:.5s all;}
.product-text{
  text-align: justify;
height: 400px;
}


/*-------------------------
  9.8 Contact us
---------------------------*/
#contact{width: 100%;margin:50px 0 auto;}
.contact-box{}
.contact-ttl{margin-top: 30px; text-align: center;font-size: 43px;font-weight: bold;color: #000}
.tel-ttl{margin-top: 20px; text-align: left;font-size: 50px;font-weight: bold;color: #000}
.contact-btn{color: #fff; background-color: #FBB03B;width:250px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 50px auto;padding: 10px 20px}

.contact-btn:hover{background-color: #FA8F00}
#submit_button{color: #fff; background-color: #FBB03B;width:200px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 50px auto;padding: 10px 20px;border: none;}
#submit_button2{color: #fff; background-color: #9FA0A0;width:200px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 50px auto;padding: 10px 20px;border: none;}
#submit_button:hover{opacity: .5}
#submit_button2:hover{opacity: .5}
#submit_button_cover{font-size: 18px}

#formWrap{margin: 0 auto;text-align: center;margin-top: 60px;width: 100%;  
 }


.formTable{  text-align: center;width: 100%}
.inner{  display: inline-block;
  text-align: left;}
.mail-txt{}

.mail-ttl{text-align: left;font-size: 15px;font-weight: 500; margin-top: 10px}
.mail-box{text-align: left;width: 100%}

input{border: solid 1px #999999;}

.mail-category{display:block;width: 100%;}
input.m-txt-box{width: 90%}

/*-------------------------
  9.9 Company
---------------------------*/

.company-table table{border:0px}
.company-table table tr{border:0px ;border-bottom:solid 1px}


/*-------- Post meta --------*/
.meta { font-size: 12px; text-transform: uppercase; margin-bottom: 20px; font-family: 'Montserrat', sans-serif;}
.meta-date { }
.meta-user { }
.meta-comment { }
.meta-author { }
.meta-cat { }
.meta-date, .meta-author, .meta-comment, .meta-cat { display: inline-block; margin-right: 10px; }
.meta-link { }
.meta-tags { }

/*-------- Post Type --------*/
.post-sticky { background: url(../images/sticky.png) no-repeat; position: absolute; right: 35px; bottom: 35px; width: 30px; height: 30px; color: #fff; }
.post-gallery { }
.post-video { }
.post-video .video-sign { }
.post-audio {}
.post-quote {background-color: #0457CC; }
.quote-content{}
.post-quote blockquote{color: #fff; font-size: 34px; line-height: 42px;}
/*-------- Related Post --------*/
.related-post-block { border-top: 1px solid #eee; padding-top: 29px; margin-top: 30px; margin-bottom: 30px; }
.related-post {margin-bottom: 30px; }
.related-post-title { }
.related-post-img { margin-bottom: 30px; }
.related-post-img img{border-radius: 10px;}
/*----- Prev Next Post -----*/
.post-navigation { margin-bottom: 30px; }
.nav-previous, .nav-next { border: 1px solid #F7F7F8; padding: 20px; }
.nav-previous { }
.nav-next { }
.prev-post { }
.next-post { }
.prev-link { }
.next-link { }
.prev-link, .next-link { margin-bottom: 10px; display: block; text-transform: uppercase; font-size: 12px; }

/*----- Author Post -----*/
.author-post { margin-bottom: 30px; background: #F7F7F8; padding: 30px; border-radius: 10px; }
.author-img { }
.author-title { }
.author-img img { width: 100%; border-radius: 10px; }
.author-bio { }
.author-meta { }
.author-name { }
.author-header { }
.author-detail { }
.author-link { }
.author-social { }
.author-social ul { }
.author-social ul li { }
.author-social ul li a { }
.author-social ul li a:hover { }
.author-info { }

/*------------- Post Pagination -------------*/
.st-pagination { }
.st-pagination .pagination>li>a, .pagination>li>span { position: relative; float: left; margin-left: -1px; line-height: 1.42857143; color: #3c3c3c; text-decoration: none; 
    font-size: 12px; background-color: #fff; 
    font-weight: 700; text-transform: uppercase; margin-right: 5px; 
    margin-bottom: 5px; padding: 8px 13px; border: 1px solid #efefef; border-radius: 100%; }
.st-pagination .pagination>li>a:focus, .st-pagination .pagination>li>a:hover, .st-pagination .pagination>li>span:focus, .st-pagination .pagination>li>span:hover, .st-pagination .pagination>li>a.active { z-index: 2; color: #fff; background-color: #0457CC; border: 1px solid #F7F7F8; }
.st-pagination .pagination>li:first-child>a, .st-pagination .pagination>li:first-child>span { margin-left: 0; border-radius: 100%; }
.st-pagination .pagination>li:last-child>a, .st-pagination .pagination>li:last-child>span { border-radius: 100%; }
.st-pagination .pagination>.active>a, .st-pagination .pagination>.active>a:focus, .st-pagination .pagination>.active>a:hover, .st-pagination .pagination>.active>span, .st-pagination .pagination>.active>span:focus, .st-pagination .pagination>.active>span:hover { z-index: 3; color: #fff; cursor: default; background-color: #0457CC;border: 1px solid #0457CC;}

/*------------------------
  12. Sidebar / Widgets
--------------------------*/

/*----- widget -----*/

.widget { margin-bottom: 10px; background-color: #F7F7F8; padding: 30px; border-radius: 10px; }
.widget-title { margin-bottom: 20px; }
.widget ul { }
.widget ul li { margin-bottom: 16px; line-height: 18px;}
.widget ul li:last-child { margin-bottom: 0px; }
.widget ul li a { color: #474747; }
.widget ul li a.active { color: #0457CC; }
.widget ul li a:hover { color: #0457CC; }
.widget-search { }
.widget-search .input-group-addon { color: #fff; text-align: center; background-color: #0457CC; border: 1px solid #0457CC; border-left: transparent; }
.widget-categories { }
.widget-categories ul { }
.widget-categories ul li { }
.widget-categories ul li a { }
.widget-archives { }
.widget-archives ul { }
.widget-archives ul li { }
.widget-archives ul li a { }
ul.widget-recent-post { }
.widget-recent-post li { margin-bottom: 10px; border-bottom: 1px solid #cecbc7;  padding-bottom: 10px;}
.widget-recent-post li:last-child{border-bottom: 1px solid transparent;}
.widget-recent-post ul li a {}
.widget-recent-post .meta{margin-bottom: 0px;}
.recent-post-img {margin-bottom: 20px; }
.recent-post-content { }
.recent-title{font-size: 12px; line-height: 18px;}

.widget-tags { }
.widget-tags a { border: 1px solid #cecbc7; padding: 2px 10px; display: inline-block; background-color: #fff; 
    font-size: 12px; text-transform: uppercase; margin-bottom: 5px; margin-right: 3px; border-radius: 50px; color: #18150d; }
.widget-tags a:hover { background-color: #0457CC; color: #fff;  border: 1px solid #0457CC; }
.widget-text { }
.widget-contact { }
.widget-social { }
.social-circle a { height: 33px; width: 33px; background-color: #0457CC; color: #fff; border-radius: 100%; padding: 5px; display: inline-block; text-align: center; margin-right: 10px; }
.social-circle a:hover { background-color: #1fb4ff; }
.widget-call-to-action{background-color: #eddba5;}
.widget-call-to-action .widget-title{font-size: 20px; font-weight: 400; margin-bottom: 20px; line-height: 28px;}
.widget-call-to-action p{font-size: 18px; color: #18150d;}
.team-block { margin-bottom: 20px; }
.team-img { margin-bottom: 20px; }
.team-content { text-align: center; }
.team-title { margin-bottom: 0px; }
.team-name { }
.team-meta { text-transform: uppercase; font-size: 12px; color: #0457CC; font-weight: 500; letter-spacing: 1px; }
.team-designation { }

/*----- Comment Post -----*/
.comments-area { }
.comments-title { border-bottom: 1px solid #F7F7F8; padding-bottom: 20px; margin-bottom: 30px; }
.comment-list { list-style: none;  padding: 0px;}
.comment { }
.comment-body { margin-top: 20px; margin-bottom: 30px; border-bottom: 1px solid #F7F7F8; padding-bottom: 20px; }
.comment-author { }
.comment-author img { float: left; }
.comment-info { padding-left: 120px; }
.comment-header { margin-bottom: 0px; }
.user-title { font-size: 15px; color: #474747; margin-bottom: 10px; font-weight: 500; }
.comment-meta { }
.comment-meta-date { color: #98989c; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; font-weight: 500; }
.comment-content { color: #6f6f6f; margin-bottom: 20px; }
.reply { }

/*---- thread comments --------*/
.childern { padding-left: 100px; list-style: none; }
.childern .comment-body { background-color: #F7F7F8; padding: 20px; border-radius: 10px; }
.childern .comment-info { padding-left: 120px; }

/*----- Leave Reply -----*/
.leave-comments { margin-top: 30px; background-color: #F7F7F8; padding: 40px; border-radius: 10px;}
.leave-comments .control-label { color: #474747; font-weight: 600; font-size: 13px; }


/*------------------------
  thanks
--------------------------*/

.thanks-section{height: 100vh;background-color: #fff;
}
.thanks-box{ margin: 150px 0 0 0;text-align: center}
.thanks-title{ font-size: 20px;line-height: 40px}

/*--------------------------------
 Extra Plugin CSS - Back to top  
---------------------------------*/
.cd-top { display: inline-block; height: 40px; width: 40px; position: fixed; bottom: 40px; right: 10px; overflow: hidden; text-indent: 100%; white-space: nowrap; background: rgba(212, 27, 44, 100) url(../images/cd-top-arrow.svg) no-repeat center 50%; visibility: hidden; opacity: 0; -webkit-transition: opacity .3s 0s, visibility 0s .3s; -moz-transition: opacity .3s 0s, visibility 0s .3s; transition: opacity .3s 0s, visibility 0s .3s; }
.cd-top.cd-is-visible, .cd-top.cd-fade-out, .no-touch .cd-top:hover { -webkit-transition: opacity .3s 0s, visibility 0s 0s; -moz-transition: opacity .3s 0s, visibility 0s 0s; transition: opacity .3s 0s, visibility 0s 0s; }
.cd-top.cd-is-visible {    /* the button becomes visible */
visibility: visible; opacity: 1; }
.cd-top.cd-fade-out {    /* if the user keeps scrolling down, the button is out of focus and becomes less visible */
opacity: .5; }
.no-touch .cd-top:hover { background-color: #e70359; opacity: 1; }

/*-------------styleguide-------------*/
.box-info { }
.box-default-color { background-color: #0457CC; height: 160px; width: 160px; }
.box-primary-color { background-color: #18150d; height: 160px; width: 160px; }
.box-heading-color { background-color: #18150d; height: 160px; width: 160px; }
.box-secondary-color { background-color: #6f6f6f; height: 160px; width: 160px; }
.box-bg-color { background-color: #eddba5; height: 160px; width: 160px; }

/*==========  Non-Mobile First Method  ==========*/

    /* Large Devices, Wide Screens */
    @media only screen and (max-width : 1200px) {
		.logo {	width:200px;}
     .navigation { float: right; }
     .hero-title {}
     .hero-section {padding-top: 50px; padding-bottom: 50px;}
     .comment-info {padding-left: 100px;}
     .cta-title {font-size: 26px; line-height: 40px;}
     .cta-section {padding-top: 50px; padding-bottom: 50px;}
     .footer-widget {margin-bottom: 20px;}
     .footer-widget .widget-title {margin-bottom: 0px;}
     .page-title {font-size: 25px;}
     .page-caption {padding: 80px 0px;}
   
     .contact-box{width: 100%}
     .contact-ttl{margin-top:20px; text-align: center;font-size: 35px;font-weight: bold;color: #000}
   
     .sp{display: none}
     .pc{display: block}
    }

    /* Medium Devices, Desktops */
    @media only screen and (max-width : 992px) {
		.logo {	width:200px;}
     .navigation { float: right; }
     .hero-title {margin-top: 30px;}
     .hero-section {padding-top: 50px; padding-bottom: 50px;}
     #service{margin-top: 90px}
     .footer-widget {margin-bottom: 20px;}
     .footer-widget .widget-title {margin-bottom: 0px;}

     .service-menu{width: 100%;margin: 0 auto}
     .service-block{}
     .service-img{height: 100px}
        .common-text{margin-top: 60px}
     #contact{}
     .contact-box{width: 100%}
     .contact-ttl{margin-top:30px; text-align: center;font-size: 35px;font-weight: bold;color: #000}
     
     .sp{display: none}
     .pc{display: block}

    }

    /* Small Devices, Tablets */
    @media only screen and (max-width : 768px) {
		.header {width: 100%; position: relative; padding-top: 0px; padding-bottom: 10px; height: 130px;text-align: center}
	 .logo {position: relative; margin: 0 auto;text-align: center;float: none; width:250px;}
        .navigation{float: none;margin-top:30px}
     #navigation{float: none; width: 100%; text-align: center;margin: 20px auto ;}
      #navigation ul{text-align: center;margin: 0 auto;}
     .hero-title {}
     .hero-section {padding-top: 20px; padding-bottom: 30px;}
        #service{margin-top: 0px}

     .footer-widget {margin-bottom: 20px;}
     .footer-widget .widget-title {margin-bottom: 0px;}
        .common-text{margin-top: 20px}
     .service-menu{text-align: center; margin: 0 auto}
     .service-block{width:100%; display:block;margin:20px 0px 70px}

     .service-img{width:100%; height: auto; text-align:center;}
   

     .common-ttl{}
     .common-text{margin-top:60px}

            /*-------------------------
product
--------------------------*/

.item-block{
  margin-top: 45px; 
  margin: 45px auto 0;
  text-align: center;
  }
  
  .item-img{
    margin: 0 auto;text-align: center;
    width:100%; 
  margin:0 auto; 
  }
  .item-img img{width:100%;transition:.5s all;}

  .product-ttl{
    text-align: center;font-size: 20px;color: #000;
    margin: 0 auto;
  }

.product-block{
  display: block;
  margin: 45px auto 0;
  text-align: center;
  }
.product-img{
  margin: 0 auto;text-align: center;
}
.product-img img{width:70%;transition:.5s all;}
.product-text{
  margin: 20px auto;
  text-align: center;
height: 150px;
}
    
        
        
        
/*-------------------------
profile
--------------------------*/
.profile-ph{width: 60%;margin-top: 20px}
.profile-txt{margin-top: 20px;text-align: justify;font-size: 15px;font-weight: 300;line-height: 25px;}
        .img-center{text-align: center}
        

   /*-------------------------
  9.8 Contact us
---------------------------*/
#contact{width: 100%;margin:50px 0 auto;height:auto}
.contact-box{}
.contact-ttl{margin-top: 30px; text-align: center;font-size: 43px;font-weight: bold;color: #000}
.tel-ttl{margin-top: 20px; text-align: left;font-size: 50px;font-weight: bold;color: #000}
.contact-btn{color: #fff; background-color: #FBB03B;width:250px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 50px auto;padding: 10px 20px}

.contact-btn:hover{background-color: #FA8F00}
#submit_button{color: #fff; background-color: #FBB03B;width:200px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 30px auto 0;padding: 10px 20px;border: none;}
#submit_button2{color: #fff; background-color: #9FA0A0;width:200px;text-align: center;box-sizing: border-box;border-radius: 30px;margin: 20px auto;padding: 10px 20px;border: none;}
#submit_button:hover{opacity: .5}
#submit_button2:hover{opacity: .5}
#submit_button_cover{font-size: 18px}

#formWrap{margin: 0 auto;text-align: center;margin-top: 30px;width: 100%;  
 }


.formTable{  text-align: center;}
.inner{  display: inline-block;
  text-align: left;}
.mail-txt{}

.mail-ttl{text-align: left;font-size: 15px;font-weight: 500; margin-top: 10px}
.mail-box{text-align: left;width: 100%}


.mail-category{display:block;width: 100%;}
.br-pc{
  display: none;
}
     .pc{display: none}
     .sp{display:block}
    }

    /* Extra Small Devices, Phones */ 
    @media only screen and (max-width : 480px) {
        .header {width: 100%; position: relative; padding-top: 0px; padding-bottom: 15px; height: 140px;opacity: .9}
	 .logo {position: relative; margin: 0 auto;text-align: center;float: none; width:100%;}
        #navigation{float:none;margin-top: 0;text-align: center;margin: 0 auto;}
        #navigation ul li a{padding:5px 15px 5px 0; text-align:center; font-size: 16px}
        .top-box{padding:0 5%}
     .hero-title {font-size: 18px; text-align: justify;
text-justify: inter-ideograph;line-height: 35px;letter-spacing:0}
     .hero-section {margin-top:30px; padding-top:0; padding-bottom: 20px;}
 
     .footer-widget {margin-bottom: 20px;}
     .footer-widget .widget-title {margin-bottom: 0px;}
        .service-block{width:100%;display: block;height: auto; margin-bottom: 20px}
        .service-ttl{margin-top: 20px;}
        .service-img{width:100%}
        .service-img img{width:100%}
.common-ttl{margin: 0 auto}
     .common-text{margin-top: 20px;}
       .common-sub{margin-top:5px;} 

       /*-------------------------
product
--------------------------*/

.item-block{
  margin-top: 45px; 
  margin: 45px auto 0;
  text-align: center;
  }
  
  .item-img{
    margin: 0 auto;text-align: center;
    width:100%; 
  margin:0 auto; 
  }
  .item-img img{width:100%;transition:.5s all;}

  .product-ttl{
    text-align: center;font-size: 20px;color: #000;
    margin: 0 auto;
  }

.product-block{
  display: block;
  margin: 45px auto 0;
  text-align: center;
  }
.product-img{
  margin: 0 auto;text-align: center;
}
.product-img img{width:100%;transition:.5s all;}
.product-text{
  margin: 20px auto;
  text-align: justify;
height: 150px;
}
    

        
        /*-----------------------------------
   opening
-------------------------------------*/

.logo_fadein{
	background: #FFF;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;

}
.logo_fadein p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
        ;
}
        
        
.logo-open{width:90%}

        
        
        
.br-pc{display: none}
     .pc{display: none}
     .sp{display:block}
        pc{display: none}
     sp{display:inline}
        .space-small{margin-top: 0;padding: 0}

    }

    /* Custom, iPhone Retina */ 
    @media only screen and (max-width : 320px) {
		.logo {}
         .header {width: 100%; position: relative; padding-top: 0px; padding-bottom: 10px; height: 140px;opacity: .9}
     #navigation {width: 100%; float: none;margin-top: -5px}
        #navigation ul{width: 100%; float: none; }
        #navigation ul li{display: block;}
     .hero-title {font-size: 18px; text-align: justify;
text-justify: inter-ideograph;line-height: 35px;letter-spacing:1px}
     .hero-section {margin-top: 20px; padding-top: 10px; padding-bottom: 20px;}
        .common-text{margin-top: 70px}
     .footer-widget {margin-bottom: 20px;}
     .footer-widget .widget-title {margin-bottom: 0px;}
        .service-block{margin: 0 auto 20px}
        .service-ttl{font-size:18px;font-weight: 600}
     .common-ttl{margin: 0 auto}
    .wide-adjust{padding: 0 5%}
        .br-pc{display: none}
     .pc{display: none}
     .sp{display:block}
     pc{display: none}
     sp{display:inline}

    }
	
table.company {
	margin: 0 auto;
}
table.company {
	font-size:15px;
}
table.company th {
	padding:5px 0 6px;
	text-align:left;
	vertical-align:top;
	
	width:100px;
}
table.company td {
	padding:5px 0;
	text-align:left;
}

br.sp {
	display:none;
}

    /* Small Devices, Tablets */
    @media only screen and (max-width : 768px) {
/*table set*/


br.sp {
	display:inherit;
}
	}