@charset "utf-8";
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
/* Reset css */
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td,
figure {
  margin: 0;
  padding: 0;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
html {
  overflow-y: scroll;
}
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
a {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
dt,
h1,
h2,
h3,
h4,
h5,
h6,
th {
  font-weight: 500;
}
p {
}
aside,
figure,
footer,
header,
main,
nav,
section {
  display: block;
}
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
}
table {
  border-collapse: collapse;
}
caption,
th {
  text-align: left;
}
q:after,
q:before {
  content: "";
}
embed,
object {
  vertical-align: top;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: 500;
}
abbr,
acronym,
fieldset,
img {
  border: 0;
}
li {
  list-style-type: none;
  list-style: none;
}
.edge li {
  white-space: nowrap;
}
img {
  vertical-align: bottom;
  height: auto;
}
hr {
  clear: both;
  border: none;
  background-color: #ffffff;
}
body {
  position: relative;
  font: 14px/1.7 "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  color: #2d2c37;
  font-weight: 400;
  line-height: 1.4em;
  -webkit-text-size-adjust: 100%;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  background-color: var(--bg);
}
img {
  width: 100%;
}
a:link {
  text-decoration: none;
}
a:visited {
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}
a:active {
  text-decoration: none;
}
a {
  color: #231815;
}
a[href^="tel:"] {
  cursor: default;
}
figure {
  display: block;
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
}
em {
  font-weight: bold;
}
svg {
  overflow: visible;
}

.mincyou {
  font-family: "noto serif jp", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.f_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.f_box_r {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-flex-wrap: wrap-reverse;
  -ms-flex-wrap: wrap-reverse;
  flex-wrap: wrap-reverse;
}
p.notes {
  margin-bottom: 1em;
}
a[href^="tel:"] {
  pointer-events: none;
}

:root {
  --brand: #171c59;
  --key: #2d2c37;
  --key_light: #606499;
  --key_thin: rgb(45 44 55 / 90%);
  --accent: #f06446;
  --caution: #ef4b4b;
  --bg: #f3f3f3;
  --gray: #ddd;
  --dark: #707070;
  --size_2s: 0.75rem;
  --size_1s: 0.875rem;
  --size_m: 1rem;
  --size_1l: 1.125rem;
  --size_2l: 1.25rem;
  --size_3l: 1.5rem;
  --size_4l: 1.75rem;
  --size_5l: 2rem;
  --size_6l: 2.25rem;
}
.mb_05 {
  margin-bottom: 5px;
}
.mb_10 {
  margin-bottom: 10px;
}
.mb_20 {
  margin-bottom: 20px;
}
.mb_30 {
  margin-bottom: 30px;
}
.mb_40 {
  margin-bottom: 40px;
}

.mt_05 {
  margin-top: 5px;
}
.mt_10 {
  margin-top: 10px;
}
.mt_20 {
  margin-top: 20px;
}
.mt_30 {
  margin-top: 30px;
}
.mt_40 {
  margin-top: 40px;
}
/* form
---------------------------------------- */
input::-ms-clear {
  display: none;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
}
input,
textarea,
label {
  display: inline-block;
  vertical-align: middle;
}
input,
textarea,
select {
  border: 1px solid #b2b2b2;
  line-height: 1;
}
select {
  -webkit-appearance: none;
  border-radius: 0;
  background-color: #fff;
}
::-webkit-input-placeholder,
:-ms-input-placeholder,
::-moz-placeholder {
  color: #ccc !important;
}
input:focus,
textarea:focus,
select:focus {
  outline: none;
  border: 1px solid #808080;
}
label {
  line-height: 1;
  padding: 10px 0;
  margin-right: 20px;
  margin-bottom: 0;
}
textarea {
  width: 100%;
  height: 175px;
  resize: vertical;
  box-sizing: border-box;
  line-height: 1.7;
}
input[type="text"],
input[type="email"] {
  width: 350px;
}
input#zip,
input#dest-zip {
  width: 200px;
}
input#address,
input#dest-address {
  width: 100%;
}
input#zip,
input#dest-zip,
select#city,
input#etc1-text,
input#etc2-text,
input#etc3-text {
  margin-left: 10px;
}
input[type="checkbox"],
input[type="radio"] {
  margin-right: 5px;
  -webkit-transform: scale(1.1, 1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
  vertical-align: middle;
}
input[type="reset"].wpcf7c-conf,
#reset.wpcf7c-conf {
  display: none;
}
input[type="reset"],
input[type="button"],
input[type="submit"] {
}
input[type="reset"],
input[type="button"] {
}
input[type="submit"] {
}
input[type="submit"][disabled] {
  opacity: 0.7;
}
form hr {
  border-top: 1px solid #b2b2b2;
  margin: 50px auto;
  width: 960px;
}

