@charset "UTF-8";

@media print, screen and (max-width:1199px) {

#kvWrap {
position: relative;
width: 96vw;
height: 380px;
margin: 0 0 0 auto;
}

#kvWrapInner {
position: relative;
background-color: #fff;
width: 96vw;
height: 380px;
overflow: hidden;
border-radius: 40px 0 0 40px;
box-shadow: 10px 10px 0 var(--themeColor);
}

#kvWrapInner::after {
position: absolute;
background: rgba(0,0,0,.4);
width: 100vw;
height: 100vh;
content: "";
left: 0;
top: 0;
z-index: 11;
}

#kvCopy {
display: none;
}

#kvCopyWh {
position: absolute;
font-size: 2.8rem;
font-weight: 700;
color: #fff;
text-align: left;
display: block;
line-height: 1.3;
letter-spacing: 0;
z-index: 45;
top: 53%;
left: 8%;
transform: translateY(-53%);
}

#kvCopyWh span {
position: relative;
font-size: 1.1rem;
letter-spacing: 0;
top: -10px;
}

#scrollDown {
position: absolute;
width: 120px;
right: -40px;
bottom: -30px;
animation: 60s linear infinite rotation;
z-index: 20;
}

@keyframes rotation{
0% { transform: rotate(0); }
100% { transform: rotate(360deg); }
}

#arrowDown {
position: absolute;
width: 8px;
height: 8px;
margin: auto;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
transform: rotate(135deg);
z-index: 20;
right: 15px;
bottom: 30px;
}

#arrowDown::after {
position: absolute;
background-color: var(--themeColor);
width: 2px;
height: 80px;
content: "";
transform: rotate(-135deg);
right: 120px;
bottom: 60px;
}

#kvNews {
position: absolute;
background-color: var(--subColor);
width: 300px;
height: 60px;
font-size: 1.1rem;
font-weight: 700;
text-align: left;
z-index: 50;
display: flex;
justify-content: space-between;
align-items: center;
border-radius: 0 15px 15px 0;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--themeColor);
left: -10px;
top: 420px;
}

#whatsNew {
position: absolute;
background-color: var(--themeColor);
width: 54px;
height: 54px;
font-size: 1rem;
font-weight: 600;
color: #fff;
text-align: center;
border-radius: 60px;
line-height: 52px;
transform: rotate(-20deg);
letter-spacing: 0;
left: 12px;
top: -45px;
}

#ticker {
width: 88%;
text-align: justify;
margin: 0 auto;
padding: 0;
line-height: 1.5;
}

#ticker a {
color: var(--txtColor);
}

/**/

#bannerFlex {
width: 88%;
text-align: center;
margin: 0 auto;
margin-bottom: 20px;
}

.bannerTop {
width: 100%;
margin-bottom: 20px;
}

#bannerTop {
width: 88%;
margin: 0 auto;
}

.contentsTitleCe,
.contentsTitle,
.contentsTitleR {
position: relative;
font-size: 2.6rem;
font-weight: 600;
text-align: left;
color: var(--bearColor);
margin-bottom: 30px;
padding-top: 10px;
line-height: 1.3;
}

.contentsTitleCe::before,
.contentsTitle::before,
.contentsTitleR::before {
position: absolute;
background-color: var(--themeColor);
width: 40px;
height: 3px;
content: "";
margin: auto;
border-radius: 50px;
left: 0;
right: 0;
top: 0;
}

.contentsTitle::before {
margin: 0;
}

.contentsTitleCe {
text-align: center;
}

.contentsTitleR {
text-align: right;
}

.contentsTitleR::before {
margin: 0 0 0 auto;
}

#wrapReason {
width: 100%;
margin: 0 auto;
padding: 80px 0 60px;
}

.indexReasonFlex {
width: 88%;
margin: 0px auto;
margin-bottom: 30px;
}

.indexReasonPhoto {
width: 100%;
margin-bottom: 40px;
overflow: hidden;
border-radius: 30px;
box-shadow: 5px 5px 0 var(--themeColor);
}

.indexReasonPhoto img {
width: 100%;
}

.indexReasonTxt {
width: 100%;
text-align: justify;
}

.reasonTitleFlex {
display: flex;
justify-content: space-between;
}

.reasonTitleFlex .number {
position: relative;
background-color: var(--subColor);
font-family: var(--font-kodchasan);
width: 40px;
height: 40px;
font-size: 1.8rem;
font-weight: 600;
color: var(--themeColor);
text-align: center;
white-space: nowrap;
margin-right: 15px;
border-radius: 40px;
border: 2px solid var(--themeColor);
box-shadow: 3px 3px 0 var(--themeColor);
line-height: 34px;
}

.reasonTitle {
position: relative;
width: 82%;
font-size: 2rem;
font-weight: 700;
color: var(--bearColor);
margin-bottom: 20px;
line-height: 1.6;
top: -5px;
}

.reasonTitle span {
background:linear-gradient(transparent 60%, var(--themeColor) 60%);
}

.indexReasonTxt p {
margin-bottom: 0;
}

.wrapColor {
background-color: var(--subColor);
width: 100%;
}

.wrapColor2 {
background-color: #fff;
width: 100%;
}

.wrap {
width: 88%;
margin: 0 auto;
padding: 60px 0;
}

#pricePlanFlex  {
margin-bottom: 30px;
}

.pricePlan {
position: relative;
background-color: #fff;
width: 100%;
text-align: center;
margin-bottom: 30px;
padding: 0 0 30px;
overflow: hidden;
border-radius: 30px;
box-shadow: 8px 8px 0 var(--bearColor);
}

.pricePlan .triangle {
position: absolute;
background-color: #f7df5f;
width: 170px;
height: calc(100px / 2 * tan(60deg));
clip-path: polygon(50% 0, 100% 100%, 0 100%);
content: "";
text-align: center;
transform: rotate(45deg);
line-height: 1;
z-index: 1;
right: -80px;
top: -30px;
}

.pricePlan .triangle::after {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.1rem;
font-weight: 700;
content: "PLAN";
color: var(--bearColor);
margin: auto;
transform: rotate(0deg);
z-index: 2;
left: -10px;
right: 0;
bottom: 10px;
}

.pricePlan .pricePhoto {
position: absolute;
width: 200px;
height: 200px;
overflow: hidden;
margin: auto;
border-radius: 300px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--bearColor);
left: 0;
right: 0;
top: -75px;
}

.pricePlan .pricePhoto img {
width: 100%;
height: 200px;
object-fit: cover;
}

.pricePlan h3 {
background-color: var(--themeColor);
font-size: 1.8rem;
font-weight: 600;
color: #fff;
margin: 0 auto;
padding: 25px 0;
margin-bottom: 5px;
line-height: 1.3;
}

.pricePlan h3 span {
display: block;
}

