/* リセット */

* {
  box-sizing: border-box;
}

html {
  overflow: auto;
}

body {
  overflow: hidden;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre,
form, fieldset, input, textarea, p, blockquote, th, td, figure {
  padding: 0;
  margin: 0;
}

a {
  text-decoration: none;
}

table {
  border-spacing: 0;
}

fieldset, img {
  border: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
  font-weight: normal;
  font-style: normal;
}

strong {
  font-weight: bold;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
}

q:before, q:after {
  content: '';
}

abbr, acronym {
  border: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

/* Noto Sans JP -------------------------------------*/

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/NotoSansCJKjp-Light.woff2') format('woff2'),
    url('fonts/NotoSansCJKjp-Light.woff') format('woff');
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/NotoSansCJKjp-Regular.woff2') format('woff2'),
    url('fonts/NotoSansCJKjp-Regular.woff') format('woff');
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/NotoSansCJKjp-Medium.woff2') format('woff2'),
    url('fonts/NotoSansCJKjp-Medium.woff') format('woff');
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/NotoSansCJKjp-Bold.woff2') format('woff2'),
    url('fonts/NotoSansCJKjp-Bold.woff') format('woff');
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 900;
  src: url('fonts/NotoSansCJKjp-Black.woff2') format('woff2'),
    url('fonts/NotoSansCJKjp-Black.woff') format('woff');
}

/* Zen Maru Gothic -------------------------------------*/

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/ZenMaruGothic-Light.woff2') format('woff2'),
    url('fonts/ZenMaruGothic-Light.woff') format('woff');
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/ZenMaruGothic-Regular.woff2') format('woff2'),
    url('fonts/ZenMaruGothic-Regular.woff') format('woff');
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/ZenMaruGothic-Medium.woff2') format('woff2'),
    url('fonts/ZenMaruGothic-Medium.woff') format('woff');
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/ZenMaruGothic-Bold.woff2') format('woff2'),
    url('fonts/ZenMaruGothic-Bold.woff') format('woff');
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 900;
  src: url('fonts/ZenMaruGothic-Black.woff2') format('woff2'),
    url('fonts/ZenMaruGothic-Black.woff') format('woff');
}

/* WebFont -------------------------------------*/

@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');


/*-------------------------------------------------
/* 基本
--------------------------------------------------*/

:root {
  --color-main: #009fe8;
  --color-light-main: #c8e6f4;
  --color-bright-main: #e0eff6;
  --color-back: #e9f1f5;
  --color-text: #321f1f;
  --color-white: #ffffff;
  --color-blue: #0075a9;
  --color-dark-blue: #16375d;
  --color-light-brown: #b99d9d;
  --color-bright-brown: #f9f4f4;
  --color-dark-brown: #321f1f;
  --color-red: #fe0014;
  --color-dark-red: #cc0010;
  --color-red-orange: #bd3d2e;
  --color-orange: #F27428;
  --color-light-orange: #f7d0b9;
  --color-pink: #e4007f;
  --color-light-pink: #f7cae3;
  --color-bright-pink: #fff0f8;
  --color-green: #32b16c;
  --color-light-green: #6ecb80;
  --color-yellow: #F5C329;
  --color-light-yellow: #f9e545;
  --color-light-gray: #cccccc;
  --color-gray: #777777;
  --color-visited: #585858;
  --color-visited-main: #86bdd1;
  --box-shadow: 10px 10px 20px 3px rgba(2, 8, 10, 0.1);
  --box-shadow-min: 0 0 10px 3px rgba(2, 8, 10, 0.1);
  --box-shadow-hover: 0 0 20px 10px rgba(2, 8, 10, 0.2);
  --font-family-main: 'Noto Sans CJK JP', 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'BIZ UDPGothic', Meiryo, sans-serif;
  --font-family-maru: 'Zen Maru Gothic', 'Hiragino Maru Gothic Pro', 'HGMaruGothicMPRO', sans-serif;
  --font-family-en: 'Poppins', Verdana, sans-serif;
  --section-width-sp: calc(100vw - 40px);
  --section-width-tb: calc(100vw - 80px);
  --section-width-pc: calc(100vw - 120px);
  --section-width-max: 1280px;
}


body {
  font-family: var(--font-family-main);
  color: var(--color-text);
  font-size: 16px;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.08em;
  line-height: 1.6;
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  -webkit-print-color-adjust: exact;
}

.foot-copy,
.en {
  font-family: var(--font-family-en);
}

a:link {
  text-decoration: none;
}

a:visited {
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

a:active {
  text-decoration: none;
}

/* iPhoneTELリンク色変更なしにする */
a[href^="tel"] {
  color: inherit;
  text-decoration: none;
}

img {
  vertical-align: bottom;
  -ms-interpolation-mode: bicubic;
}

.wrapper {
  position: relative;
  background: var(--color-back);
}

html {
  scroll-behavior: smooth;
}


/*****************************************
*
* フォーム
*
******************************************/

/*---------------------------------------------
* フォーム
----------------------------------------------*/
.mform_school,
.mform_name,
.mform_zip,
.mform_address,
.mform_tel,
.mform_mail,
.mform_text,
.mform_date {
  padding: 2px;
}

.mform_name {
  width: 200px;
}

.mform_zip {
  width: 100px;
}

.mform_tel {
  width: 300px;
}

.mform_mail {
  width: 300px;
}

.mform_date {
  width: 160px;
}

.mform_number {
  width: 100px;
}

.mform_address {
  width: 300px;
}

.mform_school {
  width: 300px;
}

.mform_text {
  width: 300px;
  height: 100px;
}

@media screen and (min-width: 768px), print {
  .mform_name {
    width: 120px;
  }

  .mform_address {
    width: 400px;
  }

  .mform_school {
    width: 400px;
  }

  .mform_text {
    width: 500px;
    height: 200px;
  }
}

/* 入力切り替え（Chrome非対応） -----------------------------------*/
/*IMEオン*/
.mform_name,
.mform_address,
.mform_school,
.mform_text {
  ime-mode: active;
}

/*IMEオフ*/
.mform_date,
.mform_zip,
.mform_tel,
.mform_mail,
.mform_number {
  ime-mode: inactive;
}

/*---------------------------------------------
親から継承せず、システムデフォルトの体裁を使用してしまう事象の対策
（このタグを入れておけば、placeholderのフォントがbodyのフォントになり、
input::placeholderのフォント指定が不要になる）
----------------------------------------------*/
button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
}

/* 入力エリア ---------------------------------------------*/
textarea,
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="date"],
input[type="number"] {
  outline: 0;
  padding: 3px 10px;
  border-radius: 3px;
  border: solid 1px var(--color-light-gray);
  background: transparent;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(52, 152, 219, 0);
}

input:focus,
select:focus,
textarea:focus {
  border: solid 1px var(--color-main);
}

@media screen and (max-width: 767px) {

  /*iOSのズーム回避*/
  textarea,
  input[type="text"],
  input[type="tel"],
  input[type="email"],
  input[type="date"],
  input[type="number"] {
    font-size: 16px;
  }
}

/*上下の矢印消去*/
/* Chrome/Safari */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

/*上下の矢印消去*/
/* Firefox */
input[type="number"] {
  -moz-appearance: textfield;
}

input::placeholder {
  color: #ccc;
}

/*---------------------------------------------
* select
----------------------------------------------*/
select {
  /* styling */
  background-color: var(--color-white);
  display: inline-block;
  color: var(--color-text);
  font: inherit;
  padding: 0.3em 3.5em 0.3em 1em;
  border-radius: 3px;
  border: 1px solid var(--color-light-gray);
  /* reset */
  margin: 0;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: none;
}

/* IE reset */
select::-ms-expand {
  display: none;
}

select.minimal {
  border: 1px solid var(--color-light-gray);
  border-radius: 3px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--color-gray) 50%),
    linear-gradient(135deg, var(--color-gray) 50%, transparent 50%),
    linear-gradient(to right, var(--color-light-gray), var(--color-light-gray));
  background-position:
    calc(100% - 20px) calc(1em + 2px),
    calc(100% - 15px) calc(1em + 2px),
    calc(100% - 2.5em) 0.5em;
  background-size:
    5px 5px,
    5px 5px,
    0px 1.5em;
  background-repeat: no-repeat;
}

/*---------------------------------------------
* radio
同じnameでないと複数選択できてしまう。
----------------------------------------------*/
.mformradio input[type="radio"] {
  display: none;
}

.mformradio label {
  position: relative;
  display: inline-block;
  padding: 3px 3px 3px 20px;
  cursor: pointer;
}

