@charset "UTF-8";

@media print, screen and (max-width:1199px) {

#kvWrap {
position: relative;
width: 100%;
height: 350px;
margin: 0 auto;
overflow: hidden;
border-radius: 0 0 30px 30px;
}

#kvWrap::after {
position: absolute;
background: rgb(0 0 0 / .3);
width: 100vw;
height: 100vh;
content: "";
z-index: 1;
left: 0;
top: 0;
}

#kvWrap h1 {
position: absolute;
width: 85%;
font-size: 2.6rem;
font-weight: 700;
text-align: left;
color: #fff;
line-height: 1.5;
z-index: 2;
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
letter-spacing: .1em;
}

#kvWrap h1 span {
font-family: var(--font-kodchasan);
font-size: 1rem;
font-weight: 600;
display: block;
margin-top: 15px;
margin-left: 7px;
letter-spacing: 0;
line-height: 1.5;
}

#kvWrap h1 em {
position: absolute;
font-size: 1.5rem;
left: 7px;
bottom: -30px;
}

#kvNews {
background-color: var(--txtColor);
width: 90%;
font-size: 1.1rem;
text-align: left;
margin: 0 auto;
margin-top: -10px;
padding: 22px 20px 18px;
display: flex;
justify-content: space-between;
align-items: center;
border-radius: 0 0 20px 20px;
line-height: 1.5;
}

#whatsNew {
position: absolute;
background-color: var(--themeColor);
font-family: var(--font-kodchasan);
width: 56px;
height: 56px;
font-size: 1rem;
font-weight: 600;
color: #fff;
text-align: center;
border-radius: 60px;
line-height: 55px;
transform: rotate(-20deg);
letter-spacing: 0;
left: 20px;
top: -40px;
}

#ticker {
width: 100%;
text-align: left;
margin: 0 auto;
}

#ticker a {
color: #fff;
}

#ticker span {
font-family: var(--font-kodchasan);
font-weight: 600;
margin-right: 20px;
}

.scroll {
display: none;
}

.scrolldown {
display: none;
}

.scrolldown .sline {
display: none;;
}

/**/

.contentsTitleCe,
.contentsTitle,
.contentsTitleR {
position: relative;
font-size: 2.6rem;
font-weight: 600;
text-align: center;
margin-bottom: 30px;
padding-top: 30px;
display: table;
line-height: 1.3;
z-index: 1;
}

.contentsTitleCe::before,
.contentsTitle::before,
.contentsTitleR::before {
position: absolute;
background: url("../img/contents_title_mark.svg") no-repeat center;
background-size: 70px;
width: 70px;
height: 22px;
content: "";
margin: auto;
left: 0;
right: 0;
top: 0;
}

.contentsTitle::before,
.contentsTitleR::before {
margin: 0 auto;
}

.contentsTitleCe {
text-align: center;
margin: 0 auto;
margin-bottom: 30px;
}

.contentsTitleCe span,
.contentsTitle span,
.contentsTitleR span {
font-family: var(--font-kodchasan);
font-size: 1.6rem;
font-weight: 700;
color: var(--themeColor);
display: block;
margin-top: 10px;
}

#wrapReason {
width: 88%;
margin: 0 auto;
padding: 40px 0 50px;
}

.indexReasonFlex {
width: 100%;
margin: 0px auto;
margin-bottom: 30px;
}

.indexReasonPhoto {
position: relative;
width: 100%;
margin-bottom: 20px;
}

.indexReasonPhoto img {
border-radius: 30px;
}

.indexReasonTxt {
width: 100%;
text-align: justify;
}

.reasonTitleFlex {
display: flex;
justify-content: flex-start;
}

.indexReasonPhoto .number,
.indexReasonPhoto .numberL {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 6rem;
font-weight: 100;
color: #ccc;
line-height: 1;
top: -32px;
}

.indexReasonPhoto .number {
right: 20px;
}

.indexReasonPhoto .numberL {
right: 20px;
}

.reasonTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 7px;
background-size: 20px;
width: 100%;
font-size: 2rem;
font-weight: 700;
margin-bottom: 20px;
padding-left: 30px;
line-height: 1.6;
}

.indexReasonTxt p {
margin-bottom: 0;
}

.wrapColor {
background-color: var(--subColor);
width: 100%;
}

.wrap {
width: 88%;
margin: 0 auto;
padding: 50px 0;
}

/**/

#pricePlanFlex  {
width: 100%;
margin: 0 auto;
margin-bottom: 30px;
}

.pricePlan {
position: relative;
background-color: #fff;
width: 100%;
text-align: center;
margin-bottom: 40px;
padding: 0 0 30px;
border-radius: 30px;
}

.pricePlan h3 {
position: relative;
background-color: var(--txtColor);
font-size: 1.7rem;
font-weight: 600;
color: #fff;
margin: 0 auto;
padding: 20px 0;
border-radius: 30px 30px 0 0;
line-height: 1.5;
}

.pricePlan h3 span {
display: block;
}

.pricePlan h3 em {
font-size: 2.6rem;
letter-spacing: 0;
}

