@charset "utf-8";
/* CSS Document */

.main{ padding-top: 1px; margin-top: -1px;}


.wrap1{ max-width: 1140px; width: 90%;}
.wrap2{ max-width: 1200px; width: 100%;}
.wrap3{ max-width: 980px; width: 90%;}

.title1l{ border-left: 15px solid var(--color-bu); padding: 10px 0 10px 85px; text-align: left;}
.title1r{ border-right: 15px solid var(--color-bu); padding: 10px 85px 10px 0; text-align: right;}
.title1-eng{ color: var(--color-pi); font-family: 'Cabin', sans-serif; font-weight: 700; font-size: 3.5rem; line-height: 1.0; margin-bottom: 10px;}
.title1 h2{ font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; letter-spacing: 0; font-size: 4.5rem; line-height: 1.4; color: var(--color-db);}
.title1 h2 .font-small{ font-size: 60%; margin-left: 1em;}
.title1l p{ text-align: left;/* padding-bottom: 20px;*/}
.title1r p{ text-align: right;/* padding-bottom: 20px;*/}

@media screen and (max-width: 719px) {
  .title1l{ border-left: 10px solid var(--color-bu); padding: 10px 0 10px 8%;}
  .title1r{ border-right: 10px solid var(--color-bu); padding: 10px 8% 10px 0;}
  .title1-eng{ font-size: 2.4rem;}
  .title1 h2{ font-size: 3.2rem;}
}
@media screen and (max-width: 419px) {
  .title1-eng{ font-size: 2.0rem;}
  .title1 h2{ font-size: 2.2rem;}
}


/* ====== header ====== */

