@charset "UTF-8";

@media print, screen and (min-width:1200px) {

#kvWrap {
position: relative;
width: 95%;
height: 82vh;
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;
font-size: 5rem;
font-weight: 700;
text-align: left;
color: #fff;
line-height: 1.5;
z-index: 2;
top: 45%;
left: 100px;
transform: translateY(-45%);
letter-spacing: .2em;
}

#kvWrap h1 span {
font-family: var(--font-kodchasan);
font-size: 1.2rem;
font-weight: 600;
display: block;
margin-top: 15px;
margin-left: 7px;
letter-spacing: .17em;
line-height: 1.5;
}

#kvWrap h1 em {
position: absolute;
font-size: 1.8rem;
left: 7px;
bottom: -50px;
}

#kvNews {
position: absolute;
background-color: var(--txtColor);
width: 700px;
height: 90px;
font-size: 1.4rem;
text-align: left;
z-index: 50;
display: flex;
justify-content: space-between;
align-items: center;
border-radius: 0 20px 20px 0;
left: -10px;
bottom: -20px;
}

#whatsNew {
position: absolute;
background-color: var(--themeColor);
font-family: var(--font-kodchasan);
width: 56px;
height: 56px;
font-size: 1rem;
color: #fff;
text-align: center;
border-radius: 60px;
line-height: 55px;
transform: rotate(-20deg);
letter-spacing: 0;
left: 20px;
top: -40px;
}

#ticker {
width: 600px;
text-align: left;
margin: 0 auto;
top: -10px;
}

#ticker a {
color: #fff;
}

#ticker span {
font-family: var(--font-kodchasan);
font-weight: 500;
margin-right: 20px;
}

.scroll {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 1.2rem;
font-weight: 600;
color: #fff;
transform: rotate(90deg);
line-height: 1;
z-index: 30;
bottom: 125px;
right: 80px;
}

.scrolldown {
position: absolute;
width: 1px;
height: 160px;
bottom: 0;
right: 130px;
overflow: hidden;
z-index: 30;
}

.scrolldown .sline {
width: 100%;
height: 100%;
display: block;
background: linear-gradient(to bottom, #fff 50%, rgba(0, 0, 0, 0) 50%);
background-position: 0 -160px;
background-size: 100% 200%;
animation: scrolldown 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}

@keyframes scrolldown {
0% {
background-position: 0 -160px;
}
75% {
background-position: 0 0;
}
100% {
background-position: 0 160px;
}
}

/**/

.contentsTitleCe,
.contentsTitle,
.contentsTitleR {
position: relative;
font-size: 4.4rem;
font-weight: 600;
text-align: center;
margin-bottom: 50px;
padding-top: 50px;
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: 100px;
width: 100px;
height: 31px;
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: 50px;
}

.contentsTitleCe span,
.contentsTitle span,
.contentsTitleR span {
font-family: var(--font-kodchasan);
font-size: 2rem;
font-weight: 700;
color: var(--themeColor);
display: block;
margin-top: 15px;
}

#wrapReason {
width: 100%;
margin: 0 auto;
padding: 170px 0 120px 0;
}

.indexReasonFlex {
width: 95%;
margin: 80px auto;
display: flex;
justify-content: space-between;
align-items: center;
}

.indexReasonPhoto {
position: relative;
width: 48%;
}

.indexReasonPhoto img {
border-radius: 30px;
}

.indexReasonTxt {
width: 48%;
text-align: justify;
padding: 0 40px;
}

.reasonTitleFlex {
display: flex;
justify-content: flex-start;
}

.indexReasonPhoto .number,
.indexReasonPhoto .numberL {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 8rem;
font-weight: 100;
color: #ccc;
line-height: 1;
top: -52px;
}

.indexReasonPhoto .number {
right: 30px;
}

.indexReasonPhoto .numberL {
left: 30px;
}

.reasonTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 10px;
background-size: 30px;
font-size: 3.2rem;
font-weight: 700;
margin-bottom: 30px;
padding-left: 46px;
line-height: 1.5;
}

.indexReasonTxt p {
margin-bottom: 0;
}

.wrapColor {
background-color: var(--subColor);
width: 100%;
border-radius: 30px;
}

.wrapColor2 {
position: relative;
background-color: #f7f2e6;
width: 100%;
margin-top: -30px;
padding-top: 30px;
border-radius: 0 0 30px 30px;
z-index: -1;
}

.wrap {
width: 1200px;
margin: 0 auto;
padding: 120px 0;
}

/**/

#pricePlanFlex  {
width: 1050px;
margin: 0 auto;
margin-bottom: 60px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.pricePlan {
position: relative;
background-color: #fff;
width: 500px;
text-align: center;
padding: 0 0 50px;
border-radius: 30px;
}

.wrapCo .pricePlan {
margin-bottom: 60px;
}

.wrapCo .pricePlan:nth-of-type(7),
.wrapCo .pricePlan:nth-of-type(8 ){
margin-bottom: 0;
}

.pricePlan h3 {
position: relative;
background-color: var(--txtColor);
font-size: 2.1rem;
font-weight: 600;
color: #fff;
margin: 0 auto;
padding: 35px 0;
border-radius: 30px 30px 0 0;
line-height: 1.5;
}

.pricePlan h3 span {
display: block;
}

.pricePlan h3 em {
font-size: 3.4rem;
letter-spacing: 0;
}

.pricePlanPhotoFlex {
display: flex;
justify-content: space-between;
}