.pricePlan h3 em {
font-size: 2.6rem;
display: block;
letter-spacing: 0;
}

.pricePlan .mark {
font-size: 1.4rem;
margin-bottom: 20px;
}

.pricePlan .price {
font-size: 1.8rem;
margin: 10px auto;
margin-bottom: 0;
line-height: 1.3;
}

.pricePlan .price span {
font-size: 4.2rem;
color: var(--themeColor);
}

.pricePlan .price em {
font-size: 2.6rem;
}

.pricePlan .priceTaxin {
font-size: 1.4rem;
margin-bottom: 20px;
line-height: 1;
}

.pricePlan .priceTaxin em {
font-size: 2rem;
}

.pricePlan .guarantee {
background-color: #f7df5f;
width: 210px;
font-size: 1.4rem;
color: var(--bearColor);
margin: 0 auto;
padding-bottom: 14px;
border-radius: 10px;
line-height: 1;
}

.pricePlan .guarantee span {
position: relative;
font-size: 2.6rem;
top: 4px;
}

/**/

#wrapWorks {
width: 100%;
text-align: left;
margin: 0 auto;
padding: 60px 25px;
overflow-x: hidden;
}

.wrapTitleFlex {
display: flex;
justify-content: space-between;
}

.btnR {
width: 88%;
text-align: center;
margin: 0 auto;
}

.btnL {
text-align: left;
}

#voiceFlex {
margin-top: 80px;
margin-bottom: -40px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.voice {
position: relative;
background-color: #fff;
width: 100%;
text-align: justify;
margin-bottom: 70px;
padding: 60px 25px 30px;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.wrapCo .voice {
background-color: var(--subColor);
}

.voice h3,
.voice h2 {
font-size: 1.8rem;
font-weight: 600;
color: var(--themeColor);
text-align: center;
margin-bottom: 15px;
line-height: 1.6;
}

.voice h3 span,
.voice h2 span {
font-size: 1.4rem;
display: block;
}

.voice .icon {
position: absolute;
width: 80px;
margin: auto;
border-radius: 80px;
left: 0;
right: 0;
top: -40px;
}

.voice .icon img {
border: 2px solid var(--themeColor);
border-radius: 120px;
box-shadow: 3px 3px 0 var(--bearColor);
}

.voice .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.6rem;
font-weight: 700;
text-align: center;
color: var(--themeColor);
margin: auto;
line-height: 1;
left: 0;
right: 0;
top: -53px;
}

.voice p {
margin-bottom: 0;
}

#constructionFlex {
margin-bottom: 30px;
}

.construction {
position: relative;
width: 100%;
margin-bottom: 30px;
}

.construction .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 5rem;
font-weight: 500;
color: #ccc;
line-height: 1;
z-index: 2;
left: 30px;
top: -25px;
}

.construction a {
color: var(--txtColor);
}

.construction .constructionPhoto {
overflow: hidden;
border-radius: 30px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.construction .constructionPhoto img {
width: 100%;
height: 220px;
object-fit: cover;
transition: .3s ease-in-out;
}

.construction h3 {
background-color: var(--bearColor);
width: 80%;
font-size: 1.5rem;
font-weight: 600;
text-align: center;
color: #fff;
margin: auto;
padding: 14px 10px 22px;
border-radius: 0 0 30px 30px;
border-left: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
border-bottom: 2px solid var(--themeColor);
z-index: 1;
line-height: 1.5;
}

.construction span {
font-size: 1.3rem;
display: block;
}

.freeWrap {
width: 88%;
margin: 0 auto;
}

#wrapBlog {
width: 100%;
text-align: left;
margin: 0 auto;
padding: 60px 0;
overflow-x: hidden;
}

.wrapBanner {
background-color: #f4f6f9;
width: 100%;
text-align: left;
margin: 0 auto;
padding: 60px 0;
}

#all-link-reformsBanner {
width: 88%;
margin: 0 auto;
}

#all-link-reformsBanner a {
position: relative;
width: 100%;
height: 100%;
display: block;
z-index: 3;
}

#all-link-reformsBanner h2 {
position: absolute;
background-color: #fff;
width: 150px;
margin: auto;
padding: 20px;
z-index: 2;
left: 0;
right: 0;
top: 0;
}

#all-link-reformsBannerTxt {
position: absolute;
font-size: 2rem;
text-align: center;
color: #fff;
padding-left: 20px;
white-space: nowrap;
top: 75%;
left: 50%;
transform: translateY(-75%)translateX(-50%);
}

#indexQaWrap {
position: relative;
width: 88%;
margin: 0 auto;
padding: 60px 0;
}

#qaR {
width: 100%;
text-align: left;
}

#qaL {
width: 100%;
text-align: justify;
margin-bottom: 40px;
}

.accordion {
width: 100%;
text-align: justify;
margin: 0 auto;
}

.accordion ul {
margin: 0 auto;
padding: 0;
}

.accordion li {
position: relative;
background-color: #fff;
width: 100%;
margin-bottom: 20px;
border: 1px solid #ddd;
box-shadow: 5px 5px 0 var(--themeColor);
border-radius: 15px;
transition: .3s;
}

.accordion li p:last-child {
margin-bottom: 0;
}

.accordion li h3 {
position: relative;
font-size: 1.3rem;
font-weight: 700;
color: var(--txtColor);
}

.accordion a {
position: relative;
color: var(--themeColor);
display: block;
text-decoration: none;
cursor: pointer;
padding: 10px 66px 18px 22px;
transition: .3s;
}

.accordion li .accordion_icon {
display: inline-block;
transition: all .3s;
box-sizing: border-box;
}

.accordion li .accordion_icon {
position: absolute;
width: 15px;
height: 15px;
margin: auto;
top: 14px;
bottom: 0;
right: 20px;
}

.accordion li .accordion_icon span {
position: absolute;
background-color: var(--themeColor);
width: 100%;
height: 2px;
transition: all .3s;
}

.accordion li .accordion_icon span:nth-of-type(1) {
transform: rotate(0deg);
}

.accordion li .accordion_icon span:nth-of-type(2) {
transform: rotate(90deg);
}

.accordion li .accordion_icon.active span:nth-of-type(1) {
display:none;
}

.accordion li .accordion_icon.active span:nth-of-type(2) {
transform: rotate(180deg);
}

.toggle dt {
float: left;
font-family: var(--font-kodchasan);
font-size: 2.2rem;
font-weight: 700;
padding: 5px 0;
line-height: 1.2;
}

.toggle dd {
padding: 7px 0 3px 34px;
}

.qaDetail {
color: var(--txtColor);
display: none;
padding: 0 24px 24px;
overflow: hidden;
}

.qaDetail dt {
float: left;
font-family: var(--font-kodchasan);
font-size: 2.2rem;
font-weight: 700;
color: var(--themeColor);
line-height: 1;
}

