@charset "UTF-8";
/*---------------------------- PC向けのスタイル ----------------------------*/
@media screen and (min-width: 680px) {
  /*---------- ページ全体の指定 ----------*/
  body {
    width: 100%;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS P ゴシック", "MS P Gothic", sans-Serif;
    margin: 0;
    padding: 0;
    font-size: 16px;
    color: #333333;
    background-color: #ffffff;
    -webkit-text-size-adjust: none;
  }
  .img_a {
    display: block;
  }
  .img_b {
    display: none;
  }
  .button-arrow-right {
    -webkit-appearance: none;
    background: #0713a0;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
    text-align: center;
    border: none;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    text-decoration: none;
    padding: 14px 60px;
    font-size: 16px;
    border-radius: 8px;
    font-weight: 700;
    transition: all 0.3s ease 0s;
    width: 304px;
    max-width: 100%;
    line-height: 1.6;
  }
  /*---------- メイン ----------*/
  #main {
    width: 100%;
    overflow: hidden;
    margin: 0 auto 0 auto;
    padding: 0;
    text-align: center;
    background-color: #ffffff;
  }
  /*---------- ヘッダー ----------*/
  #header {
    width: 100%;
    margin: 0 auto 0 auto;
    border-top: solid 4px #6aa8de;
    background-image: url(../img/header.png);
    /*-- 背景 --*/
    background-repeat: repeat-x;
  }
  #header h1 {
    margin: 0 auto 0 auto;
    width: 900px;
    padding: 2px 0 0 5px;
    font-weight: normal;
    text-align: left;
    font-size: 10px;
    color: #9d896c;
    transform: translate(13px, 35px);
    font-size: 15px;
  }
  #header #header_inner {
    width: 900px;
    height: 100px;
    /*-- 高さ --*/
    padding: 4px;
    /*-- 余白 --*/
    margin: 0 auto 0 auto;
  }
  /*---------- ヘッダー内 ----------*/
  /*----- 左 logo -----*/
  #h_logo {
    padding: 0;
    text-align: left;
    font-size: 14px;
    color: #444444;
    line-height: 1.5;
    text-decoration: none;
    float: left;
  }
  #h_logo h2 {
    margin: 0;
    padding: 40px 0 0 16px;
    /*-- logo 位置 --*/
    text-align: left;
    font-size: 22px;
    color: #444444;
    letter-spacing: 0.05em;
  }
  #h_logo a {
    font-size: 22px;
    color: #666666;
    text-decoration: none;
  }
  #h_logo a:hover {
    font-size: 22px;
    color: #888888;
    text-decoration: none;

  /*----- 中央 outer-html -----*/  }
  #h_outer-html{
    padding: 0;
    text-align: left;
    font-size: 14px;
    color: #444444;
    line-height: 1.5;
    text-decoration: none;
    float: left;
    margin-left: 183px;
    padding-top: 10px;
  }
  #h_outer-html .h_outer-html__nav{
    font-size: 16px;
    background-color: #fff;
  }
  #h_outer-html li{
    border: 2px solid #e7c129;
    border-radius: 30px;
    margin-top: 5px;
    padding: 0 5px;
  }
  #h_outer-html a{
    list-style: none;
    text-decoration: none;
  }
  /*----- 右 info -----*/
  #h_info {
    margin: 0;
    padding: 6px 14px 0 10px;
    /*-- info 位置 --*/
    text-align: right;
    font-size: 16px;
    color: #555555;
    line-height: 1.6;
    text-decoration: none;
    float: right;
  }
  #h_info p {
    margin: 0;
    padding: 3px;
    text-align: left;
    font-size: 14px;
    color: #444444;
    letter-spacing: 0.05em;
  }
  #h_info a {
    font-size: 13px;
    color: #333333;
    text-decoration: none;
  }
  #h_info a:hover {
    font-size: 13px;
    color: #666666;
    text-decoration: none;
  }
  #h_info .tel {
    font-size: 20px;
    color: #c9171e;
    line-height: 1.2;
    font-weight: bold;
  }
  #h_info .tel a {
    font-size: 20px;
    color: #c9171e;
    line-height: 1.2;
    font-weight: bold;
  }
  /*---------- ヘッダーメニュー ----------*/
  #header-menu {
    clear: both;
    width: 100%;
    margin: 6px 0 0 0;
    padding: 0;
    height: 56px;
    text-align: left;
    background-color: #ffffff;
  }
  #header-menu ul {
    width: 900px;
    text-align: left;
    margin: 0 auto 0 auto;
    padding: 0;
    background-color: #ffffff;
  }
  #header-menu li {
    display: inline;
    list-style-type: none;
    float: left;
    color: #ffffff;
  }
  #header-menu li a {
    font-size: 13px;
    color: #765c47;
    text-align: center;
    display: block;
    line-height: 1.3;
    letter-spacing: 0.05em;
    border-left: solid 1px #d6c6af;
    text-decoration: none;
    margin-top: 8px;
    padding: 6px 38px 2px 38px;
  }
  #header-menu li a:hover {
    color: #765c47;
    background-image: url(../img/head_menu_back_hover.gif);
    background-repeat: repeat-x;
  }
  #header-menu li.home a {
    padding: 6px 38px 2px 38px;
    border-left: none;
  }
  #header-menu span.sub {
    color: #b29164;
  }
  .clearfix:after {
    content: "";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
  }
  /*---------- SP電話ボタン ----------*/
  .phone {
    display: none;
  }
  /*---------- メイン画像 ----------*/
  #header-img {
    width: 100%;
    margin: 12px 0 12px 0;
    text-align: center;
    background-image: url(../img/head_img_bg.png);
  }
  .main_photo {
    display: block;
    margin: 0 auto 0 auto;
  }
  /*---------- コンテンツ ----------*/
  #container {
    width: 900px;
    margin: 0 auto 0 auto;
    overflow: hidden;
    padding: 6px 0 0 0;
    background-color: #ffffff;
  }
  /*---------- メインコンテンツ ----------*/
  #contents {
    float: right;
    margin: 0;
    padding: 0;
    font-size: 16px;
    width: 650px;
    letter-spacing: 0.05em;
    text-align: left;
    line-height: 1.7;
  }
  #contents #pannavi {
    margin: 0 0 6px 0;
    padding: 0 0 8px 0;
    font-size: 15px;
  }
  #contents #pannavi a {
    font-size: 15px;
    text-decoration: none;
  }
  #contents h2 {
    height: 43px;
    margin: 0 0 10px 0;
    padding: 14px 0 0 40px;
    font-size: 18px;
    color: #54351f;
    background-image: url(../img/titlebar.gif);
    background-repeat: no-repeat;
  }
  #contents h2.page_title {
    margin: 0 0 18px 0;
    padding: 18px 0 4px 30px;
    line-height: 1.7;
    font-size: 20px;
    color: #2b72ae;
    border: none;
    background-image: url(../img/page_title.gif);
    background-repeat: no-repeat;
  }
  #contents h2.txt {
    height: auto;
    margin: 0 0 7px 0;
    padding: 0;
    border: none;
    font-size: 16px;
    color: #54351f;
    background: none;
  }
  #contents h3 {
    margin: 12px 3px 10px 3px;
    padding: 15px 10px 10px 18px;
    line-height: 1.4;
    font-size: 17px;
    color: #54351f;
    border-top: solid 1px #dddddd;
    border-right: solid 1px #dddddd;
    background-image: url(../img/page_title.gif);
  }
  #contents h3.beta {
    margin: 12px 2px 10px 2px;
    padding: 14px 10px 12px 16px;
    line-height: 1.4;
    font-size: 18px;
    color: #fffffc;
    border: none;
    background-image: url(../img/h3_beta.gif);
    background-repeat: no-repeat;
  }
  #contents h3.point {
    margin: 10px 0 10px 0;
    padding: 10px 10px 8px 10px;
    line-height: 1.4;
    font-size: 18px;
    color: #882200;
    border-top: solid 1px #999999;
    border-right: solid 1px #bbbbbb;
    border-bottom: solid 4px #663300;
    border-left: solid 1px #bbbbbb;
    background-image: url(../img/h3_point.gif);
    background-repeat: repeat-x;
  }
  #contents h3.gold {
    height: 41px;
    margin: 12px 2px 10px 2px;
    padding: 14px 10px 0 18px;
    line-height: 170%;
    font-size: 19px;
    text-align: left;
    color: #662200;
    border: none;
    background-image: url(../img/h3_gold.gif);
    background-repeat: no-repeat;
  }
  #contents h3.gold02 {
    height: 71px;
    margin: 12px 2px 10px 2px;
    padding: 14px 2px 0 18px;
    line-height: 170%;
    font-size: 18px;
    text-align: left;
    color: #662200;
    border: none;
    background-image: url(../img/h3_gold02.gif);
    background-repeat: no-repeat;
  }
  #contents h3.gray {
    height: 41px;
    margin: 12px 2px 10px 2px;
    padding: 14px 10px 0 18px;
    line-height: 170%;
    font-size: 19px;
    text-align: left;
    color: #662200;
    border: none;
    background-image: url(../img/h3_gray.gif);
    background-repeat: no-repeat;
  }
  #contents h3.gray02 {
    height: 71px;
    margin: 12px 2px 10px 2px;
    padding: 14px 2px 0 18px;
    line-height: 170%;
    font-size: 18px;
    text-align: left;
    color: #662200;
    border: none;
    background-image: url(../img/h3_gray02.gif);
    background-repeat: no-repeat;
  }
  #contents h4{
    margin: 12px 3px 10px 3px;
    padding: 13px 10px 0 16px;
    line-height: 1.6;
    font-size: 1.28em;
    color: #2b72ae;
    border-bottom: solid 3px #d9d1d1;
    background-image: none;
    font-size: 29px;
  }
  #contents p {
    margin: 15px 0 15px 0;
    padding: 0 2px 0 2px;
    line-height: 1.7;
    font-size: 16px;
  }
  /*---------- 画像の回り込み ----------*/
  img.picture {
    margin: 0 10px 10px 0;
    float: left;
  }
  img.picture_r {
    margin: 0 5px 10px 10px;
    float: right;
  }
  /*---------- 表（テーブル） ----------*/
  table.t01 {
    width: 310px;
    padding: 4px;
    border: solid 1px #cccccc;
    border-collapse: collapse;
  }
  td.t01 {
    padding: 10px;
    border-collapse: collapse;
  }
  td.head {
    padding: 9px 6px 6px 15px;
    border: solid 1px #cccccc;
    border-collapse: collapse;
    background-image: url(../img/main_block_bg.gif);
  }
  td.t00 {
    padding: 4px;
  }
  table.table_line {
    border-collapse: collapse;
    border: solid 1px #999999;
    width: 100%;
  }
  td.table_head {
    border-collapse: collapse;
    border: solid 1px #999999;
    padding: 12px 14px 8px 14px;
    background-color: #fff8e3;
    width: 100px;
  }
  td.table_left {
    border-collapse: collapse;
    border: solid 1px #999999;
    padding: 12px 14px 8px 14px;
    width: 130px;
    background-color: #fff8e3;
  }
  td.table_right {
    border-collapse: collapse;
    border: solid 1px #999999;
    padding: 12px 14px 8px 14px;
    width: 500px;
    background-color: #ffffff;
  }
  td.table_line {
    border-collapse: collapse;
    border: solid 1px #999999;
    padding: 12px 14px 8px 14px;
    width: auto;
  }
  /*---------- サイドエリア ----------*/
  #menu {
    float: left;
    margin: 0 0 15px 0;
    padding: 0;
    width: 230px;
    text-align: left;
    letter-spacing: 0.05em;
    background-color: #ffffff;
  }
  .menulist {
    margin: 0 0 28px 0;
    padding: 5px 0 0 0;
    width: 220px;
    text-align: left;
  }
  .menulist h2, .menulist h3 {
    height: 27px;
    margin: 0;
    padding: 12px 0 5px 14px;
    font-size: 15px;
    color: #fffffc;
    background-color: #73C2FB;
    background-repeat: no-repeat;
  }
  .menulist ul {
    margin: 0;
    padding: 0;
  }
  .menulist li {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .menulist li a {
    color: #54351f;
    display: block;
    border-right: solid 1px #dddddd;
    border-bottom: solid 1px #dddddd;
    border-left: solid 1px #dddddd;
    padding: 11px 4px 6px 26px;
    font-size: 14px;
    line-height: 1.9;
    text-decoration: none;
    background-image: url(../img/side_menu_bg.gif);
    background-repeat: no-repeat;
  }
  .menulist li a:hover {
    color: #745a45;
    background-image: url(../img/side_menu_bg_hover.gif);
    background-repeat: no-repeat;
  }
  .menu_free {
    margin: 0 0 28px 0;
    padding: 0;
    width: 220px;
    text-align: left;
    background-image: url(../img/menu_back.gif);
  }
  .menu_free h2, .menu_free h3 {
    height: 27px;
    margin: 0;
    padding: 12px 0 5px 14px;
    font-size: 15px;
    color: #fffffc;
    background-color: #ABE1FA;
    background-repeat: no-repeat;
  }
  .menu_free p {
    margin: 0;
    padding: 8px 8px 14px 8px;
    font-size: 13px;
    line-height: 1.8;
  }
  .menu_top {
    margin: 0 0 5px 0;
    padding: 0;
    text-align: left;
  }
  .menu_top a {
    color: #993300;
    padding: 6px 0 6px 0;
    line-height: 1.8;
  }
  .menu_top a:hover {
    color: #666666;
  }
  .menu_top p {
    margin: 0;
    padding: 0;
    line-height: 1.8;
  }
  .menu_btn {
    margin: 0 0 14px 0;
    padding: 0;
    width: 220px;
    text-align: left;
  }
  .menu_btn a {
    margin: 0 0 8px 0;
    color: #004080;
    display: block;
    border: solid 1px #dddddd;
    padding: 8px 4px 4px 30px;
    font-size: 14px;
    line-height: 1.9;
    text-decoration: none;
    background-image: url(../img/side_menu_btn_bg.gif);
    background-repeat: no-repeat;
  }
  .menu_btn a:hover {
    color: #765c47;
    background-image: url(../img/side_menu_btn_bg_hover.gif);
    background-repeat: no-repeat;
  }
  .menu_btn_under {
    margin: 0 0 10px 0;
    padding: 0;
    width: 220px;
    text-align: left;
  }
  .menu_btn_under a {
    margin: 0 0 8px 0;
    color: #004080;
    display: block;
    border: solid 1px #dddddd;
    padding: 10px 4px 6px 12px;
    font-size: 13px;
    line-height: 1.9;
    text-decoration: none;
    background-image: url(../img/side_menu_btn_under_bg.gif);
    background-repeat: no-repeat;
  }
  .menu_btn_under a:hover {
    color: #765c47;
  }
  /*---------- サイドエリア・トップに戻る ----------*/
  .menu_back {
    display: none;
  }
  /*---------- フッター ----------*/
  #footer {
    clear: both;
    width: 100%;
    margin: 0;
    padding: 30px 0 30px 0;
    text-align: center;
    font-size: 14px;
    color: #333333;
    line-height: 1.8;
    border-top-color: #8db4d3;
    background-color: #d7e9f6;
  }
  #footer a {
    color: #333333;
    font-size: 14px;
    text-decoration: none;
  }
  #footer a:hover {
    color: #555555;
    text-decoration: none;
  }
}