.mformradio label::before {
  position: absolute;
  content: '';
  top: 50%;
  left: 0;
  width: 14px;
  height: 14px;
  margin-top: -8px;
  background: #var(--color-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 100%;
}

.mformradio input[type="radio"]:checked+label::after {
  position: absolute;
  content: '';
  top: 50%;
  left: 4px;
  width: 8px;
  height: 8px;
  margin-top: -4px;
  background: var(--color-main);
  border-radius: 100%;
}

/*---------------------------------------------
* checkbox
----------------------------------------------*/
.mformcheck input[type="checkbox"] {
  display: none;
}

.mformcheck label {
  position: relative;
  display: inline-block;
  padding: 3px 3px 3px 22px;
  cursor: pointer;
  transition: all .2s;
}

.mformcheck label::before,
.mformcheck label::after {
  position: absolute;
  content: '';
  transition: all .2s;
}

.mformcheck label::before {
  top: 50%;
  left: 0;
  width: 14px;
  height: 14px;
  margin-top: -8px;
  background: var(--color-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 3px;
}

.mformcheck label::after {
  opacity: 0;
  top: 50%;
  left: 3px;
  width: 8px;
  height: 4px;
  margin-top: -4px;
  border-left: 2px solid var(--color-main);
  border-bottom: 2px solid var(--color-main);
  transform: rotate(-45deg) scale(.5);
}

.mformcheck label:hover::before {
  background: var(--color-white);
}

.mformcheck input[type="checkbox"]:checked+label::before {
  background: var(--color-white);
  border: 1px solid var(--color-main);
}

.mformcheck input[type="checkbox"]:checked+label::after {
  opacity: 1;
  transform: rotate(-45deg) scale(1);
}


/*---------------------------------------------
* button
----------------------------------------------*/

/*buttonリセット*/
button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  outline: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
}


/*---------------------------------------------
* submit
----------------------------------------------*/
input[type="submit"] {
  -webkit-appearance: none;
}

.btn-submit {
  cursor: pointer;
  border: solid 1px var(--color-red);
  border-radius: 40px;
  background: var(--color-red);
  color: var(--color-white);
  font-size: 1.1em;
  font-weight: bold;
  padding: 10px 20px;
  transition: all .5s ease;
}

.btn-submit:hover {
  text-decoration: none;
  box-shadow: var(--box-shadow-hover);
}

.btn-back {
  cursor: pointer;
  border-radius: 40px;
  border: solid 1px var(--color-gray);
  background: var(--color-gray);
  color: var(--color-white);
  font-size: 1.1em;
  font-weight: bold;
  padding: 10px 40px;
  transition: all .5s ease;
}

.btn-back:hover {
  text-decoration: none;
  box-shadow: var(--box-shadow-hover);

}

/* 同意させるボタン --------------------------------------*/
/* ボタンがアクティブになる前のスタイル */
#submitButton {
  cursor: not-allowed;
  background-color: var(--color-light-gray);
  border: solid 1px var(--color-light-gray);
  border-radius: 40px;
  color: var(--color-gray);
  font-size: 1.1em;
  font-weight: 500;
  padding: 10px 20px;
  transition: all .5s ease;
}

/* ボタンがアクティブになった後のスタイル */
#submitButton:active, #submitButton:enabled {
  cursor: pointer;
  background-color: var(--color-red);
  border: solid 1px var(--color-red);
  color: white;
}

/*---------------------------------------------
* レイアウト
----------------------------------------------*/

/* 必須 --------------------------------------*/
.asterisk {
  display: inline-block;
  color: var(--color-white);
  font-size: 0.6em;
  line-height: 1;
  background: var(--color-red);
  border-radius: 10px;
  padding: 3px 5px;
  margin-left: 5px;
}

.asterisk-min {
  color: var(--color-red);
  margin-right: 0.2em;
}

.asterisk-min-none {
  width: 0.7em;
}


/* テキスト --------------------------------------*/
.sub-text {
  font-size: 0.8em;
}

.sub-text.margin {
  margin-bottom: 0.5em;
}

/* フォームレイアウト --------------------------------------*/
.mform-box {
  text-align: left;
  border-top: solid 1px var(--color-light-gray);
  padding-top: 20px;
  margin-top: 20px;
}

.mform-box.bordernon {
  border: 0;
}

.mform-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (min-width: 768px), print {
  .mform-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: 40px;
  }

  .mform-item {
    -ms-flex-negative: 0;
    -webkit-flex-shrink: 0;
    flex-shrink: 0;
    width: 14em;
    margin-right: 40px;
  }
}

/* 横並び --------------------------------------*/
.mformlirow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.mformlirow div {
  margin-right: 10px;
}

.mformlirow div.second {
  margin: 0;
}

/* 住所 --------------------------------------*/
.mformaddress li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 0.5em;
}

.mformaddress li p {
  width: 5em;
}

/* 電話番号 --------------------------------------*/
.mform-tel div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 0.5em;
}

.mform-tel div.second {
  margin: 0;
}

