@charset "UTF-8";
/* ==================================================
[Style]
	 1. Reset
	 2. Base
	 3. Font
	 3. Layout
	 4. Module
	 5. State
	 6. Theme
	 7. Slick
	 8. Header
	 9. Footer
	10. Index
	11. About
================================================== */
/* --------------------------------------------------
	 1. Reset
-------------------------------------------------- */
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/* --------------------------------------------------
	 2. Base
-------------------------------------------------- */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  color: #000;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.8;
  word-break: normal;
  overflow-wrap: normal;
  word-wrap: normal;
  background-color: transparent;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  color: #231815;
}

a {
  outline: none;
  word-break: break-all;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

a:link, a:visited {
  color: #c51724;
  text-decoration: underline;
}

a:hover, a:active {
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

em, dl, i, address {
  font-style: normal;
}

sup, sub {
  font-size: 0.75rem;
  line-height: 1.35;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 1rem;
  font-family: inherit;
}

table th, table td {
  text-align: left;
  vertical-align: middle;
  padding: 1.2em 2.4em;
}

table th {
  font-weight: normal;
}

table td {
  word-break: break-all;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

select,
textarea,
input[type="text"],
input[type="email"],
input[type="password"] {
  margin: 5px;
  padding: 6px;
  color: #222222;
  font-size: 1rem;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  border: 1px solid #000;
  border-radius: 4px;
  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

textarea,
input[type="text"],
input[type="email"],
input[type="password"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

input[type="text"].align_left {
  text-align: left;
}

input[type="text"].align_center {
  text-align: center;
}

input[type="text"].align_right {
  text-align: right;
}

input[type="radio"], input[type="checkbox"] {
  margin: 3px 0 5px 5px;
  outline: none;
  cursor: pointer;
}

input[type="radio"] + label,
input[type="checkbox"] + label {
  padding: 0 8px 0 2px;
  cursor: pointer;
}

input:-moz-placeholder, textarea:-moz-placeholder {
  color: #4d4d4d;
}

input::-moz-placeholder, textarea::-moz-placeholder {
  color: #4d4d4d;
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #4d4d4d;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #4d4d4d;
}

p {
  min-height: 1.8em;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

iframe {
  max-width: 100%;
}

.opacity {
  opacity: 1 !important;
}

@media all and (min-width: 740px) {
  html {
    font-size: 16px;
  }
}

@media all and (max-width: 739px) {
  html {
    font-size: 14px;
  }
}

/* --------------------------------------------------
	 2. Font
-------------------------------------------------- */
/* --------------------------------------------------
	 3. Layout
-------------------------------------------------- */
#all {
  overflow: hidden;
}

#content,
#footer {
  clear: both;
}

#content .inner, #content .inner02, #content .inner03, #content .inner04,
#footer .inner,
#footer .inner02,
#footer .inner03,
#footer .inner04 {
  position: relative;
  margin: 0 auto;
}

#primary .main_img {
  position: relative;
  background: transparent no-repeat center center;
  background-size: cover;
}

#primary .page_title {
  overflow: hidden;
  position: relative;
  background: transparent no-repeat center center;
  background-size: cover;
}

#primary .page_title h2 {
  margin-bottom: 0;
  padding: 4em 0;
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 1.875rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

#primary .page_title h2::after {
  display: none;
}

#pagetop {
  position: fixed;
  right: 20px;
  bottom: 50px;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  z-index: 5;
}

#pagetop.fixed {
  pointer-events: auto;
  opacity: 1;
}

#pagetop a {
  display: block;
  overflow: hidden;
  color: transparent;
  text-decoration: none;
  text-indent: 110%;
  white-space: nowrap;
  font-size: 0;
  width: 80px;
  height: 80px;
  background: #4d4d4d url(image/btn_pagetop.png) no-repeat center center;
  background-size: contain;
  border-radius: 50%;
}

#breadline {
  padding-top: 5px;
  font-weight: 500;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 0.875rem;
}

#breadline li {
  display: inline-block;
  vertical-align: middle;
  padding: 5px 0;
}

#breadline li .divider {
  padding: 0 10px;
  margin-top: -2px;
  color: #000;
}

#breadline li a {
  color: #000;
  text-decoration: none;
}

#breadline li span {
  display: inline-block;
  vertical-align: middle;
  max-width: 40em;
  overflow: hidden;
  -ms-text-overflow: ellipsis;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
  word-wrap: normal;
  color: #000000;
}

@media all and (min-width: 740px) {
  #content section,
  #content .section {
    padding: 5em 0;
  }
  #content .inner,
  #footer .inner {
    padding-left: 20px;
    padding-right: 20px;
    max-width: 1000px;
  }
  #content .inner02,
  #footer .inner02 {
    padding-left: 20px;
    padding-right: 20px;
    max-width: 1360px;
  }
  #content .inner03,
  #footer .inner03 {
    padding-left: 20px;
    padding-right: 20px;
    max-width: 880px;
  }
  #content .inner04,
  #footer .inner04 {
    padding-left: 20px;
    padding-right: 20px;
    max-width: 1140px;
  }
  #pagetop a {
    -webkit-transition: background-color 0.4s, -webkit-transform 0.4s;
    transition: background-color 0.4s, -webkit-transform 0.4s;
    transition: background-color 0.4s, transform 0.4s;
    transition: background-color 0.4s, transform 0.4s, -webkit-transform 0.4s;
  }
  #pagetop a:hover {
    background-color: rgba(0, 0, 0, 0.6);
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media only screen and (max-width: 939px) {
  #primary .page_title h2 {
    padding-top: 60px;
  }
}

@media only screen and (max-width: 739px) {
  #content section,
  #content .section {
    padding: 3em 0;
  }
  #header,
  #content,
  #footer {
    min-width: 320px;
  }
  #header .inner, #header .inner02, #header .inner03, #header .inner04,
  #content .inner,
  #content .inner02,
  #content .inner03,
  #content .inner04,
  #footer .inner,
  #footer .inner02,
  #footer .inner03,
  #footer .inner04 {
    padding-left: 25px;
    padding-right: 25px;
    min-width: 270px;
  }
  #primary .main_img {
    height: 210px;
  }
  #primary .page_title {
    overflow: hidden;
    position: relative;
    background: transparent no-repeat center center;
    background-size: cover;
  }
  #primary .page_title h2 {
    margin-bottom: 0;
    padding: 3em 0;
    font-size: 1.25rem;
  }
  #breadline {
    font-size: 0.625rem;
  }
  #breadline li .divider {
    padding: 0 5px;
  }
  #pagetop {
    right: 10px;
    bottom: 10px;
  }
  #pagetop a {
    width: 40px;
    height: 40px;
  }
  #about {
    padding-top: 1rem;
  }
}

/* --------------------------------------------------
	 4. Module
-------------------------------------------------- */
a[href^="tel:"] {
  pointer-events: none;
  text-decoration: none;
}

a[target="_blank"]::after, a[href^="http"]::after {
  display: inline-block;
  vertical-align: middle;
  content: "";
  margin-left: .5em;
  width: 10px;
  height: 10px;
  background: transparent url(image/icon_window_brown.png) no-repeat center center;
  background-size: contain;
}

