/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  リセットcss

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
table { border-collapse: collapse; border-spacing: 0; }
input, select, button, textarea { margin: 0; padding: 0; background: none; border: none; border-radius: 0; outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; }
select::-ms-expand { display: none; }

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

初期設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
html, body { width: 100%;  color: #333; background: transparent;  animation: BodyfadeIn 1s ease 0s 1 normal; }
html { font-size: 62.5%; }
body { background: #fff; font-size: 1.8rem; line-height: 1.6; letter-spacing: .02em; font-family: 'Noto Sans JP'; }
@font-face { font-family: 'Corporate Logo Ver2'; src: url('assets/fonts/Corporate-Logo-Medium-ver2.otf') format('truetype') }
* { box-sizing: border-box; } 
a { color: #222; text-decoration: none; transition: .3s ease-out; }
a:hover { }
a:active { color: #222; }
img { display: block; width: 100%; max-width: 100%; height: auto; vertical-align: bottom; }

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

全体設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
/* ========================================
共通パーツ
======================================== */
.wrap { width: 100%; max-width: 1200px; margin-right: auto; margin-left: auto; padding-right: 40px; padding-left: 40px; }
.wrap-s { width: 100%; max-width: 1040px; margin-right: auto; margin-left: auto; padding-right: 40px; padding-left: 40px; }
.view-l { display: none; } 
.view-s { display: none; }
.view-xs { display: none; }

/* カラー
---------------------------------------- */
.fc-red { color: #d92a24; } 
.fc-grn { color: #43b212; } 

/* マージン
---------------------------------------- */
.mb-x2 { margin-bottom: 16px; }
.mb-x3 { margin-bottom: 24px; }
.mb-x4 { margin-bottom: 32px; }
.mb-x5 { margin-bottom: 40px; }
.mb-x6 { margin-bottom: 48px; }

.mb-sect { margin-bottom: 100px; }

/* テキスト
---------------------------------------- */
.txt--center { text-align: center; }
.txt--right { text-align: right; }
.link-txt { text-decoration: underline; }
.underline { background: linear-gradient(transparent 92%, #333 8%); padding: 0 0 2px; }
.exclamation { display: inline-block; transform: rotate(10deg) translateY(3px); }

/* ボタン
---------------------------------------- */
.btn a { position: relative; overflow: hidden; display: flex; align-items: center; padding-left: 32px; width: 100%; height: 80px; background: #fff; border: solid 5px #e8e8e8; border-radius: 50px; color: #d92a24; font-size: 2rem; } 
.btn a span { position: absolute; top: 50%; right: 15px; transform: translateY(-50%); width: 40px; height: 40px; overflow: hidden; display: flex; justify-content: center; align-items: center; background: #d92a24; border-radius: 50%; }
.btn a img { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 14px; height: 9px; transition: left 0.5s ease; /* アニメーションの設定 */ }
.btn a img:last-child { left: -100%; }
.btn a:hover { background: #d92a24; border-color: #d92a24; color: #fff; }
.btn a:hover img { left: 200%; }
.btn a:hover img:last-child { left: 50%; }

/* アンカーリンク
---------------------------------------- */
.ancher-link { padding-top: 48px; margin-top: -48px; }

/* ========================================
ヘッダー
======================================== */
.header { position: relative; z-index: 9998; padding: 0 38px; height: 80px; background: #fff; border-top: solid 3px #d92a24; }
.header .header-unit .logo { padding-top: 22px; width: 250px; }
.header .header-unit .nav-btn { position: fixed; top: -3px; right: 38px; }
.header .header-unit .btn-unit { display: flex; flex-wrap: wrap; gap: 8px; }
.header .header-unit .btn-unit a { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; padding: 16px 52px; height: 96px; border-radius: 0 0 30px 30px; }
.header .header-unit .btn-unit a:hover { height: 100px; }
.header .header-unit .btn-unit .contact { position: relative; gap: 12px; border-style: solid; border-width: 0 3px 3px 3px; border-color: #eba421; background: #fff; }
.header .header-unit .btn-unit .contact::before { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 100%; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a6fdd6b8521/original.png") no-repeat; background-size: cover; }
.header .header-unit .btn-unit .download { gap: 8px; background: #d92a24; color: #fff; }
.header .header-unit .btn-unit img { width: 40px; }

/* 下層ページ
---------------------------------------- */
.lower-hero { position: relative; overflow: hidden; margin-bottom: 96px; padding: 50px 0 60px; }
.lower-hero::before { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); content: ""; width: 360px; height: 360px; background: #fff; border-radius: 50%; }
.lower-hero .icon { position: relative; display: flex; justify-content: center; align-items: center; }
.lower-hero .icon img { width: 63px; height: 52px; }
.lower-hero .pagettl { position: relative; text-align: center; }
.lower-hero .pagettl__main { margin-bottom: 4px; font-size: 4.2rem; font-weight: bold; line-height: 1.4; }
.lower-hero .pagettl__sub { font-family: "Inter"; font-size: 1.6rem; font-weight: bold; }
.breadcrumb { position: absolute; left: 38px; bottom: 16px; display: flex; }
.breadcrumb .breadcrumb__item { position: relative; font-size: 1.6rem; }
.breadcrumb .breadcrumb__item:not(:last-child) { padding-right: 40px; }
.breadcrumb .breadcrumb__item:not(:last-child)::before { position: absolute; top: 1px; right: 14px; content:">"; }

/* フォーム
---------------------------------------- */
.form { margin-bottom: 120px; } 
.form-content { position: relative; padding: 56px 64px; background: #fcfcfc; }
.hsfc-Step__Content { padding: 0 !important; }
.hsfc-RadioFieldGroup__Options { display: flex; flex-wrap: wrap; gap: 12px; }
.hsfc-RadioFieldGroup__Options label { cursor: pointer; }

/* ========================================
下層 料金・資料請求
======================================= */
#download .lower-hero { background: #FFF7F7; }
#download .lower-hero .pagettl__main,#download .lower-hero .pagettl__sub { color: #d92a24; }
.download-intro .present-unit { display: flex; align-items: center; }
.download-intro .present-unit .present-unit__vsl { position: relative; width: calc( 100% - 618px ); margin-right: -55px; z-index: -1; }
.download-intro .present-unit .present-unit__txt { padding-top: 32px; width: 674px; }
.download-intro .present-unit .present-unit__txt .note-txt { margin-left: 64px; font-size: 1.6rem; }
.download-understand { position: relative; margin-bottom: 48px; padding-top: 80px; }
.download-understand::before { position: absolute; top: 0; left: 0; z-index: -1; content: ""; width: 100%; height: 80%; background: #fcfcfc; }
.download-understand .understand-ttl { margin: 0 auto 32px; width: 100%; max-width: 710px; }
.understand-list { position: relative; display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; max-width: 960px; margin: 0 auto; }
.understand-list::before { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); content: ""; width: 124px; height: 124px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a705dc2b17a/original.png") no-repeat; background-size: contain; }
.understand-list .understand-list__item { text-align: center; padding: 40px 0; border-radius: 80px; font-size: 2.2rem; background: #fff; box-shadow : 0 0 6px rgba(0,0,0, 0.08); }
.understand-list .understand-list__item:nth-child(2) { padding: 20px 0 16px; }
#download .form-ttl { position: relative; padding-top: 88px; text-align: center; margin-bottom: 32px; font-size: 3rem; font-weight: bold; }
#download .form-ttl::before { position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ""; width: 50px; height: 54px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a705dc04022/original.png") no-repeat; background-size: contain; }
#download .form-ttl em { position: relative; padding: 0 56px 0 64px; }
#download .form-ttl em::before,#download .form-ttl em::after { position: absolute;  top: 0; content: ""; width: 45px; height: 40px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a705dc03458/original.png") no-repeat; background-size: contain; }
#download .form-ttl em::before { left: 0; }
#download .form-ttl em::after { right: 0; transform: scale(-1, 1); }

/* ========================================
追尾ボタン
======================================== */
.float-btn { display: none; }

/* ========================================
フッター
======================================== */
.footer .footer-unit { display: flex; flex-wrap: wrap; align-items: center; gap: 48px; padding: 38px 120px 30px; background: #fcfcfc; }
.footer .footer-unit .logo { width: 250px; }
.footer .footer-unit .footer-add { margin-bottom: 12px; font-size: 1.6rem; }
.footer .footer-unit .tel { font-size: 2rem; }
.footer .footer-unit .tel a { padding-left: 10px; color: #d92a24; }
.footer .copy { text-align: center; padding: 6px; background: #d92a24; font-size: 1.2rem; color: #fff; }
.c-wrapper { display: none; }

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1280px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 1280px) {
  
/* ========================================
共通パーツ
======================================== */
.wrap { padding-right: 32px; padding-left: 32px; }
.wrap-s { padding-right: 32px; padding-left: 32px; }
.none-lap { display: none; }
  
/* ========================================
フッター
======================================== */
.footer .footer-unit { padding: 38px 32px 30px; }
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1024px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 1024px) {
  
/* ========================================
下層 料金・資料請求
======================================== */
.download-intro .present-unit .present-unit__vsl { width: calc( 100% - 568px ); }
.download-intro .present-unit .present-unit__txt { width: 652px; }

}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
960px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 960px) {
  
/* ========================================
共通パーツ
======================================== */
.wrap { padding-right: 24px; padding-left: 24px; }
.wrap-s { padding-right: 24px; padding-left: 24px; }
.none-tb { display: none; }

/* マージン
---------------------------------------- */
.mb-x2 { margin-bottom: 12px; }
.mb-x3 { margin-bottom: 18px; }
.mb-x4 { margin-bottom: 24px; }
.mb-x5 { margin-bottom: 30px; }
.mb-x6 { margin-bottom: 36px; }

.mb-sect { margin-bottom: 80px; }

/* 下層ページ
---------------------------------------- */
.lower-hero { margin-bottom: 72px; padding: 40px 0 50px; }
.lower-hero::before { width: 340px; height: 340px; }
.lower-hero .icon img { width: 60px; height: 48px; }
.lower-hero .pagettl__main { font-size: 3.6rem; }

/* フォーム
---------------------------------------- */
.form { margin-bottom: 100px; } 
.form-content { padding: 40px 48px; }

/* ========================================
ヘッダー
======================================== */
.header { padding: 0 28px; height: 72px; }
.header .header-unit .logo { padding-top: 20px; width: 220px; }
.header .header-unit .nav-btn { display: none; }
  
/* ========================================
下層 料金・資料請求
======================================== */
.download-intro .present-unit { flex-direction: column; }
.download-intro .present-unit .present-unit__vsl { width: 100%; max-width: 560px; margin: 0; }
.download-intro .present-unit .present-unit__txt { padding-top: 8px; width: 100%; max-width: 652px; }
.download-intro .present-unit .present-unit__txt .note-txt { margin-left: 40px; }
 
/* ========================================
追尾ボタン
======================================== */
.float-btn { display: flex; flex-wrap: wrap; position: fixed; left: 0; bottom: 0; width: 100%; z-index: 9998; }
.float-btn__item { width: 50%; }
.float-btn__item a { position: relative; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 8px; width: 100%; height: 60px; padding: 4px 0; font-weight: bold; line-height: 1.2; }
.float-btn__item a img { width: 30px; }
.float-btn__item.contact a { background: #fff; border: solid 3px #eba421; }
.float-btn__item.download a { background: #d92a24; color: #fff; }
  
}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
768px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 768px) {

/* ========================================
初期設定
======================================== */
body { font-size: 1.6rem; letter-spacing: 0; }

/* ========================================
共通パーツ
======================================== */
.view-s { display: block; }

/* マージン
---------------------------------------- */
.mb-x2 { margin-bottom: 8px; }
.mb-x3 { margin-bottom: 12px; }
.mb-x4 { margin-bottom: 16px; }
.mb-x5 { margin-bottom: 20px; }
.mb-x6 { margin-bottom: 24px; }

.mb-sect { margin-bottom: 60px; }

/* テキスト
---------------------------------------- */
.exclamation { padding-left: 0; transform: rotate(10deg) translateY(1px); }

/* ボタン
---------------------------------------- */
.btn a { height: 72px;  font-size: 1.6rem; } 
.btn a span { width: 32px; height: 32px; }
.btn a img { width: 12px; height: 5px; }
  
/* 下層ページ
---------------------------------------- */
.lower-hero { margin-bottom: 48px; padding: 30px 0 40px; }
.lower-hero::before { width: 300px; height: 300px; }
.lower-hero .icon img { width: 56px; height: 44px; }
.lower-hero .pagettl__main { font-size: 3rem; }
.lower-hero .pagettl__sub { font-size: 1.4rem; }
.breadcrumb { left: 16px; bottom: 8px; }
.breadcrumb .breadcrumb__item { font-size: 1.4rem; }
.breadcrumb .breadcrumb__item:not(:last-child) { padding-right: 30px; }
.breadcrumb .breadcrumb__item:not(:last-child)::before { right: 10px; }

/* フォーム
---------------------------------------- */
.form { margin-bottom: 80px; } 
.form-content { padding: 24px 18px; }
.form-content::before { display: none; }

/* ========================================
ヘッダー
======================================== */
.header { padding: 0 20px; height: 64px; }
.header .header-unit .logo { margin-bottom: 0; padding-top: 16px; width: 200px; }
  
/* ========================================
下層 料金・資料請求
======================================== */
#download .form-ttl { padding-top: 64px; margin-bottom: 24px; font-size: 2rem; }
#download .form-ttl::before { width: 40px; height: 44px; }
#download .form-ttl em { padding: 0 40px 0 48px; }
#download .form-ttl em::before,#download .form-ttl em::after { width: 32px; height: 30px; }
.download-understand .understand-ttl { max-width: 380px; }
.understand-list { gap: 16px; }
.understand-list::before { width: 80px; height: 80px; }
.understand-list .understand-list__item { padding: 28px 0; font-size: 1.8rem; }
.understand-list .understand-list__item:nth-child(2) { padding: 12px 0 8px; }

/* ========================================
フッター
======================================== */
.footer .footer-unit { gap: 16px; padding: 24px 24px 16px; }
.footer .footer-unit .logo { width: 200px; }
.footer .footer-unit .footer-add { margin-bottom: 8px; font-size: 1.4rem; }
.footer .footer-unit .tel { font-size: 1.8rem; }
.footer .footer-unit .tel a { padding-left: 6px; }
.footer .copy { padding: 4px; font-size: 1rem; }
  
}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
640px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 640px) {
  
/* ========================================
下層 料金・資料請求
======================================== */
.download-intro .present-unit .present-unit__txt .note-txt { margin-left: 0; font-size: 1.4rem; }
.understand-list { grid-template-columns: 1fr; gap: 12px; }
.understand-list::before { display: none; }
.understand-list .understand-list__item { position: relative; margin-left: 24px; padding: 16px 0; }
.understand-list .understand-list__item:nth-child(2) { padding: 16px 0; }
.understand-list .understand-list__item::before { position: absolute; top: 50%; left: -24px; transform: translateY(-50%); width: 50px; height: 50px; content: ""; background: url('https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a705dc2b17a/original.png') no-repeat; background-size: contain; }
  
}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
520px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 520px) {
  
/* ========================================
共通パーツ
======================================== */
.wrap { padding-right: 16px; padding-left: 16px; }
.wrap-s { padding-right: 16px; padding-left: 16px; }
.none-xs { display: none; }
.view-xs { display: block; }
  
/* ========================================
下層 料金・資料請求
======================================== */
#download .form-ttl em { padding: 0; }
#download .form-ttl em::before,#download .form-ttl em::after { top: auto; bottom: 0; }
#download .form-ttl em::before { left: -32px; }
#download .form-ttl em::after { right: -60px; }
  
/* ========================================
フッター
======================================== */
.footer { padding-bottom: 52px; }
.footer .footer-unit { padding: 24px 16px 16px; }

/* ========================================
追尾ボタン
======================================== */
.float-btn__item a { height: 52px; font-size: 1.4rem; }
.float-btn__item a img { width: 24px; }

}