/*---------------------------- タブレット向けのスタイル ----------------------------*/
@media screen and (min-width: 680px) and (max-width: 920px) {
  /*---------- メイン ----------*/
  #main {
    min-width: 900px;
  }
}

/*---------------------------- 共通部分（コンテンツ） ----------------------------*/
/*---------- 見出しタイトル装飾 ----------*/
#contents h3.white {
  margin: 20px 4px 20px 4px;
  padding: 10px 0 6px 0;
  line-height: 1.6;
  color: #792b04;
  border-top: none;
  border-right: none;
  border-bottom: solid 2px #aaaaaa;
  border-left: none;
  background-color: #ffffff;
  background-image: none;
}

#contents h4.memo {
  margin: 12px 0 10px 0;
  padding: 15px 10px 11px 16px;
  line-height: 1.4;
  color: #df5f08;
  border-bottom: solid 1px #df5f08;
  border-left: solid 5px #df5f08;
  background-color: #fbe8d3;
}

#contents h4.memo_w {
  margin: 12px 0 10px 0;
  padding: 16px 10px 10px 16px;
  line-height: 1.4;
  color: #54351f;
  background-color: #fff8ee;
}

#contents h4.border {
  height: 34px;
  margin: 10px 0 15px 0;
  padding: 10px 10px 0 4px;
  line-height: 1.4;
  color: #e85922;
  border-top: none;
  border-right: none;
  border-bottom: solid 3px #966934;
  border-left: none;
  background-color: #ffffff;
}