.gothic {
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.mincho {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.font_big {
  font-size: 1.25rem !important;
}

.font_large {
  font-size: 1.125rem !important;
}

.font_normal {
  font-size: 1rem !important;
}

.font_small {
  font-size: 0.875rem !important;
}

.font_little {
  font-size: 0.75rem !important;
}

.mt_0 {
  margin-top: 0rem !important;
}

.mr_0 {
  margin-right: 0rem !important;
}

.mb_0 {
  margin-bottom: 0rem !important;
}

.ml_0 {
  margin-left: 0rem !important;
}

.m_0 {
  margin: 0rem !important;
}

.mx_0 {
  margin-left: 0rem !important;
  margin-right: 0rem !important;
}

.my_0 {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
}

.pt_0 {
  padding-top: 0rem !important;
}

.pr_0 {
  padding-right: 0rem !important;
}

.pb_0 {
  padding-bottom: 0rem !important;
}

.pl_0 {
  padding-left: 0rem !important;
}

.p_0 {
  padding: 0rem !important;
}

.px_0 {
  padding-left: 0rem !important;
  padding-right: 0rem !important;
}

.py_0 {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
}

.mt_1 {
  margin-top: 1rem !important;
}

.mr_1 {
  margin-right: 1rem !important;
}

.mb_1 {
  margin-bottom: 1rem !important;
}

.ml_1 {
  margin-left: 1rem !important;
}

.m_1 {
  margin: 1rem !important;
}

.mx_1 {
  margin-left: 1rem !important;
  margin-right: 1rem !important;
}

.my_1 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.pt_1 {
  padding-top: 1rem !important;
}

.pr_1 {
  padding-right: 1rem !important;
}

.pb_1 {
  padding-bottom: 1rem !important;
}

.pl_1 {
  padding-left: 1rem !important;
}

.p_1 {
  padding: 1rem !important;
}

.px_1 {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.py_1 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.mt_2 {
  margin-top: 2rem !important;
}

.mr_2 {
  margin-right: 2rem !important;
}

.mb_2 {
  margin-bottom: 2rem !important;
}

.ml_2 {
  margin-left: 2rem !important;
}

.m_2 {
  margin: 2rem !important;
}

.mx_2 {
  margin-left: 2rem !important;
  margin-right: 2rem !important;
}

.my_2 {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}

.pt_2 {
  padding-top: 2rem !important;
}

.pr_2 {
  padding-right: 2rem !important;
}

.pb_2 {
  padding-bottom: 2rem !important;
}

.pl_2 {
  padding-left: 2rem !important;
}

.p_2 {
  padding: 2rem !important;
}

.px_2 {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}

.py_2 {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

.mt_3 {
  margin-top: 3rem !important;
}

.mr_3 {
  margin-right: 3rem !important;
}

.mb_3 {
  margin-bottom: 3rem !important;
}

.ml_3 {
  margin-left: 3rem !important;
}

.m_3 {
  margin: 3rem !important;
}

.mx_3 {
  margin-left: 3rem !important;
  margin-right: 3rem !important;
}

.my_3 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.pt_3 {
  padding-top: 3rem !important;
}

.pr_3 {
  padding-right: 3rem !important;
}

.pb_3 {
  padding-bottom: 3rem !important;
}

.pl_3 {
  padding-left: 3rem !important;
}

.p_3 {
  padding: 3rem !important;
}

.px_3 {
  padding-left: 3rem !important;
  padding-right: 3rem !important;
}

.py_3 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.mt_4 {
  margin-top: 4rem !important;
}

.mr_4 {
  margin-right: 4rem !important;
}

.mb_4 {
  margin-bottom: 4rem !important;
}

.ml_4 {
  margin-left: 4rem !important;
}

.m_4 {
  margin: 4rem !important;
}

.mx_4 {
  margin-left: 4rem !important;
  margin-right: 4rem !important;
}

.my_4 {
  margin-top: 4rem !important;
  margin-bottom: 4rem !important;
}

.pt_4 {
  padding-top: 4rem !important;
}

.pr_4 {
  padding-right: 4rem !important;
}

.pb_4 {
  padding-bottom: 4rem !important;
}

.pl_4 {
  padding-left: 4rem !important;
}

.p_4 {
  padding: 4rem !important;
}

.px_4 {
  padding-left: 4rem !important;
  padding-right: 4rem !important;
}

.py_4 {
  padding-top: 4rem !important;
  padding-bottom: 4rem !important;
}

.mt_5 {
  margin-top: 5rem !important;
}

.mr_5 {
  margin-right: 5rem !important;
}

.mb_5 {
  margin-bottom: 5rem !important;
}

.ml_5 {
  margin-left: 5rem !important;
}

.m_5 {
  margin: 5rem !important;
}

.mx_5 {
  margin-left: 5rem !important;
  margin-right: 5rem !important;
}

.my_5 {
  margin-top: 5rem !important;
  margin-bottom: 5rem !important;
}

.pt_5 {
  padding-top: 5rem !important;
}

.pr_5 {
  padding-right: 5rem !important;
}

.pb_5 {
  padding-bottom: 5rem !important;
}

.pl_5 {
  padding-left: 5rem !important;
}

.p_5 {
  padding: 5rem !important;
}

.px_5 {
  padding-left: 5rem !important;
  padding-right: 5rem !important;
}

.py_5 {
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}

.clearfix::after {
  display: block;
  content: "";
  clear: both;
}

.float_left {
  float: left;
}

.float_right {
  float: right;
}

.clear_both {
  clear: both;
}

.text_center {
  text-align: center;
}

.text_left {
  text-align: left;
}

.text_right {
  text-align: right;
}

h3 {
  font-size: 1.875rem;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
  padding-bottom: 0.5em;
  position: relative;
}

h3:after {
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #c51724;
  position: absolute;
  bottom: -5px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

h4 {
  font-size: 1rem;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  padding: 0 0 0.5em 1.75em;
  position: relative;
  border-bottom: 1px solid #9e9f9f;
}

h4:after {
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #c51724;
  position: absolute;
  top: 5px;
  left: 0;
}

h5 {
  font-size: 1.1875rem;
  color: #231815;
  text-align: center;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

h6 {
  font-size: 1.4375rem;
  color: #231815;
  text-align: center;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

table {
  width: 100%;
}

table.basic_table {
  margin: 2em auto;
  background-color: #fff;
  border-bottom: 2px solid #fff;
}

table.basic_table th,
table.basic_table td {
  border-top: 2px solid #fff;
  background: #efefef;
}

table.basic_table th {
  font-weight: bold;
  text-align: center;
  width: 25%;
  background-color: #3a3838;
  border-right: 2px solid #fff;
  color: #fff;
}

table.basic_table td {
  font-weight: 500;
}

table.basic_table thead {
  line-height: 1.4;
}

table.basic_table tbody.text_center th,
table.basic_table tbody.text_center td {
  text-align: center;
}

table.basic_table td > table {
  border-bottom: 2px dashed #fff;
}

table.basic_table td > table th,
table.basic_table td > table td {
  padding: 10px 30px;
  border-top: 2px dashed #fff;
}

table.basic_table td > table th {
  width: 30%;
  background-color: #efefef;
}

div.focus_text, div.attention_text {
  margin: 2em auto;
  padding: 3em 4em;
  max-width: 960px;
  font-weight: 500;
}

div.focus_text {
  background-color: #ffe5e1;
}

div.focus_text .title {
  color: #231815;
}

div.attention_text {
  border: 4px solid #c51724;
  background-color: #ffffff;
}

div.attention_text .title {
  color: #c51724;
}

ul.inline > li,
ol.inline > li {
  display: inline-block;
  vertical-align: middle;
  padding-right: 3em;
}

ul.basic_ul {
  margin-left: 1em;
}

ul.basic_ul > li {
  position: relative;
  padding-left: .5em;
}

ul.basic_ul > li::before {
  position: absolute;
  left: -1em;
  top: .65em;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  background-color: #000000;
  border: 2px solid #000000;
  border-radius: 50%;
}

ul.basic_ul > li > ul,
ul.basic_ul > li > ol {
  margin-left: 1.25em;
}

ul.basic_ul > li > ul > li::before {
  width: 8px;
  height: 8px;
  background-color: #808080;
  border: 0;
}

ol.basic_ol {
  margin-left: 1em;
  list-style: decimal;
}

ol.basic_ol > li {
  padding-left: .25em;
}

ol.basic_ol > li > ul,
ol.basic_ol > li > ol {
  margin-left: 1.25em;
}

dl.basic_dl > dd {
  margin-left: 1em;
}

pre {
  white-space: normal;
}

@media all and (min-width: 740px) {
  table.fixed {
    table-layout: fixed;
  }
}

@media only screen and (max-width: 739px) {
  a[href^="tel:"] {
    pointer-events: auto;
  }
  table.basic_table th,
  table.basic_table td {
    padding: 10px 15px;
    display: block;
    width: 100%;
  }
  table.basic_table th {
    min-width: 80px;
  }
  table.basic_table td {
    border-top: none;
  }
  table.basic_table td > table th {
    min-width: 70px;
  }
  table.basic_table td > table th,
  table.basic_table td > table td {
    display: block;
    width: 100%;
    padding: 5px 10px;
  }
  table.basic_table td > table td {
    border-top: none;
  }
  div.focus_text, div.attention_text {
    padding: 1em 1.5em;
  }
  div.attention_text {
    border-width: 2px;
  }
  h3 {
    font-size: 1.5rem;
  }
  h3:after {
    width: 10px;
    height: 10px;
  }
  h4 {
    padding: 0 0 0.5em 1.5em;
  }
  h4:after {
    width: 12px;
    height: 12px;
  }
  h6 {
    font-size: 1.125rem;
  }
}

@media screen and (min-width: 740px) {
  .visible_sp {
    display: none !important;
  }
}

@media screen and (max-width: 739px) {
  .visible_pc {
    display: none !important;
  }
}

/* --------------------------------------------------
	 5. State
-------------------------------------------------- */
body {
  opacity: 0;
  -webkit-transition: opacity 1.5s;
  transition: opacity 1.5s;
}

body.loaded {
  opacity: 1;
}

body.loaded #primary .page_title .image {
  -webkit-transform: scale(1);
  transform: scale(1);
}

body.loaded #primary .page_title h2 strong::before {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

body.loaded #primary .page_title h2 strong span {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

body.loaded #primary .page_title h2 em {
  opacity: 1;
}

body.fadeout {
  opacity: 0;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}

/* --------------------------------------------------
	 6. Theme
-------------------------------------------------- */
a[href^="tel:"] {
  color: #000;
  text-decoration: none;
  pointer-events: none;
}

a[target="_blank"]::after {
  display: inline-block;
  vertical-align: middle;
  content: "";
  margin: -2px 0.2em 0;
  width: 12px;
  height: 12px;
  background: transparent url(image/icon_window.png) no-repeat center center;
  background-size: contain;
}

a[href^=".pdf"]::after {
  display: inline-block;
  vertical-align: middle;
  content: "";
  margin-left: .5em;
  width: 20px;
  height: 15px;
  background: transparent url(image/icon_pdf.png) no-repeat center center;
  background-size: contain;
}

.basic_btn {
  position: relative;
  display: inline-block;
  margin: 0 auto;
  min-width: 220px;
  line-height: 1.6;
  text-align: center;
  padding: 1.2em 4.9em 1.1em;
  color: #fff !important;
  background-color: #333333;
  font-size: 0.875rem;
  text-decoration: none !important;
}

.basic_btn[target="_blank"]::after {
  top: 50%;
  right: 2em;
  display: inline-block;
  vertical-align: middle;
  content: "";
  margin-left: .5em;
  margin-top: -7.5px;
  width: 20px;
  height: 15px;
  position: absolute;
  background: transparent url(image/icon_window_wh.png) no-repeat center center;
  background-size: contain;
}

.btn_map {
  display: inline-block;
  margin: 0 auto;
  padding: 0 0.5em;
  font-size: 0.875rem;
  color: #fff !important;
  background-color: #333333;
  text-decoration: none !important;
}

.btn_map[target="_blank"]::after {
  display: none;
}

.pagination {
  padding-top: 5.5em;
}

.pagination ul {
  text-align: center;
  font-size: 0;
}

.pagination li {
  display: inline-block;
  vertical-align: middle;
  font-size: 0.875rem;
}

.pagination li > a,
.pagination li > span {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 12px;
  font-weight: 500;
  padding: 10px 17.6px;
  text-align: center;
  line-height: 1.7;
  border: 1px solid #333333;
}

.pagination li > a {
  color: #333333;
  text-decoration: none;
  background-color: #fff;
}

.pagination li > a::after {
  display: none;
}

.pagination li > span {
  color: #fff;
  font-weight: bold;
  background-color: #333333;
}

.pagination li.list > a {
  color: #333333;
  padding: 15px 20px;
  min-width: 220px;
  font-weight: bold;
  position: relative;
  background: #fff url(image/icon_arrow_bl.png) no-repeat center left 1.5em;
  background-size: 25px auto;
}

.flow_nav {
  margin: 4.5em auto 5.5em;
}

.flow_nav .step_ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  max-width: 960px;
  margin: 0 auto;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

.flow_nav .step_ul::after {
  content: "";
  width: 100%;
  bottom: 32.5px;
  z-index: -1;
  position: absolute;
  border-top: 1px solid #333333;
}

.flow_nav .step_ul li {
  font-weight: bold;
  padding: 0 70px;
  font-size: 1.5rem;
}

.flow_nav .step_ul span {
  display: block;
}

.flow_nav .step_ul span.step {
  color: #333333;
  width: 65px;
  padding: 10px 5px;
  text-align: center;
  background-color: #fff;
  border: 4px solid #333333;
  font-size: 1.3125rem;
}

.essential {
  margin: 0 10px;
  position: relative;
  display: block;
  overflow: hidden;
  color: transparent;
  text-decoration: none;
  text-indent: 110%;
  white-space: nowrap;
  font-size: 0;
  width: 10px;
  height: 10px;
  background: transparent url(image/icon_essential.png) no-repeat center center;
  background-size: contain;
  display: inline-block;
}

.transmission {
  width: auto;
  text-align: center;
  margin: 125px auto 30px auto;
  display: table;
}

.transmission li {
  display: table-cell;
  padding: 2px 40px;
}

.transmission .btn_return input[type="submit"], .transmission .btn_return input[type="reset"], .transmission .btn_return input[type="button"] {
  color: #333333 !important;
  border: none;
  cursor: pointer;
  position: relative;
  border: 1px solid #333333;
  background: #fff url(image/icon_arrow_bl.png) no-repeat center left 1.5em;
  background-size: 25px auto;
}

.transmission input[type="submit"], .transmission input[type="reset"], .transmission input[type="button"] {
  min-width: 220px;
  text-align: center;
  padding: 11px 20px !important;
  font-weight: 500 !important;
  border-radius: 0 !important;
  color: #FFF !important;
  border: none;
  cursor: pointer;
  position: relative;
  background: #333333 url(image/icon_arrow_wh.png) no-repeat center right 1.5em;
  background-size: 25px auto;
}

.list_product {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.list_product li {
  width: calc(92% / 2);
  background: #fff;
  text-align: center;
  border-radius: 20px;
  position: relative;
  -webkit-box-shadow: 1px 1px 8px 2px rgba(0, 0, 0, 0.19);
  box-shadow: 1px 1px 8px 2px rgba(0, 0, 0, 0.19);
  margin: 0 2% 3em;
}

.list_product li:before {
  content: "";
  width: 56px;
  height: 56px;
  background: url("./image/border_01.png") no-repeat center center;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.list_product li:after {
  content: "";
  width: 56px;
  height: 56px;
  background: url("./image/border_02.png") no-repeat center center;
  background-size: cover;
  position: absolute;
  bottom: 0;
  right: 0;
}

.list_product li a {
  padding: 4em 1.5em;
  display: block;
  text-decoration: none;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}

.list_product li a:hover {
  opacity: 0.6;
}

.list_product li .image {
  width: 100%;
  min-height: 106px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.list_product li .image .img_size01 {
  max-width: 172px;
}

.list_product li .image .img_size {
  max-width: 111px;
}

.list_product li .image .img_size02 {
  max-width: 211px;
}

.list_product li .image img {
  width: 100%;
}

.list_product li .txt {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.35;
  margin-top: 1.75em;
  color: #3e3a39;
}

.flame01 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.flame01 .left {
  width: 60%;
}

.flame01 .right {
  width: 40%;
  padding-left: 3em;
}

.flame01 .right .right_box {
  position: relative;
  padding-top: 80%;
}

.flame01 .right .right_box:first-child {
  margin-bottom: 40px;
}

.flame01 .right img {
  position: absolute;
  width: 100%;
  max-width: 500px;
  top: 0;
  right: -6em;
}

.flame01_ttl {
  font-size: 1.5rem;
  font-weight: bold;
  color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  margin-bottom: 0.75em;
}

.flame01_txt {
  font-size: 1.125rem;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 1em;
  text-align: left;
  line-height: 1.8;
}

.list_service_flow {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 0 60px;
}

.list_service_flow li {
  width: 50%;
  margin-bottom: 4em;
  padding-bottom: 0.5em;
  position: relative;
}

.list_service_flow li:not(:nth-child(2n)) {
  padding-right: 1.75em;
}

.list_service_flow li:nth-child(2n) {
  padding-left: 3em;
}

.list_service_flow li:nth-child(2n) .image {
  right: 0;
}

.list_service_flow li:not(:first-child):before {
  content: "";
  width: 30px;
  height: 100%;
  background: url("./image/line01.png") no-repeat left top;
  background-size: 100% 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.list_service_flow li:nth-child(3n):before {
  left: -3em;
}

.list_service_flow li .number {
  font-size: 2.5rem;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  line-height: 1;
}

.list_service_flow li .ttl01 {
  font-size: 1.0625rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  color: #c51724;
  font-weight: bold;
  margin: 0.5em 0 1em;
}

.list_service_flow li .ttl02 {
  font-size: 0.9375rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
}

.list_service_flow li .txt {
  font-size: 0.9375rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

.list_service_flow li .image {
  position: absolute;
  top: 3em;
  right: 3em;
}

.list_info {
  max-width: 1000px;
  margin: 0 auto;
}

.list_info li {
  border-bottom: 1px solid #9e9f9f;
}

.list_info li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  text-decoration: none;
  padding: 1.5em 0.5em;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}

.list_info li a:hover {
  background-color: rgba(197, 23, 36, 0.1);
}

.list_info li a .txt {
  font-size: 0.9375rem;
  font-weight: 500;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  padding-left: 3em;
  width: calc(100% - 80px);
}

.list03 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.list03 li {
  width: 43%;
  margin-bottom: 8em;
}

.list03 li:not(:nth-child(2n)) {
  margin-right: 14%;
}

.list03 li .ttl {
  font-size: 1.1875rem;
  font-weight: bold;
  color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
}

.list03 li .ttl02 {
  font-size: 0.9375rem;
  font-weight: bold;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
  line-height: 1.4;
  margin-bottom: 0.5em;
}

.list03 li .image img {
  width: 100%;
}

.list_link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 1em;
}

.list_link a {
  display: inline-block;
  font-size: 0.8125rem;
  text-decoration: none;
  color: #231815;
  padding-right: 2.5em;
  position: relative;
  font-weight: bold;
}

.list_link a::before {
  content: "";
  display: block;
  width: 80%;
  height: 2px;
  bottom: 0;
  position: absolute;
  background-color: #595757;
  opacity: 0;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}

.list_link a:hover::before {
  bottom: -3px;
  opacity: 1;
}

.list_link .product_intro:after {
  content: "";
  width: 16px;
  height: 18px;
  background: url("./image/icon_link02.png") no-repeat center center;
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.list_link .site {
  color: #c51724;
}

.list_link .site::before {
  background-color: #c51724;
}

.list_link .site:after {
  content: "";
  width: 16px;
  height: 18px;
  background: url("./image/icon_link01.png") no-repeat center center;
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.ttl_date {
  font-size: 0.9375rem;
  font-weight: bold;
  color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.date {
  font-size: 0.9375rem;
  color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.flame02 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.flame02 .left {
  width: 46%;
  margin-right: 8%;
}

.flame02 .right {
  width: 46%;
}

.flame02_txt {
  font-size: 0.9375rem;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  margin-top: 1em;
  margin-bottom: 1em;
}

.flame02_txt02 {
  font-size: 0.75rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  margin-top: 0.75em;
  letter-spacing: 0.11em;
}

.flame02 .tel {
  margin: 1em 0 0 0em;
}

.flame02 .tel p {
  margin-top: 0.5em;
  text-align: right;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.flame02 .title {
  display: block;
  font-size: 0.9375rem;
  font-weight: bold;
  color: #231815;
  text-decoration: none;
  border: 1px solid #231815;
  text-align: center;
  padding: 1.25em 1.5em;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.circle01 {
  position: relative;
}

.circle01:before {
  content: "";
  width: 900px;
  height: 900px;
  max-width: 1100px;
  max-height: 1100px;
  background-color: #fef7f6;
  position: absolute;
  border-radius: 50%;
  z-index: -1;
}

.circle02 {
  position: relative;
}

.circle02:before {
  content: "";
  width: 950px;
  height: 950px;
  max-width: 1100px;
  max-height: 1100px;
  background-color: #fef7f6;
  border-radius: 50%;
  z-index: -1;
}

.btn01 a {
  display: block;
  font-size: 0.9375rem;
  font-weight: bold;
  color: #231815;
  text-decoration: none;
  border: 1px solid #231815;
  text-align: center;
  padding: 1.25em 1.5em;
}

.btn02 a {
  display: block;
  font-size: 1.4375rem;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background-color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
  padding: 0.95em;
  border-radius: 10px;
  letter-spacing: 0.3em;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  border: 1px solid #c51724;
}

.btn02 a:hover {
  color: #c51724;
  background-color: #fff;
  border: 1px solid #c51724;
}

.btn02.color02 a {
  background-color: #595757;
}

.btn03 a {
  display: block;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background-color: #c51724;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
  padding: 0.95em;
  border-radius: 10px;
  border: 1px solid #c51724;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}

.btn03 a:hover {
  background-color: #fff;
  color: #c51724;
  border: 1px solid #c51724;
}

.btn03.color02 a {
  border: 1px solid #595757;
  background-color: #595757;
}

.btn03.color02 a:hover {
  background-color: #fff;
  color: #595757;
  border: 1px solid #595757;
}

.google_map iframe {
  width: 100%;
  height: 300px;
}

p.asterisk {
  color: #231815;
  font-size: 0.75rem;
  font-weight: 500;
  text-indent: -1.0em;
  padding-left: 1em;
}

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

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

@-webkit-keyframes fadeup {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  40%, 100% {
    opacity: 1;
  }
}

@keyframes fadeup {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  40%, 100% {
    opacity: 1;
  }
}

@media all and (min-width: 740px) and (max-width: 1300px) {
  .flame01 .left {
    width: 50%;
  }
  .flame01 .right {
    width: 50%;
    padding-left: 2em;
  }
  .flame01 .right img {
    right: 0;
  }
}

@media all and (min-width: 740px) {
  .basic_btn, .btn_map {
    -webkit-transition: opacity .4s;
    transition: opacity .4s;
  }
  .basic_btn:hover, .btn_map:hover {
    opacity: 0.8;
  }
  .pagination a {
    -webkit-transition: color 0.4s, background-color 0.4s;
    transition: color 0.4s, background-color 0.4s;
  }
  .pagination a:hover {
    color: #fff;
    background-color: #333333;
  }
  .pagination li.list a {
    -webkit-transition: opacity .4s;
    transition: opacity .4s;
  }
  .pagination li.list a:hover {
    opacity: 0.8;
  }
}

@media all and (min-width: 740px) and (max-width: 959px) {
  .flame01 .right {
    padding-left: 1em;
  }
  .list_product li {
    padding: 4em 0;
  }
  .list_product li .txt {
    font-size: 1rem;
  }
  .list_service_flow {
    padding: 0;
  }
  .list_service_flow li .ttl01 {
    font-size: 0.875rem;
  }
  .list_service_flow li .ttl02 {
    font-size: 0.75rem;
  }
  .list_service_flow li .txt {
    font-size: 0.75rem;
  }
  .list_service_flow li .image {
    top: 2em;
  }
  .btn02 a {
    font-size: 0.875rem;
  }
}

@media only screen and (max-width: 739px) {
  a[href^="tel:"] {
    color: #000;
    text-decoration: underline;
    pointer-events: auto;
  }
  .basic_btn {
    min-width: 220px;
    padding: 1.1em 1em 1.1em;
  }
  .pagination {
    margin-left: -20px;
    margin-right: -20px;
    padding-top: 4em;
  }
  .pagination li {
    margin: 3px;
  }
  .pagination li a, .pagination li span {
    margin: 0;
  }
  .flow_nav .step_ul {
    padding: 0 15px;
  }
  .flow_nav .step_ul::after {
    width: 100%;
    bottom: 25px;
    left: 0px;
  }
  .flow_nav .step_ul li {
    padding: 0 10px;
    font-size: 1rem;
  }
  .flow_nav .step_ul span.step {
    font-size: 0.9375rem;
    width: 50px;
    padding: 9.5px 5px;
  }
  .transmission {
    width: auto;
    text-align: center;
    margin: 100px auto 30px auto;
    display: table;
  }
  .transmission li {
    display: block;
    padding: 2px 10px 15px;
  }
  .list_product {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 320px;
    margin: 0 auto;
  }
  .list_product li {
    width: 100%;
    padding: 0;
    border-radius: 20px;
  }
  .list_product li a {
    padding: 2em 1.5em;
  }
  .list_product li:before {
    width: 33px;
    height: 33px;
  }
  .list_product li:after {
    width: 33px;
    height: 33px;
  }
  .list_product li:not(:nth-child(2n)) {
    margin: 0 0 2em;
  }
  .list_product li .image {
    min-height: 50px;
  }
  .list_product li .image img {
    max-width: 90px;
  }
  .list_product li .image .img_size01 {
    max-width: 71px;
  }
  .list_product li .image .img_size02 {
    max-width: 105px;
  }
  .list_product li .image .img_size {
    max-width: 65px;
  }
  .list_product li .txt {
    font-size: 1.25rem;
    margin-top: 1em;
  }
  .list_product li .txt span {
    font-size: 1.125rem;
  }
  .list_service_flow {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0;
  }
  .list_service_flow li {
    width: 100%;
    margin-bottom: 0;
    padding: 3em 0 1.5em;
  }
  .list_service_flow li:not(:nth-child(2n)) {
    padding-right: 0;
  }
  .list_service_flow li:nth-child(2n) {
    padding-left: 0;
  }
  .list_service_flow li:nth-child(2n) .image {
    right: 0;
  }
  .list_service_flow li:not(:first-child):before {
    width: 100%;
    height: 25px;
    background: url("./image/line02.png") no-repeat left top;
    background-size: 100% 100%;
  }
  .list_service_flow li:nth-child(3n):before {
    left: 0;
  }
  .list_service_flow li .number {
    font-size: 2.375rem;
  }
  .list_service_flow li .ttl01 {
    font-size: 1rem;
    margin: 0.5em 0;
    width: calc(100% - 70px);
  }
  .list_service_flow li .ttl02 {
    font-size: 1rem;
  }
  .list_service_flow li .txt {
    font-size: 1rem;
  }
  .list_service_flow li .image {
    position: absolute;
    top: 3em;
    right: 0;
  }
  .list_service_flow li .image img {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }
  .flame01 {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .flame01 .left {
    width: 100%;
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
    -ms-flex-order: 2;
    order: 2;
  }
  .flame01 .right {
    width: 100%;
    padding-left: 0;
  }
  .flame01 .right .right_box {
    padding-top: 0;
  }
  .flame01 .right .right_box:first-child {
    margin-bottom: 20px;
  }
  .flame01 .right img {
    position: inherit;
    max-width: 100%;
    right: 0;
  }
  .flame01_ttl {
    font-size: 1.25rem;
    margin: 1em 0 0.5em;
    text-align: center;
  }
  .flame01_txt {
    font-size: 1rem;
  }
  .flame01_txt.text_center {
    text-align: center;
  }
  .list_info li {
    border-bottom: 1px solid #9e9f9f;
  }
  .list_info li a {
    display: block;
    padding: 1em 0;
  }
  .list_info li a .txt {
    font-size: 1rem;
    padding-left: 0;
    width: 100%;
  }
  .flame02 {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .flame02 .left {
    width: 100%;
    margin: 0 0 3em;
  }
  .flame02 .right {
    width: 100%;
  }
  .flame02_txt {
    font-size: 0.875rem;
  }
  .flame02_txt02 {
    font-size: 0.75rem;
    margin-top: 0.75em;
  }
  .flame02 .btn02 {
    margin-top: 0.5em;
  }
  .flame02 .tel {
    text-align: center;
    margin: 1em 0 0 0;
  }
  .flame02 .tel p {
    margin-top: 0.5em;
    text-align: center;
    font-weight: bold;
    font-size: 0.9375rem;
  }
  .btn01 a {
    font-size: 0.875rem;
    padding: 1em;
  }
  .btn02 a {
    font-size: 0.875rem;
    border-radius: 5px;
  }
  .google_map iframe {
    height: 200px;
  }
  .list03 {
    max-width: 300px;
    margin: 0 auto;
  }
  .list03 li {
    width: 100%;
    margin-bottom: 3em;
  }
  .list03 li:not(:nth-child(2n)) {
    margin-right: 0;
  }
  .list03 li .ttl02 {
    font-size: 1rem;
  }
  .list_link a {
    font-size: 0.9375rem;
  }
  .circle01 {
    position: relative;
  }
  .circle01:before {
    width: 300px;
    height: 300px;
  }
  .circle02 {
    position: relative;
  }
  .circle02:before {
    width: 300px;
    height: 300px;
  }
}

/* --------------------------------------------------
	 7. Slick
-------------------------------------------------- */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track::before, .slick-track::after {
  content: "";
  display: table;
}

.slick-track::after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

[dir="rtl"] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

.slick-dotted.slick-slider {
  margin-bottom: 10px;
}

.slick-prev,
.slick-next {
  display: block;
  overflow: hidden;
  color: transparent;
  text-decoration: none;
  text-indent: 110%;
  white-space: nowrap;
  font-size: 0;
  width: 60px;
  height: 60px;
  position: absolute;
  top: 32%;
  padding: 0;
  line-height: 0;
  border: none;
  outline: none;
  background-color: transparent;
  border-radius: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  z-index: 1;
  opacity: .8;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}

.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: .25;
}

.slick-prev::before,
.slick-next::before {
  position: absolute;
  top: 20px;
  display: block;
  content: "";
  width: 20px;
  height: 20px;
  opacity: .75;
}

.slick-prev {
  left: 30px;
}

.slick-prev::before {
  left: 20px;
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.slick-next {
  right: 30px;
}

.slick-next::before {
  left: 15px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.slick-dots {
  position: absolute;
  left: inherit;
  right: 50%;
  -webkit-transform: translateX(50%);
  transform: translateX(50%);
  bottom: 20px;
  list-style: none;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  padding: 0;
  z-index: 3;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  height: 15px;
  width: 15px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  width: 15px;
  height: 15px;
  outline: none;
  line-height: 0;
  font-size: 0;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}

.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover::before, .slick-dots li button:focus::before {
  background-color: #000;
}

.slick-dots li button::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #afafaf;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button::before {
  background-color: #000;
}

@media only screen and (max-width: 739px) {
  .slick-prev,
  .slick-next {
    display: block;
    overflow: hidden;
    color: transparent;
    text-decoration: none;
    text-indent: 110%;
    white-space: nowrap;
    font-size: 0;
    width: 55px;
    height: 50px;
    top: 30%;
  }
  .slick-prev::before,
  .slick-next::before {
    position: absolute;
    top: 10px;
    display: block;
    content: "";
    width: 31px;
    height: 31px;
    opacity: .75;
  }
  .slick-prev {
    left: 7px;
  }
  .slick-prev::before {
    left: 20px;
  }
  .slick-next {
    right: 12px;
  }
  .slick-next::before {
    left: 10px;
  }
  .slick-dots {
    bottom: -40px;
  }
  .slick-dots li {
    height: 10px;
    width: 10px;
  }
  .slick-dots li:not(:last-child) {
    margin-right: 15px !important;
  }
  .slick-dots li button {
    width: 10px;
    height: 10px;
  }
  .slick-dots li button:before {
    width: 10px;
    height: 10px;
  }
}

/* --------------------------------------------------
	 8. Header
-------------------------------------------------- */
#header {
  margin: auto;
  position: absolute;
  top: -100px;
  margin-top: 100px;
  background-color: #c51724;
  width: 100%;
  z-index: 9999;
  -webkit-transition: top 0.6s;
  transition: top 0.6s;
}

#header .inner {
  height: 100%;
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 120px 0 50px;
}

#header .box_header {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

#header .global_menu .nav {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-top: 2em;
}

#header .global_menu .nav li {
  position: relative;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  position: relative;
}

#header .global_menu .nav li::before {
  position: absolute;
  bottom: 2px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  content: '';
  width: 40px;
  height: 3px;
  background: #fff;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: .3s;
  transition: .3s;
}

#header .global_menu .nav li:hover::before {
  bottom: -8px;
  opacity: 1;
  visibility: visible;
}

#header .global_menu .nav li:not(:last-child):after {
  content: "";
  width: 1px;
  height: 100%;
  background: #fff;
  position: absolute;
  right: 0;
  -webkit-transform: rotate(35deg);
  transform: rotate(35deg);
  top: 0;
}

#header .global_menu .nav a {
  display: block;
  text-decoration: none;
  text-align: center;
  font-size: 0.9375rem;
  font-weight: bold;
  color: #fff;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  padding: 0 1.5em;
  line-height: 1;
}

#header .list_btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  top: 0;
  right: 140px;
}

#header .list_btn .reservation a {
  display: block;
  color: #fff;
  text-decoration: none;
  background: #000;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  padding: 0.35em 2em;
  font-weight: bold;
  border-radius: 0 0 10px 10px;
  text-align: center;
}

#header .list_btn .reservation a:hover {
  opacity: 0.7;
}

#header .list_btn .reservation a::after {
  display: none !important;
}

#header .btn_menu {
  position: fixed;
  top: 0;
  right: 1em;
  cursor: pointer;
  width: 34px;
  height: 54px;
}

#header .btn_menu span {
  display: block;
  position: absolute;
  background: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-transform: translateX(50%);
  transform: translateX(50%);
  right: 50%;
}

#header .btn_menu span:nth-child(1) {
  width: 25px;
  height: 1px;
  top: 15px;
}

#header .btn_menu span:nth-child(2) {
  width: 25px;
  height: 1px;
  top: 25px;
}

#header .btn_menu span:nth-child(3) {
  width: 25px;
  height: 1px;
  top: 35px;
}