.pricePlanPhoto {
width: 33.33333333333%;
}

.pricePlan .mark {
font-size: 1.4rem;
}

.pricePlan .price {
font-size: 2.1rem;
margin: 20px auto;
margin-bottom: 15px;
line-height: 1.3;
}

.pricePlan .price span {
font-size: 5.2rem;
color: var(--themeColor);
}

.pricePlan .price em {
font-size: 3rem;
}

.pricePlan .priceTaxin {
font-size: 1.6rem;
margin-bottom: 20px;
line-height: 1;
}

.pricePlan .priceTaxin em {
font-size: 2.2rem;
}

.pricePlan .guaranteeL,
.pricePlan .guaranteeR {
position: absolute;
width: 100px;
z-index: 1;
top: -20px;
}

.pricePlan .guaranteeL {
left: -26px;
}

.pricePlan .guaranteeR {
right: -26px;
}

.pricePlan .guarantee span {
position: relative;
font-size: 3rem;
top: 4px;
}

/**/

#wrapWorks {
width: 1200px;
text-align: left;
margin: 0 auto;
padding: 120px 0;
}

.wrapTitleFlex {
display: flex;
justify-content: space-between;
}

.btnR {
width: 1200px;
margin: 0 auto;
display: flex;
justify-content: flex-end;
}

.btnL {
text-align: left;
}

#voiceFlex {
margin-top: 100px;
margin-bottom: -30px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.voice {
position: relative;
background-color: #fff;
width: 80%;
text-align: justify;
margin: 0 auto;
margin-bottom: 60px;
padding: 50px 60px 50px 120px;
border-radius: 20px;
}

.voice:nth-of-type(1n) {
left: -60px;
}

.voice:nth-of-type(2n) {
left: 60px;
}

.voice h3,
.voice h2 {
font-size: 2.2rem;
font-weight: 600;
color: var(--themeColor);
text-align: left;
margin-bottom: 15px;
line-height: 1.6;
}

.voice h3 span,
.voice h2 span {
font-size: 1.6rem;
color: var(--txtColor);
display: block;
}

.voice .icon {
position: absolute;
width: 110px;
margin: auto;
border-radius: 110px;
left: -20px;
top: -20px;
}

.voice .icon img {
border: 2px solid var(--themeColor);
border-radius: 120px;
}

.voice .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 2rem;
font-weight: 700;
text-align: center;
color: var(--themeColor);
line-height: 1;
left: 20px;
top: -36px;
}

.voice p {
margin-bottom: 0;
}

/**/

.constructionFlex {
margin-bottom: 60px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.construction {
position: relative;
width: 370px;
}

.construction:nth-child(2) {
margin-top: 30px;
}

.construction:nth-child(3) {
margin-top: 60px;
}

.construction .number {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 5rem;
font-weight: 400;
color: var(--themeColor);
line-height: 1;
z-index: 2;
right: 20px;
top: -32px;
}

.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: 120px;
padding: 0 10px;
border-radius: 25px 25px 0 0;
display: table;
line-height: 1.5;
}

.construction h3 {
font-size: 2.2rem;
font-weight: 700;
color: #fff;
text-align: center;
display: table-cell;
vertical-align: middle;
}

.construction span {
font-size: 1.4rem;
display: block;
}

#indexQaWrap {
position: relative;
width: 1200px;
margin: 0 auto;
padding: 120px 0 90px;
display: flex;
justify-content: space-between;
}

#qaR {
width: auto;
}

#qaL {
width: 780px;
text-align: justify;
}

.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: 30px;
border-radius: 10px;
transition: .3s;
}

.accordion li p:last-child {
margin-bottom: 0;
}

.accordion li h3 {
position: relative;
font-size: 1.5rem;
font-weight: 700;
color: var(--txtColor);
}

.accordion a {
position: relative;
color: var(--themeColor);
display: block;
text-decoration: none;
cursor: pointer;
padding: 20px 76px 28px 32px;
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: 34px;
}

.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: 3.2rem;
font-weight: 500;
line-height: 1.2;
}

.toggle dd {
padding: 7px 0 3px 44px;
}

.qaDetail {
color: var(--txtColor);
display: none;
padding: 0 34px 34px;
overflow: hidden;
}

.qaDetail dt {
float: left;
font-family: var(--font-kodchasan);
font-size: 3.2rem;
font-weight: 500;
color: var(--themeColor);
line-height: 1;
}

.qaDetail dd {
padding: 0 0 0 44px;
}

#wrapBlog {
width: 1200px;
text-align: left;
margin: 0 auto;
padding: 120px 0;
}

.freeWrap {
width: 1200px;
margin: 0 auto;
}

#wrapNews {
position: relative;
width: 1200px;
margin: 0 auto;
padding: 120px 0;
display: flex;
justify-content: space-between;
}

#newsL {
width: auto;
text-align: left;
}

#newsR {
width: 800px;
text-align: justify;
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: 35px;
top: 0;
bottom: 0;
transition: .3s;
}

.news:hover::before {
right: 30px;
}

.news a {
width: 100%;
padding: 40px 30px;
display: block;
}

.news:hover {
background-color: #fff;
}

.news dt {
float: left;
font-family: var(--font-kodchasan);
font-weight: 600;
}

.news dd {
padding: 0 40px 0 160px;
}

.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: 300px;
height: 70px;
font-size: 1.6rem;
font-weight: 700;
color: #fff;
padding-bottom: 3px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btn:hover {
background-color: #fff;
color: var(--themeColor);
}