/*---------- メインコンテンツ ----------*/
img.line {
  margin: 0 8px 4px 0;
  vertical-align: middle;
}

img.head_photo {
  margin: 0 0 16px 0;
}

hr.line {
  margin: 0 0 10px 0;
  padding: 2px 0 6px 0;
  border: 0;
  border-bottom: dotted 1px #666666;
}

#news {
  height: 50px;
  overflow: auto;
  line-height: 1.8;
  padding: 8px 6px 7px 6px;
  margin: 12px 0 7px 0;
  border: solid 1px #cccccc;
  background-color: #ffffff;
}

p.back {
  margin: 0;
  padding: 0 5px 0 0;
  text-align: right;
}

/*---------- 画像の回り込み ----------*/
img.picture_le {
  margin: 0 10px 10px 0;
  float: left;
}

img.picture_ri {
  margin: 0 5px 10px 10px;
  float: right;
}

br.clear {
  display: block;
  clear: both;
}

/*---------- コンテンツ枠装飾 ----------*/
.gray_bg {
  margin: 18px 0 18px 0;
  padding: 2px 18px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #eeeeee;
}

.gray_bg p {
  padding: 3px;
  line-height: 1.7;
  letter-spacing: 0.05em;
}

.brown_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #f8f4e6;
}

.pink_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #fdeee6;
}

