@charset "UTF-8";
/*
	@include sc(pc) {
		width: 100%;
	}
	@include sc(sp) {
		width: 50%;
	}
*/
/*
	@include hover() {
		opacity: 0.6;
	}
*/
/*
	$line:イラレの行の値
	$size:イラレの文字の値

	@include lh(38, 15);
*/
/*
	$size:object-fitの値

	@include objectfit();
	@include objectfit('contain');
*/
/*
	@include taJ();
*/
/*
	@extend %rightarr;
*/
/*
@mixin f_roboto($weight:400) {
	font-family: 'Roboto',"游ゴシック","游ゴシック体","Yu Gothic",YuGothic, sans-serif;
	font-weight:$weight;
}
Robotoフォント設定
400：Regular（デフォルト）
500：Medium
700：Bold
*/
/*
	$weight:フォントの太さ

	@include f_min();
	@include f_min(500);
	@include f_min(600);
*/
/*
	$color:色指定
	$stripe:線サイズ
	$spacing:線の空きサイズ
	$height:太さ

	@include dotted(#e6e1d2, 4,4,2);
*/
/*
example
@include dotted-y(#COLOR, WidthPX,SpaceingPX,LengthPX,); 横破線
@include dotted-y(#e6e1d2, 4,4,2,10);
*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto+Serif+JP:wght@400;500;700&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Overpass:wght@100;300;400;500;600;700&display=swap");
.Note_Sans_JP {
  font-family: 'Noto Sans JP', sans-serif; }

.Note_Serif_JP {
  font-family: 'Noto Serif JP', serif; }

.zen_kaku_Gothic_New {
  font-family: 'Zen Kaku Gothic New', sans-serif; }

.Overpass {
  font-family: 'Overpass', sans-serif; }

html {
  font-size: 100px;
  /* SP */ }
  html.ie {
    font-family: "メイリオ","Meiryo","游ゴシック","游ゴシック体","Yu Gothic",YuGothic,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",verdana,"Osaka",sans-serif; }
  html.not-ie {
    font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro","游ゴシック","游ゴシック体","Yu Gothic",YuGothic,verdana,"メイリオ","Meiryo","Osaka",sans-serif;
    /*font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;*/
    font-feature-settings: "palt"; }
  @media print, screen and (min-width: 641px) {
    html {
      line-height: 1.5; } }
  @media screen and (max-width: 640px) {
    html {
      -webkit-text-size-adjust: 100%; } }
  @media print, screen and (min-width: 1440px) and (max-width: 1599px) {
    html {
      font-size: 90px; } }
  @media print, screen and (min-width: 1366px) and (max-width: 1439px) {
    html {
      font-size: 85px; } }
  @media print, screen and (min-width: 1280px) and (max-width: 1365px) {
    html {
      font-size: 80px; } }
  @media print, screen and (min-width: 641px) and (max-width: 1279px) {
    html {
      font-size: 75px; } }
  @media screen and (min-width: 428px) and (max-width: 640px) {
    html {
      /* SP： 428px から 640pxの間 ※6.7inch(iPhone12ProMax) */
      font-size: 114px; } }
  @media screen and (min-width: 414px) and (max-width: 427px) {
    html {
      /* SP： 414px から 427pxの間 ※iPhone6 Plus・6s Plus・7 Plus・8 Plus・XR・11・XS Max・11 Pro Max */
      font-size: 110px; } }
  @media screen and (min-width: 375px) and (max-width: 413px) {
    html {
      /* SP： 375px から 413pxの間 ※iPhone6・6s・7・8・SE(2)・X・XS・11 Pro */
      /* 基本 */
      font-size: 100px; } }
  @media screen and (min-width: 360px) and (max-width: 374px) {
    html {
      /* SP： 360px から 374pxの間 ※小さめAndroid */
      font-size: 96px; } }
  @media screen and (max-width: 359px) {
    html {
      /* SP： 359px以下 ※iPhone 5・5s・SE(1) */
      font-size: 85px; } }
  html.edge {
    -ms-text-size-adjust: 100%; }
  html.os-mac {
    -webkit-font-smoothing: antialiased; }
    @media print, screen and (min-width: 641px) {
      html.os-mac {
        font-feature-settings: "pkna"; } }
  html.scrollingFlg {
    pointer-events: none; }

body {
  position: relative;
  margin: 0;
  padding: 0;
  font-size: .11rem;
  background-color: #F2F2F2; }
  @media print, screen and (min-width: 641px) {
    body {
      min-width: 1024px; } }

.touchevents * {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

.chrome body {
  image-rendering: -webkit-optimize-contrast; }

h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li, td, th, figure {
  margin: 0;
  padding: 0; }

article, aside, footer, header, main, nav, section, figcaption, figure {
  display: block; }

html :where(img) {
    height: auto;
    max-width: 100%;
}

img {
  -ms-interpolation-mode: bicubic;
  border-style: none; }

svg:not(:root) {
  overflow: hidden; }

hr {
  height: 0;
  overflow: visible;
  box-sizing: border-box; }

b, strong {
  font-weight: inherit;
  font-weight: bolder; }

a {
  outline: 0;
  text-decoration: none;
  color: inherit;
  background-color: transparent;
  -webkit-text-decoration-skip: objects; }

li {
  list-style: none; }

sub, sup {
  position: relative;
  vertical-align: baseline;
  line-height: 0; }

sub {
  bottom: -.25em; }

sup {
  top: -.5em; }

audio, video {
  display: inline-block; }

audio:not([controls]) {
  display: none;
  height: 0; }

canvas {
  display: inline-block; }

/*input,select,button,optgroup,textarea {
	font-family: inherit;
    appearance: none;
	background: none;
	border:none;
	outline: 0;
	margin:0;
	padding:0;
}*/
button, input {
  overflow: visible; }

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

button:-moz-focusring,
input:-moz-focusring {
  outline: 1px dotted ButtonText; }

button, select {
  cursor: pointer;
  text-transform: none; }

[type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner, button::-moz-focus-inner {
  border: none; }

select::-ms-expand {
  display: none; }

/* プリント対応 */
[data-hidePrintMessageArea] {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  pointer-events: none;
  opacity: 0; }

@media print {
  body {
    position: relative;
    top: 100px; }

  body:before {
    content: "ページを印刷する際は一番下までスクロールして下さい。";
    display: none;
    white-space: pre;
    font-size: 20px;
    padding: 10px 10px;
    border: 3px solid #000;
    background-color: #FFF;
    color: #000;
    position: absolute;
    top: -100px;
    left: 0px;
    right: 0px;
    text-align: center;
    box-sizing: border-box; }

  .chrome body:before {
    content: "ページを印刷する際は一番下までスクロールして下さい。\A画像を表示させる場合は、「基本設定」→「背景のグラフィック」を有効にして下さい。"; }

  .ie body:before {
    content: "ページを印刷する際は一番下までスクロールして下さい。\A画像を表示させる場合は、「印刷プレビュー」→「ページ設定」→「背景の色とイメージを印刷する」を有効にして下さい。"; }

  .safari body:before {
    content: "ページを印刷する際は一番下までスクロールして下さい。\A画像を表示させる場合は、「詳細を表示」→「背景をプリント」を有効にして下さい。"; }

  .edge body:before {
    content: "※Microsoft Edgeは背景や画像を印刷できません。"; }

  .addPrintMessage body:before {
    display: block; }

  * {
    background-attachment: scroll !important; } }
/* 721px以上は消す */
@media print, screen and (min-width: 641px) {
  [data-sc-sp] {
    display: none !important; } }
/* 720px以下は消す */
@media screen and (max-width: 640px) {
  [data-sc-pc] {
    display: none !important; } }
@media screen and (max-width: 640px) {
  .mod_main {
    overflow: hidden; } }
.device-tablet .mod_main {
  width: calc(100% + 1px); }

/* 自動高さ調整 */
[data-autoheight],
[data-pc-autoheight],
[data-sp-autoheight] {
  transition: none !important; }

/* 遅延読み込み */
[data-lf] {
  opacity: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  transition: opacity 1s; }

[data-lf][src],
[data-lf][style*="background-image"],
[data-lf].load_view {
  opacity: 1; }

.flowbottomSP {
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: space-between;
  text-align: center;
  transition: transform 1.0s;
  transform: translateY(100%);
  z-index: 999; }
  .flowbottomSP.active {
    transform: none; }
  .flowbottomSP .col {
    width: 50%; }
    .flowbottomSP .col a {
      display: flex;
      vertical-align: bottom; }
      .flowbottomSP .col a img {
        width: 100%;
        height: auto; }

.flowbottomSPinview {
  position: absolute;
  top: 105vh;
  bottom: 0;
  pointer-events: none;
  width: 0; }

/* ページトップボタン */
.pagetopbtn {
  position: fixed;
  bottom: 60px;
  right: 10px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  filter: opacity(0%);
  pointer-events: none;
  transition: filter 1.0s, opacity 0.2s;
  background-color: #fff;
  z-index: 999; }
  .pagetopbtn:before {
    content: "";
    display: block;
    position: absolute;
    top: 7px;
    bottom: 0;
    right: 0;
    left: 0;
    width: 12px;
    height: 12px;
    margin: auto;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    transform: rotate(-45deg); }
  .pagetopbtn.active {
    filter: opacity(100%);
    pointer-events: auto; }
  .no-touchevents .pagetopbtn:hover {
    opacity: 0.6; }

.pagetopbtnInview {
  position: absolute;
  top: 200vh;
  bottom: 0;
  pointer-events: none;
  width: 0; }

/* ヘッダー */
.mod_header {
  width: 100%; }
  .mod_header .row01 {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    box-sizing: border-box;
    z-index: 1000;
    padding: 24px; }
    @media screen and (max-width: 640px) {
      .mod_header .row01 {
        padding: 0; } }
    .mod_header .row01 .in {
      width: 100%;
      /*max-width: 1200px;*/
      height: 60px;
      margin: auto;
      display: flex;
      align-items: center;
      justify-content: space-between; }
      @media screen and (max-width: 640px) {
        .mod_header .row01 .in {
          height: 60px; } }
    .mod_header .row01 .logo {
      display: block; }
      @media screen and (max-width: 640px) {
        .mod_header .row01 .logo {
          padding: 8% 0 0 8%; } }
      .mod_header .row01 .logo svg {
        width: 136px;
        height: auto; }
        .mod_header .row01 .logo svg .cls-1 {
          fill: #FFF; }
        @media screen and (max-width: 640px) {
          .mod_header .row01 .logo svg {
            width: auto;
            height: 38px; }
            .spmenuopen .mod_header .row01 .logo svg .cls-1 {
              fill: #333; } }
    .mod_header .row01 .link {
      width: auto;
      max-width: 950px;
      height: 100px;
      padding: 20px 30px 20px 30px;
      box-sizing: border-box;
      border-radius: 0 0 0 10px;
      background-color: #FFF;
      display: flex;
      align-items: center;
      position: absolute;
      top: 0;
      right: 0;
      z-index: 100; }
      .mod_header .row01 .link .link_l {
        height: 60px;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-end;
        align-items: center;
        width: 640px;
        margin-right: 30px; }
        .mod_header .row01 .link .link_l .link_up {
          width: 100%;
          display: flex;
          justify-content: flex-end; }
          .mod_header .row01 .link .link_l .link_up a {
            display: inline-block;
            padding: 0 16px;
            font-family: 'Noto Sans JP', sans-serif;
            font-size: 14px;
            font-weight: 500; }
        .mod_header .row01 .link .link_l .link_do {
          width: 100%;
          display: flex;
          justify-content: flex-end; }
      .mod_header .row01 .link .link_r {
        width: 220px; }
        .mod_header .row01 .link .link_r a {
          position: relative; }
          .mod_header .row01 .link .link_r a:after {
            content: '';
            width: 14px;
            height: 100%;
            background-image: url(../../common/img/arrow.png);
            background-position: center right;
            background-repeat: no-repeat;
            position: absolute;
            top: 0;
            right: 12px; }
    .mod_header .row01 .one {
      display: inline-block;
      padding: 0 16px;
      border-right: solid 1px #333333;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 14px;
      font-weight: 700;
      white-space: nowrap; }
      .mod_header .row01 .one:nth-child(1) {
        padding: 0 16px 0 0; }
      .mod_header .row01 .one:nth-child(7) {
        border-right: none; }
      .no-touchevents .mod_header .row01 .one:hover {
        text-decoration: underline; }
    .mod_header .row01 .two {
      display: flex;
      align-items: center;
      justify-content: center;
      height: 60px;
      width: 220px;
      background-color: #C8E628;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 0.14rem;
      font-weight: 700;
      border-radius: 6px; }
    .mod_header .row01 .sns {
      width: 26px;
      position: absolute;
      right: 40px;
      top: calc(50% - 54px); }
      @media screen and (max-width: 640px) {
        .mod_header .row01 .sns {
          width: auto;
          top: 35px;
          right: 100px; } }
      .mod_header .row01 .sns ul {
        margin: 0;
        padding: 0;
        list-style: none; }
        .mod_header .row01 .sns ul li {
          width: 26px;
          height: 26px;
          margin-bottom: 24px; }
          @media screen and (max-width: 640px) {
            .mod_header .row01 .sns ul li {
              margin: 0 15% 0 0; } }
          .mod_header .row01 .sns ul li:last-child {
            margin: 0; }
          .mod_header .row01 .sns ul li a {
            width: 100%;
            height: 100%;
            display: block; }
            .mod_header .row01 .sns ul li a svg {
              width: auto;
              height: 20px; }
              .mod_header .row01 .sns ul li a svg .cls-1 {
                fill: #FFF; }
              .spmenuopen .mod_header .row01 .sns ul li a svg .cls-1 {
                fill: #333; }
        @media screen and (max-width: 640px) {
          .mod_header .row01 .sns ul {
            display: flex;
            justify-content: space-between; } }
  @media screen and (max-width: 640px) {
    .mod_header .row02 {
      background-color: #f2f2f2;
      position: fixed;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      top: 0px;
      left: 0;
      width: 100%;
      bottom: 0;
      opacity: 0;
      z-index: 900;
      pointer-events: none;
      transition: opacity 0.4s;
      padding: 90px 0 0; }
      .spmenuopen .mod_header .row02 {
        opacity: 1;
        pointer-events: auto; }
      .mod_header .row02 .in {
        width: 100%; }
      .mod_header .row02 .link {
        margin-bottom: 20px; }
      .mod_header .row02 .one {
        font-size: 0.18rem;
        color: #333;
        font-weight: bold;
        display: block;
        text-align: center; }
        .mod_header .row02 .one + .one {
          margin-top: 10px; }
      .mod_header .row02 .col2 {
        width: 80%;
        margin: 0 auto 0; }
        .mod_header .row02 .col2 .col {
          width: 100%;
          margin: 0 auto 5%; }
          .mod_header .row02 .col2 .col a {
            display: block; }
            .mod_header .row02 .col2 .col a img {
              width: 100%;
              height: auto; }
      .mod_header .row02 .sub_link {
        width: 80%;
        margin: 0 auto 3%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between; }
        .mod_header .row02 .sub_link a {
          width: 50%;
          box-sizing: border-box;
          padding-left: 16px;
          line-height: 12vw;
          font-size: 4vw;
          font-weight: 700;
          position: relative; }
          .mod_header .row02 .sub_link a:after {
            content: '';
            width: 0;
            height: 0;
            border-style: solid;
            border-width: 5px 0 5px 10px;
            border-color: transparent transparent transparent #C8E628;
            position: absolute;
            left: 0;
            top: calc(50% - 5px); } }
  @media screen and (max-width: 640px) {
    .mod_header .menu {
      width: 44px;
      height: 44px;
      border-radius: 22px;
      position: fixed;
      top: 3%;
      right: 5%;
      z-index: 1000;
      background-color: #C8E628; }
      .mod_header .menu .open .bar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        width: 20px;
        height: 2px;
        margin: auto;
        background-color: #333333;
        transition: 0.3s; }
        .mod_header .menu .open .bar:nth-child(1) {
          top: -16px; }
        .mod_header .menu .open .bar:nth-child(3) {
          bottom: -16px; }
      .mod_header .menu .close .bar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        width: 0;
        height: 1px;
        margin: auto;
        background-color: #333333;
        transition: 0.3s; }
        .mod_header .menu .close .bar:nth-child(1) {
          transform: rotate(45deg); }
        .mod_header .menu .close .bar:nth-child(2) {
          transform: rotate(-45deg); }
      .spmenuopen .mod_header .menu .open .bar {
        width: 0; }
      .spmenuopen .mod_header .menu .close .bar {
        width: 24px; } }
.btn {
  width: auto;
  min-width: 310px;
  height: 60px;
  display: inline-block;
  border-radius: 6px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #C1DF28;
  margin: 0 0 0 50%;
  -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
}
@media screen and (max-width: 640px) {
  .btn {
    min-width: 100%;
    margin: 0 0 0 52%;
  }
}
.btn a {
	width: 100%;
	height: 100%;
	padding: 0 50px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	text-decoration: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
		-ms-flex-pack: center;
			justify-content: center;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
	text-align: center;
	color: #333;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 16px;
	font-weight: 700;
	position: relative;
	white-space: nowrap;
	-webkit-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
.btn a:after {
	content: "";
	width: 14px;
	height: 100%;
	background-image: url("../../common/img/arrow.png");
	background-position: center right;
	background-repeat: no-repeat;
	position: absolute;
	top: 0;
	right: 8px;
	-webkit-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
.no-touchevents .btn a:hover {
	opacity: 0.7;
}
.no-touchevents .btn a:hover:after {
	right: 5px;
}

.pankuzu {
  position: absolute;
  max-width: 1000px;
  width: 100%;
  margin: auto;
  text-align: left;
  white-space: nowrap;

  z-index: 10;
}
@media screen and (min-width: 641px) {
	.pankuzu {
		top: 105px;
		left: 123px;
	}
}
@media screen and (max-width: 640px) {
	.pankuzu {
		top: 80px;
		overflow-x: scroll;
	}
	.pankuzu .link:nth-of-type(1) {
		margin-left: 8%;
	}
}
.pankuzu .link {
	display: inline-block;
	position: relative;
	color: #FFF;
	font-family: 'Noto Sans JP', serif;
	font-weight: 400;
	font-size: 12px;
	letter-spacing: .05em;
	text-shadow: 0px 0px 1px rgb(0 0 0 / 50%);
}
@media screen and (max-width: 640px) {
	.pankuzu .link {
		font-size: .1rem;
	}
 }
.pankuzu .link + .link {
	margin-left: 20px;
}
.pankuzu .link + .link:before {
	content: "";
	display: block;
	width: 6px;
	height: 6px;
	border-right: 1px solid #c8e628;
	border-top: 1px solid #c8e628;
	position: absolute;
	top: 0;
	bottom: 0;
	left: -16px;
	margin: auto;
	transform: rotate(45deg);
}
.pankuzu.bg_white .link {
	color: #333;
}

.mod_footer {
  width: 100%;
  height: 799px;
  background-image: url("../img/footer_bk.jpg");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover; }
  @media screen and (max-width: 640px) {
    .mod_footer {
      background-image: url("../img/footer_bk_sp.jpg");
      padding-bottom: 20%;
      height: auto;
      position: relative; } }
  .mod_footer .in {
    padding: 184px 0 0; }
    .mod_footer .in .f_logo {
      width: 319px;
      margin: 0 auto 56px; }
      .mod_footer .in .f_logo img {
        width: 100%;
        height: auto; }
      @media screen and (max-width: 640px) {
        .mod_footer .in .f_logo {
          width: 42.4%;
          margin: 0 auto 7%; } }
    .mod_footer .in .add {
      margin: 0 auto 56px;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 20px;
      font-weight: 700;
      color: #FFF;
      text-align: center; }
      @media screen and (max-width: 640px) {
        .mod_footer .in .add {
          width: 100%;
          font-size: 4.2vw;
          margin-bottom: 7%; } }
    .mod_footer .in .link {
      width: auto;
      max-width: 950px;
      height: 100px;
      padding: 20px 30px 20px 30px;
      box-sizing: border-box;
      border-radius: 10px;
      background-color: #FFF;
      display: flex;
      align-items: center;
      top: 0;
      right: 0;
      z-index: 100;
      margin: 0 auto 40px; }
      .mod_footer .in .link .link_l {
        height: 60px;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-end;
        align-items: center;
        width: 640px;
        margin-right: 30px; }
        .mod_footer .in .link .link_l .link_up {
          width: 100%;
          display: flex;
          justify-content: flex-start; }
          .mod_footer .in .link .link_l .link_up a {
            display: inline-block;
            padding: 0 16px;
            font-family: 'Noto Sans JP', sans-serif;
            font-size: 14px;
            font-weight: 500; }
            .mod_footer .in .link .link_l .link_up a:first-child {
              padding-left: 0; }
            .no-touchevents .mod_footer .in .link .link_l .link_up a:hover {
              text-decoration: underline; }
        .mod_footer .in .link .link_l .link_do {
          width: 100%;
          display: flex;
          justify-content: flex-start; }
      .mod_footer .in .link .link_r {
        width: 220px; }
        .mod_footer .in .link .link_r a {
          position: relative; }
          .mod_footer .in .link .link_r a:after {
            content: '';
            width: 14px;
            height: 100%;
            background-image: url(../../common/img/arrow.png);
            background-position: center right;
            background-repeat: no-repeat;
            position: absolute;
            top: 0;
            right: 12px; }
    .mod_footer .in .one {
      display: inline-block;
      padding: 0 16px;
      border-right: solid 1px #333333;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 14px;
      font-weight: 700;
      white-space: nowrap; }
      .mod_footer .in .one:nth-child(1) {
        padding: 0 16px 0 0; }
      .mod_footer .in .one:nth-child(7) {
        border-right: none; }
    .mod_footer .in .two {
      display: flex;
      align-items: center;
      justify-content: center;
      height: 60px;
      width: 220px;
      background-color: #C8E628;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 0.14rem;
      font-weight: 700;
      border-radius: 6px; }
    .mod_footer .in ul.f_nav {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      border-top: solid 1px #FFF;
      margin-bottom: 7%; }
      .mod_footer .in ul.f_nav li {
        width: 50%;
        box-sizing: border-box;
        border-bottom: solid 1px #FFF; }
        .mod_footer .in ul.f_nav li:nth-child(2n) {
          border-left: solid 1px #FFF; }
        .mod_footer .in ul.f_nav li a {
          color: #FFF;
          text-decoration: none;
          position: relative;
          line-height: 50px;
          font-size: 4.0vw;
          text-align: center;
          display: block; }
    .mod_footer .in .btn {
      display: block;
      margin: 0 auto 7%;
      transform: translate(0, 0);
      width: 80%; }
    .mod_footer .in .f_sub_nav {
      margin: 0 auto 32px; }
      @media screen and (max-width: 640px) {
        .mod_footer .in .f_sub_nav {
          margin: 0 auto 5%; } }
      .mod_footer .in .f_sub_nav ul {
        display: flex;
        justify-content: center;
        align-items: center; }
        @media screen and (max-width: 640px) {
          .mod_footer .in .f_sub_nav ul {
            margin: 0 0 2%; } }
        .mod_footer .in .f_sub_nav ul li {
          padding: 0 16px; }
          .mod_footer .in .f_sub_nav ul li a {
            color: #FFF;
            font-family: 'Noto Sans JP', sans-serif;
            font-size: 14px;
            font-weight: 700;
            text-decoration: none; }
            @media screen and (max-width: 640px) {
              .mod_footer .in .f_sub_nav ul li a {
                font-size: 3.4vw; } }
    .mod_footer .in .copy {
      color: #FFF;
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 14px;
      font-weight: 700;
      text-align: center; }
      @media screen and (max-width: 640px) {
        .mod_footer .in .copy {
          font-size: 3.0vw; } }

.page_header {
  width: 100%;
  height: auto;
  box-sizing: border-box;
  padding: 10px 10px 0 10px;
  position: relative; }
  .page_header img {
    width: 100%;
    height: auto;
    border-radius: 10px; }
  .page_header h2 {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    text-align: center; }
    .page_header h2 img {
      width: 100%;
      height: auto;
      margin-bottom: 16px; }
    .page_header h2 span {
      color: #FFF;
      text-align: center;
      font-size: 18px;
      font-weight: 500;
      font-family: 'Zen Kaku Gothic New', sans-serif;
      position: relative; }
      @media screen and (max-width: 640px) {
        .page_header h2 span {
          font-size: 3.8vw; } }
      .page_header h2 span:before {
        content: '';
        width: 72px;
        height: 18px;
        background-image: url("../../common/img/tit_l_w.png");
        background-repeat: no-repeat;
        background-size: 100% auto;
        position: absolute;
        left: -80px;
        top: 5px; }
      .page_header h2 span:after {
        content: '';
        width: 72px;
        height: 18px;
        background-image: url("../../common/img/tit_r_w.png");
        background-repeat: no-repeat;
        background-size: 100% auto;
        position: absolute;
        right: -80px;
        top: 5px; }
  .page_header.cars h2 {
    width: 161px;
    margin: 0 auto 0; }
    @media screen and (max-width: 640px) {
      .page_header.cars h2 {
        width: 23%; } }

.archive_cars {
  width: 100%;
  margin: 0 auto 0px;
  padding: 330px 0 0px;
  position: relative;
  overflow: hidden;
  background-image: url(../../common/img/cars_bk.png);
  background-repeat: no-repeat;
  background-position: left -200px top 80px; }
  @media screen and (max-width: 640px) {
    .archive_cars {
      padding: 0;
      background-position: left -300px top 150px; } }
  .archive_cars .rem_cars {
    width: 595px;
    position: absolute;
    left: calc(50% - 550px);
    top: 96px;
    font-family: 'Zen Kaku Gothic New', sans-serif;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.8;
    color: #333333; }
    @media screen and (max-width: 640px) {
      .archive_cars .rem_cars {
        width: 90%;
        left: inherit;
        top: inherit;
        margin: 10% auto 25%;
        font-size: 4.0vw;
        position: relative; } }
  .archive_cars .outer {
    width: 1100px;
    margin: 0 auto 0;
    position: relative; }
    @media screen and (max-width: 640px) {
      .archive_cars .outer {
        width: 90%; } }
    .archive_cars .outer:before {
      content: '';
      position: absolute;
      width: 1240px;
      height: calc(100% + 234px);
      background-color: #28648C;
      border-radius: 6px;
      top: -234px;
      left: calc(50% + 100px); }
      @media screen and (max-width: 640px) {
        .archive_cars .outer:before {
          width: 80%;
          height: calc(100% - 2.85rem);
          left: 68%;
          top: -0.6rem; } }
    .archive_cars .outer .list_detail {
      width: 100%;
      position: relative;
      border-radius: 6px;
      background-color: #FFF;
      box-sizing: border-box;
      margin: 0 auto 64px; }
      .archive_cars .outer .list_detail:nth-child(2) .col2 .ph {
        text-align: center; }
        /* .archive_cars .outer .list_detail:nth-child(2) .col2 .ph img {
          width: 80%;
          margin: 0 auto; } */
          @media screen and (max-width: 640px) {
            .archive_cars .outer .list_detail:nth-child(2) .col2 .ph img {
              margin: 0 auto -10%; } }
      .archive_cars .outer .list_detail:nth-child(3) .col2 .ph {
        text-align: center; }
        /* .archive_cars .outer .list_detail:nth-child(3) .col2 .ph img {
          width: 80%;
          margin: 0 auto; } */
          @media screen and (max-width: 640px) {
            .archive_cars .outer .list_detail:nth-child(3) .col2 .ph img {
              margin: 0 auto -10%; } }
      .archive_cars .outer .list_detail .name {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 20px;
        font-weight: 700;
        color: #FFF;
        padding: 8px 16px;
        background-color: #C8E628;
        display: inline-block;
        position: absolute;
        left: 16px;
        top: -24px;
        z-index: 0; }
        .archive_cars .outer .list_detail .name:after {
          position: absolute;
          content: '';
          width: 2px;
          height: 0px;
          z-index: -1;
          top: 0;
          right: -30px;
          z-index: -1; }
        @media screen and (max-width: 640px) {
          .archive_cars .outer .list_detail .name {
            font-size: 3.6vw;
            z-index: 10;
            padding: 8px 16px 8px 16px; } }
        .archive_cars .outer .list_detail .name.car01 {
          background-color: #F1AF2D; }
          .archive_cars .outer .list_detail .name.car01:after {
            border: 23px solid #F1AF2D;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .name.car01:after {
                border: 18px solid #F1AF2D;
                border-right-color: transparent;
                right: -20px; } }
        .archive_cars .outer .list_detail .name.car02 {
          background-color: #3E9FAB; }
          .archive_cars .outer .list_detail .name.car02:after {
            border: 23px solid #3E9FAB;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .name.car02:after {
                border: 18px solid #3E9FAB;
                border-right-color: transparent;
                right: -20px; } }
        .archive_cars .outer .list_detail .name.car03 {
          background-color: #E35514; }
          .archive_cars .outer .list_detail .name.car03:after {
            border: 23px solid #E35514;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .name.car03:after {
                border: 18px solid #E35514;
                border-right-color: transparent;
                right: -20px; } }
      .archive_cars .outer .list_detail .num {
        position: absolute;
        left: -40px;
        top: 0; }
        @media screen and (max-width: 640px) {
          .archive_cars .outer .list_detail .num {
            left: 4%;
            top: 10%;
            width: 5%; }
            .archive_cars .outer .list_detail .num img {
              width: 100%;
              height: auto; } }
      .archive_cars .outer .list_detail .col2 {
        width: 100%;
        display: flex;
        justify-content: space-between; }
        @media screen and (max-width: 640px) {
          .archive_cars .outer .list_detail .col2 {
            display: block; } }
        .archive_cars .outer .list_detail .col2 .ph {
          width: 555px;
          box-sizing: border-box; }
          .archive_cars .outer .list_detail .col2 .ph img {
            width: 100%;
            height: auto; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .col2 .ph img {
                margin: 0 auto -5%; } }
          @media screen and (max-width: 640px) {
            .archive_cars .outer .list_detail .col2 .ph {
              width: 90%;
              margin: 10% 0% 0 10%; } }
        .archive_cars .outer .list_detail .col2 .col {
          box-sizing: border-box;
          width: calc(100% - 555px);
          padding: 32px 60px 0 0; }
          @media screen and (max-width: 640px) {
            .archive_cars .outer .list_detail .col2 .col {
              width: 100%;
              padding: 0% 8% 5% 5%; } }
          .archive_cars .outer .list_detail .col2 .col h3 {
            font-family: 'Zen Kaku Gothic New', sans-serif;
            font-size: 28px;
            font-weight: 700;
            color: #333333;
            border-bottom: solid 2px #C8E628;
            padding: 0 0 8px;
            margin-bottom: 16px; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .col2 .col h3 {
                font-size: 4.8vw;
                margin-bottom: 2%; } }
          .archive_cars .outer .list_detail .col2 .col.car01 h3 {
            border-bottom: solid 2px #F1AF2D; }
          .archive_cars .outer .list_detail .col2 .col.car01 .btn {
            background-color: #F1AF2D; }
            .archive_cars .outer .list_detail .col2 .col.car01 .btn a {
              color: #FFF; }
              .archive_cars .outer .list_detail .col2 .col.car01 .btn a:after {
                background-image: url("../../common/img/arrow_w.png"); }
          .archive_cars .outer .list_detail .col2 .col.car02 h3 {
            border-bottom: solid 2px #3E9FAB; }
          .archive_cars .outer .list_detail .col2 .col.car02 .btn {
            background-color: #3E9FAB; }
            .archive_cars .outer .list_detail .col2 .col.car02 .btn a {
              color: #FFF; }
              .archive_cars .outer .list_detail .col2 .col.car02 .btn a:after {
                background-image: url("../../common/img/arrow_w.png"); }
          .archive_cars .outer .list_detail .col2 .col.car03 h3 {
            border-bottom: solid 2px #E35514; }
          .archive_cars .outer .list_detail .col2 .col.car03 .btn {
            background-color: #E35514; }
            .archive_cars .outer .list_detail .col2 .col.car03 .btn a {
              color: #FFF; }
              .archive_cars .outer .list_detail .col2 .col.car03 .btn a:after {
                background-image: url("../../common/img/arrow_w.png"); }
          .archive_cars .outer .list_detail .col2 .col .detail {
            font-family: 'Zen Kaku Gothic New', sans-serif;
            font-size: 15px;
            font-weight: 500;
            color: #333333; }
            @media screen and (max-width: 640px) {
              .archive_cars .outer .list_detail .col2 .col .detail {
                font-size: 3.5vw; } }
            .archive_cars .outer .list_detail .col2 .col .detail .tr {
              width: 100%;
              display: flex;
              justify-content: flex-start;
              margin-bottom: 24px; }
              .archive_cars .outer .list_detail .col2 .col .detail .tr .th {
                width: 70px; }
              .archive_cars .outer .list_detail .col2 .col .detail .tr .td {
                width: calc(100% - 78px); }
              @media screen and (max-width: 640px) {
                .archive_cars .outer .list_detail .col2 .col .detail .tr {
                  margin-bottom: 3%; } }
    .archive_cars .outer .btn.ichiran {
      margin-left: calc(50% - 290px); }
      @media screen and (max-width: 640px) {
        .archive_cars .outer .btn.ichiran {
          margin-left: 50%; } }

.single_page_header {
  width: 100%;
  position: relative;
  padding: 10px 10px 0 10px;
  box-sizing: border-box; }
  .single_page_header:before {
    width: calc(100% - 20px);
    height: 450px;
    background-color: #286485;
    border-radius: 10px;
    content: '';
    position: absolute;
    left: 10px;
    top: 10px;
    z-index: -1; }
    @media screen and (max-width: 640px) {
      .single_page_header:before {
        height: 3.9rem; } }
  .single_page_header .in {
    width: 1300px;
    margin: 0 auto 10px;
    position: relative; }
    @media screen and (max-width: 640px) {
      .single_page_header .in {
        width: 100%; } }
    .single_page_header .in .pan {
      width: 100%;
      padding: 110px 0 0;
      margin: 0 auto 24px; }
      @media screen and (max-width: 640px) {
        .single_page_header .in .pan {
          padding: 70px 0 0 3%;
          margin-bottom: 3%; } }
      .single_page_header .in .pan ul {
        font-family: 'Noto Sans JP', sans-serif; }
        .single_page_header .in .pan ul li {
          display: inline-block;
          color: #FFF;
          font-size: 12px; }
          .single_page_header .in .pan ul li a {
            color: #FFF; }
    .single_page_header .in .mv_single {
      position: relative; }
      @media screen and (max-width: 640px) {
        .single_page_header .in .mv_single .mv_ph {
          width: 90%;
          display: block;
          border-radius: 10px;
          margin: 0 auto 0; } }
      .single_page_header .in .mv_single .name {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 20px;
        font-weight: 700;
        color: #FFF;
        padding: 8px 16px 8px 40px;
        background-color: #C8E628;
        display: inline-block;
        position: absolute;
        left: 0px;
        top: 40px;
        z-index: 0; }
        .single_page_header .in .mv_single .name:after {
          position: absolute;
          content: '';
          width: 2px;
          height: 0px;
          z-index: -1;
          top: 0;
          right: -30px;
          z-index: -1; }
        @media screen and (max-width: 640px) {
          .single_page_header .in .mv_single .name {
            font-size: 3.6vw;
            z-index: 10;
            padding: 8px 16px 8px 16px;
            position: relative;
            top: 0;
            margin-bottom: 5%; } }
        .single_page_header .in .mv_single .name.car01 {
          background-color: #F1AF2D; }
          .single_page_header .in .mv_single .name.car01:after {
            border: 23px solid #F1AF2D;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .single_page_header .in .mv_single .name.car01:after {
                border: 18px solid #F1AF2D;
                border-right-color: transparent; } }
        .single_page_header .in .mv_single .name.car02 {
          background-color: #3E9FAB; }
          .single_page_header .in .mv_single .name.car02:after {
            border: 23px solid #3E9FAB;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .single_page_header .in .mv_single .name.car02:after {
                border: 18px solid #3E9FAB;
                border-right-color: transparent; } }
        .single_page_header .in .mv_single .name.car03 {
          background-color: #E35514; }
          .single_page_header .in .mv_single .name.car03:after {
            border: 23px solid #E35514;
            border-right-color: transparent; }
            @media screen and (max-width: 640px) {
              .single_page_header .in .mv_single .name.car03:after {
                border: 18px solid #E35514;
                border-right-color: transparent; } }
      .single_page_header .in .mv_single .mv_head {
        width: 100%;
        height: 104px;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        box-sizing: border-box;
        position: absolute;
        left: 0;
        top: 120px; }
        @media screen and (max-width: 640px) {
          .single_page_header .in .mv_single .mv_head {
            position: relative;
            height: auto;
            top: 0;
            margin-bottom: 5%; } }
        .single_page_header .in .mv_single .mv_head .num {
          font-family: 'Overpass', sans-serif;
          font-size: 42px;
          font-weight: 900;
          color: #FFF;
          transform: rotate(90deg);
          border-top: solid 2px #F1AF2D; }
          @media screen and (max-width: 640px) {
            .single_page_header .in .mv_single .mv_head .num {
              font-size: 5.6vw;
              height: 100%; } }
        .single_page_header .in .mv_single .mv_head.car02 .num {
          border-top: solid 2px #3E9FAB; }
        .single_page_header .in .mv_single .mv_head.car03 .num {
          border-top: solid 2px #E35514; }
        .single_page_header .in .mv_single .mv_head h2.car_name {
          font-family: 'Overpass', sans-serif;
          font-size: 80px;
          font-weight: 700;
          letter-spacing: 0.1em;
          color: #FFF;
          line-height: 1.05; }
          @media screen and (max-width: 640px) {
            .single_page_header .in .mv_single .mv_head h2.car_name {
              font-size: 10vw; } }
          .single_page_header .in .mv_single .mv_head h2.car_name span {
            font-family: 'Zen Kaku Gothic New', sans-serif;
            font-size: 28px;
            letter-spacing: 0.01em;
            font-weight: 700;
            display: block; }
            @media screen and (max-width: 640px) {
              .single_page_header .in .mv_single .mv_head h2.car_name span {
                font-size: 4.8vw; } }

#single_cars01 .in {
  width: 1300px;
  margin: 0 auto 120px;
  background-color: #FFF;
  box-sizing: border-box;
  border-radius: 10px;
  padding: 100px 0; }
  @media screen and (max-width: 640px) {
    #single_cars01 .in {
      width: 100%;
      margin: 0 auto 15%;
      padding: 5% 0 0;
      background-color: inherit; } }
  #single_cars01 .in .point {
    width: 1100px;
    margin: 0 auto 0;
    box-sizing: border-box;
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 640px) {
      #single_cars01 .in .point {
        width: 100%;
        display: block; } }
    #single_cars01 .in .point .txt {
      width: 580px;
      font-family: 'Zen Kaku Gothic New', sans-serif; }
      @media screen and (max-width: 640px) {
        #single_cars01 .in .point .txt {
          width: 100%; } }
      #single_cars01 .in .point .txt p {
        font-size: 18px;
        letter-spacing: 0.01em;
        font-weight: 500;
        margin-bottom: 64px; }
        @media screen and (max-width: 640px) {
          #single_cars01 .in .point .txt p {
            font-size: 3.6vw;
            width: 80%;
            margin: 0 auto 10%; } }
      #single_cars01 .in .point .txt .point_area {
        margin-bottom: 80px; }
        @media screen and (max-width: 640px) {
          #single_cars01 .in .point .txt .point_area {
            width: 100%;
            background-color: #FFF;
            padding-top: 10%;
            margin-bottom: 10%;
            padding-bottom: 10%;
          } }
        #single_cars01 .in .point .txt .point_area .col {
          padding: 32px 40px;
          box-sizing: border-box;
          background-image: url("../img/point_bk.png");
          background-repeat: repeat-y;
          background-size: 100% auto; }
          @media screen and (max-width: 640px) {
            #single_cars01 .in .point .txt .point_area .col {
              background-image: url("../img/point_bk_sp.png"); } }
          #single_cars01 .in .point .txt .point_area .col ul {
            font-size: 16px; }
            @media screen and (max-width: 640px) {
              #single_cars01 .in .point .txt .point_area .col ul {
                font-size: 3.6vw; } }
            #single_cars01 .in .point .txt .point_area .col ul li {
              line-height: 1.8; }
              @media screen and (max-width: 640px) {
                #single_cars01 .in .point .txt .point_area .col ul li {
                  text-align: center; } }
              #single_cars01 .in .point .txt .point_area .col ul li span {
                font-family: 'Overpass', sans-serif;
                font-weight: 900;
                color: #F8B62D;
                margin-right: 8px; }
                @media screen and (max-width: 640px) {
                  #single_cars01 .in .point .txt .point_area .col ul li span {
                    display: block;
                    text-align: center; } }
    #single_cars01 .in .point .ph {
      width: 500px;
      margin-right: -60px; }
  #single_cars01 .in .car_spec {
    width: 1100px;
    margin: 0 auto 0;
    box-sizing: border-box;
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 640px) {
      #single_cars01 .in .car_spec {
        width: 100%;
        display: block; } }
    #single_cars01 .in .car_spec .title {
      width: 290px; }
      @media screen and (max-width: 640px) {
        #single_cars01 .in .car_spec .title {
          width: 42.4%;
          display: block;
          margin: 0 auto 0;
          text-align: center; } }
      #single_cars01 .in .car_spec .title span {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 18px;
        font-weight: 500;
        display: block; }
        @media screen and (max-width: 640px) {
          #single_cars01 .in .car_spec .title span {
            font-size: 3.8vw; } }
    #single_cars01 .in .car_spec .txt_area {
      width: 750px;
      display: flex;
      justify-content: space-between; }
      @media screen and (max-width: 640px) {
        #single_cars01 .in .car_spec .txt_area {
          width: 90%;
          display: block;
          margin: 0 auto 10%; } }
      #single_cars01 .in .car_spec .txt_area .col2 .col {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 15px;
        font-weight: 500;
        display: flex;
        justify-content: flex-start;
        line-height: 2.0; }
        @media screen and (max-width: 640px) {
          #single_cars01 .in .car_spec .txt_area .col2 .col {
            font-size: 3.5vw; } }
        #single_cars01 .in .car_spec .txt_area .col2 .col .tit {
          margin-right: 16px; }
        #single_cars01 .in .car_spec .txt_area .col2 .col .com ul li {
          display: flex;
          justify-content: flex-start; }
          #single_cars01 .in .car_spec .txt_area .col2 .col .com ul li .th {
            display: inline-block; }
          #single_cars01 .in .car_spec .txt_area .col2 .col .com ul li .td {
            display: inline-block; }
    #single_cars01 .in .car_spec .ph {
      width: 90%;
      margin: 0 auto 10%; }
      #single_cars01 .in .car_spec .ph img {
        width: 100%;
        height: auto; }