.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;
}

.btn:hover::before  {
border-top: 1px solid var(--themeColor);
border-right: 1px solid var(--themeColor);
right: 20px;
}

/**/

#companyFlex {
display: flex;
justify-content: space-between;
}

#companyL {
width: 48%;
}

.outline {
width: 100%;
text-align: left;
border-top: 1px solid #ffff;
}

.outline dt {
float: left;
padding: 30px 0;
}

.outline dd {
position: relative;
padding: 30px 0 30px 150px;
border-bottom: 1px solid #fff;
}

.outline dd::before {
position: absolute;
background-color: var(--themeColor);
width: 120px;
height: 2px;
content: "";
left: 0;
bottom: 0;
}

#companyR {
width: 48%;
}

.googleMap {
position: relative;
width: 100%;
height: 495px;
margin: 0 auto;
overflow: hidden;
border-radius: 30px;
}

.googleMap iframe {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/*
.googleMap {
position: relative;
width: 100%;
height: 0;
margin: 0 auto;
padding-top: 40%;
overflow: hidden;
border-radius: 30px 0 30px 0;
}

.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: 100px;
width: 95%;
height: 350px;
margin: 0 auto;
overflow: hidden;
border-radius: 0 0 30px 30px;
}

#contentsTite {
position: absolute;
width: 1200px;
font-size: 4.4rem;
font-weight: 600;
text-align: left;
color: #fff;
margin: auto;
line-height: 1.3;
z-index: 2;
top: 50%;
left: 0;
right: 0;
transform: translateY(-50%);
}

#contentsTite span {
font-family: var(--font-kodchasan);
font-size: 2rem;
font-weight: 700;
color: #fff;
display: block;
margin-top: 15px;
}

#breadcrumb {
width: 1200px;
font-size: 1.2rem;
text-align: left;
margin: 0 auto;
padding-top: 20px;
}

.wrapCo {
width: 1200px;
margin: 0 auto;
padding-top: 80px;
}

.wrapCoS {
width: 1000px;
text-align: justify;
margin: 0 auto;
padding-top: 80px;
}

/**/

#warpReasonCo {
width: 100%;
padding-bottom: 50px;
}

#flowWrap {
position: relative;
width: 1000px;
margin: 0 auto;
margin-top: 60px;
}

#flowWrap::before {
position: absolute;
background-color: #f3d7a8;
width: 10px;
height: 100%;
content: "";
margin: auto;
left: 0;
right: 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: "";
margin: auto;
left: 0;
right: 0;
bottom: -17px;
}

.flowL,
.flowR {
position: relative;
width: 43%;
text-align: justify;
}

.flowR {
margin: 0 0 0 auto;
}

.flowL .step,
.flowR .step {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.8rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 5px;
line-height: 1;
}

.flowL .step span ,
.flowR .step span {
font-size: 2.6rem;
font-weight: 500;
}

.flowL h3,
.flowR h3 {
font-size: 2.6rem;
font-weight: 700;
margin-bottom: 10px;
}

.guaranteeFlex {
display: flex;
justify-content: center;
}

.guaranteeWrap {
width: 380px;
text-align: center;
margin: 0 30px;
}

.guarantee {
background-color: #fff;
width: 380px;
height: 380px;
display: table;
margin-bottom: 20px;
border-radius: 380px;
}

.guarantee .inner {
display: table-cell;
vertical-align: middle;
}

.guaranteeWrap h3 {
font-size: 2rem;
font-weight: 700;
}

.guaranteeWrap p {
margin-bottom: 0;
}

.qualificationsLicenses {
display: flex;
justify-content: center;
flex-wrap: wrap;
}

.qualificationsLicenses li {
background-color: var(--txtColor);
width: 350px;
height: 50px;
font-size: 1.6rem;
text-align: center;
color: #fff;
margin: 16px 8px 0;
border-radius: 100px;
line-height: 48px;
}










/**/

.wrapColorCo {
background-color: var(--subColor);
width: 100%;
text-align: justify;
padding: 100px 80px;
border-radius: 30px;
}

/**/

#worksFlex {
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
}

.works {
position: relative;
width: 380px;
font-size: 1.4rem;
text-align: justify;
margin-right: 30px;
margin-bottom: 30px;
overflow: hidden;
border-radius: 20px;
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;
}