#header .btn_menu.active span {
  width: 25px;
}

#header .btn_menu.active span:nth-child(1) {
  -webkit-transform: translate(50%, 10px) rotate(45deg);
  transform: translate(50%, 10px) rotate(45deg);
}

#header .btn_menu.active span:nth-child(2) {
  opacity: 0;
}

#header .btn_menu.active span:nth-child(3) {
  -webkit-transform: translate(50%, -10px) rotate(-45deg);
  transform: translate(50%, -10px) rotate(-45deg);
}

#header.fixed {
  position: fixed;
  top: 0;
  margin-top: 0;
  -webkit-box-shadow: 0 0 15px 5px rgba(153, 153, 153, 0.5);
  box-shadow: 0 0 15px 5px rgba(153, 153, 153, 0.5);
}

#header.fixed .box_header {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
}

#header.fixed .global_menu {
  height: auto;
}

#header.fixed .global_menu .nav li {
  padding: 0;
}

@media all and (max-width: 1030px) and (min-width: 960px) {
  #header .global_menu .nav a {
    font-size: 0.9375rem;
    padding: 0 1em;
  }
}

@media all and (max-width: 959px) and (min-width: 864px) {
  #header .global_menu .nav a {
    font-size: 0.9375rem;
    padding: 0 1em;
  }
}