.pricePlanPhotoFlex {
display: flex;
justify-content: space-between;
}

.pricePlanPhoto {
width: 50%;
}

.pricePlan .mark {
font-size: 1.2rem;
}

.pricePlan .price {
font-size: 1.8rem;
margin: 10px auto;
line-height: 1.3;
}

.pricePlan .price span {
font-size: 5rem;
color: var(--themeColor);
}

.pricePlan .price em {
font-size: 32.6rem;
}

.pricePlan .priceTaxin {
font-size: 1.4rem;
margin-bottom: 20px;
line-height: 1;
}

.pricePlan .priceTaxin em {
font-size: 2.2rem;
}

.pricePlan .guaranteeL,
.pricePlan .guaranteeR {
position: absolute;
width: 70px;
z-index: 1;
top: -28px;
}

.pricePlan .guaranteeL {
left: -21px;
}

.pricePlan .guaranteeR {
right: -21px;
}

.pricePlan .guarantee span {
position: relative;
font-size: 3rem;
top: 4px;
}

/**/

#wrapWorks {
width: 88%;
text-align: left;
margin: 0 auto;
padding: 40px 0;
}

.wrapTitleFlex {
display: flex;
justify-content: space-between;
}

.btnR {
width: 100%;
margin: 0 auto;
margin-top: 60px;
}

.btnL {
text-align: left;
}

.voice {
position: relative;
background-color: #fff;
width: 100%;
text-align: justify;
margin: 70px auto;
padding: 60px 30px 30px;
border-radius: 20px;
}

.voice:last-of-type {
margin-bottom: 30px;
}

.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;
color: var(--txtColor);
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;
}

.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: -54px;
}

.voice p {
margin-bottom: 0;
}

/**/

.constructionFlex {
margin-bottom: -30px;
}

.construction {
position: relative;
width: 100%;
margin-bottom: 40px;
}

.construction .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 4.4rem;
font-weight: 400;
color: var(--themeColor);
line-height: 1;
z-index: 2;
right: 20px;
top: -28px;
}

.construction .constructionPhoto {
background-color: var(--txtColor);
border-radius: 0 0 25px 25px;
}

.construction .constructionPhoto img {
width: 100%;
height: 240px;
object-fit: cover;
border-radius: 25px;
}

.constructionTitle {
background-color: var(--txtColor);
width: 100%;
height: 90px;
padding: 0 22px;
border-radius: 25px 25px 0 0;
display: table;
line-height: 1.5;
}

.construction h3 {
font-size: 2rem;
font-weight: 700;
color: #fff;
text-align: center;
display: table-cell;
vertical-align: middle;
}

.construction span {
font-size: 1.3rem;
display: block;
}

#indexQaWrap {
position: relative;
width: 88%;
margin: 0 auto;
padding: 50px 0;
}

#qaR {
width: auto;
}

#qaL {
width: 100%;
text-align: justify;
}

.accordion {
width: 100%;
text-align: justify;
margin: 0 auto;
margin-top: -30px;
padding: 10px 0;
}

.accordion ul {
margin: 0 auto;
padding: 0;
}

.accordion li {
position: relative;
background-color: #fff;
width: 100%;
margin-bottom: 15px;
border-radius: 10px;
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 56px 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: 1px;
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: 500;
padding: 7px 0;
line-height: 1.2;
}

.toggle dd {
padding: 7px 0 3px 30px;
}

.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: 500;
color: var(--themeColor);
line-height: 1;
}

.qaDetail dd {
padding: 0 0 0 30px;
}

#wrapBlog {
width: 88%;
text-align: left;
margin: 0 auto;
padding: 50px 0;

}

.freeWrap {
width: 88%;
margin: 0 auto;
}

#wrapNews {
position: relative;
width: 88%;
margin: 0 auto;
padding: 40px 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 solid #fff;
transition: .3s;
overflow: hidden;
}

.news:first-of-type {
border-top: 1px solid #fff;
}

.news::before {
position: absolute;
width: 12px;
height: 12px;
content: "";
margin: auto;
border-top: 1px solid var(--themeColor);
border-right: 1px solid var(--themeColor);
transform: rotate(45deg);
right: 15px;
top: 0;
bottom: 0;
transition: .3s;
}

.news a {
width: 100%;
padding: 20px 0;
display: block;
}

.news dt {
font-family: var(--font-kodchasan);
font-weight: 600;
}

.news dd {
padding: 0 60px 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;
}


.btn {
position: relative;
background-color: var(--themeColor);
width: 100%;
height: 60px;
font-size: 1.4rem;
font-weight: 700;
color: #fff;
padding-bottom: 3px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btn::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 1px solid #fff;
border-right: 1px solid #fff;
transform: rotate(45deg);
transition: .3s;
right: 25px;
top: -2px;
bottom: 0;
}

/**/

#companyFlex {
margin: -10px auto;
}

#companyL {
width: 100%;
margin-bottom: 30px;
}

.outline {
width: 100%;
text-align: left;
border-top: 1px solid #ffff;
}