/*====================
お問合わせフォーム
 ====================*/

p.end {
  padding-top: 5px;
}
h1.contact-h1 {
  background-color: #dcdddd;
  padding: 50px 0px;
  font-size: 2em;
}
main#contact p.txt-area {
  padding: 30px 0px;
}
ul.contact_btn {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  padding-top: 30px;
}
ul.contact_btn li {
  margin: 10px;
  text-align: center;
}
/* sp
---------------------------------------- */
.forSP {
  display: none;
}
/* common
---------------------------------------- */
.layout-contents {
  width: 100%;
  margin: 0 auto;
  text-align: left;
  position: relative;
  line-break: strict;
  word-spacing: -0.2em;
}
.copy {
  padding-top: 200px;
  width: 700px;
  margin: 0 auto;
}
h1 {
  font-size: 2rem;
}
.title_box .sub-ttl {
  text-align: center;
  font-size: 1rem;
  font-weight: 400;
  color: var(--black);
  margin: 0 auto;
  line-height: 1;
  margin-bottom: 60px;
}
.title_box h3 {
  font-size: var(--size_5l);
  text-align: center;
  font-weight: 700;
}
.title_box h4 {
  font-size: var(--size_3l);
  text-align: left;
  font-weight: 700;
  border-left: 4px solid var(--key_light);
  padding-left: 10px;
  line-height: 1.4em;
  margin-bottom: 1rem;
}
.inner {
  width: 1024px;
  margin-right: auto;
  margin-left: auto;
}
.header {
  padding: 0;
  text-align: left;
}