@media all and (max-width: 863px) and (min-width: 794px) {
  #header .global_menu .nav a {
    font-size: 0.8125rem;
    padding: 0 1em;
  }
}

@media all and (max-width: 793px) and (min-width: 739px) {
  #header .global_menu .nav a {
    font-size: 0.78125rem;
    padding: 0 0.5em;
  }
}

@media all and (min-width: 740px) and (max-width: 959px) {
  #header .inner {
    padding: 0 50px 0 30px;
  }
  #header .list_btn {
    right: 55px;
  }
}

@media only screen and (max-width: 739px) {
  #header {
    top: 0;
    margin: auto;
    position: fixed;
  }
  #header .box_header {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    display: block;
  }
  #header .inner {
    padding: 0 !important;
  }
  #header .logo {
    padding-left: 25px;
  }
  #header .logo img {
    max-width: 120px;
  }
  #header .global_menu {
    display: block;
    padding: 2em 0 4em;
    position: absolute;
    top: 61px;
    left: 0;
    width: 100%;
    background: #c51724;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: 0.3s all;
    transition: 0.3s all;
  }
  #header .global_menu.active {
    visibility: visible;
    opacity: 1;
  }
  #header .global_menu .nav {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 0;
  }
  #header .global_menu .nav li {
    width: 100%;
    position: relative;
  }
  #header .global_menu .nav li:hover::before {
    bottom: 2px;
    opacity: 1;
    visibility: visible;
  }
  #header .global_menu .nav li:not(:last-child):after {
    display: none;
  }
  #header .global_menu .nav a {
    padding: 1.5em 0;
    font-size: 1rem;
  }
  #header .list_btn {
    display: block;
    position: static;
    top: 0;
    right: 0;
    max-width: 200px;
    margin: 2em auto 0;
  }
  #header .list_btn .reservation a {
    border-radius: 0;
    text-align: center;
  }
  #header .list_btn .reservation a::after {
    display: none;
  }
  #header.fixed {
    position: fixed;
    top: 0;
    margin-top: 0;
    -webkit-box-shadow: 0 0 15px 5px rgba(153, 153, 153, 0.5);
    box-shadow: 0 0 15px 5px rgba(153, 153, 153, 0.5);
  }
  #header.fixed .box_header {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
  }
  #header.fixed .global_menu {
    height: auto;
  }
  #header.fixed .global_menu .nav li {
    padding: 0;
  }
}

