﻿/* ベーススタイル */
body {
    font-family: 'Inter', 'Noto Sans JP', sans-serif;
    color: #1f2937;
    line-height: 1.6;
    margin: 0;
}


img{
	max-width:100%;
	height:auto;
}

*, *::before, *::after {
    box-sizing: border-box;
}

/* 共通レイアウト */
.container {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    z-index:10;
    position:relative;
}

.section {
width:1440px;
margin:0 auto;
	position:relative;
    padding:100px 80px;
}

.bg-white { background-color: #ffffff; }
.bg-gray { background-color: #f9fafb; }
.problem-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
}
.problem-overlay img{
	height:100%;
	opacity:0.3;
}


.bg-gray-light { background-color: #f9fafb; }
.bg-teal-dark { background-color: #0f766e; }

/* ヘッダー */
.header {
    background-color: #ffffff;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    position: sticky;
    top: 0;
    z-index: 50;
}

.header-inner {
display: grid;
    grid-template-columns: 3fr auto 1fr;
    /* grid-template-rows: 1fr 1fr; */
    grid-template-areas:
        "left top-mid right"
        "left bot-mid right";
}

.logo-area {
    grid-area: left;
display: flex;
  align-items: center; 
}

.logo-text img {
vertical-align: middle;
}

.logo-sub {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #4b5563;
    margin-left: 0.5rem;
    padding-left: 0.5rem;
    border-left: 1px solid #9ca3af;
    font-weight: 700;
    display: none;
}

/* ナビゲーションメニュー */
.nav-menu { display: none; } /* モバイルで非表示 */

.nav-link {
    font-size: clamp(16px, 1.2vw, 18px);
    font-weight: bold;
    color: #074097;
    text-decoration: none;
    transition: color 0.2s;
}

.nav-link:hover { color: #0d9488; }

/* ボタン */
.btn {
    display: inline-block;
    padding: 26px 50px;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    border: none;
}

.btn-teal {
    background-color: #F78E33;
    color: #ffffff;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.btn-yellow {
    background-color: #F78E33;
    color: #FFFFFF;
    border: 2px solid #FFFFFF;
    border-radius: 17px;
}
.btn-sm { font-size: 23px; }
.btn-xs { font-size: 0.75rem; padding: 0.5rem 1rem; }
.btn-lg { 
font-size: clamp(16px, 1.6vw, 23px);
padding: 10px 30px; 
text-shadow: 0px 0px 10px #000000;
}
.btn-xl { 
font-size: clamp(16px, 1.6vw, 23px);
padding: 0.75rem 3rem; 
width: 100%;
 }

.btn-shadow { box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1); }
.btn-scale:hover { transform: scale(1.05); }


.tel-box{
grid-area: top-mid;
text-align: end;
padding-top: 8px;
}

.tel-box a{
text-decoration:none;
color: #074097;
font-weight: bold;
}

.tel-box p{
font-size: clamp(16px, 2.5vw, 36px);
margin:0;
}


.tel-box span{
font-size: clamp(12px, 1.2vw, 18px);
}


/* Hero */
.hero-section {
    position: relative;
    color: #ffffff;
    padding: 5rem 3rem;
    text-align: center;
    overflow: hidden;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.hero-overlay img{
width: 100%;
    height: 100%;
    object-fit: cover;
}


.hero-content {
    position: relative;
    z-index: 10;
}

.hero-title {
font-size: clamp(24px, 4.17vw, 65px);
font-weight: bold;
line-height: 1.2;
margin: 0;
text-shadow: 0px 0px 10px #000000;
letter-spacing: 3.25px;
}

.hero-highlight-row {
    display: block;
    margin-top: 0.5rem;
}

.text-gradient-yellow {
    color: #FCCB00;
    font-weight: 900;
}

.text-gradient-teal {
    color: #B3FC7C;
    font-weight: 900;
}

.text-sub { 
margin: 0 0.25rem;
}

.marker-yellow { 
font-weight: 900;
 }
.marker-teal { 
font-weight: 900; 
}

.hero-description {
    font-size: clamp(14px, 1.7vw, 25px);
    color: #e5e7eb;
    margin: 0 auto 3rem;
    line-height: 1.75;
text-shadow: 0px 0px 10px #000000;
}

.hero-note {
    font-size: 0.875rem;
    color: #e5e7eb;
    margin-top: 1rem;
    background-color: rgba(0, 0, 0, 0.3);
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
}

/* 共通セクションスタイル */
.section-header { text-align: center; margin-bottom: 4rem; }
.section-tag {
    display:block;
    color: #FFFFFF;
    font-weight: bold;
    padding-bottom:15px;
    letter-spacing: 12px;
    font-size: clamp(20px, 2.8vw, 40px);
    text-align: center;
    opacity:0.5;
}
.section-title01{
    font-size: clamp(20px, 3.1vw, 45px);
    font-weight: 700;
    color: #074097;
    font-weight:bold;
    margin-bottom: 1rem;
}
.section-title02{
    font-size: clamp(20px, 2.8vw, 40px);
    font-weight: 700;
    color: ##000000;
    margin-bottom: 1rem;
}

.section-title01 span{
border-bottom: solid 2px #707070;
padding-bottom: 15px;
}

.section-subtitle { 
color: #000000; 
font-size: clamp(15px, 1.9vw, 20px);
font-weight:bold;
margin-top:50px;
}

.cost{
color:#D9843A;
}

/* グリッドシステム */
.grid-2 {
}

/* カード（Target） */
.card {
    display:flex;
    margin-bottom:30px;
}
.card-image {
    width:auto;
    margin-right:15px;

}
.card-image img{
    border: solid 3px #ffffff;
    box-shadow: 3px 3px 6px #00000080;
}

.card-content{
    align-content: center;
}

.icon-circle {
    width: 3rem; height: 3rem; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin-right: 1rem;
}
.icon-teal { background-color: #ccfbf1; color: #0d9488; }
.icon-blue { background-color: #dbeafe; color: #2563eb; }
.card-title { 
font-size: clamp(18px, 2vw, 30px);
font-weight: bold; 
margin: 0; 
color: #074097;
margin-bottom:30px;
}

.list-check { 
list-style: none; 
padding: 0;
 margin: 0; 
}
.list-check li { 
font-size: clamp(15px, 1.4vw, 20px);
margin-bottom: 0.75rem; 
position: 
relative; 
}
.list-teal li::before { color: #14b8a6; }
.list-blue li::before { color: #2563eb; }

/* Problem Section */
.problem-box {
    padding: 0 45px;
}
.text-red { color: #dc2626; }
.problem-lead { 
display: flex; 
align-items: flex-start; 
margin-bottom: 1rem; 
}
.problem-lead p{ 
margin: 0 
}

.icon-alert { 
color: #ef4444; 
margin-right: 1rem;
 flex-shrink: 0;
 }
.problem-conclusion { 
font-weight: 700; 
}
.chart-label { font-size: 0.875rem; color: #6b7280; margin-bottom: 0.5rem; }

.section-content{
display:flex;
}
.section-image {
}

.section-image img{
width: auto;
box-shadow: 2px 2px 10px #000000;

}

.problem-text{
font-size: clamp(15px, 1.9vw, 20px);
}

/* Plans Section */
#plans{
    background-color: #031D68;
    padding-top:60px;
}
#plans img{
width:auto;
box-shadow: 3px 3px 10px #000000;
}
#plans h2{
    font-size: clamp(20px, 2.8vw, 40px);
    margin:0;
}
#plans h2 span{
    border-bottom: 4px dashed #707070;
    padding-bottom:5px;
}

#plans h2 strong{
    color:#074097;
}

#plans h3{
font-size: clamp(20px, 2vw, 30px);
color:#000000;
}

#plans h3 span{
color:#ffffff;
background: #6CABFF 0% 0% no-repeat padding-box;
border-radius: 30px;
padding: 15px 38px;
}

#plans h3 strong{
font-size: clamp(15px, 1.6vw, 23px);
}


.plan-desc-sm{
font-size: clamp(20px, 1.6vw, 23px);
color:#04317B;
font-weight:bold;
text-align:center;
}

.plan-detail{
font-size: clamp(15px, 1.4vw, 20px);
}

#plans .section-header{
margin-bottom:15px;
}

.bg-white{
    background-color:#ffffff;
    border-radius:40px;
    box-shadow: inset 0px 3px 6px #000000;
    padding: 60px 90px;
}
#trust .bg-white{
    padding: 60px 150px;
}

