@charset "utf-8";

/*========================================================================================================================


  ◇◆◇ トップページ ◇◆◇
  
  
========================================================================================================================*/

#hero-wrap {
  background:url(../image/top/hero.jpg) no-repeat center center;
}

#hero-wrap,
#hero {
  color:#fff;
  box-sizing:border-box;
}

#hero {
  height:100%;
  margin-left:auto;
  margin-right:auto;
  position:relative;
  overflow:hidden;
}

.hero_blur {
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
}

#hero:before {
  width:100%;
  height:100%;
  display:block;
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:1;
  background:rgba(255,255,255,0.08);
}

.hero_main {
  position:relative;
  z-index:2;
}

.hero__cc h2 {
  display:inline-block;
  line-height:1.5;
  /*font-size:200%;*/
}
  
.hero__ccS {
  display:inline-block;
  margin-top:0.25rem;
  font-size:70%;
}

.hero_main ul {
  display:inline-block;
  text-align:left;
}

.hero_main li:not(:first-child) {
  padding-top:0.5rem;
}

.hero_main li a,
.hero_main li a:visited,
.hero_main li a:hover { color:#fff; text-decoration:none; }

.ua-pc .hero_main li a {
  -webkit-transition:opacity 0.15s ease;
  transition:opacity 0.15s ease;
}
.ua-pc .hero_main li a:hover { opacity:0.6; }

.hero__cname { display:block; }

@media print,screen and (min-width:641px) {
  #hero-wrap {
    padding-top:80px;
    padding-bottom:80px;
    background-size:2000px auto;
  }
  
  #hero {
    display:inline-block;
    padding:70px 80px 80px 80px;
  }

  .hero_blur {
    width:2000px;
    height:1000px;
  }
  
  .hero__cc {
    font-size:225.0%;
  }
  
  .hero__cc {
    /*margin-bottom:40px;*/
  }

  .hero__cc h2 {
    padding:1.25rem 2rem;
  }

  .hero__cname { padding-top:1em; }
}

@media screen and (max-width:640px) {
  #hero-wrap {
    padding:10% 0;
    background-size:1600px auto;
  }
  
  #hero {
    padding:8% 2rem;
  }

  .hero_blur {
    width:1600px;
    height:800px;
  }
  
  .hero__cc {
    font-size:185%;
    /*margin-bottom:6%;*/
  }

  .hero__cc h2 {
    padding:1.25rem;
  }
  
  .hero__cname {
    font-size:140%;
    padding-top:4%;
    padding-bottom:2%;
  }
  
  .hero_main ul {
    font-size:85%;
  }
}


/*----------------------------------------------------------------------------------------------------

  健康応援メニュー
  
----------------------------------------------------------------------------------------------------*/

#health {
  background-color:#fff;
}
  
.health_hd {
  background-image:url(../image/top/health-hd_bg.jpg);
  background-repeat:no-repeat;
  background-size:cover;
  color:#fff;
}

.health_hd p {
  text-align:left;
}
  
.health_hd .health_hd_hdLine {
  font-weight:500;
  padding-bottom:1.5rem;
}

.health_hd p:not(.health_hd_hdLine) {
  line-height:2;
}

@media print,screen and (min-width:641px) {
  #health {
    padding-bottom:40px;
  }
  
  .health_hd {
    background-position:right top;
    padding-top:120px;
    padding-bottom:160px;
    position:relative;
  }
  
  .health_hd:after {
    content:"";
    max-width:1320px;
    width:-webkit-calc(100% - 80px);
    width:calc(100% - 80px);
    height:160px;
    background-color:#fff;
    position:absolute;
    left:50%;
    bottom:0;
    transform:translateX(-50%);
  }
  
  .health_hd p {
    width:1200px;
    margin-left:auto;
    margin-right:auto;
  }
  
  .health_hd p:not(.health_hd_hdLine) {
    padding-bottom:80px;
  }
}

@media screen and (max-width:640px) {
  .health_hd {
    padding-top:120px;
    padding-bottom:5rem;
    padding-left:1.5rem;
    padding-right:1.5rem;
    font-size:90%;
    background-position:82% top;
  }
  
  .health_hd p {
    position:relative;
    z-index:2;
  }
}

.health__ct,
.health__ct * {
  box-sizing:border-box;
}

.health__ct ul {
  list-style:none;
  display:flex;
  flex-wrap:wrap;
}

.health__ct li a {
  display:block;
}

