/*
Theme Name: sakura
Author: Nouvelle murachi
Version: 1.0.0
*/

@charset "utf-8";

html {
    font-family: 'Lato', sans-serif;
    -webkit-font-smoothing: antialiased;
    -ms-text-size-adjust: 100%; /* 2 */
	-webkit-text-size-adjust: 100%; /* 2 */
}
body {
	  margin: 0 !important;
	  padding: 0 !important;
}
div, p, li {
	font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 14px;
	line-height: 1.5;
}
.sakura-basic h1 {
	font-size: 38px !important;
	margin-bottom: 50px;
	font-weight:bold;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.sakura-basic h2 {
	font-size: 34px !important;
	margin-bottom: 40px !important;
	font-weight:bold;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.sakura-basic h2 span {
	font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
	font-size: 16px !important;
	margin-left: 30px;
}
.sakura-basic h3 {
	font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight:bold;
	font-size: 14px !important;
}
.sakura-basic h4 {
	font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight:bold;
	color: #ff6699;
	font-size: 14px !important;
}
.sakura-basic a {
	color: #ff6699;
	text-decoration: underline; 	
}
.sakura-basic a:hover {
	text-decoration: none; 	
}
a:hover img {
	opacity: 0.7;
}


/* navigation
----------------------------------------------- */
.navi-bg {
	width: 100%;
	background: #de2d62;
	height: 65px;
	position: fixed !important;
	top: 0;
	left: 0;
	opacity: 0.7;
	z-index: 500;
}
#sakura-nav {
	padding: 0.2rem 1.5rem !important;
	position: fixed !important;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
}
#headNaviarea {
	width: 100%;
	position: relative;
}
#globalnavi {
	width: 610px;
	height: 24px;
	position: absolute;
	top: 12px;
	right: 0;
}
#globalnavi li {
	height: 24px;
	font-size: x-small;
	display: inline;
	float: left;
}
#globalnavi li a {
	display: block;
	height: 24px;
	text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
#globalnavi li.navi01 a {
	background: url(images/common/navi_home.png) no-repeat;
	width: 58px;
	margin-right: 50px;
}
#globalnavi li.navi01 a:hover {
	background: url(images/common/navi_home_wh.png) no-repeat;
	width: 58px;
}
#globalnavi li.navi02 a {
	background: url(images/common/navi_profile.png) no-repeat;
	width: 82px;
	margin-right: 50px;
}
#globalnavi li.navi02 a:hover {
	background: url(images/common/navi_profile_wh.png) no-repeat;
	width: 82px;
}
#globalnavi li.navi03 a {
	background: url(images/common/navi_menu.png) no-repeat;
	width: 57px;
	margin-right: 50px;
}
#globalnavi li.navi03 a:hover {
	background: url(images/common/navi_menu_wh.png) no-repeat;
	width: 57px;
}
#globalnavi li.navi04 a {
	background: url(images/common/navi_works.png) no-repeat;
	width: 69px;
	margin-right: 50px;
}
#globalnavi li.navi04 a:hover {
	background: url(images/common/navi_works_wh.png) no-repeat;
	width: 69px;
}
#globalnavi li.navi05 a {
	background: url(images/common/navi_contact.png) no-repeat;
	width: 101px;
}
#globalnavi li.navi05 a:hover {
	background: url(images/common/navi_contact_wh.png) no-repeat;
	width: 101px;
}

/* fixing bootstrap css */
.navbar-nav {
	background: #fff;
	opacity: 0.9;
	margin-top: 20px;
}
.nav-link {
	padding: 10px 20px !important;
}
.navbar-toggler {
  color: rgba(255, 255, 255, 0.5) !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
}
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

@media (max-width: 991.98px) {
	#headNaviarea {
		visibility: hidden;	
	}
	.navi-bg {
		height: 60px;
	}
}