.tab-controls { 
display: flex; 
justify-content: center;
 margin-bottom: 2.5rem; 
gap: 70px; 
}
.tab-button {
width:50%;
color: #FFFFFF;
font-size: clamp(20px, 1.6vw, 23px);
padding: 15px 60px;
border: 2px solid #FFFFFF;
border-radius: 17px;
box-shadow: 3px 3px 6px #000000DB;
cursor: pointer;
background: #707070 0% 0% no-repeat padding-box;
}
.tab-button.active {
background: #6CABFF 0% 0% no-repeat padding-box;
}

.tab-content { display: none; }
.tab-content.active { display: block; }

.grid-plan {
    display: grid;
    gap: 2rem;
}

.plan-main, .plan-side {
    background: #ffffff;
    border-radius: 1rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.plan-body { 

 }

.card-recommended {

}
.card-standard {
    border: 1px solid #e5e7eb;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

.plan-badge {
text-align: center; 
padding: 0.75rem 0;
font-size: clamp(18px, 1.6vw, 23px);
font-weight: bold; 
color: #000000;
}
.badge-gray { background-color: #6b7280; }

.plan-title-area {
text-align:center;
}
.plan-name { font-size: 1.875rem; font-weight: 700; margin: 0; }
.text-dark { color: #1f2937; }

.plan-tag {
    font-size: 0.75rem; padding: 0.25rem 0.75rem;
    border-radius: 9999px; font-weight: 700;
    border: 1px solid;
}
.tag-yellow { color: #d97706; background-color: #fefce8; border-color: #fef9c3; }

.recommend-box { 
display:flex;
padding: 1.25rem; 
border-radius: 0.5rem; 
justify-content: center;
    align-items: center;
 }
.box-gray { background-color: #f9fafb; border-color: #f3f4f6; }

.recommend-title { 
color:#FFFFFF;
font-weight: bold; 
font-size: clamp(20px, 1.7vw, 24px);
background: #6CABFF 0% 0% no-repeat padding-box;
border-radius: 14px;
padding: 25px 11px;
text-align: center;
}
.list-check-sm { 
list-style: none; 
padding: 0; 
margin: 0; 
font-size: clamp(14px, 1.4vw, 20px);
}
.list-check-sm li { 
padding-left: 1.25rem; 
position: relative;
}
.list-check-sm li::before { 
content: "●"; 
left: 0; 
color: #6CABFF;
 }
.box-gray li::before { color: #9ca3af; }

.plan-side { padding: 1.5rem; justify-content: center; }
.chart-title { 
text-align: center; 
font-size: 0.875rem; 
color: #6b7280;
 margin-bottom: 1.5rem; 
text-transform: uppercase; 
}
.chart-note { text-align: center; font-size: 0.75rem; color: #9ca3af; margin-top: 1.5rem; }
.dot-yellow { display: inline-block; width: 0.75rem; height: 0.75rem; background-color: #facc15; border-radius: 2px; }

/* Simulation */
#simulation{
background-color: #074097;
padding-top:60px;
}
#simulation h2{
font-size: clamp(20px, 2.8vw, 40px);
color: #000000;
}
#simulation h2 span{
border-bottom: 4px dashed #707070;
padding-bottom: 5px;
}

#simulation h2 strong{
color: #F78E33;
}


#simulation .grid-2{
display:grid;
}
#simulation .case-header{
background: #074097 0% 0% no-repeat padding-box;
border-radius: 17px 17px 0px 0px;
padding:15px;
}

#simulation .case-title{
font-size:22px;
color:#FFFFFF;
}

#simulation .case-desc{
font-size:16px;
color:#FFFFFF;
}
.case-card { padding: 1.5rem; display: flex; flex-direction: column; }
.case-tag { display: inline-block; padding: 0.25rem 0.75rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 700; margin-bottom: 0.5rem; }
.tag-teal-bg { background-color: #ccfbf1; color: #0f766e; }
.tag-blue-bg { background-color: #dbeafe; color: #2563eb; }
.case-title { font-size: 1.25rem; margin: 0 0 0.5rem; }
.case-desc { 
font-size: 0.875rem; 
color: #4b5563; 
margin-bottom: 0; }
.case-result { 
background-color: #f9fafb; 
padding: 1rem; border-radius: 0.75rem; 
border: 1px solid #f3f4f6; 
margin-bottom: 1rem; 
margin-top: 15px;
}
.result-row { display: flex; justify-content: space-between; align-items: flex-end; }
.border-bottom { border-bottom: 1px solid #e5e7eb; padding-bottom: 0.5rem; margin-bottom: 0.5rem; }
.result-value { font-weight: 800; font-size: 1.5rem; }
.unit { font-size: 0.875rem; font-weight: 400; color: #4b5563; margin-left: 2px; }

.case-footer { margin-top: auto; padding: 1rem; border-radius: 0 0.5rem 0.5rem 0; border-left-width: 4px; border-left-style: solid; }
.footer-yellow { background-color: #fefce8; border-left-color: #facc15; }
.footer-blue { background-color: #eff6ff; border-left-color: #60a5fa; }
.footer-title { font-size: 0.875rem; font-weight: 700; margin: 0 0 0.5rem; }
.footer-text { font-size: 0.75rem; margin: 0; }

/* Reason */
#trust{
background: #6494D4;
padding-top:60px;
}
#trust h2{
font-size: clamp(20px, 2.8vw, 40px);
color:#074097;
}

#trust h2 span{
border-bottom: 4px dashed #707070;
padding-bottom: 5px;
}

#trust h4{
font-size: clamp(20px, 1.7vw, 25px);
border-bottom: 4px dashed #707070;
}

#trust 
.reason-list { display: flex; flex-direction: column; gap: 4rem; }
.reason-item { display: flex; flex-direction: column; gap: 2rem; align-items: center; }
.reason-img-area { width: 100%; display: flex; justify-content: center; }

.icon-circle-lg { width: 6rem; height: 6rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.bg-teal-light { background-color: #ccfbf1; }
.bg-green-light { background-color: #dcfce7; }
.bg-yellow-light { background-color: #fef9c3; }

.reason-content { width: 100%; }

.reason-head { 
text-align:center;
 }

.reason-text{
font-size: clamp(15px, 1.4vw, 20px);
}
.eco{
font-size: clamp(14px, 1.4vw, 20px);
text-align:center;
}
.reason-number { 
font-size: clamp(45px, 4.9vw, 70px);
color: #6494D4;
font-weight: 700; 
opacity: 0.5; 
margin-right: 1rem; 
line-height: 1; 
}
.reason-heading { 
font-size: clamp(20px, 2vw, 30px);
font-weight: 700; 
color:#074097;
margin: 0; 
}

.info-box {
    display:flex;
}
.info-image{
margin-right:40px;
}
.info-grid { 
display: flex; 
grid-template-columns: 1fr; 
gap: 40px; 
font-size: clamp(14px, 1.4vw, 20px);
}

.info-label { font-weight: 700; color: #9ca3af; display: block; font-size: 0.75rem; }
.col-span-2 { grid-column: span 2; }

.badge-group { display: flex; gap: 1rem; flex-wrap: wrap; }
.badge { display: inline-flex; padding: 0.25rem 0.75rem; border-radius: 9999px; font-size: 0.875rem; font-weight: 500; border: 1px solid; }
.badge-green { background-color: #dcfce7; color: #15803d; border-color: #bbf7d0; }

.faq-item { 

}
.border-top { border-top: 1px solid #e5e7eb; margin-top: 1rem; padding-top: 1rem; }

.faq-q {
width: 100%;
display:flex;
align-items: center;
}
.q-person{
}
.q-bubble {
background-size: contain;
width: 100%;
display: flex;
background-image: url(image/fukidashi_1.png);
background-repeat: no-repeat;
background-position: center;
justify-content: center;
align-items: center;
}

.q-icon {
display:none;
margin-bottom: 10px;
}
.q-text {
font-weight: bold;
font-size: clamp(12px, 1.4vw, 20px);
margin: 0px 15px 15px 15px;
}

.q-text p{
margin: 45px 0px;
padding: 15px;
}

.a-text p{
margin: 45px 0px;
padding: 15px;

}


.faq-a {
width: 100%;
    display: flex;
    align-items: center;
}
.a-bubble {
background-size: contain;
    width: 100%;
    display: flex;
    background-image: url(image/fukidashi_2.png);
    background-repeat: no-repeat;
background-position: center;
justify-content: center;
align-items: center;
}
.a-text {
color:#ffffff;
font-weight: bold;
font-size: clamp(12px, 1.4vw, 20px);
margin: 0px 15px 15px 15px;
}


/* Flow */
#flow{

}
#flow h2{
    color: #074097;
font-size: clamp(25px, 2.8vw, 40px);
margin-bottom: 75px;
}

#flow h2 span{
background: #B5CFF2 0% 0% no-repeat padding-box;
box-shadow: 3px 3px 6px #00000029;
border-radius: 55px;
padding: 30px 45px;
}


.flow-wrapper { position: relative; }
.flow-line { 
display: block; 
position: absolute; 
top: 28px; 
left: 100px; 
width: 81%; 
height: 6px; 
background-color: #074097; 
z-index: 0; 
}

.flow-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; position: relative; z-index: 10; }

.flow-step { 
 text-align: center; }
.step-num {
width: 63px; 
height: 63px; 
background-color: #074097; 
color: white;
 display: flex; 
align-items: center; 
justify-content: center;
    font-weight: 700;
 margin: 0 auto 1rem; 
font-size: clamp(44px, 3.5vw, 50px);
border-radius: 12px;
}
.step-title { 
font-weight: 700;
color:#074097;
font-size: clamp(25px, 2vw, 30px);
margin: 0 0 0.5rem;
 }
.step-desc { 
font-size: clamp(16px, 1vw, 20px);
 color: #6b7280; 
margin: 0;
 }

/* CTA Form */
#cta-form{
    background-color: #031D68;
}
#cta-form .bg-white{
padding: 60px 200px;
}
.cta-title { 
color:#000000; 
font-size: clamp(20px, 2.5vw, 37px);
font-weight: 700; 
margin-bottom: 2rem; 
}
.cta-title span{ 
border-bottom: 4px dashed #707070;
padding-bottom: 15px;
}

.cta-title strong{ 
color:#D9843A; 
}
.cta-subtitle { 
color:#000000; 
font-size: clamp(15px, 1.4vw, 20px);
}
.cta-form {
    background-color: #ffffff;
    color: #1f2937;
    padding: 75px 150px;
    border-radius: 1rem;
    margin: 0 auto;
    text-align: left;
    box-shadow: 3px 3px 6px #00000080
}
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: 0.875rem; font-weight: 700; margin-bottom: 0.25rem; color: #4b5563; }


.tel{
display: none;
border-top: solid 1px;
border-bottom: solid 1px;
margin-top: 30px;
margin-bottom: 30px;
padding-bottom:30px;
}

.tel_title{

}

.tel_title h3{
font-size: clamp(24px, 2.1vw, 30px);
}

.tel_num{

}

.tel_num a{
text-decoration: none;
}


.tel_num p{
font-size: clamp(20px, 2.5vw, 36px);
font-weight: bold;
color: #074097;

}

.tel_num p strong{
font-size: clamp(18px, 1.6vw, 24px);
font-weight: bold;
color: #074097;

}


.tel_num span{

}


/* 必須バッジ */
.badge-required {
    display: inline-block;
    background-color: #ef4444;
    color: white;
    font-size: 0.7rem;
    padding: 0.1rem 0.4rem;
    border-radius: 0.2rem;
    margin-left: 0.5rem;
    vertical-align: middle;
}

/* inputとselectのデザイン */
.form-group input,
.form-group select {
    width: 100%; padding: 0.625rem 0.75rem;
    border: 1px solid #d1d5db; border-radius: 0.375rem;
    font-size: 1rem;
    color: #1f2937;
    background-color: #fff;
    box-sizing: border-box; /* 崩れ防止 */
    font-family: inherit; /* フォント継承 */
}
.form-group input:focus,
.form-group select:focus { outline: 2px solid #14b8a6; border-color: transparent; }

.form-submit { 
margin-top: 2rem; 
text-align: center; 
}

/* Footer */
.footer { 
background-color: #111827; 
color: #9ca3af; 
text-align: center; 
padding: 2rem 0; 
padding-bottom: 100px;
margin-bottom:-25px;

}

/* Utilities */
.sp-only { display: inline; }
.pc-only { display: none; }

/* Floating CTA */
.floating-cta {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #eab308;
    color: #111827;
    font-weight: 700;
    padding: 0.75rem 1.5rem;
    border-radius: 9999px;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
    display: flex; align-items: center; gap: 0.5rem;
    text-decoration: none;
    z-index: 100;
    transform: translateY(100px);
    opacity: 0;
    transition: all 0.3s;
    border: 2px solid #facc15;
}
.floating-cta.visible { transform: translateY(0); opacity: 1; }
.icon-arrow-up::before { content: "▼"; }


/* Chart Containers */
.chart-container { 
position: relative; 
width: 100%; 
text-align:center;
}
#simulation .chart-container img{ 
width: 100%; 
}
#simulation .chart-container { 

border: 3px solid #074097;
}
.chart-container-md { height: 250px; width: 100%; }
canvas { width: 100%; height: 100%; display: block; }

/* =========================================
   サンクスページ用 追加スタイル
   ========================================= */

/* サンクスページ全体のレイアウト調整 */
.thanks-page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
.thanks-page .footer {
    margin-top: auto;
}

/* メインセクション */
.thanks-section {
    background-color: #f9fafb; /* bg-gray-50 */
    padding: 6rem 0;
    flex: 1;
    display: flex;
    align-items: center;
}

/* コンテンツボックス */
.thanks-content {
    background-color: #ffffff;
    padding: 3rem 2rem;
    border-radius: 1rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

/* アイコン */
.thanks-icon {
    width: 80px;
    height: 80px;
    background-color: #ccfbf1; /* teal-100 */
    color: #0f766e; /* teal-700 */
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 2rem;
}

/* タイトル */
.thanks-title {
    font-size: 2rem;
    font-weight: 700;
    color: #111827; /* gray-900 */
    margin-bottom: 1.5rem;
    line-height: 1.3;
}

/* 本文 */
.thanks-text {
    font-size: 1rem;
    color: #4b5563; /* gray-600 */
    line-height: 1.8;
    margin-bottom: 3rem;
}

/* 注釈 */
.thanks-note {
    font-size: 0.875rem;
    color: #6b7280; /* gray-500 */
    background-color: #f9fafb;
    padding: 1rem;
    border-radius: 0.5rem;
    margin-bottom: 2rem;
    display: inline-block;
    text-align: left;
    line-height: 1.6;
}

/* ボタンエリア */
.thanks-btn-area {
    text-align: center;
    margin-top: 1rem;
}

/* ユーティリティ: テキスト中央寄せ */
.text-center {
    text-align: center;
}

#floating-cta{
display:none;
}

    /* SP */

@media (min-width: 768px) {
    .logo-sub { display: inline-block; }
    .mobile-menu-btn { display: none; }
    
    /* PCではフレックスボックスで表示 */
    .nav-menu { 
display: flex;
align-items: end;
gap: 35px; 
grid-area: bot-mid;
}

.estimate{
grid-area: right;
text-align: end;
}

#NewFixFooter {
display:none;
}




}


@media (max-width: 768px) {

.tel-box{
  display:none;
}

.floating-tel {
    position: fixed;
    bottom: 20px;
    left: 15px;
    background-color: #fff;
    color: #111827;
    font-weight: 700;
    padding: 10px 20px;
    text-decoration: none;
    z-index: 100;
    border: 2px solid #0098db;
    text-align: center;
    line-height: 0;
    border-radius: 15px;
}
.floating-tel p{
color:#074097;
}

#NewFixFooter {
        display: flex;
        margin: 0 auto;
        padding: 0;
        width: 100%;
        position: fixed;
        bottom: 0;
        z-index: 100;
        list-style: none;
    }

#NewFixFooter li.mail {
        background: #fa9309;
        width: 80%;
        margin: 0;
        padding: 0;
        text-align: center;
        color: #111;
        background: #0098db;
        font-size: 13px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

#NewFixFooter li a {
        color: #fff;
        text-decoration: none;
        display: flex;
        justify-content: center;
        padding: 6px 0;
        text-shadow: 0 -1px 0 #ccc;
        font-size: 18px;
        align-items: center;
        gap: 15px;
    }

#NewFixFooter li.mail a .mail-text {
        line-height: 28px;
    }

    #NewFixFooter li.call {
        background: #076aab;
        width: 20%;
    }