.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(--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:hover {
background-color: var(--themeColor);
color: #fff;
}

.works .inner h3 {
min-height: 68px;
font-size: 1.5rem;
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(--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: 30px;
top: 170px;
}

.works .worksAfter {
top: 160px;
}

#postFlex {
width: 100%;
text-align: justify;
margin: 0 auto;
display: flex;
justify-content: space-between;
}

.post {
position: relative;
width: 920px;
text-align: justify;
color: var(--txtColor);
}

.post a {
color: #2271b1;
text-decoration: underline;
}

.beforeAfterFlex {
position: relative;
width: 100%;
display: flex;
justify-content: space-between;
}

.beforeAfterFlex:nth-of-type(1) {
margin-top: 40px;
}

.beforeAfterWrap {
position: relative;
width: 48%;
margin-bottom: 30px;
}

.beforeAfter {
width: 100%;
height: 335px;
overflow: hidden;
border-radius: 20px;
}

.beforeAfter img {
width: 100%;
height: 335px;
object-fit: cover;
}

.beforeAfterWrap .worksBefore {
position: absolute;
background-color: #fff;
font-family: var(--font-kodchasan);
width: 70px;
height: 70px;
font-size: 1.2rem;
font-weight: 700;
text-align: center;
color: var(--txtColor);
border-radius: 70px;
border: 1px solid var(--txtColor);
line-height: 68px;
z-index: 1;
left: -10px;
top: -10px;
}

.beforeAfterWrap .worksAfter {
position: absolute;
background-color: var(--themeColor);
font-family: var(--font-kodchasan);
width: 70px;
height: 70px;
font-size: 1.2rem;
font-weight: 700;
text-align: center;
color: #fff;
border-radius: 70px;
border: 1px solid var(--themeColor);
line-height: 68px;
z-index: 1;
right: -10px;
top: -10px;
}

.beforeAfterFlex .arrow {
position: absolute;
width: 140px;
margin: auto;
z-index: 1;
top: 45%;
left: 50%;
transform: translateY(-45%)translateX(-50%);
}

.wrapWorksDetail {
margin: 50px auto;
margin-top: 20px;
}

.worksDetailFlex {
padding: 20px 0;
display: flex;
justify-content: space-between;
border-bottom: 1px dotted #ccc
}

.worksDetailFlex:first-child {
border-top: 1px dotted #ccc
}

.worksDetailItem {
width: 150px;
}

.worksDetailItem span {
background-color: var(--txtColor);
width: 130px;
height: 28px;
color: #fff;
text-align: center;
display: block;
border-radius: 50px;
line-height: 25px;
}

.worksDetailCon {
width: 83%;
}

.stateFlex {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.stateWrap {
width: 48%;
margin-bottom: 30px;
}

.stateWrap div {
width: 100%;
height: 335px;
margin-bottom: 20px;
overflow: hidden;
border-radius: 20px;
}

.stateWrap div img {
width: 100%;
height: 335px;
object-fit: cover;
}

.postSide {
width: 220px;
}

.postSide h3 {
position: relative;
font-size: 1.4rem;
font-weight: 700;
margin-bottom: 20px;
padding-bottom: 5px;
border-bottom: 1px solid #ddd;
}

.postSide ul {
margin-bottom: 40px;
}

.postSide li {
font-size: 1.4rem;
list-style: none;
}

.postTagList {
display: flex;
justify-content: flex-start;
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: 100%;
margin-bottom: 20px;
}

.worksSideRankingWrap .number,
.blogSideRankingWrap .number {
position: relative;
font-family: var(--font-kodchasan);
font-size: 1.5rem;
font-weight: 700;
color: var(--themeColor);
margin-bottom: 10px;
line-height: 1;
}

.worksSideRanking {
position: relative;
width: 100%;
}

.worksSideRanking a {
color: #fff;
text-decoration: none;
}

.worksSideRanking .worksPhoto {
position: relative;
width: 100%;
height: 150px;
overflow: hidden;
border-radius: 20px;
}

.worksSideRanking .worksPhoto img {
width: 100%;
height: 150px;
object-fit: cover;
transition: .3s ease-in-out;
}

.worksSideRanking .worksPhoto:hover img {
transform: scale(1.1);
}

.worksSideRanking .inner {
position: relative;
background-color: 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 20px 20px;
transition: .3s;
z-index: 1;
}

.worksSideRanking h4 {
font-size: 1.3rem;
color: #fff;
margin-bottom: 5px;
line-height: 1.5;
transition: .3s;
}

.worksSideRanking:hover h4 {
color: #fff;
}

.worksSideRanking .inner:hover h4 {
color: #fff;
}

.blogSideRankingWrap .blogCo {
width: 100%;
margin-bottom: 0;
border-radius: 20px;
}

.blogSideRankingWrap .blogCo a {
color: #fff;
}

.blogSideRankingWrap .blogCo a:hover {
color: #fff;
}

.blogSideRankingWrap .blogPhoto {
width: 100%;
height: 150px !important;
overflow: hidden;
}

.blogSideRankingWrap .blogPhoto img {
width: 100%;
height: 150px !important;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogSideRankingWrap .blogPhoto:hover img {
transform: scale(1.1);
}

.blogSideRankingWrap .blogCo .inner {
background-color: var(--txtColor);
font-size: 1.3rem;
line-height: 1.5;
padding: 15px 20px 18px;
}

#relatedArticlesPost {
width: 100%;
margin-bottom: 100px;
display: flex;
justify-content: space-between;
}

#relatedArticlesPost a {
color: #fff;
text-decoration: none;
}

#relatedArticlesPost .works,
#relatedArticlesPost .blogCo {
position: relative;
width: 31%;
margin: 0;
border-radius: 20px;
}

#relatedArticlesPost .blogCo a:hover {
color: #fff;
}

#relatedArticlesPost .works .worksPhoto,
#relatedArticlesPost .blogCo .blogPhoto {
position: relative;
width: 100%;
height: 220px;
overflow: hidden;
}

#relatedArticlesPost .works .worksPhoto img,
#relatedArticlesPost .blogCo .blogPhoto img {
width: 100%;
height: 220px;
object-fit: cover;
transition: .3s ease-in-out;
}

#relatedArticlesPost .works .worksPhoto:hover img {
transform: scale(1.1);
}

#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 {
padding: 18px 25px 22px;
}

#relatedArticlesPost .blogCo .inner h3 {
font-weight: 400;
margin: 0 0 5px;
padding: 0;
border: 0;
}