/* motion,btn
---------------------------------------- */
*:selection {
  background: #f27649;
  color: #fff;
}
a,
img,
.photo,
.over,
aside#sns li span,
.nav-child,
.ico-area dd ul {
  -webkit-transition: All 0.5s ease;
  -moz-transition: All 0.5s ease;
  -o-transition: All 0.5s ease;
  transition: All 0.5s ease;
}
.enlargement img {
  -moz-transition: -moz-transform all 0.4s;
  -webkit-transition: -webkit-transform all 0.4s;
  -o-transition: -o-transform all 0.4s;
  -ms-transition: -ms-transform all 0.4s;
  transition: all 0.4s;
}
a:hover .enlargement img {
  -webkit-transform: scale(1.1, 1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}

/* header
---------------------------------------- */
header:after {
  content: ".";
  display: block;
  visibility: hidden;
  height: 0.1px;
  font-size: 0.1rem;
  line-height: 0;
  clear: both;
}
header .inner {
  position: relative;
}
header .head-logo {
  padding: 15px 0px;
}
header .head-logo .logo {
  display: inline-block;
  position: relative;
  width: 400px;
  height: 100px;
  overflow: hidden;
}
.menu-area {
  background-color: #172f7a;
  border-top: 3px solid #c9bc9c;
  border-bottom: 1px solid #c9bc9c;
}
.menu {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  height: 50px;
}
.menu > li {
  width: 20%; /* グローバルナビ4つの場合 */
  height: 30px;
  line-height: 30px;
}
.menu > li:first-child {
}
.menu > li a {
  display: block;
  color: #ffffff;
  font-size: 1.1em;
}
.menu > li a:hover {
}
ul.menu__second-level {
  visibility: hidden;
  opacity: 0;
  z-index: 1;
}
.menu > li:hover {
}
.menu__second-level li {
  border-top: 1px solid #111;
}
.menu__second-level li a:hover {
  background: #7a6a5691;
}
/* floatクリア */
.menu:before,
.menu:after {
  content: " ";
  display: table;
}
.menu:after {
  clear: both;
}
.menu {
  *zoom: 1;
}
.menu > li.menu__single {
  position: relative;
}
li.menu__single ul.menu__second-level {
  position: absolute;
  top: 40px;
  width: 100%;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
li.menu__single:hover ul.menu__second-level {
  top: 30px;
  visibility: visible;
  opacity: 1;
}
.menu__second-level li a {
  padding: 10px 0px;
  background-color: #fff;
}
.fixed {
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff;
  z-index: 999;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  box-shadow: 0px 3px 3px -3px rgba(0, 0, 0, 0.13);
  -webkit-box-shadow: 0px 3px 3px -3px rgba(0, 0, 0, 0.13);
  -moz-box-shadow: 0px 3px 3px -3px rgba(0, 0, 0, 0.13);
  z-index: 999999;
}
#mobile-menu {
  display: none;
}

.tel a {
  font-size: 2.6em;
  line-height: 1em;
  color: var(--accent);
  font-weight: 700;
  letter-spacing: 0;
  display: block;
}
.tel a span.btn_inner span {
  font-size: 0.6em;
}
.hours {
  xmargin-bottom: 8px;
}
/* footer
---------------------------------------- */

ul.footer-menu {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  font-size: 12px;
  flex-wrap: wrap;
  width: 50%;
}
ul.footer-menu li {
}
ul.footer-menu li a {
  border-right: 1px solid var(--dark);
  letter-spacing: inherit;
  padding: 0 1rem;
  color: #fff;
}
ul.footer-menu li a:hover {
  text-decoration: underline;
}
ul.footer-menu li:last-child a {
  border: none;
}
footer span.adress {
  padding-right: 10px;
}
footer span.fax {
  padding: 0pc 10px;
}
footer {
  background-color: var(--key_thin);
}
footer .inner {
  position: relative;
  padding-top: 40px;
  padding: 40px 0 20px;
}
footer .wrapper {
  overflow: hidden;
}

footer .footer-logo .logo {
  display: inline-block;
  position: relative;
  width: 270px;
  height: 115px;
  overflow: hidden;
}
p.footer-logo {
  margin: 0 auto;
}
footer .column {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
  padding-bottom: 20px;
}
footer .column div {
  margin: 20px 50px;
}
footer .column a {
}
footer .foot-logo img {
  width: 238px;
}
footer .column:last-child {
  margin-right: 0;
}
footer .column li {
}
footer .column li:last-child {
  margin-bottom: 0;
}
footer .column li a {
  display: block;
  padding: 5px;
}
footer .column li a:hover {
  text-decoration: underline;
}
footer .column li ul {
  margin-left: 15px;
  color: #808080;
}
footer .column li li {
  font-weight: normal;
  margin-bottom: 1px;
}
footer .foot-address {
  line-height: 1.6;
  font-size: 0.9rem;
  text-align: left;
}
footer .column:last-child ul {
  margin-bottom: 25px;
}
footer .column:last-child ul ul {
  margin-bottom: 0;
}
p.contact_btn a {
  background-color: #fff;
  padding: 5px 30px;
  border: 1px solid #000;
  font-weight: 600;
}
p.contact_btn a:hover {
  background-color: #9f9080;
}
footer .column p.contact_btn {
  margin-left: auto;
  line-height: 3em;
}
footer span.tel {
  padding-left: 10px;
}
.copyright {
  text-align: center;
  font-size: 0.8em;
  padding-top: 10px;
  letter-spacing: 0.1em;
  padding-bottom: 10px;
  background-color: #333;
  color: #fff;
}

.footer_head {
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
}
/*====================
コンテンツスタイル
====================*/

/* index
---------------------------------------- */
main.index section {
  padding: 50px 0px 50px 0px;
}
main.index section:nth-child(odd) {
  background-color: var(--key);
}
main.index section:nth-child(odd) p,
main.index section:nth-child(odd) .title_box {
  color: #fff;
}
main.index section:nth-child(odd) .color_switch {
  color: #fff;
}

main.index section:nth-child(odd) .mailform .color_switch td span.ast {
  color: #ff9;
}
main.index section:nth-child(odd) .privacypolicy_item h2,
main.index section:nth-child(odd) .privacypolicy_item h3,
main.index section:nth-child(odd) .privacypolicy_item h4 {
  color: #fff;
}
/* #contact
---------------------------------------- */
main.contact form {
  width: 100%;
}
main.contact form dl dt {
  padding: 0;
  width: 180px;
  line-height: 35px;
}
main.contact form dl dd {
  width: 750px;
}
main.contact form .description {
  color: #ec1c24;
}
main.contact form .attention {
  margin-top: 15px;
  font-size: 14px;
  line-height: 1.7;
}
main.contact form #privacy {
  overflow: auto;
  box-sizing: border-box;
  padding: 30px;
  height: 173px;
  border: 1px solid #b2b2b2;
}
main.contact .wpcf7-response-output {
  box-sizing: border-box;
  border-radius: 4px;
  margin: 50px auto 0 auto;
  padding: 10px 15px;
  width: 960px;
  color: #f16b3a;
  font-weight: bold;
  text-align: center;
}
main.contact .wpcf7c-conf:not(#reset) {
  background-color: #ffef32;
}
.contactArea p.text {
  padding-bottom: 50px;
  font-size: 1.2em;
}
main.contact .cont {
  padding-bottom: 100px;
}
p.error_messe {
  line-height: 2rem;
  color: #f51414;
}
.flex_box {
  display: flex;
  justify-content: space-between;
}
.col_md_4 {
  flex: 0 0 calc(0.33 - 17px);
}
.col_md_5 {
  flex: 0 0 calc(41.6% - 17px);
}
.col_md_6 {
  flex: 0 0 calc(50% - 17px);
}
.col_md_7 {
  flex: 0 0 calc(58.3% - 17px);
}
/*====================
ページ先頭ボタン
 ====================*/