.health__ct li {
  line-height:1.5;
  font-size:112.5%;
}

.health__ct li img {
  margin-bottom:0.75rem;
  width:100%;
  height:100%;
  aspect-ratio:5 / 3;
  object-fit:cover;
}

.health__ct a,
.health__ct a:visited,
.health__ct a:hover {
  text-decoration:none;
}

@media print,screen and (min-width:641px) {  
  .health_body {
    margin-left:40px;
    margin-right:40px;
    position:relative;
  }
  
  .health__ct {
    width:100%;
    max-width:1280px;
    margin-left:auto;
    margin-right:auto;
    padding-top:60px;
  }
  
  .health__ct li {
    width:calc(100% / 3);
    padding-left:20px;
    padding-right:20px;
    padding-bottom:80px;
  }
}

@media screen and (max-width:640px) {
  .health_body {
    padding-top:1rem;
    margin-left:1.5rem;
    margin-right:1.5rem;
    position:relative;
  }
  
  .health__ct {
    padding-top:2.5rem;
  }
  
  .health__ct li {
    width:50%;
    padding-left:0.75rem;
    padding-right:0.75rem;
    padding-bottom:2.5rem;
  }
}

/*-----------------------------------------------------------------------------------
  初めての方へ
-----------------------------------------------------------------------------------*/

#guide {
  position:relative;
}

.instagram_ct {
  position:relative;
  width:100%;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:60px;
}

.guide_ct {
  width:100%;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  position:relative;
  background:url("../image/top/guide_bg.jpg") no-repeat left center;
  text-align:left;
}

.ua-pc .guide_ct:before {
  content:"";
  width:100%;
  height:100%;
  background-color:#ffffff;
  position:absolute;
  left:0;
  top:0;
  opacity:0;
  -webkit-transition:opacity 0.2s ease;
  transition:opacity 0.2s ease;
}

.ua-pc .guide_ct:hover:before,
.ua-pc .linkBox:hover .guide_ct:before {
  opacity:0.2;
}

.guide_ct h3 {
  line-height:1.5;
  padding-bottom:0.75em;
}

.guide-btn {
  display:inline-block;
  vertical-align:bottom;
  position:absolute;
  right:0;
  bottom:0;
}

.guide-btn .l-btn {
  background-color:#32a0b4;
  border-radius:0;
  margin-bottom:0;
  vertical-align:bottom;
  padding:0.65em 2em;
}

.ua-pc .guide-btn .l-btn:hover,
.ua-pc .linkBox:hover .guide-btn .l-btn {
  background-color:#4bb9cd;
}

@media print,screen and (min-width:641px) {
  #guide {
    padding-left:100px;
    padding-right:100px;
    margin-top:-100px;
    padding-bottom:100px;
  }

  .guide_ct .inner {
    min-height:200px;
    padding-left:480px;
    padding-bottom:1em;
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -webkit-box-orient:vertical;
    -webkit-box-direction:normal;
    -ms-flex-direction:column;
    flex-direction:column;
    -webkit-box-pack:center;
    -ms-flex-pack:center;
    justify-content:center;
    position:relative;
    font-size:96%;
  }
}

@media screen and (max-width:640px) {
  #guide {
    padding:2.5rem 1.5rem;
  }

  .instagram_ct {
    margin-bottom:40px;
  }

  .guide_ct {
    background-size:cover;
    background-position:left 75%;
    padding-top:2em;
  }

  .guide_ct .inner {
    padding-left:42%;
    padding-bottom:4em;
    font-size:90%;
  }
}


/*----------------------------------------------------------------------------------------------------

  採用情報
  
----------------------------------------------------------------------------------------------------*/

#recruit {
  position:relative;
  background-color:#fff;
}

.recruit_ct {
  width:100%;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  position:relative;
  background:url("../image/top/recruit_bg.jpg") no-repeat left center;
  text-align:left;
}

.ua-pc .recruit_ct:before {
  content:"";
  width:100%;
  height:100%;
  background-color:#ffffff;
  position:absolute;
  left:0;
  top:0;
  opacity:0;
  -webkit-transition:opacity 0.2s ease;
  transition:opacity 0.2s ease;
}

.ua-pc .recruit_ct:hover:before,
.ua-pc .linkBox:hover .recruit_ct:before {
  opacity:0.2;
}

.recruit_ct h3 {
  line-height:1.5;
  padding-bottom:0.75em;
}

.recruit-btn {
  display:inline-block;
  vertical-align:bottom;
  position:absolute;
  right:0;
  bottom:0;
}