.outline dt {
float: left;
padding: 20px 0;
}

.outline dd {
position: relative;
padding: 20px 0 20px 100px;
border-bottom: 1px solid #fff;
}

.outline dd::before {
position: absolute;
background-color: var(--themeColor);
width: 80px;
height: 2px;
content: "";
left: 0;
bottom: 0;
}

#companyR {
width: 100%;
}

.googleMap {
position: relative;
width: 100%;
height: 0;
margin: 0 auto;
padding-top: 80%;
overflow: hidden;
border-radius: 30px;
}

.googleMap iframe {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/**/

#titleWrap {
position: relative;
background: var(--txtColor) url("../img/sub_title.svg") no-repeat right bottom;
background-size: 50px;
width: 100%;
height: 230px;
margin: 0 auto;
overflow: hidden;
border-radius: 0 0 30px 30px;
}

#contentsTite {
position: absolute;
width: 88%;
font-size: 2.6rem;
font-weight: 600;
text-align: left;
color: #fff;
margin: auto;
padding-top: 30px;
line-height: 1.3;
z-index: 1;
top: 50%;
left: 0;
right: 0;
transform: translateY(-50%);
}

#contentsTite span {
font-family: var(--font-kodchasan);
font-size: 1.6rem;
font-weight: 700;
display: block;
margin-top: 10px;
}

#breadcrumb {
width: 88%;
font-size: 1rem;
text-align: left;
margin: 0 auto;
padding-top: 15px;
}

.wrapCo,
.wrapCoS {
width: 88%;
text-align: justify;
margin: 0 auto;
padding-top: 40px;
}

/**/

#warpReasonCo {
width: 88%;
margin: 0 auto;
padding: 40px 0 20px;
}

#flowWrap {
position: relative;
margin-top: 40px;
}

#flowWrap::before {
position: absolute;
background-color: #f3d7a8;
width: 10px;
height: 100%;
content: "";
left: 0;
top: 0;
}

#flowWrap::after {
position: absolute;
background-color: #f3d7a8;
height: calc(tan(60deg) * 20px / 2);
width: 10px;
clip-path: polygon(0 0, 100% 0, 50% 100%);
content: "";
left: 0;
bottom: -17px;
}

.flowL,
.flowR {
position: relative;
width: 100%;
text-align: justify;
margin-bottom: 20px;
padding-left: 30px;
}

.flowR:last-child p {
margin-bottom: 0;
}

.flowL .step,
.flowR .step {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.5rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 5px;
line-height: 1;
}

.flowL .step span ,
.flowR .step span {
font-size: 2rem;
font-weight: 500;
}

.flowL h3,
.flowR h3 {
font-size: 2rem;
font-weight: 700;
margin-bottom: 10px;
line-height: 1.5;
}

.guaranteeFlex {
}

.guaranteeWrap {
width: 280px;
text-align: center;
margin: 0 auto;
margin-bottom: 30px;
}

.guaranteeWrap:last-child {
margin-bottom: 0;
}

.guarantee {
background-color: #fff;
width: 220px;
height: 220px;
display: table;
margin: 0 auto;
margin-bottom: 20px;
border-radius: 280px;
}

.guarantee .inner {
display: table-cell;
vertical-align: middle;
}

.guaranteeWrap h3 {
font-size: 1.6rem;
font-weight: 700;
}

.guaranteeWrap p {
margin-bottom: 0;
}

.qualificationsLicenses {
}

.qualificationsLicenses li {
background-color: var(--txtColor);
width: 100%;
height: 40px;
text-align: center;
color: #fff;
margin: 6px;
border-radius: 100px;
line-height: 38px;
}










/**/

.wrapColorCo {
background-color: var(--subColor);
width: 100%;
text-align: justify;
padding: 40px;
border-radius: 30px;
}

/**/

#worksFlex {
}

.works {
position: relative;
width: 100%;
font-size: 1.4rem;
text-align: justify;
margin-right: 30px;
margin-bottom: 30px;
overflow: hidden;
border-radius: 20px;
line-height: 1.7;
}

.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;
}

.works .worksPhoto img {
width: 100%;
height: 240px;
object-fit: cover;
transition: .3s ease-in-out;
}

.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(--themeColor);
min-width: 120px;
height: 30px;
font-size: 1.2rem;
font-weight: 600;
color: #fff;
text-align: center;
padding: 0 17px;
border-radius: 0 10px 0 0;
line-height: 28px;
z-index: 1;
left: 0;
bottom: 0;
}

.works .inner {
position: relative;
background-color: var(--txtColor);
width: 92%;
color: #fff;
margin: 0 auto;
margin-top: -30px;
padding: 20px 20px 26px 26px;
border-radius: 5px 5px 15px 15px;
transition: .3s;
z-index: 1;
}

.works .inner h3 {
font-size: 1.5rem;
font-weight: 700;
margin-bottom: 10px;
line-height: 1.5;
}

.works p {
margin-bottom: 10px;
}

.slide .worksAfter,
.works .worksAfter {
position: absolute;
background-color: var(--themeColor);
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: 120px;
}

