@charset "UTF-8";
@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@font-face {
  font-family: 'Noto-B';
  src: url("/asset/font/NotoSansJP-Bold.eot");
  src: url("/asset/font/NotoSansJP-Bold.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Bold.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-L';
  src: url("/asset/font/NotoSansJP-Light.eot");
  src: url("/asset/font/NotoSansJP-Light.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Light.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-R';
  src: url("/asset/font/NotoSansJP-Regular.eot");
  src: url("/asset/font/NotoSansJP-Regular.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Regular.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-M';
  src: url("/asset/font/NotoSansJP-Medium.eot");
  src: url("/asset/font/NotoSansJP-Medium.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Medium.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'TexGyreHeros';
  src: url("../font/texgyreheros-regular.eot");
  src: url("../font/texgyreheros-regular.eot?iefix") format("eot"), url("../font/texgyreheros-regular.woff") format("woff");
  font-display: swap; }

a {
  cursor: pointer; }

@media only screen and (max-width: 767px) {
  .dn-sp {
    display: none !important; } }

@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .dn-tablet {
    display: none !important; } }

@media only screen and (min-width: 1025px) {
  .dn-pc {
    display: none !important; } }

@media only screen and (min-width: 768px) and (max-width: 1024px), only screen and (min-width: 1025px) {
  .dn-tab_pc {
    display: none !important; } }

body {
  margin: 0;
  font-family: 'Helvetica Neue',Arial, 'Hiragino Kaku Gothic ProN' , 'ヒラギノ角ゴ ProN W3', '游ゴシック Medium' , '游ゴシック体', 'Yu Gothic', YuGothic, Meiryo, メイリオ, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: #000; }

body, div, p, form, input, textarea, select, option, button, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, address, button, figure, figcaption {
  font-style: normal;
  line-height: 1;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

li {
  list-style: none; }

@font-face {
  font-family: 'Noto-B';
  src: url("/asset/font/NotoSansJP-Bold.eot");
  src: url("/asset/font/NotoSansJP-Bold.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Bold.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-L';
  src: url("/asset/font/NotoSansJP-Light.eot");
  src: url("/asset/font/NotoSansJP-Light.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Light.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-R';
  src: url("/asset/font/NotoSansJP-Regular.eot");
  src: url("/asset/font/NotoSansJP-Regular.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Regular.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto-M';
  src: url("/asset/font/NotoSansJP-Medium.eot");
  src: url("/asset/font/NotoSansJP-Medium.eot?iefix") format("eot"), url("/asset/font/NotoSansJP-Medium.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'TexGyreHeros';
  src: url("../font/texgyreheros-regular.eot");
  src: url("../font/texgyreheros-regular.eot?iefix") format("eot"), url("../font/texgyreheros-regular.woff") format("woff");
  font-display: swap; }

body,
div,
p,
form,
input,
textarea,
select,
option,
button,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
address,
button,
figure,
figcaption {
  margin: 0;
  padding: 0;
  font-style: normal;
  line-height: 1; }

select,
input,
textarea,
button {
  font-family: 'Helvetica Neue',Arial, 'Hiragino Kaku Gothic ProN' , 'ヒラギノ角ゴ ProN W3', '游ゴシック Medium' , '游ゴシック体', 'Yu Gothic', YuGothic, Meiryo, メイリオ, sans-serif; }

select,
input[type='text'],
input[type='password'],
textarea {
  border: 1px solid #dbdbdb;
  outline: none;
  border-radius: 0;
  -webkit-box-shadow: 0;
  -ms-box-shadow: 0;
  -o-box-shadow: 0;
  box-shadow: 0; }

input[type='text'],
input[type='password'],
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none; }

table {
  border-collapse: collapse; }

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

img {
  border: 0;
  vertical-align: middle; }

ul,
ol {
  list-style: none; }

html {
  font-size: 62.5%; }

body {
  font-size: 10px;
  font-size: 1.0rem; }

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

@font-face {
  font-family: 'TexGyreHeros';
  src: url("../font/texgyreheros-bold-webfont.eot");
  src: url("../font/texgyreheros-bold-webfont.eot?#iefix") format("embedded-opentype"), url("../font/texgyreheros-bold-webfont.woff") format("woff"), url("../font/texgyreheros-bold-webfont.ttf") format("truetype");
  font-display: swap; }

html,
body {
  position: relative;
  min-height: 100%;
  background-color: #fff;
  font-family: 'Helvetica Neue',Arial, 'Hiragino Kaku Gothic ProN' , 'ヒラギノ角ゴ ProN W3', '游ゴシック Medium' , '游ゴシック体', 'Yu Gothic', YuGothic, Meiryo, メイリオ, sans-serif;
  -webkit-font-smoothing: antialiased;
  -webkit-print-color-adjust: exact;
  -webkit-text-size-adjust: none; }

body * {
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box; }

body * > img {
  vertical-align: middle; }

a {
  cursor: pointer; }

input,
select {
  font-size: 14px; }

@media only screen and (max-width: 767px) {
  input,
  select {
    font-size: 12px; } }

.breadCrumb {
  margin: 12px 30px;
  font-family: 'Roboto', 'Helvetica Neue', Arial,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  font-size: 12px; }

@media only screen and (max-width: 767px) {
  .breadCrumb {
    margin: 20px 25px; } }

.breadCrumb a {
  display: inline-block;
  line-height: 1.5; }

.breadCrumb i {
  display: inline-block;
  padding: 0 4px;
  color: #dbdbdb; }

#wrapper {
  overflow: hidden;
  padding: 0 0 80px;
  background-color: #fff; }

.pageTitle {
  margin: 60px 0;
  font-weight: bold;
  font-size: 26px;
  letter-spacing: -.02em;
  text-align: center;
  text-transform: uppercase; }
  @media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
    .pageTitle {
      margin: 40px 0;
      padding: 0 20px;
      font-size: 20px; } }

.mv img {
  width: 100%; }

.mainText {
  color: #000;
  text-align: center;
  margin: 40px 0 20px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.6; }
  @media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
    .mainText {
      text-align: left;
      margin: 20px 0 40px; } }

@media only screen and (min-width: 1025px) {
  .wrappingSection {
    width: 800px;
    margin: 0 auto; } }

@media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
  .wrappingSection {
    padding: 0 20px; } }

.sectionTitle {
  color: #000;
  text-align: center;
  margin: 70px 0 50px;
  font-size: 22px;
  font-weight: bold; }
  @media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
    .sectionTitle {
      font-size: 18px;
      margin: 50px 0 30px; } }

.sectionText {
  color: #000;
  margin: 40px 0 20px;
  line-height: 1.6;
  font-size: 14px;
  font-weight: bold; }

.sectionImg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  gap: 20px; }
  @media only screen and (min-width: 1025px) {
    .sectionImg {
      width: 350px; } }

.detailButton {
  color: #000;
  display: block;
  text-align: center;
  margin: 35px auto 0;
  border: 1px solid;
  width: 200px;
  padding: 13px 0;
  font-weight: bold;
  font-size: 14px;
  border-radius: 50px; }
  @media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
    .detailButton {
      margin-top: 30px;
      padding: 15px 20px; } }

.wrappingCaution {
  background: #f1f1f1;
  padding: 30px; }
  @media only screen and (min-width: 1025px) {
    .wrappingCaution {
      width: 600px;
      margin: 50px auto 0; } }
  @media only screen and (max-width: 767px), only screen and (min-width: 768px) and (max-width: 1024px) {
    .wrappingCaution {
      margin-top: 40px;
      padding: 30px 20px; } }

.wrappingCaution_title {
  color: #000;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px; }

.wrappingCaution_listNode {
  line-height: 1.6;
  font-size: 14px;
  font-weight: bold; }
  .wrappingCaution_listNode + .wrappingCaution_listNode {
    margin-top: 5px; }