#layout {
  width: 100%;
  height: 700px;
  background-image: url("../img/layout_bk.png");
  background-size: calc(100% - 20px) 700px;
  background-repeat: no-repeat;
  background-position: center top; }
  @media screen and (max-width: 640px) {
    #layout {
      height: auto;
      background-image: none; } }
  #layout .in {
    padding: 104px 0 0; }
    @media screen and (max-width: 640px) {
      #layout .in {
        padding: 0; } }
    #layout .in img {
      width: 1306px;
      display: block;
      margin: 0 auto 0; }
      @media screen and (max-width: 640px) {
        #layout .in img {
          width: 94%;
          margin: 0 auto 0; } }

#view360 {
  width: 100%;
  height: 750px;
  box-sizing: border-box;
  padding: 10px 10px 0;
  position: relative; }


  @media screen and (max-width: 640px) {
    #view360 {
      height: auto; } }
  #view360 img {
    width: 100%;
    height: auto; }
  #view360 blockquote {
    width: 100%;
    height: auto; }
  #view360 iframe {
    width: 100% !important;
    height: 2.5rem !important;
  }

  #view360 .in {
    position: absolute;
    width: 774px;
    height: auto;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%); }
    @media screen and (max-width: 640px) {
      #view360 .in {
        width: 80%;
        width: 95%;
        transform: translate(-50%, -63%); 
      }
      #view360 .view {
        margin-top: 0.05rem;
      }
      }
    #view360 .in h2 {
      font-family: 'Overpass', sans-serif;
      font-size: 60px;
      font-weight: 900;
      color: #FFF;
      text-align: center; }
      @media screen and (max-width: 640px) {
        #view360 .in h2 {
          font-size: 7.2vw;
        }
      }
    @media screen and (min-width: 641px) {
      #view360 {
        height: 7.5rem;
      }
       #view360 .in {
       width: 7.74rem;
      }
      #view360 img {
        height: 100%;
        object-fit: cover;
        border-radius: 10px;
      }
      #view360 blockquote {
        height: 100%;
        object-fit: cover;
        border-radius: 10px;
      }
      #view360 .ricoh-theta-spherical-image {
        width: auto !important;
        height: auto !important;
      }
      #view360 iframe {
        width: 100% !important;
        height: 4.1rem !important;
      }
    }