.qaDetail dd {
padding: 0 0 0 34px;
}

#wrapNews {
position: relative;
width: 88%;
margin: 0 auto;
padding: 60px 0;
}

#newsL {
width: 100%;
text-align: left;
}

#newsR {
width: 100%;
text-align: justify;
margin-bottom: 30px;
line-height: 1.6;
}

.news {
position: relative;
width: 100%;
display: block;
border-bottom: 1px dotted #ccc;
transition: .3s;
overflow: hidden;
}

.news:first-of-type {
border-top: 1px dotted #ccc;
}

.news::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
transform: rotate(45deg);
right: 15px;
top: 0;
bottom: 0;
transition: .3s;
}

.news a {
width: 100%;
padding: 20px 20px 20px 10px;
display: block;
}

.news dt {
font-family: var(--font-kodchasan);
font-weight: 600;
}

.news dd {
padding: 0 20px 0 0;
}

.news .triangle {
position: absolute;
background-color: var(--themeColor);
width: 150px;
height: calc(100px / 2 * tan(60deg));
clip-path: polygon(50% 0, 100% 100%, 0 100%);
content: "";
text-align: center;
transform: rotate(45deg);
line-height: 1;
z-index: 1;
right: -80px;
top: -50px;
}

.news .triangle::after {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1rem;
font-weight: 700;
content: "NEW";
color: #fff;
margin: auto;
transform: rotate(0deg);
z-index: 2;
left: 1px;
right: 0;
bottom: 4px;
}

/**/

#areaMap {
width: 100%;
margin: 20px auto;
}

#areaMap img {
border-radius: 20px;
}

/**/

#contactBottomWrap {
position: relative;
background: url("../img/contact_bottom_bg.webp") no-repeat center top;
background-size: cover;
width: 100%;
color: #fff;
margin: 0 auto;
padding: 30px 20px 30px;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

#contactBottomWrap::after {
position: absolute;
background: rgba(0,0,0,.3);
width: 100vw;
height: 100vh;
content: "";
left: 0;
top: 0;
}

#contactBottomWrap h3 {
position: relative;
font-size: 1.6rem;
font-weight: 600;
margin-bottom: 30px;
z-index: 2;
}

#contactBottomWrap h4 {
position: relative;
font-size: 1.4rem;
font-weight: 600;
margin-bottom: 10px;
z-index: 2;
}

#contactBottomFlex {
position: relative;
z-index: 2;
}

.contactBottomLr {
margin: 0 auto;
}

.btnContact {
background-color: var(--themeColor);
width: 100%;
height: 100px;
font-size: 1.8rem;
font-weight: 700;
color: #fff;
padding-bottom: 10px;
cursor: pointer;
border: 2px solid var(--themeColor);
border-radius: 100px;
transition: .3s;
}

.btnContact i {
position: relative;
font-size: 2.2rem;
margin-right: 5px;
top: 3px;
}

.btnCall {
background-color: #fff;
font-family: var(--font-kodchasan);
width: 100%;
height: 100px;
font-size: 2.6rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 20px;
padding-bottom: 10px;
cursor: pointer;
border: 2px solid var(--themeColor);
border-radius: 100px;
transition: .3s;
}

.btnCall i {
margin-right: 5px;
}

.btnCall span {
font-family: var(--font-primary);
font-size: 1.1rem;
display: block;
}

/**/

#titleWrap {
position: relative;
width: 100%;
height: 200px;
}

#titleWrap #contentsTitle {
position: absolute;
height: 82px;
width: 88%;
font-size: 2.6rem;
font-weight: 600;
text-align: left;
margin: auto;
padding-top: 10px;
line-height: 1.4;
z-index: 1;
left: 0;
right: 0;
top: 0;
bottom: 0;
}

#titleWrap #contentsTitle::before {
position: absolute;
background-color: var(--themeColor);
width: 40px;
height: 3px;
content: "";
margin: auto;
border-radius: 50px;
left: 0;
top: 0;
}

.ku {
margin-left: -4px;
}

#bgReason,
#bgPricePlan,
#bgWorks,
#bgVoice,
#bgConstruction,
#bgNews,
#bgFaq,
#bgBlog,
#bgCompany,
#bgContact,
#bgPrivacy {
width: 40%;
height: 200px;
margin: 0 0 0 auto;
border-radius: 30px 0 0 30px;
box-shadow: 10px 10px 0 var(--themeColor);
}

#bgReason {
background: url("../img/bg_reason.webp") no-repeat center;
background-size: cover;
}

#bgPricePlan {
background: url("../img/bg_price.webp") no-repeat center;
background-size: cover;
}

#bgWorks {
background: url("../img/bg_works.webp") no-repeat center;
background-size: cover;
}

#bgVoice {
background: url("../img/bg_voice.webp") no-repeat center;
background-size: cover;
}

#bgConstruction {
background: url("../img/bg_construction.webp") no-repeat center;
background-size: cover;
}

#bgNews {
background: url("../img/bg_news.webp") no-repeat center;
background-size: cover;
}

#bgFaq {
background: url("../img/bg_faq.webp") no-repeat center;
background-size: cover;
}

#bgBlog {
background: url("../img/bg_blog.webp") no-repeat center;
background-size: cover;
}

#bgCompany {
background: url("../img/bg_company.webp") no-repeat center;
background-size: cover;
}

#bgContact {
background: url("../img/bg_contact.webp") no-repeat center;
background-size: cover;
}

#bgPrivacy {
background: url("../img/bg_privacy.webp") no-repeat center;
background-size: cover;
}

#breadcrumb {
width: 88%;
font-size: 1rem;
margin: 0 auto;
margin-top: 30px;
text-align: justify;
}

.wrapNews {
width: 88%;
text-align: justify;
margin: 0 auto;
padding: 40px 0;
}

.wrapCo {
width: 88%;
text-align: justify;
margin: 0 auto;
padding: 40px 0 0;
}

/**/

.reasonPhoto {
width: 100%;
height: 220px;
overflow: hidden;
border-radius: 30px;
box-shadow: 10px 10px 0 var(--themeColor);
}

.reasonPhoto img {
width: 100%;
height: 220px;
object-fit: cover;
}

.reasonTxt {
position: relative;
background-color: #fff;
width: 90%;
margin: 0 auto;
margin-bottom: 30px;
margin-top: -40px;
padding: 30px 25px 10px;
border-radius: 30px;
z-index: 1;
}

.reasonTxt:last-child {
margin-bottom: 60px;
}

#stepFlex {
margin: 40px auto;
margin-bottom: 0;
display: flex;
justify-content: center;
flex-wrap: wrap;
align-items: center;
}