/* footer
----------------------------------------------- */
.sakura-basic footer {
    text-align: right;
    margin-top: 70px;
    padding-bottom: 30px;
    background: #fff !important;
}
.sakura-basic footer p {
    margin: 0;
    font-size: 13px;
    color: #333 !important;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

/* common styles
----------------------------------------------- */
.section {
	margin: 5% 0;
}
.section-bg-left {
	width: 100% !important;
	margin: 0 auto;
	background: url(images/common/bg_base_left.png) no-repeat left 120px;
}
.section-bg-right {
	width: 100% !important;
	margin: 0 auto;
	background: url(images/common/bg_base_right.png) no-repeat right 120px;
}
#section-subpage {
	margin-top: 80px;
}
.btn-online {
	text-align: right;
}
.text-red {
	color: #eb6d95;
}
#section-subpage .btn-online {
	margin-bottom: 70px;
}
.subpage-block {
	margin-bottom: 120px;
}
.table-basic {
	width: 100%;
	border: 1px solid #cfd0d1;
}
.table-basic th {
	border: 1px solid #cfd0d1;
	padding: 5px 7px !important;
	text-align: center;
	background: #f491a8;
	color: #fff;
	font-weight: normal;
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.table-basic td {
	border: 1px solid #cfd0d1;
	padding: 7px !important;
	text-align: center;
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.table-basic td p {
	padding: 0 5px !important;
	margin: 0 !important;
	text-align: left;
}
.ul-indent {
	padding: 0;
}
.ul-indent li {
	padding: 0 0 0 1em;
	margin: 0;
	text-indent: -1em;
	list-style: none;
}
.mB20 {
	margin-bottom: 20px;
}

@media (max-width: 1401.98px) {
	#section-subpage .btn-online {
	margin: 40px 0 70px;
	}
	.subpage-block {
	margin-bottom: 80px;
	}
}
@media (max-width: 991.98px) {
	.section-bg-left {
	background: none;
	}
	.section-bg-right {
	background: none;
	}
	#section-subpage .btn-online {
	margin: 40px 0 70px;
	}
	.subpage-block {
	margin-bottom: 80px;
	}
}

/*--------------
  back to top
 ------------ */
#pageTop {
  position: fixed;
  bottom: 0;
  right: 0;
}
#pageTop i {
  padding-top: 5px;
  padding-right: 7px;
}
#pageTop a {
  display: block;
  z-index: 999;
  padding: 8px 0 0 8px;
  width: 50px;
  height: 50px;
  background-color: #000;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  font-size: 17px;
  opacity: 0.9;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* toppage
----------------------------------------------- */
#top-intro {
	position: relative;
}
#top-intro h2 {
	position: absolute;
	top: 30px;
	left: 0;
}
#top-intro div {
	text-align: right;
}
.top-maintext1 {
	margin-top: 90px;
}
.top-maintext2 {
	margin-top: 50px;
}

/* Masthead */
.masthead {
    position: relative;
}
.masthead-video {
    z-index: 0;
}
.masthead-overlay {
    background-color: #fff;
    opacity: 0;
    position: absolute;
    top: 0; left: 0;
    bottom: 0; right: 0;
    width: 100%;
    height: 100%;
}
.masthead-arrow {
    position: absolute;
    bottom: 25px;
    left: 0;
    right: 0;
    margin: auto;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    width: 30px;
    height: 30px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    opacity: 0.4;
}
.masthead h1 {
    position: absolute !important;
    width: 100%;
    text-align: center;
    height: 240px;
    line-height: 1;
    top: 0;
    bottom: 0;
    margin: auto !important;
    padding: 0 10%;
}
.masthead h1 span {
    display:block;
    margin-top: 60px;
}

/* slider */
.top-slider {
	margin: 50px 140px 100px 0;
    width: 1070px;
}
#crossfade {
    position: relative;
    z-index: 1;
    overflow: visible;
    height: 650px;
}
#crossfade2 {
    position: relative;
    z-index: 1;
    overflow: visible;
    height: 700px;
}
#crossfade li,
#crossfade2 li {
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    list-style: none;
}