#interior {
  padding: 120px 0 80px; }
  @media screen and (max-width: 640px) {
    #interior {
      padding: 15% 0 10%; } }
  #interior h2 {
    width: 1100px;
    margin: 0 auto 64px;
    padding: 32px 0 24px;
    border-top: solid 4px #000;
    border-bottom: solid 1.5px #000; }
    @media screen and (max-width: 640px) {
      #interior h2 {
        width: 90%;
        margin: 0 auto 8%;
        padding: 4% 0 3%; } }
    #interior h2 img {
      width: 176px;
      height: auto;
      display: block;
      margin: 0 auto 0; }
      @media screen and (max-width: 640px) {
        #interior h2 img {
          width: 44%; } }
    #interior h2 span {
      text-align: center;
      display: block;
      font-family: 'Zen Kaku Gothic New', sans-serif;
      font-size: 18px;
      font-weight: 500;
      color: #333; }
      @media screen and (max-width: 640px) {
        #interior h2 span {
          font-size: 3.8vw; } }
  #interior h3 {
    text-align: center;
    margin-bottom: 56px; }
    @media screen and (max-width: 640px) {
      #interior h3 {
        margin-bottom: 7%; } }
    #interior h3 span {
      text-align: center;
      font-family: 'Zen Kaku Gothic New', sans-serif;
      font-size: 18px;
      font-weight: 500;
      color: #333;
      display: inline-block;
      position: relative; }
      @media screen and (max-width: 640px) {
        #interior h3 span {
          font-size: 3.8vw; } }
      #interior h3 span:before {
        content: '';
        width: 72px;
        height: 18px;
        background-image: url("../../common/img/tit_l.png");
        background-repeat: no-repeat;
        background-size: 100% auto;
        position: absolute;
        left: -80px;
        top: 5px; }
      #interior h3 span:after {
        content: '';
        width: 72px;
        height: 18px;
        background-image: url("../../common/img/tit_r.png");
        background-repeat: no-repeat;
        background-size: 100% auto;
        position: absolute;
        right: -80px;
        top: 5px; }
  #interior .detail_col3 {
    width: 1155px;
    margin: 0 auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center; }
    @media screen and (max-width: 640px) {
      #interior .detail_col3 {
        width: 100%; } }
    #interior .detail_col3 .col {
      width: 330px;
      margin: 0 27.5px 80px; }
      #interior .detail_col3 .col .ph {
        position: relative;
        width: 100%;
        border-radius: 10px;
        margin-bottom: 16px; }
        #interior .detail_col3 .col .ph .num {
          position: absolute;
          left: 32px;
          top: -24px;
          color: #F8B62D;
          font-family: 'Overpass', sans-serif;
          font-size: 40px;
          font-weight: 900; }
          #interior .detail_col3 .col .ph .num:after {
            content: '';
            position: absolute;
            width: 100%;
            height: 2px;
            background-color: #F8B62D;
            left: 0;
            bottom: 0; }
        #interior .detail_col3 .col .ph img {
          width: 100%;
          border-radius: 10px; }
      #interior .detail_col3 .col p {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 15px;
        font-weight: 500;
        color: #333; }
  #interior .detail_col4 {
    width: 1100px;
    margin: 0 auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start; }
    @media screen and (max-width: 640px) {
      #interior .detail_col4 {
        width: 90%;
        margin: 0 auto 0;
        justify-content: space-between; } }
    #interior .detail_col4 .col {
      width: 240px;
      margin-right: 46.6px;
      margin-bottom: 48px; }
      @media screen and (max-width: 640px) {
        #interior .detail_col4 .col {
          width: 48.0%;
          margin-bottom: 10%;
          margin-right: 0; } }
      #interior .detail_col4 .col:nth-child(4n) {
        margin-right: 0; }
      #interior .detail_col4 .col .ph {
        position: relative;
        width: 100%;
        border-radius: 10px;
        margin-bottom: 16px; }
        @media screen and (max-width: 640px) {
          #interior .detail_col4 .col .ph {
            margin-bottom: 2%; } }
        #interior .detail_col4 .col .ph img {
          width: 100%;
          border-radius: 10px; }
      #interior .detail_col4 .col p {
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 18px;
        font-weight: 700;
        color: #333;
        text-align: center; }
        @media screen and (max-width: 640px) {
          #interior .detail_col4 .col p {
            font-size: 3.8vw; } }

