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

  リセット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 { 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; }

/* ========================================
下層 お問い合わせ
======================================= */
#contact .lower-hero { background: #FEFAF1; }
#contact .lower-hero .pagettl__main,#contact .lower-hero .pagettl__sub { color: #eba421; }
.contact-intro .intro-unit { display: flex; flex-wrap: wrap; gap: 40px; }
.contact-intro .intro-unit .intro-unit__vsl { width: 230px; }
.contact-intro .intro-unit .intro-unit__vsl img { border-radius: 4px; }
.contact-intro .intro-unit .intro-unit__txt { width: calc( 100% - 270px ); }
.contact-intro .intro-unit .intro-unit__txt .intro-ttl { margin-bottom: 24px; }
.contact-intro .intro-unit .intro-unit__txt .intro-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin-bottom: 8px; }
.contact-intro .intro-unit .intro-unit__txt .intro-list .intro-list__item { display: flex; justify-content: center; align-items: center; padding: 16px; background: #fcfcfc; border-radius: 4px; font-size: 2rem; line-height: 1.4; }
.contact-intro .intro-unit .intro-unit__txt .intro-list .intro-list__item img { width: 32px; height: 22px; margin-right: 8px; }
.contact-intro .intro-unit .intro-unit__txt .note-txt { margin-bottom: 38px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit { position: relative; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; }
.contact-intro .intro-unit .intro-unit__txt .present-unit::before { position: absolute; top: 50%; left: 0; z-index: -1; transform: translateY(-50%); content: ""; width: calc( 100% - 64px ); height: calc( 100% - 48px ); border: solid 3px #43B212; border-radius: 4px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit::after { position: absolute; top: 10px; left: 20px; content: ""; width: 121px; height: 22px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a701df94656/original.png") no-repeat; background-size: contain; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__txt { margin-left: 64px; width: 430px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__vsl { width: 290px; }
#contact .form-ttl { width: 100%; max-width: 576px; margin: 0 auto 32px; }

/* ========================================
追尾ボタン
======================================== */
.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; }
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1150px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

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

/* ========================================
下層　お問い合わせ
======================================== */
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__txt { margin-left: 48px; width: 375px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__vsl { width: 240px; }

}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1024px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 1024px) {
  
/* ========================================
下層　お問い合わせ
======================================== */
.contact-intro .intro-unit .intro-unit__txt .present-unit::before { width: 100%; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__txt { padding: 44px 0; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__vsl { position: absolute; width: 200px; top: -10px; right: -20px; }

}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
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; }
  
/* ========================================
下層 お問い合わせ
======================================== */
.contact-intro .intro-unit { gap: 24px; }
.contact-intro .intro-unit .intro-unit__vsl { width: 100%; }
.contact-intro .intro-unit .intro-unit__txt { width: 100%; }
.contact-intro .intro-unit .intro-unit__txt .intro-ttl { margin-bottom: 16px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit { margin: 0 auto; max-width: 640px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__txt { margin-left: 40px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit::after { left: 12px; }
  
/* ========================================
追尾ボタン
======================================== */
.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; }

/* ========================================
ヘッダー
======================================== */
.header { padding: 0 20px; height: 64px; }
.header .header-unit .logo { margin-bottom: 0; padding-top: 16px; width: 200px; }
  
/* ========================================
下層 お問い合わせ
======================================== */
.contact-intro .intro-unit .intro-unit__txt .intro-list { gap: 8px; margin-bottom: 4px; }
.contact-intro .intro-unit .intro-unit__txt .note-txt { font-size: 1.4rem; }
.contact-intro .intro-unit .intro-unit__txt .intro-list .intro-list__item { padding: 12px; font-size: 1.6rem; }
.contact-intro .intro-unit .intro-unit__txt .intro-list .intro-list__item img { width: 28px; }
#contact .form-ttl { max-width: 450px; margin: 0 auto 24px; }

/* ========================================
フッター
======================================== */
.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) {
  
/* ========================================
下層 お問い合わせ
======================================== */
.contact-intro .intro-unit .intro-unit__txt .present-unit::after { width: 110px; height: 20px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__txt { margin: 0 24px; }
.contact-intro .intro-unit .intro-unit__txt .present-unit .present-unit__vsl { width: 160px; top: -16px; right: 10px; }
  
}
  
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
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; }
  
/* ========================================
下層 お問い合わせ
======================================== */
.contact-intro .intro-unit .intro-unit__txt .intro-list { grid-template-columns: 1fr; }
  
/* ========================================
フッター
======================================== */
.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; }

}