.recruit-btn .l-btn {
  background-color:#f591aa;
  border-radius:0;
  margin-bottom:0;
  vertical-align:bottom;
  padding:0.65em 2em;
}

.ua-pc .recruit-btn .l-btn:hover,
.ua-pc .linkBox:hover .recruit-btn .l-btn {
  background-color:#FFA0B9;
}

@media print,screen and (min-width:641px) {
  #recruit {
    padding-left:100px;
    padding-right:100px;
    padding-bottom:100px;
  }
  
  .recruit_ct {
    background-size:auto 140%;
  }
  
  .recruit_ct .inner {
    min-height:200px;
    padding-left:480px;
    padding-bottom:1em;
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -webkit-box-orient:vertical;
    -webkit-box-direction:normal;
    -ms-flex-direction:column;
    flex-direction:column;
    -webkit-box-pack:center;
    -ms-flex-pack:center;
    justify-content:center;
    position:relative;
    font-size:96%;
  }
}

@media screen and (max-width:640px) {
  #recruit {
    padding:2.5rem 1.5rem;
  }
  
  .recruit_ct {
    background-size:cover;
    background-position:22% 0;
    padding-top:2em;
  }
  
  .recruit_ct .inner {
    padding-left:46%;
    padding-bottom:4em;
    font-size:90%;
  }
}


/*----------------------------------------------------------------------------------------------------

  お知らせ
  
----------------------------------------------------------------------------------------------------*/

.info_ct {
  text-align:left;
}
  
.info__hd {
  position:relative;
}

.info__hd h3 {
  font-weight:400;
  line-height:1.5;
}

.info__hd h3,
.info__hd .more {
  display:inline-block;
}

.info__hd .more {
  position:absolute;
  right:0;
  bottom:0.25em;
}

.info__hd .more-ic {
  width:0.6em;
  height:9px;
  display:inline-block;
  position:relative;
  vertical-align:middle;
  margin-right:0.75rem;
}

.info__hd .more-ic span {
  content:"";
  width:100%;
  height:1px;
  display:inline-block;
  background-color:#144a52;
  position:absolute;
  left:0;
}

.info__hd .more-ic span:nth-child(1) { top:-1px; }
.info__hd .more-ic span:nth-child(2) { top:3px; }
.info__hd .more-ic span:nth-child(3) { bottom:1px; }

.info__hd .more-ic span:after {
  content:"";
  width:2px;
  height:1px;
  display:inline-block;
  background-color:#144a52;
  position:absolute;
  left:-4px;
}

.info__list {
  list-style:none;
  border-top:1px solid rgba(19,59,70,0.1);
  margin-top:1.5rem;
}

.info__list li {
  border-bottom:1px solid rgba(19,59,70,0.1);
  line-height:1.5;
}

.no-rgba .info__list { border-top:1px solid #d5dcdd; }
.no-rgba .info__list li { border-bottom:1px solid #d5dcdd; }

.info__list li a,
.info__list li .inner {
  display:block;
  padding:1rem 0.5rem;
}

.info__hd .more,
.info__hd .more:visited,
.info__hd .more:hover,
.info__list a,
.info__list a:visited,
.info__list a:hover {
  text-decoration:none;
}

.info__err {
  border-top:1px solid rgba(19,59,70,0.1);
  margin-top:1rem;
  padding-top:2rem;
}

@media print,screen and (min-width:641px) {
  #info {
    background:url(../image/top/info_bg.jpg?v=2) no-repeat center bottom;
    padding-top:100px;
    padding-bottom:100px;
  }
  
  .info_ct {
    width:1200px;
    margin-left:auto;
    margin-right:auto;
    box-sizing:border-box;
    padding-left:620px;
  }
  
  .info__list,
  .info__err { margin-bottom:60px; }
}

@media screen and (max-width:640px) {
  #info {
    background:url(../image/top/info-sp_bg.jpg) no-repeat center top;
    background-size:contain;
    background-color:#e9ebed;
    position:relative;
  }
  
  .info_ct {
    padding-top:50%;
    padding-bottom:3rem;
    padding-left:1.5rem;
    padding-right:1.5rem;
  }
  
  .info__list,
  .info__err { margin-bottom:2.5rem; }
  
  .info__err { padding-bottom:0.5rem; }
}


/*----------------------------------------------------------------------------------------------------

  診療内容
  
----------------------------------------------------------------------------------------------------*/