#start,
#goal {
position: relative;
background-color: var(--themeColor);
font-family: var(--font-kodchasan);
width: 125px;
height: 125px;
font-size: 2rem;
font-weight: 600;
color: #fff;
text-align: center;
margin-bottom: 40px;
display: table;
border-radius: 125px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--bearColor);
line-height: 1.3;
}

#goal {
font-family: var(--font-primary);
font-size: 1.8rem;
}

.step {
position: relative;
background-color: #fff;
width: 125px;
height: 125px;
font-size: 1.3rem;
font-weight: 600;
color: var(--bearColor);
text-align: center;
margin-bottom: 40px;
display: table;
border-radius: 120px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--themeColor);
line-height: 1.3;
}

.stepColor {
background-color: var(--bearColor);
color: #fff;
border: 2px solid var(--bearColor);
}

.stepOther {
position: relative;
background-color: #fff;
width: 115px;
height: 115px;
font-size: 1.1rem;
font-weight: 600;
color: var(--bearColor);
text-align: center;
margin-bottom: 40px;
display: table;
border-radius: 15px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--themeColor);
line-height: 1.5;
}

.stepOther i {
font-size: 1.8rem;
color: var(--themeColor);
margin-bottom: 10px;
}

#start .inner,
#goal .inner,
.step .inner,
.stepOther .inner {
display: table-cell;
vertical-align: middle;
}

.stepNumber {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.6rem;
font-weight: 700;
color: var(--themeColor);
line-height: 1;
left: 0;
right: 0;
top: -28px;
}

.stepNumber span {
font-size: 2.6rem;
font-weight: 600;
}

#stepFlex .stepAarrow {
position: relative;
width: 10px;
height: 10px;
margin: 0 10px;
border-top: 2px solid var(--bearColor);
border-right: 2px solid var(--bearColor);
transform: rotate(45deg);
top: -22px;
}

.warrantyFlex {
width: 100%;
margin: 0 auto;
margin-bottom: 40px;
display: flex;
justify-content: space-between;
}

.warrantyFlex:last-child {
margin-bottom: 0;
}

.warrantyL {
width: 35%;
}

.warrantyR {
width: 60%;
text-align: justify;
}

.warrantyR h3 {
font-size: 1.4rem;
font-weight: 600;
color: var(--bearColor);
margin-bottom: 10px;
}

.warrantyEtcFlex {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.warrantyEtc {
width: 45%;
text-align: justify;
margin: 0 auto;
margin-bottom: 20px;
}

.warrantyEtc:nth-of-type(7),
.warrantyEtc:nth-of-type(8) {
margin-bottom: 0;
}

.warrantyEtc h3 {
font-weight: 600;
text-align: center;
margin: 15px auto;
margin-bottom: 10px;
}

#warrantyOther {
width: auto;
text-align: left;
display: table;
margin: 0 auto;
margin-top: 0px;
}

/**/

.pricePlanCo {
position: relative;
background-color: #fff;
width: 100%;
text-align: center;
margin-bottom: 30px;
padding: 0 0 25px;
overflow: hidden;
border-radius: 30px;
box-shadow: 8px 8px 0 var(--bearColor);
}

.pricePlanCo .triangle {
position: absolute;
background-color: #f7df5f;
width: 170px;
height: calc(100px / 2 * tan(60deg));
clip-path: polygon(50% 0, 100% 100%, 0 100%);
content: "";
text-align: center;
transform: rotate(45deg);
line-height: 1;
z-index: 1;
right: -80px;
top: -30px;
}

.pricePlanCo .triangle::after {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.1rem;
font-weight: 700;
content: "PLAN";
color: var(--bearColor);
margin: auto;
transform: rotate(0deg);
z-index: 2;
left: -10px;
right: 0;
bottom: 10px;
}

.pricePlanCo .pricePhoto {
position: absolute;
width: 200px;
height: 200px;
overflow: hidden;
margin: auto;
border-radius: 300px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--bearColor);
left: 0;
right: 0;
top: -75px;
}

.pricePlanCo .pricePhoto img {
width: 100%;
height: 200px;
object-fit: cover;
}

.pricePlanCo h3 {
background-color: var(--themeColor);
font-size: 1.8rem;
font-weight: 600;
color: #fff;
margin: 0 auto;
padding: 25px 0;
line-height: 1.3;
}

.pricePlanCo h3 span {
font-size: 1.8rem;
display: block;
}

.pricePlanCo h3 em {
font-size: 2.6rem;
display: block;
letter-spacing: 0;
}

.pricePlanPhotoFlex {
display: flex;
justify-content: space-between;
}

.pricePlanPhoto {
width: 350%;
}

.pricePlanCo .mark {
font-size: 1.4rem;
margin-bottom: 20px;
}

.pricePlanCo .price {
font-size: 1.8rem;
margin: 10px auto;
margin-bottom: 0;
line-height: 1.3;
}

.pricePlanCo .price span {
font-size: 4.2rem;
color: var(--themeColor);
}

.pricePlanCo .price em {
font-size: 2.6rem;
}

.pricePlanCo .priceTaxin {
font-size: 1.4rem;
margin-bottom: 20px;
line-height: 1;
}

.pricePlanCo .priceTaxin em {
font-size: 2rem;
}

.pricePlanCo .guarantee {
background-color: #f7df5f;
width: 210px;
font-size: 1.4rem;
color: var(--bearColor);
margin: 0 auto;
padding-bottom: 14px;
border-radius: 10px;
line-height: 1;
}

.pricePlanCo .guarantee span {
position: relative;
font-size: 2.6rem;
top: 4px;
}

.pricePlanCoTxt {
text-align: justify;
margin-top: 30px;
padding: 0 30px;
}

/**/

#blogNav {
margin-bottom: 20px;
border-bottom: 2px solid var(--themeColor);
}

#blogNav ul {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

#blogNav ul li {
background-color: #fff;
width: 49%;
text-align: center;
border-left: 2px solid var(--themeColor);
border-top: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
border-radius: 20px 20px 0 0;
}

#blogNav ul li a {
width: 100%;
height: 100%;
font-weight: 600;
color: var(--themeColor);
padding: 10px;
display: block;
transition: .3s;
}

/**/

#worksFlex {
}

.works {
position: relative;
width: 100%;
font-size: 1.2rem;
text-align: justify;
margin-bottom: 30px;
padding-right: 8px;
overflow: hidden;
border-radius: 30px;
line-height: 1.7;
}

.works:nth-of-type(3n) {
margin-right: 0;
}

.works a {
color: var(--txtColor);
display: block;
}

.works a:hover {
color: var(--themeColor);
text-decoration: none;
}