/* 電話番号 --------------------------------------*/
.mformtel .cont {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.mformtel .cont.second {
  margin-top: 0.5em;
}

.mformtel .cont p {
  width: 7em;
}

.hyphen {
  padding: 0 0.5em;
}

/* 年月 --------------------------------------*/
.yearmonth p {
  margin-left: 0.5em;
}

/* 卒業高校 --------------------------------------*/
.highschool p {
  width: 6em;
  margin-right: 0.5em;
}

.highschool.margin {
  margin-top: 0.5em;
}


/*確認画面 --------------------------------------*/
.submit-confirm {
  display: inline-block;
  width: 100%;
  text-align: center;
  margin-top: 40px;
}

.submit-confirm ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.submit-confirm ul li:not(:first-child) {
  margin-left: 20px;
}


/*****************************************
*
* 共通パーツ
*
******************************************/


/*------------------------------------------*/
/* section
/*------------------------------------------*/

.section {
  width: calc(100% - 40px);
  margin: 0 auto;
  margin-top: 60px;
}

.section.back-white {
  background: var(--color-white);
  border-radius: 10px;
  padding: 60px 10px;
}

@media screen and (min-width: 768px), print {
  .section {
    width: calc(100% - 80px);
  }

  .section.back-white {
    border-radius: 20px;
    padding: 60px 40px;
  }
}

@media screen and (min-width: 834px), print {
  .section {
    width: calc(100% - 120px);
    margin-top: 100px;
  }

  .section.back-white {
    padding: 80px 60px;
  }
}

@media screen and (min-width: 1200px), print {
  .section {
    width: 1100px;
  }
}

.section.margin0 {
  margin-top: 0;
}

/*------------------------------------------*/
/* margin 区切りごと
/*------------------------------------------*/

.contents-section {
  margin-top: 40px;
}

@media screen and (min-width: 1020px), print {
  .contents-section {
    margin-top: 60px;
  }
}


/*------------------------------------------*/
/* margin 区切りマージンより少し狭い
/*------------------------------------------*/
.contents-margin {
  margin-top: 30px;
}

@media screen and (min-width: 768px), print {
  .contents-margin {
    margin-top: 40px;
  }
}

/*------------------------------------------*/
/* margin 1文字文
/*------------------------------------------*/
.margin-p {
  margin-top: 1em;
}

/*------------------------------------------*/
/* 訪問済みでも色を戻したくない場合
/*------------------------------------------*/
a.link-color,
a.link-color:visited {
  color: var(--color-main);
}


/*------------------------------------------*/
/* 外部リンク
/*------------------------------------------*/

.link-blank {
  color: var(--color-main);
}

.link-blank::after {
  content: '';
  display: inline-block;
  background: url('img/icon_blank.svg') no-repeat;
  background-size: 100%;
  width: 15px;
  height: 15px;
  margin-left: 3px;
}

.link-blank-dark::after {
  content: '';
  display: inline-block;
  background: url('img/icon_blank_dark.svg') no-repeat;
  background-size: 100%;
  width: 15px;
  height: 15px;
  margin-left: 3px;
}

.link-blank-white::after {
  content: '';
  display: inline-block;
  background: url('img/icon_blank_white.svg') no-repeat;
  background-size: 100%;
  width: 15px;
  height: 15px;
  margin-left: 3px;
}

/*------------------------------------------*/
/* PDFリンク
/*------------------------------------------*/

.link-pdf {
  color: var(--color-main);
}

.link-pdf::after {
  content: '';
  display: inline-block;
  background: url('img/icon_pdf.svg') no-repeat;
  background-size: 100%;
  width: calc(17px / 1);
  height: calc(20px / 1);
  margin-right: 3px;
}


/*------------------------------------------*/
/* リンク無効
/*------------------------------------------*/
.link-off {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
}

/*------------------------------------------*/
/* 注意書き
/*------------------------------------------*/
.notes {
  text-align: justify;
  text-justify: inter-ideograph;
  padding-left: 1em;
  text-indent: -1em;
  font-size: 0.9rem;
}

/*------------------------------------------*/
/* テキスト
/*------------------------------------------*/
.text-def {
  text-align: justify;
  text-justify: inter-ideograph;
  line-height: 1.8;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.tex-indent-1 {
  margin-left: 1em;
}

.text-bold {
  font-weight: bold;
}

.text-min {
  font-size: 0.9rem;
}

.text-large {
  font-size: 1.2rem;
}

.text-red {
  color: var(--color-red);
}

.text-pink {
  color: var(--color-red);
}

/*------------------------------------------*/
/* H2
/*------------------------------------------*/

.heading-secondary {
  position: relative;
  width: 100%;
  margin-bottom: 40px;
}

.heading-secondary .heading {
  position: relative;
  display: inline-block;
  font-family: var(--font-family-maru);
  font-size: 1.1rem;
  font-weight: bold;
}

.heading-secondary .heading::before {
  content: '';
  display: inline-block;
  background: url('img/line_wave.svg') repeat-x;
  background-size: contain;
  aspect-ratio: 110/60;
  width: 100%;
  height: 6px;
  position: absolute;
  bottom: -10px;
  left: 0;
}

@media screen and (min-width: 768px), print {
  .heading-secondary {
    margin-bottom: 80px;
  }

  .heading-secondary .heading {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 1020px), print {
  .heading-secondary .heading {
    font-size: 2rem;
  }
}

/*------------------------------------------*/
/* H3
/*------------------------------------------*/

.heading-tertiary {
  position: relative;
  text-align: left;
  border-bottom: dashed 2px var(--color-dark-brown);
  font-size: 1.1rem;
  font-weight: bold;
  padding-bottom: 10px;
  margin-bottom: 20px;
}

@media screen and (min-width: 834px), print {
  .heading-tertiary {
    font-size: 1.4rem;
  }
}


/*------------------------------------------*/
/* リスト 丸
/*------------------------------------------*/

.list-type-circle li {
  position: relative;
  text-align: left;
  padding-left: 15px;
}

.list-type-circle li::before {
  content: '';
  display: inline-block;
  background: var(--color-text);
  border-radius: 50%;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 0.7em;
  left: 0;
}

.list-type-circle.red-orange li::before {
  background: var(--color-red-orange);
}

.list-type-circle.orange li::before {
  background: var(--color-orange);
}

.list-type-circle.pink li::before {
  background: var(--color-pink);
}

.list-type-circle.blue li::before {
  background: var(--color-main);
}

.list-type-circle li+li {
  margin-top: 0.5em;
}


/*------------------------------------------*/
/* ボタン
/*------------------------------------------*/

.btn-type1 {
  position: relative;
  display: inline-block;
  background: transparent;
  border: solid 2px var(--color-text);
  border-radius: 40px;
  color: var(--color-text);
  font-weight: bold;
  padding: 10px 50px 10px 30px;
  transition: all .5s ease;
}

.btn-type1.blue {
  background: var(--color-main);
  border: solid 2px var(--color-main);
  color: var(--color-white);
}

.btn-type1.green {
  background: var(--color-green);
  border: solid 2px var(--color-green);
  color: var(--color-white);
}

.btn-type1.pink {
  background: var(--color-pink);
  border: solid 2px var(--color-pink);
  color: var(--color-white);
}

.btn-type1::after {
  content: '';
  display: inline-block;
  background: url('img/arrow_btn_white.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 1/1;
  width: 20px;
  height: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
  transition: all .5s ease;
}

.btn-type1.blank::after {
  background: url('img/icon_blank_dark.svg') no-repeat;
  background-size: 100%;
}

.btn-type1:hover {
  text-decoration: none;
  background: var(--color-text);
  color: var(--color-white);
}

.btn-type1.blue:hover {
  background: transparent;
  color: var(--color-main);
}

.btn-type1.green:hover {
  background: transparent;
  color: var(--color-green);
}

.btn-type1.pink:hover {
  background: transparent;
  color: var(--color-pink);
}

.btn-type1:hover::after {
  background: url('img/arrow_btn.svg') no-repeat;
  background-size: 100%;
}

.btn-type1.blue:hover::after {
  background: url('img/arrow_btn_blue.svg') no-repeat;
  background-size: 100%;
}

.btn-type1.green:hover::after {
  background: url('img/arrow_btn_green.svg') no-repeat;
  background-size: 100%;
}

.btn-type1.pink:hover::after {
  background: url('img/arrow_btn_pink.svg') no-repeat;
  background-size: 100%;
}

.btn-type1.blank:hover::after {
  background: url('img/icon_blank_white.svg') no-repeat;
  background-size: 100%;
}

@media screen and (min-width: 834px), print {
  .btn-type1 {
    padding: 15px 60px 15px 40px;
  }
}


/*------------------------------------------*/
/* 表 下線が破線
/*------------------------------------------*/
.table-type-underline-dashed {
  border-collapse: collapse;
  width: 100%;
}

.table-type-underline-dashed th,
.table-type-underline-dashed td {
  text-align: left;
  border-bottom: dashed 1px var(--color-light-gray);
  padding: 20px 0;
}

.table-type-underline-dashed th {
  font-weight: bold;
}

.table-type-underline-dashed.text-top th {
  vertical-align: text-top;
}

.table-type-underline-dashed td {
  text-align: justify;
  text-justify: inter-ideograph;
}

@media screen and (max-width: 767px) {

  .table-type-underline-dashed tr,
  .table-type-underline-dashed th,
  .table-type-underline-dashed td {
    display: block;
    width: auto;
  }

  .table-type-underline-dashed th,
  .table-type-underline-dashed td {
    border-bottom: 1px solid var(--color-light-gray);
    padding: 10px 0;
  }

  .table-type-underline-dashed th {
    border-bottom: 1px dotted var(--color-light-gray);
  }
}

@media screen and (min-width: 768px), print {
  .table-type-underline-dashed th {
    width: 10em;
  }
}


/*------------------------------------------*/
/* 表 thの背景が薄い青
/*------------------------------------------*/
.table-type-th-background {
  border-collapse: collapse;
  width: 100%;
}

.table-type-th-background thead th {
  border: 0;
  background: var(--color-dark-brown);
  border-radius: 20px 20px 0 0;
  color: var(--color-white);
  font-weight: bold;
}

.table-type-th-background th,
.table-type-th-background td {
  text-align: center;
  border: 1px solid var(--color-dark-brown);
  padding: 10px;
}

.table-type-th-background th.center,
.table-type-th-background td.center {
  text-align: center;
}

.table-type-th-background th.left,
.table-type-th-background td.left {
  text-align: left;
}

.table-type-th-background th.right,
.table-type-th-background td.right {
  text-align: right;
}

.table-type-th-background th {
  background: var(--color-bright-pink);
}

@media screen and (max-width: 767px) {
  .table-type-th-background {
    /*テーブルスマホで横スクロールさせる場合*/
    display: block;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  .table-type-th-background th,
  .table-type-th-background td {
    font-size: 0.9rem;
  }
}

/*------------------------------------------*/
/* ロゴ
/*------------------------------------------*/

.logo {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  font-size: 0;
  display: inline-block;
  background: url('img/logo.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 19/2;
  width: 140px;
  height: auto;
}

@media screen and (min-width: 768px), print {
  .logo {
    width: calc(calc(200 / 1400) * 100vw);
    ;
  }
}

@media screen and (min-width: 1400px), print {
  .logo {
    width: 200px;
  }
}


/*****************************************
*
* ヘッダ
*
******************************************/

header {
  width: 100%;
  text-align: left;
}

/*------------------------------------------*/
/* ロゴ
/*------------------------------------------*/

header .logo {
  width: 140px;
  margin-top: 10px;
  margin-left: 20px;
  margin-bottom: 10px;
}

@media screen and (min-width: 768px), print {
  header .logo {
    width: calc(calc(200 / 1400) * 100vw);
    ;
    margin-top: 20px;
    margin-left: 20px;
  }
}

@media screen and (min-width: 834px), print {
  header .logo {
    margin-left: 60px;
    margin-bottom: 20px;
  }
}

@media screen and (min-width: 1400px), print {
  header .logo {
    width: 200px;
    margin-left: calc(50% - calc(1280px / 2));
  }
}


/*****************************************
*
* フッタ
*
******************************************/

footer {
  position: relative;
  width: 100%;
  background: var(--color-text);
  color: var(--color-white);
  text-align: center;
  margin-top: 60px;
}

.footer {
  width: calc(100% - 40px);
  padding: 20px 0;
  margin: 0 auto;
}

@media screen and (min-width: 768px), print {
  .footer {
    width: calc(100% - 80px);
    padding: 40px 0;
  }
}

@media screen and (min-width: 834px), print {
  footer {
    margin-top: 100px;
  }

  .footer {
    width: calc(100% - 120px);
  }
}

@media screen and (min-width: 1400px), print {
  .footer {
    width: 1100px;
  }
}


/* フッタロゴ --------------------------------*/
footer .logo {
  background: url('img/logo_white.svg') no-repeat;
  background-size: 100%;
}


/* フッタコピーライト --------------------------------*/
.footer-copy {
  font-size: 0.8rem;
  font-weight: 400;
  margin-top: 20px;
}

@media screen and (min-width: 768px), print {
  .footer-copy {
    margin-top: 40px;
  }
}


/*------------------------------------------*/
/* フッタ上へ
/*------------------------------------------*/
.totop {
  display: inline-block;
  background: url('img/totop.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 10/5;
  width: 30px;
  height: auto;
  position: absolute;
  right: 10px;
  top: 20px;
  z-index: 10;
  transition: all .5s ease;
}

.totop:hover {
  text-decoration: none;
  transform: translateY(-10px);
}

@media screen and (min-width: 768px), print {
  .totop {
    width: 60px;
    top: 40px;
    right: 40px;
  }
}

/*****************************************
*
* 印刷用
*
******************************************/

@media print {
  body {
    width: 1200px;
    transform: scale(0.8);
    transform-origin: 0 0;
    -webkit-print-color-adjust: exact;
  }

  /* FireFoxテーブル印刷バグ回避 */
  _:-ms-lang(x)::-ms-backdrop, .wrapper {
    overflow: auto;
    display: table;
  }
}


/*****************************************
*
* topmain
*
******************************************/

.topmain {
  width: var(--section-width-sp);
  margin: 0 auto;
}

.topmain-inner {
  position: relative;
}

@media screen and (min-width: 768px), print {
  .topmain {
    width: var(--section-width-tb);
  }
}

@media screen and (min-width: 834px), print {
  .topmain {
    width: var(--section-width-pc);
  }
}

@media screen and (min-width: 1400px), print {
  .topmain {
    width: var(--section-width-max);
  }
}

/* メイン画像 --------------------------------*/
.topmain .image-main img {
  width: 100%;
  mask-image: url('img/main_mask.svg');
  mask-repeat: no-repeat;
  mask-size: 100%;
  /* Chrome, Safari用 */
  -webkit-mask-image: url('img/main_mask.svg');
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100%;
}

.topmain .image-main {
  width: 100%;
}

@media screen and (min-width: 768px), print {
  .topmain .image-main {
    --width: calc(calc(800 / 1400) * 100vw);
    width: var(--width);
    margin-left: calc(calc(100vw - 80px) - var(--width));
  }
}

@media screen and (min-width: 834px), print {
  .topmain .image-main {
    --width: calc(calc(800 / 1400) * 100vw);
    width: var(--width);
    margin-left: calc(calc(100vw - 120px) - var(--width));
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .image-main {
    width: 800px;
    /* 1280 - 800 */
    margin-left: 480px;
  }
}

/*------------------------------------------*/
/* キャッチコピー
/*------------------------------------------*/

.topmain .catchcopy {
  position: absolute;
  top: calc(calc(140 / 767) * 100vw);
  left: 0;
  z-index: 1;
}

@media screen and (min-width: 768px), print {
  .topmain .catchcopy {
    top: calc(calc(40 / 1400) * 100vw);
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .catchcopy {
    top: 40px;
  }
}

/* テキスト --------------------------------*/
.topmain .catchcopy .text {
  text-align: left;
  color: var(--color-dark-blue);
  font-family: var(--font-family-maru);
  font-size: 1.2rem;
  font-weight: bold;
}

.topmain .catchcopy .text .min {
  font-size: 1rem;
}

.topmain .catchcopy .text .font {
  font-family: var(--font-family-main);
}

.topmain .catchcopy .text-3 {
  color: var(--color-pink);
}

@media screen and (max-width: 767px) {
  .topmain .catchcopy .text {
    text-shadow: 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back), 0 0 2px var(--color-back);
  }
}

@media screen and (min-width: 768px), print {
  .topmain .catchcopy .text {
    --font-size: calc(3.4 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
    font-weight: 700;
  }

  .topmain .catchcopy .text .min {
    --font-size: calc(2.6 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .catchcopy .text {
    font-size: 3.4rem;
  }

  .topmain .catchcopy .text .min {
    font-size: 2.6rem;
  }
}

/* 車画像 --------------------------------*/
.topmain .image-car img {
  width: 100%;
}

.topmain .image-car {
  width: 40px;
  position: absolute;
  top: -30px;
  left: 10px;
}

@media screen and (min-width: 768px), print {
  .topmain .image-car {
    width: calc(calc(160 / 1400) * 100vw);
    top: calc(calc(-20 / 1400) * 100vw);
    left: auto;
    right: 0;
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .image-car {
    width: 160px;
    top: -20px;
  }
}

/*------------------------------------------*/
/* 金利
/*------------------------------------------*/

.topmain .rate-box {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: var(--color-white);
  border: solid 2px var(--color-main);
  padding: 10px;
  padding: 10px 15px 15px 15px;
}

.topmain .rate-box::before,
.topmain .rate-box::after {
  content: '';
  display: inline-block;
  background: var(--color-main);
  position: absolute;
  bottom: -10px;
  right: -10px;
}

.topmain .rate-box::before {
  width: 2px;
  height: 100%;
}

.topmain .rate-box::after {
  width: 100%;
  height: 2px;
}

.topmain .rate-box .pink {
  color: var(--color-pink);
}

@media screen and (max-width: 767px) {
  .topmain .rate-box {
    margin-top: 20px;
  }
}

@media screen and (min-width: 768px), print {
  .topmain .rate-box-wrap {
    position: absolute;
    bottom: 20px;
    left: 0;
  }

  .topmain .rate-box {
    padding: calc(calc(20 / 1400) * 100vw) calc(calc(40 / 1400) * 100vw) calc(calc(10 / 1400) * 100vw) calc(calc(40 / 1400) * 100vw);
    padding: calc(calc(20 / 1400) * 100vw) calc(calc(40 / 1400) * 100vw);
  }

  .topmain .rate-box::before,
  .topmain .rate-box::after {
    bottom: calc(calc(-10 / 1400) * 100vw);
    right: calc(calc(-10 / 1400) * 100vw);
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .rate-box {
    padding: 20px 40px 10px 40px;
    padding: 20px 40px;
  }

  .topmain .rate-box::before,
  .topmain .rate-box::after {
    bottom: -10px;
    right: -10px;
  }
}

/* 金利 --------------------------------*/
.topmain .rate-box {
  color: var(--color-dark-blue);
  font-weight: bold;
  line-height: 1;
}

.topmain .rate-box .kinri {
  font-size: 1rem;
  margin-right: 0.5em;
}

.topmain .rate-box .year {
  font-size: 1.2rem;
}

.topmain .rate-box .rate {
  font-size: 1.2rem;
  margin-left: 0.2em;
}

.topmain .rate-box .rate .en {
  display: inline-block;
  font-weight: 600;
  margin-bottom: -0.7em;
}

.topmain .rate-box .rate .large {
  font-size: 2rem;
}

.topmain .rate-box .rate .min {
  font-size: 1rem;
}

.topmain .rate-box .rate .medium {
  font-size: 1.4rem;
}

@media screen and (min-width: 768px), print {
  .topmain .rate-box .rate .en {
    margin-bottom: -1em;
  }

  .topmain .rate-box .kinri {
    --font-size: calc(1.4 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
    margin-right: 0.5em;
  }

  .topmain .rate-box .year {
    --font-size: calc(1.8 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }

  .topmain .rate-box .rate {
    --font-size: calc(3 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }

  .topmain .rate-box .rate .large {
    --font-size: calc(4 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }

  .topmain .rate-box .rate .medium {
    --font-size: calc(2.4 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }

  .topmain .rate-box .rate .min {
    --font-size: calc(1.8 * 16);
    font-size: calc(calc(var(--font-size) / 1400) * 100vw);
  }
}

@media screen and (min-width: 1400px), print {
  .topmain .rate-box .kinri {
    font-size: 1.4rem;
    margin-right: 0.5em;
  }

  .topmain .rate-box .year {
    font-size: 1.8rem;
  }

  .topmain .rate-box .rate {
    font-size: 3rem;
  }

  .topmain .rate-box .rate .large {
    font-size: 4rem;
  }

  .topmain .rate-box .rate .medium {
    font-size: 2.4rem;
  }

  .topmain .rate-box .rate .min {
    font-size: 1.8rem;
  }
}



/*****************************************
*
* 選ばれるポイント
*
******************************************/

@media screen and (max-width: 767px) {
  .top-point {
    background: var(--color-white);
    border-radius: 10px;
    padding: 10px;
    margin-top: 40px;
  }

  .top-point .heading {
    position: relative;
    display: inline-block;
    width: 100%;
    background: var(--color-dark-brown);
    border-radius: 20px;
    color: var(--color-white);
    font-size: 1rem;
    font-weight: bold;
    padding: 5px 10px;
  }

  .top-point .heading::before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-color: var(--color-dark-brown) transparent transparent transparent;
    border-width: 10px 8px 0 8px;
    border-style: solid;
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
  }

  .top-point .list {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 10px;
    margin-top: 20px;
  }

  .top-point .list li {
    text-align: left;
    display: flex;
    width: 100%;
  }

  .top-point .list li .num {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-dark-brown);
    border-radius: 4px;
    color: var(--color-white);
    font-size: 1.2rem;
    font-weight: bold;
    width: 1.5em;
    height: 1.5em;
  }

  .top-point .list li .num::before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-color: transparent transparent transparent var(--color-dark-brown);
    border-width: 0px 0 10px 15px;
    border-style: solid;
    position: absolute;
    top: 0;
    right: -10px;
  }

  .top-point .list li .cont {
    width: 100%;
    border-radius: 4px;
    background: var(--color-light-pink);
    font-size: 1rem;
    font-weight: bold;
    padding: 5px 10px;
  }

  .top-point .list li .non {
    display: none;
  }
}

@media screen and (min-width: 768px), print {
  .top-point {
    margin-top: calc(calc(20 / 1400) * 100vw);
  }

  .top-point .heading {
    display: none;
  }

  .top-point .list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 20px;
  }

  .top-point .list li {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    background: var(--color-dark-brown);
    border-radius: 10px;
    color: var(--color-white);
    font-family: var(--font-family-maru);
    font-size: calc(calc(18 / 1400) * 100vw);
    font-weight: bold;
    padding: calc(calc(20 / 1400) * 100vw);
  }

  .top-point .list li .num {
    display: none;
  }
}

@media screen and (min-width: 1400px), print {
  .top-point {
    margin-top: 20px;
  }

  .top-point .list li {
    font-size: 1.2rem;
    padding: 20px;
  }
}


/*****************************************
*
* 申込み タブなし
*
******************************************/


.top-register {
  background: var(--color-light-yellow);
  border-radius: 10px;
  padding: 10px;
}

@media screen and (min-width: 768px), print {
  .top-register {
    border-radius: 20px;
    padding: 20px 40px;
  }
}

@media screen and (min-width: 834px), print {
  .top-register {
    padding: 30px 60px;
  }
}

/* 見出し --------------------------------*/
.top-register .heading {
  position: relative;
  display: inline-block;
  font-family: var(--font-family-maru);
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 20px;
}

@media screen and (min-width: 768px), print {
  .top-register .heading {
    font-size: 2rem;
    margin-bottom: 20px;
  }
}

/* ボタン --------------------------------*/
.top-register .btn .btn-type1 {
  width: 100%;
}

.top-register .btn .btn-type1.pink:hover {
  background: var(--color-white);
  color: var(--color-pink);
}

/* テキスト --------------------------------*/
.top-register .notes {
  font-size: 0.7rem;
}



/*****************************************
*
* 申込み
*
******************************************/


.top-apply {
  background: var(--color-light-yellow);
  border-radius: 10px;
  padding: 10px;
}

@media screen and (min-width: 768px), print {
  .top-apply {
    border-radius: 20px;
    padding: 20px 40px;
  }
}

@media screen and (min-width: 834px), print {
  .top-apply {
    padding: 30px 60px;
  }
}

/* 見出し --------------------------------*/
.top-apply .heading {
  position: relative;
  display: inline-block;
  font-family: var(--font-family-maru);
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 20px;
}

@media screen and (min-width: 768px), print {
  .top-apply .heading {
    font-size: 2rem;
    margin-bottom: 20px;
  }
}

/*------------------------------------------*/
/* トリガー
/*------------------------------------------*/

.list-tab {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 10px;
}

@media screen and (min-width: 768px), print {
  .list-tab {
    column-gap: 40px;
  }
}

/* タブ --------------------------------*/
.list-tab li .inner {
  cursor: pointer;
  position: relative;
  display: block;
  text-align: center;
  border-radius: 40px;
  font-family: var(--font-family-maru);
  font-size: 0.9rem;
  font-weight: bold;
  padding: 10px;
  transition: all .5s ease;
}

.list-tab li.contents1 .inner {
  color: var(--color-green);
  background: var(--color-white);
  border: solid 2px var(--color-green);
}

.list-tab li.contents2 .inner {
  color: var(--color-main);
  background: var(--color-white);
  border: solid 2px var(--color-main);
}

.list-tab li .inner::before {
  content: '';
  display: inline-block;
  aspect-ratio: 8/3;
  width: 15px;
  height: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 10px;
  transition: all .5s ease;
}

.list-tab li.contents1 .inner::before {
  background: url('img/arrow_green.svg') no-repeat;
  background-size: 100%;
}

.list-tab li.contents2 .inner::before {
  background: url('img/arrow.svg') no-repeat;
  background-size: 100%;
}

.list-tab li span {
  font-size: 1.2rem;
}

@media screen and (min-width: 768px), print {
  .list-tab li .inner {
    font-size: 1.2rem;
  }

  .list-tab li .inner::before {
    width: 20px;
    right: 10px;
  }

  .list-tab li br {
    display: none;
  }

  .list-tab li span {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 834px), print {
  .list-tab li .inner::before {
    width: 30px;
    right: 20px;
  }
}


/* active --------------------------------*/
.list-tab li.active .inner {
  border-bottom: 0;
  border-radius: 40px 40px 0 0;
  padding-bottom: 30px;
}

.list-tab li.active.contents1 .inner {
  background: var(--color-white);
  color: var(--color-green);
}

.list-tab li.active.contents2 .inner {
  background: var(--color-white);
  color: var(--color-main);
}

.list-tab li:not(.active) {}

.list-tab li.contents1:not(.active):hover .inner {
  background: var(--color-green);
  color: var(--color-white);
}

.list-tab li.contents2:not(.active):hover .inner {
  background: var(--color-main);
  color: var(--color-white);
}

.list-tab li:not(.active):hover .inner::before {
  background: url('img/arrow_white.svg') no-repeat;
  background-size: 100%;
}


/*------------------------------------------*/
/* コンテンツ
/*------------------------------------------*/

.tab-content {
  position: relative;
  display: block;
  background: var(--color-white);
  border-radius: 0 0 20px 20px;
  padding: 20px 10px;
}

.tab-content.contents1 {
  border: solid 2px var(--color-green);
  border-top: 0;
}

.tab-content.contents2 {
  border: solid 2px var(--color-main);
  border-top: 0;
}

.tab-content::before {
  content: '';
  display: inline-block;
  width: calc(50% + 7px);
  height: 2px;
  position: absolute;
  top: 0;
}

.tab-content.contents1::before {
  background: var(--color-green);
  right: 0;
}

.tab-content.contents2::before {
  background: var(--color-main);
  left: 0;
}

@media screen and (min-width: 768px), print {
  .tab-content {
    padding: 40px 60px;
  }

  .tab-content::before {
    width: calc(50% + 22px);
  }
}

/* ボタン --------------------------------*/
.tab-content .btn {
  margin-bottom: 40px;
}

.tab-content .btn .btn-type1 {
  display: inline-block;
  width: 100%;
  font-size: 1.2rem;
}

/* 見出し --------------------------------*/
.tab-content .heading-sub {
  position: relative;
  display: inline-block;
  color: var(--color-pink);
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 20px;
  z-index: 2;
}

.tab-content .heading-sub::before {
  content: '';
  display: inline-block;
  background: repeating-linear-gradient(-45deg, var(--color-light-pink), var(--color-light-pink) 5px, var(--color-white) 5px, var(--color-white) 10px);
  width: 100%;
  height: 20px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}

@media screen and (min-width: 768px), print {
  .tab-content .heading-sub {
    font-size: 1.6rem;
    margin-bottom: 40px;
  }
}

/* テキスト --------------------------------*/
@media screen and (max-width: 767px) {
  .tab-content.contents2 .text {
    text-align: justify;
    text-justify: inter-ideograph;
    line-height: 1.8;
  }
}

/* アプリダウンロード --------------------------------*/
.tab-content .appdl {
  margin-top: 20px;
}

.tab-content .appdl .box .btn {
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .tab-content .appdl .box .qr {
    display: none;
  }
}

@media screen and (min-width: 768px), print {
  .tab-content .appdl {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    row-gap: 20px;
    column-gap: 60px;
    margin-top: 40px;
  }

  .tab-content .box .btn img {
    height: 60px;
  }
}


/*****************************************
*
* キャンペーン金利
*
******************************************/

/*------------------------------------------*/
/* 金利
/*------------------------------------------*/

.top-rate .rate-list .box {
  background: var(--color-bright-brown);
  border: dashed 2px var(--color-light-brown);
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .top-rate .rate-list .box {
    display: grid;
    grid-template-columns: 120px 1fr;
    row-gap: 20px;
    align-items: center;
  }

  .top-rate .rate-list .box+.box {
    margin-top: 20px;
  }
}

@media screen and (min-width: 768px), print {
  .top-rate .rate-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 10px;
  }

  .top-rate .rate-list .box {
    padding: 20px;
  }

  .top-rate .rate-list .box+.box {
    margin-left: 20px;
  }
}

/* 条件 --------------------------------*/
.top-rate .rate-list .terms {
  font-size: 0.9rem;
  font-weight: bold;
  line-height: 1.1;
}

@media screen and (min-width: 768px), print {
  .top-rate .rate-list .terms {
    font-size: 1.2rem;
  }
}

/* 金利 --------------------------------*/
.top-rate .rate-list .rate {
  font-family: var(--font-family-en);
  font-size: 1rem;
  font-weight: 600;
}

.top-rate .rate-list .rate span {
  color: var(--color-pink);
  font-size: 1.6rem;
}

@media screen and (min-width: 768px), print {
  .top-rate .rate-list .rate {
    font-size: 2.4rem;
  }

  .top-rate .rate-list .rate span {
    font-size: 4rem;
  }
}

/* テキスト --------------------------------*/
.top-rate .rate-list .text {
  font-size: 0.9rem;
}

.top-rate .rate-list .text span {
  font-family: var(--font-family-en);
  font-size: 1rem;
  font-weight: 600;
}

@media screen and (min-width: 768px), print {
  .top-rate .rate-list .text {
    font-size: 1rem;
  }

  .top-rate .rate-list .text span {
    font-size: 1.1rem;
  }
}


/*------------------------------------------*/
/* 条件 アルファベット
/*------------------------------------------*/

.top-rate .alphabet {
  display: inline-block;
  border-radius: 4px;
  color: var(--color-white);
  font-family: var(--font-family-en);
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.1;
  padding: 5px 10px;
  margin-left: 5px;
}

.top-rate .alphabet.blue {
  background: var(--color-blue);
}

.top-rate .alphabet.green {
  background: var(--color-green);
}

.top-rate .alphabet.orange {
  background: var(--color-orange);
}

.top-rate .alphabet:hover {
  text-decoration: none;
}

@media screen and (min-width: 768px), print {
  .top-rate .alphabet {
    font-size: 1.4rem;
  }
}

/*------------------------------------------*/
/* 条件
/*------------------------------------------*/

.terms-list {
  margin-top: 40px;
}

.terms-list .box {
  display: grid;
  grid-template-columns: 40px 1fr;
  column-gap: 20px;
}

.terms-list .box+.box {
  margin-top: 40px;
}

@media screen and (min-width: 768px), print {
  .terms-list {
    margin-top: 80px;
  }
}

/* リスト --------------------------------*/
.terms-list .list {
  margin-top: 1em;
}

.terms-list .list li {
  text-align: left;
  padding-left: 1em;
  text-indent: -1em;
}

.terms-list .list li+li {
  margin-top: 0.5em;
}



/*****************************************
*
* 選ばれている理由
*
******************************************/

.top-reason-contents+.top-reason-contents {
  margin-top: 40px;
}

@media screen and (min-width: 768px), print {
  .top-reason-contents+.top-reason-contents {
    margin-top: 60px;
  }
}

@media screen and (min-width: 834px), print {
  .top-reason .heading-secondary .heading br {
    display: none;
  }
}

/* 小見出し --------------------------------*/
.top-reason .heading-reason-wrap {
  width: 100%;
  text-align: center;
}

.top-reason .heading-reason {
  position: relative;
  font-family: var(--font-family-maru);
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1;
  padding-top: 10px;
}

.top-reason .heading-reason::before {
  content: '';
  display: inline-block;
  background: url('img/icon_fukidashi.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 124/130;
  width: 90px;
  height: auto;
  position: absolute;
  top: 0px;
  left: 50%;
  transform: translateX(-50%);
}

.top-reason .heading-reason span {
  display: block;
}

.top-reason .heading-reason .en {
  color: var(--color-red-orange);
  font-size: 2rem;
  font-weight: 500;
  margin-top: 10px;
}

@media screen and (min-width: 768px), print {
  .top-reason .heading-reason {
    font-size: 1.4rem;
    padding-top: 15px;
  }

  .top-reason .heading-reason::before {
    width: 124px;
  }

  .top-reason .heading-reason .en {
    font-size: 3rem;
  }
}

/* キャッチコピー --------------------------------*/
.top-reason .catchcopy {
  font-family: var(--font-family-maru);
  font-size: 1.1rem;
  font-weight: bold;
  margin-top: 40px;
}

@media screen and (min-width: 480px), print {
  .top-reason .catchcopy br {
    display: none;
  }
}

@media screen and (min-width: 768px), print {
  .top-reason .catchcopy {
    font-size: 1.4rem;
    margin-top: 60px;
  }
}

/* 画像 --------------------------------*/
.top-reason .image img {
  width: 100%;
}

.top-reason .image {
  width: 200px;
  margin: 0 auto;
  margin-top: 20px;
}

@media screen and (min-width: 768px), print {
  .top-reason .image {
    width: 300px;
    margin-top: 40px;
  }
}

/* テキスト --------------------------------*/
.top-reason .text-def {
  display: inline-block;
  border: solid 2px var(--color-light-brown);
  border-radius: 20px;
  padding: 10px;
  margin-top: 20px;
}

@media screen and (min-width: 768px), print {
  .top-reason .text-def {
    max-width: 780px;
    padding: 20px;
    margin-top: 40px;
  }
}


/*------------------------------------------*/
/* 用途
/*------------------------------------------*/

.top-reason .list-uses {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 20px;
  column-gap: 20px;
  margin-top: 40px;
}

@media screen and (min-width: 768px), print {
  .top-reason .list-uses {
    grid-template-columns: repeat(4, 1fr);
    row-gap: 0;
    column-gap: 10px;
    margin-top: 60px;
  }
}

@media screen and (min-width: 1200px), print {
  .top-reason .list-uses {
    column-gap: 20px;
  }
}

/* 画像 --------------------------------*/
.top-reason .list-uses figure img {
  width: 100%;
}

.top-reason .list-uses figure {
  display: inline-block;
  width: 80px;
}

/* 文字 --------------------------------*/
.top-reason .list-uses .caption {
  font-size: 0.9rem;
  font-weight: bold;
  margin-top: 1em;
}

@media screen and (min-width: 1200px), print {
  .top-reason .list-uses .caption {
    font-size: 1rem;
  }
}


/*****************************************
*
* ディーラー系ローンとの比較
*
******************************************/

/* 表 --------------------------------*/



@media screen and (max-width: 767px) {
  .top-comparison .table thead {
    display: none;
  }

  .top-comparison .table tr,
  .top-comparison .table td {
    display: block;
    width: auto;
  }

  .top-comparison .table tr {
    border: 1px solid var(--color-dark-brown);
    border-radius: 10px;
    margin-bottom: 20px;
    overflow: hidden;
  }

  .top-comparison .table th {
    display: inline-block;
    text-align: center;
    background: var(--color-dark-brown);
    width: 100%;
    color: var(--color-white);
    font-weight: bold;
    padding: 10px;
  }

  .top-comparison .table td {
    position: relative;
    text-align: justify;
    text-justify: inter-ideograph;
    border: none;
    border-bottom: 1px solid var(--color-dark-brown);
    font-size: 0.9rem;
    padding: 10px;
    padding-top: 50px;
  }

  .top-comparison .table td::after {
    content: '';
    display: inline-block;
    border-top: 1px dashed var(--color-dark-brown);
    width: 100%;
    height: 1px;
    position: absolute;
    top: 40px;
    left: 0;
  }

  .top-comparison .table td.kuwashin {
    background: var(--color-light-pink);
  }

  .top-comparison .table td:last-child {
    border-bottom: none;
  }

  .top-comparison .table td::before,
  .top-comparison .table td.kuwashin::before {
    display: inline-block;
    width: 100%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }

  .top-comparison .table td::before {
    content: attr(aria-label);
    font-size: 1rem;
    font-weight: bold;
    text-align: center;
    top: 8px;
  }

  .top-comparison .table td.kuwashin::before {
    content: '';
    background: url('img/logo.svg') no-repeat;
    background-size: 100%;
    aspect-ratio: 19/2;
    width: 150px;
    height: auto;
    top: 13px;
  }
}

@media screen and (min-width: 768px), print {
  .top-comparison .table {
    border-collapse: collapse;
    width: 100%;
  }

  .top-comparison .table thead th {
    text-align: center;
    border-radius: 20px 20px 0 0;
    font-weight: bold;
    padding: 10px;
  }

  .top-comparison .table tbody th {
    text-align: center;
    background: var(--color-dark-brown);
    border-top: solid 1px var(--color-white);
    width: 8em;
    color: var(--color-white);
    font-weight: bold;
    padding: 10px;
  }

  .top-comparison .table tbody td {
    vertical-align: text-top;
    text-align: left;
    padding: 10px;
  }

  .top-comparison .table tbody td,
  .top-comparison .table thead th.kuwashin,
  .top-comparison .table thead th.typical {
    border-bottom: 1px solid var(--color-dark-brown);
  }

  .top-comparison .table thead th.caption {
    background: var(--color-dark-brown);
    color: var(--color-white);
  }

  .top-comparison .table thead th.kuwashin,
  .top-comparison .table tbody td.kuwashin {
    background: var(--color-light-pink);
  }

  .top-comparison .table thead th.kuwashin .logo {
    background: url('img/logo.svg') no-repeat;
    background-size: 100%;
    margin-top: 10px;
  }
}

/* マーク --------------------------------*/
.top-comparison .table .symbol {
  position: relative;
  text-align: center;
  border-bottom: dashed 2px var(--color-light-brown);
  padding: 10px 0;
  margin-bottom: 1em;
}

.top-comparison .table .symbol span {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  font-size: 0;
}

.top-comparison .table .symbol.circle span::before,
.top-comparison .table .symbol.triangle span::before {
  content: '';
  display: inline-block;
  aspect-ratio: 24/20;
  width: 24px;
  height: auto;
}

.top-comparison .table .symbol.circle span::before {
  background: url('img/icon_circle.svg') no-repeat;
  background-size: 100%;
}

.top-comparison .table .symbol.triangle span::before {
  background: url('img/icon_triangle.svg') no-repeat;
  background-size: 100%;
}

@media screen and (min-width: 768px), print {

  .top-comparison .table .symbol.circle span::before,
  .top-comparison .table .symbol.triangle span::before {
    width: 30px;
  }
}

/* テキスト --------------------------------*/
.top-comparison .table .emphasis {
  font-weight: bold;
}

.top-comparison .table .emphasis.large {
  font-size: 1rem;
}

@media screen and (min-width: 768px), print {
  .top-comparison .table .emphasis.large {
    font-size: 1.2rem;
  }
}


/*****************************************
*
* 返済額シミュレーション例
*
******************************************/

.top-simulation .catchcopy {
  font-family: var(--font-family-maru);
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 40px;
}

.top-simulation .catchcopy .large {
  font-size: 1.2rem;
  margin-bottom: 1em;
}

@media screen and (min-width: 1200px), print {
  .top-simulation .catchcopy {
    font-size: 1.2rem;
  }

  .top-simulation .catchcopy .large {
    font-size: 1.4rem;
  }
}

/*------------------------------------------*/
/* 比較
/*------------------------------------------*/

.top-simulation .list {
  border-top: dashed 2px var(--color-light-brown);
}

.top-simulation .list .group {
  border-bottom: dashed 2px var(--color-light-brown);
  padding-bottom: 20px;
  padding-top: 20px;
}

.top-simulation .list .group+.group {
  background: var(--color-bright-pink);
}

.top-simulation .list .box {
  display: flex;
  align-items: flex-end;
  text-align: left;
}

.top-simulation .list .box+.box {
  margin-top: 10px;
}

@media screen and (min-width: 768px), print {
  .top-simulation .list .group {
    display: flex;
    align-items: center;
  }

  .top-simulation .list .box+.box {
    margin-top: 20px;
  }
}

/* ロゴ --------------------------------*/
.top-simulation .list .heading {
  font-family: var(--font-family-maru);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 10px;
}

@media screen and (min-width: 768px), print {
  .top-simulation .list .heading {
    display: inline-block;
    width: 10em;
    font-size: 1rem;
    margin-bottom: 0;
  }
}

@media screen and (min-width: 1020px), print {
  .top-simulation .list .heading {
    width: 15em;
    font-size: 1.2rem;
  }
}

/* 項目 --------------------------------*/
.top-simulation .list .caption {
  display: inline-block;
  width: 10em;
  font-size: 0.9rem;
  font-weight: 600;
}

.top-simulation .list .caption a.btn-type1 {
  background: var(--color-dark-brown);
  border: solid 2px var(--color-dark-brown);
  color: var(--color-white);
  font-size: 0.7rem;
  padding: 5px;
  line-height: 1.1;
  margin-left: 0.5em;
}

.top-simulation .list .caption a.btn-type1::after {
  content: none;
}

.top-simulation .list .caption a.btn-type1:hover {
  background: transparent;
  color: var(--color-dark-brown);
}

@media screen and (min-width: 1020px), print {
  .top-simulation .list .caption {
    width: 14em;
    font-size: 1rem;
  }
}

/* 金利 --------------------------------*/
.top-simulation .list .rate {
  font-family: var(--font-family-en);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.1;
}

.top-simulation .list .rate span {
  color: var(--color-orange);
  font-size: 1.2rem;
}

@media screen and (min-width: 768px), print {
  .top-simulation .list .rate {
    font-size: 1.2rem;
  }

  .top-simulation .list .rate span {
    font-size: 2rem;
  }
}

/* 金額 --------------------------------*/
.top-simulation .list .num {
  font-family: var(--font-family-en);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.1;
}

.top-simulation .list .num span {
  display: inline-block;
  font-size: 1.2rem;
  margin-bottom: -0.5em;
}

.top-simulation .list .num.minus span {
  color: var(--color-pink);
  font-size: 1.4rem;
}

@media screen and (min-width: 768px), print {
  .top-simulation .list .num {
    font-size: 1.2rem;
  }

  .top-simulation .list .num span {
    font-size: 1.8rem;
  }

  .top-simulation .list .num.minus span {
    font-size: 2.4rem;
  }
}

/* テキスト --------------------------------*/
.top-simulation .list .text {
  color: var(--color-pink);
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1.1;
}

@media screen and (min-width: 768px), print {
  .top-simulation .list .text {
    font-size: 1.4rem;
    margin-left: 0.5em;
  }
}



/*****************************************
*
* 融資までの流れ
*
******************************************/

.top-flow .list li {
  margin-top: 40px;
}

@media screen and (min-width: 768px), print {
  .top-flow .list li {
    margin-top: 60px;
  }
}

/* box --------------------------------*/

@media screen and (min-width: 768px), print {
  .top-flow .list li {
    display: flex;
    margin-bottom: 60px;
  }
}

/* step --------------------------------*/
.top-flow .list .caption {
  position: relative;
  display: inline-block;
  font-family: var(--font-family-maru);
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1;
  padding: 10px 40px;
  z-index: 2;
}

.top-flow .list .caption::before,
.top-flow .list .caption::after {
  content: '';
  display: inline-block;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
}

.top-flow .list .caption::before {
  background: var(--color-pink);
  top: 5px;
  left: 5px;
}

.top-flow .list .caption::after {
  background: var(--color-light-pink);
  top: 0px;
  left: 0px;
}

.top-flow .list .caption .en {
  color: var(--color-pink);
  font-size: 2rem;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .top-flow .list .caption {
    margin-bottom: 40px;
  }
}

@media screen and (min-width: 768px), print {
  .top-flow .list .caption-wrap {
    flex-shrink: 0;
  }

  .top-flow .list .caption {
    font-size: 1.4rem;
  }

  .top-flow .list .caption .en {
    font-size: 3rem;
  }
}

/* cont --------------------------------*/
@media screen and (min-width: 768px), print {
  .top-flow .list .cont {
    margin-left: 40px;
  }
}

/* 見出し --------------------------------*/
.top-flow .list .heading {
  font-family: var(--font-family-maru);
  font-size: 1.1rem;
  font-weight: bold;
}

@media screen and (min-width: 768px), print {
  .top-flow .list .heading {
    text-align: left;
    font-size: 1.4rem;
  }
}

/* テキスト --------------------------------*/
.top-flow .list .text-def {
  margin-top: 20px;
}

@media screen and (min-width: 768px), print {
  .top-flow .list .text-def {
    margin-top: 10px;
  }
}

/*****************************************
*
* よくある質問
*
******************************************/

.top-faq-box {
  display: inline-block;
  width: 100%;
  text-align: justify;
  text-justify: inter-ideograph;
  line-height: 1.8em;
  border-bottom: dashed 1px var(--color-dark-brown);
  padding-bottom: 20px;
}

.top-faq-box+.top-faq-box {
  margin-top: 20px;
}

@media screen and (min-width: 768px), print {
  .top-faq-box {
    padding-bottom: 40px;
  }

  .top-faq-box+.top-faq-box {
    margin-top: 40px;
  }
}

/* box --------------------------------*/
.top-faq-box .question-box {
  font-size: 1.1rem;
  font-weight: bold;
}

.top-faq-box .answer-box {
  margin-top: 20px;
}

.top-faq-box .answer-box .cont {
  display: inline-block;
  width: 100%;
}

@media screen and (min-width: 768px), print {
  .top-faq-box .question-box {
    display: flex;
    align-items: center;
    text-align: left;
    font-size: 1.2rem;
  }

  .top-faq-box .answer-box {
    display: flex;
  }
}

/* アイコン --------------------------------*/
.top-faq-box .question-box .q,
.top-faq-box .answer-box .a {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  width: 40px;
  height: 40px;
  color: var(--color-white);
  margin-right: 1em;
}

.top-faq-box .question-box .q {
  background: var(--color-main);
}

.top-faq-box .answer-box .a {
  background: var(--color-pink);
}

@media screen and (max-width: 767px) {

  .top-faq-box .question-box .q,
  .top-faq-box .answer-box .a {
    margin: 0 auto;
    margin-bottom: 10px;
  }
}

@media screen and (min-width: 768px), print {

  .top-faq-box .question-box .q,
  .top-faq-box .answer-box .a {
    flex-shrink: 0;
  }
}


/*****************************************
*
* 申込み可能地域
*
******************************************/


/*****************************************
*
* 商品詳細
*
******************************************/



/*****************************************
*
* ポリシー
*
******************************************/

.parts-policy-list {
  line-height: 2;
}

.parts-policy-list .box-cont+.box-cont {
  border-top: dashed 2px var(--color-light-gray);
  padding-top: 2em;
  margin-top: 2em;
}

.pages-agree .heading-secondary {
  font-size: 1.1rem;
  font-weight: bold;
  margin-bottom: 1em;
}

@media screen and (min-width: 768px), print {
  .pages-agree .heading-secondary {
    font-size: 1.4rem;
  }
}

.parts-policy-list .heading-primary {
  text-align: left;
  font-size: 1.1rem;
  font-weight: bold;
  margin-bottom: 1em;
}

@media screen and (min-width: 768px), print {
  .parts-policy-list .heading-primary {
    font-size: 1.2rem;
  }
}

.parts-policy-list .heading {
  text-align: left;
  font-size: 1rem;
  font-weight: bold;
  padding-left: 1em;
  text-indent: -1em;
  margin-top: 2em;
  margin-bottom: 1em;
}

.parts-policy-list .heading-sub {
  text-align: left;
  font-size: 1rem;
  margin-top: 0.5em;
}

.parts-policy-list .heading-sub+.text {
  padding-left: 1em;
}

.parts-policy-list .text+ul {
  margin-top: 0.5em;
}


/*------------------------------------------*/
/* スクロール
/*------------------------------------------*/

.parts-policy-list-scroll-y {
  overflow-y: scroll;
  height: 300px;
  padding: 10px;
}


/*------------------------------------------*/
/* 各種方針・健康経営宣言・指針等 一覧
/*------------------------------------------*/

.parts-policy-item {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 20px;
  column-gap: 20px;
}

.parts-policy-item .cont {
  position: relative;
  background: var(--color-white);
  border-radius: 10px;
  width: 100%;
  font-family: var(--font-family-maru);
  color: var(--color-text);
  box-shadow: var(--box-shadow);
  transition: all .5s ease;
}

.mac.safari .parts-policy-item .cont {
  border: 2px solid var(--color-main);
}

.parts-policy-item .cont::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 10px;
  border: 2px solid transparent;
  background: var(--gradient-main) border-box border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  -webkit-mask-composite: destination-out;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  mask-composite: exclude;
}

.parts-policy-item .heading {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  text-align: left;
  font-size: 1rem;
  font-weight: bold;
  padding: 10px;
  padding-right: 30px;
}

.parts-policy-item .heading::after,
.parts-policy-item .pdf .heading::after {
  content: '';
  display: inline-block;
  width: 20px;
  height: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 10px;
  z-index: 1;
}

.parts-policy-item .heading::after {
  background: url('../img/common/icon_arrow_circle_scoop.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 1/1;
}

.parts-policy-item .pdf .heading::after {
  background: url('../img/common/icon_pdf.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 17/20;
}

.parts-policy-item .cont:hover {
  text-decoration: none;
  box-shadow: var(--box-shadow-hover);
}

.parts-policy-item .cont:visited {
  color: var(--color-text);
}

@media screen and (min-width: 768px), print {
  .parts-policy-item {
    row-gap: 20px;
    column-gap: 40px;
  }

  .parts-policy-item .heading {
    font-size: 1.2rem;
    padding: 20px;
    padding-right: 50px;
  }

  .parts-policy-item .heading::after {
    width: 30px;
    right: 20px;
  }

  .parts-policy-item .pdf .heading::after {
    width: 30px;
    right: 20px;
  }
}

@media screen and (min-width: 1020px), print {
  .parts-policy-item {
    row-gap: calc(calc(40 / 1300) * 100vw);
    column-gap: calc(calc(60 / 1300) * 100vw);
  }
}

@media screen and (min-width: 1300px), print {
  .parts-policy-item {
    row-gap: 40px;
    column-gap: 60px;
  }
}

/*------------------------------------------*/
/* リスト インデントタイプ
/*------------------------------------------*/

.list-type-indent li {
  position: relative;
  text-align: left;
}

.list-type-indent li+li {
  margin-top: 0.5em;
}

.list-type-indent li .span {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}

/* 数値はjQueryにて設定 */

/*
.list-type-indent.indent1 li {
  padding-left: 1em;
}

.list-type-indent.indent1 li .span {
  width: 1em;
}
*/


/*------------------------------------------*/
/* ボタン 角丸ライン
/*------------------------------------------*/

.btn-type-rounded-line-wrap {
  display: inline-block;
  width: 100%;
  margin-top: 20px;
}

.btn-type-rounded-line-wrap.left {
  text-align: left;
}

.btn-type-rounded-line-wrap.center {
  text-align: center;
}

.btn-type-rounded-line-wrap.right {
  text-align: right;
}

.btn-type-rounded-line {
  position: relative;
  display: inline-block;
  background: transparent;
  border: solid 2px var(--color-text);
  border-radius: 40px;
  font-family: var(--font-family-maru);
  color: var(--color-text);
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.4;
  padding: 10px 50px;
  transition: all .5s ease;
}

.mac.safari .btn-type-rounded-line {
  border: 2px solid var(--color-text);
}

.btn-type-rounded-line::after {
  content: '';
  display: inline-block;
  background: url('img/icon_arrow.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 10/16;
  width: 8px;
  height: auto;
  opacity: 1;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
  transition: all .5s ease;
}

.btn-type-rounded-line.blank::after {
  background: url('img/icon_blank.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 1/1;
  width: 18px;
}

.btn-type-rounded-line.pdf::after {
  background: url('img/icon_pdf.svg') no-repeat;
  background-size: 100%;
  aspect-ratio: 17/20;
  width: 17px;
}

.btn-type-rounded-line:hover {
  text-decoration: none;
  box-shadow: var(--box-shadow-hover);
}

.btn-type-rounded-line:visited {
  color: var(--color-dark-main);
}

@media screen and (min-width: 768px), print {
  .btn-type-rounded-line {
    padding: 10px 60px;
  }
}