#medical {
  background-color:#fff;
}

.medical_ct {
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
}

.medical_ct .col {
  border-style:solid;
  border-color:#dce2e3;
  box-sizing:border-box;
}

.medical_ct .col a {
  box-sizing:border-box;
  display:block;
  width:100%;
  height:100%;
}

.medical_ct .col a,
.medical_ct .col a:visited,
.medical_ct .col a:hover {
  color:inherit;
  text-decoration:none;
}
  
.ua-pc .medical_ct .col a {
  -webkit-transition:background 0.2s ease;
  transition:background 0.2s ease;
}
  
.ua-pc .medical_ct .col a:hover {
  background-color:#f0f8f8;
}

.medical_ct .col p {
  text-align:left;
  padding-top:0.75rem;
  overflow-wrap:break-word;
	word-wrap:break-word;
}

.medical_ct .col h4 {
  color:#1e968c;
  font-size:156.2%;
  font-weight:400;
  position:relative;
}

.medical_ct .col h4:before {
  content:"";
  width:100%;
  height:80px;
  margin-bottom:0.5rem;
  display:block;
  background-position:center center;
  background-repeat:no-repeat;
  background-size:contain;
}

.medical_ct .col-01 h4:before { background-image:url(../image/icon/medical_ic01.svg); }
.medical_ct .col-02 h4:before { background-image:url(../image/icon/medical_ic02.svg); }
.medical_ct .col-03 h4:before { background-image:url(../image/icon/medical_ic03.svg); }
.medical_ct .col-04 h4:before { background-image:url(../image/icon/medical_ic04.svg); }
.medical_ct .col-05 h4:before { background-image:url(../image/icon/medical_ic05.svg); }
.medical_ct .col-06 h4:before { background-image:url(../image/icon/medical_ic06.svg); }
.medical_ct .col-07 h4:before { background-image:url(../image/icon/medical_ic07.svg); }

.no-svg .medical_ct .col-01 h4:before { background-image:url(../image/icon/medical_ic01.png); }
.no-svg .medical_ct .col-02 h4:before { background-image:url(../image/icon/medical_ic02.png); }
.no-svg .medical_ct .col-03 h4:before { background-image:url(../image/icon/medical_ic03.png); }
.no-svg .medical_ct .col-04 h4:before { background-image:url(../image/icon/medical_ic04.png); }
.no-svg .medical_ct .col-05 h4:before { background-image:url(../image/icon/medical_ic05.png); }
.no-svg .medical_ct .col-06 h4:before { background-image:url(../image/icon/medical_ic06.png); }
.no-svg .medical_ct .col-06 h4:before { background-image:url(../image/icon/medical_ic07.png); }

@media print,screen and (min-width:641px) {
  #medical {
    padding-top:100px;
    padding-bottom:100px;
  }
  
  .medical_ct {
    width:1200px;
    margin-left:auto;
    margin-right:auto;
    padding-top:60px;
  }
  
  .medical_ct .col {
    width:33.333333%;
    border-width:1px 0 1px 1px;
  }
  
  .medical_ct .col:nth-child(3n),
  .medical_ct .col:last-child {
    border-right-width:1px;
  }
  
  /*
  .medical_ct .col:nth-child(4n) {
    clear:both;
  }
  
  .medical_ct .col:nth-child(n+4) {
    width:50%;
  }
  */
  
  .medical_ct .col:nth-child(n+4) {
    border-top-width:0;
  }

  .medical_ct .col a {
    padding:2.5rem 2rem;
  }
  
  .medical_ct .col p {
    display:inline-block;
    margin-left:auto;
    margin-right:auto;
  }
}

@media screen and (max-width:640px) {
  #medical {
    padding-top:2.5rem;
    padding-bottom:2.5rem;
    padding-left:1.5rem;
    padding-right:1.5rem;
  }
  
  .medical_ct {
    width:100%;
    margin-top:2rem;
  }
  
  .medical_ct .col {
    width:100%;
    border-width:1px;
  }
  
  .medical_ct .col:not(:first-child) {
    clear:both;
    border-top-width:0;
    border-top-color:transparent;
  }

  .medical_ct .col a {
    padding:2rem 1.5rem;
  }
}


/*----------------------------------------------------------------------------------------------------

  口臭治療
  
----------------------------------------------------------------------------------------------------*/

#breath {
  background:url(../image/top/breath_bg.jpg) no-repeat center top;
}

.breath__body {
  background-color:#fff;
}