/* --------------------------------------------------
	 9. Footer
-------------------------------------------------- */
#footer {
  background: #eee;
  text-align: center;
  padding: 2.5em 0 2em;
}

#footer p {
  font-size: 0.9375rem;
}

#footer .logo_fb {
  margin-bottom: 1.5em;
}

#footer .logo_fb a {
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}

#footer .logo_fb a::after {
  display: none;
}

#footer .logo_fb a:hover {
  opacity: 0.7;
}

@media only screen and (max-width: 739px) {
  #footer {
    background: #eee;
    text-align: center;
    padding: 1.5em 0;
  }
  #footer .logo_fb {
    margin-bottom: 0.75em;
  }
  #footer .logo_fb img {
    max-width: 30px;
  }
  #footer p {
    font-size: 0.625rem;
  }
}

/* --------------------------------------------------
	10. Index
-------------------------------------------------- */
body.index #primary {
  margin-top: 129px;
}

body.index #primary .main_img {
  position: relative;
  height: 45vw;
  min-height: 440px;
  background: url(./image/main_slide01.png) no-repeat center center;
  background-size: cover;
}

body.index #primary .main_img .inner {
  position: absolute;
  z-index: 111;
  top: 45%;
  left: 7%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

body.index #primary .main_img .inner .main_txt {
  max-width: 470px;
  max-height: 150px;
}

body.index #primary .main_img .inner .main_txt span {
  font-size: 1.75rem;
  font-weight: bold;
}

article.index .txt01 {
  font-size: 0.9375rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
}

article.index .sec_top01 {
  padding-top: 4.25em !important;
  position: relative;
  margin-top: 3em;
}

article.index .sec_top01:after {
  content: "";
  width: calc(100% - 50px);
  height: 100%;
  background-color: #fbe2df;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
}

article.index .sec_top01 .list_product {
  margin-top: 4.5em;
}

article.index .sec_top01 .flame01 {
  margin-top: 3em;
}

article.index .sec_top01 .top_box01:not(:last-of-type) {
  margin-bottom: 6em;
}

article.index .sec_top01 .inner04 {
  padding-bottom: 4rem;
}

article.index .sec_top01 .flame01_ttl {
  opacity: 0;
}

article.index .sec_top01 .flame01_ttl.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top01 .flame01_txt {
  opacity: 0;
}

article.index .sec_top01 .flame01_txt.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top01 .list_product {
  opacity: 0;
}

article.index .sec_top01 .list_product.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top02 {
  padding-top: 10em !important;
}

article.index .sec_top02 .circle01:before {
  top: -5em;
  left: -5em;
}

article.index .sec_top02 h3 {
  margin-bottom: 2.75em;
}

article.index .sec_top02 h6 {
  margin-bottom: 1.75em;
}

article.index .sec_top02 h3 {
  opacity: 0;
}

article.index .sec_top02 h3.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top02 h6 {
  opacity: 0;
}

article.index .sec_top02 h6.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top02 .list_service_flow {
  opacity: 0;
}

article.index .sec_top02 .list_service_flow.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top03 {
  padding-top: 2em !important;
}

article.index .sec_top03 h3 {
  margin-bottom: 2em;
}

article.index .sec_top03 h3 {
  opacity: 0;
}

article.index .sec_top03 h3.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top03 .list_info {
  opacity: 0;
}

article.index .sec_top03 .list_info.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top04 {
  padding-top: 3em !important;
  position: relative;
}

article.index .sec_top04 .circle02:before {
  position: absolute;
  top: -2em;
  right: -16em;
}

article.index .sec_top04 h3 {
  margin-bottom: 3em;
}

article.index .sec_top04 h3 {
  opacity: 0;
}

article.index .sec_top04 h3.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top04 .flame02 {
  opacity: 0;
}

article.index .sec_top04 .flame02.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top04 .flame02 .asterisk {
  font-size: 1rem;
}

article.index .sec_top04 .btn03 a::after {
  display: none;
}

article.index .sec_top05 {
  padding: 4em 0 0 !important;
}

article.index .sec_top05 h3 {
  margin-bottom: 2.5em;
}

article.index .sec_top05 h3 {
  opacity: 0;
}

article.index .sec_top05 h3.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top05 .txt01 {
  opacity: 0;
}

article.index .sec_top05 .txt01.is_show {
  -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
}

article.index .sec_top06 {
  padding: 3em  0 5em !important;
}

@media all and (min-width: 740px) and (max-width: 1300px) {
  article.index .sec_top01:after {
    width: 100%;
    border-radius: 0;
  }
}

@media all and (min-width: 740px) {
  body.index #content {
    margin-bottom: 0;
  }
  article.index .sec_top01 h3 {
    opacity: 0;
  }
  article.index .sec_top01 h3.is_show {
    -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
    animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  }
  article.index .sec_top01 .right {
    opacity: 0;
  }
  article.index .sec_top01 .right.is_show {
    -webkit-animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
    animation: fadeup 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s forwards;
  }
}