#page-top {
  width: 70px;
  height: 70px;
  position: fixed;
  right: 10px;
  bottom: -50px;
  background: #808080;
  opacity: 0.6;
  z-index: 99;
}
#page-top a {
  position: relative;
  display: block;
  width: 70px;
  height: 70px;
  text-decoration: none;
}
#page-top a::before {
  font-family: FontAwesome;
  content: "\f077";
  font-size: 36px;
  color: #fff;
  position: absolute;
  width: 70px;
  height: 70px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
/*====================
ぱんくず
 ====================*/
.breadcrumb {
  text-align: left;
  padding: 10px 0px 0px 0px;
  color: #999;
}
.breadcrumb li {
  display: inline; /*横に並ぶように*/
  list-style: none;
}
.breadcrumb li:after {
  /* >を表示*/
  content: ">";
  padding: 0 3px;
}
.breadcrumb li:last-child:after {
  content: "";
}
.breadcrumb li a {
  text-decoration: none;
  color: #333;
}
.breadcrumb li a:hover {
  text-decoration: underline;
}

/*==================== ヘッダースタイル（共通）====================*/
h1.logo {
  text-align: left;
}
.header {
  background-color: #fff;
  height: 120px;
  background-color: var(--bg);
  padding: 0 100px 0 20px;
}
.top-head {
  width: 100%;
  padding: 0;
}
.top-head {
  margin-top: 0;
  text-decoration: none;
  z-index: 999;
}
.top-head .inner {
  position: relative;
}
header .logo img {
  display: inline-block;
  position: relative;
  overflow: hidden;
  width: 238px;
}
.logo_box {
  display: flex;
  justify-content: start;
  align-items: center;
}
.mobile-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 120px;
}