.estimate{
display:none;
}

}



@media (min-width: 768px) {
    .hero-highlight-row { display: inline; }
}

@media (min-width: 768px) { 
.grid-2 { 
grid-template-columns: 1fr 1fr;
} 
}

@media (min-width: 768px) { .reason-img-area { width: 33%; } }


@media (min-width: 768px) { .flow-grid { grid-template-columns: repeat(5, 1fr); } }

@media (min-width: 768px) {
    .sp-only { display: none; }
    .pc-only { display: inline; }

.btn {
    min-width: 238px;
}


}




@media screen and (max-width: 1439px) {

.mobile-menu-btn{
margin-right: 5px;
}

.logo-area {
margin-top: 5px;
}
.section {
    width: 100%;
    padding: 30px 15px;
}

.cta-form {
    padding: 30px;
}

#cta-form .bg-white {
    padding: 30px;
}

} 

@media screen and (max-width: 768px) {

.header-inner {

display: flex;
    justify-content: space-between;
    align-items: center;

}


.br-sp {
    display: block;
    }

.pc_only{
    display: none;
}

.tab-controls {
    display: block;
    text-align: center;
}
.tab-button {
    width:90%;
    margin-bottom:15px;
}

.bg-white {
    padding: 30px 15px;
}

.recommend-box {
    display: block;
}

#simulation{
    display: none;
}

