@charset "utf-8";
/*
Theme Name: Asairo Design
Author: asairo desgin
Author URI: https://asairo.com
Description: 浅色デザインのスタイルテーマ
Version: 2021．02.27
Text Domain: asairo-design
*/

/*--------------------------------------------------
  reset css
--------------------------------------------------*/
/* margin, paddingの幅を考慮せずに幅指定を可能にする */
* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { 
  padding: 0; margin: 0; border: 0; font-style:normal; font-weight: normal; font-size: 100%; vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
html {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ＭＳ ゴシック", sans-serif;
}
h1, h2, h3, h4, h5, h6 {
  /*font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;*/
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ＭＳ ゴシック", sans-serif;
}
blockquote, q { quotes: none; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
input, textarea { padding: 0; margin: 0; }
input[type="button"],input[type="submit"] { -webkit-appearance: none; }
ol, ul{ list-style:none; }
table{ border-collapse: collapse; border-spacing:0; width: 100%; }
caption, th{ text-align: left; }
a:focus { outline:none; }
img { width: 100%; height: auto; display: block; vertical-align: bottom; }
.inline_block { display: inline-block; *display: inline; *zoom: 1; }
/* 入力フォームのパーツデザイン */
input[type="text"], input[type="password"], input[type="datetime"], input[type="datetime-local"],
input[type="date"], input[type="month"], input[type="time"], input[type="week"], input[type="number"],
input[type="email"], input[type="url"], input[type="search"], input[type="tel"], input[type="color"],
select, textarea, .field {
  padding: 0 14px; display: block; height: 44px; line-height: 44px;
  vertical-align: middle; box-shadow: none; border: 0;
  width: 100%; background-color: #fff; font-size: 16px; border: 1px solid #ccc;
  -webkit-transition: background-color 0.24s ease-in-out;
  transition: background-color 0.24s ease-in-out;
}
input::-webkit-input-placeholder, input:-ms-input-placeholder, input::-moz-placeholder {
  color: #ccc; font-weight: normal;
}
select {
  -webkit-appearance: none;
  /* 1 */
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAHCAYAAADXhRcnAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpEOEZCMjYxMEYwNUUxMUUyOTI4REZGQTEzMzA2MDcyNiIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpEOEZCMjYxMUYwNUUxMUUyOTI4REZGQTEzMzA2MDcyNiI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkQ4RkIyNjBFRjA1RTExRTI5MjhERkZBMTMzMDYwNzI2IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkQ4RkIyNjBGRjA1RTExRTI5MjhERkZBMTMzMDYwNzI2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Vxkp9gAAAI9JREFUeNpidHFxucHAwKAOxE+AmJmBMPgLxDJAfJMFSKwD4kqoAClgA+P///8ZXF1dPaCGcBKh6QcQB+3evXs7WDMIAA2QB1I7gFgDj0aQFz2BGh+AOEwwUaDAQyBlCMR7cGjcC5KHaQQBuM3IAOiKTiBVhiTUDdRUhq4Oq2aoAelAahIQ5wM1zsCmBiDAADhYMJXVZ9u9AAAAAElFTkSuQmCC);
  background-repeat: no-repeat;
  background-position: 97.5% center;
}


/*--------------------------------------------------
  reset css
--------------------------------------------------*/
/* PC対応 */
@media screen and (min-width: 781px) {
  .pc_view { display:block; }
  .sp_view { display:none; }
}

/* スマートフォン対応 */
@media screen and (max-width: 780px) {
  .pc_view { display:none; }
  .sp_view { display:block; }
}

/*--------------------------------------------------
  リンク
--------------------------------------------------*/
/*【注意】順番を入れ替えると正常に動作しなくなります*/
a {
  color: #707070; text-decoration: none; -webkit-transition: 0.3s; -moz-transition: 0.3s;
  -o-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s;
}
a:visited { color: #1A1311; }
a:hover { color: #1A1311; /*background: rgba(255,255,255,0.8);*/ opacity:0.8; -moz-opacity:0.8; filter: alpha(opacity=80); }
a:active { color: #1A1311; }



/*--------------------------------------------------
  画像
--------------------------------------------------*/


/*--------------------------------------------------
  装飾
--------------------------------------------------*/
/* margin */

/* padding */

/* 位置揃え */

/* フォント */
html, body { width: 100%; height: 100%; color: #545454; background-color: #FFF; line-height: 1.6;  }
html { font-size:62.5%; }   /* ！！！消去厳禁！！！ */
body { font-size: 1.6rem; }
.bold { font-weight: bold; }
em { color: #586370; }
strong, b { font-weight: 600; }
p { margin: 0 0 1em 0; }
.underline { border-bottom: 2px solid; padding-bottom: 0.1em; }
a.underline { color: #5B97E1; }


.mb10 { margin-bottom: 10px!important; }
.mb20 { margin-bottom: 20px!important; }
.mb30 { margin-bottom: 30px!important; }
.mb40 { margin-bottom: 40px!important; }
.mb50 { margin-bottom: 50px!important; }
.mb60 { margin-bottom: 60px!important; }
.mb70 { margin-bottom: 70px!important; }
.mb80 { margin-bottom: 80px!important; }
.mb90 { margin-bottom: 90px!important; }
.mb100 { margin-bottom: 100px!important; }

.pl1em { padding-left: 1em!important; }
.pl2em { padding-left: 2em!important; }
.pl10 { padding-left: 10px!important; }
.pl20 { padding-left: 20px!important; }
.pl30 { padding-left: 30px!important; }
.pl40 { padding-left: 40px!important; }
.pl50 { padding-left: 50px!important; }
.pl60 { padding-left: 60px!important; }
.pl70 { padding-left: 70px!important; }
.pl80 { padding-left: 80px!important; }
.pl90 { padding-left: 90px!important; }
.pl100 { padding-left: 100px!important; }

.w50 { width: 50%!important; }
.w100 { width: 100%!important; }

/* PC, TAB, SP共通 */
/* clearfixを使用する場合は、親要素のclassに「cf」を追加する */
.cf:after { content: ""; clear: both; display: block; }


/*--------------------------------------------------
  メインスタイル開始
--------------------------------------------------*/ 
/*--------------------------------------------------
                全サイズの基盤スタイル
--------------------------------------------------*/

  main { position: relative; z-index: 1; }
  #main { margin: 0 auto; width: 100%; font-size: 16px; font-size: 1.6rem; }
  #content { margin: 0 auto; width: 100%; }
  .wrap { padding: 0 0%; margin: 0 auto; width: 100%; max-width: 1100px; position: relative; }
  .visual { position: relative; margin: 0 auto 0; width: 100%; max-width: 2000px; }
  .visual img { width: 100%; }
  .visual h1 { padding: 0 0 0 0; text-align: center; font-size: 40px; font-size: 4.0rem; font-weight: 600; position: relative; z-index: 1; }
  .visual h1 span { display: block; font-size: 30%; color: #e8e3e3; position: absolute; top: 15px; left: 0; right: 0; margin: 0 auto; }

  a.btn { }
  a.h_btn:hover { background: #078755; color: #fff; }


  .flex { display: flex; display: -webkit-box; display: -ms-flexbox; display: -webkit-flex; justify-content: space-between; align-items: stretch; }

  /* 矢印アイコン */
  .arrow { position: relative; display: inline-block; padding: 0 16px 0 0; vertical-align: middle; text-decoration: none; }
  .arrow::before, .arrow::after {position: absolute;top: 0;bottom: 0;right: 0;margin: auto;content: "";vertical-align: middle;}
  .maru::after { right: 5px; width: 3px; height: 3.2px; border-top: 1px solid #fff; border-right: 1px solid #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
  .maru:hover::after { border-color: #fff; }

  a.blank[target="_blank"] {
    &:after {
      content: '(外部リンク)';
      display: inline-block;
    }
  }


  /* font-family */
  .mincho { font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  .gothic { font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ＭＳ ゴシック", sans-serif; }
  .marugo { font-family:"ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO"; }
  .meiryo { font-family: "メイリオ", "Meiryo", sans-serif; }
  .italic { 
    -webkit-transform: skewX(-15deg);
    -moz-transform: skewX(-15deg);
    -o-transform: skewX(-15deg);
    transform: skewX(-15deg);
    -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=1, M12=-0.26794919243112214, M21=0, M22=1, SizingMethod='auto expand')";
  }
  .zenmaru { font-family: 'Zen Maru Gothic', serif; }
  .biz-udpgothic-regular {
    font-family: "BIZ UDPGothic", sans-serif;
    font-weight: 400;
    font-style: normal;
  }
  
  .biz-udpgothic-bold {
    font-family: "BIZ UDPGothic", sans-serif;
    font-weight: 700;
    font-style: normal;
  }
  

  .disc { list-style: disc; padding: 0 0 0 1em; }
  .disc li { margin-left: 0.5em; }
  .disc li::marker { font-size: 170%; }
  .disc li span { color: #E6305B; font-weight: bold; }
  .decimal { list-style: decimal; padding: 0 0 0 1em; }
  .decimal li { margin-left: 0.5em; }
  .decimal li::marker {  }
  .decimal li span { color: #E6305B; font-weight: bold; }
  .num { counter-reset: number 0; }
  .num li { margin-left: 1.8em; }
  .num li::before { counter-increment: number 1; content: "" counter(number) "　 "; margin: 0 0em 0 -1.8em; }

  .mac .num li,
  .iphone .num li,
  .ipad .num li {
    width: calc(100% - 3.6em);
  }
  .mac .num li::before,
  .iphone .num li::before,
  .ipad .num li::before {
    margin: 0 0 0 -1.8em;
  }

  .circle { list-style: circle; padding: 0 0 0 1.5em; }
  .diamond { list-style: none; padding: 0 0 0 2.4em; }
  .diamond li { margin-bottom: 10px; }
  .diamond li::before { content:'◆ '; margin-left: -1.4em; }
  .grecaptcha-badge { display: none!important; }


  
  /*--------------------------------------------------
  ヘッダー
  --------------------------------------------------*/
  .drawer--left .drawer-nav { display: flex; overflow: initial; position: absolute; width: calc(100% - 480px); padding: 0px 0 0px; background: transparent; right: 0; }
  /* floatクリア */
  .drawer-menu { *zoom: 1; }
  /* dropdown menu */
  .drawer-menu { position: relative; width: 100%; margin: 0 auto; display: flex; justify-content: flex-end; align-items: stretch; }
  .drawer-menu > li { padding: 0 0; display: inline-flex; justify-content: center; width: 25%; position: relative;}
  .drawer-menu > li:first-of-type {  }
  .drawer-menu > li a { color: #000000; display: inline-flex; justify-content: center; align-items: center; }
  .drawer-menu > li a.contact { width: 100%; }
  .drawer-menu > li a.contact i { margin-right: 5px; }
  /* 下矢印 */
  header { position: relative; z-index: 10; margin-bottom: 0; }
  header .header_wrap { display: flex; justify-content: space-between; align-items: stretch; max-width: 1550px; margin: 0px auto 0px; position: relative; }
  header .header_logo { width: 125px; margin: 10px 0; }
  header .header_logo a {  }

  

  /*--------------------------------------------------
  フッター
  --------------------------------------------------*/
  footer { margin: 200px 0 0; }
  footer .footer_wrap { max-width: 1100px; margin: 0 auto; }
  footer .footer_wrap .logo { display: flex; align-items: center; justify-content: center; margin: 0 0 50px; }
  footer .footer_wrap .logo a { width: 125px; }
  footer .footer_wrap .logo p { margin: 0 0 0 10px; font-size: 31px; font-weight: bold; }
  footer .footer_wrap .add_block { padding: 0 0px; }
  footer .footer_wrap .add_block .tel_area { margin-bottom: 50px; }
  footer .footer_wrap .add_block .tel_area a { display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }
  footer .footer_wrap .add_block .tel_area a img { width: 32px; }
  footer .footer_wrap .add_block .tel_area a span { font-size: 34px; font-weight: bold; color: #000; }
  footer .footer_wrap .add_block .add { text-align: center; font-size: px; }


  .copy { background: #3A75BB; width: 100%; padding: 20px 0 20px; text-align: center; position: relative; font-size: 16px; color: #fff; font-weight: bold; }



/* ----------------------------------------
* ページトップボタン 
---------------------------------------- */
.pagetop { position: fixed; bottom: 20px; right: 20px; display: block; z-index: 999; width: 50px; height: 50px; font-weight: bold; text-decoration: none; text-align: center; }
.pagetop:hover { cursor: pointer; opacity: 0.7; }

a.btn--circle {
  width: 60px;
  height: 60px;
  padding: 0;
  background: rgb(255 255 255 / 80%);
  border-radius: 50%;
  -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
  box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
}

a.btn--circle i { font-size: 150%; line-height: 60px; letter-spacing: 0; }
a.btn--circle .svg-inline--fa { vertical-align: -1.125em; -webkit-transition: all .3s; transition: all .3s; }
a.btn--circle:hover .svg-inline--fa { vertical-align: -0.125em; }



  /*ACCORDION*/
  .acMenu dt { display:block; cursor:pointer; }
  .acMenu dd { display:none; }


/*--------------------------------------------------
  ローディングロゴアニメーション
  --------------------------------------------------*/
  /* Loading背景画面設定　*/
#splash {
/*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 999;
  background:#fff;
  text-align:center;
  top: 0;
}

/* Loading画像中央配置　*/
#splash_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

/* Loading アイコンの大きさ設定　*/
#splash_logo img {
  width:100px;
  margin: 0 auto 10px;
}
#splash_logo .image {  }
#splash_logo .name {  }

/* fadeUpをするアイコンの動き */
#splash .fadeUp{
animation-name: fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity: 0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(0);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}


  /*--------------------------------------------------
  エフェクト
  --------------------------------------------------*/
/* 上からフェードイン */
.slide-top {
  opacity: 0;
  transform: translate(0, -20px);
  transition: all 1s ease-out;
 }

/* 下からフェードイン */
.slide-bottom {
  opacity: 0;
  transform: translate(0, 20px);
  transition: all 1s ease-out;
 }

 /* 左からフェードイン */
.slide-left {
  opacity: 0;
  transform: translate(-20px, 0);
  transition: all 1s ease-out;
 }

/* 右からフェードイン */
.slide-right {
  opacity: 0;
  transform: translate(20px, 0);
  transition: all 1s ease-out;
 }


 /*--------------------------------------------------
  animetion
  --------------------------------------------------*/
.anim { opacity: 0; }
/* フェードイン */
.fadein.is-animated {
  animation: fadeIn 0.7s cubic-bezier(0.33, 1, 0.68, 1) 1 forwards;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* スライドイン */
.slidein.is-animated {
  animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
}

@keyframes slideIn {
  0% {
    transform: translateX(180px);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
  }
  40%,100% {
    opacity: 1;
  }
}

/* ズームイン */
.zoomin.is-animated {
  animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
}

@keyframes zoomIn {
  0% {
    transform: scale(0.8);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* ぽよよん */
.poyoyon.is-animated {
  animation: poyoyon 0.5s cubic-bezier(0.12, 0, 0.39, 0) 1 forwards;
}

@keyframes poyoyon {
  0% {
    transform: translateX(140px);
    opacity: 0;
  }
  50% {
    transform: translateX(0);
  }
  65% {
    transform: translateX(30px);
  }
  100% {
    transform: translateX(0);
  }
  20%,100% {
    opacity: 1;
  }
}

/* ぽよよん2 */
.poyoyon2.is-animated {
  animation: poyoyon2 1s ease-in-out 1 forwards;
}

@keyframes poyoyon2 {
  0%  {
    transform: scale(1.0, 1.0) translate(0, 0);
  }
  15% {
    transform: scale(0.98, 0.9) translate(0, 5px);
  }
  30% {
    transform: scale(1.02, 1.0) translate(0, 8px);
  }
  50% {transform: scale(0.98, 1.05) translate(0, -8px);
  }
  70% {
    transform: scale(1.0, 0.9) translate(0, 5px);
  }
  100% {
    transform: scale(1.0, 1.0) translate(0, 0);
  }
  0%, 100% {
    opacity: 1;
  }
}

/* ぽよよん3 */
.poyoyon3 {
  animation: poyoyon3 2.5s infinite;
  opacity: 1;
}
@keyframes poyoyon3 {
  0%, 40% {
    transform: skew(0deg, 0deg);
  }
  5% {
    transform: skew(5deg, 5deg);
  }
  10% {
    transform: skew(-4deg, -4deg);
  }
  15% {
    transform: skew(3deg, 3deg);
  }
  20% {
    transform: skew(-2deg, -2deg);
  }
  25% {
    transform: skew(1deg, 1deg);
  }
  30% {
    transform: skew(-0.6deg, -0.6deg);
  }
  35% {
    transform: skew(0.3deg, 0.3deg);
  }
}


/* ポップアップ */
.popup.is-animated {
  animation: popup 0.6s cubic-bezier(0.22, 1, 0.36, 1) 1 forwards;
}

@keyframes popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scale(1.0);
  }
  80%, 100% {
    opacity: 1;
  }
}

/* どくどく */
.poyopoyo {
  animation: poyopoyo 2s ease-out infinite;
  opacity: 1;
}
@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.95);
  }
}

/* ななめから出てくる */
.slide-skew.is-animated {
  animation: slide-skew 0.4s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
}

@keyframes slide-skew {
  0% {
    transform: translate(180px,30px);
    opacity: 0;
  }
  100% {
    transform: translate(0,0);
  }
  20%,100% {
    opacity: 1;
  }
}


/* きらん */
.kiran {
  opacity: 1;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
.kiran::before {
  background-color: #fff;
  content: "";
  display: block;
  position: absolute;
  top: -100px;
  left: 0;
  width: 30px;
  height: 100%;
  opacity: 0;
  transition: cubic-bezier(0.32, 0, 0.67, 0);
}
.kiran:hover::before {
  animation: kiran 0.5s linear 1;
}

@keyframes kiran {
  0% {
    transform: scale(2) rotate(45deg);
    opacity: 0;
  }
  20% {
    transform: scale(20) rotate(45deg);
    opacity: 0.6;
  }
  40% {
    transform: scale(30) rotate(45deg);
    opacity: 0.4;
  }
  80% {
    transform: scale(45) rotate(45deg);
    opacity: 0.2;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

/* 背景色が流れてくる */
.bg .bg-wrap {
  position: relative;
  display: inline-block;
  margin-top: 5px;
}
.bg.is-animated .bg-wrap::before {
  animation: bg 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  background: linear-gradient(to right, #362ae0 0%,#3b79cc 50%,#42d3ed 100%);
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
}
.bg .bg-wrap .inn {
  color: #fff;
  display: inline-block;
  font-size: 36px;
  font-weight: bold;
  padding: 5px 15px;
  position: relative;
  z-index: 1;
}

@keyframes bg {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}

/* 文字がぬるりと現れる */
.matrix .bg-wrap,
.matrix .bg-wrap .inn {
  display: block;
}

.matrix .bg-wrap {
  overflow: hidden;
  opacity: 0;
}

.matrix .bg-wrap + .bg-wrap {
  margin-top: 10px;
}

.matrix .bg-wrap .inn.large {
  font-size: 36px;
  font-weight: bold;
}
.matrix .bg-wrap .inn.small {
  font-size: 15px;
}

.matrix .bg-wrap .inn {
  opacity: 0;
  transform: matrix(1, 0, 0, 1, 0, 100);
  transition: 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.matrix.is-animated .bg-wrap {
  opacity: 1;
}

.matrix.is-animated .bg-wrap .inn {
  opacity: 1;
  transform: matrix(1, 0, 0, 1, 0, 0);
}

/* 背景色が消えてから表示されるテキスト */
.mask-bg {
  color: transparent;
  display: inline-block;
  font-size: 36px;
  font-weight: bold;
  overflow: hidden;
  position: relative;
  transition: color 0ms 450ms;
}
.mask-bg::after {
  background: linear-gradient(to right, #362ae0 0%,#3b79cc 50%,#42d3ed 100%);
  bottom: 0;
  content: '';
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(0, 100%);
}

.mask-bg.is-animated {
  color: #362ae0;
}
.mask-bg.is-animated::after {
  animation: mask-bg 1.2s cubic-bezier(0.8, 0, 0.170, 1);
}

@keyframes mask-bg {
  0% {
    transform: translate(0, 101%)
  }
  40%, 60% {
    transform: translate(0, 0%)
  }
  100% {
    transform: translate(0, -100%)
  }
}


/* 線が伸びる */
.line {
  display: block;
  position: relative;
  margin-top: 20px;
}
.line::after {
  background: linear-gradient(to right, #362ae0 0%,#3b79cc 50%,#42d3ed 100%);
  content: '';
  display: block;
  height: 1px;
  width: 0;
  transform: translateX(-50%);
  transition: 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  position: absolute;
  bottom: 0;
  left: 50%;
}
.line.is-animated::after {
  width: 100%;
}


/* フェードアップ */
.fadeup.is-animated {
  animation: fadeup 1s cubic-bezier(0.33, 1, 0.68, 1) 1 forwards;
}

@keyframes fadeup {
  0% {
    transform: translateY(30px);
    opacity: 0;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ボーダーが緩やかにつく */
.stroke {
  background: #f0f0f0;
  max-width: 400px;
  height: 250px;
  position: relative;
}

.stroke .border {
  content: "";
  position: absolute;
  opacity: 0;
}
.stroke .border.top,
.stroke .border.bottom {
  width: calc(100% - 20px);
}
.stroke .border.top {
  border-top: 3px solid #362ae0;
  right: 0;
  top: 0;
}
.stroke .border.bottom {
  border-bottom: 3px solid #362ae0;
  left: 0;
  bottom: 0;
}

.stroke .border.right,
.stroke .border.left {
  height: calc(100% - 20px);
}
.stroke .border.right {
  border-right: 3px solid #362ae0;
  right: 0;
  top: 0;
}
.stroke .border.left {
  border-left: 3px solid #362ae0;
  left: 0;
  bottom: 0;
}

.stroke.is-animated .border {
  opacity: 1;
}

.stroke.is-animated .border.top,
.stroke.is-animated .border.bottom {
  animation: stroke-width 1.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.stroke.is-animated .border.right,
.stroke.is-animated .border.left {
  animation: stroke-height 1.8s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes stroke-width {
  0% {
    width: 0;
    opacity: 1;
  }
  100% {
    width: calc(100% - 20px);
    opacity: 1;
  }
}

@keyframes stroke-height {
  0% {
    height: 0;
    opacity: 1;
  }
  100% {
    height: calc(100% - 20px);
    opacity: 1;
  }
}

/* 文字が滑らかに表示される */
.smooth {
  clip-path: inset(0 100% 0 0);
  display: inline-block;
  font-size: 36px;
  font-weight: bold;
  transition: 1.4s cubic-bezier(0.37, 0, 0.63, 1);
  transition-property: clip-path;
  line-height: 1;
  height: 40px;
  margin-top: 15px;
}
.smooth.is-animated {
  clip-path: inset(0);
}

/* ふわふわ */
.fuwafuwa {
  animation: fuwafuwa 3s infinite ease-in-out .8s alternate;
  background: url(../img/ico-apple.svg) no-repeat center center / 60px auto;
  display: inline-block;
  transition: 1.5s ease-in-out;
  width: 70px;
  height: 70px;
  margin-top: 15px;
}

@keyframes fuwafuwa {
  0% {
    transform:translate(0, 0) rotate(-7deg);
  }
  50% {
    transform:translate(0, -7px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(7deg);
  }
}

/* ゆったりスクロールボタン */

.scroll {
  display: inline-block;
  padding-top: 70px;
  position: relative;
}
.scroll::before {
  animation: scroll 3.5s infinite;
  border: solid #000;
  border-width: 0 0 1px 1px;
  content: "";
  display: inline-block;
  margin: auto;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  transform: rotate(-45deg);
  width: 20px;
  height: 20px;
}
@keyframes scroll {
  0% {
    transform: rotate(-45deg) translate(0, 0);
  }
  80% {
    transform: rotate(-45deg) translate(-30px, 30px);
  }
  0%, 80%, 100% {
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
}

/* くるくる回りながら出現 */
.kurukuru {
  background: linear-gradient(to right, #362ae0 0%,#3b79cc 50%,#42d3ed 100%);
  width: 50px;
  height: 50px;
  opacity: 0;
  padding-bottom: 40px;
}
.kurukuru.is-animated {
  animation: kurukuru 1.4s ease-out;
  opacity: 1;
}
@keyframes kurukuru {
  0%{
    transform: rotateY(0) translateY(40px);
    opacity: 0;
  }
  100%{
    transform: rotateY(360deg) translateY(0);
    opacity: 1;
  }
}

.fadeIn {
  transition: 1s;
  opacity: 0;
}
 
.fadeIn.animated {
  opacity: 1;
}




  /*--------------------------------------------------
  ページの余白設定
  --------------------------------------------------*/
  /* コンテンツとコンテンツの間の余白 */
  #top { padding-top: 0%; position: relative; z-index: 2; width: 100%; overflow: hidden; }  /* トップページで必要なければ削除すること */
  #main section { margin-bottom: 10%; }

  /* 共通部分 */


  /*--------------------------------------------------
  見出しの設定
  --------------------------------------------------*/
  /* ページの見出し */
  h1 {}
  h2.ttl { }



  /*--------------------------------------------------
  固定ページの共通部分
  --------------------------------------------------*/
  /* 固定ページの親要素として使用する */

  .table { display: table; width: 100%; }
  .table .th, .table .td { display: table-cell; }
  .left { float: left; }
  .right { float: right; }

  .text p { margin-bottom: 1em; }

  #map { width: 100%; }
  #map iframe { width: 100%; }




  /*--------------------------------------------------
  TOP
  --------------------------------------------------*/
  aside { position: relative; z-index: 0; }

  #top {  }
  #top .headline { display: flex; justify-content: center; margin-bottom: 80px; font-size: 36px; font-weight: bold; }
  #top .headline span { border-bottom: solid 5px #DEDEDE; position: relative; text-align: center; }
  #top .headline span::before { position: absolute; content: " "; display: block; border-bottom: solid 5px #3A75BB; bottom: -5px; width: 50%; }

  #top #visual { margin-bottom: 130px; }
  #top h2.headline {  }
  #top #works { }
  #top #works h2 {  }
  #top #works ul { display: flex; flex-wrap: wrap; }
  #top #works ul li { width: 30%; margin: 0 5% 60px 0; position: relative; }
  #top #works ul li:nth-of-type(3n) { margin-right: 0; }

  #top #works ul li .txt { position: absolute; bottom: 0; background: rgba(0, 0, 0, 0.6); text-align: center; width: 100%; padding: 5px 0; }
  #top #works ul li .txt span { color: #fff; font-weight: bold; font-size: 22px; }


  #top #about { background: url(img/top_message_bg.png) no-repeat; background-size: cover; background-position: center top; height: 415px; margin-bottom: 270px; }
  #top #about .wrap { position: relative; height: 100%; }
  #top #about .lead { position: absolute; top: 50%; right: 0; background: rgba(255, 255, 255, 0.95); border-radius: 20px; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); max-width: 695px; padding: 30px 75px 50px; top: 50%; left: 50%; transform: translate(0%, 0%); }
  #top #about .lead h2 { margin: 0 0 25px; font-size: 31px; font-weight: bold; text-align: center; }
  #top #about .lead p { font-size: 18px; line-height: 1.6; margin-bottom: 30px; }
  #top #about .lead .btn { display: flex; justify-content: flex-end; }
  #top #about .lead .btn a { background: #FF5800; border-radius: 22px; padding: 12px 32px; color: #fff; font-size: 16px; }
  
  #top #maker ul { display: flex; flex-wrap: wrap; }
  #top #maker ul li { margin: 0 20px 20px 0; position: relative; background: #DFDFDF; border-radius: 5px; padding: 11px 20px; font-size: 16px; }


  

  /*--------------------------------------------------
  page
  --------------------------------------------------*/

#page a.link { color: #5B97E1; text-decoration: underline; }

/* アコーディオン　見出し部分 */
details > summary {
  cursor: pointer;
  padding: 25px 25px 25px 45px;
  background-color: #F4F8F6;
  color: #03937C;
  font-size: 18px;
  border-bottom: 1px solid #707070;
}
details > summary::marker { content: none; }
details > summary::before { content: 'Q'; margin-left: -1.5em; margin-right: 1em; }

/* アコーディオン　見出し部分　オープン時 */
details[open] > summary { }

/* アコーディオン　内容部分 */
details > div {
  padding: 25px 25px 25px 45px;
  background-color: white;
}
details > div::before { content: 'A'; color: #FE3231; margin-left: -1.5em; margin-right: 1em; }
details > div p { display: inline; }

/* アコーディオン　内容部分　オープン時 */
details[open] > div { border-bottom: 1px solid #707070; }
details[open] > div span { color: #FE3231; }

/* アコーディオン　見出し部分　プラス・マイナスのマーク */
details {
  position: relative;
}
details > summary::after {
  position: absolute;
  content: '＋';
  top: 23px;
  right: 10px;
}
details[open] > summary::after {
  content: '−';
  top: 23px;
  right: 14px;
}

/* アコーディオン　Safariの▲マークを消す */
details > summary::-webkit-details-marker {
  display: none;
}

/* アコーディオン間のスペース */
details + details { }


#page .headline {
  margin-bottom: 20px; font-size: 60px; font-weight: bold;
  & + p { border-left: 20px solid #3C3C3C; padding-left: 15px; margin-bottom: 60px; font-size: 33px; font-weight: bold; line-height: 1; }
}

#page .cover { 
  background-size: cover; height: 600px; position: relative; margin-bottom: 70px; min-height: 310px;
  & .wrap {
    display: flex; flex-wrap: wrap; height: 100%;
    & h1 { 
      color: #fff; display: inline-flex; align-items: flex-end; width: 100%; color: #fff; font-size: 35px; letter-spacing: 6px;
      & + p { color: #fff; }
    }
  }
}
#page #about .cover { background: url(img/header-company.png) no-repeat; background-size: cover; background-position: center center; }
#page #about #message {
    margin-bottom: 150px;
    & .block { padding: 0 40px; font-size: 18px; line-height: 2; }
    & .ceo { display: flex; justify-content: flex-end;
      & .block { font-size: 24px; font-weight: 600; letter-spacing: 5px;
        & .name { font-size: 34px; font-weight: 600; letter-spacing: 1px; }
      }
    }
}

#page #about #company {
  margin-bottom: 150px;
  & .headline + p { margin-bottom: 140px; }
  & .block {
    padding: 0 40px;
    & dl {
      display: flex; justify-content: space-between; width: 100%;
      & dt { border-bottom: 2px solid #3A75BB; width: 30%; padding: 35px 0; font-size: 20px; color: #3A75BB; }
      & dd { border-bottom: 2px solid #C2C2C2; width: 70%; padding: 35px 50px; font-size: 20px; }
      &:first-of-type {
        & dt { border-top: 2px solid #3A75BB; }
        & dd { border-top: 2px solid #C2C2C2; }
      }
    }
  }
}

#page #about #access {
  & .wrap {
    display: flex; flex-wrap: wrap; justify-content: flex-end;
    & #map {
      margin: 0 0 30px;
      max-width: 966px;
    }
    & .txt {
      display: flex; justify-content: space-between; flex-wrap: wrap;
      & dt { width: 20%; }
      & dd { width: 80%; }
    }
  }
}

#page #business {
  & .cover{ background: url(img/header-business.png) no-repeat; background-size: cover; background-position: center center; }
  & #bus { 
    & ul {
      padding: 0 40px;
      & li { border-bottom: 1px solid #1D92BE; padding: 20px 0; }
    }
  }
}




#page #contact {
  & .cover{ background: url(img/header-contact.png) no-repeat; background-size: cover; background-position: center center; }
  & .leadText { margin: 0 0 70px; text-align: center; font-size: 22px; }
  & .tel {
    font-size: 30px; color: #1D92BE; font-weight: bold; line-height: 1;
    & span { font-size: 150%; font-weight: bold; }
  }
  & form {
    & .inner {
      & dl {
        display: flex; justify-content: space-between;
        &:first-of-type dt { border-top: 2px solid #3A75BB; }
        &:first-of-type dd { border-top: 2px solid #c2c2c2; }
        & dt {
          width: 30%; padding: 30px 0; border-bottom: 2px solid #3A75BB;
          & .hissu { }
          & span { color: #3A75BB; font-size: 24px; }
        }
        & dd {
          width: 70%; padding: 30px 0; border-bottom: 2px solid #c2c2c2;
          & input { border: none; width: 100%; }
          & textarea { border: none; height: 300px; }
        }
      }
    }
    .accpt { text-align: center; margin: 50px 0; font-size: 20px; }
  }
}

.bustime { color: #8A8A8A; }

#page #contact .privacy { font-size: 15px; }
#page #contact .privacy h2 { margin-bottom: 50px; font-size: 40px; color: #1D92BE; font-weight: bold; text-align: center; }
#page #contact .privacy p { margin-bottom: 50px; font-size: 24px; text-align: center; }

#page #contact .privacy .txt { margin-bottom: 150px; height: 500px; overflow-y: scroll; border: 2px solid #3A75BB; padding: 30px; }
.privacy dl { margin: 0 0 30px; }
.privacy dt { font-weight: bold; font-size: 2.0rem; }
.privacy dd { font-size: 1.6rem; }
.privacy dd ul { padding: 1em 0 1em 2.4em; }


  /*--------------------------------------------------
  お知らせ
  --------------------------------------------------*/


  
/* アーカイブ */
  .archive {  }



  /* パスワードページ */
.page_pass_bg { padding: 100px 0 0; margin-bottom: 100px; position: relative; z-index: 1; }
.page_pass_wrap { margin: 0 auto; max-width: 500px; padding: 50px 80px 80px; text-align: center; color: #707070; box-shadow: 0 4px 20px rgba(0,0,0,0.44); background: #fff; border-radius: 10px; }
.page_pass_ttl { font-weight: bold; font-size: 30px; }
.page_pass_site_ttl { margin: 10px auto 50px; font-size: 15px; }
.page_pass_text { display: flex; justify-content: center; }
.page_pass_input { border: 1px solid #707070; border-radius: 10px; display: block; font-size: 16px; margin-top: 20px; padding: 10px; width: 100%; }
input[type=submit].page_pass_submit { background-color: #004EA1; cursor: pointer; color: #fff; display: block; font-size: 1.5rem; margin: 20px auto; padding: 10px 0; width: 163px; height: auto; line-height: 1.8; border-radius: 10px; border:none; -webkit-appearance: none; box-shadow: none; }
.page_pass_submit:hover { opacity: 0.7; filter: alpha(opacity=70); -ms-filter: "alpha(opacity=70)"; }
.page_pass_bg .forget { font-size: 13px; text-align: center; }



/* シングル */
.single { margin: 0px auto 0; }
.single .cover { background: url(img/single_header.jpg) no-repeat; background-size: cover; }
.single .date { font-size: 20px; }
.single h2 { font-size: 30px; border-bottom: 1px solid #707070; padding: 0 0 15px; margin: 0 0 25px; position: relative; }
.single h2 .pagetag { position: absolute; top: 0; right: 0; }
.single h2 .pagetag span { background: #00C280; padding: 5px 35px; font-size: 15px; color: #fff; font-family: "Noto Sans JP"; }
.single .inner { padding: 0 20px; margin-bottom: 100px; }
.single .inner img { width: revert-layer; }
.single .btn { display: flex; justify-content: center; margin: 0 0 100px;}
.single .btn a { background: #03937C; padding: 22px 65px; font-size: 18px; color: #fff; box-shadow: 6px 6px 0 rgba(0, 0, 0, 0.16); letter-spacing: 2px; text-align: center; }
 


  #single .eyecatch img { width: 100%; margin-bottom: 30px; }
  #single .inner .text h2 { background: initial; padding: initial; color: #222; line-height: 1.875em; font-size: 1.5em; margin: 36px 0 24px; border-bottom: 2px solid; }
  #single .inner .text h3 { margin: 36px 0 24px; padding: 12px; background: #f3f3f3; border-radius: 10px; width: fit-content; font-family: "A-OTF Shin Go Pro"; }
  #single .inner .text a { color: #81c7d4; }
  #single .inner .text ul { margin: 24px 0; padding-left: 40px; list-style: initial; }
  #single .inner .text ol { margin: 24px 0; padding-left: 40px; list-style: auto; }


  
/*ページネーション*/
.pagination ul { display: flex; flex-wrap: wrap; justify-content: center; margin: 50px 0 50px; }
.pagination li .page-numbers { padding: 10px 15px; margin: 0 5px 5px 0; background-color: #fff; border: 1px solid #006600; display: inline-flex; align-items: center; }
.pagination li .page-numbers.current,
.pagination li .page-numbers:hover { background: #006600; color: #fff;; }


  /* ビジュアルリッチテキストエディタ */
  #page #single .box .text h1, #page #single .box .text h2, #page #single .box .text h3,
  #page #single .box .text h4, #page #single .box .text h5, #page #single .box .text h6 {
    font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ＭＳ ゴシック", sans-serif;
    line-height: 1.6; font-weight: bold;
  }
  #page #single .box .text h1 span, #page #single .box .text h2 span, #page #single .box .text h3 span,
  #page #single .box .text h4 span, #page #single .box .text h5 span, #page #single .box .text h6 span {
    font-weight: bold;
  }
  #page #single .box .text h1 { font-size: 30px; font-size: 3.0rem; }
  #page #single .box .text h2 { font-size: 26px; font-size: 2.6rem; }
  #page #single .box .text h3 { font-size: 22px; font-size: 2.2rem; }
  #page #single .box .text h4 { font-size: 18px; font-size: 1.8rem; }
  #page #single .box .text h5 { font-size: 14px; font-size: 1.4rem; }
  #page #single .box .text h6 { font-size: 12px; font-size: 1.2rem; }
  #page #single .box .text strong { font-weight: bold; }
  #page #single .box .text em { font-style: italic; }
  #page #single .box .text ol li { list-style-type: decimal; }
  #page #single .box .text ul li { list-style-type: disc; }
  #page #single .box .text a { text-decoration: underline; color: #009BD4; }

/* エディタ使用した場合 */
img.aligncenter { margin-right: auto; margin-left: auto; display: block; clear: both; }
img.alignleft { float: left; margin-right: 1.5em; display: inline; }
img.alignright { float: right; margin-left: 1.5em; display: inline;}


  /*--------------------------------------------------
  お問い合わせ
  --------------------------------------------------*/
  #contact_1 {}
  #contact_1 .form_area { max-width: 800px; margin: 0 auto; }
  #contact_1 .form_area dl { margin-bottom: 35px; }
  #contact_1 .form_area dl dt { margin-bottom: 10px; font-weight: bold; }
  #contact_1 .form_area dl dt .box { padding: 1px 13px; border-radius: 5px; margin-right: 8px; color: #fff; font-weight: 500; }
  #contact_1 .form_area dl dt .hissu { background: #FF7587; }
  #contact_1 .form_area dl dt .ninni { background: #727272; }
  #contact_1 #privacy { text-align: center; }
  #contact_1 #privacy .box { margin-bottom: 40px; }
  #contact_1 #privacy .acc span { font-weight: bold; font-family: 'Zen Maru Gothic', serif; }
  
  
  #contact_1 input[type="text"],
  #contact_1 input[type="email"],
  #contact_1 input[type="tel"],
  #contact_1 textarea { width: calc(100% - 45px); }

  
  /*ie firefoxでのselect矢印*/
  #contact_1 textarea { padding: 14px 14px; height: 150px; line-height: 1.2; }
  select { -webkit-appearance: none; -moz-appearance: none; appearance: none; text-indent: 0.01px; text-overflow: ""; }
  select::-ms-expand { display: none; }

  /* 送信ボタン（共通） */
  input[type=submit] {
    padding: 15px 90px; margin: 100px auto 150px; 
    background-color: #fff; color: #3A75BB; font-size: 33px; font-weight: bold; text-align: center; display: block; border: 5px solid #3A75BB; border-radius: 60px;
  }
  input[type=submit].back { background-color: #858585; }
  input[type=submit]:hover { cursor: pointer; opacity: 0.6; box-shadow: none; }
  input[type=submit]:active { box-shadow: none; }
  /* formの枠 */
  div.wpcf7-response-output { padding: 0; margin: 0; margin-top: 1.5%; font-size: 1.4rem; }
  /* メール送信完了ボックス */
  div.wpcf7-mail-sent-ok {
    padding: 2%; border: 2px solid #17a1c1; background-color: #F5F5F5; text-align: center;
    color: #666; font-size: 13px; font-size: 1.3rem; border-radius: 6px; color: #17a1c1;
  }
  /* 警告文のボックス */
  div.wpcf7-validation-errors {
    padding: 2%; border: 2px solid #666; background-color: #F5F5F5; text-align: center;
    color: #666; font-size: 13px; font-size: 1.3rem; border-radius: 6px;
  }
  /* エラーメッセージのカラー */
  span.wpcf7-not-valid-tip { color: #b50000; font-size: 13px; font-size: 1.3rem; }
  /* エラー箇所の背景色 */
  .wpcf7 .wpcf7-not-valid { background-color: #DDD; color: #666; }



  /*--------------------------------------------------
  404 Not Found
  --------------------------------------------------*/
  #notfound { margin-top: 50px; }
  #notfound h1 { text-align: center; color: #a08b77; font-size: 80px; font-size: 8.0rem; }
  #notfound .txt { margin: 0 auto; width: 100%; }
  #notfound ul { padding: 2%; margin: 1.5% auto; width: 100%; background-color: #f5f5f5; }
  #notfound ul li { list-style-type: disc; margin-left: 2%; }
  .back404 { padding: 50px 0; margin: 0 auto 0px; width: 100%; }
  .back404 .btn { margin: 0 auto; width: 50%; height: 60px; line-height: 60px; text-align: center; font-size: 22px; font-size: 2.2rem; border-radius: 10px; }
  .back404 .btn a { width: 100%; height: 100%; display: block; background-color: #fff; color: #25764d; border-radius: 10px; border: 1px solid #25764d; }
  .back404 .btn a:hover { background-color: #25764d; color: #fff; }



  /*--------------------------------------------------
  PDF
  --------------------------------------------------*/
  #sidenav-container { display: none; }



/* モーダル */
/*全て共通：hideエリアをはじめは非表示*/
.hide-area{
	display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after, 
.modaal-close:before{
	background:#ccc;	
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
	background:#666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title{
	font-size:1.2rem;
	text-align: center;
	margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-video .modaal-inner-wrapper{
	padding:0;
}






/*------------------------------------------------------------------------
                                < 1804
------------------------------------------------------------------------*/

@media screen and (max-width: 1804px) {

  

  
  
}
  




/*------------------------------------------------------------------------
                                < 1400
------------------------------------------------------------------------*/

@media screen and (max-width: 1400px) {

  .wrap { padding: 0 20px; }

  

}
  
  
  
  

  
  
  /*------------------------------------------------------------------------
                                < 1200
------------------------------------------------------------------------*/

@media screen and (max-width: 1200px) {


  
}
  
  
  
  
  /*------------------------------------------------------------------------
                                < 1100
------------------------------------------------------------------------*/

@media screen and (max-width: 1100px) {

  header .header_wrap { flex-wrap: wrap; }
  

}




  /*------------------------------------------------------------------------
                                < 1060
------------------------------------------------------------------------*/

@media screen and (max-width: 1060px) {


  

}




/*------------------------------------------------------------------------
                                < 950
------------------------------------------------------------------------*/

@media screen and (max-width: 950px) {

  .drawer--left .drawer-nav { width: 80%;  }

  

}




/*------------------------------------------------------------------------
                                < 800
------------------------------------------------------------------------*/

@media screen and (max-width: 800px) {




}




/*------------------------------------------------------------------------
                                < 780
------------------------------------------------------------------------*/

@media screen and (max-width: 780px) {

  /*--------------------------------------------------
  共通
  --------------------------------------------------*/
  /* ドロワーの装飾 */
  header { z-index: 101; background: none; }
  header .flex { flex-wrap: wrap; padding: 0 20px; }
  header .flex .header_logo { width: 100%; padding: 0 15% 30px; }
  header .flex .header_online { margin: 0 auto; width: 46%; }
  header .flex .header_recruit { margin: 0; width: 46%; }

  nav ul { display: block; }
  nav ul li { }
  header nav ul { display: block; }
  nav ul li a { width: 100%; padding: 15px 1em; color: #1A1311!important; border-bottom: 1px solid #ddd; font-size: 1.6rem; }
  nav ul li.contact a { border-bottom: none; display: flex; align-items: center; justify-content: center; }
  header nav ul .contact i { margin: 0 10px; }
  .drawer--left .drawer-nav { padding: 0px; overflow: hidden; position: fixed!important; background: #fff; width: 16.25rem; left: -16.25rem; }
  .drawer-open .drawer-nav { width: 80%; }
 /* imgでボタンを使う場合 */
 .drawer--left .drawer-hamburger { display: block!important; top: 3rem; right: 2rem; left: auto!important; background: #808080!important; padding: 1px 1px 1px 1px; border-radius: 8px; width: 50px; position: fixed; }
 .drawer-hamburger-icon:before, .drawer-hamburger-icon:after { display: none; }
.drawer-hamburger-icon, .drawer-hamburger-icon:before, .drawer-hamburger-icon:after { height: auto!important; background: none!important; }
.drawer-hamburger-icon { margin: 0!important;}

  /* ページ上部の開閉メニューを非表示 */
  .drawer-menu { flex-wrap: wrap; display: block; }
  header nav ul li { width: 100%; }
  .drawer-menu > li { padding: 0; border-right: none; width: 100%; }
  .drawer-menu > li:first-of-type { border-left: none; }
  header nav ul li:last-child { border-right: none; }
  header nav ul li a { display: block; }


 /*ACCORDION*/
  nav.drawer-nav ul.drawer-menu li ul li { border-bottom: 1px solid #EFEFEF; padding-bottom: 0; }
  nav.drawer-nav ul.drawer-menu li ul li:last-of-type { border-bottom: none; }
  #acMenu .toggle { display:block; width:100%; height:auto; cursor:pointer; }
  #acMenu ul { width:100%; height:auto; display:none; border-top: 1px solid #EFEFEF; }
  #acMenu .maru::after {
    border-top: none;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  nav.drawer-nav ul.drawer-menu li a.toggle { position: relative; }
  nav.drawer-nav ul.drawer-menu li a.toggle::before,
  nav.drawer-nav ul.drawer-menu li a.toggle::after { position: absolute; top: 0; bottom: 0; right: 0; margin: auto; content: ""; vertical-align: middle; }
  nav.drawer-nav ul.drawer-menu li a.toggle::before { right: 15px; width: 4px; height: 4px; border-top: 1px solid #231f20; border-right: 1px solid #231f20; -webkit-transform: rotate(135deg); transform: rotate(135deg); }
  nav.drawer-nav ul.drawer-menu li a span {  }
  nav.drawer-nav ul.drawer-menu li a:hover { color: #fff!important; background: #FE3231; }
  .drawer-menu > li a.contact { background: #fff; }


  .alt { text-align: center; color: #192e66; font-weight: bold; }
  .alt::after { content: attr(data-label); font-size: 2rem; border-bottom: 2px solid #192e66; padding-bottom: 10px; }
  .alt img { display: none; }

  input[type=submit] { width: 80%; padding: 20px 40px; }
  #notfound h1 { font-size: 40px; font-size: 4rem; line-height: 1.2; margin-bottom: 5%; }
  #notfound ul li { list-style-type :none }
  .back404 { padding: 50px 3%; }
  .back404 .btn { width: 100%; height: 50px; line-height: 50px; }
  .open a.toggle::before { -webkit-transform: rotate(90deg)!important; transform: rotate(-45deg)!important; }

  header .header_wrap { justify-content: space-between; }
  header .header_logo { width: 70vw; margin: 10px 16vw 10px 0; }

  .w50 { width: 100%!important; }

 
  .pagetop { display: none!important; }
  footer { margin: 100px 0 0; }
  footer .footer_wrap { flex-wrap: wrap; padding: 30px 20px; }
  footer .footer_wrap .company {  }
  footer .footer_wrap .add_block .sitemap { display: none; }
  
  header .header_wrap { justify-content: space-around; }
  header .header_logo { margin: 20px 0; width: 40vw; }
  header .header_logo a { width: 100%; }
  header .linebnr { width: 30%; }


  
  /*--------------------------------------------------
  top
  --------------------------------------------------*/
  #top #visual { margin-bottom: 50px; }
  #top #works ul { justify-content: space-between; }
  #top #works ul li:nth-of-type(3n) {  }
  #top #works ul li { width: 48%; margin: 0 0 40px 0; }
  #top #works ul li .txt span { font-size: 18px; }
  #top #about { margin-bottom: 170px; }
  #top #about .lead { width: 90%; left: 5%; transform: none; padding: 20px 30px 40px; }
  #top #about .lead h2 { margin: 0 0 15px; font-size: 25px; }
  #top #about .lead p { font-size: 16px; margin-bottom: 20px; }



  /*--------------------------------------------------
  page
  --------------------------------------------------*/
  .cover { margin-bottom: 30px; }
  #page .cover { height: 100%; display: flex; align-items: center; }
  
  #page .headline { font-size: 30px; margin-bottom: 10px; }
  #page .headline + p { font-size: 24px; }
  #page #contact .privacy .txt { margin-bottom: 100px; }
  #page #about #company .block { padding: 0; }
  #page #about #company .block dl dt { font-size: 16px; }
  #page #about #company .block dl dd { font-size: 16px; }
  #page #business #bus ul { padding: 0; }

  
  


  
  
}






/*------------------------------------------------------------------------
                                < 640
------------------------------------------------------------------------*/

@media screen and (max-width: 640px) {


  




  
}






/*------------------------------------------------------------------------
                                < 600
------------------------------------------------------------------------*/

@media screen and (max-width: 600px) {

  footer .footer_wrap .logo p { font-size: 4vw; }
  #top #about { background-position: 40% top;}
  
  
}






/*------------------------------------------------------------------------
                                < 480
------------------------------------------------------------------------*/

@media screen and (max-width: 480px) {


  #top #works ul li .txt span { font-size: 14px; }
  #top #about { margin-bottom: 210px; }
  footer .footer_wrap .logo a { width: 23vw; }
  #top #about .lead p { font-size: 3.5vw; }
  #page #contact form .inner dl dt span { font-size: 14px; }
  #page #contact form .inner dl dt { padding: 10px 0; }
  #page #contact form .inner dl dd { padding: 10px 0; }
  input[type=submit] { font-size: 20px; margin: 50px auto 100px; }
  #page #contact .privacy h2 { font-size: 30px; }
  #page #contact .privacy p { font-size: 18px; }
  .privacy dd { font-size: 14px; }
  #page #contact .tel { font-size: 26px; }
  #page #about #message { margin-bottom: 80px; }
  #page #about #message > .block { padding: 0; margin-bottom: 20px; }
  #page #about #message .ceo .block { padding: 0; }
  #page #about #message .ceo .block .name {  }
  #page #about #company .headline + p { margin-bottom: 30px; }
  #page #about #company { margin-bottom: 80px; }
  #page #about #access .wrap { padding: 0; }
  #page #about #access .wrap .txt dd { width: 75%; }




  
}




/*------------------------------------------------------------------------
                                < 370
------------------------------------------------------------------------*/

@media screen and (max-width: 370px) {


  
  
    
  }