/* ------------------------------------------------ drawer menu */

.check {
  display: none;
}
.drawer-menu dt i {
  display: inline-block;
}
ul.drawer-menu-sub {
  display: block;
}
.drawer-menu {
  box-sizing: border-box;
  position: fixed;
  top: 0;
  right: 0;
  width: 30%;
  min-width: 320px;
  height: 100%;
  xpadding: 120px 0;
  padding: 20px 0;
  background: var(--key);
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: 0.2s;
  transition-duration: 0.2s;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform-origin: right center;
  -ms-transform-origin: right center;
  transform-origin: right center;
  -webkit-transform: perspective(500px) rotateY(-90deg);
  transform: perspective(500px) rotateY(-90deg);
  opacity: 0;
}

@media screen and (max-width: 480px) {
  /* 480px以下に適用されるCSS（SP用） */
  .drawer-menu {
    width: 100%;
  }
}
.drawer-menu dl {
  text-align: left;
  color: #fff;
}
.drawer-menu dt {
  cursor: pointer;
  text-align: left;
  padding: 15px 0;
  font-size: 1.3rem;
  border-style: solid;
  border-width: 1px 0 0 0;
  border-color: #ccc;
  color: #555;
}
.drawer-menu dt:last-child {
  border-width: 1px 0;
}
.drawer-menu dd {
  display: none;
}
.drawer-menu li {
  text-align: left;
}
.drawer-menu li a {
  xdisplay: block;
  xheight: 50px;
  xline-height: 50px;
  xfont-size: 14px;
  xcolor: #fff;
  x-webkit-xtransition: all 0.8s;
  text-decoration: none;
  xtransition: all 0.8s;
}
.drawer-menu li a:hover {
  xcolor: #1a1e24;
  xbackground: #fff;
}
.mob-menu {
  font-size: 80%;
  padding: 80px 20px 0 20px;
}
.drawer-menu > .mob-menu li {
  font-size: 1.3rem;
  padding: 10px 0;
  background-color: #fff;
  text-align: left;
}
.drawer-menu > .mob-menu li:last-child {
  border-width: 1px 0 0 0;
}
.drawer-menu > .mob-menu i {
  color: var(--key_light);
}
.drawer-menu > .mob-menu i.drawer-anker {
  color: #ffc451;
}
.drawer-menu ul.drawer-menu-sub {
  padding: 10px 0;
  background-color: #fff;
}
.drawer-menu .mob-menu a:link {
  width: 100%;
  text-decoration: none;
  color: #fff;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  display: block;
  font-size: 1rem;
}
.drawer-menu .mob-menu a:visited {
  color: #fff;
}
.drawer-menu .mob-menu a:hover {
  color: #fff;
}
ul.drawer-menu-sub {
}
.fa-chevron-down:before {
  padding-right: 3px;
}
label.close-menu {
  display: none;
}
/* ------------------------------------------------ checked */

.check:checked ~ .drawer-menu {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
  -webkit-transform: none;
  -ms-transform: none;
  transform: none;
  opacity: 1;
  z-index: 999;
  overflow-y: auto;
}

