@charset "UTF-8";
.clearfix:before, .container:before, .row:before, [class*="block-grid-"]:before, .pagination ul:before, .faq-question:before, .faq-answer:before, .contents-archive article:before, .clearfix:after, .container:after, .row:after, [class*="block-grid-"]:after, .pagination ul:after, .faq-question:after, .faq-answer:after, .contents-archive article:after {
  content: " ";
  display: table; }
.clearfix:after, .container:after, .row:after, [class*="block-grid-"]:after, .pagination ul:after, .faq-question:after, .faq-answer:after, .contents-archive article:after {
  clear: both; }

.hidden {
  display: none !important; }

@media screen and (min-width: 36em) {
  .hidden-sm-up {
    display: none !important; } }
@media screen and (max-width: 47.9375em) {
  .hidden-sm-down {
    display: none !important; } }
@media screen and (min-width: 48em) {
  .hidden-md-up {
    display: none !important; } }
@media screen and (max-width: 61.9375em) {
  .hidden-md-down {
    display: none !important; } }
@media screen and (min-width: 62em) {
  .hidden-lg-up {
    display: none !important; } }
@media screen and (max-width: 74.9375em) {
  .hidden-lg-down {
    display: none !important; } }
.text-12 {
  font-size: 12px !important;
  font-size: 0.75rem !important; }

.text-14 {
  font-size: 14px !important;
  font-size: 0.875rem !important; }

.text-16 {
  font-size: 16px !important;
  font-size: 1rem !important; }

.text-18 {
  font-size: 18px !important;
  font-size: 1.125rem !important; }

.text-20 {
  font-size: 20px !important;
  font-size: 1.25rem !important; }

.text-22 {
  font-size: 22px !important;
  font-size: 1.375rem !important; }

.text-24 {
  font-size: 24px !important;
  font-size: 1.5rem !important; }

.text-26 {
  font-size: 26px !important;
  font-size: 1.625rem !important; }

.text-28 {
  font-size: 28px !important;
  font-size: 1.75rem !important; }

.text-30 {
  font-size: 30px !important;
  font-size: 1.875rem !important; }

@media screen and (min-width: 36em) and (max-width: 47.9375em) {
  .text-sm-12 {
    font-size: 12px !important;
    font-size: 0.75rem !important; }

  .text-sm-14 {
    font-size: 14px !important;
    font-size: 0.875rem !important; }

  .text-sm-16 {
    font-size: 16px !important;
    font-size: 1rem !important; }

  .text-sm-18 {
    font-size: 18px !important;
    font-size: 1.125rem !important; }

  .text-sm-20 {
    font-size: 20px !important;
    font-size: 1.25rem !important; }

  .text-sm-22 {
    font-size: 22px !important;
    font-size: 1.375rem !important; }

  .text-sm-24 {
    font-size: 24px !important;
    font-size: 1.5rem !important; }

  .text-sm-26 {
    font-size: 26px !important;
    font-size: 1.625rem !important; }

  .text-sm-28 {
    font-size: 28px !important;
    font-size: 1.75rem !important; }

  .text-sm-30 {
    font-size: 30px !important;
    font-size: 1.875rem !important; } }
@media screen and (min-width: 48em) and (max-width: 61.9375em) {
  .text-md-12 {
    font-size: 12px !important;
    font-size: 0.75rem !important; }

  .text-md-14 {
    font-size: 14px !important;
    font-size: 0.875rem !important; }

  .text-md-16 {
    font-size: 16px !important;
    font-size: 1rem !important; }

  .text-md-18 {
    font-size: 18px !important;
    font-size: 1.125rem !important; }

  .text-md-20 {
    font-size: 20px !important;
    font-size: 1.25rem !important; }

  .text-md-22 {
    font-size: 22px !important;
    font-size: 1.375rem !important; }

  .text-md-24 {
    font-size: 24px !important;
    font-size: 1.5rem !important; }

  .text-md-26 {
    font-size: 26px !important;
    font-size: 1.625rem !important; }

  .text-md-28 {
    font-size: 28px !important;
    font-size: 1.75rem !important; }

  .text-md-30 {
    font-size: 30px !important;
    font-size: 1.875rem !important; } }
@media screen and (min-width: 62em) and (max-width: 74.9375em) {
  .text-lg-12 {
    font-size: 12px !important;
    font-size: 0.75rem !important; }

  .text-lg-14 {
    font-size: 14px !important;
    font-size: 0.875rem !important; }

  .text-lg-16 {
    font-size: 16px !important;
    font-size: 1rem !important; }

  .text-lg-18 {
    font-size: 18px !important;
    font-size: 1.125rem !important; }

  .text-lg-20 {
    font-size: 20px !important;
    font-size: 1.25rem !important; }

  .text-lg-22 {
    font-size: 22px !important;
    font-size: 1.375rem !important; }

  .text-lg-24 {
    font-size: 24px !important;
    font-size: 1.5rem !important; }

  .text-lg-26 {
    font-size: 26px !important;
    font-size: 1.625rem !important; }

  .text-lg-28 {
    font-size: 28px !important;
    font-size: 1.75rem !important; }

  .text-lg-30 {
    font-size: 30px !important;
    font-size: 1.875rem !important; } }
.text-left {
  text-align: left; }

.text-right {
  text-align: right; }

.text-center {
  text-align: center; }

.text-justify {
  text-align: justify; }

@media screen and (min-width: 36em) {
  .text-left-sm {
    text-align: left; }

  .text-right-sm {
    text-align: right; }

  .text-center-sm {
    text-align: center; }

  .text-justify-sm {
    text-align: justify; } }
@media screen and (min-width: 48em) {
  .text-left-md {
    text-align: left; }

  .text-right-md {
    text-align: right; }

  .text-center-md {
    text-align: center; }

  .text-justify-md {
    text-align: justify; } }
@media screen and (min-width: 62em) {
  .text-left-lg {
    text-align: left; }

  .text-right-lg {
    text-align: right; }

  .text-center-lg {
    text-align: center; }

  .text-justify-lg {
    text-align: justify; } }
@font-face {
  font-family: "Noto Sans Japanese";
  font-weight: 300;
  src: url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Light.woff") format("woff"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Light.ttf") format("truetype"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Light.eot") format("eot"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-weight: 350;
  src: url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-DemiLight.woff") format("woff"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-DemiLight.ttf") format("truetype"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-DemiLight.eot") format("eot"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-weight: 400;
  src: url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Regular.woff") format("woff"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Regular.ttf") format("truetype"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Regular.eot") format("eot"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-weight: 500;
  src: url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Medium.woff") format("woff"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Medium.ttf") format("truetype"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Medium.eot") format("eot"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-weight: 700;
  src: url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Bold.woff") format("woff"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Bold.ttf") format("truetype"), url("../library/fonts/NotoSansCJKJP-subset/NotoSansCJKjp-Bold.eot") format("eot"); }
html {
  box-sizing: border-box;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  -moz-box-sizing: inherit;
  box-sizing: inherit; }

html, body {
  height: 100%; }