@media (max-width: 1391.98px) {
	.top-maintext1 {
		margin-top: 200px;
	}
}
@media (max-width: 991.98px) {
	 #top-intro h2 {
	 	position: inherit;
	}
	#top-intro .btn-online {
		margin-top: 70px;	
	}
	.top-maintext1 {
		margin-top: 70px;
	}
	.top-maintext2 {
		margin-top: 30px;
	}
	.top-slider {
		margin: 50px 0;
		width: 100% !important;
	}
	#crossfade {
    	height: 400px;
	}
}
@media (max-width: 768px) {
	.top-maintext1 {
	margin-top: 50px;
	}
	.top-maintext2 {
		visibility: hidden;
		height: 0;
	}
	.top-maintext-sp {
		text-align: center !important;
	}
	#crossfade2 {
		height: 700px;
	}
	.subpage-logo {
		visibility: hidden;
		height: 0;
	}
	#section-subpage .btn-online {
		margin: 10px 0 50px;
	}
}
@media (max-width: 576px) {
	#crossfade {
    	visibility: hidden;
		height: 0;
	}
	#crossfade2 {
		height: 600px;
	}
}
@media (max-width: 440px) {
	.top-maintext2 {
		visibility: hidden;
		height: 0;
	}
	.top-maintext-sp {
		text-align: center !important;
	}
	#crossfade2 {
    	height: 500px;
	}
}

/* profile
----------------------------------------------- */
.profile-section {
	width: 100%;
	max-width: 1500px;
	margin: -235px auto 0;
}
.profile-section img {
	width: 100%;
}
@media (max-width: 991.98px) {
	.profile-btn {
		height: 215px;
	}
}
@media (max-width: 768px) {
	.profile-btn {
		visibility: hidden;
	}
}
@media (max-width: 576px) {
	
	.profile-section-pc {
		visibility: hidden;
		height: 0;
	}
}

/* works
----------------------------------------------- */
.works-thumb {
	text-align: center;
	margin-bottom: 30px;
}
.works-thumb img {
	width: 100%;
	height: auto;
}
.works-date {
	border-top: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
	padding: 15px;
	font-size: 1.1em;
	margin: 0;
}
.works-name {
	border-bottom: 1px dotted #ccc;
	padding: 15px;
	font-size: 1.1em;
	margin: 0 0 30px;
}
.works-box {
	margin-bottom: 30px;
	border-bottom: 1px dotted #ccc;
}
.works-box h3 {
	font-size: 1.2em;
	margin-bottom: 15px;
	padding-bottom: 10px;
}

/* contact
----------------------------------------------- */
.form-group {
	padding-bottom: 20px;
}
.form-group input {
	width: 100% !important;
}
.form-control-file {
	padding: 5px !important;
	border-radius: 5px !important;
	margin-right: 10px;
}
.wpcf7-submit {
	background: #eb6d95;
	color: #fff !important;
	margin-left: 4px;
	padding: 10px 50px;
	margin-bottom: 0;
	font-weight: normal !important;
	text-decoration: none !important;
	font-weight: bold;
	font-size: 16px;
}

/* online service
----------------------------------------------- */
.section-os {
	width: 100% !important;
	margin: -15px auto 0;
	padding-top: 14px;
	max-width:1500px;
	background: url(images/subpage/os-bg.jpg) no-repeat center top;
}
.os-sakusaku {
	margin-top: 20px;
}
.os-banners {
	margin-top: 60px;
}
.os-banners img {
	margin-bottom: 40px;
}

@media (max-width: 991.98px) {
	.section-os {
		margin: -20px auto 0;
	}
}
@media (max-width: 768px) {
	.section-os {
		background-size: 100%;
	}
	.os-text-hide {
		visibility: hidden;
		height: 0;
		margin-bottom: 30px;
	}
	.os-banners {
	margin-top: 30px;
	}
	.os-banners img {
		margin-bottom: 20px;
	}
}