.check:checked ~ .contents {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: translateX(-300px);
  -ms-transform: translateX(-300px);
  transform: translateX(-300px);
}
.check:checked ~ .menu-btn {
}
.check:checked ~ .menu-btn .menu-btn__text {
  visibility: hidden;
  opacity: 0;
}
.check:checked ~ .menu-btn .bar.top {
  width: 35px;
  margin: 0px 6px;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.check:checked ~ .menu-btn .bar.middle {
  opacity: 0;
}
.check:checked ~ .menu-btn .bar.bottom {
  width: 35px;
  xtop: 40px;
  xtop: 24px;
  margin: 13px 6px;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.menu .fa-dot-circle-o {
  color: #00a6e7;
}
dt.js_toggle_item.forsp {
  display: block;
}
dt.js_toggle_item.forpc {
  display: none;
}
/* ------------------------------------------------ menu button */

.menu-btn {
  position: fixed;
  top: 35px;
  right: 5px;
  display: block;
  width: 35px;
  height: 30px;
  text-align: center;
  cursor: pointer;
  z-index: 1000;
  padding: 8px 5px;
  border-radius: 4px;
  /* box-sizingリセット */
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  -o-box-sizing: content-box;
  -ms-box-sizing: content-box;
  box-sizing: content-box;
  background-color: var(--bg);
}
.bar {
  display: block;
  width: 35px;
  height: 1px;
  background: var(--key);
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  transform-origin: left top;
}
.bar.middle {
  opacity: 1;
  margin: 8px 0;
}
.bar.bottom {
  -webkit-transform-origin: left bottom;
  -ms-transform-origin: left bottom;
  transform-origin: left bottom;
}
.menu-btn__text {
  position: absolute;
  font-size: 10px;
  font-weight: bold;
  bottom: 3px;
  left: 0;
  right: 0;
  margin: auto;
  color: var(--key);
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  display: block;
  visibility: visible;
  opacity: 1;
}

.menu-btn:hover {
  xbackground: var(--key);
}
.menu-btn:hover .menu-btn__text {
  xcolor: #fff;
}
.menu-btn:hover .bar {
  xbackground: #fff;
}
/*--------------
お問い合わせ誘導
--------------*/

/************************ ページ送り ************************/
.pageArea.clearfix.member {
  padding-bottom: 30px;
  border-top: 1px solid #ccc;
}
.pageArea-item {
  text-align: center;
  padding-top: 20px;
  margin: 10px 0px;
}
ul.pageArea-navi-number {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 50%;
  margin: 0 auto;
}
ul.pageArea-navi-number li {
  margin-right: 10px;
  list-style: none;
}
ul.pageArea-navi-number li a {
  text-decoration: none;
}
span.pager_index {
  background-color: #fff;
  border: 1px solid var(--accent);
  padding: 10px;
  color: #333;
  display: block;
  margin-top: 5px;
}
span.pager_index.nowpage {
  background-color: var(--accent);
  border: 1px solid var(--accent);
  padding: 10px;
  color: #fff;
  display: block;
  margin-top: 5px;
}
.member_page .pageArea .link_next,
.member_page .pageArea .link_before {
  color: #231815;
}
.member_page .pageArea .pageArea-navi {
  color: #231815;
}
.member_page .pageArea .link_next,
.member_page .pageArea .link_before {
  color: #231815;
}
.pageArea .pageArea-navi-number form,
.pageArea .pageArea-navi form {
  width: 0;
  height: 0;
  margin: 0;
  padding: 0;
  font-size: 0;
  display: none;
}
.member_page .pageArea .link_next3,
.member_page .pageArea .link_before3 {
  color: #ccc;
}

/*タグ*/
.tag-info {
  border-radius: 4px;
  padding: 8px 20px;
  margin-bottom: 10px;
  display: inline-block;
  margin-right: 8px;
  font-size: 16px;
}

.bk01 {
  background-color: var(--accent);
  color: #fff;
}
.jikyu,
.kyuryo {
  border: 1px solid #c3003c;
  background: #fff;
  color: #333;
}
.syokuba {
  background-color: var(--key);
  color: #fff;
}

/************************ contact ************************/

.domain-info {
  background-color: #f2f2f2;
  border-style: solid;
  border-color: #e6e6e6;
  border-width: 1px;
  padding: 20px;
  text-align: center;
  margin: 50px auto;
  width: 900px;
}
.domain-info > p strong {
  display: block;
  padding: 10px 0px;
}
.domain-info p {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 0;
}
.domain-info > p#domain strong {
  color: #e6144e;
  display: block;
}
p#domain strong a {
  color: var(--key);
  font-size: 18px;
}
.domain-info > p:last-child {
  margin: 0;
}