@media only screen and (max-width: 739px) {
  body.index #primary {
    margin-top: 61px;
  }
  body.index #primary .main_img {
    min-height: 250px;
    background-color: #fbe2df;
  }
  body.index #primary .main_img .inner {
    top: 48%;
    left: 10px;
  }
  body.index #primary .main_img .inner .main_txt {
    max-width: 280px;
  }
  article.index .txt01 {
    font-size: 0.875rem;
  }
  article.index .sec_top01 {
    margin-top: 0;
  }
  article.index .sec_top01:after {
    width: 100%;
    border-radius: 0;
  }
  article.index .sec_top01 .list_product {
    margin-top: 2.5em;
  }
  article.index .sec_top01 .flame01 {
    margin-top: 2em;
  }
  article.index .sec_top01 .top_box01:not(:last-of-type) {
    margin-bottom: 3em;
  }
  article.index .sec_top02 {
    padding-bottom: 2em !important;
  }
  article.index .sec_top02 .inner {
    max-width: 500px;
  }
  article.index .sec_top02 .circle01:before {
    left: -2em;
  }
  article.index .sec_top02 .circle02:before {
    position: absolute;
    bottom: 6em;
    right: -4em;
  }
  article.index .sec_top02 h3 {
    margin-bottom: 1.5em;
  }
  article.index .sec_top02 h6 {
    font-size: 1.03125rem;
    margin-bottom: 1em;
  }
  article.index .sec_top03 {
    padding-top: 0 !important;
  }
  article.index .sec_top03 h3 {
    margin-bottom: 1em;
  }
  article.index .sec_top03 .circle01:before {
    left: -2em;
  }
  article.index .sec_top04 {
    padding: 1em 0 0 !important;
    position: relative;
  }
  article.index .sec_top04 .circle02:before {
    position: absolute;
    top: 8em;
    right: -4em;
  }
  article.index .sec_top04 h3 {
    margin-bottom: 2em;
  }
  article.index .sec_top04 .flame02 .title {
    font-size: 1rem;
  }
  article.index .sec_top04 .flame02_txt {
    font-size: 1rem;
  }
  article.index .sec_top04 .flame02 .asterisk {
    font-size: 1rem;
  }
  article.index .sec_top04 .btn03 a {
    font-size: 0.96875rem;
  }
  article.index .sec_top05 {
    padding-bottom: 0 !important;
    position: relative;
  }
  article.index .sec_top05 h3 {
    margin-bottom: 1em;
  }
  article.index .sec_top05 .circle01:before {
    top: -8em;
    left: -2em;
  }
  article.index .sec_top05 .txt01 {
    font-size: 1rem !important;
  }
  article.index .sec_top06 {
    padding-top: 2em !important;
  }
}

/* --------------------------------------------------
	11. product
-------------------------------------------------- */
body.product #primary {
  margin-top: 128px;
}

body.product_electronic #primary .page_title {
  background-image: url("./images/product/page_title_electronic.png");
}

body.product_reception #primary .page_title {
  background-image: url("./images/product/page_title_reception.png");
}

body.product_management #primary .page_title {
  background-image: url("./images/product/page_title_management.png");
}

body.product_ultrasounddevice #primary .page_title {
  background-image: url("./images/product/page_title_ultrasounddevice.png");
}

article.product .btn03 a::after {
  display: none;
}

article.product .txt_electronic, article.product .txt_ultrasounddevice {
  font-size: 1rem;
  color: #231815;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
}

article.product .ttl01 {
  font-size: 1.3125rem;
  color: #231815;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: center;
}

article.product .list_btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  max-width: 840px;
  margin: 0 auto;
}

article.product .list_btn .btn03 {
  width: 47%;
}

article.product .list_btn .btn03:not(:nth-child(2n)) {
  margin-right: 6%;
}

article.product .basic_table .w50 {
  width: 50%;
}

article.product .basic_table .w40 {
  width: 40%;
}

article.product .basic_table .w30 {
  width: 30%;
}

article.product .basic_table .w25 {
  width: 25%;
}

article.product .basic_table .w20 {
  width: 20%;
}

article.product .basic_table .text_center {
  text-align: center;
}

article.product .basic_table thead th {
  background-color: #f9e7e9;
  border-right: none;
}

article.product .basic_table tbody tr td {
  background: #fff;
}

article.product .basic_table tbody tr:nth-child(odd) td {
  background: #fef7f6;
}

article.product .basic_table tbody tr td:nth-child(1) {
  padding-left: 3em;
}

article.product .basic_table th, article.product .basic_table td {
  padding: 1.5em 1em;
  font-size: 0.875rem;
  border: none;
  font-weight: 500;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  color: #231815;
  text-align: left;
}

article.product .sec_electronic01 {
  background: #fef7f6;
}

article.product .sec_electronic01 .txt_electronic {
  margin-bottom: 2.5em;
}

article.product .sec_electronic01 .list_btn {
  margin-bottom: 4.5em;
}

article.product .sec_electronic02 {
  padding-top: 6em !important;
  position: relative;
}

article.product .sec_electronic02 .circle01:before {
  top: 5rem;
  left: -10em;
}

article.product .sec_electronic02 .circle02:before {
  position: absolute;
  bottom: 60em;
  right: -20em;
}

article.product .sec_electronic02 h3 {
  margin-bottom: 3em;
}

article.product .sec_electronic03 {
  padding: 2em 0 8em !important;
  position: relative;
}

article.product .sec_electronic03 .circle01:before {
  top: -60em;
  left: -10em;
}

article.product .sec_electronic03 .circle02:before {
  position: absolute;
  bottom: -10em;
  right: -20em;
}

article.product .sec_electronic03 h3 {
  margin-bottom: 3em;
}

article.product .sec_electronic03 .list_btn {
  margin-top: 4em;
}

article.product_reception .list03 li {
  margin: 0 auto;
}

article.product_reception h3 {
  margin-bottom: 2em;
}

article.product_reception .reception_box01 h4 {
  font-size: 1.1875rem;
  color: #231815;
  text-align: center;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  margin-bottom: 1.5em;
  border: none;
  padding: 0;
}

article.product_reception .reception_box01 h4::after {
  display: none;
}

article.product_reception .reception_box01:not(:last-of-type) {
  margin-bottom: 8em;
}

article.product_reception .sec_reception01 {
  background-color: #fef7f6;
}

article.product_reception .sec_reception01 .list_btn {
  margin-top: 5em;
}

article.product_reception .sec_reception02 {
  position: relative;
}

article.product_reception .sec_reception02 .circle01:before {
  top: 5rem;
  left: -10em;
}

article.product_reception .sec_reception02 .circle02:before {
  position: absolute;
  bottom: -50em;
  right: -20em;
}

article.product_reception .sec_reception03 {
  padding-top: 7em !important;
}

article.product_reception .sec_reception04 {
  padding-top: 7em !important;
  position: relative;
}

article.product_reception .sec_reception04 .circle01:before {
  bottom: -10em;
  left: -10em;
}

article.product_reception .sec_reception04 .circle02:before {
  position: absolute;
  bottom: 20em;
  right: -20em;
}

article.product_management .sec_management01 {
  padding: 8em 0 4em !important;
  position: relative;
}

article.product_management .circle01:before {
  top: 0em;
  left: -10em;
}

article.product_management .circle02:before {
  position: absolute;
  bottom: -25em;
  right: -20em;
}

article.product_management .list03 .list_link a {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-size: 1.125rem;
  margin-left: 0.5em;
}

article.product_management .list03 .list_link a::after {
  background-position: center center;
  right: 1em;
}

article.product_ultrasounddevice .sec_ultrasounddevice01 {
  background: #fef7f6;
}

article.product_ultrasounddevice .sec_ultrasounddevice01 .txt_ultrasounddevice {
  margin-bottom: 2.5em;
}