.header{ position: fixed; top: 0; left: 0; max-width: 1920px; width: 100%; max-height: 70px; width: 100%; height: 100%; aspect-ratio: 1242 / 70; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: no-wrap; background-color: #fff; z-index: 10;}
.header-logo{ max-width: 600px;  width: 100%; display: flex; align-items: center;}
.header-logo a{ width: 100%; display: flex; align-items: center;}
.logo-pc{display: none; width: 100%; line-height: 1px;}
.logo-sp{display: inline; width: 100%; line-height: 1px;}

.header-nav{ width: 70%; max-width: 800px; padding: 0 80px 0 30px; display: flex; justify-content: space-between; align-items: center;}
.smaller .header-nav{display: none;}
.header-tel{ width: 28.3%;}
.header-tel a{ display: block; transition: 0.5s all;}
.header-tel a:hover{ opacity: 0.7;}
.header-contact{ width: 34.3%;}
.header-contact a{ display: block; transition: 0.5s all;}
.header-contact a:hover{ opacity: 0.7;}
.headerback{ max-width: 1242px; max-height: 70px; width: 100%; height: 100%; aspect-ratio: 1242 / 70;}
@media screen and (max-width: 1399px) {
  .header-logo{ max-width: 400px; width: 35%; padding: 0 0 0 1.56%; display: flex; align-items: center;}
  .logo-pc{display: inline; width: 100%;}
  .logo-sp{display: none;}
}
@media screen and (max-width: 1200px) {
  .header-nav{ display: none;}
}
@media screen and (max-width: 719px) {
  .header{ position: fixed; height: 50px; padding: 10px 0;}
  .header-logo{ width: calc(100% - 50px); padding: 0 20px; text-align: center;}
  .logo-pc{display: none;}
  .logo-sp{display: inline;}
  .header-nav{ width: 100%; padding-bottom: 2px; display: none;}
  .header-tel{ width: 39%; padding: 0;}
  .header-contact{ width: 20%;}
  .headerback{ height: 50px;}
}
@media screen and (max-width: 479px) {
  .header .pconly{ display: none;}
}



/* ====== topimage ====== */

.topimgback{ background: linear-gradient(110deg, #c2e1fc, #fefef8); width: 100%; height: calc(100vh - 70px); padding: 1px;}
.topimg{ width: 100%; height: 100%; background-image: url("../imagesclinic2023/topimg1pc.avif"),url("../imagesclinic2023/topimg1pc.png"); background-position: top right; background-repeat: no-repeat; background-size: contain; padding: 2.0% 2.63%; max-width: 2200px;}
.toptext{ width: 50%; height: 100%; max-width: 900px;}
.toptext{ display: flex; flex-direction: column; justify-content: space-between; }
.toptext-p1{ width: 100%;}
.toptext-p2{ width: 100%;}

@media screen and (max-width: 1800px) {
  .topimgback{ height: inherit;}
  .toptext{ padding: 20px 0;}
  .toptext-p1{ margin-bottom: 5vw;}
  .toptext-p2{ margin-top: 5vw;}
}
@media screen and (max-width: 1299px) {
  .topimg{ padding: 2.0% 2.63%; margin-top: 60px;}
  .toptext{ width: 65%; margin-top: -60px;}
  .toptext-p1{ margin-bottom: 5vw; padding: 0 3% 0 3%;}
  .toptext-p2{ margin-top: 1vw; padding: 0 3% 0 3%; width: 90%;}
}
@media screen and (max-width: 900px) {
  .topimgback{ aspect-ratio: 810 / 846; padding-bottom: 10px;}
  .topimg{ background-image: url("../imagesclinic2023/topimg1sp.avif"),url("../imagesclinic2023/topimg1sp.png"); background-position: bottom center; background-repeat: no-repeat; background-size: contain; padding: 50px 2.63%; width: 100%; margin-top: 50px;}
  .toptext{ width: 80%; justify-content: flex-start; margin-top: -50px;}
  .toptext-p1{ margin-bottom: 3vw; padding: 0 3% 0 3%;}
  .toptext-p2{ margin-top: 5vw; padding: 0 3% 0 3%; width: 90%;}
}
@media screen and (max-width: 640px) {
  .topimg{ padding: 3vw 2.63%; width: 100%;}
  .toptext{ width: 90%;}
  .toptext-p1{ margin-bottom: 2vw;}
  .toptext-p2{ margin-top: 4vw;}
}
@media screen and (max-width: 479px) {
  .topimgback{ aspect-ratio: 810 / 920;}
  .topimg{ padding: 1vw 2.63%;}
  .toptext{ width: 100%;}
  .toptext-p1{ margin-bottom: 3vw;}
  .toptext-p2{ margin-top: 5vw;}
}

.topbtnnew{ position: relative; display: flex; justify-content: space-between; align-items: flex-end; max-width: 700px; width: 100%; padding: 2% 5%; border-radius: 2vw;}
.topbtnnew_img{ width: 34%; margin-right: -4%; z-index: 1;}
.topbtnnew a{ position: relative; display: block; width: 70%; margin: 0 auto; background-color: #F8779A; color: #fff; font-size: 14px; text-align: center; padding: 12px; overflow: hidden; border-radius: 80px; margin-bottom: 20px; filter: drop-shadow(0 3px 3px rgba(0,0,0,0.40)); opacity: 1.0; transition: opacity 0.6s;}
.topbtnnew a:hover{ opacity: 0.7;}
.topbtnnew span{ display: block; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; font-size: 30px; line-height: 1.2;}
.topbtnnew a i{ position: absolute; right: 16px; top: 50%; transform: translateY(-50%); font-size: 30px;}
@media screen and (max-width: 1299px) {
  .topbtnnew{  width: 100%;}
  .topbtnnew a{ font-size: 12px; padding: 10px; border-radius: 80px; margin-bottom: 15px;}
  .topbtnnew span{ font-size: 26px;}
  .topbtnnew a i{ right: 12px; font-size: 24px;}
}
@media screen and (max-width: 1000px) {
  .topbtnnew a{ font-size: 10px; padding: 10px; border-radius: 80px; margin-bottom: 10px;}
  .topbtnnew span{ font-size: 23px;}
}
@media screen and (max-width: 900px) {
  .topbtnnew{ width: 100%; margin-top: 2vw; padding: 3% 5% 5% 5%; max-width: none; background-color: rgba(255,255,255,0.67); border: 1px solid #fff;}
  .topbtnnew_img{ width: 30%; margin-right: -5%; z-index: 1;}
  .topbtnnew a{ font-size: 1.6vw; width: 75%; padding: 5px; margin-bottom: 0;}
  .topbtnnew span{ font-size: 3.8vw;}
  .topbtnnew a i{ font-size: 4vw; right: 10px;}
}


/* ====== contact banner ----- */

.contactbanner{ background-color: var(--color-bu); width: 100%; padding: 1px;}
.contactbannerbox{ margin: 50px auto; display: flex; justify-content: space-between; align-items: center;}
.contactbannerbox1 { display: none;}
.contactbannerbox2 { width: 51%; text-align: center;}
.contactbannerbox2 p{ display: inline-block; position: relative; text-align: center; font-size: 1.8rem; line-height: 1.2; color: #fff; margin-bottom: 15px; padding: 0 20px;}
.contactbannerbox2 p::before,.contactbannerbox2 p::after{ position: absolute; width: 2px; height: 80%; content: ""; background-color: #fff;}
.contactbannerbox2 p::before{ bottom: 0; left: -10px; transform: rotate(-45deg);}
.contactbannerbox2 p::after{ bottom: 0; right: -10px; transform: rotate(45deg);}
.contactbannerbox2 a{ display: flex; justify-content: center; align-items: center; position: relative; padding: 0.4em 10px; background-color: #fff; color: var(--color-pi); font-size: 3.2rem; line-height: 1.2; border: 5px solid var(--color-pi); border-radius: 100px; transition: 0.5s all;}
.contactbannerbox2 a:hover{ background-color: rgba(255,228,240,1.00);}
.contactbannerbox2 a div{ text-align: center; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; letter-spacing: 0;}
.contactbannerbox2 a i{ position: absolute; right: 10px; top: 50%; transform: translateY(-50%);}
/*.contactbannerbox2 a i{ display: block; width: 35px; height: 35px; line-height: 35px; margin-left: 5px;}*/
.contactbannerbox2 a i img{ width: 35px;}
.contactbannerbox3 { width: 44%; aspect-ratio: 504 / 287; display: block; background-image: url("../imagesclinic2023/contactimg.avif"),url("../imagesclinic2023/contactimg.png"); background-position: center center; background-repeat: no-repeat; background-size: cover; border: 5px solid #fff; border-radius: 20px;}
@media screen and (max-width: 1099px) {
  .contactbannerbox{ margin: 36px auto;}
  .contactbannerbox2 a{ font-size: 2.4rem;  border: 3px solid var(--color-pi); border-radius: 60px;}
  .contactbannerbox2 a i{ width: 25px; height: 25px; line-height: 25px;}
  .contactbannerbox2 a i img{ width: 25px;}
  .contactbannerbox3 { border: 3px solid #fff;}
}
@media screen and (max-width: 719px) {
  .contactbannerbox2 a{ font-size: 2.0rem; line-height: 1.2;}
  .contactbannerbox2 a i{ width: 20px; height: 20px; line-height: 20px;}
  .contactbannerbox2 a i img{ width: 20px;}
  .contactbannerbox2 p{ font-size: 1.5rem; line-height: 1.2; margin-bottom: 1em;}
  .contactbannerbox3 { border: 2px solid #fff; border-radius: 10px;}
}
@media screen and (max-width: 599px) {
  .contactbannerbox{ align-items: stretch;}
  .contactbannerbox2{ width: 58%;}
  .contactbannerbox3{ width: 37%; aspect-ratio: unset;}
  .contactbannerbox2 p{ font-size: 1.3rem; margin-bottom: 0.6em; padding: 0 10px;}
}
@media screen and (max-width: 499px) {
  .contactbannerbox2 { width: 70%;}
  .contactbannerbox3{ width: 25%;}
  .contactbannerbox2 a{ padding: 0.5em 0.3em; font-size: 1.6rem;}
  .contactbannerbox2 p::before{ bottom: 0; left: -1px; transform: rotate(-35deg); width: 1px;}
  .contactbannerbox2 p::after{ bottom: 0; right: -1px; transform: rotate(35deg); width: 1px;}
}


/* ====== Solution ====== */

.solutionbox{ display: grid; grid-template-columns: repeat(2, 1fr); row-gap: 60px; column-gap: 20px; margin-top: 120px;}
.solutionbox div{ position: relative; border: 3px dashed var(--color-bu); background-color: var(--color-back-bu); border-radius: 20px; padding: 45px 20px 20px 20px; font-weight: 600;/*font-size: 2.0rem; font-weight: 700;*/}
.solutionbox div::before{ position: absolute; content: ""; width: 50px; height: 50px; left: 50%; top: 0; transform: translate(-50%,-50%);}
.solution_a{ margin-top: 1em; color: #0076B4; font-weight: 600;}
@media screen and (max-width: 949px) {
  .solutionbox{ grid-template-columns: repeat(2, 1fr); row-gap: 50px; column-gap: 18px; margin-top: 100px;}
  .solutionbox div{ border-radius: 18px; padding: 45px 15px 20px 15px;}
}
@media screen and (max-width: 719px) {
  .solutionbox{ grid-template-columns: repeat(1, 1fr); row-gap: 50px; column-gap: 16px; margin-top: 80px;}
  .solutionbox div{ border-radius: 16px; padding: 35px 10px 16px 10px;}
  .solutionbox div::before{ width: 40px; height: 40px;}
}
@media screen and (max-width: 479px) {
  .solutionbox{ grid-template-columns: repeat(1, 1fr); row-gap: 40px; column-gap: 0; margin-top: 60px;}
  .solutionbox div{ border-radius: 12px; padding: 26px 10px 16px 10px;}
  .solutionbox div::before{ width: 40px; height: 40px;}
}
.solutionbox div:nth-of-type(1)::before{ background: url("../imagesclinic2023/icons/sol_01.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(2)::before{ background: url("../imagesclinic2023/icons/sol_02.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(3)::before{ background: url("../imagesclinic2023/icons/sol_03.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(4)::before{ background: url("../imagesclinic2023/icons/sol_04.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(5)::before{ background: url("../imagesclinic2023/icons/sol_05.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(6)::before{ background: url("../imagesclinic2023/icons/sol_06.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(7)::before{ background: url("../imagesclinic2023/icons/sol_07.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(8)::before{ background: url("../imagesclinic2023/icons/sol_08.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(9)::before{ background: url("../imagesclinic2023/icons/sol_09.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(10)::before{ background: url("../imagesclinic2023/icons/sol_10.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(11)::before{ background: url("../imagesclinic2023/icons/sol_11.svg") center center no-repeat; background-size: contain;}
.solutionbox div:nth-of-type(12)::before{ background: url("../imagesclinic2023/icons/sol_12.svg") center center no-repeat; background-size: contain;}



/* ===== Q&A ===== */

.qandabox1 dt{ width: 100%; margin-top: var(--m-m); background-color: var(--color-bu); color: #fff; font-size: 2.5rem; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; line-height: 1.5; padding: 16px 30px; border-radius: 20px; text-align: justify;}
.qandabox1 dd{ margin-top: var(--m-s); text-align: justify; padding: 0 30px;}
@media screen and (max-width: 419px) {
  .qandabox1 dt{ font-size: 1.8rem; padding: 20px;}
  .qandabox1 dd{ margin-top: var(--m-s); padding: 0 20px;}
}

/*=========================================================
accordion faq
=========================================================*/
 
.accordion_area { margin-top: var(--m-m);}
.accordion_one .ac_header { position: relative; min-height: 60px; background-color: var(--color-bu); padding: 1.0rem 40px 1.0rem 80px; z-index: +1; cursor: pointer; transition: .2s; margin-bottom: 10px; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; font-size: 2.2rem; line-height: 1.4; color: #fff; border-radius: 36px;}
.accordion_one .ac_header::before, .accordion_one .ac_inner::before{ font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; font-size: 2.4rem; position: absolute; width: 60px; height: 60px; border-radius: 50%; text-align: center; line-height: 55px; }
.accordion_one .ac_header::before{ content: "Q"; color: #fff; left: 0px; top: 48%; transform: translateY(-50%);}
.accordion_one .ac_inner::before{ content: "A"; color: #fff; background-color: var(--color-pi); left: 0; top: 10px;}
.accordion_one .ac_header:not(.ac_open):hover { opacity: 0.9;}
.accordion_one .ac_header .i_box { position: absolute; top: 50%; transform: translateY(-50%); right: 20px; width: 20px; height: 20px;}
.accordion_one .ac_header .i_box::before, .accordion_one .ac_header .i_box::after { position: absolute; content: ""; margin: auto; box-sizing: border-box; vertical-align: middle;}
.accordion_one .ac_header .i_box::before { border-top: 2px solid var(--color-pi); width: 20px; height: 0; top: 0; bottom: 0; right: 0;}
.accordion_one .ac_header .i_box::after { border-left: 2px solid var(--color-pi); width: 0; height: 20px; top: 0; bottom: 0; right: 9px; transition: .3s;}
.accordion_one .ac_header.ac_open .i_box::after { height: 0;}
.accordion_one .ac_inner { position: relative; display: none; padding: 10px 10px 50px 80px; box-sizing: border-box; line-height: 1.6;}
@media screen and (max-width: 719px){
  .accordion_one .ac_header { min-height: 45px; padding: 10px 32px 10px 60px; font-size: 1.8rem; border-radius: 24px;}
  .accordion_one .ac_inner {  padding: 10px 10px 30px 60px;}
  .accordion_one .ac_header::before, .accordion_one .ac_inner::before{ font-size: 2.0rem;width: 45px; height: 45px; line-height: 45px;}
  .accordion_one .ac_header .i_box { width: 16px; height: 16px; right: 5px;}
}
@media screen and (max-width: 460px) {
  .accordion_one .ac_header { min-height: 45px; padding: 10px 32px 10px 50px; font-size: 1.8rem;}
  .accordion_one .ac_inner { padding: 10px 10px 30px 50px;}
  .accordion_one .ac_header::before, .accordion_one .ac_inner::before{ font-size: 2.0rem;width: 45px; height: 45px; line-height: 45px;}
  .accordion_one .ac_header .i_box { width: 16px; height: 16px;}
}






/* ====== Features ====== */

.feature1{ display: flex; justify-content: space-between; align-items: flex-start; flex-direction: row; margin-top: var(--m-l);}
.feature1-l{ position: relative; width: 48%; overflow: hidden; border: 3px solid var(--color-bu); border-radius: 20px;}
.feature1-l img{ width: 100%; aspect-ratio: 550 / 300; object-fit: cover; object-position: center center;}
.feature1-l span{ position: absolute; top: 0; left: 0; font-size: 2.5rem; line-height: 1.5; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; color: #fff; background: var(--color-bu); padding: 0.7em 0.8em 0.8em 0.8em; border-radius: 0 0 20px 0;}
.feature1-r{ width: 50%; text-align: justify;}
.feature1_ttl{ position: relative; font-size: 2.5rem; line-height: 1.4; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; border-radius: 10px; padding: 10px; color: #fff; background: var(--color-bu);}
.feature1_ttl i{ display: none; position: absolute; right: 10px; bottom: 10px; color: #fff;}
.featurebox1 .feature1:nth-of-type(2n){ flex-direction: row-reverse;}
.feature_text{ width: 95%; margin: 1em 2.5% 0 2.5%;}
@media screen and (max-width: 949px) {
  .feature1_ttl{ font-size: 2.2rem;}
}
@media screen and (max-width: 719px) {
  .feature1{ flex-wrap: wrap; margin-top: var(--m-m);}
  .feature1-l{ width: 100%; border-radius: 10px 10px 0 0;}
  .feature1-l span{ font-size: 1.8rem; padding: 0.5em 0.8em 0.6em 0.8em; border-radius: 0 0 10px 0;}
  .feature1-r{ width: 100%;}
  .feature1_ttl{ font-size: 1.8rem; line-height: 1.4; border-radius: 0 0 10px 10px; padding: 10px 25px 10px 10px;}
  .feature1_ttl i{  display:block; position: absolute; right: 10px; bottom: 10px; color: #fff;}
}

.accordion_area2 { }
.accordion_2 .ac_header2 { position: relative; z-index: +1; cursor: none; transition: .2s;}
.accordion_2 .ac_header2:not(.ac_open2):hover { opacity: 0.9;}
.accordion_2 .ac_inner2 { position: relative; display: block;}
@media screen and (max-width: 719px){
  .accordion_2 .ac_header2 { cursor: pointer;}
  .accordion_2 .ac_inner2 { position: relative; display: none;}
}
@media screen and (max-width: 460px) {
  .accordion_2 .ac_header2 { }
  .accordion_2 .ac_inner2 { }
}

/* ====== Difference ====== */

.differencebox1{ max-width: 950px; width: 100%;}
.differencebox1 th,
.differencebox1 td{ position: relative; border-bottom: 1px solid var(--color-bu); padding: 30px; text-align: center; vertical-align: middle; line-height: 1.75;}
.differencebox1 th{ padding: 5px; letter-spacing: 0.1em; font-size: 4.0rem; border: 1px solid var(--color-bu);}
.differencebox1 tr th:nth-of-type(1){ background-color: var(--color-bu); color: #fff;}
.differencebox1 tr th:nth-of-type(2){ background-color: var(--color-back-bu); color: var(--color-bu);}
.differencebox1 tr td:nth-of-type(1){padding: 30px 50px 30px 30px;}
.differencebox1 tr td:nth-of-type(2){padding: 30px 30px 30px 50px;}
.differencebox1 tr td:nth-of-type(1)::after{ position: absolute; content: ""; width: 50px; height: 50px; right: 0; top: 50%; transform: translate(50%,-50%);}
.differencebox1 tr:nth-of-type(2) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_01.svg") center center no-repeat; background-size: contain;}
.differencebox1 tr:nth-of-type(3) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_02.svg") center center no-repeat; background-size: contain;}
.differencebox1 tr:nth-of-type(4) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_03.svg") center center no-repeat; background-size: contain;}
.differencebox1 tr:nth-of-type(5) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_04.svg") center center no-repeat; background-size: contain;}
.differencebox1 tr:nth-of-type(6) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_05.svg") center center no-repeat; background-size: contain;}
.differencebox1 tr:nth-of-type(7) td:nth-of-type(1)::after{ background: url("../imagesclinic2023/icons/dif_06.svg") center center no-repeat; background-size: contain;}
@media screen and (max-width: 679px) {
  .differencebox1 tr td{ font-size: 1.4rem; line-height: 1.5;}
  .differencebox1 tr td:nth-of-type(1)::after{ width: 30px; height: 30px;}
  .differencebox1 tr td:nth-of-type(1){padding: 15px 20px 15px 0px;}
  .differencebox1 tr td:nth-of-type(2){padding: 15px 0px 15px 20px;}
  .differencebox1 th{ padding: 5px; font-size: 2.2rem;}
  .differencebox1 tr td br{ display: none;}
}


/* ====== Construction ====== */

.slider{ max-width: 1920px; width: 100%; margin: var(--m-m) auto var(--m-s) auto;}
.slick-img img { height: auto; opacity: .5; transform: scale(.8); transition: opacity .5s, transform .5s; width: 100%; border-radius: 20px;}
.slider .slick-center img { opacity: 1; transform: scale(1);}
.thumbnail{ width: 100%; margin: 0 auto;}
.thumbnail-img{ margin: 0 5px; border-radius: 20px;}
.thumbnail-img img{ border-radius: 20px;}
@media screen and (max-width: 679px) {
  .slick-img img { opacity: .4; transform: scale(.9); border-radius: 10px;}
  .thumbnail-img{ margin: 0 3px; border-radius: 10px;}
  .thumbnail-img img{ border-radius: 10px;}
}

.constraction-text1{ font-size: 3.0rem; line-height: 2; text-align: center; max-width: 800px; width: 90%;}
.conbr1{ display: inline;}
.conbr1n{ display: none;}
.conbr2{ display: none;}
.conbr2n{ display: inline;}
@media screen and (max-width: 899px) {
  .constraction-text1{ font-size: 2.2rem;}
}
@media screen and (max-width: 699px) {
  .constraction-text1{ font-size: 2.0rem;}
}
@media screen and (max-width: 569px) {
  .constraction-text1{ font-size: 1.8rem;}
}
@media screen and (max-width: 499px) {
  .conbr1{ display: none;}
  .conbr1n{ display: inline;}
  .conbr2{ display: inline;}
  .conbr2n{ display: none;}
}


/* ===== Voice ===== */

/*.voice1{ margin-top: var(--m-l);}
.voice1 h3{ font-size: 2.5rem; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; line-height: 1.5; background-color: var(--color-bu); color: #fff; border-radius: 20px; padding: 0.6em 2em;}
.voice1 .voicetop{ position: relative;}
.voice1 .cf:before,.cf:after {content: " "; display: table; }
.voice1 .cf:after { clear: both; }
.voice1 .cf { *zoom: 1; }
.voice1 .voiceimg{ float: left; width: 36.8%; border-radius: 20px; overflow: hidden; border: 3px solid var(--color-bu); margin: 0 2% 1% 0;}
.voice1 .voiceimg img{ object-fit: cover; aspect-ratio: 320 / 240;}
.voice1 .voicetext{ width: 100%;}

.voice1 .voiceperson{ font-size: 2.5rem; line-height: 1.5; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; color: var(--color-db);}
.voice1 h4{ overflow: hidden; font-size: 2.5rem; line-height: 1.5; font-weight: 700; color: var(--color-bu); margin: var(--m-s) 0; padding-bottom: 10px; border-bottom: 5px solid var(--color-bu);}
@media screen and (max-width: 639px) {
  .voice1 h3{ font-size: 2.0rem; border-radius: 10px; padding: 0.6em 1.5em;}
  .voice1 .voicetop{ display: block;}
  .voice1 .voiceimg{ width: 50%; border-radius: 10px; border: 3px solid var(--color-bu); float: left;}
  .voice1 .voicetext{ width: auto;}
  .voice1 .voiceperson{ font-size: 2.0rem;}
  .voice1 h4{ clear: both; font-size: 2.0rem; border-bottom: 3px solid var(--color-bu);}
}
@media screen and (max-width: 519px) {
  .voice1 h3{ font-size: 1.8rem; padding: 0.6em 1em;}
  .voice1 .voiceperson{ font-size: 1.7rem; letter-spacing: 0;}
  .voice1 h4{ font-size: 1.8rem; padding-top: var(--m-s);}
}
*/
.voice2{ margin-top: var(--m-l);}
.voice2 h3{ font-size: 2.5rem; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; line-height: 1.5; background-color: var(--color-bu); color: #fff; border-radius: 20px; padding: 0.6em 2em;}
.voice2 .voicetop{ display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap;}
.voice2 .voiceimg{ width: 36.8%; border-radius: 20px; overflow: hidden; border: 3px solid var(--color-bu); margin: 0 2% 1% 0;}
.voice2 .voiceimg img{ object-fit: cover; aspect-ratio: 320 / 240;}
.voice2 .voicetext{ width: 60.5%;}
.voice2 .voiceperson{ font-size: 2.5rem; line-height: 1.5; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; color: var(--color-db);}
.voice2 h4{ width: 100%; overflow: hidden; font-size: 2.5rem; line-height: 1.5; font-weight: 700; color: var(--color-bu); margin: var(--m-s) 0; padding-bottom: 10px; border-bottom: 5px solid var(--color-bu);}
@media screen and (max-width: 639px) {
  .voice2 h3{ font-size: 2.0rem; border-radius: 10px; padding: 0.6em 1.5em;}
  .voice2 .voicetop{ display: block;}
  .voice2 .voiceimg{ width: 50%; border-radius: 10px; border: 3px solid var(--color-bu); float: left;}
  .voice2 .voicetext{ width: auto;}
  .voice2 .voiceperson{ font-size: 2.0rem;/* margin-left: 55%;*/}
  .voice2 h4{ clear: both; font-size: 2.0rem; border-bottom: 3px solid var(--color-bu);}
}
@media screen and (max-width: 519px) {
  .voice2 h3{ font-size: 1.8rem; padding: 0.6em 1em;}
  .voice2 .voiceperson{ font-size: 1.7rem; letter-spacing: 0;}
  .voice2 h4{ font-size: 1.8rem; padding-top: var(--m-s);}
}

/* ===== Produce ===== */

.producewrap{ width: 100%; padding: var(--m-l) 0; background-image: url("../imagesclinic2023/produce.avif"),url("../imagesclinic2023/produce.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover;}
.producebox1{ padding: 40px; border: 5px solid var(--color-bu); background-color: rgba(255,255,255,0.80); border-radius: 20px;}
.producebox1 p{ text-align: justify; width: 100%;}
/*.credo{ padding-bottom: var(--m-s);}
.credo h3{ font-size: 2.5rem; line-height: 1.5; background-color: var(--color-bu); color: #fff; border-radius: 20px; padding: 0.6em 2em; margin: var(--m-s) 0; }
.credo h3:first-child{ margin: 15px 0 var(--m-s) 0;}
.credo p{ font-size: 2.5rem; line-height: 1.5; color: var(--color-db); padding: 0 2em; text-align: left;}*/
.credo2{ margin: 1em 0; border: 2px solid var(--color-bu); padding: 0.5em 1em; border-radius: 5px;}
.producebox1 p.signature{font-size: 2.6rem; line-height: 1.1; text-align: right; margin: 1em 1em 0 0;}
.producebox1 p.signature span{ display: inline-block; width: 220px; margin-left: 1em;}
@media screen and (max-width: 719px){
  .producewrap{ padding: var(--m-m) 0 var(--m-l) 0;}
  .producebox1{ padding: 20px; border: 2px solid var(--color-bu);}
  .credo h3{ font-size: 2.0rem; border-radius: 10px; padding: 0.4em 0.9em; text-align: center;}
  .credo p{ font-size: 1.8rem; line-height: 1.5; color: var(--color-db); padding: 0 1em;}
  .producebox1 p.signature{font-size: 1.5rem; margin: 1em 0 0 0;}
  .producebox1 p.signature span{ width: 150px; margin-left: 0.6em;}
}



/* ===== After Maintenance ===== */

.afterbox1{ width: 100%; padding: var(--m-l) 0; background-image: url("../imagesclinic2023/after.avif"),url("../imagesclinic2023/after.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover; border-top: 6px solid #fff;}
.afterboxttl1{ font-size: 4.0rem; line-height: 1.5; text-align: center; color: var(--color-db);}
.afterbox2{ padding: 40px; border: 5px solid var(--color-bu); background-color: rgba(255,255,255,0.80); border-radius: 20px;}
@media screen and (max-width: 719px){
  .afterboxttl1{ font-size: 2.4rem;}
}
@media screen and (max-width: 419px) {
  .afterbox1{ padding: var(--m-m) 0 var(--m-l) 0;}
  .afterbox2{ padding: 20px; border: 2px solid var(--color-bu);}
}

/* ===== Flow ===== */

.slider__step{ padding: 10px; background-color: rgba(255,255,255,0.50); border: 1px solid #fff;}
.flow1box{ display: flex; justify-content: space-between; box-sizing: border-box;}
.flow1box *,.flow1box ::before{ box-sizing: border-box;}
.flow1num{ width: 120px; position: relative;}
.flow1num div{ width: 120px; height: 120px; font-family: 'Cabin', sans-serif; font-size: 35px; font-weight: 700; line-height: 40px; padding: 25px 0 15px 0; background-color: var(--color-bu); color: #fff; border-radius: 50%; text-align: center;}
/*.flow1num::before{ position: absolute; content: ""; top: 110px; left: calc(50% - 3px); width: 6px; height: calc(100% - 108px); background-color: var(--color-bu);}*/
.flow1contitle{ width: calc(100% - 150px); margin-bottom: var(--m-s); background-color: #fff; color: var(--color-db); font-size: 2.5rem; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; line-height: 1.5; padding: 40px; border: 3px solid var(--color-bu); border-radius: 20px; margin-right: 3px;}
.flow1con{ display: flex; justify-content: space-between; flex-wrap: wrap; align-items: flex-start;}
.flow1img{ width: 34.5%; border: 3px solid var(--color-bu); border-radius: 20px; overflow: hidden;}
.flow1-r{ width: 60.5%;}
.flow1:last-child .flow1num::before{ height: calc(100% - 108px -  var(--m-m));}
.flow1-dotcomment{ font-size: 13px; line-height: 1.2; text-align: center; margin: var(--m-l) auto 40px auto;}
@media screen and (max-width: 899px) {
  .flow1num{ width: 80px;}
  .flow1num div{ width: 80px; height: 80px; font-size: 23px; line-height: 26px; padding: 18px 0 13px 0;}
  .flow1num::before{ top: 75px; left: calc(50% - 2px); width: 4px; height: calc(100% - 73px);}
  .flow1contitle{ width: calc(100% - 100px); font-size: 2.0rem; padding: 1em; border: 2px solid var(--color-bu); border-radius: 10px;}
  .flow1img{ width: 34.5%; border: 2px solid var(--color-bu); border-radius: 10px;}
  .flow1-r{ width: 62%; margin-left: 3.5%;}
  .flow1:last-child .flow1num::before{ height: calc(100% - 73px - var(--m-m));}
}
@media screen and (max-width: 539px) {
  .flow1num{ width: 60px;}
  .flow1num div{ width: 60px; height: 60px; font-size: 18px; line-height: 20px; padding: 13px 0 9px 0;}
  .flow1num::before{ top: 58px; left: calc(50% - 2px); width: 4px; height: calc(100% - 58px);}
  .flow1contitle{ font-size: 2.0rem; padding: 12px;}
  .flow1img{ width: 50%; float: left; margin-right: 5%;}
  .flow1-r{ width: 100%; margin-left: 0;}
  .flow1:last-child .flow1num::before{ height: calc(100% - 58px - var(--m-m));}
}
@media screen and (max-width: 460px) {
  .flow1img{ width: 100%; float: none; margin-right: 0; margin-bottom: 20px;}
  .flow1-r{ width: 100%; margin-left: 0;}
  .flow1-dotcomment{ font-size: 12px; margin: var(--m-l) auto 25px auto;}
}





/* ===== Contact ===== */

.contact1-telttl{ font-size: 3.0rem; line-height: 1.5; font-weight: 900; color: #fff; text-align: center;}
.contacttel1text{ font-size: 2.0rem; text-align: center; color: #fff; margin-top: var(--m-s);}
.contact1-telbox{ display: flex; justify-content: space-around; flex-wrap: wrap; background-color: #fff; padding: var(--m-s) 20px; border-radius: 20px; margin-top: var(--m-m);}
.contacttel1{ width: 50%;/* border: 3px solid var(--color-pi); border-radius: 20px; padding: 20px 0;*/}
.contacttel1 h3{ font-size: 2.5rem; line-height: 1.5; color: var(--color-db); text-align: center;}
.contact1-telbox p{ width: 100%; color: var(--color-db); text-align: center; margin-top: 20px;}
.contacttel1 a{ display: block; margin-top: 20px; transition: 0.5s all; font-size: 5.8rem; line-height: 1.0; font-family: 'Cabin', sans-serif; font-weight: 700; color: var(--color-pi); text-align: center; transition: 0.5s all;}
.contacttel1 a:hover{ opacity: 0.6;}
.contacttel1 a i{ font-size: 3.5rem; margin-right: 5px; vertical-align: top; position: relative; top: 0.4em;}
/*.contact1-line{ display:block; font-size: 3.0rem; color: #fff; background-color: var(--color-line); text-align: center; line-height: 1.2; padding: 30px 10px; max-width: 710px; width: 90%; margin: var(--m-m) auto 0 auto; border: none; border-radius: 100px; transition: 0.5s all; position: relative;}
.contact1-line img{ display: block; position: absolute; height: 50%; right: 8.7%; top: 50%; transform: translateY(-50%);}*/

.contact1-line{ display:flex; justify-content: center; align-items: center; padding: 10px; font-size: 3.0rem; color: #fff; background-color: #00B901; text-align: center; line-height: 1.2; max-width: 640px; width: 80%; margin: 40px auto 40px auto; border: none; border-radius: 100px; transition: 0.5s all; position: relative;}
.contact1-line img{ width: 60px; margin-right: 10px;}
.contact1-line i{ width: 1em; margin-left: 10px;}
.contact1-line:hover{ background-color: #1D924D;}
@media screen and (max-width: 1099px) {
  .contacttel1 h3{ font-size: 3.0rem;}
  .contacttel1 a{ font-size: 4.0rem; padding-top: 14px;}
  .contacttel1 a i{ font-size: 2.5rem; top: 0.3em;}
  .contact1-line{ font-size: 2.4rem;}
}
@media screen and (max-width: 719px) {
  .contact1-telbox{ border-radius: 10px;}
  .contacttel1 h3{ font-size: 2.2rem;}
  .contacttel1 a{ font-size: 3.0rem; padding: 10px 5px 0 5px;}
  .contacttel1 a i{ font-size: 2.0rem; top: 0.2em;}
  .contact1-telttl{ font-size: 2.2rem; line-height: 1.5; font-weight: 900; color: #fff; text-align: center;}
  .contact1-line{ font-size: 1.8rem; padding: 10px 10px; margin: 30px auto; border-radius: 50px;}
  .contact1-line img{ width: 40px;}
}
@media screen and (max-width: 549px) {
  .contact1-telbox{ padding: var(--m-s) 0px;}
  .contacttel1text{ font-size: 1.4rem;}
  .contacttel1 a{ font-size: 3.0rem; line-height: 1.3; transform: scaleX(0.8); margin: 0 -10%;}
  .contacttel1 a i{ /*font-size: 1.6rem; top: 0.3em;*/ display: none;}
  .contact1-telbox p{ margin-top: 10px;}
  .contact1-line{ width: 95%; padding: 10px 5px;}
  .contact1-line br.sponly{ display: inline;}
  .contact1-line img{ width: 40px; margin-right: 5px;}
  .contact1-line i{ width: 1.5em; margin-left: 5px;}
}

 
/* iOSでのデフォルトスタイルをリセット */

input[type="submit"] { border-radius: 0; -webkit-box-sizing: content-box; -webkit-appearance: button; appearance: button; border: none; box-sizing: border-box; cursor: pointer;}
input[type="submit"]::-webkit-search-decoration { display: none;}
input[type="submit"]::focus { outline-offset: -2px;}

.contactform{ max-width: 1030px; background-color: #fff; padding: var(--m-s); border-radius: 20px;}
.contact1-formttl{ font-size: 4.0rem; line-height: 1.5; text-align: center;}

dl.formTable{ width:100%; border-collapse:collapse; font-size: 2.0rem; display: flex; justify-content: space-between; flex-wrap: wrap;}
dl.formTable dt{ width: 35%; background-color: #C9EDFF; padding:20px;/* white-space: nowrap;*/ border-radius: 20px; margin-bottom: 10px;}
dl.formTable dd{ width: 65%; padding:20px 0 20px 24px; margin-bottom: 10px;}
dl.formTable dt span.color-bw{ font-size: 70%; color: #931611;}
dl.formTable dd input[type="text"]{ width:100%; display:block; padding: 15px; border-radius: 5px; background-color: #E8E8E8;}
dl.formTable dd select,
dl.formTable dd input[type="date"] { vertical-align:middle; position:relative; margin: 0 4px 2px 0; background-color: #E8E8E8;	padding: 15px; border-radius: 5px;}
dl.formTable dd input[type="date"]{ display:inline-block; width: 200px;}
dl.formTable dd span.select{ display:inline-block; position: relative;}
dl.formTable dd span.select select{ display:inline-block;}
dl.formTable dd span.select::after{ position: absolute; right: 15px; top: 50%; transform: translateY(-50%); content: '\f078'; font-size: 1em; font-family: "Font Awesome 5 Free"; font-weight: 900; line-height: 1; color: var(--color-base);}
dl.formTable dd label{margin-left: 0px;}
dl.formTable dd input[type="radio"]{ padding-left: 30px;}
dl.formTable dd textarea { box-sizing: border-box; width: 100%; display:block; padding: 10px; background-color: #E8E8E8; border-radius: 5px;}

/*input.formTablesubmit[type="submit"] { display:block; font-size: 3.0rem; color: #fff; background-color: #F8779A; text-align: center; line-height: 1.2; padding: 30px 10px; max-width: 570px; width: 80%; margin: 40px auto 0 auto; border: none; border-radius: 60px;}
input.formTablesubmit[type="submit"]:hover { opacity: 0.8;}*/
button.formTablesubmit[type="submit"] { display:block; font-size: 3.0rem; color: #fff; background-color: #F8779A; text-align: center; line-height: 1.2; padding: 30px 10px; max-width: 570px; width: 80%; margin: 40px auto 0 auto; border: none; border-radius: 60px;}
button.formTablesubmit[type="submit"]:hover { opacity: 0.8;}
button.formTablesubmit[type="submit"] i img{ width: 30px; margin-left: 10px;}
::placeholder {color: #BBB;}
@media screen and (max-width:719px) {
  .contactform{ border-radius: 10px;}
  .contact1-formttl{ font-size: 2.8rem;}
  dl.formTable{ font-size: 1.8rem; display: block;}
	dl.formTable dt,
  dl.formTable dd { width:100%; display:block; margin-bottom: 0;}
  dl.formTable dt { margin-top:5px; border-bottom:0; padding:10px; text-align: center; border-radius: 10px;}
  dl.formTable dd{ padding:15px 10px 20px 10px;}
	dl.formTable dd input[type="text"],
  dl.formTable dd textarea { width:100%; display:block; padding: 8px;}
  dl.formTable dd select,
  dl.formTable dd input[type="date"] { padding: 10px;}
  dl.formTable dd input[type="date"]{ font-size: 13px; margin-bottom: 5px; width: 140px;}
  dl.formTable dd select{ font-size: 13px; margin-bottom: 5px;}
	/*input.formTablesubmit[type="submit"]{ font-size: 1.8rem; padding: 15px 10px; margin: 0 auto; max-width: 400px;}*/
  button.formTablesubmit[type="submit"]{ font-size: 1.8rem; padding: 15px 10px; margin: 0 auto; max-width: 400px;}
  button.formTablesubmit[type="submit"] i img{ width: 18px; margin-left: 10px;}
}
@media screen and (max-width: 479px) {
  .contact1-formttl{ font-size: 2.2rem;}
  /*input.formTablesubmit[type="submit"] { width: 90%;}*/
  button.formTablesubmit[type="submit"] { width: 90%;}
}


.radio label,
.checkbox label { position: relative; display: block; padding-left: 1.8em; line-height: 1.5; margin-bottom: 18px;}
.radio label::before,
.checkbox label::before { content: ""; display: block; position: absolute; top: 3px; left: 0; width: 20px; height: 20px; border: 1px solid var(--color-bu); border-radius: 50%; background: #fff;}
.radio input:checked + label::after,
.checkbox input:checked + label::after{ content: ""; display: block; position: absolute; top: 7px; left: 4px; width: 12px; height: 12px; background: var(--color-bu); border-radius: 50%;}




/* ===== Company ===== */

dl.companybox1{ max-width: 959px; width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap;}
dl.companybox1 dt{ width: 31%; padding: 30px 2%; background-color: #BBE9F4; border-radius: 20px; display: flex; align-items: center; margin-bottom: 20px;}
dl.companybox1 dd{ width: 66%; padding: 30px 5%; background-color: #F1FAFC; border-radius: 20px; margin-bottom: 20px;}
@media screen and (max-width: 479px) {
  dl.companybox1 dt{ width: 25%; padding: 20px 8px; border-radius: 10px; display: block;}
  dl.companybox1 dd{ width: 73%; padding: 20px 8px; border-radius: 10px;}
}

.companyttl{ font-size: 3.6rem;}

.companybox2 h3{ font-size: 3.0rem; line-height: 1.5; color: var(--color-db); border-bottom: 3px solid #000; padding-bottom: 10px; margin-bottom: var(--m-s);}
.company2-img{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; grid-auto-rows: auto auto; column-gap: 10px; row-gap: 10px;}
.company2-img div.company2-img1{grid-row: 1 / 3;}
.company2-img div{ border-radius: 20px; overflow: hidden;}
.company2-img div img{ width: 100%; height: 100%; object-fit: cover;}
.company2-address{ display: flex; justify-content: space-between; margin-top: var(--m-s); line-height: 1.5; background-color: #fff; border-radius: 20px;}
.company2-address1{ width: 15%; height: 80px; padding: 10px; display: flex; align-items: center; justify-content: center; background-color: #BBE9F4; border-radius: 20px;}
.company2-address2{ width: 35%; height: 80px; padding: 10px; display: flex; align-items: center; background-color: #fff;}
.company2-map{ margin-top: var(--m-s);}
.company2-map iframe{ width: 100%; height: 424px; border-radius: 20px;}
@media screen and (max-width: 639px) {
  .companybox2 h3{ font-size: 2.0rem; border-bottom: 2px solid #000; padding-bottom: 6px;}
  .company2-img{ column-gap: 5px; row-gap: 5px;}
  .company2-img div{ border-radius: 10px;}
  .company2-address{ flex-wrap: wrap; border-radius: 10px;}
  .company2-address1{ width: 30%; height: auto; border-radius: 10px;}
  .company2-address2{ width: 70%; height: auto;}
  .company2-address div:nth-of-type(1),.company2-address div:nth-of-type(2){ margin-bottom: 10px;}
  .company2-map iframe{ border-radius: 10px;}
}
@media screen and (max-width: 479px) {
  .company2-img{ display: grid; grid-template-columns: 1fr 1fr 1fr; grid-auto-rows: auto auto; column-gap: 10px; row-gap: 10px;}
  .company2-img div.company2-img1{grid-row: 1 / 3; grid-column: 1 / 3;}
  .company2-img div:last-child{ display: none;}
}



/* ===== tsuishin ===== */

.tsuishinttl{ font-size: 4.5rem; line-height: 1.0; color: #fff; text-align: center;}
.tsuishinbox1{ background-image: url("../imagesclinic2023/tsuishin.avif"),url("../imagesclinic2023/tsuishin.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover; padding: var(--m-l) 0;}
.tsuishinbox2{ background-color: rgba(255,255,255,0.80); padding: var(--m-m); border-radius: 20px;}
.tsuishin_contact{ position: relative; display: block; max-width: 520px; width: 90%; margin: var(--m-m) auto 0 auto; background-color: #F8779A; color: #fff; font-size: 14px; text-align: center; padding: 12px; overflow: hidden; border-radius: 80px; filter: drop-shadow(0 3px 3px rgba(0,0,0,0.40)); transition: background-color 0.6s;}
.tsuishin_contact:hover{ background-color: #EF91AB;}
.tsuishin_contact span{ display: block; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; font-size: 30px; line-height: 1.2;}
.tsuishin_contact i{ position: absolute; right: 20px; top: 50%; transform: translateY(-50%); font-size: 30px;}
@media screen and (max-width: 1299px) {
  .tsuishin_contact{ font-size: 12px; padding: 10px;}
  .tsuishin_contact span{ font-size: 26px;}
  .tsuishin_contact i{ right: 15px; font-size: 24px;}
}
@media screen and (max-width: 719px) {
  .tsuishinttl{ font-size: 2.4rem; line-height: 1.0; color: #fff; text-align: center;}
  .tsuishin_contact span{ font-size: 22px;}
  .tsuishin_contact i{ right: 10px; font-size: 22px;}
}
@media screen and (max-width: 559px) {
  .tsuishin_contact{ width: 96%; font-size: 2.2vw; width: 75%; padding: 5px; margin-bottom: 0;}
  .tsuishin_contact span{ font-size: 4.8vw;}
  .tsuishin_contact i{ font-size: 4vw; right: 10px;}
}


/* ===== footer ===== */

.footer{ position: relative; text-align: center; padding: 12px; background-color: var(--color-bu); color: #fff; pointer-events: none;}
.footernav{ position: absolute; right: 5%; top: 50%; transform: translateY(-50%) rotate(0.05deg); pointer-events: auto;}
.footernav a{ display: inline-block; transition: 0.5s all; color: #fff;}
.footernav a:hover{ color: var(--color-db);}

.foot_contact{ display: none; position: fixed; bottom: 10px; width: calc(100% - 20px); background-color: var(--color-pi); padding: 2px; margin: 0 10px; border-radius: 50px; overflow: hidden;}
.foot_contact a{ display: block; border: 1px solid rgba(255,255,255,0.65); border-radius: 30px; padding: 7px 10px 7px 10px; text-align: center; color: #fff; font-family: 'Zen Maru Gothic', sans-serif; font-weight:700; font-size: 18px; line-height: 21px;}
.foot_contact ul{ display: grid; grid-template-columns: 1fr 1fr 1fr; }
.foot_contact ul li{ list-style: none;}
.foot_contact ul li:nth-child(2),.foot_contact ul li:nth-child(3){ border-left: 1px solid #fff;}
.foot_contact ul li a{display: block; padding: 10px 10px 8px 10px; text-align: center; color: #fff; font-size: 10px; font-weight: 300;}
.foot_contact ul li a i{ display: block; font-size: 12px; padding-bottom: 3px;}
@media screen and (max-width: 520px) {
  .footer{ font-size: 1.2rem; text-align: left;}
}
@media screen and (max-width: 460px) {
  .footer{ padding: 8px 12px 75px 12px;}
  .footernav{ top: 12px; transform: translateY(0) rotate(0);}
  .foot_contact{display: block;}
}

/* ===== factorythanks.html ===== */

.thanksttl{ font-size: 2.4rem; text-align: center; padding: 30px 10%; color: #fff; background-color: var(--color-bu);}
.thankstext1{ width: 90%; max-width: 680px; margin: var(--m-m) auto;}
.thankstext1btn{ display: flex; justify-content: center;}
.thankstext1btn a{ display: flex; justify-content: space-between; align-items: center; font-size: 150%; font-weight: 900; color: #fff; background-color: var(--color-pi); padding: 10px 30px; gap: 30px; border-radius: 10px;}
.thankstext1 ul{ list-style: disc; margin-left: 1.5em;}
@media screen and (max-width: 719px) {
  .thanksttl{ margin-top: 50px;}
}