.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%;
}

.beforeAfterFlex:nth-of-type(1) {
margin-top: 30px;
}

.beforeAfterWrap {
position: relative;
width: 100%;
}

.beforeAfter {
width: 100%;
height: 230px;
margin-bottom: 30px;
overflow: hidden;
border-radius: 20px;
}

.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(--txtColor);
border-radius: 60px;
border: 1px solid var(--txtColor);
line-height: 58px;
z-index: 1;
left: -10px;
top: -10px;
}

.beforeAfterWrap .worksAfter {
position: absolute;
background-color: var(--themeColor);
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(--themeColor);
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%);
}

.wrapWorksDetail {
margin: 30px auto;
margin-top: 10px;
}

.worksDetailFlex {
padding: 20px 0;
display: flex;
justify-content: space-between;
border-bottom: 1px dotted #ccc
}

.worksDetailFlex:first-child {
margin-top: 20px;
border-top: 1px dotted #ccc
}

.worksDetailItem {
width: 20%;
}

.worksDetailItem span {
background-color: var(--txtColor);
width: 80px;
height: 24px;
font-size: 1.3rem;
color: #fff;
text-align: center;
display: block;
border-radius: 50px;
line-height: 22px;
}

.worksDetailCon {
width: 72%;
}

.stateFlex {
}

.stateWrap {
width: 100%;
margin-bottom: 30px;
}

.stateWrap div {
width: 100%;
height: 230px;
margin-bottom: 20px;
overflow: hidden;
border-radius: 20px;
}

.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;
}

.postSide h3 {
position: relative;
font-size: 1.3rem;
font-weight: 700;
margin-bottom: 20px;
padding-bottom: 5px;
border-bottom: 1px solid #ddd;
}

.postSide ul {
margin-bottom: 30px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.postSide li {
font-size: 1.3rem;
list-style: none;
}

.postTagList {
display: flex;
justify-content: flex-start !important;
flex-wrap: wrap;
}

.postTagList li {
background-color: var(--txtColor);
width: auto;
height: 20px;
font-size: 1.2rem;
display: inline-block;
margin: 0 5px 5px 0;
padding: 0 8px;
line-height: 18px;
}

.postTagList li a {
color: #fff;
}

.worksSideRankingWrap,
.blogSideRankingWrap {
position: relative;
width: 48%;
margin-bottom: 15px;
}

.worksSideRankingWrap .number,
.blogSideRankingWrap .number {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.2rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 10px;
line-height: 1;
}

.worksSideRanking {
position: relative;
width: 100%;
}

.worksSideRanking a {
color: var(--txtColor);
text-decoration: none;
}

.worksSideRanking .worksPhoto {
position: relative;
width: 100%;
height: 120px;
overflow: hidden;
border-radius: 15px;
}

.worksSideRanking .worksPhoto img {
width: 100%;
height: 120px;
object-fit: cover;
transition: .3s ease-in-out;
}

.worksSideRanking .inner {
position: relative;
background: var(--txtColor);
width: 92%;
font-size: 1.2rem;
color: #fff;
margin: 0 auto;
margin-top: -20px;
padding: 15px 15px 16px 16px;
border-radius: 5px 5px 15px 15px;
transition: .3s;
z-index: 1;
}

.worksSideRanking h4 {
font-size: 1.2rem;
font-weight: 700;
color: #fff;
margin-bottom: 5px;
line-height: 1.5;
transition: .3s;
}

.blogSideRankingWrap .blogCo {
width: 100%;
margin-bottom: 0;
border-radius: 20px;
}

.blogSideRankingWrap .blogCo a {
color: #fff;
}

.blogSideRankingWrap .blogPhoto {
width: 100%;
height: 100px !important;
overflow: hidden;
}

.blogSideRankingWrap .blogPhoto img {
width: 100%;
height: 100px !important;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogSideRankingWrap .blogCo .inner {
background-color: var(--txtColor);
font-size: 1.2rem;
line-height: 1.5;
padding: 10px 15px 14px;
}

#relatedArticlesPost {
width: 100%;
margin-bottom: 30px;
}

#relatedArticlesPost a {
color: #fff;
text-decoration: none;
}

#relatedArticlesPost .works,
#relatedArticlesPost .blogCo {
position: relative;
width: 100%;
border-radius: 20px;
}

#relatedArticlesPost .works .worksPhoto,
#relatedArticlesPost .blogCo .blogPhoto {
position: relative;
width: 100%;
height: 200px;
overflow: hidden;
}

#relatedArticlesPost .works .worksPhoto img,
#relatedArticlesPost .blogCo .blogPhoto img {
width: 100%;
height: 200px;
object-fit: cover;
transition: .3s ease-in-out;
}

#relatedArticlesPost .works .inner {
position: relative;
width: 90%;
font-size: 1.2rem;
text-align: left;
margin-top: -20px;
padding: 18px 20px 22px;
z-index: 1;
}

#relatedArticlesPost .blogCo .inner {
background-color: var(--txtColor);
padding: 18px 20px 22px;
}