.mailform {
  xwidth: 900px;
  margin: 0 auto;
}
.mailform table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-right: auto;
  margin-left: auto;
  width: 100%;
  font-size: 16px;
}
.mailform th {
  width: 250px;
  font-size: 14px;
  font-weight: normal;
  padding: 20px 10px;
  background-color: rgb(255 255 255 / 10%);
  vertical-align: top;
  border-top: 1px solid #ccc;
  line-height: 1.4em;
}
.mailform th:last-of-type {
  border-bottom: 1px solid #ccc;
}
.mailform th span {
  width: 50px;
  display: inline-block;
  color: #fff;
  background-color: #097530;
  padding: 5px 10px;
  margin: auto 0;
  text-align: center;
  font-size: 10px;
  border-radius: 5px;
  margin-left: 10px;
}
.mailform th span.formhead-need {
  background-color: var(--caution);
}
.mailform td {
  font-size: 90%;
  padding: 20px 10px;
  text-align: left;
  background-color: rgb(255 255 255 / 10%);
  border-top: 1px solid #ccc;
}
.mailform td span.ast {
  display: block;
  padding-top: 10px;
  font-size: 14px;
  color: var(--caution);
}
.mailform td:last-child {
  border-bottom: 1px solid #ccc;
}
.mailform td p {
}
.mailform td.postcode input {
  width: 250px;
}
.mailform td.postcode span {
  padding-left: 20px;
}
.mailform td ul li {
  margin-bottom: 20px;
}
.mailform td ul.address-list li span {
  padding-right: 20px;
}
.mailform td.work_history p span {
  padding-right: 20px;
}

.mailform td.work_history p {
  margin-bottom: 1rem;
}
.mailform td ul.address-list li span {
  padding-right: 20px;
}
.mailform td ul li input {
  width: 400px;
}
.mailform textarea {
  width: 100%;
  padding: 10px;
  border: none;
}
.mailform input,
.mailform select {
  font-size: 16px !important;
  height: 40px;
  background: #fff;
  border: none;
  padding-left: 20px;
  /*color: #817b75;*/
}
.mailform select {
  padding-left: 10px;
  padding-right: 10px;
}
.mail-form-footer {
  text-align: center;
  margin-top: 50px;
}
.cat-list {
  display: inline-block;
  vertical-align: middle;
  text-align: center;
  width: 50%;
  min-width: 300px;
  line-height: 1.4;
}
.cat-list button {
  padding: 0;
  width: 100%;
}
.cat-list label {
  display: inline-block;
  margin-bottom: 0;
  cursor: pointer;
  position: relative;
  top: 0;
  right: 0;
  width: 100%;
}
input[type="submit"],
input[type="button"] {
}
input[type="button"] {
  background-color: #fff;
  border: 2px solid #333;
  background-color: #ffffff;
  border: 1px solid #31364d;
  color: #31364d;
}
input[type="submit"]:hover {
  opacity: 0.6;
}
input[type="button"]:hover {
  opacity: 0.6;
}

.cat-list button {
  margin-top: 20px;
  background: none;
}
.cat-list span a {
  color: #f15a24;
}
.cat-list span a:hover {
  opacity: 0.6;
}
button {
  border: none;
  　outline: none;
}
button:focus {
  outline: 0;
}