.green_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #f0f6da;
}

.blue_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #ebf6f7;
}

.info_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #fff8e3;
}

.point_bg {
  margin: 10px 2px 10px 2px;
  padding: 2px 5px 2px 15px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border: solid 1px #dfcf98;
  background-color: #fcfbf9;
}

.pale_bg {
  margin: 18px 2px 18px 2px;
  padding: 8px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #fffedf;
}

.message_bg {
  margin: 18px 2px 18px 2px;
  padding: 2px 8px 2px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #fff8e3;
  background-image: url(../img/message.png);
  background-repeat: no-repeat;
}

.memo_bg {
  margin: 8px 0 18px 0;
  padding: 6px 18px 6px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #faf2e2;
}

.memo_w_bg {
  margin: 8px 0 12px 0;
  padding: 6px 18px 6px 18px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #fff8ee;
}

.koe_bg {
  margin: 0;
  padding: 0;
}

.koe_beta_bg {
  margin: 8px 0 8px 0;
  padding: 2px 10px 2px 10px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  background-color: #7e6a41;
}

.check_bg {
  margin: 8px 0 18px 0;
  padding: 2px 18px 2px 18px;
  line-height: 1.7;
  letter-spacing: 0.05em;
  color: #6c4e1f;
  border: solid 6px #ded0b2;
  background-color: #faf1e3;
}