.works .worksPhoto {
position: relative;
width: 100%;
height: 240px;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.works .worksPhoto img {
width: 100%;
height: 240px;
object-fit: cover;
transition: .3s ease-in-out;
}

.works .worksPhoto:hover img,
.works .inner:hover .worksPhoto img {
transform: scale(1.1);
}

.works .triangle,
.blogCo .triangle {
position: absolute;
background-color: var(--themeColor);
width: 150px;
height: calc(100px / 2 * tan(60deg));
clip-path: polygon(50% 0, 100% 100%, 0 100%);
content: "";
text-align: center;
transform: rotate(45deg);
line-height: 1;
z-index: 1;
right: -70px;
top: -40px;
}

.works .triangle::after,
.blogCo .triangle::after {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.1rem;
font-weight: 700;
content: "NEW";
color: #fff;
margin: auto;
transform: rotate(0deg);
z-index: 2;
left: 0;
right: 0;
bottom: 10px;
}

.blogCo .category {
position: absolute;
background-color: var(--bearColor);
min-width: 120px;
height: 28px;
font-size: 1.1rem;
font-weight: 600;
color: #fff;
text-align: center;
padding: 0 17px;
border-radius: 0 10px 0 0;
line-height: 26px;
z-index: 1;
left: 0;
bottom: 0;
}

.works .inner {
position: relative;
background: #fff;
width: 92%;
margin-top: -30px;
padding: 20px 20px 26px 26px;
border-radius: 0 5px 5px 30px;
transition: .3s;
z-index: 1;
border-left: 2px solid var(--themeColor);
border-bottom: 2px solid var(--themeColor);
}

.works .inner:hover {
background-color: var(--themeColor);
color: #fff;
}

.works .inner h3 {
font-size: 1.3rem;
font-weight: 700;
margin-bottom: 10px;
line-height: 1.5;
}

.works .inner:hover h3 {
color: #fff;
}

.works p {
margin-bottom: 10px;
}

.slide .worksAfter,
.works .worksAfter {
position: absolute;
background-color: var(--bearColor);
font-family: var(--font-kodchasan);
width: 60px;
height: 60px;
font-size: 1.2rem;
font-weight: 700;
text-align: center;
color: #fff;
border-radius: 60px;
line-height: 58px;
z-index: 1;
left: 20px;
top: 100px;
}

.works .worksAfter {
top: 160px;
}

#postFlex {
width: 100%;
text-align: justify;
margin: 0 auto;
}

.post {
position: relative;
width: 100%;
text-align: justify;
color: var(--txtColor);
margin-bottom: 60px;
}

.post a {
color: #2271b1;
text-decoration: underline;
}

.beforeAfterFlex {
position: relative;
width: 100%;
}

.beforeAfterWrap {
position: relative;
width: 100%;
}

.beforeAfter {
width: 100%;
height: 230px;
margin-bottom: 30px;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.beforeAfter img {
width: 100%;
height: 230px;
object-fit: cover;
}

.beforeAfterWrap .worksBefore {
position: absolute;
background-color: #fff;
font-family: var(--font-kodchasan);
width: 60px;
height: 60px;
font-size: 1.1rem;
font-weight: 700;
text-align: center;
color: var(--bearColor);
border-radius: 60px;
border: 1px solid var(--bearColor);
line-height: 58px;
z-index: 1;
left: -10px;
top: -10px;
}

.beforeAfterWrap .worksAfter {
position: absolute;
background-color: var(--bearColor);
font-family: var(--font-kodchasan);
width: 60px;
height: 60px;
font-size: 1.1rem;
font-weight: 700;
text-align: center;
color: #fff;
border-radius: 60px;
border: 1px solid var(--bearColor);
line-height: 58px;
z-index: 1;
right: -10px;
top: -10px;
}

.beforeAfterFlex .arrow {
position: absolute;
width: 30px;
margin: auto;
z-index: 1;
top: 52%;
left: 50%;
transform: translateY(-50%)translateX(-52%);
}

.worksDetail {
margin: 50px auto;
border-top: 1px dotted #ccc
}

.worksDetail dt {
float: left;
font-weight: 700;
color: var(--themeColor);
padding: 20px 0;
}

.worksDetail  dd {
padding: 20px 0 20px 80px;
border-bottom: 1px dotted #ccc
}

.stateFlex {
}

.stateWrap {
width: 100%;
margin-bottom: 30px;
}

.stateWrap div {
width: 100%;
height: 230px;
margin-bottom: 20px;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.stateWrap div img {
width: 100%;
height: 230px;
object-fit: cover;
}

.postSide {
width: 100%;
}

.postSide h3 {
position: relative;
font-size: 1.3rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 20px;
padding-bottom: 5px;
border-bottom: 1px solid #ddd;
}

.postSide ul {
margin-bottom: 40px;
}

.postSide li {
font-size: 1.3rem;
list-style: none;
}

.postTagList {
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
}

.postTagList li {
background-color: #ddd;
width: auto;
height: 20px;
font-size: 1.2rem;
display: inline-block;
margin: 0 5px 5px 0;
padding: 0 8px;
line-height: 18px;
}

.rankingFlex {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.worksSideRankingWrap,
.blogSideRankingWrap {
position: relative;
width: 47%;
margin-bottom: 20px;
}

.worksSideRankingWrap .number,
.blogSideRankingWrap .number {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.4rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 10px;
line-height: 1;
}

.worksSideRanking {
position: relative;
background-color: #fff;
width: 100%;
}

.worksSideRanking a {
color: var(--txtColor);
text-decoration: none;
}

.worksSideRanking .worksPhoto {
position: relative;
width: 100%;
height: 120px;
overflow: hidden;
border-radius: 20px;
box-shadow: 5px 5px 0 var(--themeColor);
}

.worksSideRanking .worksPhoto img {
width: 100%;
height: 120px;
object-fit: cover;
transition: .3s ease-in-out;
}

.worksSideRanking .inner {
position: relative;
background: #fff;
width: 92%;
font-size: 1.1rem;
margin-top: -20px;
padding: 15px 15px 16px 16px;
border-radius: 0 5px 5px 20px;
transition: .3s;
z-index: 1;
border-left: 2px solid var(--themeColor);
border-bottom: 2px solid var(--themeColor);
}

.worksSideRanking h4 {
font-size: 1.2rem;
font-weight: 700;
color: var(--txtColor);
margin-bottom: 5px;
line-height: 1.5;
transition: .3s;
}

.blogSideRankingWrap .blogCo {
width: 100%;
margin-bottom: 0;
box-shadow: 5px 5px 0 var(--themeColor);
border-radius: 17px;
}

.blogSideRankingWrap .blogPhoto {
width: 100%;
height: 120px !important;
overflow: hidden;
border-radius: 0 !important;
}

.blogSideRankingWrap .blogPhoto img {
width: 100%;
height: 120px !important;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogSideRankingWrap .blogCo .inner {
font-size: 1.2rem;
font-weight: 700;
line-height: 1.5;
padding: 15px 20px 18px;
}

#relatedArticlesPost {
width: 100%;
margin-bottom: 40px;
}

#relatedArticlesPost a {
color: var(--txtColor);
text-decoration: none;
}

#relatedArticlesPost .works {
position: relative;
width: 100%;
}

#relatedArticlesPost .works .worksPhoto {
position: relative;
width: 100%;
height: 230px;
overflow: hidden;
}