#manual {
  padding: 120px 0;
  background-color: #C2DAE2; }
  @media screen and (max-width: 640px) {
    #manual {
      padding: 15% 0; } }
  #manual .in {
    width: 1100px;
    margin: 0 auto 0; }
    @media screen and (max-width: 640px) {
      #manual .in {
        width: 90%; } }
    #manual .in h2 {
      width: 1100px;
      margin: 0 auto 64px;
      padding: 32px 0 24px;
      border-top: solid 4px #000;
      border-bottom: solid 1.5px #000; }
      @media screen and (max-width: 640px) {
        #manual .in h2 {
          width: 90%;
          margin: 0 auto 8%;
          padding: 4% 0 3%; } }
      #manual .in h2 img {
        width: 167px;
        height: auto;
        display: block;
        margin: 0 auto 0; }
        @media screen and (max-width: 640px) {
          #manual .in h2 img {
            width: 41.4%; } }
      #manual .in h2 span {
        text-align: center;
        display: block;
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 18px;
        font-weight: 500;
        color: #333; }
        @media screen and (max-width: 640px) {
          #manual .in h2 span {
            font-size: 3.8vw; } }
    #manual .in p {
      font-family: 'Zen Kaku Gothic New', sans-serif;
      font-size: 18px;
      font-weight: 700;
      color: #333;
      text-align: center;
      margin-bottom: 56px; }
      @media screen and (max-width: 640px) {
        #manual .in p {
          width: 90%;
          margin: 0 auto 7%;
          font-size: 3.8vw; } }
    #manual .in .col3 {
      width: 1100px;
      margin: 0 auto 0;
      display: flex;
      justify-content: space-between; }
      @media screen and (max-width: 640px) {
        #manual .in .col3 {
          width: 90%;
          display: block; } }
      #manual .in .col3 .col {
        width: 348px; }
        @media screen and (max-width: 640px) {
          #manual .in .col3 .col {
            width: 100%;
            margin-bottom: 10%; } }
        #manual .in .col3 .col a {
          width: 100%;
          height: auto;
          display: block; }
          #manual .in .col3 .col a .ph {
            width: 100%;
            height: auto;
            border-radius: 10px; }
          #manual .in .col3 .col a h3 {
            text-align: center;
            font-family: 'Zen Kaku Gothic New', sans-serif;
            font-size: 18px;
            font-weight: 500;
            color: #333; }
            @media screen and (max-width: 640px) {
              #manual .in .col3 .col a h3 {
                font-size: 3.8vw; } }