#relatedArticlesPost .works .inner:hover h3 {
color: #fff;
}

#relatedArticlesPost .works h3 {
font-size: 1.4rem;
color: #fff;
margin-top: 0;
margin-bottom: 5px;
padding-left: 0;
border-left: 0;
transition: .3s;
}

/**/

.wrapConstruction {
width: 95%;
margin: 0 auto;
padding: 120px 0 0;
}

.wrapConstruction .conwide {
width: 31.5% !important;
margin-bottom: 60px;
}

.wrapConstruction .constructionTitle {
height: 180px;
}

.wrapConstruction .conwide h3 {
font-size: 3rem;
line-height: 1.6;
}

.wrapConstruction .conwide h3 span {
font-size: 1.8rem;
}

.wrapConstruction .construction:nth-child(2) {
margin-top: 0;
}

.wrapConstruction .construction:nth-child(3) {
margin-top: 0;
}

.construction .constructionPhotoCo {
background-color: var(--txtColor);
border-radius: 0 0 25px 25px;
}

.wrapConstruction .constructionPhotoCo img {
width: 100%;
border-radius: 25px;
}

.wrapConstructionBottom {
width: 1000px;
margin: 0 auto;
margin-bottom: -100px;
}

.wrapConstructionBottom .construction {
width: 48%;
margin-bottom: 50px !important;
}

.wrapConstructionBottom .constructionTitle {
border-radius: 20px !important;
}

.wrapConstructionBottom .constructionTitle {
height: 180px;
}

.wrapConstructionBottom .constructionTitle h3 {
font-size: 2.3rem;
line-height: 1.7;
}

/**/

#blogNav {
margin-bottom: 60px;
border-bottom: 1px solid var(--txtColor);
}

#blogNav ul {
display: flex;
justify-content: center;
}

#blogNav ul li {
background-color: var(--txtColor);
min-width: 200px;
text-align: center;
margin: 0 5px;
border-left: 1px solid var(--txtColor);
border-top: 1px solid var(--txtColor);
border-right: 1px solid var(--txtColor);
border-radius: 15px 15px 0 0;
transition: .3s;
}

#blogNav ul li:hover {
background-color: var(--themeColor);
border-left: 1px solid var(--themeColor);
border-top: 1px solid var(--themeColor);
border-right: 1px solid var(--themeColor);
}

#blogNav ul li a {
width: 100%;
height: 100%;
font-weight: 600;
color: #fff;
padding: 12px 20px;
display: block;
transition: .3s;
}

#blogNav ul li a:hover {
color: #fff;
}

/**/

#blogFlex {
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
}

.blogCo {
position: relative;
background-color: #fff;
width: 372px;
font-size: 1.4rem;
margin-right: 42px;
margin-bottom: 42px;
overflow: hidden;
border-radius: 30px;
line-height: 1.7;
}

.blogCo:nth-of-type(3n) {
margin-right: 0;
}

.blogCo .blogPhoto {
position: relative;
width: 100%;
height: 230px;
overflow: hidden;
border-radius: 20px 20px 0 0;
}

.blogCo .blogPhoto img {
width: 100%;
height: 230px;
object-fit: cover;
transition: .3s ease-in-out;
}

.blogCo .blogPhoto:hover img {
transform: scale(1.1);
}

.blogCo .inner {
background-color: var(--txtColor);
text-align: justify;
padding: 26px 30px;
}

.blogCo .inner h3 {
font-size: 1.5rem;
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.3rem;
}

.blogCo a {
color: #fff;
transition: .3s;
}

#supervisorWrap {
background-color: var(--subColor);
width: 100%;
margin: 40px auto;
padding: 30px 60px;
border-radius: 20px;
display: flex;
justify-content: space-between;
align-items: center;
}

#supervisorPhotoWrap {
position: relative;
width: 150px;
}

#supervisorPhoto {
width: 150px;
height: 150px;
overflow: hidden;
border-radius: 150px;
}

#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.4rem;
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: 610px;
}

#supervisorName {
font-size: 1.8rem;
font-weight: 600;
}

#toc_container {
background-color: var(--subColor);
width: 100%;
margin: 60px auto;
margin-top: 40px;
padding: 30px 40px 36px;
border-radius: 20px;
}

.toc_title {
font-size: 2rem;
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.6rem;
}

.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.5rem;
margin-left: 15px;
}

/**/

#postTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 10px;
background-size: 30px;
font-size: 3.2rem;
font-weight: 700;
padding-left: 46px;
padding-bottom: 25px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

#postDate {
font-family: var(--font-kodchasan);
font-weight: 700;
margin-bottom: 20px;
}

#postDateNews {
font-family: var(--font-kodchasan);
font-weight: 700;
margin-top: 23px;
margin-bottom: 40px;
}

#categoryPost {
background-color: var(--txtColor);
width: 170px;
height: 30px;
font-size: 1.2rem;
text-align: center;
color: #fff;
margin-bottom: 40px;
line-height: 28px;
border-radius: 0 0 10px 0;
}

.postBlogThumbnail {
margin-bottom: 40px;
}

