@charset "UTF-8";
@font-face {
  font-family: YuGothicM;
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* Windows8.1ではMediumがないのでRegularを指定 */ }
@font-face {
  font-family: YuGothicM;
  font-weight: bold;
  src: local("YoGothic-Bold"), local("Yu Gothic");
  /* Chrome用 */ }
/* バージョン5 */
/* 各ページ共通の CSS
------------------------------------------ */
body {
  color: #333333;
  font-family: "Noto Sans Japanese", Verdana, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif, serif;
  font-size: 1rem;
  line-height: 1.7;
  /* font-sizeを基準に相対値 */ }

/* トップページのみ jumbotron との距離を縮めるため */
body#index,
body#test {
  /*padding-top: 80px;*/ }

/* メディアクエリ（転記用）モバイルファースト版
--------------------------------- */
/* メディアクエリ（転記用）逆方向版
--------------------------------- */
/* オーバーライト（再定義用） 
--------------------------*/
/* ヘッダの送り行を1remに */
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
  margin-bottom: 1rem; }

/* レイアウト 
--------------------------*/
/* レイアウトブロック */
.block {
  margin-bottom: 30px; }

.block_border {
  border: 1px solid #000;
  padding: 30px; }

.block_border_color {
  border: 1px solid #E2007E;
  border-radius: 8px;
  padding: 30px; }