#relatedArticlesPost .blogCo .inner h3 {
font-weight: 400;
margin: 0 0 5px;
padding: 0;
border: 0;
}

#relatedArticlesPost .works h3 {
font-size: 1.3rem;
color: #fff;
margin-top: 0;
margin-bottom: 5px;
padding-left: 0;
border-left: 0;
transition: .3s;
}

/**/

.wrapConstruction {
width: 88%;
margin: 0 auto;
padding: 40px 0;
}

.wrapConstruction .conwide {
width: 100%;
margin-bottom: 40px;
}

.wrapConstruction .constructionTitle {
height: 140px;
}

.wrapConstruction .conwide h3 {
font-size: 2.5rem;
line-height: 1.6;
}

.wrapConstruction .conwide h3 span {
font-size: 1.5rem;
}

.wrapConstruction .construction:nth-child(2) {
margin-top: 0;
}

.wrapConstruction .construction:nth-child(3) {
margin-top: 0;
}

.wrapConstructionBottom {
width: 100%;
margin: 70px auto;
margin-bottom: -60px;
}

.wrapConstructionBottom .construction {
width: 100%;
margin-bottom: 40px !important;
}

.wrapConstructionBottom .constructionTitle {
border-radius: 20px !important;
}

.wrapConstructionBottom .constructionTitle {
height: 120px;
}

.wrapConstructionBottom .constructionTitle h3 {
}

.construction .constructionPhotoCo {
background-color: var(--txtColor);
border-radius: 0 0 25px 25px;
}

.wrapConstruction .constructionPhotoCo img {
width: 100%;
border-radius: 25px;
}

/**/

#blogNav {
margin-bottom: 20px;
border-bottom: 1px solid var(--txtColor);
}

#blogNav ul {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

#blogNav ul li {
background-color: var(--txtColor);
width: 49%;
text-align: center;
border-left: 1px solid var(--txtColor);
border-top: 1px solid var(--txtColor);
border-right: 1px solid var(--txtColor);
border-radius: 15px 15px 0 0;
}

#blogNav ul li a {
width: 100%;
height: 100%;
font-weight: 600;
color: #fff;
padding: 10px;
display: block;
transition: .3s;
}

/**/

#blogFlex {
}

.blogCo {
position: relative;
background-color: #fff;
width: 100%;
margin: 0 auto;
margin-bottom: 20px;
overflow: hidden;
border-radius: 20px;
line-height: 1.7;
}

.blogCo .blogPhoto {
position: relative;
width: 100%;
height: 200px;
overflow: hidden;
border-radius: 20px 20px 0 0;
}

.blogCo .blogPhoto img {
width: 100%;
height: 200px;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogCo .inner {
background-color: var(--txtColor);
text-align: justify;
padding: 18px 24px 20px;
}

.blogCo .inner h3 {
font-size: 1.3rem;
margin-bottom: 10px;
}

.blogCo .inner p {
margin-bottom: 10px;
}

.blogCo .inner .postDate {
font-family: var(--font-kodchasan);
font-weight: 600;
font-size: 1.2rem;
}

.blogCo a {
color: #fff;
font-weight: 700;
transition: .3s;
}

#supervisorWrap {
background-color: var(--subColor);
width: 100%;
margin: 40px auto;
padding: 30px;
border-radius: 20px;
}

#supervisorPhotoWrap {
position: relative;
width: 120px;
margin: 0 auto;
margin-bottom: 20px;
}

#supervisorPhoto {
width: 120px;
height: 120px;
overflow: hidden;
border-radius: 120px;
}

#supervisorPhoto img {
width: 100%;
height: 150px;
object-fit: cover;
}

#supervisorPlate {
position: absolute;
background-color: var(--txtColor);
width: 90%;
height: 30px;
color: #fff;
font-size: 1.3rem;
font-weight: 600;
text-align: center;
margin: 0 auto;
border-radius: 100px;
line-height: 28px;
z-index: 1;
left: 0;
right: 0;
bottom: 0;
}

#supervisorTxt {
width: 100%;
}

#supervisorName {
font-size: 1.5rem;
font-weight: 600;
}

#toc_container {
background-color: var(--subColor);
width: 100%;
margin: 30px auto;
padding: 30px;
border-radius: 20px;
}

.toc_title {
font-size: 1.7rem;
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 7 Free";
font-wigth: 900;
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 a:hover {
color: var(--themeColor);
}

.toc_list li::before {
content: "- ";
}

.toc_list li ul li {
font-size: 1.3rem;
margin-left: 15px;
}

/**/

#postTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 7px;
background-size: 20px;
width: 100%;
font-size: 2rem;
font-weight: 700;
padding-left: 30px;
padding-bottom: 15px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

#postDate {
font-family: var(--font-kodchasan);
font-weight: 700;
margin-bottom: 10px;
}

#postDateNews {
font-family: var(--font-kodchasan);
font-weight: 700;
margin-top: 12px;
margin-bottom: 26px;
}