article.product_ultrasounddevice .sec_ultrasounddevice01 .list_btn {
  margin-bottom: 4.5em;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

article.product_ultrasounddevice .sec_ultrasounddevice01 .list_btn .btn03:not(:nth-child(2n)) {
  margin-right: 0;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 {
  padding-top: 6em !important;
  position: relative;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 .list_btn {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 .list_btn .btn03:not(:nth-child(2n)) {
  margin-right: 0;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 .circle01:before {
  top: 5rem;
  left: -10em;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 .circle02:before {
  position: absolute;
  bottom: 60em;
  right: -20em;
}

article.product_ultrasounddevice .sec_ultrasounddevice02 h3 {
  margin-bottom: 3em;
}

@media all and (min-width: 740px), print {
  .product_reception .sec_reception05 {
    padding-top: 7em !important;
    position: relative;
  }
  .product_reception .sec_reception05 .circle01:before {
    bottom: -40em;
    left: -10em;
  }
}

@media only screen and (max-width: 739px) {
  body.product #primary {
    margin-top: 61px;
  }
  article.product .txt_electronic {
    font-size: 1rem;
  }
  article.product .ttl01 {
    font-size: 1.125rem;
  }
  article.product .list_btn {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  article.product .list_btn .btn03 {
    width: 100%;
  }
  article.product .list_btn .btn03:not(:nth-child(2n)) {
    margin: 0 0 1em;
  }
  article.product .table_frame01 {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  article.product .table_frame01::-webkit-scrollbar {
    height: 10px;
  }
  article.product .table_frame01::-webkit-scrollbar-thumb {
    background-color: #ffe4e7;
  }
  article.product .table_frame01 table {
    margin-bottom: 0 !important;
    width: 100%;
  }
  article.product .table_frame01 th,
  article.product .table_frame01 td {
    white-space: nowrap;
    display: table-cell;
    width: auto;
    padding: 1em 0.5em;
    border: 1px solid #d0d0d0;
  }
  article.product .basic_table {
    border: 1px solid #d0d0d0;
  }
  article.product .basic_table .w50 {
    width: 50%;
  }
  article.product .basic_table .w30 {
    width: 30%;
  }
  article.product .basic_table .w25 {
    width: 25%;
  }
  article.product .basic_table .w20 {
    width: 20%;
  }
  article.product .basic_table .text_center {
    text-align: center;
  }
  article.product .basic_table thead th {
    background-color: #f9e7e9;
    border-right: none;
  }
  article.product .basic_table tbody tr td {
    background: #fff;
  }
  article.product .basic_table tbody tr:nth-child(odd) td {
    background: #fef7f6;
  }
  article.product .basic_table tbody tr td:nth-child(1) {
    padding-left: 3em;
  }
  article.product .basic_table th, article.product .basic_table td {
    padding: 1em;
    font-size: 1rem;
    border: none;
    font-weight: 500;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    color: #231815;
    text-align: left;
  }
  article.product .sec_electronic01 {
    background: #fef7f6;
  }
  article.product .sec_electronic01 .txt_electronic {
    margin-bottom: 2em;
  }
  article.product .sec_electronic01 .list_btn {
    margin-bottom: 3em;
  }
  article.product .sec_electronic02 h3 {
    margin-bottom: 2em;
  }
  article.product .sec_electronic02 .circle01:before {
    left: -2em;
  }
  article.product .sec_electronic02 .circle02:before {
    bottom: 120em;
    right: -4em;
  }
  article.product .sec_electronic03 {
    padding: 2em 0 5em !important;
  }
  article.product .sec_electronic03 h3 {
    margin-bottom: 2em;
  }
  article.product .sec_electronic03 .circle01:before {
    left: -2em;
  }
  article.product .sec_electronic03 .circle02:before {
    bottom: -10em;
    right: -4em;
  }
  article.product_reception .reception_box01 h5 {
    margin-bottom: 1em;
  }
  article.product_reception .reception_box01:not(:last-of-type) {
    margin-bottom: 4em;
  }
  article.product_reception .sec_reception01 .list_btn {
    margin-top: 3em;
  }
  article.product_reception .sec_reception02 {
    position: relative;
  }
  article.product_reception .sec_reception02 .circle01:before {
    left: -2em;
  }
  article.product_reception .sec_reception02 .circle02:before {
    bottom: -10em;
    right: -4em;
  }
  article.product_reception .sec_reception04 .circle01:before {
    left: -2em;
  }
  article.product_reception .sec_reception04 .circle02:before {
    bottom: -10em;
    right: -4em;
  }
  article.product_reception .sec_reception05 {
    display: none;
  }
  article.product_management .sec_management01 .circle01:before {
    left: -2em;
  }
  article.product_management .sec_management01 .circle02:before {
    position: absolute;
    bottom: -10em;
    right: -4em;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice01 {
    background: #fef7f6;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice01 .txt_ultrasounddevice {
    margin-bottom: 2em;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice01 .list_btn {
    margin-bottom: 3em;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice02 h3 {
    margin-bottom: 2em;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice02 .circle01:before {
    left: -2em;
  }
  article.product_ultrasounddevice .sec_ultrasounddevice02 .circle02:before {
    bottom: 120em;
    right: -4em;
  }
}

/* --------------------------------------------------
	12. reservation
-------------------------------------------------- */
body.reservation #primary {
  margin-top: 129px;
}

body.reservation #primary .page_title {
  background-image: url("./images/reservation/page_title.png");
}

article.reservation_thanks p {
  text-align: center;
}

article.reservation_confirm .form_box_check {
  margin-top: 2em;
  margin-bottom: 2em;
}

article.reservation_confirm .form_box_check .ttl_reservation {
  margin-bottom: 1em;
}

article.reservation_confirm .form_box_check ul {
  padding-left: 2em;
}

article.reservation_confirm .form_box_check ul li {
  padding-left: -1em;
  list-style: disc;
}

article.reservation_confirm .form_box_check p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.reservation_confirm .form_box p {
  word-break: break-all;
}

article.reservation_confirm .form_box .form_box_input .border {
  border: 1px solid #231815;
  padding: 0.5em 1em;
  background-color: #fff;
  display: block;
}

article.reservation_confirm .btn02 .return {
  background-color: #595757;
  border: 1px solid #595757;
  margin-bottom: 1.5em;
}

article.reservation_confirm .btn02 .return:hover {
  background-color: #fff;
  color: #595757;
  border-color: #595757;
}

article.reservation .form_box {
  max-width: 460px;
  margin: 2em auto;
}

article.reservation .form_box .form_box_input:not(:last-of-type) {
  margin-bottom: 1em;
}

article.reservation .form_box .form_box_input p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.reservation .form_box .form_box_input .asterisk {
  color: #231815;
  font-size: 0.8125rem;
  font-weight: 500;
  text-indent: -1.0em;
  padding-left: 1em;
}

article.reservation .form_box .form_box_input input {
  width: 100%;
  height: 36px;
  border: 1px solid #231815;
}

article.reservation .form_box .form_box_input textarea {
  width: 100%;
  resize: none;
  border-radius: 0;
  margin: 0;
  border-radius: 0 !important;
}

article.reservation .form_box .form_box_input .textarea01 {
  height: 92px;
  margin-bottom: 0;
}

article.reservation .form_box .error input, article.reservation .form_box .error select, article.reservation .form_box .error .textarea01 {
  border: 1px solid #ff5757;
  background-color: #ffdddd;
}

article.reservation .form_box .error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

article.reservation .box {
  margin-bottom: 2em;
}

article.reservation .box.error {
  padding: 1em;
  background-color: #ffdddd;
}

article.reservation .box.error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

article.reservation .ttl_reservation {
  font-size: 1.125rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  border: 1px solid #231815;
  padding: 0.75em 1em 0.5em;
}

article.reservation .ttl_reservation span.small {
  font-size: 0.8125rem;
  font-weight: 400;
}

article.reservation .ttl_reservation span {
  font-size: 0.9375rem;
}

article.reservation .box_checkbox {
  text-indent: -1.25em;
  padding-left: 1.25em;
}

article.reservation input[type="text"], article.reservation textarea {
  width: 100%;
}

article.reservation .reservation_check {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

article.reservation .list_checkbox li {
  padding: 0.5em 0 0;
}

article.reservation .list_checkbox li:first-child {
  margin-top: 0.5em;
}

article.reservation .btn02 {
  max-width: 460px;
  margin: 4em auto;
}

article.reservation .sec_reservation01 {
  position: relative;
}

article.reservation .sec_reservation01 .circle01:before {
  top: 0;
  left: -10em;
}

article.reservation .sec_reservation01 .circle02:before {
  position: absolute;
  bottom: -32em;
  right: -20em;
}

@media all and (min-width: 740px), print {
  .sec_reservation01 .circle02 {
    display: none;
  }
}

@media only screen and (max-width: 739px) {
  body.reservation #primary {
    margin-top: 61px;
  }
  article.reservation.reservation .ttl_reservation {
    font-size: 1rem;
    padding: 0.5em 1em 0.25em;
  }
  article.reservation.reservation .form_box {
    margin: 2em auto 0;
  }
  article.reservation.reservation .form_box .form_box_input:not(:last-of-type) {
    margin-bottom: 1em;
  }
  article.reservation.reservation .form_box .form_box_input p {
    font-size: 0.875rem;
  }
  article.reservation.reservation .form_box .form_box_input p em {
    padding-left: 0 !important;
  }
  article.reservation.reservation .form_box .form_box_input .asterisk {
    padding-left: 1em;
  }
  article.reservation.reservation .form_box .form_box_input input {
    height: 30px;
  }
  article.reservation.reservation .form_box .form_box_input .textarea01 {
    height: 60px;
  }
  article.reservation.reservation .form_box .form_box_input .check_box label {
    font-size: 0.875rem;
  }
  article.reservation.reservation .btn02 {
    margin: 2em auto;
  }
  article.reservation.reservation .sec_reservation01 .circle01:before {
    left: -2em;
  }
  article.reservation.reservation .sec_reservation01 .circle02:before {
    bottom: -10em;
    right: -4em;
  }
}

/* --------------------------------------------------
	13. request
-------------------------------------------------- */
body.request #primary {
  margin-top: 129px;
}

body.request #primary .page_title {
  background-image: url("./images/request/page_title.png");
}

body.request #primary .page_title h2 {
  color: #fff;
}

article.request_thanks p {
  text-align: center;
}

article.request_confirm .form_box {
  margin-top: 2em !important;
}

article.request_confirm .form_box p {
  word-break: break-all;
}

article.request_confirm .form_box_check {
  margin-bottom: 2em;
}

article.request_confirm .form_box_check .ttl_request {
  margin-bottom: 1em;
}

article.request_confirm .form_box_check ul {
  padding-left: 2em;
}

article.request_confirm .form_box_check ul li {
  padding-left: -1em;
  list-style: disc;
}

article.request_confirm .form_box_check p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.request_confirm .form_box_input .border {
  border: 1px solid #231815;
  padding: 0.5em 1em;
  background-color: #fff;
  display: block;
}

article.request_confirm .btn02 .return {
  background-color: #595757;
  border: 1px solid #595757;
  margin-bottom: 1.5em;
}

article.request_confirm .btn02 .return:hover {
  background-color: #fff;
  color: #595757;
  border-color: #595757;
}

article.request .box.error {
  padding: 1em;
  background-color: #ffdddd;
}

article.request .box.error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

article.request .txt01_request {
  font-size: 1.0625rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
  margin: 2em 0 3em;
}

article.request .txt02_request {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

article.request .ttl_request {
  font-size: 1.125rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  border: 1px solid #231815;
  padding: 0.75em 1em 0.5em;
}

article.request .ttl_request span.small {
  font-size: 0.8125rem;
  font-weight: 400;
}

article.request .ttl_request span {
  font-size: 0.9375rem;
}

article.request .box_checkbox {
  text-indent: -1.25em;
  padding-left: 1.25em;
}

article.request .request_check {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

article.request .form_box {
  max-width: 460px;
  margin: 6em auto 0;
}

article.request .form_box .form_box_input:not(:last-of-type) {
  margin-bottom: 1em;
}

article.request .form_box .form_box_input p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.request .form_box .form_box_input input {
  width: 100%;
  height: 36px;
  border: 1px solid #231815;
}

article.request .form_box .form_box_input textarea {
  width: 100%;
  resize: none;
  border-radius: 0;
  margin: 0;
  border-radius: 0 !important;
}

article.request .form_box .form_box_input .textarea01 {
  height: 92px;
  margin-bottom: 0;
}

article.request .form_box .form_box_input .textarea01::-webkit-input-placeholder {
  color: #231815;
}

article.request .form_box .form_box_input .textarea01::-moz-placeholder {
  color: #231815;
}

article.request .form_box .form_box_input .textarea01:-ms-input-placeholder {
  color: #231815;
}

article.request .form_box .form_box_input .textarea01::-ms-input-placeholder {
  color: #231815;
}

article.request .form_box .form_box_input .textarea01::placeholder {
  color: #231815;
}

article.request .form_box .form_box_input .textarea02 {
  height: 230px;
}

article.request .form_box .error input, article.request .form_box .error .textarea01, article.request .form_box .error .textarea02 {
  border: 1px solid #ff5757;
  background-color: #ffdddd;
}

article.request .form_box .error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  margin-top: 0.5em;
}

article.request .btn02 {
  max-width: 460px;
  margin: 4em auto;
}

article.request .list_checkbox li {
  padding: 1em 0;
}

article.request .list_checkbox li:not(:last-child) {
  border-bottom: 1px dotted #000;
}

article.request .request_box01:not(:last-of-type) {
  margin-bottom: 2em;
}

article.request .sec_request01 {
  position: relative;
}

article.request .sec_request01 .circle01:before {
  top: 6em;
  left: -10em;
}

article.request .sec_request01 .circle02:before {
  position: absolute;
  bottom: 10em;
  right: -20em;
}

@media only screen and (max-width: 739px) {
  body.request #primary {
    margin-top: 61px;
  }
  article.request.request .txt01_request {
    font-size: 1rem;
    margin: 1em 0 2em;
  }
  article.request.request .txt02_request {
    font-size: 0.875rem;
  }
  article.request.request .ttl_request {
    font-size: 1rem;
    padding: 0.5em 1em 0.25em;
  }
  article.request.request .request_check {
    font-size: 0.875rem;
  }
  article.request.request .form_box {
    margin: 2em auto 0;
  }
  article.request.request .form_box .form_box_input:not(:last-of-type) {
    margin-bottom: 1em;
  }
  article.request.request .form_box .form_box_input p {
    font-size: 0.875rem;
  }
  article.request.request .form_box .form_box_input input {
    height: 30px;
  }
  article.request.request .form_box .form_box_input .textarea01 {
    height: 60px;
  }
  article.request.request .form_box .form_box_input .textarea02 {
    height: 130px;
  }
  article.request.request .btn02 {
    margin: 2em auto;
  }
  article.request.request .sec_request01 {
    position: relative;
  }
  article.request.request .sec_request01 .circle01:before {
    left: -2em;
  }
  article.request.request .sec_request01 .circle02:before {
    position: absolute;
    bottom: -10em;
    right: -4em;
  }
}

/* --------------------------------------------------
	14. news
-------------------------------------------------- */
body.news #primary {
  margin-top: 129px;
}

body.news #primary .page_title {
  background-image: url("./images/news/page_title.png");
}

body.news #all {
  min-height: 100vh;
  /* ←コンテンツの高さの最小値＝ブラウザの高さに指定 */
  position: relative;
  /* ←相対位置 */
  padding-bottom: 160px;
  /* ←フッターの高さを指定 */
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body.news #footer {
  position: absolute;
  /* ←絶対位置 */
  bottom: 0;
  width: 100%;
}

article.news {
  position: relative;
}

article.news .circle01:before {
  top: -5em;
  left: -5em;
}

article.news .circle02 {
  display: none;
}

article.news .circle02:before {
  position: absolute;
  bottom: -10em;
  right: -16em;
}

article.news_detail h3 {
  border: 1px solid #c51724;
  padding: 0.7em 2em 0.7em 5em;
  font-size: 1.0625rem;
  text-align: left;
}

article.news_detail h3::before {
  content: "";
  width: 55px;
  height: 100%;
  background-color: #c51724;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}

article.news_detail h3::after {
  background-color: #fff;
  top: 50%;
  left: 27.5px;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

article.news_detail .detail {
  position: relative;
}

article.news_detail .circle01:before {
  top: -5em;
  left: -5em;
}

article.news_detail .circle02:before {
  bottom: -10em;
  right: 0;
}

article.news_detail .date_box {
  margin: 2em 0 2em;
}

article.news_detail p {
  font-size: 0.9375rem;
  color: #231815;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  text-align: left;
}

article.news_detail a.pdf {
  color: #c51724;
  text-decoration: none;
}

article.news_detail a.pdf:hover {
  text-decoration: underline;
}

article.news_detail .image {
  text-align: center;
}

article.news_detail .border {
  border: 1px dotted #231815;
  margin: 1.5em 0;
}

article.news_detail .btn01 {
  max-width: 300px;
}

article.news_detail .btn01 a {
  border: 1px solid #c51724;
  color: #c51724;
}

article.news_detail table {
  max-width: calc(1000px - 2.5em * 2) !important;
  background-color: #fff;
}

article.news_detail table td, article.news_detail table th {
  border: 1px solid;
}

article.news_detail table.aligncenter {
  margin: 0 auto;
}

article.news_detail table.alignleft {
  float: left;
}

article.news_detail table.alignright {
  float: right;
}

article.news_detail img.aligncenter {
  display: block;
  margin: 0 auto;
}

article.news_detail img.alignleft {
  float: left;
}

article.news_detail img.alignright {
  float: right;
}

article.news_detail ul {
  margin-left: 1em;
  list-style: disc;
}

article.news_detail ol {
  margin-left: 1em;
  list-style: decimal;
}

article.news_detail em {
  font-style: italic;
}

article.news_detail a[target="_blank"]::after {
  display: inline-block;
  vertical-align: middle;
  content: "";
  margin: -5px 0.4em 0;
  width: 18px;
  height: 16px;
  background: transparent url(images/news/icon_window.png) no-repeat center center;
  background-size: contain;
}

@media all and (min-width: 740px), print {
  .news .circle02 {
    display: none;
  }
  .news_detail .content table {
    max-width: calc(1000px - 2.5em * 2) !important;
  }
}

@media only screen and (max-width: 739px) {
  body.news #primary {
    margin-top: 61px;
  }
  body.news #all {
    padding-bottom: 100px;
    /* ←フッターの高さを指定 */
  }
  article.news .circle01:before {
    left: -2em;
  }
  article.news .circle02:before {
    bottom: -10em;
    right: -4em;
  }
  article.news_detail .circle01:before {
    left: -2em;
  }
  article.news_detail .circle02:before {
    bottom: 6em;
    right: -4em;
  }
  article.news_detail h3 {
    padding: 0.7em 2em 0.7em 4em;
  }
  article.news_detail h3::before {
    width: 40px;
  }
  article.news_detail h3::after {
    left: 20px;
  }
  article.news_detail .date {
    font-size: 0.9375rem;
  }
  article.news_detail p {
    font-size: 1rem;
  }
}

/* --------------------------------------------------
	15. contact
-------------------------------------------------- */
body.contact #primary {
  margin-top: 129px;
}

body.contact #primary .page_title {
  background-image: url("./images/contact/page_title.png");
}

body.contact #primary .page_title h2 {
  color: #fff;
}