#trust h4 {
    margin: 0;
}

#trust .bg-white {
    padding: 30px 15px;
}

#trust h2 span {
    border-bottom: none;
}

.info-box {
    display: block;
}

.info-image {
    text-align: center;
    margin-right: 0px;
}

.info-detail{
    padding: 15px 10px;
}

.info-grid{
    gap:15px;
}

.flow-line {
    top: 30px;
    left: 30px;
    width: 6px;
    height: 80%;
}

.step-num {
    margin: 0 ;
}

.flow-step {
    display: block;
    align-items: center;
}

.step-title {
    margin: 0;
    margin-top:-60px;
}

.section-title01 span {
    border-bottom: none;
}

.card{
    display:block;
}

.section-content {
    display:block;
}

.problem-box {
    padding: 0 ;
}

#plans h2 span {
    border-bottom: none;
    padding-bottom: 15px;
}

.tab-button {
padding: 15px 0px;
}

.recommend-box {
    padding: 0;
}

.cta-title span {
    border-bottom: none;
}

.btn-xl {
    padding: 0.75rem 2rem;
}

.faq-a {
display:block;
}

.faq-q {
width: 100%;
display:flex;
align-items: center;
flex-direction: column;
}
.q-person{
width: 100%;
text-align: justify;
order: 2;
}

.q-person img{
width: 25%;
}

.q-text p {
    margin: 30px 0px;
    padding: 15px;
}

.a-person{
text-align: end;
}

.a-person img{
width: 25%;
}


}