#categoryPost {
background-color: var(--txtColor);
width: 130px;
height: 28px;
font-size: 1.1rem;
text-align: center;
color: #fff;
margin-bottom: 30px;
line-height: 26px;
border-radius: 0 0 10px 0;
}

.postBlogThumbnail {
margin-bottom: 30px;
}

.post h2 {
font-size: 2rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 30px;
padding-left: 12px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h3 {
font-size: 1.8rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 30px;
padding-left: 12px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h4 {
font-size: 1.6rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 30px;
padding-left: 12px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h5 {
font-size: 1.4rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 30px;
padding-left: 12px;
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;
}

/**/

#prevNextWrap {
margin-bottom: 30px;
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;
color: var(--themeColor);
cursor: pointer;
padding-bottom: 3px;
border: 1px solid var(--themeColor);
border-radius: 15px 5px 15px;
transition: .3s;
}

.btnPrevWrap,
.btnNextWrap {
width: 10px;
}

.btnPrev,
.btnNext {
position: relative;
background: transparent;
width: 10px;
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: 1px solid var(--themeColor);
border-left: 1px 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: 1px solid var(--themeColor);
border-right: 1px solid var(--themeColor);
transform: rotate(45deg);
z-index: 10;
right: 5px;
top: 0;
bottom: 0;
transition: .5s;
}

.wp-block-image {
margin-bottom: 30px;
}

/**/

.pageNavi {
font-family: var(--font-kodchasan);
margin: 0 auto;
margin-top: 30px;
}

.wp-pagenavi {
position: relative;
font-size: 1rem;
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
line-height: 28px;
}

.wp-pagenavi .pages {
display: none;
}

.wp-pagenavi .page {
margin: 0 3px;
}

.wp-pagenavi .current {
background-color: var(--txtColor);
width: 30px;
height: 30px;
color: #fff;
margin: 0 3px;
display: block;
border: 1px solid var(--txtColor) !important;
border-radius: 5px;
}

.wp-pagenavi a,
.wp-pagenavi .extend {
width: 30px;
height: 30px;
display: block;
border: 1px solid var(--themeColor) !important;
border-radius: 5px;
}
.wp-pagenavi .first,
.wp-pagenavi .last {
display: none;
}

.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
position: relative;
font-size: 0;
text-indent: -1000px;
margin: 0 3px;
border: 0 !important;
}

.wp-pagenavi .previouspostslink::after {
position: absolute;
width: 8px;
height: 8px;
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: 8px;
height: 8px;
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;
}

/**/

#messageFlex {
}

#messageL {
width: 100%;
font-size: 1.4rem;
text-align: justify;
line-height: 2;
}

#messageL:last-child p {
margin-bottom: 0;
}

#messageR {
width: 100%;
}

#messagePhoto {
position: relative;
overflow: hidden;
border-radius: 30px;
}

#messagePhoto #nameEn {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 3rem;
color: #eee;
z-index: 1;
line-height: 1;
left: 0;
right: 0;
bottom: -3px;
}

#messageR #name {
font-size: 1.4rem;
margin-top: 20px;
}

#messageR #name span {
font-size: 2rem;
margin-left: 15px;
}

.wrapCompany {
width: 100%;
margin: 0 auto;
}

.wrapCompany dd {
padding: 20px 0 20px 100px;
}

/**/

.privacy h2 {
position: relative;
font-size: 1.8rem;
font-weight: 700;
margin: 26px auto;
margin-top: 30px;
padding-bottom: 15px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

/**/

#wrapContactBottomBlog {
position: relative;
width: 100%;
text-align: center;
}

#wrapContactBottomBlog #contactBottomWrap {
width: 100%;
}

#wrapRelatedArticles {
position: relative;
width: 100%;
text-align: justify;
margin: 0 auto;
margin-bottom: -140px;
z-index: 1;
}

#wrapRelatedArticles h2 {
font-size: 2rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 30px;
padding-left: 12px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

#prevNextWrapBlog {
width: 85%;
margin: 0 auto;
margin-bottom: 50px;
}

/**/

#wrapContact {
position: relative;
background-color: #fcf8ee;
width: 88%;
text-align: justify;
margin: 0 auto;
margin-bottom: -140px;
padding: 40px 0 60px;
border-radius: 0 0 30px 30px;
z-index: 1;
}

.contactSubTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 5px;
background-size: 20px;
width: 100%;
font-size: 2rem;
font-weight: 700;
margin-bottom: 25px;
padding-left: 30px;
padding-bottom: 15px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

.flowWrapCo {
margin-bottom: 60px !important;
}

.contactCallWrap {
position: relative;
background-color: #fff;
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;
border: 1px solid 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: #fff;
font-family: var(--font-primary);
width: 100%;
height: 60px;
font-size: 1.3rem;
padding: 15px;
border: 1px solid #fff;
border-radius: 10px;
}

.contactR input {
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
}

.contactR textarea {
background-color: #fff;
font-family: var(--font-primary);
width: 100%;
height: 200px;
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
border: 1px solid #fff;
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: #fff;
font-family: var(--font-primary);
width: 100%;
height: 60px;
font-size: 1.3rem;
font-weight: 500;
color: var(--txtColor);
padding: 15px;
border: 1px solid #fff;
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;
}