.send_form .mailform {
  width: 700px;
}
.send_form .mailform th,
.send_form .mailform td {
  xbackground-color: #fff;
  border-bottom: 1px solid #472800;
}
.send_form p.txt-area {
  font-size: 18px;
  color: #472800;
  margin-bottom: 50px;
  text-align: center;
}
.radio input {
  height: auto;
  width: auto;
  margin-right: 10px;
}

/*-----//contact-----*/

/*-----社員の声-----*/
p.employee_spec {
  font-weight: 700;
  margin-bottom: 0.5rem;
}
/*-----簡単エントリー-----*/
.privacypolicy {
  overflow-y: scroll;
  width: 100%;
  height: 300px;
  margin-bottom: 20px;
  padding: 20px;
  box-sizing: border-box;
  border: 1px solid #ccc;
}
main.contact form .privacypolicy dl dt {
  width: 100%;
  line-height: 1.2em;
}
main.contact form .privacypolicy dl dd {
  width: 100%;
  font-size: var(--size_s);
  margin-bottom: 1rem;
}

.privacypolicy_item .pages_title_box h2 {
  font-size: 1.2rem;
  margin-bottom: 1rem;
}
.privacypolicy_item .pages_title_box h3 {
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}

.privacypolicy_item .pages_title_box h4 {
  font-size: 1rem;
  margin-bottom: 0.5rem;
}

.privacypolicy_item dd {
  margin-bottom: 1rem;
}
.privacypolicy_item p {
  margin-bottom: 0.5rem;
}
/************************ search ************************/

/*
.search_box h2:before {
  font-family: "Font Awesome 5 Free";
  content: "\f002";
  height: 2em;
  line-height: 2.25em;
  margin-right: 0.25em;
}
*/
.search dd.search_list input,
.search dd.search_list select {
  margin: 0 3px 3px 0;
  padding: 2px;
  position: relative;
  top: 1px;
  height: 50px;
}
.search_box h2 {
  color: #fff;
  padding: 1em;
  margin: 0;
  border: 1px solid var(--dark);
  border-bottom: none;
  line-height: 1.25em;
  font-size: 1.25em;
  text-align: center;
  font-weight: 700;
  background: var(--dark);
}
.search_box h2 span {
  font-size: 1em;
  display: inline-block;
  white-space: nowrap;
}
.search_box ul.search_list li {
  width: 30%;
  margin-right: 5%;
  float: left;
  margin-bottom: 1.5em;
}
.search_box ul.search_list li:nth-child(3) {
  margin-right: 0%;
}
.search ul.search_list input,
.search ul.search_list select {
  width: 100%;
  height: 3em;
  padding-left: 0.5em;
}
.search_box.search_box_top p {
  font-size: 1.6em;
  font-weight: 700;
  text-align: center;
}

.search_box {
  width: 1024px;
  margin: 0 auto;
}
.search_box .search_inner {
  padding: 20px;
  border: 1px solid var(--dark);
  border-radius: 0 0 8px 8px;
  background: #fff;
}

.search_box h2 {
  font-size: 32px;
}
/*アコーディオン*/
.accordion .toggle {
  display: none;
}
.accordion .Label {
  /*タイトル*/
  padding: 1em;
  display: inline-block;
  color: #fff;
  background: var(--dark);
  padding-right: 50px;
}
.accordion .Label::before {
  /*タイトル横の矢印*/
  content: "";
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  position: absolute;
  top: calc(50% - 3px);
  right: 20px;
  transform: rotate(135deg);
}
.accordion .Label,
.accordion .content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}
.accordion .content {
  /*本文*/
  height: 0;
  margin-bottom: 10px;
  padding: 0 20px;
  overflow: hidden;
}
.accordion .toggle:checked + .Label + .content {
  /*開閉時*/
  height: auto;
  padding: 20px 4px;
  transition: all 0.3s;
}
.accordion .toggle:checked + .Label::before {
  transform: rotate(-45deg) !important;
}
