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

  リセット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); }
.note-txt { margin-left: 1em; font-size: 1.4rem; text-indent: -1em; }
.note-txt::before {  content: '※'; color: #D92A24; }

/* ボタン
---------------------------------------- */
.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: 4px; 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; }

/* アニメーション
---------------------------------------- */
@keyframes fadeIn { 0% {
    opacity: 0; 
    transform: translateY(-10px); 
  }
  100% {
    opacity: 1;
    transform: none;
  }
}

/* CV
---------------------------------------- */
.cv { position: relative; overflow: hidden; margin-bottom: 100px; padding-bottom: 3px; }
.cv::before { position: absolute; top: 48px; left: 0; content: ""; width: 100%; height: 480px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30646aae11/original.jpg") no-repeat; background-size: cover; background-position: 10% 80%; z-index: -1; }
.cv .cv-intro { margin: 0 auto 12px; width: 100%; max-width: 644px; }
.cv .cv-txt { position: relative; text-align: center; margin-bottom: 150px; font-size: 2.8rem; font-weight: bold; }
.cv .cv-txt .present { position: relative; color: #e61e18; text-shadow: 0px 0px 4px #fff; font-size: 6.4rem; line-height: 1.2; letter-spacing: .3rem; }
.cv .cv-txt .present::before,.cv .cv-txt .present::after { position: absolute; bottom: 12px; content: ""; width: 224px; height: 118px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a306334539a/original.png") no-repeat; background-size: contain; }
.cv .cv-txt .present::before { left: -240px; }
.cv .cv-txt .present::after { transform: scale(-1,1); right: -230px; }
.cv .cv-txt .present small { font-size: 5rem; }
.cv .cv-btn-unit { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.cv .cv-btn { text-align: center; }
.cv .cv-btn a { position: relative; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 20px; height: 198px; border-radius: 4px; font-size: 4rem; font-weight: bold; line-height: 1.2; }
.cv .cv-btn a:hover { transform: translate(3px,3px); }
.cv .cv-btn a img { width: 58px; }
.cv .cv-btn--download a { background: #d60903; border: solid 10px #FFA09D; color: #fff; }
.cv .cv-btn--contact a { background: #fff; border: solid 10px #eba421; color: #eba421; }
.cv .cv-btn--download a::before,.cv .cv-btn--contact a::before { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 100%; } 
.cv .cv-btn--download a::after,.cv .cv-btn--contact a::after { position: absolute; top: 2px; left: 12px; font-size: 3.2rem; font-weight: bold; }
.cv .cv-btn--download a::before { background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a306ccec8f3/original.png"); background-size: cover; }
.cv .cv-btn--download a::after { content: "DOWNLOAD"; color: #fff; opacity: .16; }
.cv .cv-btn--contact a::before { background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a306ccee925/original.png"); background-size: cover; } 
.cv .cv-btn--contact a::after { content: "CONTACT"; color: #FFF7E8; }

/* ========================================
ヘッダー
======================================== */
.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; }

/* フォーム
---------------------------------------- */
.form { margin-bottom: 120px; } 
.form-content { padding: 56px 64px; background: #fcfcfc; }
.hsfc-Step__Content { padding: 16px !important; }
.hsfc-Row { margin-bottom: 12px !important; }
.hsfc-FieldLabel { margin-bottom: 4px !important; font-size: 14px !important; }
.hsfc-ErrorAlert { font-size: 10px !important;; }

/* ========================================
MV
======================================== */
.hero { position: relative; overflow: hidden; margin: -16px 0 64px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a2fb4514391/original.jpg") no-repeat; background-size: cover; }
.hero .hero-unit { max-width: 1400px; display: flex; flex-wrap: wrap; justify-content: center; gap: 40px; margin: 0 auto; padding: 92px 64px 72px; }
.hero .hero-unit .hero-unit__vsl { position: relative; width: calc( 100% - 420px ); }
.hero .hero-unit .hero-unit__vsl .source { position: absolute; right: 2%; bottom: 0; font-size: 1.2rem; text-shadow: 0px 0px 2px #fff; line-height: 1.2; }
.hero .hero-unit .hero-unit__form { position: relative; padding: 112px 0 0; width: 380px; background: #fff; border-radius: 8px; }
.hero .hero-unit .hero-unit__form iframe { height: 100%; }
.hero .hero-unit .hero-unit__form .hero-form-ttl { position: absolute; top: 32px; left: 50%; transform: translateX(-50%); width: 260px; }
.hero .hero-unit .hero-unit__form .hero-form-inner { overflow: auto; height: 100%; max-height: 520px; border-top: solid 1px #e8e8e8; }

/* .hero .hero-txt { position: absolute; top: calc( 50% - 30px); left: 64px; transform: translateY(-50%); z-index: 10; }
.hero .hero-txt .catchcopy { margin-bottom: 30px; width: 880px; }
.hero .hero-txt .award { width: 580px; }
.hero .freezer-vsl { position: absolute; left: 740px; bottom: 30px; width: 130px; z-index: 10; }
.hero .freezer-txt { position: absolute; left: 648px; bottom: 30px; width: 220px; }
.hero .source { position: absolute; left: 16px; bottom: 8px; font-size: 1.2rem; }
.hero .hero-form { position: absolute; top: 80px; right: 64px; padding: 24px; background: #fff; width: 380px; height: calc(100% - 113px); border-radius: 8px; }
.hero .hero-form iframe { height: 100%; } */

/* ========================================
企業の声
======================================== */
.voice { position: relative; overflow: hidden; padding-top: 62px; }
.voice::before,.voice::after { position: absolute; top: 16px; content: ""; width: 488px; height: 405px; z-index: -1; }
.voice::before { left: 20px; background: url('https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a301ea453da/original.png') center / contain no-repeat; }
.voice::after { right: 20px; background: url('https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a301ea3d213/original.png') center / contain no-repeat; }
.voice .voice-intro img { display: block; margin: 0 auto 24px; width: 544px; }
.voice .voice-intro .intro-ttl img { display: block; margin: 0 auto 48px; width: 870px; }
.voice .voice-list { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; }
.voice .voice-list_item { position: relative; padding: 40px 20px; background: #fff; border: solid 3px #E51607; border-radius: 4px; }
.voice .voice-list_item::before,.voice .voice-list_item::after { position: absolute; content: ""; width: 33px;  height: 5px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3076fbb219/original.png") no-repeat; background-size: contain; }
.voice .voice-list_item::before { top: -3px; left: 3px; }
.voice .voice-list_item::after { bottom: -3px; right: 3px; }
.voice .voice-list_item .voice-logo { margin: 0 auto 18px; width: 200px; }
.voice .voice-list_item .voice-graph { margin: 0 0 16px; }
.voice .voice-list_item .voice-ttl { position: relative; margin: 0 0 10px; padding: 0 0 10px 16px; border-bottom: solid 1px rgba(51,15,15,.24); font-size: 2.4rem; font-weight: bold; }
.voice .voice-list_item .voice-ttl::before { position: absolute; top: calc( 50% - 4px ); left: 0; transform: translateY(-50%); content: ""; width: 8px; height: 7px; background: #E51607; clip-path: polygon(100% 0, 0 0, 50% 100%); }
.voice .voice-list_item:nth-child(2) { border-color: #EFA51A; }
.voice .voice-list_item:nth-child(2)::before,.voice .voice-list_item:nth-child(2)::after { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3076fbcd72/original.png"); }
.voice .voice-list_item:nth-child(2) .voice-ttl::before { background: #EFA51A; }
.voice .voice-list_item:nth-child(3) { border-color: #43B212; }
.voice .voice-list_item:nth-child(3)::before,.voice .voice-list_item:nth-child(3)::after { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3076fc2ae1/original.png"); }
.voice .voice-list_item:nth-child(3) .voice-ttl::before { background: #43B212; }

/* ========================================
こんなお悩みございませんか？
======================================== */
.worry { overflow: hidden; position: relative; padding: 116px 0 140px; background: linear-gradient( transparent 36px ,#F0F0F0 36px); }
.worry::before { position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ""; width: 3px; height: 98px; background: #E51607; }
.worry::after { position: absolute; top: 36px; left: 0; content: ""; width: 100%; height: calc( 100% - 36px ); background-image: radial-gradient(circle, rgba(51, 51, 51, 0.08) 10%, transparent 10%); background-size: 12px 12px; }
.worry .wrap { position: relative; z-index: 1; }
.worry .wrap::before,.worry .wrap::after,.worry .wrap-inner::before  { position: absolute; content: "？"; font-size: 28rem; font-weight: bold; color: #fff; line-height: 1; opacity: .64; }
.worry .wrap::before { top: -48px; left: -148px; transform: rotate(30deg); }
.worry .wrap::after {top: 160px; right: -80px; transform: rotate(-30deg); }
.worry .wrap-inner::before { bottom: -90px; left: -100px; transform: rotate(30deg); }
.worry .worry-ttl { position: relative; z-index: 1; display: block; margin: 0 auto 48px; width: 100%; max-width: 738px; }
.worry .worry-content { position: relative; z-index: 1; display: grid; gap: 56px; }
.worry .worry-content .worry-txt { position: relative; text-align: center; margin-right: auto; margin-left: 200px; padding: 32px 68px 36px 130px; width: calc( 100% - 200px ); background: #fff; border-radius: 60px; font-size: 2.4rem; }
.worry .worry-content .worry-txt .underline { font-size: 3.2rem; }
.worry .worry-content .worry-txt::before { position: absolute; top: 50%; left: -200px; transform: translateY(-50%); z-index: 1; content: ""; width: 310px; height: 185px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30bc6c92a2/original.png") no-repeat; background-size: contain; }
.worry .worry-content .worry-txt:nth-child(2) { padding: 32px 48px 36px 130px; border-radius: 100px; }
.worry .worry-content .worry-txt:nth-child(2)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30bc6b0d54/original.png"); }
.worry .worry-content .worry-txt:nth-child(3) { padding: 14px 68px 18px 130px; }
.worry .worry-content .worry-txt:nth-child(3)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30bc6d738e/original.png"); }

/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve { position: relative; text-align: center; background: #E24944; }
.solve::before { position: absolute; top: -44px; left: 50%; transform: translateX(-50%); content: ""; width: 147px; height: 94px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30db026407/original.png") no-repeat; background-size: contain; }
.solve::after { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 100%; background-image: repeating-linear-gradient(to right, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.07) 1px, transparent 1px, transparent 12px); background-size: 100% 12px; }
.solve-inner { position: relative; overflow: hidden; padding: 140px 0; }
.solve-inner::before,.solve-inner::after { position: absolute; top: calc( 50% - 20px ); transform: translateY(-50%); content: ""; width: 565px; height: 493px; }
.solve-inner::before { left: -40px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30d83bfedb/original.png") no-repeat; background-size: cover; }
.solve-inner::after { right: -40px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30d83b1fe7/original.png") no-repeat; background-size: cover; }
.solve p { font-size: 3.6rem; color: #fff; line-height: 1.4; }
.solve p .underline { background: linear-gradient(transparent 92%, #fff 8%); }
.solve p em { font-size: 5.2rem; }

/* ========================================
お悩み解決
======================================== */
.solution { padding: 100px 0 0; }
.solution .solution-content { display: grid; gap: 64px; }
.solution .solution-unit { position: relative; display: flex; flex-wrap: wrap; align-items: center; gap: 48px; padding: 48px 0; }
.solution .solution-unit::before { position: absolute; top: 0; right: 0; z-index: -1; content: ""; width: calc( 100% - 148px ); height: 100%; background: #fff; border-radius: 4px; box-shadow : 0 0 6px rgba(0,0,0, 0.08); }
.solution .solution-unit::after { position: absolute; top: 71px; right: -91px; transform: rotate(-90deg); content: "SOLUTION"; color: #eee; font-family: "Inter"; font-size: 4rem; font-weight: bold; }
.solution .solution-unit_vsl { width: 249px; }
.solution .solution-unit_vsl img { border-radius: 4px; }
.solution .solution-unit_txt { width: calc( 100% - 345px ); }
.solution .solution-unit_txt .solution-ttl { position: relative; z-index: 1; margin: 0 0 30px; padding-top: 82px; font-size: 4rem; font-weight: bold; line-height: 1.2; }
.solution .solution-unit_txt .solution-ttl .exclamation { position: absolute; transform: rotate(10deg) translate(-8px,-6px); display: inline-block; font-size: 5.2rem;  }
.solution .solution-unit_txt .solution-ttl::before { position: absolute; top: 0; left: 0; content: ""; width: 382px; height: 75px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30eb56734e/original.png") no-repeat; background-size: contain; }
.solution .solution-unit_txt .qa-box { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.solution .solution-unit_txt .qa-box::before { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); content: ""; width: 52px; height: 9px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a311c9e6593/original.png") no-repeat; background-size: contain; z-index: 1; }
.solution .solution-unit_txt .qa-box .qa-box_q,.solution .solution-unit_txt .qa-box .qa-box_a { position: relative; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; padding: 16px; height: 148px; border-radius: 4px; font-size: 2rem; line-height: 1.4; }
.solution .solution-unit_txt .qa-box .qa-box_q { background: #eee; }
.solution .solution-unit_txt .qa-box .qa-box_a { border: solid 3px #333; background: #fff; }
.solution .solution-unit_txt .qa-box .qa-box_a::before { position: absolute; bottom: -33px; right: 10px; content: ""; width: 72px; height: 124px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30f04c5ee4/original.png") no-repeat; background-size: contain; }
.solution .solution-unit_txt .btn a { padding: 0 40px; max-width: 504px; line-height: 1.4; }
.solution .solution-unit:nth-child(2) .solution-unit_txt .solution-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30eb5854de/original.png") ; }
.solution .solution-unit:nth-child(3) .solution-unit_txt .solution-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30eb57d947/original.png") ; }
.solution .solution-unit_txt .persistence-graph { width: 100%; max-width: 366px; height: 110px; }
.solution .txt--center { font-size: 2.4rem; font-weight: bold; }

/* ========================================
今、健康経営が注目されています
======================================== */
.management .management-ttl { margin: 0 auto 40px; width: 100%; max-width: 833px; }
.management .management-box { position: relative; margin: 0 auto 64px; padding: 24px 40px 32px; max-width: 960px; background: #F8F8F8; border-radius: 4px; }
.management .management-box::before { position: absolute; top: 88px; left: 0; content: ""; width: 100%; height: 3px; background: #fff; }
.management .management-box::after { position: absolute; right: 16px; bottom: 0; content: ""; width: 80px; height: 163px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a324b757367/original.png") no-repeat; background-size: contain; }
.management .management-box .box-ttl { text-align: center; margin-bottom: 32px; font-size: 3.2rem; font-weight: bold; line-height: 1.4; }
.management .management-box p { position: relative; z-index: 1; text-shadow: 0px 0px 4px #fff; }
.management .management-unit { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-bottom: 12px; }
.management .management-unit .management-graph { position: relative; padding: 108px 40px 48px; background: #fff; border-radius: 4px; box-shadow : 0 0 6px rgba(0,0,0, 0.08); }
.management .management-unit .management-graph::before { position: absolute; top: -8px; right: 32px; content: ""; width: 74px; height: 30px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a325a9515ba/original.png") no-repeat; background-size: contain; }
.management .management-unit .management-graph .number { position: absolute; top: 24px; left: 0; display: flex; justify-content: center; align-items: baseline; padding: 8px; width: 175px; height: 60px; background: #d92a24; border-radius: 0 34px 34px 0; color: #fff; font-size: 2.8rem; font-weight: bold; font-family: "Inter"; }
.management .management-unit .management-graph .number small { padding-right: 6px; font-size: 2rem; }
.management .management-unit .management-graph .graph-ttl { text-align: center; font-size: 2.8rem; font-weight: bold; }
.management .management-unit .management-graph .result-txt { text-align: center; }
.management .management-unit .management-graph .result-txt-inner { position: relative; display: inline-block; padding: 8px 0 0; font-size: 2rem; font-weight: bold; line-height: 1.1; }
.management .management-unit .management-graph .result-txt-inner .percent { font-size: 4rem; }
.management .management-unit .management-graph .result-txt-inner .percent em { font-size: 6.4rem; }
.management .management-unit .management-graph .result-txt-inner::before,.management .management-unit .management-graph .result-txt-inner::after { position: absolute; top: 50%; transform: translateY(-50%); content: ""; width: 76px; height: 100px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a325b2d6ab6/original.png") no-repeat; background-size: contain; }
.management .management-unit .management-graph .result-txt-inner::before { left: -88px; }
.management .management-unit .management-graph .result-txt-inner::after { right: -94px; transform: scale(-1,1) translateY(-50%); }
.management .txt--right { font-size: 1.4rem; }

/* ========================================
たんぱく質が大切なワケ
======================================== */
.protein { padding: 80px 0; background: linear-gradient(to right, transparent 16%, #FCFCFC 16%); }
.protein .protein-ttl { margin: 0 auto 32px; width: 100%; max-width: 707px; } 
.protein .protein-content { display: grid; gap: 48px; margin-bottom: 28px; }
.protein .protein-content .protein-item { display: grid; gap: 28px; }
.protein .protein-content .protein-item .balloon { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 28px; }
.protein .protein-content .protein-item .balloon .balloon-icon { width: 64px; transform: translateY(16px); }
.protein .protein-content .protein-item .balloon .balloon-txt { position: relative; padding: 20px 48px 26px; width: calc( 100% - 92px ); background: #fff; border-radius: 40px 40px 40px 4px; box-shadow : 3px 3px 6px rgba(0,0,0, 0.12); }
.protein .protein-content .protein-item .balloon .balloon-txt::before { position: absolute; bottom: -11px; left: -18px; content: ""; width: 40px; height: 30px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3264123501/original.png") no-repeat; background-size: contain; }
.protein .protein-content .protein-item .balloon--q .balloon-txt { font-size: 2.4rem; font-weight: bold; }
.protein .protein-content .protein-item .balloon--a .balloon-txt { border-radius: 74px 74px 4px 74px; }
.protein .protein-content .protein-item .balloon--a .balloon-txt .answer-ttl { margin-bottom: 10px; color: #43b212; font-size: 2.4rem; font-weight: bold; }
.protein .protein-content .protein-item .balloon--a .balloon-txt::before { right: -23px; left: auto; transform: scale(-1,1); }
.protein .txt--right { font-size: 1.4rem; }

/* アスリート
---------------------------------------- */
.athlete-ttl { position: relative; text-align: center; padding: 82px 0 0; font-size: 4.4rem; font-weight: bold; }
.athlete-ttl small { font-size: 3.2rem; }
.athlete-ttl::before,.athlete-ttl::after { position: absolute; left: 50%; transform: translateX(-50%); content: ""; width: 50px; height: 20px; clip-path: polygon(100% 0, 0 0, 50% 100%); }
.athlete-ttl::before { top: 0; background: #ccc; }
.athlete-ttl::after { top: 30px; background: #999; }
.athlete-unit { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; padding-top: 50px; }
.athlete-unit .athlete-item { position: relative; padding: 0 24px 45px; background: #fff; box-shadow : 0 0 6px rgba(0,0,0, 0.08); border-radius: 4px; }
.athlete-unit .athlete-item::before { position: absolute; right: -5px; bottom: -6px; content: "VOICE01"; color: #eee; font-family: "Inter"; font-size: 4rem; font-weight: bold; line-height: 1; }
.athlete-unit .athlete-item .profile-unit { position: relative; margin-bottom: 32px; padding-top: 40px; }
.athlete-unit .athlete-item .profile-unit_name { width: 222px; font-size: 4rem; color: #d92a24; font-weight: bold; line-height: 1.4; }
.athlete-unit .athlete-item .profile-unit_name small { font-size: 2rem; }
.athlete-unit .athlete-item .profile-unit_name .position { display: block; text-align: center; height: 28px; background: #F5F5F5; border-radius: 2px; color: #333; font-size: 1.6rem; line-height: 26px; }
.athlete-unit .athlete-item .profile-unit_name .title { display: block; font-size: 1.6rem; line-height: 1; }
.athlete-unit .athlete-item .profile-unit_vsl { position: absolute; width: calc( 100% - 250px); top: -50px; right: 0; }
.athlete-unit .athlete-item:last-child::before { content: "VOICE02"; }
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 28px; padding-top: 28px; }
.athlete-unit .athlete-item:last-child .profile-unit_name { width: 238px; }
.athlete-unit .athlete-item .comment-ttl { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; margin-bottom: 12px; padding-bottom: 12px; height: 92px; border-bottom: solid 3px #ededed; font-size: 2.4rem; font-weight: bold; line-height: 1.4; }
.athlete-unit .athlete-item .comment-ttl span { position: relative; display: flex; align-items: center; padding: 0 32px; height: 100%; }
.athlete-unit .athlete-item .comment-ttl span::before,.athlete-unit .athlete-item .comment-ttl span::after { position: absolute; top: 20px; content: ""; width: 40px; height: 40px; border-right: 3px solid #999; border-top: 3px solid #999; }
.athlete-unit .athlete-item .comment-ttl span::before { left: 0; transform: rotate(225deg); }
.athlete-unit .athlete-item .comment-ttl span::after { right: 0; transform: rotate(45deg); }

/* ========================================
導入までの流れ
======================================== */
.flow,.flow-inner { position: relative; } 
.flow::before,.flow::after,.flow-inner::before { position: absolute; content: ""; width: 80%; height: 172px; background: #FCFCFC; z-index: -1; }
.flow::before { top: 180px; }
.flow::after { top: 400px; right: 0; }
.flow-inner::before { top: 640px; }
.flow .flow-ttl { margin: 0 auto 80px; width: 416px; }
.flow .flow-ttl img:first-child { margin-bottom: 10px; }
.flow .flow-content { position: relative; display: grid; gap: 20px; }
.flow .flow-content::before { position: absolute; top: 40px; left: 110px; content: ""; background: #d92a24; width: 6px; height: 80%; z-index: 1; }
.flow .flow-content .flow-item { position: relative; padding: 30px 24px 30px 34px; display: flex; flex-wrap: wrap; align-items: center; gap: 44px; background: #fff; border-radius: 4px; box-shadow : 0 0 6px rgba(0,0,0, 0.08); }
.flow .flow-content .flow-item .flow-vsl { position: relative; z-index: 1; width: 160px; }
.flow .flow-content .flow-item .flow-vsl::before { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); content: ""; width: 180px; height: 180px; background: linear-gradient(115deg,#EDEDED,transparent 40%); border-radius: 50%; z-index: -1; }
.flow .flow-content .flow-item .flow-vsl::after { position: absolute; top: 0; right: -38px; content: ""; width: 76px; height: 76px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3298f02c37/original.png") no-repeat; background-size: contain; }
.flow .flow-content .flow-item .flow-txt { width: calc( 100% - 204px ); }
.flow .flow-content .flow-item .flow-txt .flow-step-ttl { margin-bottom: 10px; padding-bottom: 8px; border-bottom: solid 3px #ededed; font-size: 3.2rem; font-weight: bold; }
.flow .flow-content .flow-item:nth-child(2) .flow-vsl::after { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3298f0ba4a/original.png"); }
.flow .flow-content .flow-item:nth-child(3) .flow-vsl::after { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3298f05aab/original.png"); }

/* ========================================
従業員様のご利用の流れ
======================================== */
.employee .employee-ttl {  margin: 0 auto 80px; width: 100%; max-width: 698px; }
.employee .employee-content { display: grid; grid-template-columns: 0.95fr 0.95fr 1.05fr; margin-bottom: 20px;  border-radius: 4px; box-shadow: 0 0 6px rgba(0,0,0, 0.08); }
.employee .employee-content .employee-item { position: relative; display: flex; flex-direction: column; padding-top: 36px; padding-bottom: 30px; }
.employee .employee-content .employee-item::before { position: absolute; top: 0; right: -44px; z-index: 1; content: ""; }
.employee .employee-content .employee-item:nth-child(1) { padding-right: 20px; padding-left: 20px; }
.employee .employee-content .employee-item:nth-child(1)::before { width: 44px; height: 100%; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a363416943f/original.png") center / cover no-repeat; }
.employee .employee-content .employee-item:nth-child(2) { padding-right: 16px; padding-left: 58px; background: #fdfdfd; }
.employee .employee-content .employee-item:nth-child(2)::before { width: 44px; height: 100%; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a36341838bb/original.png") center / cover no-repeat; }
.employee .employee-content .employee-item:nth-child(3) { padding-right: 20px; padding-left: 64px; background: #fafafa; }
.employee .employee-content .employee-item .employee-txt { display: flex; flex-direction: column; flex-grow: 1; }
.employee .employee-content .employee-item .employee-txt .employee-step-ttl { position: relative; text-align: center; margin-bottom: 6px; font-size: 3.2rem; font-weight: bold; line-height: 1.4; }
.employee .employee-content .employee-item .employee-txt .employee-step-ttl::before { position: absolute; top: -60px; left: 50%; translate: -50% 0; content: ""; width: 140px; height: 50px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a35bc2d9239/original.png") center / contain no-repeat; }
.employee .employee-content .employee-item:nth-child(2) .employee-txt .employee-step-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a35bd59d3fc/original.png"); }
.employee .employee-content .employee-item:nth-child(3) .employee-txt .employee-step-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a35bda194da/original.png"); }
.employee .employee-content .employee-item .employee-txt p { display: flex; flex-grow: 1; justify-content: center; align-items: center; text-align: center; letter-spacing: 0;  }
.employee .employee-content .employee-item .employee-txt p .employee-txt-inner { position: relative; }
.employee .employee-content .employee-item .employee-txt p .note {position: absolute; right: 0; top: 24px;color: #D92A24; font-size: 1.4rem; }
.employee .employee-content .employee-item .employee-vsl { max-width: 310px; margin-inline: auto; }
.employee .employee-content .employee-item:nth-child(2) .employee-vsl { max-width: 280px; }
.employee .note-txt { text-align: right; }

/* ========================================
他社食サービスとの違い
======================================== */
.difference .difference-ttl { margin: 0 auto 60px; width: 705px; }
.difference .difference-content { display: grid; grid-template-columns: repeat(2,1fr); gap: 52px; }
.difference .difference-box { position: relative; }
.difference .difference-box::before { position: absolute; top: -20px; left: -20px; content: ""; width: 90px; height: 90px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a32a234672c/original.png") no-repeat; background-size: contain; z-index: 1; }
.difference .difference-box:nth-child(2)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a32a23647ff/original.png"); }
.difference .difference-box:nth-child(3)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a32a235f0aa/original.png"); }
.difference .difference-box:nth-child(4)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a32a235535c/original.png"); }
.difference .difference-box .difference-box-inner { position: relative; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 32px; padding: 35px 16px 30px; border: solid 3px #d92a24; border-radius: 4px; }
.difference .difference-box .difference-box-inner::before,.difference .difference-box .difference-box-inner::after { position: absolute; content: ""; width: 33px;  height: 5px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a3076fbb219/original.png") no-repeat; background-size: contain; }
.difference .difference-box .difference-box-inner::before { top: -3px; right: -7px; }
.difference .difference-box .difference-box-inner::after { bottom: -3px; left: 5px; }
.difference .difference-box .difference-box-inner .difference-vsl { width: 108px; }
.difference .difference-box .difference-box-inner .difference-txt { position: relative; text-align: center; padding-top: 38px; font-size: 3.2rem; font-weight: bold; line-height: 1; }
.difference .difference-box .difference-box-inner .difference-txt .exclamation { font-size: 4rem; }
.difference .difference-box .difference-box-inner .difference-txt::before { position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ""; width: 33px; height: 26px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a32acac6dff/original.png") no-repeat; background-size: contain; }
.difference .difference-box:nth-child(2) .difference-box-inner {gap: 16px; padding-left: 56px; }

/* ========================================
こだわりのメニュー
======================================== */
.menu { position: relative; padding: 72px 0 120px; background: repeating-linear-gradient(to bottom,#f8f8f8,#f8f8f8 3px,transparent 3px,transparent 23px); }
.menu::before { position: absolute; top: -10px; left: 0; content: ""; width: 80%; height: calc( 100% + 10px ); background: #fcfcfc; z-index: -1; }
.menu .menu-ttl { margin: 0 auto 40px; width: 530px; }
.menu-content { display: grid; grid-template-columns: repeat(2,1fr); justify-content: center; gap: 32px 40px; }
.menu-content .menu-col img { border-radius: 4px; }

/* 
.menu-content .menu-item { width: calc( 50% - 20px ); }
.menu-content .menu-item .menu-vsl { position: relative; padding-top: 40px; }
.menu-content .menu-item .menu-vsl img { border-radius: 4px; }
.menu-content .menu-item .menu-vsl::before { position: absolute; top: 0; left: -34px; content: ""; width: 108px; height: 86px; background: url("/img/top/menu-deco.svg") no-repeat; background-size: contain; }
.menu-content .menu-item .menu-txt { position: relative; margin: -20px auto 0; padding: 24px 16px 12px; max-width: 420px; background: #fff; box-shadow : 0 0 6px rgba(0,0,0, 0.08); border-radius: 4px; }
.menu-content .menu-item .menu-txt::before { position: absolute; top: -24px; left: 50%; transform: translateX(-50%); content: ""; width: 54px; height: 40px; background: url("/img/top/tape.svg") no-repeat; background-size: contain; }
.menu-content .menu-item .menu-txt .menu-name { text-align: center; display: flex; justify-content: center; align-items: center; margin-bottom: 14px; height: 56px; color: #d92a24; font-size: 2.4rem; font-weight: bold; line-height: 1.2; }
.menu-content .menu-item .menu-txt .nutrition-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; text-align: center; }
.menu-content .menu-item .menu-txt .nutrition-list dt { margin-bottom: 6px; padding: 2px; background: #43b212; border-radius: 2px; color: #fff; font-size: 1.6rem; }
.menu-content .menu-item:nth-child(2) .menu-txt .nutrition-list dt,.menu-content .menu-item:nth-child(3) .menu-txt .nutrition-list dt { background: #eba421; } */

/* ========================================
よくあるご質問
======================================== */
.qa .qa-ttl { position: relative; margin: 0 auto 40px; width: 416px; }
.qa .qa-ttl .qa-ttl-deco { position: absolute; top: -58px; left: -76px; width: 83px; height: 88px; }
.qa .qa-list { display: grid; gap: 12px; }
.qa .qa-list .qa-item { position: relative; border: solid #ededed 3px; border-radius: 4px; cursor: pointer; transition: .3s ease-out; }
.qa .qa-list .qa-item:hover { border-color: #aaa; }
.qa .qa-list .qa-item:hover summary { color: #d92a24; }
.qa .qa-list .qa-item[open] .qa-txt { animation: fadeIn 0.5s ease; }
.qa .qa-list .qa-item summary { position: relative; padding: 16px 40px 18px 62px; font-size: 2rem; font-weight: bold; line-height: 1.4; list-style: none; transition: .3s ease-out; }
.qa .qa-list .qa-item summary::before { position: absolute; top: 9px; left: 24px; content: "Q"; color: #d92a24; font-family: "Inter"; font-size: 3rem; font-weight: bold; }
.qa-plus { position: absolute; top: calc( 50% + 2px ); right: 16px; transform: translateY(-50%); display: inline-block; vertical-align: middle; line-height: 1; min-width: 16px; height: 3px; background-color: #333; }
.qa-plus::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: inherit; border-radius: inherit; transform: rotate(90deg); transition: 0.3s; }
.qa-item[open] .qa-plus::before { transform: rotate(0deg); }
.qa .qa-list .qa-item .qa-txt { position: relative; padding: 0 40px 20px 62px; }
.qa .qa-list .qa-item .qa-txt::before { position: absolute; top: -8px; left: 24px; content: "A"; color: #43b212; font-family: "Inter"; font-size: 3rem; font-weight: bold; }

/* ========================================
追尾ボタン
======================================== */
.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; }


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1400px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

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

/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve-inner::before { left: -80px; }
.solve-inner::after { right: -120px; }

}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
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; }

/* ========================================
MV
======================================== */
.hero .hero-unit { padding: 80px 48px 64px; }
.hero .hero-unit .hero-unit__vsl { width: calc(100% - 380px); }
.hero .hero-unit .hero-unit__form { padding: 112px 0 0; width: 340px; }
.hero .hero-unit .hero-unit__form .hero-form-inner { max-height: 440px; }

/* ========================================
フッター
======================================== */
.footer .footer-unit { padding: 38px 32px 30px; }

/* ========================================
企業の声
======================================== */
.voice::before,.voice::after { opacity: .4; }
.voice::before { left: -80px; }
.voice::after { right: -80px; }

/* ========================================
こんなお悩みございませんか？
======================================== */
.worry .worry-content .worry-txt:nth-child(2) { margin-bottom: 20px; }

/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve-inner::before,.solve-inner::after { width: 520px; height: 446px; }
.solve-inner::before { left: -230px; }
.solve-inner::after { right: -230px; }

/* ========================================
お悩み解決
======================================== */
.solution .solution-unit_vsl { width: 230px; }
.solution .solution-unit_txt { width: calc( 100% - 296px ); }
.solution .solution-unit_txt .qa-box .qa-box_q, .solution .solution-unit_txt .qa-box .qa-box_a { font-size: 1.8rem; }
.solution .solution-unit_txt .qa-box .qa-box_a { padding: 16px 24px 16px 16px; }
.solution .solution-unit_txt .qa-box .qa-box_a::before { bottom: -36px; right: -22px; width: 64px; height: 110px; }
 
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1100px以下
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media screen and (max-width: 1100px) {
      
/* ========================================
たんぱく質が大切なワケ
======================================== */
/* アスリート
---------------------------------------- */
.athlete-unit .athlete-item .profile-unit_name { width: 204px; font-size: 3.6rem; }
.athlete-unit .athlete-item .profile-unit_name .title { line-height: 1.2; }
.athlete-unit .athlete-item .profile-unit_vsl { width: calc( 100% - 236px); }
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 24px; }
.athlete-unit .athlete-item .comment-ttl { font-size: 2.2rem; }

}

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

@media screen and (max-width: 1024px) {
  
/* ========================================
共通パーツ
======================================== */
.view-l { display: block; }

/* ========================================
MV
======================================== */
.hero .hero-unit { gap: 20px; padding: 64px 32px 48px; }
.hero .hero-unit .hero-unit__vsl { width: calc(100% - 337px); }
.hero .hero-unit .hero-unit__form { padding: 112px 0 0; width: 317px; }
.hero .hero-unit .hero-unit__form .hero-form-inner { max-height: 400px; }

}


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
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; }
.view-m { display: block; }

/* マージン
---------------------------------------- */
.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: 72px; }

/* CV
---------------------------------------- */
.cv { margin-bottom: 80px; }
.cv::before { height: 400px; }
.cv .cv-intro { margin-bottom: 10px; max-width: 540px; }
.cv .cv-txt { margin-bottom: 130px; font-size: 2.4rem; }
.cv .cv-txt .present { font-size: 5.6rem; letter-spacing: .2rem; }
.cv .cv-txt .present::before,.cv .cv-txt .present::after { width: 204px; height: 107px; }
.cv .cv-txt .present::before { left: -210px; }
.cv .cv-txt .present::after { right: -200px; }
.cv .cv-txt .present small { font-size: 4rem; }
.cv .cv-btn-unit { gap: 12px; }
.cv .cv-btn a { gap: 12px; height: 160px; font-size: 3.2rem; }
.cv .cv-btn a img { width: 48px; }
.cv .cv-btn--download a::after,.cv .cv-btn--contact a::after { font-size: 2.4rem; }

/* フォーム
---------------------------------------- */
.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; }

/* ========================================
MV
======================================== */
.hero { background-position: 25% 10%; } 
.hero .hero-unit .hero-unit__vsl { width: 100%; }
.hero .hero-unit .hero-unit__form { display: none; }

/* .hero { background-position: 70% 10%; } 
.hero .hero-txt { top: 40px; left: 24px; transform: translateY(0); }
.hero .hero-txt .catchcopy { margin-bottom: 10px; width: 680px; }
.hero .hero-txt .award { width: 530px; }
.hero .freezer-vsl { left: auto; right: 20px; bottom: 10px; width: 160px; }
.hero .freezer-txt { left: auto; right: 60px; bottom: 0; width: 220px; }
.hero .hero-form  { display: none; } */

/* ========================================
企業の声
======================================== */
.voice::before { left: -120px; }
.voice::after { right: -120px; }
.voice .voice-intro .intro-ttl img { margin: 0 auto 40px; }
.voice .voice-list { grid-template-columns: 1fr; gap: 24px; }
.voice .voice-list_item { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; padding: 30px 12px; }
.voice .voice-list_item .voice-vsl { width: 260px; }
.voice .voice-list_item .voice-txt { width: calc( 100% - 276px ); }
.voice .voice-list_item .voice-graph { margin: 0; }

/* ========================================
こんなお悩みございませんか？
======================================== */
.worry { padding: 96px 0 100px; }
.worry .wrap::before,.worry .wrap::after,.worry .wrap-inner::before  { font-size: 20rem; }
.worry .worry-content { gap: 64px; }
.worry .worry-content .worry-txt { padding: 16px 48px 20px 80px; }
.worry .worry-content .worry-txt .underline { font-size: 3.2rem; }
.worry .worry-content .worry-txt::before { width: 280px; height: 168px; }
.worry .worry-content .worry-txt:nth-child(2)  { padding: 16px 48px 20px 80px; margin-bottom: 0; margin-left: 200px; }
.worry .worry-content .worry-txt:nth-child(3) { padding: 18px 68px 10px 80px; }

/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve::before { width: 120px; height: 78px; }
.solve-inner { padding: 110px 0; }
.solve p { font-size: 3rem; }
.solve p em { font-size: 4.2rem; }

/* ========================================
お悩み解決
======================================== */
.solution { padding: 80px 0 0; }
.solution .solution-content { display: grid; gap: 48px; }
.solution .solution-unit { gap: 40px; padding: 40px 0; }
.solution .solution-unit::before { width: calc( 100% - 112px ); }
.solution .solution-unit::after { top: 56px; right: -74px; font-size: 3.2rem; }
.solution .solution-unit_vsl { width: 200px; }
.solution .solution-unit_txt { width: calc( 100% - 253px ); }
.solution .solution-unit_txt .solution-ttl { margin: 0 0 24px; padding-top: 74px; font-size: 3.2rem; }
.solution .solution-unit_txt .solution-ttl .exclamation { font-size: 4rem; transform: rotate(10deg)  translate(-8px,-3px); }
.solution .solution-unit_txt .solution-ttl::before { width: 350px; height: 70px; }
.solution .solution-unit_txt .qa-box { grid-template-columns: 1fr; gap: 16px; }
.solution .solution-unit_txt .qa-box::before { transform: rotate(90deg) translateX(-50%); top: 105px; left: calc(50% - 20px); width: 40px; height: 6px; }
.solution .solution-unit_txt .qa-box .qa-box_q,.solution .solution-unit_txt .qa-box .qa-box_a { height: auto; }
.solution .solution-unit_txt .qa-box .qa-box_q { padding: 12px; }
.solution .solution-unit_txt .qa-box .qa-box_a { padding: 12px 32px 12px 12px; }
.solution .solution-unit_txt .qa-box .qa-box_a::before { bottom: -23px; right: -20px; }
.solution .solution-unit_txt .btn a { max-width: 504px; }
.solution .solution-unit:nth-child(2) .solution-unit_txt .solution-ttl::before { background-image: url("/img/top/solution-ttl-deco2.png") ; }
.solution .solution-unit:nth-child(3) .solution-unit_txt .solution-ttl::before { background-image: url("/img/top/solution-ttl-deco3.png") ; }
.solution .solution-unit_txt .persistence-graph { max-width: 366px; height: 110px; }

/* ========================================
今、健康経営が注目されています
======================================== */
.management .management-ttl { margin-bottom: 30px; }
.management .management-box { margin: 0 auto 48px; padding: 16px 32px 24px; }
.management .management-box::before { top: 70px; }
.management .management-box::after { width: 70px; height: 143px; }
.management .management-box .box-ttl { margin-bottom: 24px; font-size: 2.8rem; }
.management .management-unit { grid-template-columns: 1fr; gap: 12px; }
.management .management-unit .management-graph { padding: 96px 30px 40px }
.management .management-unit .management-graph .number { top: 20px; width: 160px; height: 56px; font-size: 2.4rem; }
.management .management-unit .management-graph .number small { padding-right: 6px; font-size: 2rem; }
.management .management-unit .management-graph .graph-ttl { font-size: 2.4rem; }
.management .management-unit .management-graph .graph-vsl { margin-right: auto; margin-left: auto; width: 100%; max-width: 580px; }
.management .management-unit .management-graph .result-txt-inner .percent { font-size: 3.6rem; }
.management .management-unit .management-graph .result-txt-inner .percent em { font-size: 5.6rem; }
.management .management-unit .management-graph .result-txt-inner::before,.management .management-unit .management-graph .result-txt-inner::after { width: 64px; height: 84px; }
.management .management-unit .management-graph .result-txt-inner::before { left: -80px; }
.management .management-unit .management-graph .result-txt-inner::after { right: -80px; }

/* ========================================
たんぱく質が大切なワケ
======================================== */
.protein { padding: 60px 0; }
.protein .protein-ttl { margin: 0 auto 24px; } 
.protein .protein-content { gap: 36px; }
.protein .protein-content .protein-item { gap: 20px; }
.protein .protein-content .protein-item .balloon {  gap: 20px; }
.protein .protein-content .protein-item .balloon .balloon-icon { width: 60px; transform: translateY(12px); }
.protein .protein-content .protein-item .balloon .balloon-txt { padding: 16px 40px 22px; width: calc( 100% - 80px ); }

/* アスリート
---------------------------------------- */
.athlete-ttl { padding: 64px 0 0; font-size: 4rem; }
.athlete-ttl small { font-size: 2.8rem; }
.athlete-unit { gap: 16px; padding-top: 40px; }
.athlete-unit .athlete-item { padding: 0 16px 32px; }
.athlete-unit .athlete-item::before { font-size: 3.2rem; }
.athlete-unit .athlete-item .profile-unit { margin-bottom: 24px; padding-top: 150px; }
.athlete-unit .athlete-item .profile-unit_name { text-align: center; margin: 0 auto; }
.athlete-unit .athlete-item .profile-unit_vsl { width: 230px; top: -50px; right: auto; left: 50%; transform: translateX(-50%); }
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 4px; padding-top: 150px; }

/* ========================================
導入までの流れ
======================================== */
.flow .flow-content { gap: 16px; }
.flow::before, .flow::after, .flow-inner::before { width: 90%; }
.flow::before { top: 170px; }
.flow::after { top: 370px; }
.flow-inner::before { top: 615px; }
.flow .flow-ttl { margin: 0 auto 60px; }
.flow .flow-content::before { left: 96px; }
.flow .flow-content .flow-item { padding: 24px 18px 24px 28px; gap: 38px; }
.flow .flow-content .flow-item .flow-vsl { width: 140px; }
.flow .flow-content .flow-item .flow-vsl::before { width: 160px; height: 160px; }
.flow .flow-content .flow-item .flow-vsl::after { right: -32px; width: 70px; height: 70px; }
.flow .flow-content .flow-item .flow-txt { width: calc( 100% - 178px ); }
.flow .flow-content .flow-item .flow-txt .flow-step-ttl { margin-bottom: 8px; padding-bottom: 6px; font-size: 2.6rem; }

/* ========================================
他社食サービスとの違い
======================================== */
.difference .difference-ttl { margin: 0 auto 50px; width: 660px; }
.difference .difference-content { gap: 40px; }
.difference .difference-box::before { width: 72px; height: 72px; }
.difference .difference-box .difference-box-inner { gap: 24px; padding: 30px 12px 25px; }
.difference .difference-box .difference-box-inner .difference-vsl { width: 88px; }
.difference .difference-box .difference-box-inner .difference-txt { font-size: 2.4rem; }
.difference .difference-box .difference-box-inner .difference-txt .exclamation { font-size: 3rem; }
.difference .difference-box:nth-child(2) .difference-box-inner { gap: 8px; padding-left: 26px; }

/* ========================================
こだわりのメニュー
======================================== */
.menu { padding: 60px 0 100px; }
.menu::before { width: 90%; }
.menu .menu-ttl { margin-bottom: 30px; width: 500px; }
.menu-content { gap: 24px 30px; }

/*
.menu-content .menu-item { width: calc( 50% - 15px ); }
.menu-content .menu-item .menu-vsl { padding-top: 28px; }
.menu-content .menu-item .menu-vsl::before { left: -12px; width: 90px; height: 70px; }
.menu-content .menu-item .menu-txt { width: 90%; padding: 20px 12px 8px; }
.menu-content .menu-item .menu-txt .menu-name { margin-bottom: 10px; height: 50px; font-size: 2rem; }

/* ========================================
従業員様のご利用の流れ
======================================== */
.employee .employee-ttl { margin: 0 auto 60px; } 
.employee .employee-content {  grid-template-columns: 1fr; }
.employee .employee-content .employee-item { flex-direction: row; align-items: center; gap: 24px; padding-top: 20px;  padding-bottom: 20px; }
.employee .employee-content .employee-item:nth-child(1) { padding-right: 60px; padding-left: 60px; }
.employee .employee-content .employee-item:nth-child(2) { padding: 40px 60px 20px; }
.employee .employee-content .employee-item:nth-child(2) .employee-vsl {     max-width: 310px; }
.employee .employee-content .employee-item:nth-child(3) { padding: 40px 60px; } 
.employee .employee-content .employee-item:nth-child(1)::before,.employee .employee-content .employee-item:nth-child(2)::before{ top: auto; right: 0; bottom: -40px;  width: 100%; height: 45px;  }
.employee .employee-content .employee-item:nth-child(1)::before { background-image: url('https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a6ef997f1f5/original.png'); }
.employee .employee-content .employee-item:nth-child(2)::before { background-image: url('https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a6f264670f8/original.png'); }    
.employee .employee-content .employee-item .employee-txt { flex-grow: 0; width: 360px; } 
.employee .employee-content .employee-item .employee-txt .employee-step-ttl { text-align: left; padding-top: 48px;  font-size: 2.8rem; }  
.employee .employee-content .employee-item .employee-txt .employee-step-ttl::before { top: 0; left: 0; translate: 0; width: 120px; height: 44px; } 
.employee .employee-content .employee-item .employee-txt .employee-step-ttl  .view-l { display: none; } 
.employee .employee-content .employee-item .employee-txt p {  display: block; flex-grow: 0; text-align: left;  } 
  
/* ========================================
よくあるご質問
======================================== */
.qa .qa-ttl { margin-bottom: 30px; width: 380px; }
.qa .qa-ttl .qa-ttl-deco { top: -56px; left: -70px; width: 76px; height: 82px; }
.qa .qa-list .qa-item summary { padding: 12px 36px 14px 54px; }
.qa .qa-list .qa-item summary::before {  top: 4px; left: 18px; }
.qa .qa-list .qa-item .qa-txt { padding: 0 36px 14px 54px; }
.qa .qa-list .qa-item .qa-txt::before { left: 18px; }

/* ========================================
フッター
======================================== */
.footer { padding-bottom: 60px; }
.footer .footer-unit { gap: 32px; padding: 32px 24px 24px; }
.footer .footer-unit .logo { width: 230px; }

/* ========================================
追尾ボタン
======================================== */
.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: 48px; }

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

/* ボタン
---------------------------------------- */
.btn a { height: 72px;  font-size: 1.6rem; } 
.btn a span { width: 32px; height: 32px; }
.btn a img { width: 12px; }

/* CV
---------------------------------------- */
.cv { margin-bottom: 48px; }
.cv::before { top: 36px; height: 278px; }
.cv .cv-intro { margin-bottom: 6px; max-width: 450px; }
.cv .cv-txt { margin-bottom: 80px; font-size: 2rem; }
.cv .cv-txt .present { font-size: 4.3rem; }
.cv .cv-txt .present::before,.cv .cv-txt .present::after { width: 85px; height: 94px; background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a306381cfb3/original.png"); }
.cv .cv-txt .present::before { left: -110px; }
.cv .cv-txt .present::after { right: -100px; }
.cv .cv-txt .present small { font-size: 3.3rem; }
.cv .cv-txt .underline { font-size: 1.9rem; }
.cv .cv-btn-unit { display: grid; gap: 8px; }
.cv .cv-btn a { gap: 8px; height: 100px; border-radius: 2px; font-size: 2.4rem; }
.cv .cv-btn a img { width: 36px; }
.cv .cv-btn--download a,.cv .cv-btn--contact a { border-width: 6px; }
.cv .cv-btn--download a::after,.cv .cv-btn--contact a::after { top: 0; left: 6px; font-size: 1.8rem; }

/* フォーム
---------------------------------------- */
.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; }

/* ========================================
MV
======================================== */
.hero { margin: -16px 0 48px; }
.hero .hero-unit { padding: 48px 16px 32px; }
.hero .hero-unit .hero-unit__vsl .source { font-size: 1rem; }

/* .hero { height: 650px; }
.hero:before { display: none; }
.hero::after { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 100%; background: linear-gradient(45deg,rgba(51,51,51) 5%,transparent 10% ); opacity: .32;  }
.hero .hero-txt { top: 24px; left: 12px; }
.hero .hero-txt .catchcopy { width: 640px; }
.hero .hero-txt .award { width: 300px; }
.hero .freezer-vsl { right: -2px; bottom: -2px; width: 160px; }
.hero .freezer-txt { right: 48px; width: 200px; }
.hero .source { left: 12px; bottom: 6px; padding-right: 180px; font-size: 1rem; } */

/* ========================================
企業の声
======================================== */
.voice::before, .voice::after { width: 420px; height: 343px; }
.voice::before { left: -180px; }
.voice::after { right: -180px; }
.voice .voice-intro img { margin: 0 auto 16px; width: 460px; }
.voice .voice-intro .intro-ttl img { margin: 0 auto 32px; }
.voice .voice-list { gap: 16px; }
.voice .voice-list_item { gap: 12px; padding: 24px 12px; }
.voice .voice-list_item .voice-vsl { width: 230px; }
.voice .voice-list_item .voice-logo { margin: 0 auto 10px; width: 160px; }
.voice .voice-list_item .voice-txt { width: calc( 100% - 242px ); }
.voice .voice-list_item .voice-ttl { margin: 0 0 5px; padding: 0 0 5px 14px; font-size: 2rem; }
.voice .voice-list_item .voice-ttl::before { top: calc(50% - 1px); width: 7px; height: 6px; }

/* ========================================
こんなお悩みございませんか？
======================================== */
.worry { overflow: hidden; position: relative; padding: 64px 0 72px; }
.worry::before { height: 56px; }
.worry .wrap::before,.worry .wrap::after,.worry .wrap-inner::before  { font-size: 15rem; }
.worry .worry-ttl { margin-bottom: 32px; max-width: 340px; }
.worry .worry-content { gap: 32px; }
.worry .worry-content .worry-txt { margin-left: 0; padding: 132px 32px 16px; width: 100%; border-radius: 30px; font-size: 2rem; }
.worry .worry-content .worry-txt .underline { font-size: 2.4rem; }
.worry .worry-content .worry-txt::before { top: -20px; left: 50%; width: 250px; transform: translateX(-50%); background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a8772941006/original.png") }
.worry .worry-content .worry-txt:nth-child(2)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a877293bc20/original.png"); }
.worry .worry-content .worry-txt:nth-child(3)::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a877293c84a/original.png"); }
.worry .worry-content .worry-txt::after { top: -4px; left: 0; border-radius: 30px; }
.worry .worry-content .worry-txt:nth-child(2)  { margin-left: 0; padding: 132px 32px 16px; border-radius: 30px;  }
.worry .worry-content .worry-txt:nth-child(3) { padding: 132px 32px 12px; }
  
/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve::before { width: 100px; height: 65px; }
.solve-inner { padding: 80px 24px; }
.solve-inner::before, .solve-inner::after { width: 320px; height: 298px; background-size: contain; }
.solve-inner::before { left: -140px; }
.solve-inner::after { right: -160px; }
.solve p { font-size: 2.4rem; }
.solve p em { font-size: 3.6rem; }

/* ========================================
お悩み解決
======================================== */
.solution { padding: 64px 0 0; }
.solution .solution-content { gap: 12px; }
.solution .solution-unit { flex-direction: column-reverse; gap: 32px; padding: 32px 0; }
.solution .solution-unit::before { width: 100%; height: calc( 100% - 100px ); border-radius: 2px; }
.solution .solution-unit::after { top: 42px; right: -55px; font-size: 2.4rem; }
.solution .solution-unit_vsl { width: calc( 100% - 32px ); }
.solution .solution-unit_vsl img { border-radius: 2px; }
.solution .solution-unit_txt { width: 94%; }
.solution .solution-unit_txt .solution-ttl { margin: 0 0 20px; padding-top: 64px; font-size: 2.4rem; }
.solution .solution-unit_txt .solution-ttl .exclamation { font-size: 3rem; transform: rotate(10deg)  translate(-5px,-3px); }
.solution .solution-unit_txt .solution-ttl::before { width: 280px; height: 55px; }
.solution .solution-unit_txt .qa-box { gap: 12px; }
.solution .solution-unit_txt .qa-box::before { display: none; }
.solution .solution-unit_txt .qa-box .qa-box_q,.solution .solution-unit_txt .qa-box .qa-box_a { border-radius: 2px; font-size: 1.6rem; }
.solution .solution-unit_txt .qa-box .qa-box_q::before { position: absolute; bottom: -12px; left: calc( 50% - 2px ); transform: translateX(-50%); content: ""; width: 2px; height: 20px; background: #333; }
.solution .solution-unit_txt .qa-box .qa-box_a::before { bottom: -22px; width: 60px; height: 100px; }
.solution .solution-unit_txt .qa-box .qa-box_a::after { position: absolute; top: 0; left: 50%; transform: translateX(-50%); content: ""; width: 6px; height: 12px; background: url("/img/icon/arrow-a.svg") no-repeat; background-size: contain; }
.solution .solution-unit_txt .btn a { padding: 0 48px 0 24px; }
.solution .solution-unit:nth-child(2) .solution-unit_txt .solution-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30eb5854de/original.png") ; }
.solution .solution-unit:nth-child(3) .solution-unit_txt .solution-ttl::before { background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30eb57d947/original.png") ; }
.solution .solution-unit_txt .persistence-graph { max-width: 280px; height: 85px; }
.solution .txt--center { font-size: 2rem; }

/* ========================================
今、健康経営が注目されています
======================================== */
.management .management-ttl { margin-bottom: 20px; max-width: 400px; }
.management .management-box { margin: 0 auto 32px; padding: 12px 24px 20px; }
.management .management-box::before { top: 48px; }
.management .management-box::after { right: 8px; width: 60px; height: 122px; }
.management .management-box .box-ttl { margin-bottom: 16px; font-size: 2rem; }
.management .management-unit { gap: 24px; margin-bottom: 8px; }
.management .management-unit .management-graph { padding: 80px 20px 24px }
.management .management-unit .management-graph::before { right: 24px; width: 64px; height: 26px; }
.management .management-unit .management-graph .number { top: 16px; width: 120px; height: 48px; font-size: 2rem; }
.management .management-unit .management-graph .number small { padding-right: 4px; font-size: 1.4rem; }
.management .management-unit .management-graph .number small { padding-right: 6px; font-size: 2rem; }
.management .management-unit .management-graph .graph-ttl { font-size: 2rem; }
.management .management-unit .management-graph .result-txt-inner { padding: 6px 0 0; font-size: 1.6rem; }
.management .management-unit .management-graph .result-txt-inner .percent { font-size: 3rem; }
.management .management-unit .management-graph .result-txt-inner .percent em { font-size: 4.8rem; }
.management .management-unit .management-graph .result-txt-inner::before,.management .management-unit .management-graph .result-txt-inner::after { width: 48px; height: 62px; }
.management .management-unit .management-graph .result-txt-inner::before { left: -56px; }
.management .management-unit .management-graph .result-txt-inner::after { right: -56px; }
.management .txt--right { font-size: 1.2rem; }

/* ========================================
たんぱく質が大切なワケ
======================================== */
.protein { padding: 40px 0; }
.protein .protein-ttl { margin: 0 auto 16px; max-width: 300px; } 
.protein .protein-content { gap: 28px; margin-bottom: 14px; }
.protein .protein-content .protein-item { gap: 16px; }
.protein .protein-content .protein-item .balloon { gap: 16px; }
.protein .protein-content .protein-item .balloon .balloon-icon { width: 48px; transform: translateY(8px); }
.protein .protein-content .protein-item .balloon .balloon-txt { padding: 12px 16px 18px 72px; width: 100%; border-radius: 8px; }
.protein .protein-content .protein-item .balloon .balloon-txt::before { display: none; }
.protein .protein-content .protein-item .balloon--q .balloon-txt::after { position: absolute; content: ""; top: 50%; left: 16px; translate: 0 -50%; width: 44px; height: 44px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a326b685512/original.png") center / contain no-repeat; }
.protein .protein-content .protein-item .balloon--q .balloon-txt { font-size: 2rem; }
.protein .protein-content .protein-item .balloon--a .balloon-txt { padding: 12px 16px 18px; border-radius: 8px; }
.protein .protein-content .protein-item .balloon--a .balloon-txt .answer-ttl { position: relative;  margin-bottom: 6px; padding-left: 56px; font-size: 2rem; line-height: 1.4; }
.protein .protein-content .protein-item .balloon--a .balloon-txt .answer-ttl::after { position: absolute; content: ""; top: 50%; left:  0; translate: 0 -50%;  width: 44px; height: 44px; background: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a326b6948f1/original.png") center / contain no-repeat; }
.protein .protein-content .protein-item .balloon--a .balloon-txt p { font-size: 1.5rem; }
.protein .protein-content .protein-item .balloon .balloon-icon { display: none; }
.protein .txt--right { font-size: 1.2rem; }

/* アスリート
---------------------------------------- */
.athlete-ttl { padding: 56px 0 0; font-size: 3.2rem; line-height: 1.4; }
.athlete-ttl small { font-size: 2.4rem; }
.athlete-ttl::before,.athlete-ttl::after { width: 40px; height: 16px; }
.athlete-ttl::after { top: 24px; }
.athlete-unit { padding-top: 30px; }
.athlete-unit .athlete-item { padding: 0 16px 24px; }
.athlete-unit .athlete-item::before { right: -3px; bottom: -4px; font-size: 2.8rem; }
.athlete-unit .athlete-item .profile-unit { padding-top: 150px; }
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 8px; }
.athlete-unit .athlete-item .profile-unit_name { width: 183px; font-size: 3.2rem; }
.athlete-unit .athlete-item .profile-unit_name .position { height: 26px; font-size: 1.4rem; line-height: 24px; }
.athlete-unit .athlete-item .profile-unit_vsl { top: -40px; }
.athlete-unit .athlete-item .comment-ttl { margin-bottom: 8px; padding-bottom: 8px; height: 100px; font-size: 2rem; }
.athlete-unit .athlete-item .comment-ttl span { padding: 0 24px; }
.athlete-unit .athlete-item .comment-ttl span::before, .athlete-unit .athlete-item .comment-ttl span::after { top: 2px; transform: none; width: 10px; height: calc( 100% - 10px ); border-top: solid 3px #999; border-bottom: solid 3px #999; }
.athlete-unit .athlete-item .comment-ttl span::before { border-right: none; border-left: solid 3px #999; }
.athlete-unit .athlete-item:last-child .profile-unit_name { width: 231px; }

/* ========================================
導入までの流れ
======================================== */
.flow::before, .flow::after, .flow-inner::before { height: 100px; }
.flow::before { top: 146px; }
.flow::after { top: 310px; }
.flow-inner::before { top: 480px; }
.flow .flow-ttl { margin: 0 auto 40px; width: 100%; max-width: 370px; }
.flow .flow-content { gap: 12px; }
.flow .flow-content::before { left: 80px; }
.flow .flow-content .flow-item { gap: 32px; padding: 20px 14px 20px 24px; border-radius: 2px; }
.flow .flow-content .flow-item .flow-vsl { width: 120px; }
.flow .flow-content .flow-item .flow-vsl::before { width: 140px; height: 140px; }
.flow .flow-content .flow-item .flow-vsl::after { width: 60px; height: 60px; }
.flow .flow-content .flow-item .flow-txt { width: calc(100% - 152px); }
.flow .flow-content .flow-item .flow-txt .flow-step-ttl { margin-bottom: 6px; padding-bottom: 4px; font-size: 2.2rem; }

/* ========================================
他社食サービスとの違い
======================================== */
.difference .difference-ttl { margin: 0 auto 30px; width: 100%; max-width: 420px; }
.difference .difference-content { gap: 24px; }
.difference .difference-box::before { top: -16px; left: -16px; }
.difference .difference-box .difference-box-inner { flex-direction: column; gap: 12px; padding: 24px 12px 20px; border-radius: 2px; }
.difference .difference-box .difference-box-inner .difference-vsl { width: 72px; }
.difference .difference-box .difference-box-inner .difference-txt { text-align: left; padding: 0 0 0 32px; font-size: 2rem; }
.difference .difference-box .difference-box-inner .difference-txt .exclamation { font-size: 2.4rem; }
.difference .difference-box .difference-box-inner .difference-txt::before { top: 50%; left: 0; transform: translateY(-50%); width: 28px; height: 20px; }
.difference .difference-box:nth-child(2) .difference-box-inner { gap: 12px; padding-left: 12px; }
.difference .difference-box:nth-child(2) .difference-box-inner .difference-vsl { transform: translateX(8px); }

/* ========================================
こだわりのメニュー
======================================== */
.menu { padding: 30px 0 60px; }
.menu.mb-sect { margin-bottom: 40px }
.menu .menu-ttl { margin-bottom: 20px; width: 100%; max-width: 460px; }
.menu-content { gap: 16px 20px; }
.menu-content .menu-col img { border-radius: 2px; }

/*
.menu-content .menu-item { width: calc( 50% - 10px ); }
.menu-content .menu-item .menu-vsl { padding-top: 18px; }
.menu-content .menu-item .menu-vsl::before { width: 80px; height: 62px; }
.menu-content .menu-item .menu-vsl img { border-radius: 2px; }
.menu-content .menu-item .menu-txt { margin: -30px auto 0; padding: 16px 10px 6px; border-radius: 2px; }
.menu-content .menu-item .menu-txt .menu-name { margin-bottom: 8px; height: 44px; font-size: 1.8rem; }
.menu-content .menu-item .menu-txt .nutrition-list dt { margin-bottom: 2px; padding: 1px; }

/* ========================================
従業員様のご利用の流れ
======================================== */
.employee .employee-ttl { margin: 0 auto 40px; max-width: 340px; } 
.employee .employee-content .employee-item:nth-child(1) { padding-right: 30px; padding-left: 30px; } 
.employee .employee-content .employee-item:nth-child(2) { padding: 40px 30px 20px; } 
.employee .employee-content .employee-item:nth-child(3) { padding: 40px 30px; } 
.employee .employee-content .employee-item .employee-txt .employee-step-ttl { padding-top: 40px; font-size: 2.4rem; }
.employee .employee-content .employee-item .employee-txt .employee-step-ttl::before { width: 100px; height: 36px; }
.employee .employee-content .employee-item .employee-vsl,.employee .employee-content .employee-item:nth-child(2) .employee-vsl  { max-width: 240px; } 
.employee .employee-content .employee-item .employee-txt p .employee-txt-inner { display: inline-block; padding-bottom: 16px; } 
.employee .employee-content .employee-item .employee-txt p .note { top: auto; right: auto; left: 0; bottom: 0; }
  
/* ========================================
よくあるご質問
======================================== */
.qa .qa-ttl { margin-bottom: 20px; width: 100%; max-width: 340px; }
.qa .qa-ttl .qa-ttl-deco { top: -56px; left: -70px; width: 76px; height: 82px; }
.qa .qa-list { gap: 8px; }
.qa .qa-list .qa-item summary { padding: 8px 32px 10px 40px; font-size: 1.8rem; }
.qa .qa-list .qa-item summary::before { left: 14px; font-size: 2.4rem; }
.qa .qa-list .qa-item .qa-txt { padding: 0 32px 10px 40px; }
.qa .qa-list .qa-item .qa-txt::before { top: -5px; left: 14px; font-size: 2.4rem; }

/* ========================================
フッター
======================================== */
.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) {

/* ========================================
企業の声
======================================== */
.voice .voice-intro img { width: 380px; }

/* ========================================
そのお悩み、筋肉食堂Officeが解決します！
======================================== */
.solve-inner::before, .solve-inner::after { width: 340px; height: 358px; }
.solve-inner::before { left: -200px; background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30d83a4bca/original.png"); }
.solve-inner::after { right: -200px; background-image: url("https://s3-ap-northeast-1.amazonaws.com/s3.peraichi.com/userData/8bb63d67-5d19-4791-b87c-a5fb05d3e170/img/66a30d83eea8d/original.png"); }

/* ========================================
こだわりのメニュー
======================================== */
.menu-content { grid-template-columns: 1fr; }

/* ========================================
たんぱく質が大切なワケ
======================================== */
/* アスリート
---------------------------------------- */
.athlete-unit { grid-template-columns: 1fr; gap: 56px; }
.athlete-unit .athlete-item .profile-unit { margin: 0 auto 24px; padding-top: 48px; max-width: 450px; }
.athlete-unit .athlete-item .profile-unit_name { text-align: left; margin: 0; }
.athlete-unit .athlete-item .profile-unit_vsl { width: calc( 100% - 232px ); right: 0; left: auto; transform: translateX(0); } 
.athlete-unit .athlete-item .comment-ttl { height: auto; }
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 32px; padding-top: 24px; }
.athlete-unit .athlete-item:last-child .comment-ttl { height: auto; margin-bottom: 12px; padding-bottom: 16px; }
.athlete-unit .athlete-item:last-child .comment-ttl span::before, .athlete-unit .athlete-item:last-child  .comment-ttl span::after { top: -2px; height: 100%; }
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
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; }

/* CV
---------------------------------------- */
.cv::before { top: 6%; }
.cv .cv-btn-unit { grid-template-columns: 1fr; }
.cv .cv-txt { font-size: 1.8rem; }
.cv .cv-txt .present { font-size: 3.2rem; letter-spacing: 0; }
.cv .cv-txt .present small { font-size: 2.4rem; }
.cv .cv-txt .present::before, .cv .cv-txt .present::after { width: 75px; height: 82px; }
.cv .cv-txt .present::before { left: -90px; }
.cv .cv-txt .present::after { right: -80px; }

/* ========================================
MV
======================================== */
.hero .hero-unit { padding: 40px 6px 64px; }
.hero .hero-unit .hero-unit__vsl .source { bottom: -40px; }

/* ========================================
企業の声
======================================== */
.voice::before { left: -260px; }
.voice::after { right: -260px; }
.voice .voice-list_item { flex-direction: column; }
.voice .voice-list_item .voice-txt { width: 100%; }

/* ========================================
たんぱく質が大切なワケ
======================================== */
.protein .protein-content .protein-item .balloon--q .balloon-txt { font-size: 1.8rem;  }
.protein .protein-content .protein-item .balloon--a .balloon-txt .answer-ttl { font-size: 1.8rem; }

/* アスリート
---------------------------------------- */
.athlete-unit .athlete-item .profile-unit { margin: 0 auto 8px; }
.athlete-unit .athlete-item .profile-unit_name { text-align: center; margin: 0 auto; padding-top: 88px; }
.athlete-unit .athlete-item .profile-unit_vsl { width: 200px; right: auto; left: 50%; transform: translateX(-50%); } 
.athlete-unit .athlete-item:last-child .profile-unit { margin-bottom: 16px; }
.athlete-unit .athlete-item:last-child .profile-unit_name { padding-top: 104px; }

/* ========================================
導入までの流れ
======================================== */
.flow::after { top: 430px; }
.flow-inner::before { top: 740px; }
.flow .flow-content { gap: 24px; }
.flow .flow-content::before { left: 50%; transform: translateX(-50%); }
.flow .flow-content .flow-item { gap: 8px; padding: 16px 10px 16px 20px; z-index: 1; }
.flow .flow-content .flow-item .flow-vsl { margin: 0 auto; max-width: 100px; }
.flow .flow-content .flow-item .flow-vsl::after { top: -12px; left: -12px; }
.flow .flow-content .flow-item .flow-txt { width: calc(100% - 116px); }
.flow .flow-content .flow-item .flow-txt .flow-step-ttl { font-size: 2rem; line-height: 1.4; }
.flow .flow-content .flow-item .flow-vsl::before { width: 120px; height: 120px; }

/* ========================================
他社食サービスとの違い
======================================== */
.difference .difference-content {grid-template-columns: 1fr }
.difference .difference-box::before { top: -12px; left: -12px; }
.difference .difference-box .difference-box-inner { gap: 8px; padding: 14px 12px 18px; }
.difference .difference-box .difference-box-inner .difference-txt::before { top: calc( 50% + 3px ); }
.difference .difference-box:nth-child(2) .difference-box-inner { gap: 8px; }

/* ========================================
従業員様のご利用の流れ
======================================== */
.employee .employee-content .employee-item { flex-direction: column; gap: 12px; } 
.employee .employee-content .employee-item:nth-child(2) { padding: 56px 30px 20px; }
.employee .employee-content .employee-item:nth-child(3) { padding: 56px 30px 40px; }
.employee .employee-content .employee-item .employee-txt { width: 100%; }

/* ========================================
よくあるご質問
======================================== */
.qa { padding-top: 24px; }
.qa .qa-ttl .qa-ttl-deco { top: -64px; left: -12px; height: 60px; width: 76px; height: 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; }

}