.post h2 {
font-size: 2.8rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 5px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h3 {
font-size: 2.4rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 4px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h4 {
font-size: 2rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 3px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

.post h5 {
font-size: 1.7rem;
font-weight: 700;
margin-top: 50px;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 2px;
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-top: 60px;
display: flex;
justify-content: space-between;
align-items: center;
}

#prevNextWrap a {
text-decoration: none;
}

.btnBackToList {
background-color: #fff;
font-family: var(--font-primary);
width: 200px;
height: 60px;
font-size: 1.4rem;
color: var(--themeColor);
cursor: pointer;
padding-bottom: 3px;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px;
transition: .3s;
}

.btnBackToList:hover {
background-color: var(--themeColor);
color: #fff;
}

.btnPrevWrap,
.btnNextWrap {
width: 12%;
}

.btnPrev,
.btnNext {
position: relative;
background: transparent;
width: auto;
height: 25px;
font-size: 1.4rem;
text-align: left;
color: var(--themeColor);
padding-left: 20px;
padding-right: 0;
white-space: nowrap;
border: none;
cursor: pointer;
line-height: 23px;
}

.btnNext {
text-align: right;
padding-left: 0;
padding-right: 20px;
}

.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;
}

.btnNext:hover::after {
right: 0;
}

.btnPrev:hover::after {
left: 0;
}

.wp-block-image {
margin-bottom: 40px;
}

/**/

.pageNavi {
font-family: var(--font-kodchasan);
margin: 0 auto;
margin-top: 50px;
}

.wp-pagenavi {
position: relative;
font-size: 1.2rem;
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
line-height: 42px;
}

.wp-pagenavi .pages {
display: none;
}

.wp-pagenavi .page {
margin: 0 3px;
}

.wp-pagenavi .current {
background-color: var(--txtColor);
width: 45px;
height: 45px;
color: #fff;
margin: 0 3px;
display: block;
border: 1px solid var(--txtColor) !important;
border-radius: 10px;
}

.wp-pagenavi a,
.wp-pagenavi .extend {
width: 45px;
height: 45px;
display: block;
border: 1px solid var(--themeColor) !important;
border-radius: 10px;
}
.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;
margin: 0 3px;
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;
}

/**/

#messageFlex {
display: flex;
justify-content: space-between;
}

#messageL {
width: 650px;
font-size: 1.6rem;
text-align: justify;
line-height: 2.5;
}

#messageL:last-child p {
margin-bottom: 0;
}

#messageR {
width: 490px;
}

#messagePhoto {
position: relative;
overflow: hidden;
border-radius: 30px;
}

#messagePhoto #nameEn {
position: absolute;
font-family: var(--font-kodchasan);
font-size: 5rem;
color: #eee;
z-index: 1;
line-height: 1;
left: 0;
right: 0;
bottom: -6px;
}

#messageR #name {
font-size: 1.6rem;
margin-top: 20px;
}

#messageR #name span {
font-size: 2.2rem;
margin-left: 20px;
}

.wrapCompany {
width: 900px;
margin: 0 auto;
}

.wrapCompany dd {
padding: 30px 0 30px 200px;
}

/**/

.privacy h2 {
position: relative;
font-size: 2.2rem;
font-weight: 700;
margin: 30px auto;
margin-top: 40px;
padding-bottom: 15px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

/**/

#wrapContactBottomBlog {
position: relative;
width: 1200px;
margin: 0 auto;
padding: 40px 0;
}

#wrapRelatedArticles {
position: relative;
background-color: #fcf8ee;
width: 100%;
text-align: justify;
margin: 0 auto;
margin-bottom: -120px;
padding: 40px 0 120px;
border-radius: 0 0 30px 30px;
z-index: 1;
}

#wrapRelatedArticles h2 {
font-size: 2.8rem;
font-weight: 700;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 5px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

#prevNextWrapBlog {
width: 85%;
margin: 0 auto;
}

/**/

#wrapContact {
position: relative;
background-color: #fcf8ee;
width: 1200px;
text-align: justify;
margin: 0 auto;
margin-bottom: -140px;
padding: 80px 100px;
border-radius: 0 0 30px 30px;
z-index: 1;
}

.contactSubTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 10px;
background-size: 30px;
font-size: 3.2rem;
font-weight: 700;
margin-bottom: 36px;
padding-left: 46px;
padding-bottom: 25px;
border-bottom: 1px solid #ddd;
line-height: 1.4;
}

.flowWrapCo {
margin-bottom: 100px !important;
}

.contactCallWrap {
position: relative;
background-color: #ffff;
font-family: var(--font-kodchasan);
width: 100%;
font-size: 5rem;
font-weight: 600;
color: var(--themeColor);
text-align: center;
margin: 40px auto;
margin-bottom: 80px;
padding: 40px 40px 50px;
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.5rem;
margin-left: 25px;
line-height: 1.5;
}

.contactTxt {
text-align: center;
margin-bottom: 45px;
}

.contactFlex {
width: 100%;
color: var(--txtColor);
padding: 30px 0;
display: flex;
justify-content: space-between;
align-items: center;
border-top: 1px dotted #ccc;
}

.contactFlex p {
margin-bottom: 0;
}

.contactL {
width: 300px;
}

.contactR {
width: 700px;
text-align: left;
}

.contactR .inputW {
background-color: #fff;
font-family: var(--font-primary);
width: 100%;
height: 80px;
font-size: 1.5rem;
padding: 20px;
border: 1px solid #fff;
border-radius: 10px;
transition: .3s;
}

.contactR .inputW:hover {
background-color: #fff;
border: 1px solid var(--themeColor);
}

.contactR textarea {
background-color: #fff;
font-family: var(--font-primary);
width: 100%;
height: 250px;
font-size: 1.5rem;
font-weight: 500;
color: var(--txtColor);
padding: 20px;
border: 1px solid #fff;
border-radius: 10px;
transition: .3s;
}