/* ドットの飾り下線 */
.border_dotted {
  padding-top: 20px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #ddd; }

/* ドットの飾り下線_タブレット以下の時は余白を小さく */
@media only screen and (max-width: 768px) {
  .border_dotted {
    padding-top: 0px;
    margin-bottom: 10px;
    border-bottom: 1px dotted #ddd; } }
/* ヘッダー */
header {
  background-color: #FFF; }

/* ペーパーシャドウ（マテリアルデザイン） */
header,
.paper_shadow {
  -webkit-box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
  -moz-box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
  position: relative; }

/* マップ背景 */
#map {
  background-color: #EEEEEE; }

/* タイポグラフィ 
--------------------------*/
/* フォントサイズ */
h1 {
  font-size: 1.4rem;
  font-weight: 600; }

h2 {
  font-size: 1.2rem;
  font-weight: 500; }

h3 {
  font-size: 1.1rem; }

h4 {
  font-size: 1rem; }

h5 {
  font-size: 0.9rem; }

h6 {
  font-size: 0.85rem; }

h1 .small {
  font-size: 1.2rem; }

h2 .small {
  font-size: 1rem; }

h3 .small {
  font-size: 1rem; }

h4 .small {
  font-size: 0.85rem; }

/* 行間調整 */
.gyokan_00 {
  margin-bottom: 0; }

.gyokan_10 {
  margin-bottom: 10px; }

.gyokan_20 {
  margin-bottom: 20px; }

.gyokan_30 {
  margin-bottom: 30px; }

.gyokan_40 {
  margin-bottom: 40px; }

/* フォントを明朝に */
.mincho {
  letter-spacing: 0.1em;
  line-height: 1.8em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

/* タイトル */
.title {
  font-weight: 700; }

p.title {
  border-bottom: dotted 1px #CCC;
  margin-bottom: 4px;
  padding: 2px 0; }

h1.title {
  color: #fff;
  padding: 4px 0;
  font-size: 2em; }

/* ページヘッダ */
.page_header {
  background-color: #EEEEEE;
  padding: 2rem 0;
  text-align: center;
  font-weight: 700;
  margin-bottom: 3rem; }

.page_header h1 {
  line-height: 1;
  margin-bottom: 0; }

/* リード部分 */
h2.title {
  color: #333333;
  margin-bottom: 10px;
  padding: 4px 0; }

/* ツートーンカラーのアンダーバー */
h2.title + .under_bar {
  display: inline-block;
  width: 240px;
  height: 4px;
  background-image: -webkit-linear-gradient(0deg, #E2007E 0, #E2007E 30%, #EEEEEE 30%, #EEEEEE 100%);
  background-image: -moz-linear-gradient(90deg, #E2007E 0, #E2007E 30%, #EEEEEE 30%, #EEEEEE 100%);
  background-image: linear-gradient(90deg, #E2007E 0, #E2007E 30%, #EEEEEE 30%, #EEEEEE 100%);
  background-position: 50% 50%;
  -webkit-background-origin: padding-box;
  background-origin: padding-box;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-background-size: auto auto;
  background-size: auto auto; }

/* アイテム（アンダーバータイプ） */
h3.title {
  border-bottom: dotted 1px #CCC;
  margin-bottom: 10px;
  padding-bottom: 10px; }

h3.title b,
h3.title strong {
  color: #333333;
  font-size: 140%;
  font-weight: 700; }

h5.title {
  border-bottom: solid 1px #CCC;
  margin-bottom: 10px;
  padding-bottom: 10px; }

/* アイテム（大きい数字タイプ） */
.number_title {
  font-size: 5em;
  font-family: "Lato", sans-serif; }

/* アイテム（囲みタイプ） */
p.box_title {
  border: 1px solid #E2007E;
  color: #E2007E;
  text-align: center;
  padding: 10px;
  margin-top: 8px; }

/* アイテム（大きい数字タイプ） */
h3.number_title {
  font-size: 3em;
  color: #E2007E;
  font-family: "Lato", sans-serif; }

.message {
  font-size: 1.8em;
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  line-height: 1.7em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

/* 強調文字 */
.caution {
  font-weight: bold;
  color: #E2007E; }

/*数字のフォント変更 */
.concept_number {
  font-family: "Lato", sans-serif;
  font-size: 1.5em;
  color: #E2007E;
  text-shadow: 0 0 3px white, 0 0 6px white;
  /* グローエフェクト */ }

/* リンクカラー */
a {
  color: #00468C;
  text-decoration: none; }

a:hover,
a:focus {
  color: rgba(0, 70, 140, 0.7);
  text-decoration: none; }

/* リンクした画像は hover時 半透明 */
a:hover img,
a:active img {
  opacity: 0.7; }

/* リンクの部品 */
.square_btn {
  position: relative;
  display: inline-block;
  border-radius: 20px;
  padding: 0.5em 2em;
  text-decoration: none;
  color: #fff;
  background: #E2007E;
  transition: .4s; }

.square_btn:hover {
  background: #ECECEC;
  color: #E2007E; }

/* リード */
.lead {
  font-size: 1.1rem; }

/* インデント（マージン調整版） */
.indent {
  margin-left: 2rem; }

.indent2 {
  margin-left: 4rem; }

.indent3 {
  margin-left: 6rem; }

/* アイコン Font Awesome
------------------------------------------ */
/* Android や iPhone で表示されない時は、FontAwesome の提供する CDN を無効にし、以下の記述を効かせること  
@import url(//use.fontawesome.com/releases/v5.2.0/css/all.css);*/
/* font awesome 右マージン調整 */
.fa,
.fas,
.far {
  margin-right: 6px; }

/* 新たな FontAwesome 5 では使うフォントごとにウェイトが必要 */
.fas {
  font-weight: 900; }

/* fes SOLID の場合 */
.far {
  font-weight: 400; }

/* fer REGULAR の場合 */
/* 頭に矢印をつける */
.arrow:before,
article .arrow:before,
.post .arrow:before {
  content: "\f138";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  width: 1.2em; }

.arrow {
  color: #00468C; }

/* リンクの頭には別の矢印をつける */
a.arrow:before,
article a.arrow:before,
.post a.arrow:before {
  content: "\f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  width: 1.2em; }

/* ご注意アイコンを付ける */
.warning:before,
article .warning:before,
.post .warning:before {
  content: "\f071";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  width: 1.2em; }

.warning {
  color: #CC0000; }

/* チェックマークアイコン */
.check:before,
article .check:before,
.post .check:before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-block;
  width: 1.2em; }

/* Back to Top のアイコンは黒ベースに */
.back-to-top {
  color: #E2007E; }

/* ナビゲーション
--------------------------------- */
/* ナビゲーションの調整 */
.navbar {
  /*min-height: 80px;*/
  padding: 0 1rem; }

/* ナビバーの背景はグラデーション */
.navbar-light {
  background-image: -webkit-linear-gradient(-90deg, #F6C3DC 0, #EE68B3 100%);
  background-image: -moz-linear-gradient(180deg, #F6C3DC 0, #EE68B3 100%);
  background-image: linear-gradient(180deg, #F6C3DC 0, #EE68B3 100%);
  background-position: 50% 50%;
  -webkit-background-origin: padding-box;
  background-origin: padding-box;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-background-size: auto auto;
  background-size: auto auto; }

/* スマホ時のプルダウンメニューの調整 */
.navbar-light .navbar-toggler {
  color: #333;
  border: none; }

/* ナビのホバー色 */
.navbar-light .navbar-nav > li > a:hover,
.navbar-light .navbar-nav > li > a:focus {
  color: #333333;
  background-color: rgba(255, 255, 255, 0.2); }

/* ラージ、ワイドのときのナビの設定 */
@media (min-width: 992px) {
  /* ナビバーのリンクの幅を広めにした */
  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem; } }
/* スマホ、ファブレット、タブレットのときのナビの設定 */
@media (max-width: 991.98px) {
  /* プルダウンメニューの境界線 */
  .navbar-nav > li.nav-item {
    border-top: dotted 1px #FFF; }

  /* 幅をマイナスマージンで調整 */
  .navbar-collapse {
    margin-left: -1rem;
    margin-right: -1rem; }

  /* 上記をすると文字が左側にくっつくので */
  .navbar-nav > li.nav-item > .nav-link {
    padding-right: 1rem;
    padding-left: 1rem; } }
/* ドロップダウンで active なコンテンツに背景色がつくのをやめる */
.navbar-light .navbar-nav .open .dropdown-menu > .active > a,
.navbar-light .navbar-nav .open .dropdown-menu > .active > a:focus,
.navbar-light .navbar-nav .open .dropdown-menu > .active > a:hover {
  color: #E2007E;
  background-color: transparent; }

/* ハンバーガーメニューの調整 */
.navbar-toggle {
  margin-top: 13px; }

/* スマホ時ナビゲーションの 上下の幅を広げる */
.navbar-nav > li > a {
  	/*min-height: 59px;
    line-height: unset;
  	padding-top: 15px;
  	padding-bottom: 15px;*/ }

/* ナビゲーションの項目が多いので余白を詰めカラム落ちしないように */
.nav > li > a {
  padding: 15px 11px; }

.dropdown-menu {
  padding: 0;
  box-shadow: none; }

/* ナビゲーション ドロップダウン時の上下の幅を広げる */
.dropdown-menu > li {
  padding: 8px 0px; }

/* ナビゲーション スマートフォンの時ロゴの左に余白を付ける */
@media only screen and (max-width: 768px) {
  .navbar-brand {
    margin-left: 10px; } }
/* ナビゲーションの高さの制限を解除*/
.navbar-fixed-bottom .navbar-collapse, .navbar-fixed-top .navbar-collapse {
  max-height: none; }

/* ナビゲーション_スマホ時のドロップダウンのhover */
.navbar-light .navbar-nav .open .dropdown-menu > li > a:hover {
  color: #E2007E;
  background-color: #fff; }

/* パンくずリストの調整 */
.breadcrumbs {
  font-size: 0.9em;
  padding-bottom: 40px;
  margin-top: -30px; }

.breadcrumbs a {
  color: #252525; }

/* スライダー（fxslider）
--------------------------------- */
/* スライダー背景 */
.slider {
  background-color: #EEE;
  /*padding: 0;*/ }

/* スライダーのボーダー消去・白背景削除 */
.flexslider {
  margin: 0;
  border: none;
  background-color: transparent; }

/* スライダー下の丸いコントロール消去 */
.flex-control-paging {
  display: none; }

/* スライダー左右のコントロール下が切れるので */
.flex-direction-nav a {
  height: 50px; }

/* スライダーのオーバーレイ */
.slider .overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10; }

/* HOME
------------------------------------------ */
/* 言語選択の国旗の幅を小さく */
.lang_select img {
  width: 20px; }

@media (min-width: 768px) {
  .lang_select img {
    width: 24px; } }
/* HOME_info */
.info_date {
  color: #E2007E;
  margin-right: 20px; }

ul.info {
  list-style: none;
  padding-left: 0; }

ul.info li {
  border-bottom: dotted 1px #CCCCCC;
  padding: 4px 0; }

@media only screen and (max-width: 479px) {
  .info_date {
    display: block; } }
/* カバー写真 */
.cover {
  background-image: url(../images/img_top_concept.jpg);
  background-size: cover;
  height: 500px; }

/* footer 
------------------------------------------ */
footer {
  background-image: -webkit-linear-gradient(-90deg, #F6C3DC 0, #EE68B3 100%);
  background-image: -moz-linear-gradient(180deg, #F6C3DC 0, #EE68B3 100%);
  background-image: linear-gradient(180deg, #F6C3DC 0, #EE68B3 100%);
  background-position: 50% 50%;
  -webkit-background-origin: padding-box;
  background-origin: padding-box;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-background-size: auto auto;
  background-size: auto auto;
  color: #333333;
  padding: 20px 0;
  margin-top: 40px; }

.footer_title {
  font-size: 1.4rem;
  font-weight: 600;
  color: #C7C7C7; }

.footer-logo {
  margin-top: 30px;
  margin-bottom: 15px;
  background: url("../images/logo_white.png") no-repeat left center;
  background-size: contain;
  height: 30px;
  width: 120px; }

.footer-nav {
  padding-left: 0; }

.footer_btn {
  margin-top: 20px;
  margin-bottom: 20px; }

.footer_btn a {
  padding: 10px 20px;
  margin: 0 30px;
  color: #fff;
  border: 1px solid #fff;
  transition: all .3s; }

.footer_btn a:hover
.footer_btn a:active {
  color: #000;
  background-color: #fff;
  text-decoration: none; }

.footer-nav li {
  font-size: 1.3rem;
  list-style: none;
  margin-bottom: 5px; }

.footer-nav li a {
  color: #fff; }

.footer-nav li a:hover,
.footer-nav li a:focus {
  color: #fff;
  opacity: 0.9;
  text-decoration: underline; }

/* スマホ用アイコンボタン内アイコンの色 */
footer .fa-inverse {
  color: #E2007E; }

/* スマホ用アイコンボタン内アイコンの背景色 */
footer .tap a {
  color: #fff; }

/* スマホ用アイコンボタンをタップした時の色 */
footer .tap a:hover,
footer .tap a:focus {
  color: rgba(255, 255, 255, 0.5); }

footer .tap a:hover .fa-inverse,
footer .tap a:focus .fa-inverse {
  color: #FFF; }

/* スマホ用アイコンボタン下のテキスト */
footer .tap p {
  padding-top: 8px; }

/* footer_最下部のリンク */
.footer-links a {
  /*margin-right: 25px;*/
  font-size: 0.9em; }

/* コピーライト */
.copyright {
  padding: 0.3rem;
  background-color: #333;
  color: #FFF; }

.copyright p {
  line-height: 1;
  margin-bottom: 0; }

.copyright small {
  font-weight: 200; }

.footer_btn {
  padding-bottom: 40px;
  border-bottom: 1px dotted #ddd; }

/* コース
------------------------------------------ */
/* コースの背景色 */
.course_2 th {
  background-color: #FFA64D; }

.course_15 th {
  background-color: #FFDC73; }

/* プライバシーボリシー
------------------------------------------ */
/* 個々のタイトルの前にスペースを設ける */
#privacy h2.title,
#privacy h3.title {
  margin-top: 2rem;
  border-bottom: dotted 1px #CCC;
  margin-bottom: 10px;
  padding-bottom: 10px; }

/* qanda よくある質問
------------------------------------------ */
/*ボックス全体*/
.accbox {
  margin: 2em 0;
  padding: 0; }

/*Q.の色を$theme_colorに*/
.q-color {
  color: #E2007E; }

/*ラベル*/
.accbox label {
  display: block;
  margin: 1.5px 0;
  padding: 11px 12px;
  color: #252525;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.5s;
  border-bottom: solid 1.5px #f5f5f5; }

/*ラベルホバー時*/
.accbox label:hover {
  background: #f5f5f5; }

/*チェックは隠す*/
.accbox input {
  display: none; }

/*中身を非表示にしておく*/
.accbox .accshow {
  height: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.8s;
  margin-bottom: 20px; }

/*クリックで中身表示*/
.cssacc:checked + .accshow {
  height: auto;
  padding: 5px;
  opacity: 1; }

/*pの中身を読みやすく*/
.accshow p {
  line-height: 1.7; }

/* recruit_採用情報
------------------------------------------ */
/* bootstrapのデフォルトを書き換え */
.alert-danger {
  color: #000;
  background-color: #fff;
  border-color: #E2007E; }

.alert-danger a {
  color: #E2007E;
  font-weight: 600; }

.btn-danger {
  margin-top: 30px; }

/* テーブルの背景 */
table.works th {
  background: #EEEEEE; }

/* スマホ時の幅調整*/
@media (max-width: 767px) {
  table.works th {
    /*width: 35%;*/ } }
/* about_会社情報
------------------------------------------ */
.about_img {
  background-imag: url("../images/loopimage.png"); }

.dl-horizontal dd {
  text-align: left;
  padding-left: 40px;
  border-left: 1px dotted #252525;
  margin-bottom: 30px; }

@media (max-width: 767px) {
  /* スマホ時 */
  .dl-horizontal dt {
    border-bottom: 1px dotted #252525; }

  .dl-horizontal dd, dt {
    text-align: center; }

  .dl-horizontal dd {
    padding-left: 0;
    padding-top: 5px;
    border: none; } }
/* equipment_スムホームの標準仕様
------------------------------------------ */
/* 左に黒見出し） */
.equipment_item_title {
  font-weight: 600;
  border-bottom: solid 1px #000;
  border-left: solid 6px #000;
  padding: 5px 0px 5px 10px; }

/* 製品特徴の説明文 */
section.point p {
  line-height: 1.5;
  padding-top: 10px; }

.example {
  position: relative;
  margin-bottom: 30px; }

.example:nth-child(even) {
  margin-bottom: 0; }

.example a {
  /*aタグを画像の真ん中に*/
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  margin: 0;
  /*余計な隙間を除く*/
  border: solid 2px #fff;
  /*線で囲う*/
  padding: 7px 15px;
  /*文字と線の間の余白*/
  color: #fff;
  /*文字色*/
  text-decoration: none;
  /*下線を表示させない*/ }

.example a:hover {
  /*カーソルを当てたとき*/
  background: rgba(255, 255, 255, 0.3);
  /*背景を半透明に*/ }

.example img {
  width: 100%; }

.example::before {
  background-color: rgba(0, 0, 0, 0.3);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: ' '; }

/* voices_お客様の声
------------------------------------------ */
/* マウスオーバーでキャプション表示 
参考サイト：http://www.nxworld.net/tips/css-only-caption-effect.html
*/
.portfolio figure {
  position: relative;
  overflow: hidden; }

.portfolio figcaption {
  position: absolute;
  bottom: -100%;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  -webkit-transition: .3s;
  transition: .3s;
  padding: 6px; }

.portfolio figure:hover figcaption {
  bottom: 0; }

/* マウスオーバーで写真ちょっと拡大 */
.portfolio figure .transform {
  /* baguettebox 適用でおかしくなるので外した */
  -webkit-transform: scale(1);
  transform: scale(1);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out; }

.portfolio figure:hover .transform_xxx {
  /* baguettebox 適用でおかしくなるので外した */
  -webkit-transform: scale(1.1);
  transform: scale(1.1); }

/* キャプション内は下マージンなし */
.portfolio figcaption > * {
  margin-bottom: 0;
  color: #FFF; }

/* 写真の下マージンの調整 */
.portfolio figure.portfolio-item {
  margin-bottom: 20px; }

/* アイコンを四角のボタンに */
a.portfolio-zoom i.fa,
a.portfolio-zoom i.fas,
a.portfolio-link i.fa,
a.portfolio-link i.fas {
  padding: 15px;
  background-color: rgba(255, 255, 255, 0.3);
  display: inline-block; }

/* アイコンの hover 時背景 */
a.portfolio-zoom i.fa:hover,
a.portfolio-zoom i.fas:hover,
a.portfolio-link i.fa:hover,
a.portfolio-link i.fas:hover {
  background-color: #D9A300;
  color: #FFF; }

/* 物件名・カテゴリのマージン、文字色調整 */
.portfolio-text {
  height: 100px; }

.portfolio-text > * {
  margin-top: 0;
  margin-bottom: 0;
  color: #FFF;
  line-height: 1.4; }

/* アイコンは中央揃え */
.portfolio-icons {
  text-align: center; }

.portfolio-icons a {
  color: #FFF; }