.checkWrap {
width: 100%;
text-align: center;
margin-bottom: 20px;
padding-top: 30px;
border-top: 1px dotted #ccc;
}

.checkWrap a {
color: var(--themeColor);
text-decoration: underline;
}

.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;
display: none;
}

.checkWrap .wpcf7-list-item {
display: inline-block;
}

.checkWrap .wpcf7-list-item label {
position: relative;
display: flex;
align-items: center;
cursor: pointer;
}

.wpcf7-list-item-label {
margin-left: 7px;
}

.checkWrap .wpcf7-list-item label::before,
.checkWrap .wpcf7-list-item label:has(:checked)::after {
content: '';
}

.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;
}

.checkWrap .wpcf7-list-item label:has(:checked)::before {
background-color: var(--themeColor);
}

.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;
}

.wpcf7-submit {
background-color: var(--themeColor);
font-family: var(--font-primary);
width: 80%;
height: 80px;
font-size: 1.7rem;
font-weight: 600;
color: #fff;
padding-bottom: 5px;
cursor: pointer;
transition: .3s;
border: 1px solid var(--themeColor);
border-radius: 500px;
}

.thanksTxt {
text-align: center;
padding: 30px 0 60px;
}

/**/

.staffFlex {
}

.staff,
.staffCo {
position: relative;
width: 100%;
}

.staffPhoto,
.staffPhotoCo {
width: 100%;
height: 400px;
margin-bottom: 30px;
overflow: hidden;
border-radius: 20px;
}

.staffPhoto img,
.staffPhotoCo img {
width: 100%;
height: 400px;
object-fit: cover;
transition: .6s;
}

.staff h2,
.staff h3,
.staffCo h1 {
position: absolute;
font-size: 1.9rem;
writing-mode: vertical-rl;
text-align: left;
color: #fff;
margin: auto;
line-height: 1.7;
z-index: 1;
right: -25px;
top: 15px;
}

.staff h2 span,
.staff h3 span,
.staffCo h1 span {
background-color: var(--txtColor);
margin: 0 12px;
padding: 15px 0;
display: table;
border-radius: 5px;
}

.affiliationNameFlex,
.affiliationNameFlexCo {
position: absolute;
background-color: var(--txtColor);
min-width: 250px;
height: 60px;
color: #fff;
padding: 0 20px;
border-radius: 0 10px 0 20px;
line-height: 68px;
left: 0;
top: 340px;
display: flex;
justify-content: center;
align-items: center;
}

.staff .name,
.staffCo .name {
position: relative;
font-size: 2.4rem;
font-weight: 700;
line-height: 1;
top: -3px;
}

.staff .affiliation,
.staffCo .affiliation {
height: 26px;
font-size: 1.2rem;
margin-right: 20px;
padding: 0 10px;
border: 1px solid #fff;
line-height: 22px;
}

.staff .staffEn,
.staffCo .staffEn {
position: absolute;
width: 45px;
opacity: .5;
z-index: 1;
left: -1px;
top: 40px;
}

.staffTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 5px;
background-size: 20px;
width: 100%;
font-size: 1.9rem;
font-weight: 700;
margin-bottom: 20px;
padding-left: 28px;
line-height: 1.5;
}

.question {
font-family: var(--font-kodchasan);
font-size: 1.4rem;
color: var(--themeColor);
font-weight: 600;
}

.question span {
font-size: 2.2rem;
font-weight: 400;
margin-left: 5px;
}

.wrapInterview {
width: 100%;
text-align: justify;
margin: 0 auto;
}

.staffPhotoCo2 {
width: 100%;
margin: 30px auto;
margin-bottom: 20px;
overflow: hidden;
border-radius: 20px;
}

#prevNextWrapStaff {
margin: 40px auto;
}

#wrapOtherStaff {
margin-top: 60px;
}

#wrapOtherStaff h2 {
font-size: 1.9rem;
font-weight: 700;
margin-bottom: 30px;
padding-left: 12px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

/**/

#wrapContactBottom {
position: relative;
width: 100%;
margin: 10px auto;
margin-bottom: -140px;
padding: 40px 0 0;
z-index: 1;
}

#contactBottomWrap {
position: relative;
background: url("../img/contact_bottom_bg.webp") no-repeat center bottom;
background-size: cover;
width: 92%;
color: #fff;
margin: 0 auto;
padding: 30px;
overflow: hidden;
border-radius: 30px;
}

#contactBottomWrap::after {
position: absolute;
background: rgb(0 0 0 / .3);
width: 100vw;
height: 100vh;
content: "";
left: 0;
top: 0;
}

#contactBottomWrap h3 {
position: relative;
font-size: 1.7rem;
font-weight: 600;
margin-top: -20px;
margin-bottom: 30px;
z-index: 2;
}

#contactBottomWrap h4 {
position: relative;
font-size: 1.5rem;
margin-bottom: 10px;
z-index: 2;
}