.contactR textarea:hover {
background-color: #fff;
border: 1px solid var(--themeColor);
}

.required,
.any {
position: relative;
background-color: #da2124;
width: 46px;
height: 22px;
font-size: 1.1rem;
font-weight: 600;
color: #fff;
text-align: center;
display: inline-block;
margin-right: 10px;
border-radius: 300px;
line-height: 20px;
top: -1px;
}

.any {
background-color: #ccc;
}

.formSelect {
position: relative;
}

.formSelect select {
position: relative;
background-color: #fff;
font-family: var(--font-primary);
width: 100%;
height: 80px;
font-size: 1.5rem;
font-weight: 500;
color: var(--txtColor);
padding: 20px;
border: 1px solid #fff;
border-radius: 10px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
transition: .3s;
}

.formSelect select:hover {
background-color: #fff;
border: 1px solid var(--themeColor);
}

.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: 30px;
}

.checkWrap {
width: 100%;
text-align: center;
margin-bottom: 30px;
padding-top: 40px;
border-top: 1px dotted #ccc;
}

.checkWrap a {
color: var(--themeColor);
text-decoration: underline;
}

.checkWrap input[type="checkbox"] {
margin: 0;
padding: 0;
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;
}

.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;
margin-right: 7px;
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;
margin-bottom: 30px;
}

.wpcf7-submit {
background-color: var(--themeColor);
font-family: var(--font-primary);
width: 300px;
height: 90px;
font-size: 2rem;
font-weight: 600;
color: #fff;
padding-bottom: 5px;
cursor: pointer;
transition: .3s;
border: 2px solid var(--themeColor);
border-radius: 500px;
}

.wpcf7-submit:hover {
background-color: #fff;
color: var(--themeColor);
}

.thanksTxt {
text-align: center;
padding: 40px 0;
}

/**/

.staffFlex {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.staff {
position: relative;
width: 45%;
padding-bottom: 60px;
}

.staff:nth-of-type(2n) {
margin-top: 80px;
}

.staffPhoto {
width: 100%;
height: 600px;
overflow: hidden;
border-radius: 30px;
}

.staffPhoto img {
width: 100%;
height: 600px;
object-fit: cover;
transition: .6s;
}

.staffPhoto img:hover {
transform: scale(1.05);
}

.staff h2,
.staff h3 {
position: absolute;
font-size: 3.5rem;
font-weight: 700;
writing-mode: vertical-rl;
text-align: left;
color: #fff;
margin: 0 0 0 auto;
white-space: nowrap;
line-height: 1.7;
z-index: 2;
right: -40px;
top: 40px;
}

.staff h2 span,
.staff h3 span {
background-color: var(--txtColor);
margin: 0 12px;
padding: 15px 0;
display: table;
border-radius: 5px;
}

.affiliationNameFlex {
position: absolute;
background-color: var(--txtColor);
min-width: 320px;
height: 70px;
color: #fff;
padding: 0 20px;
border-radius: 0 10px 0 30px;
line-height: 68px;
z-index: 2;
left: 0;
top: 530px;
display: flex;
justify-content: center;
align-items: center;
}

.staff .name,
.staffCo .name {
position: relative;
font-size: 3rem;
font-weight: 700;
line-height: 1;
top: -3px;
}

.staff .affiliation,
.staffCo .affiliation {
height: 30px;
font-size: 1.3rem;
margin-right: 20px;
padding: 0 10px;
border: 1px solid #fff;
line-height: 26px;
}

.staffCo {
position: relative;
width: 100%;
margin-bottom: 60px;
}

.staffPhotoCo {
width: 100%;
overflow: hidden;
border-radius: 30px;
}

.staffCo h1 {
position: absolute;
font-size: 3.7rem;
font-weight: 700;
writing-mode: vertical-rl;
text-align: left;
color: #fff;
white-space: nowrap;
line-height: 1.7;
z-index: 2;
right: 40px;
top: 50px;
}

.staffCo h1 span {
background-color: var(--txtColor);
margin: 0 12px;
padding: 15px 0;
display: table;
border-radius: 5px;
}

.affiliationNameFlexCo {
position: absolute;
background-color: var(--txtColor);
min-width: 330px;
height: 70px;
color: #fff;
padding: 0 20px;
border-radius: 0 10px 0 30px;
line-height: 68px;
z-index: 2;
left: 0;
bottom: 0;
display: flex;
justify-content: center;
align-items: center;
}

.staff .staffEn {
position: absolute;
width: 70px;
opacity: .5;
z-index: 1;
left: -2px;
top: 50px;
}

.staffCo .staffEn {
position: absolute;
width: 65%;
opacity: .5;
z-index: 1;
right: 40px;
bottom: -2px;
}

.staffTitle {
position: relative;
background: url("../img/sub_title.svg") no-repeat left 10px;
background-size: 30px;
font-size: 3.2rem;
font-weight: 700;
margin-bottom: 30px;
padding-left: 46px;
line-height: 1.5;
}

.question {
font-family: var(--font-kodchasan);
font-size: 1.8rem;
color: var(--themeColor);
font-weight: 600;
margin-top: 60px;
}

.question span {
font-size: 2.8rem;
font-weight: 400;
margin-left: 5px;
}

.wrapInterview {
width: 1000px;
text-align: justify;
margin: 0 auto;
}

.staffPhotoCo2 {
width: 100%;
margin: 50px auto;
margin-bottom: 40px;
overflow: hidden;
border-radius: 30px;
}

#prevNextWrapStaff {
margin: 80px auto;
}