#price {
  padding: 120px 0;
  background-color: #FFF; }
  @media screen and (max-width: 640px) {
    #price {
      padding: 15% 0; } }
  #price .in {
    width: 1100px;
    margin: 0 auto 0; }
    @media screen and (max-width: 640px) {
      #price .in {
        width: 90%; } }
    #price .in h2 {
      width: 1100px;
      margin: 0 auto 64px;
      padding: 32px 0 24px;
      border-top: solid 4px #000;
      border-bottom: solid 1.5px #000; }
      @media screen and (max-width: 640px) {
        #price .in h2 {
          width: 100%;
          padding: 4% 0 3%; } }
      #price .in h2 img {
        width: 110px;
        height: auto;
        display: block;
        margin: 0 auto 0; }
        @media screen and (max-width: 640px) {
          #price .in h2 img {
            width: 17.5%; } }
      #price .in h2 span {
        text-align: center;
        display: block;
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 18px;
        font-weight: 500;
        color: #333; }
        @media screen and (max-width: 640px) {
          #price .in h2 span {
            font-size: 3.8vw; } }
    #price .in table {
      width: 1100px;
      margin: 0 auto 60px;
      border-left: solid 1px #000;
      border-bottom: solid 1px #000; }
      @media screen and (max-width: 640px) {
        #price .in table {
          width: 90%; } }
      #price .in table tbody tr th {
        width: 157px;
        padding: 14px 0;
        text-align: center;
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 14px;
        font-weight: 500;
        color: #333;
        background-color: #F8B62D;
        border-top: solid 1px #000;
        border-right: solid 1px #000; }
        #price .in table tbody tr th:first-child {
          width: 300px; }
      #price .in table tbody tr td {
        border-top: solid 1px #000;
        border-right: solid 1px #000;
        border-collapse: collapse;
        padding: 14px;
        text-align: center;
        font-family: 'Zen Kaku Gothic New', sans-serif;
        font-size: 14px;
        font-weight: 500;
        color: #333; }
        #price .in table tbody tr td .col2 {
          display: flex;
          justify-content: space-between;
          align-items: center; }
          #price .in table tbody tr td .col2 .ph {
            width: 104px;
            margin-right: 28px; }
          #price .in table tbody tr td .col2 .txt {
            font-family: 'Zen Kaku Gothic New', sans-serif;
            font-size: 20px;
            font-weight: 500;
            text-align: center; }
            #price .in table tbody tr td .col2 .txt .txt_s {
              font-size: 14px;
              display: block; }
    #price .in .price_tb {
      width: 100%;
      margin-bottom: 10%;
      border-left: solid 1px #000;
      border-top: solid 1px #000; }
      #price .in .price_tb .tr {
        width: 100%;
        display: block;
        line-height: 40px; }
        #price .in .price_tb .tr .th {
          font-size: 4vw;
          font-weight: 700;
          background-color: #F8B62D;
          color: #000;
          text-align: center;
          border-right: solid 1px #000;
          border-bottom: solid 1px #000; }
        #price .in .price_tb .tr .td.col2 {
          display: flex;
          justify-content: center;
          align-items: center;
          border-right: solid 1px #000;
          border-bottom: solid 1px #000; }
          #price .in .price_tb .tr .td.col2 .ph {
            width: 50%;
            display: flex;
            justify-content: center;
            align-items: center;
          }
          #price .in .price_tb .tr .td.col2 .txt {
            width: 50%;
            font-size: 4vw;
            font-weight: 700;
            text-align: center;
            line-height: 1.4; }
            #price .in .price_tb .tr .td.col2 .txt .txt_s {
              font-size: 3.2vw;
              display: block; }
        #price .in .price_tb .tr .td.col4 {
          display: flex;
          flex-wrap: wrap;
          justify-content: center;
          align-items: center; }
          #price .in .price_tb .tr .td.col4.gr {
            background-color: #E5E5E5; }
          #price .in .price_tb .tr .td.col4 .col {
            width: calc(100% / 4);
            height: 60px;
            display: flex;
            justify-content: center;
            align-items: center;
            box-sizing: border-box;
            text-align: center;
            font-size: 3.2vw;
            font-weight: 700;
            line-height: 1.4;
            padding: 0;
            border-right: solid 1px #000;
            border-bottom: solid 1px #000; }