.check_bg p {
  margin: 18px 0 18px 0;
  padding: 0 2px 0 2px;
  line-height: 1.7;
  color: #6c4e1f;
}

.banner_bg {
  margin: 3px 0 10px 0;
  padding: 10px 10px 10px 14px;
  border-top: solid 3px #dec58e;
  border-right: solid 3px #dec58e;
  border-bottom: solid 3px #dec58e;
  border-left: solid 3px #dec58e;
  background-color: #fff8e3;
}

.waku_bg {
  margin: 14px 2px 14px 2px;
  padding: 2px 8px 2px 10px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 10px #f1eae0;
  border-right: solid 6px #f1eae0;
  border-bottom: solid 10px #f1eae0;
  border-left: solid 6px #f1eae0;
}

.waku_gray_bg {
  margin: 14px 2px 14px 2px;
  padding: 6px 14px 2px 14px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 2px #dddddd;
  border-right: solid 2px #dddddd;
  border-bottom: solid 2px #dddddd;
  border-left: solid 2px #dddddd;
  background-color: #fcfbf9;
}

#contents .waku_tone_bg {
  margin: 14px 2px 14px 2px;
  padding: 2px 8px 2px 10px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 10px #f1eae0;
  border-right: solid 6px #f1eae0;
  border-bottom: solid 10px #f1eae0;
  border-left: solid 6px #f1eae0;
  background-color: #fffcf7;
}