#wrapOtherStaff {
margin-top: 100px;
}

#wrapOtherStaff h2 {
font-size: 2.8rem;
font-weight: 700;
margin-bottom: 36px;
padding-left: 15px;
padding-bottom: 5px;
line-height: 1.4;
border-left: 3px solid  var(--themeColor);
}

/**/

.privacy {
text-align: justify;
padding-bottom: 100px;
}

.privacy h2 {
font-size: 2rem;
font-weight: 700;
margin-bottom: 30px;
}

/**/

#wrapContactBottom {
position: relative;
width: 1200px;
margin: 0 auto;
margin-bottom: -140px;
padding: 120px 0 0;
z-index: 1;
}

#contactBottomWrap {
position: relative;
background: url("../img/contact_bottom_bg.webp") no-repeat center bottom;
background-size: cover;
width: 1200px;
color: #fff;
margin: 0 auto;
padding: 90px 30px 100px;
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: 2.2rem;
font-weight: 600;
margin-bottom: 60px;
z-index: 2;
}

#contactBottomWrap h4 {
position: relative;
font-size: 2rem;
margin-bottom: 10px;
z-index: 2;
}

#contactBottomFlex {
position: relative;
display: flex;
justify-content: center;
z-index: 2;
}

.contactBottomLr {
margin: 0 20px;
}

.btnContact {
background-color: var(--themeColor);
width: 480px;
height: 120px;
font-size: 2.5rem;
font-weight: 700;
color: #fff;
padding-bottom: 5px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btnContact i {
position: relative;
font-size: 3rem;
margin-right: 5px;
top: 3px;
}

.btnContact:hover {
background-color: #fff;
color: var(--themeColor);
}

.btnCall {
background-color: #fff;
font-family: var(--font-kodchasan);
width: 480px;
height: 120px;
font-size: 3.8rem;
font-weight: 700;
color: var(--themeColor);
padding-bottom: 10px;
cursor: pointer;
border: 1px solid var(--themeColor);
border-radius: 20px 5px 20px 5px;
transition: .3s;
}

.btnCall i {
margin-right: 10px;
}

.btnCall span {
font-family: var(--font-primary);
font-size: 1.3rem;
display: block;
}

.btnCall:hover {
background-color: var(--themeColor);
color: #fff;
}

/**/

footer {
position: relative;
background-color: var(--subColor);
width: 100%;
font-size: 1.4rem;
padding: 200px 0 0;
border-radius: 30px 30px 0 0;
}

#footerNav {
margin-bottom: 80px;
}

#footerNav ul {
position: relative;
width: 1200px;
margin: 0 auto;
margin-bottom: 30px;
display: flex;
justify-content: center;
}

#footerNav ul li {
width: 250px;
text-align: center;
border-left: 1px dotted var(--txtColor);
}

#footerNav ul li:last-child {
border-right: 1px dotted  var(--txtColor);
}

#footerNav ul li a {
position: relative;
font-size: 1.4rem;
font-weight: 700;
text-decoration: none;
display: table;
margin: 0 auto;
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;
}

#footerNav ul li a::after {
position: absolute;
background-color: var(--themeColor);
content: "";
width: 100%;
height: 1px;
bottom: -6px;
left: 0;
-webkit-transform: scale(0, 1);
transform: scale(0, 1);
-webkit-transform-origin: center top;
transform-origin: center top;
-webkit-transition: all 0.3s ease;
transition: all 0.3s ease;
}

#footerNav ul li a:hover::after {
transform: scale(1, 1);
}

#footerBottom {
position: relative;
width: 1200px;
margin: 0 auto;
display: flex;
justify-content: space-between;
}

#footerL {
width: 45%;
text-align: left;
}

#footerLogo {
width: 254px;
margin-bottom: 30px;
}

#footerSns {
width: 100%;
margin-bottom: 30px;
display: flex;
justify-content: flex-start;
}

#footerSns li {
font-size: 3.2rem;
margin-right: 12px;
}

#footerTel {
font-size: 3rem;
line-height: 1;
}

#footerTel span {
font-family: var(--font-kodchasan);
font-weight: 600;
}

#astecLogo {
width: 130px;
margin: 30px 0 60px;
overflow: hidden;
border-radius: 10px;
}

#footerR {
width: auto;
text-align: center;
display: table;
line-height: 1;
}

#footerR h6 {
position: relative;
font-size: 3.2rem;
font-weight: 600;
margin-bottom: 30px;
padding-top: 40px;
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: 1.7rem;
font-weight: 700;
color: var(--themeColor);
display: block;
margin-top: 10px;
}

#footerServiceArea {
background-color: #463a3d;
width: 500px;
height: 500px;
margin: 35px auto;
margin-bottom: 0;
overflow: hidden;
border-radius: 500px;
}

#copyRight {
background-color: var(--txtColor);
font-family: var(--font-kodchasan);
width: 100%;
font-size: 1rem;
font-weight: 500;
color: #fff;
margin-top: -25px;
padding: 30px;
}

#btnContactSp {
display: none;
}

#pagetop {
position: fixed;
background-color: var(--themeColor);
width: 100px;
height: 100px;
border-radius: 20px 0 0;
bottom: -100px;
right: 0;
transition: .3s;
z-index: 1010;
}

#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;
}

}