#list_banner {
  width: 100%;
  background-color: #286485;
  padding: 80px 0; }
  @media screen and (max-width: 640px) {
    #list_banner {
      padding: 15% 0 7%; } }
  #list_banner .in {
    width: 1100px;
    margin: 0 auto 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    row-gap: 30px;
   }
    @media screen and (max-width: 640px) {
      #list_banner .in {
        width: 77%;
        display: block; } }
    #list_banner .in .col {
      width: 340px; }
      @media screen and (max-width: 640px) {
        #list_banner .in .col {
          width: 100%;
          margin-bottom: 8%; } }
      #list_banner .in .col a {
        display: block; }

[data-svgtextanimation01] {
  opacity: 0;
  overflow: visible !important; }
  [data-svgtextanimation01] [data-svgtextanimation01-bg] {
    fill: #E3F293;
    stroke: none; }
  [data-svgtextanimation01] [data-svgtextanimation01-line] {
    fill: none;
    stroke: #333333;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-miterlimit: 10; }

[data-svganimation03] {
  display: block;
  overflow: visible !important; }

[data-svganimation03] [data-svganimation03-target] {
  fill: none;
  stroke: #FFF;
  stroke-width: 2px; }

.cmnTit01 {
  position: relative; }
  @media print, screen and (min-width: 641px) {
    .cmnTit01 {
      padding-bottom: 20px; } }
  @media screen and (max-width: 640px) {
    .cmnTit01 {
      padding-bottom: 10px; } }
  .cmnTit01 img {
    display: block;
    margin: auto; }
    @media screen and (max-width: 640px) {
      .cmnTit01 img {
        width: auto;
        height: 30px; } }
  .cmnTit01 svg {
    display: block;
    margin: auto; }
    @media print, screen and (min-width: 641px) {
      .cmnTit01 svg {
        padding-top: 20px; } }
    @media screen and (max-width: 640px) {
      .cmnTit01 svg {
        width: auto;
        height: 30px;
        padding-top: 10px; } }
    @media screen and (max-width: 640px) {
      .cmnTit01 svg [data-svgtextanimation01-line] {
        stroke-width: 2.5; } }

[data-pararax01] {
  position: relative; }

[data-pararax01-inview] {
  position: absolute !important;
  top: 120px;
  bottom: 120px;
  left: 0;
  right: 0;
  width: 0%;
  margin-left: auto;
  margin-right: auto;
  pointer-events: none;
  opacity: 0; }
@media print, screen and (min-width: 641px) and (max-height: 800px) {
  [data-pararax01-inview] {
    top: 120px;
    bottom: 120px; } }
@media print, screen and (min-width: 641px) and (max-height: 650px) {
  [data-pararax01-inview] {
    top: 50px;
    bottom: 50px; } }

  @media screen and (max-width: 640px) {
    [data-pararax01-inview] {
      top: 100px;
      bottom: 100px; } }

[data-pararax01-opacity01] {
  opacity: 0 !important; }
  [data-pararax01-opacity01].active {
    opacity: 1 !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity02] {
  opacity: 0 !important;
  transform: translateX(-20px) !important; }
  [data-pararax01-opacity02].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity03] {
  opacity: 0 !important;
  transform: translateX(20px) !important; }
  [data-pararax01-opacity03].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity04] {
  opacity: 0 !important;
  transform: translateY(20px) !important; }
  [data-pararax01-opacity04].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity05] {
  opacity: 0 !important;
  transform: translateY(-20px) !important; }
  [data-pararax01-opacity05].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity06] {
  opacity: 0 !important;
  transform: scale(0.8) !important; }
  [data-pararax01-opacity06].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity07] {
  opacity: 0 !important;
  transform: scale(1.2) !important; }
  [data-pararax01-opacity07].active {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), transform 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity08] {
  perspective: 1000px; }
  [data-pararax01-opacity08] [data-pararax01-opacity08-target] {
    transform-style: preserve-3d;
    opacity: 0;
    transform: rotateY(720deg) scale(0.2);
    overflow: hidden; }
    [data-pararax01-opacity08] [data-pararax01-opacity08-target]:after {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: #fff;
      opacity: 0.5;
      clip-path: polygon(0px 0%, 100% 0%, 100% 100%, 0% 100%); }
  [data-pararax01-opacity08].active [data-pararax01-opacity08-target] {
    opacity: 1;
    transform: rotateY(0deg) scale(1);
    transition: 3.6s cubic-bezier(0.515, 0.005, 0.505, 1); }
    [data-pararax01-opacity08].active [data-pararax01-opacity08-target]:after {
      left: 100%;
      transition: 1.8s cubic-bezier(0.515, 0.005, 0.505, 1) 0.7s;
      clip-path: polygon(50px 0%, 100% 0%, 100% 100%, 0% 100%); }