.waku_gold_bg {
  margin: 14px 2px 14px 2px;
  padding: 2px 6px 2px 8px;
  line-height: 1.8;
  letter-spacing: 0.05em;
  border-top: solid 5px #f0ddb2;
  border-right: solid 5px #f0ddb2;
  border-bottom: solid 5px #f0ddb2;
  border-left: solid 5px #f0ddb2;
  background-color: #fff8e3;
}

.gray_bg_contact {
  margin: 18px 2px 10px 2px;
  padding: 10px 8px 10px 18px;
  line-height: 1.7;
  letter-spacing: 0.05em;
  border-top: solid 1px #dddddd;
  border-right: solid 1px #dddddd;
  border-bottom: solid 1px #dddddd;
  border-left: solid 1px #dddddd;
  background-color: #eeeeee;
}

.gray_bg_contact p {
  margin: 0;
  padding: 3px 0 3px 0;
  line-height: 1.7;
}

/*---------- 文字装飾 ----------*/
span.big {
  font-size: 1.12em;
  line-height: 1.9;
}

span.b_big {
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.b_big_x {
  font-weight: bold;
  font-size: 1.25em;
  line-height: 1.7;
}

span.check {
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
  color: #555555;
}

span.red {
  color: #e60033;
}

span.red_x {
  color: #e60033;
  font-size: 1.12em;
  line-height: 1.7;
}

span.red_b {
  color: #e60033;
  font-weight: bold;
  line-height: 1.7;
}

span.red_big {
  color: #e60033;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.red_big_x {
  color: #e60033;
  font-weight: bold;
  font-size: 1.25em;
  line-height: 1.7;
}

span.brown {
  color: #993300;
}

span.brown_b {
  color: #993300;
  font-weight: bold;
}

span.brown_x {
  color: #993300;
  font-size: 1.12em;
  line-height: 1.7;
}

span.brown_b {
  color: #993300;
  font-weight: bold;
  line-height: 1.7;
}

span.brown_big {
  color: #993300;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.brown_big_x {
  color: #993300;
  font-weight: bold;
  font-size: 1.25em;
  line-height: 1.7;
}

span.blue {
  color: #007bbb;
}

span.blue_b {
  color: #007bbb;
  font-weight: bold;
  line-height: 1.7;
}

span.blue_big {
  color: #007bbb;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.pink {
  color: #c53d43;
}

span.pink_b {
  color: #c53d43;
  font-weight: bold;
  line-height: 1.7;
}

span.pink_big {
  color: #c53d43;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.orange {
  color: #e85922;
  line-height: 1.7;
}

span.orange_b {
  color: #e85922;
  font-weight: bold;
  line-height: 1.7;
}

span.orange_big {
  color: #e85922;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.orange_big_x {
  color: #e85922;
  font-weight: bold;
  font-size: 1.25em;
  line-height: 1.7;
}

span.green {
  color: #00ae4f;
}

span.green_b {
  color: #688119;
  font-weight: bold;
  line-height: 1.7;
}

span.green_big {
  color: #688119;
  font-weight: bold;
  font-size: 1.12em;
  line-height: 1.7;
}

span.mark {
  padding: 2px 2px 0 2px;
  color: #54351f;
  line-height: 1.7;
  background-color: #fdfaab;
}

span.mark_b {
  padding: 2px 2px 0 2px;
  color: #54351f;
  line-height: 1.7;
  font-weight: bold;
  background-color: #fdfaab;
}

span.mark_big {
  padding: 2px 2px 0 2px;
  color: #54351f;
  font-size: 1.12em;
  line-height: 1.7;
  font-weight: bold;
  background-color: #fdfaab;
}

span.mark_red {
  padding: 2px 2px 0 2px;
  color: #e60033;
  line-height: 1.7;
  background-color: #fdfaab;
}

span.mark_red_b {
  padding: 2px 2px 0 2px;
  color: #e60033;
  font-weight: bold;
  line-height: 1.7;
  background-color: #fdfaab;
}

span.mark_brown {
  padding: 2px 2px 0 2px;
  color: #993300;
  line-height: 1.7;
  background-color: #fdfaab;
}

span.mark_brown_b {
  padding: 2px 2px 0 2px;
  color: #993300;
  font-weight: bold;
  line-height: 1.7;
  background-color: #fdfaab;
}

/*---------- ご挨拶 ----------*/
.greeting {
  text-align: center;
}

.greeting span {
  font-size: 24px;
}

.greeting span .greeting-title {
  margin-right: 30px;
  color: #0000CD;
  position: relative;
  display: inline-block;
}

.greeting span .greeting-title::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 24px;
  background-color: #333333;
  position: absolute;
  top: 8px;
  right: -18px;
}