#contactBottomFlex {
position: relative;
z-index: 2;
}

.contactBottomLr {
margin: 0 auto;
}

.btnContact {
background-color: var(--themeColor);
width: 100%;
height: 90px;
font-size: 1.7rem;
font-weight: 700;
color: #fff;
padding-bottom: 3px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btnContact i {
position: relative;
font-size: 2.6rem;
margin-right: 5px;
top: 3px;
}

.btnContact:hover {
background-color: #fff;
color: var(--themeColor);
}

.btnCall {
background-color: #fff;
font-family: var(--font-kodchasan);
width: 100%;
height: 90px;
font-size: 2.6rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 10px;
padding-bottom: 5px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btnCall i {
margin-right: 5px;
}

.btnCall span {
font-family: var(--font-primary);
font-size: 1.1rem;
display: block;
}

.btnCall:hover {
background-color: var(--themeColor);
color: #fff;
}

/**/

footer {
position: relative;
background-color: var(--subColor);
width: 100%;
font-size: 1.2rem;
text-align: center;
padding: 170px 0 0;
border-radius: 30px 30px 0 0;
}

#footerNav {
width: 90%;
margin: 0 auto;
display: flex;
justify-content: space-between;
}

#footerNav ul {
position: relative;
width: 100%;
margin: 0 auto;
margin-bottom: 30px;
}

#footerNav ul li {
text-align: center;
margin: 10px auto;
border-left: 1px dotted var(--txtColor);
}

#footerNavR li {
border-right: 1px dotted var(--txtColor);
}

#footerNav ul li a {
position: relative;
font-size: 1.2rem;
font-weight: 700;
text-decoration: none;
display: block;
margin: 0;
padding: 0;
line-height: 1.5;
}

#footerNav ul li a span {
font-family: var(--font-kodchasan);
font-size: 1rem;
font-weight: 700;
color: var(--themeColor);
display: block;
}

#footerBottom {
position: relative;
width: 88%;
margin: 0 auto;
}

#footerL {
width: 100%;
margin-bottom: 30px;
}

#footerLogo {
width: 160px;
margin: 0 auto;
margin-bottom: 30px;
}

#footerSns {
width: 100%;
margin-bottom: 30px;
display: flex;
justify-content: center;
}

#footerSns li {
font-size: 2.6rem;
margin: 0 10px;
}

#footerTel {
font-size: 2.7rem;
line-height: 1;
}

#footerTel span {
font-family: var(--font-kodchasan);
font-weight: 600;
}

#astecLogo {
width: 120px;
margin: 30px auto;
margin-bottom: 40px;
overflow: hidden;
border-radius: 5px;
}

#footerR {
width: 100%;
text-align: center;
display: table;
line-height: 1.7;
}

#footerR h6 {
position: relative;
font-size: 2.2rem;
font-weight: 600;
margin-bottom: 25px;
padding-top: 32px;
line-height: 1.3;
}

#footerR h6::before {
position: absolute;
background: url("../img/contents_title_mark.svg") no-repeat center;
background-size:70px;
width: 70px;
height: 25px;
content: "";
margin: auto;
left: 0;
right: 0;
top: 0;
}

#footerR h6 span {
font-family: var(--font-kodchasan);
font-size: 1rem;
font-weight: 700;
color: var(--themeColor);
display: block;
margin-top: 10px;
}

#footerServiceArea {
background-color: #463a3d;
width: 300px;
height: 300px;
margin: 30px auto;
margin-bottom: 0;
overflow: hidden;
border-radius: 300px;
}

#copyRight {
background-color: var(--txtColor);
font-family: var(--font-kodchasan);
width: 100%;
font-size: 1rem;
font-weight: 500;
color: #fff;
margin-top: -30px;
margin-bottom: 42px;
padding: 40px 20px 10px;
}

#btnContactSp {
position: fixed;
background-color: var(--themeColor);
width: 100%;
height: 42px;
font-size: 1rem;
font-weight: 700;
color: #fff;
padding: 8px 0 12px;
border: 0;
display: flex;
justify-content: center;
align-items: center;
line-height: 1;
z-index: 500;
left: 0;
bottom: 0;
}

#btnContactSp span {
font-size: 1.6rem;
}

#btnContactSp i {
position: relative;
font-size: 2.2rem;
margin-right: 5px;
top: 2px;
}

#pagetop {
position: fixed;
background-color: var(--themeColor);
width: 50px;
height: 60px;
border-radius: 15px 0 0;
bottom: -80px;
right: 0;
transition: .3s;
z-index: 500;
}

#pagetop::before {
position: absolute;
width: 10px;
height: 10px;
content: "";
margin: auto;
border-top: 1px solid #fff;
border-right: 1px solid #fff;
transform: rotate(-45deg);
left: 0;
right: 0;
top: 0;
bottom: 0;
}

.orderBox { 
display: flex;
flex-direction: column;
}

.order1 { order: 1; }
.order2 { order: 2; }
.order3 { order: 3; }
.order4 { order: 4; }
.order5 { order: 5; }

}