#relatedArticlesPost .works .worksPhoto img {
width: 100%;
height: 230px;
object-fit: cover;
}

#relatedArticlesPost .works .inner {
position: relative;
width: 90%;
font-size: 1.2rem;
text-align: left;
margin-top: -20px;
padding: 18px 20px;
z-index: 1;
}

#relatedArticlesPost .works h3 {
font-size: 1.3rem;
font-weight: 700;
color: var(--txtColor);
margin-top: 0;
margin-bottom: 5px;
padding-left: 0;
border-left: 0;
}

#relatedArticlesPost .blogCo .inner  h3 {
font-size: 1.3rem;
margin-top: 0;
margin-bottom: 5px;
padding-left: 0;
border-left: 0;
}

/**/

#postTitle {
position: relative;
font-size: 2.2rem;
font-weight: 700;
margin-bottom: 40px;
padding-bottom: 25px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

#postTitle::before {
position: absolute;
background-color: var(--themeColor);
width: 100px;
height: 2px;
content: "";
left: 0;
bottom: 0;
z-index: 1;
}

#postDate {
font-family: var(--font-kodchasan);
font-weight: 700;
color: var(--themeColor);
margin-bottom: 40px;
}

.postBlogThumbnail {
margin-bottom: 30px;
}

.post h2 {
font-size: 2rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 20px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h3 {
font-size: 1.8rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 20px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h4 {
font-size: 1.6rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 20px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h5 {
font-size: 1.4rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 20px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post ol {
list-style: decimal;
padding-inline-start: 20px;
margin-bottom: 32px;
}

.post ul {
list-style: disc;
padding-inline-start: 20px;
margin-bottom: 32px;
}

#supervisorWrap {
background-color: var(--subColor);
width: 100%;
margin: 30px auto;
padding: 20px;
border-radius: 20px;
display: flex;
justify-content: space-between;
align-items: center;
}

#supervisorPhotoWrap {
position: relative;
width: 100px;
}

#supervisorPhoto {
width: 100px;
height: 100px;
overflow: hidden;
border-radius: 100px;
}

#supervisorPhoto img {
width: 100%;
height: 100px;
object-fit: cover;
}

#supervisorPlate {
position: absolute;
background-color: var(--themeColor);
width: 90%;
height: 28px;
color: #fff;
font-size: 1.2rem;
font-weight: 600;
text-align: center;
margin: 0 auto;
border-radius: 100px;
line-height: 26px;
z-index: 1;
left: 0;
right: 0;
bottom: 0;
}

#supervisorTxt {
width: 70%;
padding-left: 15px;
}

#supervisorName {
font-size: 1.5rem;
font-weight: 600;
}

#toc_container {
background-color: var(--subColor);
width: 100%;
margin: 40px auto;
margin-top: 40px;
padding: 20px 26px 26px;
border-radius: 20px;
}

.toc_title {
font-size: 1.6rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 20px;
padding-bottom: 10px;
border-bottom: 1px solid #ddd;
}

.toc_title::before {
content: '\f03a';
font-family: "Font Awesome 6 Free";
font-wigth: 400;
margin-right: 5px;
}

.toc_list,
.toc_list ul {
margin: 0 !important;
padding-inline-start: 5px !important;
list-style: none !important;
}

.toc_list li {
font-size: 1.3rem;
}

.toc_list li a {
color: var(--txtColor);
text-decoration: none;
}

.toc_list li::before {
content: "- ";
}

.toc_list li ul li {
font-size: 1.2rem;
margin-left: 15px;
}

.mediaWrap {
width: 100%;
color: var(--themeColor);
text-align: center;
margin: 80px auto;
margin-top: 60px;
}

.mediaWrap i {
font-size: 2.6rem;
color: var(--themeColor);
margin: 0 5px;
}

#prevNextWrap {
display: flex;
justify-content: space-between;
align-items: center;
}

#prevNextWrap a {
text-decoration: none;
}

.btnBackToList {
background-color: #fff;
font-family: var(--font-primary);
width: 120px;
height: 50px;
font-size: 1.3rem;
font-weight: 600;
color: var(--themeColor);
cursor: pointer;
padding-bottom: 3px;
border: 2px solid var(--themeColor);
border-radius: 100px;
transition: .3s;
}

.btnPrevWrap,
.btnNextWrap {
width: 150px;
}

.btnPrev,
.btnNext {
position: relative;
background: transparent;
width: 110px;
height: 25px;
font-size: 0;
font-weight: 700;
text-align: left;
text-indent: -1000px;
color: var(--themeColor);
border: none;
cursor: pointer;
line-height: 23px;
}

.btnPrev {
text-align: right;
}

.btnPrev::after {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid var(--themeColor);
border-left: 2px solid var(--themeColor);
transform: rotate(-45deg);
left: 5px;
top: 0;
bottom: 0;
transition: .5s;
}

.btnNext::after {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
transform: rotate(45deg);
z-index: 10;
right: 5px;
top: 0;
bottom: 0;
transition: .5s;
}

.wp-block-image {
margin-bottom: 30px;
}

/**/

#wrapConstructionCo {
width: 88%;
margin: 0 auto;
padding: 50px 0 30px;
}

.constructionCo {
position: relative;
width: 100%;
}

.constructionCo .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 5rem;
font-weight: 500;
color: #ccc;
line-height: 1;
z-index: 2;
left: 30px;
top: -25px;
}

.constructionCo .constructionPhoto {
overflow: hidden;
border-radius: 30px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.constructionCo .constructionPhoto img {
width: 100%;
height: 220px;
object-fit: cover;
}

.constructionCoTitle {
background-color: var(--bearColor);
width: 80%;
font-size: 1.5rem;
font-weight: 600;
text-align: center;
color: #fff;
margin: 0 auto;
margin-bottom: 30px;
padding: 14px 10px 22px;
border-radius: 0 0 30px 30px;
border-left: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
border-bottom: 2px solid var(--themeColor);
z-index: 1;
line-height: 1.5;
}

.constructionCoTitle span {
font-size: 1.3rem;
display: block;
}

/**/

#wrapFaqCo {
width: 100%;
margin: 0 auto;
}

#wrapFaqCo .accordion li {
background-color: var(--subColor);
}

/**/

.blogCo {
position: relative;
background-color: #fff;
width: 100%;
font-size: 1.3rem;
margin: 0 auto;
margin-bottom: 30px;
overflow: hidden;
border-radius: 30px;
box-shadow: 8px 8px 0 var(--themeColor);
line-height: 1.7;
}