.greeting span span {
  color: #000000;
}

.greeting-subtitle {
  position: relative;
  color: #158b2b;
  font-size: 20px;
  padding: 10px 0;
  text-align: center;
  margin: 1.5em 0;
}

.greeting-subtitle:before {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  width: 150px;
  height: 58px;
  border-radius: 50%;
  border: 5px solid #a6ddb0;
  border-left-color: transparent;
  border-right-color: transparent;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.greeting-text span {
  transform: translateY(50px);
}

.ceo-name{
  text-align: right;
  display: block;
  margin-right: 20px;
  margin-bottom: 50px;
}

/*---------- よくあるご質問 ----------*/
dl.accordion {
  border-bottom: 2px dotted #dadada;
  overflow: hidden;
  margin: 0;
  width: 100%;
}

dl.accordion dt {
  color: #666;
  /* cursor: pointer; */
  font-size: 24px;
  font-weight: bold;
  min-height: 25px;
  line-height: 1.1;
  margin: 20px 0;
  padding: 4px 5px 0 30px;
  position: relative;
}

dl.accordion dt:before {
  content: "Q";
  color: #00a7ad;
  font-size: 24px;
  font-weight: bold;
  left: 0;
  margin-right: 10px;
  position: absolute;
  width: 30px;
}

dl.accordion dd {
  font-size: 16px;
  padding-bottom: 20px;
  padding-left: 30px;
  padding-top: 10px;
  position: relative;
}

dl.accordion dd:before {
  color: #ff9b39;
  content: "A";
  font-size: 24px;
  font-weight: bold;
  left: 0;
  margin-right: 10px;
  position: absolute;
  top: 6px;
  width: 30px;
}

/*---------- お問い合わせフォーム ----------*/
.contact__item {
  padding: 30px;
  background: #fff;
  width: 580px;
  max-width: 100%;
  margin-right: 0;
  border: 1px solid #2b72ae;
  background-color: #f8f7f3;
}

.contact__controls {
  margin: 0;
}

.contact__control {
  margin-bottom: 60px;
  display: flex;
}

.contact__control dt {
  width: 160px;
  padding: 6px 0 0;
  margin: 0;
}

.contact__control dd {
  flex-grow: 1;
  padding: 0;
  margin: 0;
}

.contact__label {
  font-size: 16px;
  font-weight: 700;
}

.contact__label--required {
  position: relative;
}

.contact__label--required::after {
  content: "必須";
  position: absolute;
  background: red;
  border-radius: 4px;
  text-align: center;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
  padding: 4px 8px;
  width: 44px;
  display: block;
  top: calc(100% + 8px);
  left: 0;
}

.contact__required {
  border-radius: 12px;
  text-align: center;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  padding: 1px 8px;
  width: 46px;
  display: block;
  margin-top: 6px;
}

.contact__radio {
  margin-top: 26px;
  padding: 0;
}

.contact__radio-item {
  margin-right: 32px;
}

.contact__radio-item:last-child {
  margin-right: 0;
}

.contact__check {
  margin-top: 58px;
  text-align: center;
}

.contact__check a {
  transition: all 0.3s ease 0s;
  font-weight: 700;
}

.contact__submit {
  margin-top: 30px;
  text-align: center;
}

.form-input {
  width: 100%;
  border: 1px solid #707070;
  padding: 4px 16px;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  background-image: none;
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: 14px;
  box-shadow: none;
  height: 38px;
  box-sizing: border-box;
  background-color: #fff;
}

.form-select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background: transparent url(../img/select-arrow.png) no-repeat center right 12px/17px 14px;
  border-radius: 0;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  padding: 3px 16px;
  width: 100%;
  border: 1px solid #707070;
  height: 38px;
}