[data-pararax01-opacity09] {
  clip-path: polygon(0% 50%, 100% 50%, 100% 50%, 0% 50%);
  opacity: 0; }
  [data-pararax01-opacity09].active {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    opacity: 1;
    transition: clip-path 1.8s cubic-bezier(0.515, 0.005, 0.505, 1), opacity 1.8s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity10] {
  clip-path: polygon(0% 0%, 100% -100%, -100% 100%);
  opacity: 0; }
  [data-pararax01-opacity10].active {
    clip-path: polygon(0% 0%, 200% 0%, 0% 200%);
    opacity: 1;
    transition: clip-path 3.6s cubic-bezier(0.515, 0.005, 0.505, 1), opacity 3.6s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity11] {
  clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);
  opacity: 0; }
  [data-pararax01-opacity11].active {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    opacity: 1;
    transition: clip-path 3.6s cubic-bezier(0.515, 0.005, 0.505, 1), opacity 3.6s cubic-bezier(0.515, 0.005, 0.505, 1); }

[data-pararax01-opacity12] {
  clip-path: polygon(100% 0%, 100% 0%, 100% 0%, 100% 0%);
  opacity: 0; }
  [data-pararax01-opacity12].active {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    opacity: 1;
    transition: clip-path 3.6s cubic-bezier(0.515, 0.005, 0.505, 1), opacity 3.6s cubic-bezier(0.515, 0.005, 0.505, 1); }