.blogCo .blogPhoto {
position: relative;
width: 100%;
height: 210px;
overflow: hidden;
border-radius: 20px 20px 0 0;
}

.blogCo .blogPhoto img {
width: 100%;
height: 210px;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogCo .inner {
background-color: #fff;
text-align: justify;
padding: 20px 24px;
}

.blogCo .inner h3 {
font-size: 1.3rem;
font-weight: 700;
margin-bottom: 10px;
}

.blogCo .inner p {
margin-bottom: 10px;
}

.blogCo .inner .postDate {
font-family: var(--font-kodchasan);
font-weight: 600;
font-size: 1.2rem;
}

/**/

.pageNavi {
margin: 0 auto;
margin-top: 40px;
}

.wp-pagenavi {
position: relative;
font-size: 1.2rem;
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
line-height: 30px;
}

.wp-pagenavi .pages {
display: none;
}

.wp-pagenavi .page {
margin: 0 3px;
}

.wp-pagenavi .current {
background-color: var(--themeColor);
width: 35px;
height: 35px;
color: #fff;
margin: 0 3px;
display: block;
border: 1px solid var(--themeColor) !important;
}

.wp-pagenavi a,
.wp-pagenavi .extend {
width: 35px;
height: 35px;
display: block;
border: 1px solid var(--themeColor) !important;
}
.wp-pagenavi .first,
.wp-pagenavi .last {
display: none;
}

.wp-pagenavi a:hover {
background-color: var(--themeColor);
color: #fff;
}

.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
position: relative;
font-size: 0;
text-indent: -1000px;
border: 0 !important;
}

.wp-pagenavi a:hover.previouspostslink,
.wp-pagenavi a:hover.nextpostslink {
background-color: #fff;
}

.wp-pagenavi .previouspostslink::after {
position: absolute;
width: 12px;
height: 12px;
content: "";
margin: auto;
border-top: 1px solid var(--themeColor);
border-left: 1px solid var(--themeColor);
transform: rotate(-45deg);
left: 0;
right: 0;
top: 0;
bottom: 0;
}

.wp-pagenavi .nextpostslink::after {
position: absolute;
width: 12px;
height: 12px;
content: "";
margin: auto;
border-top: 1px solid var(--themeColor);
border-right: 1px solid var(--themeColor);
transform: rotate(45deg);
left: 0;
right: 0;
top: 0;
bottom: 0;
}

/**/

.btn {
position: relative;
background-color: var(--themeColor);
width: 88%;
height: 60px;
font-size: 1.4rem;
font-weight: 700;
color: #fff;
padding-bottom: 3px;
cursor: pointer;
border: 2px solid var(--themeColor);
border-radius: 100px;
transition: .3s;
}

.btn::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
transform: rotate(45deg);
transition: .3s;
right: 20px;
top: -2px;
bottom: 0;
}

.btnWh {
position: relative;
background-color: #fff;
width: 70%;
height: 55px;
font-size: 1.3rem;
font-weight: 700;
color: var(--themeColor);
margin-top: 20px;
padding-bottom: 3px;
cursor: pointer;
border: 2px solid var(--themeColor);
border-radius: 100px;
transition: .3s;
}

.btnWh::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid var(--themeColor);
border-right: 2px solid var(--themeColor);
transform: rotate(45deg);
transition: .3s;
right: 20px;
top: -2px;
bottom: 0;
}

/**/

#messageFlex {
width: 100%;
margin: 0 auto;
margin-bottom: 60px;
}

#message {
width: 100%;;
text-align: justify;
}

#messagePhoto {
width: 100%;
height: 230px;
margin-bottom: 40px;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

#messagePhoto img {
width: 100%;
height: 230px;
object-fit: cover;
}

#representative {
width: 215px;
text-align: right;
margin: 0 0 0 auto;
line-height: 1.5;
}

#representative img {
margin-bottom: 15px;
}

#representative span {
font-size: 1.7rem;
}

.outline {
width: 100%;
text-align: left;
margin: 0 auto;
margin-bottom: 50px;
border-top: 1px dotted #ccc;
}

.outline dt {
font-weight: 600;
padding: 20px 0 0;
}

.outline dd {
position: relative;
padding: 0 0 20px;
border-bottom: 1px dotted #ccc;
}

.outline dd::before {
position: absolute;
background-color: var(--themeColor);
width: 70px;
height: 2px;
content: "";
left: 0;
bottom: 0;
}

.googleMap {
position: relative;
width: 100%;
height: 0;
margin: 0 auto;
margin-bottom: 10px;
margin-top: 40px;
padding-top: 90%;
overflow: hidden;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.googleMap iframe {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

#groupCompanyFlex {
background-color: #fff;
width: 100%;
margin-bottom: -50px;
padding: 40px 30px 10px;
border-radius: 20px;
box-shadow: 8px 8px 0 var(--themeColor);
}

.groupCompany {
width: 100%;
font-size: 1.2rem;
margin: 0 auto;
margin-bottom: 30px;
}

.groupLogo {
width: 160px;
margin: 0 auto;
margin-bottom: 10px;
}

.groupCompany span {
display: block;
}

/**/

#wrapContact {
width: 88%;
text-align: justify;
margin: 0 auto;
padding: 40px 0 60px;
}

.contactSubTitle {
position: relative;
font-size: 2rem;
font-weight: 600;
color: var(--bearColor);
margin-bottom: 30px;
padding-bottom: 12px;
border-bottom: 1px solid #ccc;
}

.contactSubTitle::after {
position: absolute;
background-color: var(--themeColor);
width: 130px;
height: 2px;
content: "";
left: 0;
bottom: 0;
}

#stepFlexContact {
margin: 50px auto;
}

#stepFlexContact .stepAarrow {
position: relative;
width: 10px;
height: 10px;
margin: 0 auto;
margin-bottom: 40px;
border-right: 2px solid var(--bearColor);
border-bottom: 2px solid var(--bearColor);
transform: rotate(45deg);
}

.stepContact {
position: relative;
background-color: #fff;
width: 100%;
font-size: 1.6rem;
font-weight: 600;
color: var(--bearColor);
text-align: center;
margin-bottom: 20px;
display: table;
border-radius: 20px;
border: 2px solid var(--themeColor);
box-shadow: 5px 5px 0 var(--bearColor);
line-height: 1.5;
}

.stepContactTitle {
background-color: var(--themeColor);
border-radius: 17px 17px 0 0;
width: 100%;
height: 60px;
font-size: 1.9rem;
color: #fff;
display: table;
line-height: 1.4;
}

.stepContact h3 {
display: table-cell;
vertical-align: middle;
}

.stepContact .inner {
font-size: 1.3rem;
font-weight: 500;
text-align: justify;
padding: 20px 22px;
line-height: 1.7;
}