.form-textarea {
  width: 100%;
  height: 240px;
  border: 1px solid #707070;
  resize: none;
  padding: 10px 16px;
  line-height: 1.625;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  background-image: none;
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: 14px;
  vertical-align: bottom;
  box-sizing: border-box;
  background-color: #fff;
}

.form-radio {
  display: none;
}

.form-radio + span {
  cursor: pointer;
  display: inline-block;
  padding: 0 0 0 28px;
  position: relative;
}

.form-radio + span::before, .form-radio + span::after {
  content: "";
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.form-radio + span::before {
  background: #fff;
  border: 1px solid #707070;
  display: block;
  left: 0;
  width: 20px;
  height: 20px;
}

.form-radio + span::after {
  border: 1px solid transparent;
  left: 5px;
  width: 10px;
  height: 10px;
  transition: opacity 0.3s ease 0s;
  opacity: 0;
}

.form-radio:checked + span::after {
  opacity: 1;
}

.form-checkbox {
  display: none;
}

.form-checkbox + span {
  cursor: pointer;
  display: inline-block;
  padding: 0 0 0 50px;
  position: relative;
}

.form-checkbox + span::before, .form-checkbox + span::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.form-checkbox + span::before {
  background: #fff;
  border: 1px solid #707070;
  display: block;
  left: 0;
  width: 25px;
  height: 25px;
}

.form-checkbox + span::after {
  border: 1px solid transparent;
  left: 0;
  width: 25px;
  height: 25px;
  background: transparent url(../img/icon-check.png) no-repeat center center/contain;
  transition: opacity 0.3s ease 0s;
  opacity: 0;
}

.form-checkbox:checked + span::after {
  opacity: 1;
}

.btn-contact{
  border: #707070 solid 1px;
  text-decoration: none;
  color: rgba(0,0,0,0.901);
  transition: all 0.5s ease 0s;
  display: inline-block;
  padding: 23px 37px;
  background: #0713a0;
  /* transform: translate(50px,30px); */
  margin-top: 30px;
  margin-left: 20%;
}

.btn-contact a{
  color: #fff;
  text-decoration: none;
}

/*---------- サイドエリア ----------*/
#menu hr.line {
  margin: 0;
  padding: 2px 0 6px 0;
  border: 0;
  border-bottom: dotted 1px #666666;
}

/*---------- トップに戻る ----------*/
.menu_back p.back {
  margin: 6px 0 0 0;
  padding: 0 5px 0 0;
  text-align: right;
}

.scroll {
  width: 180px;
  height: 28px;
}