html {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

body {
  margin: 0;
  padding: 0;
  background: #fff;
  cursor: auto; }

div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, p, blockquote, th, td {
  margin: 0;
  padding: 0; }

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

img {
  width: auto\9;
  max-width: 100%;
  height: auto;
  border: 0;
  vertical-align: top;
  -ms-interpolation-mode: bicubic; }

figure {
  margin: 0; }

a,
a:hover {
  transition: all 0.3s ease; }

.container {
  position: relative;
  width: 100%;
  max-width: 1076px;
  margin-left: auto;
  margin-right: auto; }

.container {
  padding-left: 12px;
  padding-right: 12px; }

@media screen and (min-width: 48em) {
  .container {
    padding-left: 16px;
    padding-right: 16px; } }
/*
@each $size, $width in $container-fixed-max-widths {
	$width: strip-unit($width);
	@include breakpoint($size) {
		.container {
			width: em-calc( $width );
		}
	}
}
*/
.row {
  margin-left: -12px;
  margin-right: -12px; }

@media screen and (min-width: 48em) {
  .row {
    margin-left: -16px;
    margin-right: -16px; } }
.gutter {
  padding-left: 12px;
  padding-right: 12px; }

@media screen and (min-width: 48em) {
  .gutter {
    padding-left: 16px;
    padding-right: 16px; } }
[class*="col-"] {
  display: block;
  position: relative;
  float: left;
  width: 100%;
  min-height: 1px; }

.col-xs-1 {
  width: 8.3333333333%; }

.col-xs-2 {
  width: 16.6666666667%; }

.col-xs-3 {
  width: 25%; }

.col-xs-4 {
  width: 33.3333333333%; }

.col-xs-5 {
  width: 41.6666666667%; }

.col-xs-6 {
  width: 50%; }

.col-xs-7 {
  width: 58.3333333333%; }

.col-xs-8 {
  width: 66.6666666667%; }

.col-xs-9 {
  width: 75%; }

.col-xs-10 {
  width: 83.3333333333%; }

.col-xs-11 {
  width: 91.6666666667%; }

.col-xs-12 {
  width: 100%; }

.col-xs-offset-1 {
  margin-left: 8.3333333333% !important; }

.col-xs-offset-2 {
  margin-left: 16.6666666667% !important; }

.col-xs-offset-3 {
  margin-left: 25% !important; }

.col-xs-offset-4 {
  margin-left: 33.3333333333% !important; }

.col-xs-offset-5 {
  margin-left: 41.6666666667% !important; }

.col-xs-offset-6 {
  margin-left: 50% !important; }

.col-xs-offset-7 {
  margin-left: 58.3333333333% !important; }

.col-xs-offset-8 {
  margin-left: 66.6666666667% !important; }

.col-xs-offset-9 {
  margin-left: 75% !important; }

.col-xs-offset-10 {
  margin-left: 83.3333333333% !important; }

.col-xs-offset-11 {
  margin-left: 91.6666666667% !important; }

@media screen and (min-width: 36em) {
  .col-sm-1 {
    width: 8.3333333333%; }

  .col-sm-2 {
    width: 16.6666666667%; }

  .col-sm-3 {
    width: 25%; }

  .col-sm-4 {
    width: 33.3333333333%; }

  .col-sm-5 {
    width: 41.6666666667%; }

  .col-sm-6 {
    width: 50%; }

  .col-sm-7 {
    width: 58.3333333333%; }

  .col-sm-8 {
    width: 66.6666666667%; }

  .col-sm-9 {
    width: 75%; }

  .col-sm-10 {
    width: 83.3333333333%; }

  .col-sm-11 {
    width: 91.6666666667%; }

  .col-sm-12 {
    width: 100%; }

  .col-sm-offset-1 {
    margin-left: 8.3333333333% !important; }

  .col-sm-offset-2 {
    margin-left: 16.6666666667% !important; }

  .col-sm-offset-3 {
    margin-left: 25% !important; }

  .col-sm-offset-4 {
    margin-left: 33.3333333333% !important; }

  .col-sm-offset-5 {
    margin-left: 41.6666666667% !important; }

  .col-sm-offset-6 {
    margin-left: 50% !important; }

  .col-sm-offset-7 {
    margin-left: 58.3333333333% !important; }

  .col-sm-offset-8 {
    margin-left: 66.6666666667% !important; }

  .col-sm-offset-9 {
    margin-left: 75% !important; }

  .col-sm-offset-10 {
    margin-left: 83.3333333333% !important; }

  .col-sm-offset-11 {
    margin-left: 91.6666666667% !important; } }
@media screen and (min-width: 48em) {
  .col-md-1 {
    width: 8.3333333333%; }

  .col-md-2 {
    width: 16.6666666667%; }

  .col-md-3 {
    width: 25%; }

  .col-md-4 {
    width: 33.3333333333%; }

  .col-md-5 {
    width: 41.6666666667%; }

  .col-md-6 {
    width: 50%; }

  .col-md-7 {
    width: 58.3333333333%; }

  .col-md-8 {
    width: 66.6666666667%; }

  .col-md-9 {
    width: 75%; }

  .col-md-10 {
    width: 83.3333333333%; }

  .col-md-11 {
    width: 91.6666666667%; }

  .col-md-12 {
    width: 100%; }

  .col-md-offset-1 {
    margin-left: 8.3333333333% !important; }

  .col-md-offset-2 {
    margin-left: 16.6666666667% !important; }

  .col-md-offset-3 {
    margin-left: 25% !important; }

  .col-md-offset-4 {
    margin-left: 33.3333333333% !important; }

  .col-md-offset-5 {
    margin-left: 41.6666666667% !important; }

  .col-md-offset-6 {
    margin-left: 50% !important; }

  .col-md-offset-7 {
    margin-left: 58.3333333333% !important; }

  .col-md-offset-8 {
    margin-left: 66.6666666667% !important; }

  .col-md-offset-9 {
    margin-left: 75% !important; }

  .col-md-offset-10 {
    margin-left: 83.3333333333% !important; }

  .col-md-offset-11 {
    margin-left: 91.6666666667% !important; } }
@media screen and (min-width: 62em) {
  .col-lg-1 {
    width: 8.3333333333%; }

  .col-lg-2 {
    width: 16.6666666667%; }

  .col-lg-3 {
    width: 25%; }

  .col-lg-4 {
    width: 33.3333333333%; }

  .col-lg-5 {
    width: 41.6666666667%; }

  .col-lg-6 {
    width: 50%; }

  .col-lg-7 {
    width: 58.3333333333%; }

  .col-lg-8 {
    width: 66.6666666667%; }

  .col-lg-9 {
    width: 75%; }

  .col-lg-10 {
    width: 83.3333333333%; }

  .col-lg-11 {
    width: 91.6666666667%; }

  .col-lg-12 {
    width: 100%; }

  .col-lg-offset-1 {
    margin-left: 8.3333333333% !important; }

  .col-lg-offset-2 {
    margin-left: 16.6666666667% !important; }

  .col-lg-offset-3 {
    margin-left: 25% !important; }

  .col-lg-offset-4 {
    margin-left: 33.3333333333% !important; }

  .col-lg-offset-5 {
    margin-left: 41.6666666667% !important; }

  .col-lg-offset-6 {
    margin-left: 50% !important; }

  .col-lg-offset-7 {
    margin-left: 58.3333333333% !important; }

  .col-lg-offset-8 {
    margin-left: 66.6666666667% !important; }

  .col-lg-offset-9 {
    margin-left: 75% !important; }

  .col-lg-offset-10 {
    margin-left: 83.3333333333% !important; }

  .col-lg-offset-11 {
    margin-left: 91.6666666667% !important; } }
[class*="block-grid-"] > * {
  display: block;
  position: relative;
  float: left;
  width: 100%;
  min-height: 1px; }

.block-grid-xs-1 > * {
  width: 100%; }
  .block-grid-xs-1 > *:nth-of-type(1n) {
    clear: none; }
  .block-grid-xs-1 > *:nth-of-type(1n + 1) {
    clear: both; }

.block-grid-xs-2 > * {
  width: 50%; }
  .block-grid-xs-2 > *:nth-of-type(1n) {
    clear: none; }
  .block-grid-xs-2 > *:nth-of-type(2n + 1) {
    clear: both; }

.block-grid-xs-3 > * {
  width: 33.3333333333%; }
  .block-grid-xs-3 > *:nth-of-type(1n) {
    clear: none; }
  .block-grid-xs-3 > *:nth-of-type(3n + 1) {
    clear: both; }

.block-grid-xs-4 > * {
  width: 25%; }
  .block-grid-xs-4 > *:nth-of-type(1n) {
    clear: none; }
  .block-grid-xs-4 > *:nth-of-type(4n + 1) {
    clear: both; }

.block-grid-xs-5 > * {
  width: 20%; }
  .block-grid-xs-5 > *:nth-of-type(1n) {
    clear: none; }
  .block-grid-xs-5 > *:nth-of-type(5n + 1) {
    clear: both; }

@media screen and (min-width: 36em) {
  .block-grid-sm-1 > * {
    width: 100%; }
    .block-grid-sm-1 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-sm-1 > *:nth-of-type(1n + 1) {
      clear: both; }

  .block-grid-sm-2 > * {
    width: 50%; }
    .block-grid-sm-2 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-sm-2 > *:nth-of-type(2n + 1) {
      clear: both; }

  .block-grid-sm-3 > * {
    width: 33.3333333333%; }
    .block-grid-sm-3 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-sm-3 > *:nth-of-type(3n + 1) {
      clear: both; }

  .block-grid-sm-4 > * {
    width: 25%; }
    .block-grid-sm-4 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-sm-4 > *:nth-of-type(4n + 1) {
      clear: both; }

  .block-grid-sm-5 > * {
    width: 20%; }
    .block-grid-sm-5 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-sm-5 > *:nth-of-type(5n + 1) {
      clear: both; } }
@media screen and (min-width: 48em) {
  .block-grid-md-1 > * {
    width: 100%; }
    .block-grid-md-1 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-md-1 > *:nth-of-type(1n + 1) {
      clear: both; }

  .block-grid-md-2 > * {
    width: 50%; }
    .block-grid-md-2 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-md-2 > *:nth-of-type(2n + 1) {
      clear: both; }

  .block-grid-md-3 > * {
    width: 33.3333333333%; }
    .block-grid-md-3 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-md-3 > *:nth-of-type(3n + 1) {
      clear: both; }

  .block-grid-md-4 > * {
    width: 25%; }
    .block-grid-md-4 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-md-4 > *:nth-of-type(4n + 1) {
      clear: both; }

  .block-grid-md-5 > * {
    width: 20%; }
    .block-grid-md-5 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-md-5 > *:nth-of-type(5n + 1) {
      clear: both; } }
@media screen and (min-width: 62em) {
  .block-grid-lg-1 > * {
    width: 100%; }
    .block-grid-lg-1 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-lg-1 > *:nth-of-type(1n + 1) {
      clear: both; }

  .block-grid-lg-2 > * {
    width: 50%; }
    .block-grid-lg-2 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-lg-2 > *:nth-of-type(2n + 1) {
      clear: both; }

  .block-grid-lg-3 > * {
    width: 33.3333333333%; }
    .block-grid-lg-3 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-lg-3 > *:nth-of-type(3n + 1) {
      clear: both; }

  .block-grid-lg-4 > * {
    width: 25%; }
    .block-grid-lg-4 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-lg-4 > *:nth-of-type(4n + 1) {
      clear: both; }

  .block-grid-lg-5 > * {
    width: 20%; }
    .block-grid-lg-5 > *:nth-of-type(1n) {
      clear: none; }
    .block-grid-lg-5 > *:nth-of-type(5n + 1) {
      clear: both; } }
.bg-white {
  background: #fefefe; }

.bg-gray {
  background: #868686; }

.bg-gray-light {
  background: #F0F0F0; }

.bg-gray-lighter {
  background: #F0F0F0; }

.bg-gray-dark {
  background: #666666; }

.bg-gray-darker {
  background: #484848; }

.bg-black {
  background: #000000; }

.bg-black-5 {
  background: #f2f2f2; }

.bg-black-10 {
  background: #e6e6e6; }

.bg-black-15 {
  background: #d9d9d9; }

.bg-black-20 {
  background: #cccccc; }

.bg-black-25 {
  background: #bfbfbf; }

.bg-black-30 {
  background: #b3b3b3; }

.bg-black-35 {
  background: #a6a6a6; }

.bg-black-40 {
  background: #999999; }

.bg-black-45 {
  background: #8c8c8c; }

.bg-black-50 {
  background: gray; }

.bg-black-55 {
  background: #737373; }

.bg-black-60 {
  background: #666666; }

.bg-black-65 {
  background: #595959; }

.bg-black-70 {
  background: #4d4d4d; }

.bg-black-75 {
  background: #404040; }

.bg-black-80 {
  background: #333333; }

.bg-black-85 {
  background: #262626; }

.bg-black-90 {
  background: #1a1a1a; }

.bg-black-95 {
  background: #0d0d0d; }

.bg-primary {
  background: #FF7600; }

.bg-secondary {
  background: #50b875; }

.bg-tertiary {
  background: #cfe5f0; }

.bg-success {
  background: #3adb76; }

.bg-error {
  background: #ec5840; }

.bg-warning {
  background: #ffae00; }

.bg-disabled {
  background: #ffe4cc; }

.sg-section {
  margin: 0 0 40px;
  padding: 0 0 40px;
  border-bottom: 1px solid #bdbdbd; }
  .sg-section:last-child {
    border: none; }

.sg-page-title {
  font-size: 3rem; }
  .sg-page-title span {
    margin-left: 1em; }

.sg-section-heading {
  font-size: 2.4rem; }
  .sg-section-heading span {
    margin-left: 1.2em;
    font-size: 1.3rem; }

.inline-list {
  margin: 0;
  padding: 0;
  list-style: none; }
  .inline-list li {
    display: inline-block; }

.hljs {
  padding: 0 24px;
  border: 1px solid #bdbdbd;
  background: #f9f9f9; }

.hljs-tag {
  color: #2f6f9f; }

.hljs-name {
  color: #2f6f9f; }

.hljs-attr {
  color: #4f9fcf; }

.hljs-string {
  color: #d44950; }

.visibility-table {
  table-layout: fixed; }
  .visibility-table th code {
    color: #ec5840; }
  .visibility-table thead th {
    font-size: 18px;
    line-height: 1.4;
    vertical-align: middle; }
    .visibility-table thead th small {
      display: block;
      font-size: 13px; }
  .visibility-table thead th:first-child {
    width: 110px; }
  .visibility-table tbody td {
    text-align: center; }
  .visibility-table .is-visible {
    background: rgba(255, 118, 0, 0.2);
    color: #FF7600; }
  .visibility-table .is-hidden {
    color: #868686; }

a.btn,
input.btn,
button.btn {
  display: inline-block;
  position: relative;
  margin-bottom: 0;
  padding: .7em 1.2em;
  border: none;
  width: 100%;
  max-width: 280px;
  line-height: normal;
  background: #FF7600;
  color: #fff;
  font-size: 16px;
  font-size: 1rem;
  font-weight: normal;
  text-align: center;
  text-decoration: none;
  transition: background 0.4s 0s, color 0.4s 0s;
  box-shadow: 0px 3px #cc5e00; }
  a.btn:hover,
  input.btn:hover,
  button.btn:hover {
    background: #cc5e00;
    color: #fff;
    text-decoration: none;
    transition: background 0.4s 0s, color 0.4s 0s; }
  a.btn.btn-rounded,
  input.btn.btn-rounded,
  button.btn.btn-rounded {
    border-radius: 4px; }
  a.btn.btn-xsmall,
  input.btn.btn-xsmall,
  button.btn.btn-xsmall {
    padding: .5em 0;
    font-size: 12px;
    font-size: 0.75rem; }
  a.btn.btn-small,
  input.btn.btn-small,
  button.btn.btn-small {
    padding: .6em 0;
    font-size: 14px;
    font-size: 0.875rem; }
  a.btn.btn-medium,
  input.btn.btn-medium,
  button.btn.btn-medium {
    padding: .7em 0;
    font-size: 16px;
    font-size: 1rem; }
  a.btn.btn-large,
  input.btn.btn-large,
  button.btn.btn-large {
    padding: .8em 0;
    font-size: 18px;
    font-size: 1.125rem; }
  a.btn.btn-xlarge,
  input.btn.btn-xlarge,
  button.btn.btn-xlarge {
    padding: .9em 0;
    font-size: 20px;
    font-size: 1.25rem; }
  a.btn.btn-secondary,
  input.btn.btn-secondary,
  button.btn.btn-secondary {
    background: #50b875;
    color: #fff; }
    a.btn.btn-secondary:hover,
    input.btn.btn-secondary:hover,
    button.btn.btn-secondary:hover {
      background: #3d985e;
      color: #fff; }
  a.btn.btn-success,
  input.btn.btn-success,
  button.btn.btn-success {
    background: #3adb76;
    color: #fff; }
    a.btn.btn-success:hover,
    input.btn.btn-success:hover,
    button.btn.btn-success:hover {
      background: #23bf5d;
      color: #fff; }
  a.btn.btn-error,
  input.btn.btn-error,
  button.btn.btn-error {
    background: #ec5840;
    color: #fff; }
    a.btn.btn-error:hover,
    input.btn.btn-error:hover,
    button.btn.btn-error:hover {
      background: #e23317;
      color: #fff; }
  a.btn.btn-warning,
  input.btn.btn-warning,
  button.btn.btn-warning {
    background: #ffae00;
    color: #fff; }
    a.btn.btn-warning:hover,
    input.btn.btn-warning:hover,
    button.btn.btn-warning:hover {
      background: #cc8b00;
      color: #fff; }
  a.btn.btn-disabled,
  input.btn.btn-disabled,
  button.btn.btn-disabled {
    background: #ffae00;
    color: #fff;
    opacity: 0.25;
    cursor: not-allowed;
    pointer-events: none; }
  a.btn.btn-ghost,
  input.btn.btn-ghost,
  button.btn.btn-ghost {
    background: transparent;
    color: #FF7600;
    border: #FF7600 solid 1px; }
    a.btn.btn-ghost:hover,
    input.btn.btn-ghost:hover,
    button.btn.btn-ghost:hover {
      background: #FF7600;
      color: #fff; }
  a.btn.btn-ghost-secondary,
  input.btn.btn-ghost-secondary,
  button.btn.btn-ghost-secondary {
    background: transparent;
    color: #50b875;
    border: #50b875 solid 1px; }
    a.btn.btn-ghost-secondary:hover,
    input.btn.btn-ghost-secondary:hover,
    button.btn.btn-ghost-secondary:hover {
      background: #50b875;
      color: #fff; }
  a.btn.btn-ghost-success,
  input.btn.btn-ghost-success,
  button.btn.btn-ghost-success {
    background: transparent;
    color: #3adb76;
    border: #3adb76 solid 1px; }
    a.btn.btn-ghost-success:hover,
    input.btn.btn-ghost-success:hover,
    button.btn.btn-ghost-success:hover {
      background: #3adb76;
      color: #fff; }
  a.btn.btn-ghost-error,
  input.btn.btn-ghost-error,
  button.btn.btn-ghost-error {
    background: transparent;
    color: #ec5840;
    border: #ec5840 solid 1px; }
    a.btn.btn-ghost-error:hover,
    input.btn.btn-ghost-error:hover,
    button.btn.btn-ghost-error:hover {
      background: #ec5840;
      color: #fff; }
  a.btn.btn-ghost-warning,
  input.btn.btn-ghost-warning,
  button.btn.btn-ghost-warning {
    background: transparent;
    color: #ffae00;
    border: #ffae00 solid 1px; }
    a.btn.btn-ghost-warning:hover,
    input.btn.btn-ghost-warning:hover,
    button.btn.btn-ghost-warning:hover {
      background: #ffae00;
      color: #fff; }

body {
  font-family: 'Noto Sans Japanese';
  color: #333;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.6;
  cursor: auto; }

@media screen and (min-width: 48em) {
  body {
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 1.66; } }
@media screen and (min-width: 62em) {
  body {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.66; } }
/* これ入れると色々と不具合が・・・
.topbar,
.header-main,
.site-main,
.footer-contact-wrapper,
.site-footer {
	transform: rotate(0.05deg);
}
*/
a {
  color: #FF7600;
  text-decoration: underline; }
  a:active, a:hover {
    outline: 0; }
  a:hover, a:focus {
    color: #b35300;
    text-decoration: none; }

hr {
  position: relative;
  z-index: 11;
  clear: both;
  box-sizing: content-box;
  margin: 0 auto 16px;
  height: 0;
  border: solid #bdbdbd;
  border-width: 1px 0 0; }

p {
  margin-top: 16px; }

p:first-child {
  margin-top: 0; }

ul {
  list-style-type: disc; }

ol {
  list-style-type: decimal; }

ul, ol {
  list-style-position: outside;
  margin-top: 16px;
  margin-left: 1.6em; }

li {
  margin-top: 8px; }

ul ul, ul ol, ol ul, ol ol {
  margin-top: 0;
  margin-left: 1.5em; }

dl {
  margin-top: 16px; }

dt {
  margin-top: 8px;
  font-weight: bold; }

dd {
  margin-top: 8px; }

blockquote, q {
  quotes: none;
  -webkit-hyphens: none;
  -moz-hyphens: none;
  -ms-hyphens: none;
  hyphens: none; }

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

blockquote {
  margin-top: 32px;
  padding: 16px;
  border-left: 6px solid #FF7600;
  background: #F0F0F0;
  color: #767676;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.66; }
  blockquote p {
    margin: 0; }
  blockquote cite {
    color: #555;
    font-size: 16px;
    font-size: 1rem; }

pre {
  overflow: auto;
  white-space: pre-wrap;
  word-wrap: break-word; }

.light {
  font-weight: 300; }

.demilight {
  font-weight: 350; }

.regular {
  font-weight: 400; }

.medium {
  font-weight: 500; }

.bold {
  font-weight: 700; }

h1, h2, h3, h4, h5, h6 {
  position: relative;
  color: inherit;
  font-style: normal;
  font-weight: bold;
  line-height: 1.4;
  text-rendering: optimizeLegibility; }

h1 {
  margin-top: 24px;
  margin-bottom: 24px;
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.2; }

h2 {
  margin: 48px 0 24px;
  font-size: 26px;
  font-size: 1.625rem;
  line-height: 1.2; }
  h2 + h3, h2 + h4, h2 + h5, h2 + h6 {
    margin-top: 24px; }

h3 {
  margin: 48px 0 24px;
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 1.2; }
  h3 + h4, h3 + h5, h3 + h6 {
    margin-top: 24px; }

h4 {
  margin: 32px 0 16px;
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.2; }
  h4 + h5, h4 + h6 {
    margin-top: 16px; }

h5 {
  margin: 24px 0 16px;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.6; }
  h5 + h6 {
    margin-top: 16px; }

h6 {
  margin: 24px 0 16px;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.6; }

.ttl01 {
  position: relative;
  margin: 0 0 64px;
  font-size: 28px;
  font-weight: 700;
  text-align: center; }
  .ttl01 span {
    position: relative;
    z-index: 100;
    padding: 0 20px 0;
    background: #fff; }
  .ttl01:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 300px;
    height: 2px;
    background: #000;
    transform: translateY(-50%) translateX(-50%); }

@media screen and (min-width: 48em) {
  .ttl01 {
    font-size: 38px; }
    .ttl01:before {
      width: 594px; } }
.contents-single h1,
.contents-page h1 {
  padding: 10px;
  border: solid #000;
  border-width: 4px 0;
  font-size: 35px;
  font-weight: 500; }
.contents-single h2,
.contents-page h2 {
  position: relative;
  color: #fff;
  background-color: #000;
  padding: 10px 10px 10px 27px;
  border-left: 14px solid #ff7600;
  font-size: 26px;
  font-weight: 700; }
  .contents-single h2:before,
  .contents-page h2:before {
    content: '';
    display: block;
    width: 7px;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 7px;
    background: #FF7600;
    transform: translateY(-50%); }
.contents-single h3,
.contents-page h3 {
  padding: 8px 0 10px 48px;
  border-bottom: 4px solid #ff7600;
  background: url(../images/common/icon-h3.png) no-repeat 10px 10px;
  background-size: 22px auto;
  font-size: 23px;
  font-weight: 500; }
.contents-single h4,
.contents-page h4 {
  padding: 8px 0 10px 52px;
  border-bottom: 2px dashed #000;
  background: url(../images/common/icon-h4.png) no-repeat 4px 5px;
  background-size: 39px auto;
  font-size: 20px;
  font-weight: 500; }
.contents-single h5,
.contents-page h5 {
  padding: 20px;
  background: #f0f0f0; }
.contents-single h6,
.contents-page h6 {
  font-size: 17px;
  font-weight: 700; }
  .contents-single h6 a,
  .contents-page h6 a {
    color: #000;
    text-decoration: underline; }
    .contents-single h6 a:before,
    .contents-page h6 a:before {
      position: relative;
      margin-right: .2em;
      display: inline-block;
      overflow: hidden;
      height: 21px;
      content: '\025b6'; }
  .contents-single h6 a:hover,
  .contents-page h6 a:hover {
    color: #ff7600;
    text-decoration: underline; }

.table-scroll {
  overflow: auto;
  white-space: nowrap; }

.table-scroll::-webkit-scrollbar {
  height: 5px; }

.table-scroll::-webkit-scrollbar-track {
  background: #F1F1F1; }

.table-scroll::-webkit-scrollbar-thumb {
  background: #BCBCBC; }

@media screen and (min-width: 36em) {
  .scroll-table {
    white-space: normal; } }
table {
  margin-top: 16px;
  padding: 0;
  min-width: 100%;
  margin-left: -8px;
  margin-right: -8px; }

table, tr, th, td {
  height: auto !important;
  border: none !important; }

th, td {
  padding: 0 8px 16px;
  word-wrap: break-word;
  vertical-align: top; }
  th img, td img {
    width: 100%; }

th {
  vertical-align: top;
  text-align: left;
  font-weight: normal; }

thead th, thead td {
  background: inherit;
  color: inherit;
  font-size: inherit;
  font-weight: bold; }

tfoot th, tfoot td {
  background: inherit;
  color: inherit;
  font-size: inherit;
  font-weight: bold; }

table.hyou {
  margin-left: 0;
  margin-right: 0;
  border: 1px solid #bdbdbd !important;
  border-collapse: collapse;
  border-spacing: 0;
  background: #fff; }
  table.hyou th, table.hyou td {
    padding: 8px 10px 10px;
    border: 1px solid #bdbdbd !important; }

table.tate {
  display: table; }

@media screen and (max-width: 47.9375em) {
  table.tate th, table.tate td {
    display: block;
    width: 100% !important; } }
table.box {
  display: table; }
  table.box th, table.box td {
    padding: 16px;
    background: #f7f7f7; }

th.gray, td.gray {
  background: #f7f7f7; }

th.beige, td.beige {
  background: #fffac6; }

table.table-30-70,
table.table-40-60,
table.table-50-50,
table.table-60-40,
table.table-70-30,
table.table-33-33-33 {
  display: table;
  min-width: 100%; }

@media screen and (min-width: 48em) {
  table.table-30-70 th:first-child, table.table-30-70 td:first-child {
    width: 30% !important; }

  table.table-40-60 th:first-child, table.table-40-60 td:first-child {
    width: 40% !important; }

  table.table-50-50 th:first-child, table.table-50-50 td:first-child {
    width: 50% !important; }

  table.table-60-40 th:first-child, table.table-60-40 td:first-child {
    width: 60% !important; }

  table.table-70-30 th:first-child, table.table-70-30 td:first-child {
    width: 70% !important; }

  table.table-33-33-33 th, table.table-33-33-33 td {
    width: 33.3333% !important; } }
.mce-content-body table {
  margin-left: 0 !important;
  margin-right: 0 !important;
  border-collapse: separate !important;
  border-spacing: 2px !important; }
.mce-content-body table, .mce-content-body th, .mce-content-body td, .mce-content-body caption {
  border: 1px dashed #BBB !important; }
.mce-content-body table.hyou {
  border: 1px solid #bdbdbd !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important; }
  .mce-content-body table.hyou th, .mce-content-body table.hyou td {
    border: 1px solid #bdbdbd !important; }

caption {
  margin: 0 0 8px;
  background: transparent;
  color: inherit;
  font-size: inherit;
  font-weight: bold;
  text-align: left; }

.table-borderless {
  border: none; }
  .table-borderless th, .table-borderless td {
    border: none; }

.table-striped tr:nth-child(even) th,
.table-striped tr:nth-child(even) td {
  background: #F0F0F0; }

/*動画の最大幅を指定する*/
.video-container {
  max-width: 100%; }

/*動画の大きさを調整*/
.video {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  height: auto; }

/*動画を囲んでいるdiv目一杯に広げる*/
.video iframe,
.video object,
.video embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

.widget {
  margin-bottom: 24px;
  /*
  &:first-child {
  	margin-top: 0;
  }
  */ }
  .widget ul {
    margin: 0;
    padding: 0;
    list-style: none; }
  .widget li {
    position: relative;
    margin: 0; }
  .widget a {
    display: block;
    position: relative;
    text-decoration: none; }
  .widget a:hover {
    text-decoration: none; }

.widget-title {
  margin: 0 0 12px;
  padding: 0;
  line-height: 1.5;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
  color: inherit; }

.widget_archive label,
.widget_categories label,
.widget_meta label,
.widget_nav_menu label,
.widget_pages label {
  display: none; }
.widget_archive a,
.widget_categories a,
.widget_meta a,
.widget_nav_menu a,
.widget_pages a {
  padding: 10px 10px 10px 1.5em;
  border: #bdbdbd solid;
  border-width: 0 0 1px; }
  .widget_archive a:before,
  .widget_categories a:before,
  .widget_meta a:before,
  .widget_nav_menu a:before,
  .widget_pages a:before {
    content: '\f105';
    position: absolute;
    margin-top: -7px;
    top: 50%;
    left: .5em;
    line-height: 1;
    font-family: "Font Awesome\ 5 Free";
    font-weight: 900;
    font-size: 14px;
    font-size: 0.875rem; }
  .widget_archive a span,
  .widget_categories a span,
  .widget_meta a span,
  .widget_nav_menu a span,
  .widget_pages a span {
    margin-left: .5em; }
.widget_archive .children a,
.widget_categories .children a,
.widget_meta .children a,
.widget_nav_menu .children a,
.widget_pages .children a {
  padding: 10px 10px 10px 2.2em; }
  .widget_archive .children a:before,
  .widget_categories .children a:before,
  .widget_meta .children a:before,
  .widget_nav_menu .children a:before,
  .widget_pages .children a:before {
    left: 1.5em; }

.widget_calendar table {
  width: 100%; }
.widget_calendar th, .widget_calendar td {
  padding: 4px 0;
  text-align: center;
  color: #000000; }
.widget_calendar thead th {
  background: #fff; }
.widget_calendar caption {
  margin: 0 0 8px; }

.widget_recent_comments li {
  padding: 8px 0;
  border-style: solid;
  border-color: #bdbdbd;
  border-width: 0 0 1px; }

.widget_recent_entries li {
  padding: 10px 0;
  border: #bdbdbd solid;
  border-width: 0 0 1px; }
  .widget_recent_entries li:first-child {
    padding: 0 0 10px; }
.widget_recent_entries .post-date {
  text-align: left;
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: normal; }

.widget_search .screen-reader-text {
  display: none; }
.widget_search .search-table {
  display: table;
  width: 100%; }
.widget_search .search-field,
.widget_search .search-button {
  display: table-cell;
  vertical-align: top; }
.widget_search .search-button {
  width: 40px; }
.widget_search .search-submit {
  padding: 0;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 0 4px 4px 0;
  background: #FF7600;
  color: #fff; }
.widget_search input {
  display: inline-block;
  margin: 0;
  padding: 0 16px;
  width: 100%;
  height: 40px;
  border-radius: 4px 0 0 4px; }

.widget_tag_cloud .tagcloud {
  overflow: hidden;
  vertical-align: bottom; }
.widget_tag_cloud a {
  display: inline-block;
  text-decoration: none; }
.widget_tag_cloud a:hover {
  text-decoration: none; }

.widget_sp_image {
  margin: 12px 0 0;
  position: relative; }
  .widget_sp_image:first-child {
    margin: 0; }
  .widget_sp_image img {
    margin: 0; }

p.margin-top-0 {
  margin-top: 0px; }

p.margin-top-4 {
  margin-top: 4px; }

p.margin-top-8 {
  margin-top: 8px; }

p.margin-top-12 {
  margin-top: 12px; }

img.img-20, img.img-30, img.img-40 {
  width: 100%; }

@media screen and (min-width: 48em) {
  img.img-20 {
    max-width: 20%; }

  img.img-30 {
    max-width: 30%; }

  img.img-40 {
    max-width: 40%; } }
img.img-sm,
img.img-pc {
  display: block; }

@media screen and (min-width: 48em) {
  img.img-sm {
    display: none; } }
@media screen and (max-width: 47.9375em) {
  img.img-pc {
    display: none; } }
table.table-sm,
table.table-pc {
  display: table; }

.alignleft {
  float: left;
  margin: 0 1.5em 1em 0; }

.alignright {
  float: right;
  margin: 0 0 1em 1.5em; }

.aligncenter {
  clear: both;
  display: block;
  margin: 0 auto 1em; }

img.alignleft,
img.alignright {
  margin: 0;
  max-width: none;
  width: 100%; }

img.alignleft {
  margin: 0 0 1em 0; }

img.alignright {
  margin: 0 0 1em 0; }

@media screen and (min-width: 48em) {
  img.alignleft,
  img.alignright {
    max-width: 50%;
    width: auto; }

  img.alignleft {
    float: left;
    margin: 0 1.5em 1em 0; }

  img.alignright {
    float: right;
    margin: 0 0 1em 1.5em; } }
.wp-caption {
  margin-bottom: 24px;
  max-width: 100%;
  width: auto !important; }
  .wp-caption img {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto; }
  @media screen and (min-width: 36em) {
    .wp-caption.alignleft, .wp-caption.alignright {
      max-width: 50%; } }

.wp-caption img[class*="wp-image-"] {
  display: block;
  margin: 0; }

.wp-caption .wp-caption-text {
  margin: 8px 0 0;
  color: #686868;
  font-size: 13px;
  font-size: 0.8125rem;
  font-style: normal;
  line-height: 1.66; }

.gallery {
  margin-left: -8px !important;
  margin-right: -8px !important; }

.gallery-item {
  padding: 0 8px; }

@media screen and (max-width: 47.9375em) {
  .gallery-item {
    width: 50% !important; } }
.gallery-caption {
  display: block;
  color: #686868;
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: 1.66;
  text-align: left; }

.bypostauthor {
  background: #F0F0F0; }

.img-full-width img {
  width: 100%;
  height: auto; }

.img-thumbnail {
  display: inline-block;
  padding: 4px;
  border: 4px solid #fff;
  border-radius: 4px; }

.img-rounded,
.img-rounded img {
  border-radius: 4px; }

.img-circle,
.img-circle img {
  border-radius: 50%; }

.image-brightness {
  background: inherit;
  opacity: 1;
  transition: all 0.3s 0s; }
  .image-brightness:hover {
    opacity: .8;
    transition: all 0.3s 0s; }

.image-zoom-in {
  overflow: hidden; }
  .image-zoom-in img {
    display: block;
    width: 100%;
    transition: all 0.3s 0s; }
  .image-zoom-in img:hover {
    transition: all 0.3s 0s;
    -moz-transform: scale(1.25);
    -webkit-transform: scale(1.25);
    -o-transform: scale(1.25);
    -ms-transform: scale(1.25); }

.image-zoom-out {
  overflow: hidden; }
  .image-zoom-out img {
    display: block;
    width: 100%;
    transition: all 0.3s 0s;
    -moz-transform: scale(1.25);
    -webkit-transform: scale(1.25);
    -o-transform: scale(1.25);
    -ms-transform: scale(1.25); }
  .image-zoom-out img:hover {
    transition: all 0.3s 0s;
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1); }

fieldset {
  margin: 24px 0;
  padding: 20px;
  border: 1px solid #bdbdbd;
  border-radius: 4px; }
  fieldset legend {
    margin: 0;
    padding: .5em;
    background: transparent;
    font-weight: bold;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1; }

[type="text"], [type="password"], [type="date"], [type="datetime"], [type="datetime-local"], [type="month"], [type="week"], [type="email"], [type="number"], [type="search"], [type="tel"], [type="time"], [type="url"], [type="color"],
textarea {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 0 16px;
  padding: 8px;
  border: 1px solid #bdbdbd;
  border-radius: 4px;
  background-color: #fff;
  color: inherit;
  font-family: inherit;
  font-size: 16px;
  font-size: 1rem;
  transition: all 0.3s 0s;
  -webkit-appearance: none;
  -moz-appearance: none; }
  [type="text"]:focus, [type="password"]:focus, [type="date"]:focus, [type="datetime"]:focus, [type="datetime-local"]:focus, [type="month"]:focus, [type="week"]:focus, [type="email"]:focus, [type="number"]:focus, [type="search"]:focus, [type="tel"]:focus, [type="time"]:focus, [type="url"]:focus, [type="color"]:focus,
  textarea:focus {
    box-shadow: 0 0 5px #868686;
    border: 1px solid #bdbdbd;
    background: #fafafa;
    outline: none;
    transition: all 0.3s 0s; }
  [type="text"]:disabled, [type="password"]:disabled, [type="date"]:disabled, [type="datetime"]:disabled, [type="datetime-local"]:disabled, [type="month"]:disabled, [type="week"]:disabled, [type="email"]:disabled, [type="number"]:disabled, [type="search"]:disabled, [type="tel"]:disabled, [type="time"]:disabled, [type="url"]:disabled, [type="color"]:disabled,
  textarea:disabled {
    background-color: #ffe4cc;
    cursor: not-allowed; }

textarea {
  max-width: 100%; }
  textarea[rows] {
    height: auto; }

input[disabled], input[readonly], fieldset[disabled] input,
textarea[disabled],
textarea[readonly],
fieldset[disabled] textarea {
  background-color: #ffe4cc;
  cursor: not-allowed; }

[type='submit'],
[type='button'] {
  border-radius: #ffe4cc;
  -webkit-appearance: none;
  -moz-appearance: none; }

[type='number'] {
  -moz-appearance: textfield; }

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0; }

select {
  width: auto;
  margin: 0 0 16px 0;
  padding: 8px;
  background-color: #fff;
  border: 1px solid #bdbdbd;
  border-radius: 4px;
  color: #000000;
  font-family: inherit;
  font-size: 16px;
  font-size: 1rem;
  line-height: normal;
  -webkit-appearance: none !important;
  -moz-appearance: none !important; }
  select:hover {
    border-color: #bdbdbd;
    background-color: #fff; }
  select:disabled {
    background-color: #ffe4cc;
    cursor: not-allowed; }
  select::-ms-expand {
    display: none; }

[type="file"],
[type="checkbox"],
[type="radio"] {
  margin: 0 0 16px; }

[type='checkbox'] + label,
[type='radio'] + label {
  display: inline-block;
  margin-left: 8px;
  margin-left: 16px;
  margin-bottom: 0;
  vertical-align: baseline; }

label > [type='checkbox'],
label > [type='label'] {
  margin-right: 8px; }

[type="file"] {
  width: 100%; }

label {
  display: block;
  margin-bottom: 8px;
  color: #444;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.66;
  cursor: pointer; }

.form-group dl {
  margin: 24px 0 0; }
  .form-group dl:first-child {
    margin: 0; }
.form-group dt {
  line-height: 1; }
.form-group .submit {
  margin-top: 24px;
  margin-bottom: 10px; }

.site-header {
  position: fixed;
  top: 0;
  z-index: 9999;
  width: 100%;
  box-shadow: rgba(0, 0, 0, 0.2) 0 1px 3px;
  background: #fff;
  transition: all 0.3s ease; }

.topbar {
  display: block;
  background: #F0F0F0; }

.site-description {
  float: left;
  margin: 0;
  padding: 8px 0;
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: normal; }

.header-main {
  position: relative; }

.site-logo {
  max-width: 80%;
  font-size: 16px;
  font-size: 1rem; }
  @media screen and (min-width: 48em) {
    .site-logo {
      max-width: 328px;
      font-size: 20px;
      font-size: 1.25rem; } }
  @media screen and (min-width: 62em) {
    .site-logo {
      max-width: 328px;
      font-size: 24px;
      font-size: 1.5rem; } }

@media screen and (min-width: 62em) {
  .header-right {
    max-width: 30%; } }

@media screen and (min-width: 62em) {
  .header3 .site-logo site-logo {
    max-width: 30%; }
  .header3 .menu-primary-wrap {
    float: right;
    max-width: 68%; } }
.site-logo {
  display: block;
  float: left;
  margin: 0;
  padding: 20px 0;
  line-height: 1.1;
  font-weight: bold; }
  .site-logo a {
    text-decoration: none; }
  .site-logo a:hover {
    text-decoration: none; }

.header-right {
  position: absolute;
  top: 50%;
  right: 1em;
  margin-top: -26px; }
  .header-right img {
    height: 52px; }

.header-contact {
  margin: 0;
  list-style: none;
  line-height: 1;
  text-align: right; }
  .header-contact .header-contact-tel {
    display: block;
    margin: 0;
    font-size: 28px;
    font-size: 1.75rem;
    font-weight: bold; }
    .header-contact .header-contact-tel .tel-link {
      color: #FF7600; }
    .header-contact .header-contact-tel a {
      color: #FF7600;
      text-decoration: none; }
    .header-contact .header-contact-tel i {
      margin-right: .1em;
      color: #FF7600; }
  .header-contact .header-contact-tel-tit {
    display: block;
    margin: 0 0 8px;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: 700; }
  .header-contact img {
    width: auto;
    min-height: 52px;
    max-height: 52px; }

.is-sticky .header-main {
  position: fixed;
  width: 100%;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.2) 0 1px 3px; }

@media screen and (min-width: 62em) {
  .is-sticky.header1 .menu-primary-wrap, .is-sticky.header2 .menu-primary-wrap {
    position: fixed;
    top: 0;
    left: 0;
    min-width: 100%;
    box-shadow: rgba(0, 0, 0, 0.2) 0 1px 3px; }
    .admin-bar .is-sticky.header1 .menu-primary-wrap, .admin-bar .is-sticky.header2 .menu-primary-wrap {
      top: 32px; } }
.topbar, .header-right, .menu-primary-wrap {
  display: none; }

.mobile-menu-btn, .menu-mobile-wrap {
  display: block; }

@media screen and (min-width: 62em) {
  .topbar, .header-right, .menu-primary-wrap {
    display: block; }

  .mobile-menu-btn, .menu-mobile-wrap {
    display: none; } }
@media screen and (min-width: 62em) {
  .is-sticky.header-default .topbar, .is-sticky.header-default .header-main, .is-sticky.header1 .topbar, .is-sticky.header1 .header-main, .is-sticky.header2 .topbar, .is-sticky.header2 .header-main {
    display: none; }
  .is-sticky.header3 .topbar {
    display: none; } }
.menu {
  list-style: none;
  margin: 0;
  padding: 0; }
  .menu ul {
    list-style: none;
    margin: 0;
    padding: 0; }
  .menu li {
    position: relative;
    margin: 0; }
  .menu a {
    display: block;
    text-decoration: none;
    white-space: normal; }
  .menu a:hover {
    text-decoration: none; }

.menu-primary-wrap {
  padding-top: 12px;
  background: #000;
  border-bottom: 4px solid #FF7600; }
  .menu-primary-wrap ul.menu {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-grow: 10;
    -moz-flex-grow: 10;
    -ms-flex-positive: 10;
    -ms-flex-grow: 10;
    flex-grow: 10;
    width: 100%; }
    .menu-primary-wrap ul.menu > li {
      -webkit-flex-grow: 1;
      -moz-flex-grow: 1;
      -ms-flex-positive: 1;
      -ms-flex-grow: 1;
      flex-grow: 1;
      text-align: center;
      padding: 0 .2em; }
      .menu-primary-wrap ul.menu > li > a {
        padding: 12px 4px;
        font-weight: bold;
        color: #fff;
        text-decoration: none; }
      .menu-primary-wrap ul.menu > li > a:hover, .menu-primary-wrap ul.menu > li.current-menu-item > a, .menu-primary-wrap ul.menu > li.current-page-ancestor > a, .menu-primary-wrap ul.menu > li.current-category-ancestor > a, .menu-primary-wrap ul.menu > li.current-menu-ancestor > a {
        background: #FF7600;
        color: #fff;
        text-decoration: none;
        border-radius: 6px 6px 0 0; }
  .menu-primary-wrap .sub-menu {
    visibility: hidden;
    opacity: 0;
    overflow: visible;
    position: absolute;
    top: 100%;
    left: 0;
    right: auto;
    z-index: 3000;
    transform: translateY(30px);
    min-width: 100%;
    width: auto;
    height: auto;
    background: #fff;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.15);
    transition: all 0.3s 0s; }
    li:last-child .menu-primary-wrap .sub-menu {
      right: 0;
      left: auto; }
    .menu-primary-wrap .sub-menu li {
      display: block;
      float: none;
      width: 100%;
      text-align: left; }
    .menu-primary-wrap .sub-menu a {
      padding: .5em 1em;
      white-space: nowrap;
      color: #000000;
      text-decoration: none; }
    .menu-primary-wrap .sub-menu a:hover {
      color: #000000;
      text-decoration: none;
      background: #F0F0F0; }
  .menu-primary-wrap li:hover .sub-menu {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
    transition: all 0.3s 0s; }

.header1 .menu-primary-wrap {
  background: #fff;
  border-bottom: 5px solid #FF7600; }
  .header1 .menu-primary-wrap ul.menu {
    margin-bottom: -5px; }
    .header1 .menu-primary-wrap ul.menu > li > a {
      padding: 12px 4px;
      font-weight: bold;
      color: #222;
      text-decoration: none;
      border-bottom: 5px solid transparent; }
    .header1 .menu-primary-wrap ul.menu > li > a:hover, .header1 .menu-primary-wrap ul.menu > li.current-menu-item > a, .header1 .menu-primary-wrap ul.menu > li.current-page-ancestor > a, .header1 .menu-primary-wrap ul.menu > li.current-category-ancestor > a, .header1 .menu-primary-wrap ul.menu > li.current-menu-ancestor > a {
      border-bottom: 5px solid #a7dae2;
      color: #FF7600;
      text-decoration: none; }

.header2 .menu-primary-wrap {
  background: #FF7600; }
  .header2 .menu-primary-wrap ul.menu > li > a {
    padding: 12px 4px;
    font-weight: bold;
    color: #fff;
    text-decoration: none; }
  .header2 .menu-primary-wrap ul.menu > li > a:hover, .header2 .menu-primary-wrap ul.menu > li.current-menu-item > a, .header2 .menu-primary-wrap ul.menu > li.current-page-ancestor > a, .header2 .menu-primary-wrap ul.menu > li.current-category-ancestor > a, .header2 .menu-primary-wrap ul.menu > li.current-menu-ancestor > a {
    background: #cfe5f0;
    color: #FF7600;
    text-decoration: none; }

.header3 .menu-primary-wrap {
  margin-top: 20px; }
  .header3 .menu-primary-wrap ul.menu > li > a {
    padding: 20px 8px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.3; }

.menu-secondary-container {
  float: right; }
  .menu-secondary-container .menu > li {
    float: left;
    text-align: center;
    margin-left: 2em; }
    .menu-secondary-container .menu > li > a {
      position: relative;
      padding: 8px 0 8px 1.2em;
      font-size: 12px;
      font-size: 0.75rem;
      font-weight: 700;
      color: #000000;
      text-decoration: none; }
      .menu-secondary-container .menu > li > a:hover {
        color: #000000;
        text-decoration: underline; }
      .menu-secondary-container .menu > li > a:before {
        display: inline-block;
        content: '・';
        position: absolute;
        top: .5em;
        left: 0;
        font-size: 13px;
        font-size: 0.8125rem; }

.mobile-menu-btn {
  position: absolute;
  top: 50%;
  right: 8px;
  margin-top: -22px;
  padding: 8px 8px 6px;
  border: none;
  border-radius: 4px;
  background: #FF7600;
  color: #FF7600;
  text-align: center; }

.mobile-menu-icon {
  display: block;
  margin-top: 0;
  margin-bottom: 4px; }
  .mobile-menu-icon .icon-bar {
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 24px;
    height: 2px;
    border-radius: 1px;
    background: #fff; }
    .mobile-menu-icon .icon-bar + .icon-bar {
      margin-top: 4px; }
    .mobile-menu-icon .icon-bar + .icon-bar + .icon-bar {
      margin-top: 4px; }

.mobile-menu-btn-name {
  display: block;
  color: #fff;
  font-size: 10px;
  font-size: 0.625rem;
  transform: scale(0.8);
  line-height: 1; }

.menu-mobile-wrap {
  position: relative;
  clear: both; }

.collapse {
  position: relative; }

.menu-mobile-dropdown {
  margin-left: -12px;
  margin-right: -12px; }

@media screen and (min-width: 48em) {
  .menu-mobile-dropdown {
    margin-left: -16px;
    margin-right: -16px; } }
.menu-mobile-dropdown {
  position: relative;
  z-index: 1000; }
  .menu-mobile-dropdown .menu {
    visibility: hidden;
    opacity: 0;
    backface-visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    clear: both;
    transform: translateY(30px);
    width: 100%;
    background: #fff;
    height: auto;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.15);
    transition: all 0.3s 0s; }
    @media screen and (min-width: 62em) {
      .menu-mobile-dropdown .menu {
        max-width: 600px; } }
  .menu-mobile-dropdown.active .menu {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
    transition: all 0.3s 0s; }
  .menu-mobile-dropdown a {
    padding: .5em 1em; }
  .menu-mobile-dropdown .sub-menu a {
    padding: .5em 1em .5em 2em; }

.menu-mobile-overlay {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 100;
  clear: both;
  width: 100%;
  height: 100%;
  padding: 10% 6%;
  background: rgba(1, 1, 1, 0.9);
  transition: all 0.3s 0s; }
  .menu-mobile-overlay.active {
    visibility: visible;
    overflow-y: scroll;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    opacity: 1;
    transition: all 0.3s 0s; }
    .menu-mobile-overlay.active .menu {
      overflow: auto; }
  .menu-mobile-overlay .menu {
    position: static;
    clear: both;
    padding: 40px 0;
    width: 100%;
    height: 100%; }
    .menu-mobile-overlay .menu li {
      line-height: 1.5;
      text-align: left; }
    .menu-mobile-overlay .menu a {
      position: relative;
      display: block;
      padding: .5em 1em .5em 2.2em;
      color: #fff;
      border-bottom: 1px solid #fff; }
      .menu-mobile-overlay .menu a:hover {
        color: #fff; }
      .menu-mobile-overlay .menu a:before {
        position: absolute;
        top: .6em;
        left: .6em;
        display: inline-block;
        content: '\f138';
        font-size: 14px;
        font-size: 0.875rem;
        font-family: "Font Awesome\ 5 Free";
        font-weight: 900;
        color: #fff; }
  .menu-mobile-overlay .sub-menu a {
    padding: .5em 1em .5em 2.2em; }
    .menu-mobile-overlay .sub-menu a:before {
      position: absolute;
      top: .6em;
      left: .9em;
      display: inline-block;
      content: '\f105';
      font-family: "Font Awesome\ 5 Free";
      font-weight: 900;
      color: #fff; }

.mobile-menu-close-btn {
  position: fixed;
  top: 2em;
  right: 1em;
  margin: auto;
  padding: .8em 1em;
  border: 1px solid #fff;
  border-radius: 4px;
  background: transparent;
  color: #fff;
  font-size: 15px;
  font-size: 0.9375rem; }

.page-header-image {
  position: relative; }
  .page-header-image img {
    width: 100%;
    max-width: none; }

.breadcrumb-wrap {
  padding-top: 16px;
  padding-bottom: 0; }

.breadcrumb {
  list-style: none;
  line-height: 1.2; }
  .breadcrumb li {
    display: inline-block; }
  .breadcrumb a {
    text-decoration: underline; }
  .breadcrumb a:hover {
    text-decoration: none; }

.bcn-nav-xt span {
  margin: 0 .2em; }

.bcn-nav-xt {
  color: #666666; }
  .bcn-nav-xt > span {
    margin: 0 .2em;
    font-size: 12px;
    font-size: 0.75rem;
    color: #000000; }
  .bcn-nav-xt a {
    color: #000000; }
  .bcn-nav-xt a:hover {
    color: #FF7600; }

.wrapper {
  overflow: hidden;
  position: relative; }

.site-main {
  position: relative;
  padding-top: 0;
  padding-bottom: 0; }

#contents {
  width: 100%;
  margin-bottom: 45px;
  padding-top: 24px; }

.sidebar {
  width: 100%;
  margin-bottom: 45px;
  padding-top: 24px; }

.home #contents {
  padding-top: 40px; }
.home .sidebar {
  padding-top: 40px; }

@media screen and (min-width: 48em) {
  #contents {
    width: 100%; }

  .sidebar-left #contents,
  .sidebar-right #contents {
    width: 72%; }

  .sidebar-left #contents {
    float: right; }

  .sidebar-right #contents {
    float: left; }

  .sidebar {
    float: left;
    width: 24%; }

  .sidebar-left .sidebar {
    float: left; }

  .sidebar-right #sidebar {
    float: right; } }
@media screen and (min-width: 48em) {
  table.table-sm {
    display: none; } }
@media screen and (max-width: 47.9375em) {
  table.table-pc {
    display: none; } }
#sidebar-bnr {
  margin-bottom: 45px; }

.sidebar-bnr-list {
  margin: 0;
  list-style: none; }

.sidebar-bnr {
  position: relative;
  margin-top: 12px; }
  .sidebar-bnr:first-child {
    margin: 0; }
  .sidebar-bnr a {
    display: block;
    position: relative;
    text-decoration: none; }
  .sidebar-bnr a:hover {
    text-decoration: none; }
  .sidebar-bnr .bnr-caption {
    position: absolute;
    top: 50%;
    left: 1em;
    font-weight: bold;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%); }
  .sidebar-bnr .bnr-bar-caption {
    display: block;
    padding: .2em .5em;
    background: #FF7600;
    color: #fff;
    text-decoration: none !important; }
    .sidebar-bnr .bnr-bar-caption:focus .sidebar-bnr .bnr-bar-caption {
      text-decoration: none; }
  .sidebar-bnr img {
    max-width: none;
    width: 100%; }

/*
.sidebar-bnr {
	border-left: 5px solid $color-primary;
	background: rgb(255,255,255);
	background: -moz-linear-gradient(top, rgba(255,255,255,1) 0%, rgba(237,239,240,1) 100%);	background: -webkit-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(237,239,240,1) 100%);
	background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(237,239,240,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#edeff0',GradientType=0 ); 
	width: 100%;
	height: 100%;

	a {
		position: relative;
		display: block;
		padding: 0 10px;
		border: 1px solid #edeff0;
		vertical-align: middle;
		@include font-size(18);
		font-weight: bold;
		color: $color-primary;
		line-height: 1.5;
		text-decoration: none;
	}
	a:hover {
		color: $color-primary;
		text-decoration: none;
	}
	span {
		display: table-cell;
		width: 100%;
		height: 78px;
		vertical-align: middle;
	}
}


.sidebar-bnr-1 {
	a {
		background: url(images/common/sidebar-bnr-img1.png) no-repeat 137% 11%;
	}
}

.sidebar-bnr-2 {
	a {
		background: url(images/common/sidebar-bnr-img2.png) no-repeat 170% center;
	}
}
*/
.sidebar-widget {
  margin-bottom: 45px; }

.sidebar-widget-column {
  margin-top: 45px; }
  .sidebar-widget-column:first-child {
    margin-top: 0; }

.sidebar-local-menu {
  margin: 0 0 32px;
  background: #fff; }
  .sidebar-local-menu .sidebar-local-menu-heading {
    margin: 0 0;
    padding: 4px 4px 0;
    color: #000;
    font-size: 18px;
    font-size: 1.125rem;
    font-weight: bold; }
    .sidebar-local-menu .sidebar-local-menu-heading a {
      display: block;
      padding: .3em .5em;
      text-decoration: none;
      color: #000; }
    .sidebar-local-menu .sidebar-local-menu-heading a:hover {
      text-decoration: none;
      color: #000; }
  .sidebar-local-menu ul {
    margin: 0;
    padding: 0;
    list-style: none; }
    .sidebar-local-menu ul li {
      position: relative;
      margin: 0;
      padding: 0;
      border-top: 1px solid #fff; }
    .sidebar-local-menu ul a {
      position: relative;
      display: block;
      padding: .7em 1em .6em 1em;
      text-decoration: none;
      font-size: 16px;
      font-size: 1rem;
      line-height: 1.2;
      background: #000;
      border-radius: 3px;
      color: #fff; }
    .sidebar-local-menu ul a:hover {
      text-decoration: none;
      background-color: #000;
      color: #fff; }
    .sidebar-local-menu ul .current_page_item > a, .sidebar-local-menu ul .current-cat > a {
      background-color: #F0F0F0;
      color: #000; }
  .sidebar-local-menu .children {
    border: none; }
    .sidebar-local-menu .children li {
      border: dashed #000;
      border-width: 1px 0 0; }
      .sidebar-local-menu .children li:first-child {
        border: none; }
      .sidebar-local-menu .children li:last-child {
        padding: 0; }
    .sidebar-local-menu .children a {
      padding: .7em 1em .6em 2em;
      background: #fff;
      color: #000; }
      .sidebar-local-menu .children a:before {
        position: absolute;
        top: 1.1em;
        left: 1.2em;
        display: inline-block;
        content: '・';
        font-size: 13px;
        font-size: 0.8125rem;
        line-height: 1; }
    .sidebar-local-menu .children a:hover {
      background: #EDEFF1;
      color: #000; }
    .sidebar-local-menu .children .current_page_item > a, .sidebar-local-menu .children .current-cat > a {
      background: #EDEFF1;
      color: #000; }

.sidebar-contact {
  display: block;
  margin: 0px 0px 32px 0px;
  border: 1px solid #bdbdbd;
  background: #fff;
  font-size: 16px;
  font-size: 1rem; }
  @media screen and (max-width: 61.9375em) {
    .sidebar-contact {
      display: none; } }

.sidebar-contact-header {
  margin: 0 0 10px;
  padding: .8em .5em;
  background: #000;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  text-align: center; }

.sidebar-contact-body {
  padding: 16px 16px; }
  .sidebar-contact-body .company-name {
    margin: 0 0 0;
    font-weight: 500;
    font-size: 20px;
    font-size: 1.25rem;
    line-height: 1; }
  .sidebar-contact-body .company-tel {
    margin: 8px 0 0;
    color: #000;
    font-size: 26px;
    font-size: 1.625rem;
    font-weight: bold;
    line-height: 1; }
    .sidebar-contact-body .company-tel i {
      margin-right: .1em; }
  .sidebar-contact-body .company-postcode {
    display: block;
    margin: 0;
    font-size: 14px;
    font-size: 0.875rem; }
  .sidebar-contact-body .company-address {
    margin: 12px 0 0;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.4; }
  .sidebar-contact-body .company-fax {
    margin: 12px 0 0;
    line-height: 1;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    line-height: 1;
    color: #000; }
    .sidebar-contact-body .company-fax i {
      margin-right: .2em;
      font-size: 20px; }
  .sidebar-contact-body .company-mail {
    margin: 12px 0 0;
    font-size: 14px;
    font-size: 0.875rem; }
    .sidebar-contact-body .company-mail a {
      text-decoration: none;
      color: #000; }
    .sidebar-contact-body .company-mail a:hover {
      color: #000;
      text-decoration: none; }
    .sidebar-contact-body .company-mail i {
      margin-right: .2em;
      font-size: 20px; }
  .sidebar-contact-body .sidebar-contact-btn-wrap {
    margin: 12px 0 0; }
  .sidebar-contact-body .sidebar-contact-btn {
    display: block;
    margin: 0 0 0;
    padding: .7em 0;
    background: #FF7600;
    width: 100%;
    color: #fff;
    text-decoration: none;
    text-align: center; }
    .sidebar-contact-body .sidebar-contact-btn:hover {
      background: #cc5e00;
      color: #fff;
      text-decoration: none; }
    .sidebar-contact-body .sidebar-contact-btn i {
      margin-right: .2em;
      font-size: 20px; }

.site-footer-label {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 1px;
  height: 1px; }

.footer-contact-wrapper {
  padding: 0 0 62px;
  color: #000000; }

.footer-contact-heading {
  margin: 0 0;
  padding: 15px 0;
  text-align: center;
  background: #000;
  color: #fff;
  font-size: 20px;
  font-size: 1.25rem; }
  .footer-contact-heading span {
    display: block;
    margin-top: 16px;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: normal;
    line-height: 1.66; }

@media screen and (min-width: 48em) {
  .footer-contact-heading {
    font-size: 30px;
    font-size: 1.875rem; }
    .footer-contact-heading span {
      font-size: 14px;
      font-size: 0.875rem; } }
.footer-contact-column {
  margin-top: 36px; }
  .footer-contact-column:first-child {
    margin-top: 0; }

@media screen and (min-width: 48em) {
  .footer-contact-column {
    margin-top: 0; } }
.footer-contact-body {
  padding: 20px;
  background: #F0F0F0; }
  .footer-contact-body .row {
    display: flex;
    flex-wrap: wrap; }
  .footer-contact-body h4 {
    margin: 0 0 10px;
    font-size: 16px;
    font-size: 1rem;
    font-weight: 500; }
  .footer-contact-body .contact-tel, .footer-contact-body .contact-fax, .footer-contact-body .contact-mail {
    text-align: center; }
  .footer-contact-body .tel-number {
    margin: 0 0 10px;
    padding: 10px 0 0;
    font-size: 28px;
    font-size: 1.75rem;
    font-weight: bold;
    line-height: 1;
    color: #000000; }
    @media screen and (min-width: 62em) {
      .footer-contact-body .tel-number {
        font-size: 32px;
        font-size: 2rem; } }
    .footer-contact-body .tel-number i {
      margin-right: .1em; }
  .footer-contact-body .tel a {
    color: #000000;
    text-decoration: none; }
  .footer-contact-body .tel a:hover {
    color: #000000;
    text-decoration: none; }
  .footer-contact-body .tel-reception {
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: normal;
    line-height: 1; }
  .footer-contact-body .btn-contact {
    display: block;
    padding: 18px 0;
    background: #FF7600;
    font-size: 19px;
    font-size: 1.1875rem;
    color: #fff;
    line-height: 1;
    text-align: center;
    text-decoration: none; }
    .footer-contact-body .btn-contact:hover {
      background: #A00000;
      text-decoration: none; }
    .footer-contact-body .btn-contact i {
      position: relative;
      top: 1px;
      margin-right: .2em;
      font-size: 23px;
      font-size: 1.4375rem; }

@media screen and (min-width: 48em) {
  .footer-contact-body {
    padding: 40px 70px; }

  .footer-contact-column {
    width: 33.3333%; } }
.site-footer {
  background: #F0F0F0; }

.footer-widget-area {
  padding: 40px 0; }

.footer-main {
  padding: 60px 0 60px; }

.footer-information {
  margin-bottom: 24px;
  font-size: 14px;
  font-size: 0.875rem; }
  .footer-information .company-name {
    margin: 4px 0 12px;
    font-size: 18px;
    font-size: 1.125rem;
    font-weight: bold;
    line-height: 1.6; }
  .footer-information .company-postcode {
    display: block; }
  .footer-information .company-address {
    margin: 0; }
  .footer-information .company-tel {
    margin: 0; }
    .footer-information .company-tel .tel a {
      text-decoration: none; }
    .footer-information .company-tel .tel a:hover {
      text-decoration: none; }
  .footer-information .company-fax {
    margin: 0; }
  .footer-information .company-mail {
    margin: 0; }
    .footer-information .company-mail a {
      color: #000000;
      line-height: 1;
      text-decoration: underline; }
    .footer-information .company-mail a:hover {
      color: #000000;
      text-decoration: none; }

.footer-nav a {
  position: relative;
  display: block;
  margin: 0 0 8px;
  padding: 0 1em 0 1em;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.4;
  text-decoration: none;
  color: #000000; }
  .footer-nav a:before {
    position: absolute;
    top: .15em;
    left: 0;
    display: inline-block;
    content: '・';
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: 1; }
.footer-nav a:hover {
  color: #000000;
  text-decoration: underline; }
.footer-nav .sub-menu a {
  padding: 0 1em 0 1.5em; }
  .footer-nav .sub-menu a:before {
    position: absolute;
    top: .1em;
    left: .3em;
    display: inline-block;
    content: '\f105';
    font-size: 14px;
    font-size: 0.875rem;
    font-family: "Font Awesome\ 5 Free";
    font-weight: 900;
    color: #fff;
    line-height: 1; }

.footer-copyright {
  padding: 10px 0;
  border-top: 1px solid #000000;
  text-align: center; }
  .footer-copyright a {
    color: #000000;
    text-decoration: none; }
  .footer-copyright a:hover {
    color: #000000;
    text-decoration: none; }

@media screen and (max-width: 47.9375em) {
  .footer-widget-column {
    margin-top: 45px; }
    .footer-widget-column:first-child {
      margin-top: 0; } }
.pagetop {
  position: fixed;
  right: 1em;
  bottom: 1em;
  text-align: center;
  width: 60px; }
  .pagetop a {
    display: block;
    text-decoration: none; }
  .pagetop a:hover {
    text-decoration: none; }

.pagination {
  margin-top: 24px;
  margin-bottom: 24px;
  text-align: center; }
  .pagination ul {
    list-style: none;
    display: inline-block;
    margin: 0; }
  .pagination li {
    float: left;
    margin: 0 2px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1; }
    .pagination li a {
      display: block;
      padding: 10px 12px;
      border: 1px solid #bdbdbd;
      border-radius: 4px;
      color: #FF7600;
      text-decoration: none; }
    .pagination li a:hover {
      border-color: #FF7600;
      background: #FF7600;
      color: #fff; }
    .pagination li.current {
      padding: 10px 12px;
      border: 1px solid #FF7600;
      border-radius: 4px;
      background: #FF7600;
      color: #fff;
      font-weight: bold; }
    .pagination li.page-numbers {
      padding: 10px 12px;
      border: 1px solid #bdbdbd;
      border-radius: 4px;
      color: #666666;
      text-decoration: none; }
    .pagination li.first a, .pagination li.previous a, .pagination li.next a, .pagination li.last a {
      border: 1px solid #bdbdbd;
      border-radius: 4px; }

.pager {
  margin: 24px 24px; }
  .pager ul {
    padding-left: 0;
    margin: 20px 0;
    text-align: center;
    list-style: none;
    line-height: 1; }
  .pager li {
    display: inline-block;
    margin: 0; }
  .pager a {
    display: inline-block;
    padding: 10px 12px;
    background-color: #fff;
    border: 1px solid #bdbdbd;
    border-radius: 4px;
    text-decoration: none;
    color: #FF7600; }
  .pager a:hover {
    border-color: #FF7600;
    background: #FF7600;
    color: #fff; }

.metaslider {
  width: 100% !important;
  max-width: 100% !important; }

#slider {
  position: relative; }
  #slider:before {
    content: "";
    display: block;
    visibility: hidden; }
  @media screen and (min-width: 48em) {
    #slider .caption-wrap {
      position: absolute;
      top: 50%;
      bottom: auto;
      -webkit-transform: translateY(-50%);
      /* Safari用 */
      transform: translateY(-50%);
      width: 100%;
      background: none; }
    #slider .caption {
      max-width: 640px;
      margin-left: auto;
      margin-right: auto;
      padding: 40px;
      background: #000;
      color: #fff;
      font-size: 24px;
      font-size: 1.5rem;
      line-height: 1.5;
      text-align: center; } }

.section {
  padding-top: 80px;
  padding-bottom: 80px; }

.btn-wrap {
  text-align: center; }

.btn01 {
  display: inline-block;
  padding: 10px 0;
  border: 1px solid #000;
  min-width: 90%;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  color: #000;
  text-decoration: none;
  border-radius: 30px; }
  .btn01 i {
    margin-right: .5em; }
  .btn01:hover {
    border: 1px solid #FF7600;
    background: #FF7600;
    color: #fff;
    text-decoration: none; }

@media screen and (min-width: 48em) {
  .btn01 {
    min-width: 402px;
    font-size: 24px; } }
#asset {
  margin-left: -200%;
  margin-right: -200%;
  padding-left: 200%;
  padding-right: 200%;
  background: #f0f0f0; }
  #asset .ttl01 span {
    background: #f0f0f0; }
  #asset .list {
    display: flex;
    flex-wrap: wrap;
    margin-left: -14px;
    margin-right: -14px; }
  #asset .item {
    margin-bottom: 48px;
    padding-left: 14px;
    padding-right: 14px;
    width: 100%; }
    #asset .item a {
      color: #000;
      text-decoration: none; }
    #asset .item a:hover {
      color: #666;
      text-decoration: none; }
    #asset .item .img {
      margin-bottom: 16px; }
    #asset .item p {
      font-size: 24px;
      font-weight: 700;
      line-height: 1.4; }
  #asset .inner {
    padding: 10px;
    background: #fff;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.4);
    text-align: center; }

@media screen and (min-width: 48em) {
  #asset .item {
    width: 33.33333%; }
    #asset .item p {
      font-size: 21px;
      font-weight: 700; } }
@media screen and (min-width: 62em) {
  #asset .item {
    width: 33.33333%; }
    #asset .item p {
      font-size: 24px;
      font-weight: 700; } }
.product-list {
  display: flex;
  flex-wrap: wrap;
  margin-left: -14px;
  margin-right: -14px; }

.product-item {
  margin-bottom: 24px;
  padding-left: 14px;
  padding-right: 14px;
  width: 50%; }
  .product-item a {
    color: #000;
    text-decoration: none; }
  .product-item a:hover {
    color: #FF7600;
    text-decoration: none; }
  .product-item h3 {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    font-size: 16px; }
    .product-item h3:before {
      content: '\025b6';
      margin-right: .1em; }

@media screen and (min-width: 62em) {
  .product-item {
    width: 25%; } }
#bnr-area {
  margin-left: -200%;
  margin-right: -200%;
  padding-left: 200%;
  padding-right: 200%;
  background: #f0f0f0; }
  #bnr-area .list {
    display: flex;
    flex-wrap: wrap;
    margin-left: -14px;
    margin-right: -14px; }
  #bnr-area .item {
    margin-bottom: 24px;
    padding-left: 14px;
    padding-right: 14px;
    width: 100%; }
  #bnr-area .img a {
    position: relative;
    display: block; }

@media screen and (min-width: 48em) {
  #bnr-area .item {
    margin-bottom: 0;
    width: 50%; } }
#topics {
  max-width: 750px;
  margin-left: auto;
  margin-right: auto; }
  #topics h2 {
    position: relative;
    margin: 0;
    color: #fff;
    background-color: #000;
    padding: 10px 10px 10px 27px;
    border-left: 14px solid #ff7600;
    font-size: 26px;
    font-weight: 700; }
    #topics h2:before {
      content: '';
      display: block;
      width: 7px;
      height: 100%;
      position: absolute;
      top: 50%;
      left: 7px;
      background: #FF7600;
      transform: translateY(-50%); }

.topics-list {
  padding: 20px 20px;
  border: solid #000;
  border-width: 1px 1px 1px; }

.topics-item {
  margin-bottom: 8px;
  padding: .8em 12px;
  border-bottom: 1px solid #A3A3A3; }
  .topics-item:before, .topics-item:after {
    content: " ";
    display: table; }
  .topics-item:after {
    clear: both; }

.topics-date {
  color: #000; }
  .topics-date:before {
    display: inline-block;
    margin-right: .5em;
    content: '\025b6';
    color: #FF7600; }

.topics-text {
  margin: 0; }

@media screen and (min-width: 48em) {
  .topics-list {
    padding: 20px 32px; }

  .topics-item {
    padding: .8em 25px; }

  .topics-date {
    float: left;
    width: 10em;
    font-size: 15px; }

  .topics-text {
    padding-left: 12em;
    font-size: 15px; } }
.page .product-list {
  margin-top: 40px;
  margin-bottom: 14px; }
  .page .product-list h3 {
    font-size: 14px; }

.contents-page .product-item {
  width: 50%; }
  @media screen and (min-width: 48em) {
    .contents-page .product-item {
      width: 33.3333%; } }

.faq-item {
  padding: 16px 0;
  border: solid #bdbdbd;
  border-width: 0 0 1px; }

.faq-title {
  margin: 40px 0 16px; }

.faq-question p, .faq-answer p {
  margin-left: 2em;
  margin-top: 0; }

.faq-question {
  margin-bottom: 16px;
  font-weight: bold; }

.question-mark, .answer-mark {
  float: left;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: bold;
  color: #FF7600;
  line-height: 1; }

.faq-link {
  margin-top: 24px;
  text-align: right; }

.faq-accordion .faq-item {
  margin: 0 0 24px;
  padding: 0;
  border: solid #bdbdbd;
  border-width: 1px; }
.faq-accordion .faq-question {
  position: relative;
  margin: 0;
  padding: .8em 1em;
  border: none;
  background: #F0F0F0; }
  .faq-accordion .faq-question:after {
    position: absolute;
    top: 50%;
    right: 1em;
    content: "+";
    margin-top: -12px;
    background: #FF7600;
    border-radius: 50%;
    color: #fff;
    width: 24px;
    line-height: 24px;
    text-align: center; }
  .faq-accordion .faq-question.active:after {
    content: "-"; }
  .faq-accordion .faq-question p {
    margin: 0 2.2em 0 2em; }
.faq-accordion .faq-answer {
  display: none;
  padding: .8em 1em;
  border: solid #bdbdbd;
  border-width: 1px 0 0; }

.btn-404 {
  font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "Meiryo UI", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important; }

.sticky {
  padding: 18px 20px; }

.contents-archive article {
  margin: 0 0 64px; }
.contents-archive .post-thumbnail {
  margin: 0 0 24px; }
  .contents-archive .post-thumbnail img {
    width: 100%; }
.contents-archive .post-content .entry-title {
  margin: 0 0 16px;
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold; }
.contents-archive .meta-info {
  margin: 0 0 16px;
  font-size: 13px;
  font-size: 0.8125rem; }
.contents-archive .entry-summary {
  margin: 0 0 16px; }
  .contents-archive .entry-summary p {
    margin: 0; }
.contents-archive .more-link {
  text-align: right; }

@media screen and (min-width: 48em) {
  .contents-archive .post-thumbnail {
    float: left;
    width: 290px;
    margin: 0 24px 0 0; }
    .contents-archive .post-thumbnail img {
      width: 100%; }
  .contents-archive .post-content {
    overflow: hidden; }
    .contents-archive .post-content .entry-title {
      margin: 0 0 16px;
      font-size: 16px;
      font-size: 1rem;
      font-weight: bold; } }

/*# sourceMappingURL=theme.css.map */