.pararax01_pattern01 {
  font-size: 20px;
  line-height: 2;
  font-weight: bold; }
  .pararax01_pattern01 .pararax01_pattern01_underline {
    background-image: linear-gradient(#f00 0%, #f00 100%);
    background-position: left bottom;
    background-repeat: no-repeat;
    background-size: 0% 2px; }
  .pararax01_pattern01.active .pararax01_pattern01_underline {
    background-size: 100% 2px;
    transition: background-size 3.6s cubic-bezier(0.2, 0, 0.18, 1); }

[data-pararax01-photo01a],
[data-pararax01-photo01b],
[data-pararax01-photo02a],
[data-pararax01-photo02b],
[data-pararax01-photo03a],
[data-pararax01-photo03b],
[data-pararax01-photo03c],
[data-pararax01-photo04a],
[data-pararax01-photo04b] {
  display: inline-block;
  position: relative;
  opacity: 0;
  font-size: 0; }
  .ie [data-pararax01-photo01a] > *, .ie
  [data-pararax01-photo01b] > *, .ie
  [data-pararax01-photo02a] > *, .ie
  [data-pararax01-photo02b] > *, .ie
  [data-pararax01-photo03a] > *, .ie
  [data-pararax01-photo03b] > *, .ie
  [data-pararax01-photo03c] > *, .ie
  [data-pararax01-photo04a] > *, .ie
  [data-pararax01-photo04b] > * {
    opacity: 0; }

[data-pararax01-photo01a].active,
[data-pararax01-photo01b].active,
[data-pararax01-photo02a].active,
[data-pararax01-photo02b].active,
[data-pararax01-photo03a].active,
[data-pararax01-photo03b].active,
[data-pararax01-photo03c].active,
[data-pararax01-photo04a].active,
[data-pararax01-photo04b].active {
  opacity: 1; }
  .ie [data-pararax01-photo01a].active > *, .ie
  [data-pararax01-photo01b].active > *, .ie
  [data-pararax01-photo02a].active > *, .ie
  [data-pararax01-photo02b].active > *, .ie
  [data-pararax01-photo03a].active > *, .ie
  [data-pararax01-photo03b].active > *, .ie
  [data-pararax01-photo03c].active > *, .ie
  [data-pararax01-photo04a].active > *, .ie
  [data-pararax01-photo04b].active > * {
    opacity: 1; }

.ie [data-pararax01-photo01a],
.ie [data-pararax01-photo01b],
.ie [data-pararax01-photo02a],
.ie [data-pararax01-photo02b],
.ie [data-pararax01-photo03a],
.ie [data-pararax01-photo03b],
.ie [data-pararax01-photo03c],
.ie [data-pararax01-photo04a],
.ie [data-pararax01-photo04b],
.edge [data-pararax01-photo01a],
.edge [data-pararax01-photo01b],
.edge [data-pararax01-photo02a],
.edge [data-pararax01-photo02b],
.edge [data-pararax01-photo03a],
.edge [data-pararax01-photo03b],
.edge [data-pararax01-photo03c],
.edge [data-pararax01-photo04a],
.edge [data-pararax01-photo04b] {
  background-color: #FFF;
  opacity: 1 !important; }

[data-pararax01-photo01a] svg,
[data-pararax01-photo01b] svg,
[data-pararax01-photo02a] svg,
[data-pararax01-photo02b] svg,
[data-pararax01-photo03a] svg,
[data-pararax01-photo03b] svg,
[data-pararax01-photo03c] svg,
[data-pararax01-photo04a] svg,
[data-pararax01-photo04b] svg {
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none; }

[data-pararax01-photo01a] rect,
[data-pararax01-photo01b] rect,
[data-pararax01-photo02a] rect,
[data-pararax01-photo02b] rect,
[data-pararax01-photo03a] rect,
[data-pararax01-photo03b] rect,
[data-pararax01-photo03c] rect,
[data-pararax01-photo04a] rect,
[data-pararax01-photo04b] rect {
  fill: #FFF; }

[data-pararax01-photo01a].init,
[data-pararax01-photo01b].init,
[data-pararax01-photo02a].init,
[data-pararax01-photo02b].init,
[data-pararax01-photo03a].init,
[data-pararax01-photo03b].init,
[data-pararax01-photo03c].init,
[data-pararax01-photo04a].init,
[data-pararax01-photo04b].init {
  opacity: 1; }

#contact {
	margin: 0 auto 96px;
	padding: 96px 0 0;
}
@media screen and (max-width: 640px) {
	#contact {
		margin: 0 auto 12%;
		padding: 12% 0 0;
	}
}
#contact h2 {
	width: 292px;
	margin: 0 auto 32px;
	text-align: center;
}
#contact h2 img {
	width: 100%;
	height: auto;
}
@media screen and (max-width: 640px) {
	#contact h2 {
		width: 47%;
		margin: 0 auto 4%;
	}
}
#contact h2 span {
	display: inline-block;
	position: relative;
	font-size: 18px;
	font-weight: 500;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #333333;
}
@media screen and (max-width: 640px) {
	#contact h2 span {
		font-size: 3.8vw;
	}
}
#contact h2 span:before {
	content: "";
	width: 72px;
	height: 18px;
	background-image: url("../../common/img/tit_l.png");
	background-repeat: no-repeat;
	background-size: 100% auto;
	position: absolute;
	left: -80px;
	top: 5px;
}
#contact h2 span:after {
	content: "";
	width: 72px;
	height: 18px;
	background-image: url("../../common/img/tit_r.png");
	background-repeat: no-repeat;
	background-size: 100% auto;
	position: absolute;
	right: -80px;
	top: 5px;
}
#contact .col2 {
	width: 1100px;
	margin: 0 auto 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
@media screen and (max-width: 640px) {
	#contact .col2 {
		width: 90%;
		display: block;
	}
}
#contact .col2 .col {
	width: 520px;
}
#contact .col2 .col img {
	width: 100%;
	height: auto;
}
@media screen and (max-width: 640px) {
	#contact .col2 .col {
		width: 100%;
		margin: 0 auto 8%;
	}
  #price .in .price_tb .tr .td.col4 .col.twotimes_sp{
    width: calc(100% / 2);
  }
  #price .in .price_tb .tr .td.col2 .ph {
    padding: 10px 0;
  }
}