article.contact_thanks p {
  text-align: center;
}

article.contact_confirm .form_box {
  margin-top: 2em !important;
}

article.contact_confirm .form_box p {
  word-break: break-all;
}

article.contact_confirm .form_box_check {
  margin-bottom: 2em;
}

article.contact_confirm .form_box_check .ttl_contact {
  margin-bottom: 1em;
}

article.contact_confirm .form_box_check ul {
  padding-left: 2em;
}

article.contact_confirm .form_box_check ul li {
  padding-left: -1em;
  list-style: disc;
}

article.contact_confirm .form_box_check p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.contact_confirm .form_box_input .border {
  border: 1px solid #231815;
  padding: 0.5em 1em;
  background-color: #fff;
  display: block;
}

article.contact_confirm .btn02 .return {
  background-color: #595757;
  border: 1px solid #595757;
  margin-bottom: 1.5em;
}

article.contact_confirm .btn02 .return:hover {
  background-color: #fff;
  color: #595757;
  border-color: #595757;
}

article.contact .box.error {
  padding: 1em;
  background-color: #ffdddd;
}

article.contact .box.error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

article.contact .txt01_contact {
  font-size: 1.0625rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
  margin: 2em 0 3em;
}

article.contact .txt02_contact {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

article.contact .ttl_contact {
  font-size: 1.125rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  border: 1px solid #231815;
  padding: 0.75em 1em 0.5em;
}

article.contact .ttl_contact span.small {
  font-size: 0.8125rem;
  font-weight: 400;
}

article.contact .ttl_contact span {
  font-size: 0.9375rem;
}

article.contact .box_checkbox {
  text-indent: -1.25em;
  padding-left: 1.25em;
}

article.contact .contact_check {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
}

article.contact .form_box {
  max-width: 460px;
  margin: 6em auto 0;
}

article.contact .form_box .form_box_input:not(:last-of-type) {
  margin-bottom: 1em;
}

article.contact .form_box .form_box_input p {
  font-size: 1rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 500;
  margin-bottom: 0.25em;
}

article.contact .form_box .form_box_input input {
  width: 100%;
  height: 36px;
  border: 1px solid #231815;
}

article.contact .form_box .form_box_input textarea {
  width: 100%;
  resize: none;
  border-radius: 0;
  margin: 0;
  border-radius: 0 !important;
}

article.contact .form_box .form_box_input .textarea01 {
  height: 92px;
  margin-bottom: 0;
}

article.contact .form_box .form_box_input .textarea01::-webkit-input-placeholder {
  color: #231815;
}

article.contact .form_box .form_box_input .textarea01::-moz-placeholder {
  color: #231815;
}

article.contact .form_box .form_box_input .textarea01:-ms-input-placeholder {
  color: #231815;
}

article.contact .form_box .form_box_input .textarea01::-ms-input-placeholder {
  color: #231815;
}

article.contact .form_box .form_box_input .textarea01::placeholder {
  color: #231815;
}

article.contact .form_box .form_box_input .textarea02 {
  height: 230px;
}

article.contact .form_box .error input, article.contact .form_box .error .textarea01, article.contact .form_box .error .textarea02 {
  border: 1px solid #ff5757;
  background-color: #ffdddd;
}

article.contact .form_box .error .error_text {
  color: #ff5757;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  margin-top: 0.5em;
}

article.contact .btn02 {
  max-width: 460px;
  margin: 4em auto;
}

article.contact .list_checkbox li {
  padding: 1em 0;
}

article.contact .list_checkbox li:not(:last-child) {
  border-bottom: 1px dotted #000;
}

article.contact .contact_box01:not(:last-of-type) {
  margin-bottom: 2em;
}

article.contact .sec_contact01 {
  position: relative;
}

article.contact .sec_contact01 .circle01:before {
  top: 6em;
  left: -10em;
}

article.contact .sec_contact01 .circle02:before {
  position: absolute;
  bottom: 10em;
  right: -20em;
}

@media only screen and (max-width: 739px) {
  body.contact #primary {
    margin-top: 61px;
  }
  article.contact.contact .txt01_contact {
    font-size: 1rem;
    margin: 1em 0 2em;
  }
  article.contact.contact .txt02_contact {
    font-size: 0.875rem;
  }
  article.contact.contact .ttl_contact {
    font-size: 1rem;
    padding: 0.5em 1em 0.25em;
  }
  article.contact.contact .contact_check {
    font-size: 0.875rem;
  }
  article.contact.contact .form_box {
    margin: 2em auto 0;
  }
  article.contact.contact .form_box .form_box_input:not(:last-of-type) {
    margin-bottom: 1em;
  }
  article.contact.contact .form_box .form_box_input p {
    font-size: 0.875rem;
  }
  article.contact.contact .form_box .form_box_input input {
    height: 30px;
  }
  article.contact.contact .form_box .form_box_input .textarea01 {
    height: 60px;
  }
  article.contact.contact .form_box .form_box_input .textarea02 {
    height: 130px;
  }
  article.contact.contact .btn02 {
    margin: 2em auto;
  }
  article.contact.contact .sec_contact01 {
    position: relative;
  }
  article.contact.contact .sec_contact01 .circle01:before {
    left: -2em;
  }
  article.contact.contact .sec_contact01 .circle02:before {
    position: absolute;
    bottom: -10em;
    right: -4em;
  }
}