.stepContact .inner dt {
float: left;
color: var(--themeColor);
}

.stepContact .inner dd {
padding: 0 0 0 16px;
}

.stepContact .inner dd span {
border-bottom: 1px solid #ee0003;
}

.contactCallWrap {
position: relative;
background-color: var(--subColor);
font-family: var(--font-kodchasan);
width: 100%;
font-size: 3rem;
font-weight: 600;
color: var(--themeColor);
text-align: center;
margin: 30px auto;
margin-bottom: 40px;
padding: 30px 10px 35px;
border-radius: 20px;
box-shadow: 5px 5px 0 var(--themeColor);
line-height: 1.2;
}

.contactCallWrap a {
color: var(--themeColor);
}

.contactCallWrap .manager {
font-family: var(--font-primary);
font-size: 1.1rem;
line-height: 1.7;
}

.contactTxt {
text-align: center;
margin-bottom: 30px;
}

.contactFlex {
width: 100%;
color: var(--txtColor);
padding: 20px 0;
border-top: 1px dotted #ccc;
}

.contactFlex p {
margin-bottom: 0;
}

.contactL {
width: 100%;
margin-bottom: 10px;
}

.contactR {
width: 100%;
text-align: left;
}

.contactR .inputW {
background-color: #f2f2f2;
font-family: var(--font-primary);
width: 100%;
height: 60px;
font-size: 1.3rem;
padding: 15px;
border: 1px solid #f2f2f2;
border-radius: 10px;
}

.contactR input {
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
}

.contactR textarea {
background-color: #f2f2f2;
font-family: var(--font-primary);
width: 100%;
height: 200px;
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
border: 1px solid #f2f2f2;
border-radius: 10px;
}

.required,
.any {
position: relative;
background-color: #DA2124;
width: 40px;
height: 20px;
font-size: 1rem;
font-weight: 600;
color: #fff;
text-align: center;
display: inline-block;
margin-right: 7px;
border-radius: 300px;
line-height: 19px;
top: -1px;
}

.any {
background-color: #ccc;
}

.formSelect {
position: relative;
}

.formSelect select {
position: relative;
background-color: #f2f2f2;
font-family: var(--font-primary);
width: 100%;
height: 60px;
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
border: 1px solid #f2f2f2;
border-radius: 10px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

.formSelect::after {
position: absolute;
width: 10px;
height: 10px;
content: "";
border-right: 1px solid var(--themeColor);
border-bottom: 1px solid var(--themeColor);
margin: auto;
transform: rotate(45deg);
z-index: 1;
top: -8px;
bottom: 0;
right: 20px;
}

.contactR .checkWrap input[type="checkbox"] {
margin: 0;
padding: 0 0 0 18px;
background: none;
border: none;
border-radius: 0;
outline: none;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

.contactR .checkWrap .wpcf7-list-item {
display: inline-block;
}

.contactR .checkWrap .wpcf7-list-item label {
position: relative;
display: flex;
align-items: center;
cursor: pointer;
left: -12px;
}

.wpcf7-list-item-label {
margin-left: -10px;
}

.contactR .checkWrap .wpcf7-list-item label::before,
.contactR .checkWrap .wpcf7-list-item label:has(:checked)::after {
content: '';
}

.contactR .checkWrap .wpcf7-list-item label::before {
position: relative;
background-color: #fff;
width: 20px;
height: 20px;
border-radius: 3px;
border: 1px solid var(--themeColor);
top: 1px;
}

.contactR .checkWrap .wpcf7-list-item label:has(:checked)::before {
background-color: var(--themeColor);
}

.contactR .checkWrap .wpcf7-list-item label:has(:checked)::after {
position: absolute;
top: 6px;
left: 6px;
transform: rotate(45deg);
width: 8px;
height: 12px;
border: solid #fff;
border-width: 0 2px 2px 0;
}

.submitWrap {
position: relative;
width: 100%;
text-align: center;
margin: 0 auto;
margin-bottom: 10px;
padding-top: 30px;
border-top: 1px dotted #ccc;
}

.wpcf7-submit {
background-color: var(--themeColor);
font-family: var(--font-primary);
width: 100%;
height: 80px;
font-size: 1.7rem;
font-weight: 600;
color: #fff;
padding-bottom: 5px;
cursor: pointer;
transition: .3s;
border: 2px solid #ED9F0C;
border-radius: 500px;
}

.thanksTxt {
text-align: center;
padding: 30px 0 60px;
}

/**/

.privacy {
text-align: justify;
}

.privacy h2 {
font-size: 1.6rem;
font-weight: 700;
margin-bottom: 20px;
}

/**/

footer {
position: relative;
background-color: var(--subColor);
width: 94vw;
font-size: 1.2rem;
padding: 60px 30px 190px;
border-radius: 0 50px 0 0;
box-shadow: 10px 10px 0 var(--themeColor);
}

#footerL {
position: relative;
width: auto;
font-weight: 500;
text-align: center;
top: 30px;
}

#footerLogo {
width: 180px;
text-align: center;
margin: 0 auto;
margin-bottom: 30px;
}

#footerLogoAllLinkReforms {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.1rem;
font-weight: 700;
color: var(--bearColor);
margin-top: 3px;
}

#copyRight {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.2rem;
font-weight: 500;
margin-top: 30px;
}

#footerR {
width: 100%;
text-align: center;
}

#footerR ul {
}

#footerR ul li {
position: relative;
width: 100%;
text-align: center;
margin-bottom: 10px;
}

#footerR ul li a {
position: relative;
font-size: 1.2rem;
color: var(--txtColor);
line-height: 1.5;
}

#footerR ul li a:hover {
text-decoration: underline;
}

#footerAreaSp {
width: 100%;
margin-top: 20px;
}

#footerArea {
display: none;
}

#footerBg {
position: fixed;
background: url("../img/footer_bg.svg") repeat-x;
background-size: 800px;
width: 100%;
height: 40px;
left: 0;
bottom: 0;
z-index: 500;
will-change: transform;
}

#pagetop {
position: fixed;
background-color: var(--themeColor);
width: 60px;
height: 60px;
border-radius: 20px 0 0;
bottom: -60px;
right: 0;
transition: .3s;
z-index: 600;
will-change: transform;
}

#pagetop::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
transform: rotate(-45deg);
left: 0;
right: 0;
top: 0;
bottom: 0;
}

#kumasan {
position: absolute;
width: 45px;
margin: auto;
left: 0;
right: 0;
top: -54px;
}

.orderBox { 
display: flex;
flex-direction: column;
}

.order1 { order: 1; }
.order2 { order: 2; }
.order3 { order: 3; }
.order4 { order: 4; }
.order5 { order: 5; }

.alignright,
.alignleft,
.aligncente {
display: block;
margin: 0 auto;
margin-bottom: 30px;
}

}