.breath__body_txt {
  overflow-wrap:break-word;
	word-break:keep-all;
}

.breath__body_txt:before {
  content:"";
  display:block;
  position:absolute;
  background:url(../image/honda-acMark.png) no-repeat center center;
  background-size:cover;
}

@media print,screen and (min-width:641px) {
  #breath {
    padding-top:120px;
    overflow:hidden;
    position:relative;
  }
  
  #breath:after {
    content:"";
    width:100%;
    height:80px;
    background-color:#f0f8f8;
    display:block;
    position:absolute;
    left:0;
    bottom:0;
  }
  
  .breath_ct {
    width:1200px;
    margin-left:auto;
    margin-right:auto;
    box-sizing:border-box;
    padding-left:530px;
    position:relative;
    z-index:1;
  }
  
  .breath__body {
    width:670px;
    float:right;
    position:relative;
    box-sizing:border-box;
    padding:90px 0 80px 60px;
    text-align:left;
  }
  
  .breath__body:after {
    content:"";
    width:100%;
    height:100%;
    background-color:#fff;
    display:block;
    position:absolute;
    left:670px;
    top:0;
  }
  
  .honda-ac {
    width:300px;
    margin-bottom:40px;
  }

  .breath__body_txt {
    line-height:2;
    padding-bottom:40px;
    text-align:left;
  }
  
  .breath__body_txt:before {
    width:111px;
    height:120px;
    top:60px;
    right:0;
  }
}

@media screen and (max-width:640px) {
  #breath {
    background-size:auto 350px;
    padding-top:350px;
    padding-bottom:1rem;
    position:relative;
  }
  
  .breath_ct {
    padding-left:1.5rem;
    padding-right:1.5rem;
  }
  
  .breath__body {
    padding:3rem 2rem;
    margin-top:-2rem;
  }
  
  .honda-ac {
    width:300px;
    position:absolute;
    left:50%;
    top:190px;
    transform:translateX(-50%);
  }
  
  .breath__body_txt {
    padding-bottom:0.5rem;
  }
  
  .breath__body_txt p {
    padding-bottom:2rem;
  }
  
  .breath__body_txt:before {
    width:90px;
    height:98px;
    top:65px;
    left:50%;
    transform:translateX(-50%);
  }
}


/*----------------------------------------------------------------------------------------------------

  バナー
  
----------------------------------------------------------------------------------------------------*/

#gBnr ul {
  list-style:none;
}

#gBnr li {
  box-sizing:border-box;
  background-color:#fff;
}
  
#gBnr li .gBnr_btn {
  display:block;
}

#gBnr li a span {
  position:relative;
  z-index:2;
}

#gBnr li a:after {
  content:url(../image/icon/glink_green.svg);
  position:absolute;
  top:0.25em;
  right:0.75em;
  z-index:2;
}

.no-svg #gBnr li a:after { content:url(../image/icon/glink_green.png); }

.ua-pc #gBnr li:hover a:after { content:url(../image/icon/glink_white.svg); }
.ua-pc.no-svg #gBnr li:hover a:after { content:url(../image/icon/glink_white.png); }

#gBnr li .rmk {
  display:inline-block;
  vertical-align:middle;
  margin:0 1px;
}

@media print,screen and (min-width:641px) {
  #gBnr {
    max-width:1200px;
    margin-left:auto;
    margin-right:auto;
    padding-top:80px;
  }
  
  #gBnr ul {
    width:100%;
  }
  
  #gBnr li {
    width:33.333333%;
    float:left;
    padding:2.5rem 0;
  }
  
  #gBnr li:not(:last-child) {
    border-right:1px solid #dcf0f2;
  }

  #gBnr li p {
    padding-top:1.5rem;
    padding-bottom:1.5rem;
  }
  
  #gBnr li.dbm p,
  #gBnr li.poic p {
    padding-top:2.5rem;
  }
  
  .gBnr_btn .l-btn {
    padding:0.65em 2em 0.65em 1.5em;
  }
}

@media screen and (max-width:640px) {
  #gBnr {
    padding-top:2.5rem;
    padding-left:1.5rem;
    padding-right:1.5rem;
  }
  
  #gBnr li:not(:first-child) {
    border-top:1px solid #dcf0f2;
  }
  
  #gBnr li {
    padding:2.5rem 1.5rem;
  }

  #gBnr li p {
    padding-top:1.25rem;
    padding-bottom:1.5rem;
  }
}

