@charset "UTF-8";

*,
*:before,
*:after {
  box-sizing: border-box;
}

img,
object,
embed,
video {
  max-width: 100%;
}

/*  IE 6 does not support max-width so default to width 100%  */

.ie6 img {
  width: 100%;
}

html {
  font-size: 12.5px;
}

body {
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans",
    "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  background-color: #fff;
}

ul,
ol {
  list-style: none;
}

dl {
  margin: 0;
}

table th,
table td {
  padding: 0;
}

a {
  text-decoration: none;
}

p {
  margin: 0;
  line-height: 1.8;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  line-height: 1;
}

.full-screen {
  width: 100%;
}

.grid-container01,
.grid-container02,
.grid-container05,
.grid-container06 {
  width: 85%;
  margin: auto;
  padding-left: 0;
  padding-right: 0;
}

.grid-container03,
.grid-container04 {
  width: 90%;
  margin: auto;
  padding-left: 0;
  padding-right: 0;
}

.grid-container99 {
  width: 100%;
  margin: auto;
  padding-left: 0;
  padding-right: 0;
}

.anchor {
  margin-top: -65px;
  padding-top: 65px;
}

.pc-mode {
  display: none;
}

.sp-mode {
  display: block;
}

.pc-inline {
  display: none;
}

.pos {
  position: relative;
}

.center {
  text-align: center;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.left-center {
  text-align: left;
}

.center-left {
  text-align: center;
}

.center-right {
  text-align: center;
}

.justify {
  text-align: justify;
  text-justify: inter-ideograph;
}

.texttop {
  vertical-align: text-top;
}

.middle {
  vertical-align: middle;
}

.baseline {
  vertical-align: baseline;
}

.img100 {
  display: block;
  width: 100%;
}

.img80 {
  display: block;
  width: 80%;
  margin: 0 auto;
}

.upper {
  z-index: 990;
}

.upper02 {
  z-index: 999;
}

/*   font
--------------------------------------- */
/*砧 丸明Yoshino StdN R*/
.kinuta {
  font-family: kinuta-maruminyoshino-stdn, serif;
  font-weight: 400;
  font-style: normal;
}

/*源ノ角ゴシック Bold*/
.gen-bold {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 700;
  font-style: normal;
}

/*源ノ角ゴシック Normal*/
.gen-nomal {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 300;
  font-style: normal;
}

/*源ノ角ゴシック Midium*/
.gen-medium {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 500;
  font-style: normal;
}

/*源ノ角ゴシック Regular*/
.gen-regular {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 400;
  font-style: normal;
}

/*   font color
--------------------------------------- */
:root {
  --color-primary: #3676ba;
}

.color-white {
  color: #ffffff;
}

.color-black01 {
  color: #000000;
}

.color-black02 {
  color: #3c3c3c;
}

.color-black03 {
  color: #333333;
}

.color-black04 {
  color: #231815;
}

.color-black05 {
  color: #040000;
}

.color-black06 {
  color: #505050;
}

.color-blue01 {
  color: var(--color-primary);
}

.color-blue04 {
  color: #64abdf;
}

.color-blue05 {
  color: #3071b7;
}

.color-blue08 {
  color: #006ab2;
}

.color-green02 {
  color: #80ad29;
}

.color-red01 {
  color: #f05f37;
}

.color-red02 {
  color: #aa4e4e;
}

.color-red03 {
  color: #ee7e70;
}

.color-gray01 {
  color: #9b9b9b;
}

/* link color */
.color-black02:hover,
.color-black02:visited,
.blog__main .color-black02 a,
.blog__main .color-black02 a:hover,
.blog__main .color-black02 a:visited {
  color: #3c3c3c;
}

.color-blue01:hover,
.color-blue01:visited {
  color: var(--color-primary);
}

.color-white.menu__text02:hover,
.color-white.thispage {
  color: #a1c2e2;
}

.color-hover:hover {
  opacity: 0.7;
}

/*   bg
--------------------------------------- */
.bg-white {
  background-color: #ffffff;
}

.bg-blue01 {
  background-color: var(--color-primary);
}

.bg-blue02 {
  background-color: #3072ad;
}

.bg-blue03 {
  background-color: #eaeff5;
}

.bg-blue04 {
  background-color: #64abdf;
}

.bg-blue06 {
  background-color: #ebf1f6;
}

.bg-blue07 {
  background-color: #5ba9d3;
}

.bg-blue08 {
  background-color: #006ab2;
}

.bg-green01 {
  background-color: #91b938;
}

.bg-green02 {
  background-color: #80ad29;
}

.bg-green03 {
  background-color: #f1f6e7;
}

.bg-green04 {
  background-color: #06c755;
}

.bg-red03 {
  background-color: #ee7e70;
}

.bg-pattern {
  background-image: url(../img/01-back-left-sp.png),
    url(../img/01-back-right-sp.png);
  background-repeat: no-repeat, no-repeat;
  background-position: left top, bottom right;
  background-size: 40rem, 40rem;
}

/* 
.bg-header {
    background-image: url("../img/99-header-bg.png");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
}

.bg-footer {
    background-image: url("../img/99-footer-bg-sp.png");
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 100%;
}

.bg-news {
    background-image: url("../img/01-news-bg-sp.png");
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: auto 100%;
}



.bg-white__70 {
    background-color: rgba(255, 255, 255, 0.7);
}

.bg-white__75 {
    background-color: rgba(255, 255, 255, 0.75);
} */

/*   border
--------------------------------------- */
.border-blue01 {
  border: 1px solid var(--color-primary);
}

.border-blue04 {
  border: 1px solid #64abdf;
}

.border-blue01 .event__text {
  border-top: 1px solid var(--color-primary);
}

.border-blue04 .event__text {
  border-top: 1px solid #64abdf;
}

.border-green02 {
  border: 1px solid #80ad29;
}

.border-red03 {
  border: 1px solid #ee7e70;
}

.border-footer {
  border-top: 1px solid #c3c3c3;
}

.border-2color {
  border-bottom: 1px solid #808080;
  padding-bottom: 1em;
  margin-bottom: 1px;
}

.border-2color::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 5em;
  height: inherit;
  border-bottom: 1px solid #75c4b4;
}

/*   text
--------------------------------------- */
.cmn__title {
  padding-bottom: 0.1rem;
}

.cmn__title01 {
  font-size: 2.2rem;
}

.cmn__title02 {
  font-size: 1rem;
}

.cmn__title03 {
  font-size: 1.7rem;
}

.cmn__title04 {
  font-size: 1.25rem;
}

.cmn__title05 {
  font-size: 1.5rem;
}

.cmn__title06 {
  font-size: 1.55rem;
}

.cmn__title07 {
  font-size: 1.2rem;
}

.title__line01 {
  display: inline-block;
  padding-bottom: 0.25em;
  border-bottom: 0.9784px solid #000000;
}

/* .title__line01::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 1.5em;
    height: 1px;
    background-color: #b0c6db;
} */

.title__line02 {
  border-left: 4px solid var(--color-primary);
  padding-left: 0.5em;
}

.title__line03 {
  border-bottom: 2px dotted #000000;
  padding-bottom: 0.5em;
}

.cmn__text01 {
  font-size: 1.1rem;
}

.cmn__text02 {
  font-size: 1rem;
}

.color__title01 {
  font-size: 1.4rem;
  padding: 0.5rem 1rem;
  border-left: 6.7746px solid #1d4c7c;
}

.underline00 {
  text-decoration: underline;
}

.underline01 {
  text-decoration: underline;
  text-underline-offset: 0.2em;
  padding-bottom: 0.2em;
}

.underline02 {
  text-decoration: underline;
  text-underline-offset: 0.5em;
  text-decoration-thickness: 1px;
  padding-bottom: 0.5em;
}

/*   改行
--------------------------------------- */

.br-ip::before {
  content: "\A";
  white-space: pre;
}

.br-sp::before {
  content: "\A";
  white-space: pre;
}

.br-sp-space::before {
  content: "\A　";
  white-space: pre;
}

.br-sp02::before,
.br-sp03::before {
  content: "\A";
  white-space: pre;
}

.br-ip-tab::before {
  content: "\A";
  white-space: pre;
}

.br-sptab {
  display: block;
}

/*   スペース
--------------------------------------- */
.top05,
.top05--sp {
  padding-top: 0.25rem;
}

.top10 {
  padding-top: 0.5rem;
}

.top10--sp {
  padding-top: 0.55rem;
}

.top12 {
  padding-top: 0.6rem;
}

.top15 {
  padding-top: 0.75rem;
}

.top16 {
  padding-top: 0.8rem;
}

.top20,
.top20--sp {
  padding-top: 1rem;
}

.top25 {
  padding-top: 1.25rem;
}

.top30 {
  padding-top: 1.5rem;
}

.top32 {
  padding-top: 1.6rem;
}

.top35 {
  padding-top: 1.75rem;
}

.top40,
.top40--sp {
  padding-top: 2rem;
}

.top45 {
  padding-top: 2.25rem;
}

.top50,
.top50--sp {
  padding-top: 2.5rem;
}

.top55 {
  padding-top: 2.75rem;
}

.top60,
.top60--sp {
  padding-top: 3rem;
}

.mtop60 {
  margin-top: 3rem;
}

.top65 {
  padding-top: 3.25rem;
}

.top70 {
  padding-top: 3.5rem;
}

.top75 {
  padding-top: 3.75rem;
}

.top80,
.top80--sp {
  padding-top: 4rem;
}

.top85 {
  padding-top: 4.25rem;
}

.top90 {
  padding-top: 4.5rem;
}

.top95 {
  padding-top: 4.75rem;
}

.top100 {
  padding-top: 5rem;
}

.top105 {
  padding-top: 5.25rem;
}

.top110 {
  padding-top: 5.5rem;
}

.top120 {
  padding-top: 6rem;
}

.top125 {
  padding-top: 6.25rem;
}

.top130 {
  padding-top: 6.5rem;
}

.top140 {
  padding-top: 7rem;
}

.top150 {
  padding-top: 7.5rem;
}

.top200 {
  padding-top: 10rem;
}

.bottom10 {
  padding-bottom: 0.5rem;
}

.bottom15 {
  padding-bottom: 0.75rem;
}

.bottom20 {
  padding-bottom: 1rem;
}

.bottom25 {
  padding-bottom: 1.25rem;
}

.bottom30 {
  padding-bottom: 1.5rem;
}

.bottom32 {
  padding-bottom: 1.6rem;
}

.bottom40,
.bottom40--sp {
  padding-bottom: 2rem;
}

.bottom45 {
  padding-bottom: 2.25rem;
}

.bottom50 {
  padding-bottom: 2.5rem;
}

.bottom55 {
  padding-bottom: 2.75rem;
}

.bottom60 {
  padding-bottom: 3rem;
}

.bottom65 {
  padding-bottom: 3.25rem;
}

.bottom70 {
  padding-bottom: 3.5rem;
}

.bottom75 {
  padding-bottom: 3.75rem;
}

.bottom80 {
  padding-bottom: 4rem;
}

.bottom85 {
  padding-bottom: 4.25rem;
}

.bottom90 {
  padding-bottom: 4.5rem;
}

.bottom95 {
  padding-bottom: 4.75rem;
}

.bottom100 {
  padding-bottom: 5rem;
}

.bottom105 {
  padding-bottom: 5.25rem;
}

.bottom110 {
  padding-bottom: 5.5rem;
}

.bottom120 {
  padding-bottom: 6rem;
}

.bottom125 {
  padding-bottom: 6.25rem;
}

.bottom130 {
  padding-bottom: 6.5rem;
}

.bottom140 {
  padding-bottom: 7rem;
}

.bottom150 {
  padding-bottom: 7.5rem;
}

.bottom200 {
  padding-bottom: 10rem;
}

/*   行間,文字間
--------------------------------------- */
.line01 {
  line-height: 1;
}

.line01_2,
.line01_2--sp {
  line-height: 1.2;
}

.line01_4,
.line01_4--sp {
  line-height: 1.4;
}

.line01_5 {
  line-height: 1.5;
}

.line01_6,
.line01_6--sp,
.line01_6--sp02,
.line01_6--sp03 {
  line-height: 1.6;
}

.line01_8,
.line01_8--sp {
  line-height: 1.8;
}

.line01_9,
.line01_9--sp {
  line-height: 1.9;
}

.line02,
.line02--sp,
.line02--sp02 {
  line-height: 2;
}

.line02_2 {
  line-height: 2.2;
}

.line02_4 {
  line-height: 2.4;
}

.line02_6 {
  line-height: 2.6;
}

.line03_2 {
  line-height: 3.2;
}

.line03_6 {
  line-height: 3.6;
}

.line-deduction {
  line-height: 1.4;
}

.text-space20 {
  letter-spacing: 0.005em;
}

.text-space50 {
  letter-spacing: 0.02em;
}

.text-space100 {
  letter-spacing: 0.04em;
}

.text-space120 {
  letter-spacing: 0.048em;
}

.text-space150 {
  letter-spacing: 0.06em;
}

.text-space200 {
  letter-spacing: 0.08em;
}

.text-space300 {
  letter-spacing: 0.12em;
}

.text-kerning,
.text-kerning-sp,
.text-kerning-nomal {
  font-feature-settings: "palt";
}

.text-space-minus {
  letter-spacing: -0.1em;
}

.text-space00 {
  letter-spacing: 0;
}

/*   button
--------------------------------------- */
.round05 {
  border-radius: 0.25rem;
}

.round10 {
  border-radius: 0.5rem;
}

.round15 {
  border-radius: 0.75rem;
}

.round20 {
  border-radius: 1rem;
}

.round30 {
  border-radius: 1.5rem;
}

.round40 {
  border-radius: 2rem;
}

.round50 {
  border-radius: 5rem;
}

.round-circle {
  border-radius: 50%;
}

/* button */
.button__text01 {
  font-size: 1.1rem;
}

.button__common {
  display: block;
  width: 100%;
  background: #ffffff;
  border: 1px solid #3c3c3c;
  color: #3c3c3c;
  height: 3em;
  padding: 0 1em 0 1.5em;
}

.button__common:visited {
  color: #3c3c3c;
}

.button__common:hover {
  color: #ffffff;
}

.button__common.button__blue06:hover {
  color: #ebf1f6;
}

.hvr-sweep-to-right:before {
  background: #3c3c3c;
}

.button__common:hover .arrow__button01::before {
  background: #a16060;
  transition-delay: 0.2s;
}

.button__common:hover .arrow__button01::after {
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  transition-delay: 0.2s;
}

.button__common.button__blue06 {
  background: #ebf1f6;
}

.button__common.button__blue06:hover .arrow__button01::before {
  background: #ebf1f6;
}

.button__common.button__blue06:hover .arrow__button01::after {
  border-top: 1px solid #ebf1f6;
  border-right: 1px solid #ebf1f6;
}

.button__common01 {
  width: 100%;
  margin: 0;
}

.button__common02 {
  width: 100%;
}

.button__oralsurgery {
  width: 100%;
  margin: 0;
}

.button__center {
  margin: 0 auto;
}

/* 
.button__common::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 0;
    display: block;
    background: #51a3db;
    z-index: -1;
    transition: .2s;
}

.button__common:hover::before {
    width: 100%;
    z-index: 1;
} */

.button__text {
  display: block;
  color: #51a3db;
  z-index: 10;
}

.button__common:hover .button__text {
  color: #ffffff;
}

.arrow__button02::before {
  border-top: 1px solid #51a3db;
  border-right: 1px solid #51a3db;
  z-index: 10;
}

.button__common:hover .arrow__button02::before {
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
}

.button__common04 {
  width: 100%;
  margin: 0;
}

.button__guide>div,
.button__box--0203>div,
.button__box--0204>div {
  width: 50%;
}

.button__medical02>div {
  width: 80%;
  margin: 0 auto 1rem auto;
}

.button__medical03 {
  width: 80%;
  margin: 0 auto;
}

.button__medical02>div:first-child {
  margin-bottom: 0.8rem;
}

.button__left {
  margin: 0;
}

/* round */
.title__color01 {
  width: 100%;
  padding: 0.8em 1em;
}

.title__color02 {
  width: 100%;
  padding: 1em 1em;
}

.title__color03 {
  width: 100%;
  padding: 1.5em 1em;
}

.title__color04,
.title__color05 {
  width: 100%;
  padding: 1em 1em;
}

/*   flexbox
--------------------------------------- */
.flex-item-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-direction: column;
  flex-direction: column;
}

.flex-item-center-sp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-direction: column;
  flex-direction: column;
}

.flex-item-center-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-direction: column;
  flex-direction: column;
}

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

.flex-column,
.flex-column-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.flex-row-column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}

.flex-justify-around,
.flex-justify-around-between {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.flex-justify-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.flex-justify-center,
.flex-justify-center-start {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.flex-justify-start-center {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.flex-justify-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.flex-justify-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.flex-align-start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.flex-align-strech {
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}

.flex-align-center,
.flex-align-center-start,
.flex-align-center-end,
.flex-align-center-strech {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.flex-align-end,
.flex-align-end-center,
.flex-align-end-start {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.flex-align-start-strech,
.flex-align-start-center {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.flex-wrap,
.flex-wrap-sp {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.flex-bottom {
  margin-top: auto;
}

/* 4ページ目 */
.flex-deduction {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/*   list
--------------------------------------- */
.list__text {
  font-size: 1.05rem;
}

.circle__list li,
.career__list li {
  position: relative;
  padding: 0;
  vertical-align: middle;
  text-indent: -1.2em;
  padding-left: 1.2em;
}

.asterisk__list li,
.career__list li:last-child,
.event__list li {
  position: relative;
  padding: 0;
  vertical-align: middle;
  text-indent: -1em;
  padding-left: 1em;
}

.square__list li {
  position: relative;
  padding: 0;
  vertical-align: middle;
  text-indent: -1.2em;
  padding-left: 1.2em;
}

.check__list li {
  position: relative;
  padding: 0;
  vertical-align: middle;
  text-indent: -1.1em;
  padding-left: 1.1em;
  width: 100%;
}

.check__icon {
  width: 1.1em;
  margin-right: 0.5em;
}

.dot__list li {
  position: relative;
  padding: 0;
  vertical-align: middle;
  text-indent: -1em;
  padding-left: 1em;
}

.space__list li {
  padding-bottom: 0.7em;
}

.space__list li:last-child {
  padding-bottom: 0;
}

/*   drawer
--------------------------------------- */
.drawer-hamburger {
  width: 26px !important;
  padding: 22px 24px 38px 20px !important;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  background-color: #404040 !important;
  height: 1px !important;
}

.drawer-open .drawer-hamburger-icon {
  background-color: #ffffff !important;
}

.drawer-hamburger-icon:before {
  top: -8px !important;
}

.drawer-hamburger-icon:after {
  top: 8px !important;
}

.drawer-open .drawer-hamburger-icon:after,
.drawer-open .drawer-hamburger-icon:before {
  top: 0 !important;
}

/* .menu-title {
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0.5rem;
    font-size: 8px;
}

.drawer-open .sp__menu .menu-title::before {
    font-size: 8px;
    content: 'CLOSE';
}

.drawer-open .sp__menu .menu-title {
    font-size: 0;
} */

.drawer-nav {
  width: 100vw !important;
  background-color: #e9eef4 !important;
}

.drawer-navbar .drawer-nav {
  padding-top: 0 !important;
  margin-top: 65px !important;
  right: -100vw !important;
}

.drawer--right.drawer-open .drawer-nav {
  right: 0 !important;
}

/* .drawer-menu {
    padding: 0 !important;
} */

.drawer-menu li a {
  color: #3c3c3c !important;
  border-bottom: 1.0909px solid #a1c2e2 !important;
  padding: 2rem 3rem;
  font-size: 1.1rem;
  vertical-align: middle;
}

.drawer-menu>li:last-child a {
  border-bottom: none !important;
}

.drawer-menu li a:hover {
  color: #3c3c3c !important;
}

.drawer-dropdown-menu {
  background-color: #6fa1d2 !important;
  padding: 1.5rem 3rem;
}

.drawer-dropdown-menu li a {
  color: #ffffff !important;
  border-bottom: none !important;
  padding: 1rem 0;
  font-size: 1rem;
}

.drawer-dropdown.open>.drawer-dropdown-menu.box-drawer {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

.drawer-dropdown-menu {
  position: relative;
}

.drawer-dropdown-menu.box-drawer01>li:first-child {
  width: 40% !important;
}

.drawer-dropdown-menu.box-drawer01>li:last-child {
  width: 60% !important;
}

.drawer-dropdown-menu.box-drawer02>li:nth-child(odd) {
  width: 60% !important;
}

.drawer-dropdown-menu.box-drawer02>li:nth-child(even) {
  width: 40% !important;
}

.drawer-dropdown-menu-item {
  line-height: 1.4 !important;
}

.drawer-menu-item:hover {
  text-decoration: none !important;
}

/*   header
--------------------------------------- */
.sp__header {
  height: 65px;
  top: 0;
  width: 100%;
  z-index: 9999 !important;
}

.sp__home {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 65px;
}

/* .sp__tel {
    position: fixed;
    top: 0;
    right: 65px;
    display: block;
    box-sizing: border-box;
    width: 65px;
    height: 65px;
    border: 0;
    outline: 0;
    z-index: 9999;
    padding: 12px 20px 12px 20px;
} */

.sp__menu {
  position: fixed;
  top: 0;
  right: 0;
  display: block;
  box-sizing: content-box;
  width: 65px;
  height: 65px;
  padding: 0;
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
  border: 0;
  outline: 0;
  z-index: 9999;
}

.header__logo {
  display: block;
  width: 60%;
  padding-left: 20px;
}

/* sp__menu */
.menu__toggle {
  position: absolute;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}

.menu__toggle:before,
.menu__toggle:after {
  display: block;
  content: "";
  background-color: #404040;
  position: absolute;
  width: 1.5rem;
  height: 1px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.menu__toggle:before {
  width: 1px;
  height: 1.5rem;
}

.menu__title.selected .menu__toggle:before {
  content: normal;
}

/* 1ページ目 */
.header__space {
  margin-top: 65px;
}

.header__img {
  height: 30rem;
}

.header__img__inner {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
}

.header__img--pc {
  display: none;
}

.header__img--sp {
  display: block;
  max-width: 95%;
  height: 35.2rem;
  margin: 0 auto;
}

.header__img__under {
  padding-top: 5.2rem;
}

.header__message {
  position: absolute;
  top: 2.25rem;
  /* left: 0;
    right: 0;
    margin: 0 auto;
    width: calc(95% - 2rem); */
  left: 2rem;
  z-index: 999;
}

.header__title01 {
  display: inline-block;
  font-size: 1.1rem;
}

.header__title02 {
  display: inline-block;
  font-size: 1.4rem;
  padding: 0.5em 0.5em 0.35em 0.5em;
}

.header__title02__01 {
  margin-top: 0.5em;
}

.header__title02__02 {
  margin-top: 0.3em;
}

.header__message--slide {
  animation-name: slideIn;
  animation-duration: 2s;
  animation-timing-function: ease-in;
  animation-fill-mode: forwards;
}

@keyframes slideIn {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
  }

  100% {
    -webkit-clip-path: inset(0);
    clip-path: inset(0);
  }
}

.header__career {
  display: block;
  position: absolute;
  width: 12rem;
  right: calc(2.5% + 0.5rem);
  bottom: 0.5rem;
  z-index: 99;
  padding: 0.5rem;
}

.header__career img {
  border: 1px solid #ffffff;
}

.header__career:hover {
  opacity: 0.8;
}

/* breadcrumb */
.breadcrumb li,
.breadcrumb span {
  font-size: 0.75rem;
}

.breadcrumb {
  padding-left: 0;
  margin-left: 0;
  text-align: left;
}

.bread-bottom {
  padding-bottom: 0;
}

.breadcrumb li {
  display: inline;
  list-style: none;
}

.breadcrumb li:after {
  content: ">";
  padding: 0 0.2em 0 0.5em;
  color: #333333;
}

.breadcrumb li:last-child:after {
  content: "";
}

.breadcrumb li a {
  text-decoration: none;
}

/*   footer
--------------------------------------- */
/* footer01 */
.footer__h1 {
  font-size: 1rem;
}

.footer__logo {
  display: block;
  width: 80%;
  margin: 0 auto;
}

.footer__left {
  width: 85%;
  margin: 0 auto;
  padding-bottom: 3rem;
}

.footer__tel01 {
  font-size: 1.5rem;
  margin-right: 1em;
  display: block;
}

.footer__tel02 {
  font-size: 0.95rem;
}

.footer__web {
  font-size: 1rem;
  display: block;
}

.footer__line {
  padding: 1rem 1rem;
  width: 60%;
  margin: 0 auto;
  margin-top: 1.5rem;
}

.footer__line__icon {
  width: 1.5em;
  padding-right: 0.2em;
}

.footer__line__text {
  font-size: 1.7rem;
}

.footer__table,
.footer__table tr {
  width: 100%;
}

.footer__table {
  margin-top: 1.3rem;
  position: relative;
  z-index: 99;
}

.footer__table th {
  width: 20%;
  vertical-align: text-top;
}

.footer__table td {
  width: 80%;
  padding-bottom: 0.7em;
}

.footer__text01 {
  font-size: 1rem;
}

/* footer02 */
.footer__text02 {
  font-size: 1rem;
  line-height: 2.4rem;
}

.footer__text03 {
  font-size: 0.9rem;
  line-height: 2.1rem;
}

.footer__menu>ul:first-child {
  width: 55%;
}

.footer__menu>ul:last-child {
  width: 45%;
}

.footer__menu>ul:first-child>li {
  width: 12rem;
}

.footer__menu>ul:last-child>li {
  width: 9rem;
}

.footer__menu a:visited,
.footer__menu a:hover {
  color: #ffffff;
}

.footer__border::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 2%;
  width: 0.8864px;
  height: 96%;
  background-color: #7490ba;
}

.copy__text {
  font-size: 0.8rem;
  padding-bottom: 5rem;
}

/*  news
---------------------------------------*/
.border-post {
  border-top: 0.9754px solid #3c3c3c;
  padding: 2rem 0.2rem;
}

.border-post:last-child {
  border-bottom: 0.9754px solid #3c3c3c;
}

.post__title01 {
  font-size: 0.8rem;
}

.post__title02 {
  font-size: 0.65rem;
  margin: 0 1.5em;
}

.post__title03 {
  font-size: 0.9rem;
}

.post__cat {
  padding: 0.5em 1em;
  width: 6.5em;
  background-color: var(--color-primary);
}

/* single */
.post-cat-title02 {
  display: block;
  padding: 0.5em 1em;
}

.border-single {
  border-bottom: 2px solid var(--color-primary);
  padding-bottom: 1rem;
  margin-bottom: 3rem;
}

.post-img img {
  display: block;
  margin: 0 auto 3.5rem auto;
  width: 70%;
  height: auto;
}

.flex-cat li {
  margin-right: 1rem;
}

.cat-box {
  padding-top: 3rem;
}

.cat-box>p {
  width: 9em;
  background-color: #3c3c3c;
  padding: 0.5em 0;
}

.cat-box>ul {
  padding: 1rem 0 0 0;
}

.cat-box>ul>li {
  /* background-image: url("../img/99-tag.svg");
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: contain; */
  line-height: 1;
  padding-left: 1.5em;
  margin: 0 1em 0.25em 0;
}

.cat-box>ul>li img {
  display: inline-block;
  width: 1.5em;
}

.cat-box>ul>li a {
  color: #3c3c3c;
  display: inline-block;
  line-height: 1;
  margin-bottom: 0.25em;
}

.line-post>p {
  line-height: 2.4;
}

.line-post>p img {
  display: inline-block;
  height: auto;
}

/* sidebar */
.blog__main,
.blog__side {
  width: 100%;
}

.blog__side {
  padding-top: 4rem;
}

.side__list,
.side__list li,
.side__list h2,
.side__list ul {
  position: relative;
}

.side__list h2 {
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 0.5em;
  margin-bottom: 1px;
  color: var(--color-primary);
  font-size: 1.2rem;
  /*源ノ角ゴシック Medium*/
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 500;
  font-style: normal;
}

.side__list h2::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 5em;
  height: inherit;
  border-bottom: 1px solid var(--color-primary);
}

.side__list ul {
  padding: 0.5rem 0 3rem 0;
}

.side__list a,
.side__list a:hover,
.side__list a:visited {
  color: #3c3c3c;
}

.side__list a {
  font-size: 1rem;
  display: block;
  padding: 0.5em 0.2em;
  /*源ノ角ゴシック Nomal*/
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 300;
  font-style: normal;
}

/*  content
--------------------------------------- */
/* arrow */
.arrow__menu01 {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  width: auto;
  margin-left: 1em;
}

.arrow__menu01::before {
  position: absolute;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.arrow__menu01::before {
  top: 25%;
  right: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-bottom: 0.7134px solid #3c3c3c;
  border-right: 0.7134px solid #3c3c3c;
  transform: rotate(45deg);
}

.arrow__button01 {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  width: 2em;
}

.arrow__button01::before,
.arrow__button01::after {
  position: absolute;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.arrow__button01::before {
  left: 0.5em;
  width: 1.5em;
  height: 1px;
  background: #3c3c3c;
}

.arrow__button01::after {
  left: auto;
  right: 0;
  top: -0.2em;
  width: 0.5em;
  height: 0.5em;
  border-top: 1px solid #3c3c3c;
  border-right: 1px solid #3c3c3c;
  transform: rotate(45deg);
}

/* features */
.features__num {
  font-size: 2.7rem;
}

.features__num--deco {
  position: absolute;
  top: 0;
  left: 0;
}

.features__title {
  font-size: 1.6rem;
}

/* flow */
.flow__box {
  border: 5px solid #eaeff5;
  padding: 1.5rem 1.5rem 2rem 1.5rem;
}

.flow__arrow {
  height: 3.5rem;
}

.flow__arrow::before,
.flow__arrow::after {
  position: absolute;
  top: 1rem;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.flow__arrow::before {
  left: 1rem;
  box-sizing: border-box;
  width: 1rem;
  height: 1rem;
  border: 1rem solid transparent;
  border-top: 1rem solid var(--color-primary);
}

.flow__arrow02::before {
  left: 1rem;
  box-sizing: border-box;
  width: 0.3rem;
  height: 1rem;
  border: 0.8rem solid transparent;
  border-top: 1.2rem solid var(--color-primary);
}

.visitingflow__box {
  padding: 1.8rem 1.5rem;
}

.visitingflow__text {
  letter-spacing: -0.4px;
}

/* table */
.cost__table02,
.cost__table02 tr {
  width: 100%;
}

.cost__table02 th,
.cost__table02 td {
  border: 1px solid var(--color-primary);
  padding: 0.8em 1em;
}

.cost__table02 th {
  width: 67%;
}

.cost__table02 td {
  width: 33%;
}

/* 下層ページ */
.medicalcontents__list01 li {
  width: 48%;
  margin-bottom: 1.6rem;
  height: 4em;
}

.medicalcontents__title01 {
  font-size: 1.1rem;
}

.medicalcontents__title02 {
  padding: 1.5em 0 0.8em 0;
}

.medicalcontents__list02 li {
  padding-bottom: 3rem;
  width: 90%;
  margin: 0 auto;
}

.medicalcontents__list03 li {
  padding: 2.5rem 2.25rem 2.75rem 2.25rem;
  margin-bottom: 3.2rem;
}

.medicalcontents__list04 li {
  margin-bottom: 3.2rem;
}

.medicalcontents__none {
  display: none;
}

/*   1ページ目
--------------------------------------- */
/* news */
.covid__text {
  font-size: 0.95rem;
  padding: 1em;
}

.covid__text>span {
  display: block;
}

.covid__icon {
  display: block;
  width: 1.5em;
}

.covid__arrow {
  display: block;
  width: 1.5em;
}

.event__box--sp {
  margin-top: 1.5rem;
}

.event__box dt {
  padding: 0.8rem 0;
}

.event__box dd {
  padding: 0.8rem 1.9rem 1rem 1.9rem;
}

.event__icon {
  width: 3.8rem;
  height: 3.8rem;
  border: 0.8884px solid #ffffff;
}

.event__title01 {
  font-size: 2.7rem;
  padding: 0.1em 0 0 0.15em;
}

.event__title02 {
  font-size: 0.9rem;
}

.event__title02--space {
  padding-top: 0.4em;
}

.event__deco {
  width: 105%;
  height: 0.5rem;
  position: absolute;
  top: 1.5rem;
  left: -2.5%;
}

.event__title03 {
  font-size: 3.6rem;
}

.event__title04 {
  font-size: 1.1rem;
}

.event__title05 {
  font-size: 1.4rem;
}

.event__title06 {
  font-size: 1rem;
  padding: 0.2em 0.1em 0 0.1em;
}

.event__title06 span {
  display: block;
}

.event__text {
  padding-top: 0.55em;
  margin-top: 0.8em;
}

.event__list__text {
  font-size: 0.95rem;
}

.news__img img {
  display: block;
  width: 100%;
  height: 14rem;
  object-fit: cover;
}

.news__box {
  padding: 1.5rem 1.5rem;
}

.news__title01 {
  font-size: 0.9rem;
}

/* features */
.features__text01 {
  font-size: 1.1rem;
}

.features__list {
  width: 90%;
  margin: 0 auto;
}

.features__list li {
  padding-top: 1rem;
  margin-top: 2.25rem;
}

.features__border {
  padding-top: 1em;
  padding-bottom: 0.5em;
  border-bottom: 1px dotted #000000;
}

/* treatment */
.treatment__list01 li {
  width: 32%;
  margin-bottom: 1.6rem;
}

.treatment__list01 li:not(:first-child) h4 {
  padding: 0.5em 0;
}

.treatment__list01 li:nth-child(13),
.treatment__list01 li:nth-child(14),
.treatment__list01 li:nth-child(15) {
  display: none;
}

.treatment__list01 li:hover {
  transform: scale(1.1);
  transition-duration: 0.6s;
}

.treatment__box {
  display: block;
  border: 0.95px solid #6fa1d2;
  margin: 0.4rem;
  padding: 0.6rem 0.4rem;
}

.treatment__img {
  display: block;
  width: 4.5em;
  margin: 0 auto;
}

.treatment__title01 {
  font-size: 0.95rem;
}

/*   2ページ目
--------------------------------------- */
/* guide */
.guide__box02 {
  padding: 2.5rem 2rem 3rem 2rem;
}

.guide__title01 {
  font-size: 1.4rem;
}

.guide__box03 a {
  height: 3rem;
}

.guide__box03 a:last-child {
  margin-top: 1rem;
}

.guide__icon {
  width: 1.8rem;
  height: 1.8rem;
  margin-right: 0.5rem;
}

.guide__tel {
  font-size: 1.6rem;
}

.guide__web {
  font-size: 1.2rem;
}

.guide__treatmenttime {
  display: block;
  width: 100%;
  margin: 0 auto;
}

/*   3ページ目
--------------------------------------- */
/* features */
.bg-features01 {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.bg-features02 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.features__box {
  width: 95%;
  margin: 0 auto;
}

/*   4ページ目
--------------------------------------- */
/* deduction */
.deduction__img {
  display: block;
  width: 80%;
  margin: 0 auto;
  padding-top: 2rem;
}

.deduction__box02 {
  padding: 2rem 2rem 2.5rem 2rem;
  margin-top: 1.75rem;
}

.deduction__box03 {
  padding: 2rem 2rem 2.5rem 2rem;
  margin-top: 1.5rem;
}

.deduction__list__text {
  font-size: 0.95rem;
}

/*   5ページ目
--------------------------------------- */
/* facility */
.facility__title {
  padding: 1.5em 0 1em 0;
}

.facility__list li {
  padding-bottom: 4rem;
}

.facility__list--last {
  display: none;
}

/*   6ページ目
--------------------------------------- */
/* doctor */
.doctor__title01 {
  font-size: 1.7rem;
}

.doctor__title02 {
  font-size: 1.1rem;
  padding-bottom: 0.15em;
}

.doctor__title03 {
  font-size: 1.6rem;
  padding: 0 0.5em;
}

.doctor__title04 {
  font-size: 0.9rem;
}

.doctor__table01,
.doctor__table01 tr,
.doctor__table02,
.doctor__table02 tr,
.doctor__table02 td {
  width: 100%;
}

.doctor__table01 th {
  width: 8em;
}

.doctor__table01 td {
  width: auto;
}

.doctor__table01,
.doctor__table02 {
  margin-top: 1rem;
}

/*   7ページ目
--------------------------------------- */
/* career */
.career__title {
  font-size: 1.3rem;
  padding: 1em 0;
  width: 48%;
  margin-right: 2%;
}

.career__title01 {
  font-size: 1.6rem;
}

.career__title02 {
  font-size: 1.2rem;
}

.career__title03 {
  font-size: 1.4rem;
}

.career__text01 {
  font-size: 1.1rem;
}

.career__num {
  width: 1.75rem;
  height: 1.75rem;
  margin-right: 0.5rem;
}

.career__box01 {
  padding: 2rem 1rem 3rem 1rem;
}

.career__border {
  position: absolute;
  border-top: 1.6213px solid #006ab2;
  border-left: 1.6213px solid #006ab2;
  width: 1.5rem;
  height: 1.5rem;
}

.career__border01 {
  top: 0;
  left: 0;
}

.career__border02 {
  transform: rotate(90deg);
  top: 0;
  right: 0;
}

.career__border03 {
  transform: rotate(180deg);
  bottom: 0;
  right: 0;
}

.career__border04 {
  transform: rotate(270deg);
  bottom: 0;
  left: 0;
}

.career__list01 {
  width: 100%;
}

.career__list01 li {
  margin-bottom: 1rem;
  width: 100%;
}

.career__box03 {
  width: 100%;
  margin: 0 auto;
  background-color: #e7ebf3;
  padding: 1.5rem 2rem 2rem 2rem;
}

.career__box04 {
  display: inline-block;
}

.career__box04::before,
.career__box04::after {
  content: "";
  height: 7.5rem;
  width: 3px;
  background-color: #006ab2;
  border-radius: 5rem;
  position: absolute;
}

.career__box04::before {
  bottom: 0;
  left: -2rem;
  transform: rotate(-25deg);
}

.career__box04::after {
  bottom: 0;
  right: -2rem;
  transform: rotate(25deg);
}

/* recruit */
.recruit__box {
  margin-top: 3rem;
  padding: 1.25rem 1rem;
}

.career__table,
.career__table tr {
  width: 100%;
}

.career__table tr {
  border-bottom: 0.4945px solid #919191;
}

.career__table tr:last-child {
  border-bottom: none;
}

.career__table th {
  width: 25%;
  padding: 1.75rem 0.5rem;
}

.career__table td {
  width: 75%;
  padding: 1.75rem 0;
}

.career__none {
  display: none;
}

.recruit__title {
  font-size: 1.1rem;
}

/*   8ページ目
--------------------------------------- */
/* prevention */
.prevention__title01 {
  font-size: 1.4rem;
  padding: 1.5em 0;
}

/* exam */
.exam__title01 {
  font-size: 2.2rem;
  padding-right: 0.3em;
}

.exam__box {
  padding: 2rem 1.5rem;
}

/*   9ページ目
--------------------------------------- */
/* reason01 */
.caries__box01>div:first-child {
  width: 85%;
  margin: 0 auto;
}

/* reason02 */
.caries__box02>div:first-child {
  width: 80%;
  margin: 0 auto;
}

.reason__text {
  font-size: 0.9rem;
}

/*   10ページ目
--------------------------------------- */

/*   11ページ目
--------------------------------------- */
/* please */
.please__box dt {
  padding: 2rem 0 1.5rem 0;
}

.please__box dd {
  padding: 1rem 1rem;
}

/* area */
.area__box01 {
  padding: 2.5rem 1.5rem;
}

.area__box02 div:last-child {
  width: 80%;
  margin: 0 auto;
}

.area__box03 {
  padding: 2.5rem 1.5rem;
}

.area__box03 a {
  width: 80%;
  height: 3.5rem;
}

.area__title {
  font-size: 1.25rem;
}

/*   12ページ目
--------------------------------------- */
/* difference */
.difference__box {
  margin-top: 2rem;
}

.difference__box dt {
  padding: 2rem 0 1.5rem 0;
}

.difference__box dd {
  padding: 1.2rem 1.5rem 1.5rem 1.5rem;
}

/* type */
.type__title01 {
  padding: 0.5em 0 0.5em 0;
  width: 5rem;
  margin: 0.2rem 0.5rem 0 0;
}

.type__text {
  padding-top: 0.5rem;
}

.whitening-type__cost {
  width: 100%;
  margin: 0 auto;
  margin-top: 2.25rem;
}

.whitening-type__cost tr {
  width: 100%;
  border: 2px solid var(--color-primary);
}

.whitening-type__cost th,
.whitening-type__cost td {
  border: 1px solid var(--color-primary);
}

.whitening-type__cost tr:first-child th {
  border-right: 1px solid #ffffff;
}

.whitening-type__cost th {
  width: 30%;
  padding: 0.8em 1em;
}

.whitening-type__cost th.cost__title01 {
  width: 36%;
}

.whitening-type__cost td {
  width: 34%;
  padding: 0.8em 0.8em 0.8em 0.4em;
}

/* whitening02 */
.whitening-type__cost__sm {
  width: 100%;
}

.whitening-type__cost__sm th,
.whitening-type__cost__sm td {
  border: 1px solid var(--color-primary);
  padding: 0.8em 1em;
}

.whitening-type__cost__sm th {
  width: 55%;
}

.whitening-type__cost__sm td {
  width: 45%;
}

/*   13ページ目
--------------------------------------- */
/* type */
.type__list>li {
  padding: 2.3rem 1.8rem;
}

.type__img {
  display: block;
  width: 70%;
  margin: 0 auto;
}

.type__title02 {
  padding: 1.5em 0 1em 0;
}

.type__title03 {
  padding: 0.5em 0;
}

.type__icon {
  display: block;
  width: 1.2em;
  margin-right: 0.25em;
}

.implant-type__cost01 {
  width: 100%;
  margin: 0 auto;
  margin-top: 2.25rem;
}

.implant-type__cost01 tr {
  width: 100%;
  border: 2px solid var(--color-primary);
}

.implant-type__cost01 th,
.implant-type__cost01 td {
  border: 1px solid var(--color-primary);
}

.implant-type__cost01 tr:first-child th {
  border-right: 1px solid #ffffff;
}

.implant-type__cost01 th {
  width: 31%;
  padding: 0.8em 1em;
}

.implant-type__cost01 th.cost__title02 {
  width: 35%;
}

.implant-type__cost01 td {
  width: 34%;
  padding: 0.8em 0.8em 0.8em 0.4em;
}

/* implant */
.implant__text {
  font-size: 1.05rem;
}

.implant-type__cost02 {
  width: 100%;
  margin: 0 auto;
  margin-top: 2.25rem;
}

.implant-type__cost02 tr {
  width: 100%;
  border: 2px solid var(--color-primary);
}

.implant-type__cost02 tr:first-child th {
  border-right: 1px solid #ffffff;
}

.implant-type__cost02 th,
.implant-type__cost02 td {
  border: 1px solid var(--color-primary);
  width: 50%;
  padding: 0.8em 1em;
}

/*   14ページ目
--------------------------------------- */
/* recommendation */
.recommendation__list li {
  width: 100%;
  height: 4em;
  margin-bottom: 1.2rem;
}

/* notes */
.notes__box dt {
  padding: 2rem 0 1.5rem 0;
}

.notes__box dd {
  padding: 1.2rem 1.5rem 1.5rem 1.5rem;
}

/*   15ページ目
--------------------------------------- */
/* therapy */
.therapy__box {
  margin-top: 2rem;
}

.therapy__box dt {
  padding: 2rem 0 1.5rem 0;
}

.therapy__box dd {
  padding: 1.2rem 0.5rem 1.5rem 1.5rem;
}

/*  動き
--------------------------- */
.fade-up,
.fade-features {
  transition: 1s;
  opacity: 0;
  transform: translate(0, 50px);
}

.fade-visible {
  transition: 0.8s;
  opacity: 0;
  transform: translate(0, 50px);
}

.delay01 {
  transition-delay: 0.3s;
}

.delay02 {
  transition-delay: 0.6s;
}

.fade-non {
  transform: none;
}

.fade-left01 {
  transition-duration: 1s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.fade-left02 {
  transition-duration: 1s;
  transition-delay: 0.3s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.fade-left03 {
  transition-duration: 1s;
  transition-delay: 0.6s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.fade-left04 {
  transition-duration: 1s;
  transition-delay: 0.9s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.fade-left05 {
  transition-duration: 1s;
  transition-delay: 1.2s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.fade-left06 {
  transition-duration: 1s;
  transition-delay: 1.5s;
  opacity: 0;
  transform: translate(-100px, 0);
}

.isAnimate {
  opacity: 1;
  transform: translate(0, 0);
}

.isAnimate02 {
  opacity: 1;
  transform: scale(1, 1);
}

/* menu */
.menu--close {
  opacity: 0;
}

.menu--open {
  opacity: 1;
  width: 100vw;
  height: 100vh;
  background-color: rgba(91, 67, 48, 0.9);
  transition: all 1.5s;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}

.menu__treatment {
  display: block;
  width: 70%;
  margin: 0 auto;
  padding-top: 4rem;
}

/* loading */
.loading {
  width: 100vw;
  height: 100vh;
  background-color: #ffffff;
  transition: all 1s;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}

.loaded {
  opacity: 0;
  visibility: hidden;
}

.loading__img {
  display: block;
  width: 50%;
  margin: 0 auto;
  /* padding-top: 25vh; */
}

.loading__text {
  font-size: 1rem;
}

.eachTextAnime {
  opacity: 0;
}

.eachTextAnime span {
  opacity: 0;
}

.eachTextAnime.appeartext {
  opacity: 1;
}

.eachTextAnime.appeartext span {
  animation: text_anime_on 0.8s ease-out forwards;
}

@keyframes text_anime_on {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.scroll__text {
  position: absolute;
  width: 100%;
  bottom: 2rem;
  text-align: center;
  font-size: 0.7rem;
  display: inline-block;
  padding: 0 0 3rem;
  cursor: pointer;
}

.scroll__text::before {
  content: "";
  position: absolute;
  width: 1.2em;
  height: 1.2em;
  left: 0;
  right: 0;
  bottom: 2.2rem;
  margin: auto;
  border-bottom: 1px solid #333333;
  border-right: 1px solid #333333;
  transform: rotate(45deg);
}

/* @keyframes move {
    0% {
        transform: rotate(45deg) translate(0, 0);
    }

    50% {
        transform: rotate(45deg) translate(10px, 10px);
    }

    100% {
        transform: rotate(45deg) translate(0, 0);
    }
} */

.loading__area {
  width: 100vw;
  height: 100vh;
}

.loadingbody {
  overflow: hidden;
}

/*   swiper
--------------------------------------- */
.swiper-button-next,
.swiper-button-prev {
  width: 3.75rem;
  height: 3.75rem;
}

.swiper-button-prev {
  background: none;
}

.swiper-button-next {
  background: none;
}

.swiper-button-next:after,
.swiper-button-prev:after {
  font-size: 0;
}

.swiper-slide img {
  opacity: 0.5;
}

.swiper-slide-active img {
  opacity: 1;
}

/* facility */
.swiper__facility {
  padding-bottom: 2.75rem;
  overflow: hidden;
}

.swiper-pagination-bullet {
  background: #c4c4c4;
  width: 0.6rem;
  height: 0.6rem;
  margin: 0 0.5rem !important;
}

.swiper-pagination-bullet-active {
  background: var(--color-primary);
}

.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 0;
}

/* ゆっくり */
.swiper-doctor {
  width: 100%;
  position: relative;
  overflow: hidden;
}

/*   googlemap枠
---------------------------------- */

.ggmap {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 60%;
  overflow: hidden;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*   pagetop設定
---------------------------------- */
.fixed--sp {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
}

.fixed__icon {
  display: block;
  width: 2rem;
  height: 2rem;
}

.fixed__text {
  display: block;
  font-size: 1.2rem;
  padding: 1em 0 1em 0.5em;
}

.fixed__tel {
  width: 30%;
}

.fixed__web {
  width: 35%;
}

.fixed__line {
  width: 35%;
}

.fixed--pc {
  display: none;
}

.fixed__pagetop {
  width: 18%;
  padding-right: 2px;
}

/* .pagetop {
    position: fixed;
    bottom: 5px;
    right: 3%;
    width: 20%;
    z-index: 1000;
} */

.pagetop {
  display: block;
}

.googlepolicy {
  padding: 1rem 0;
  line-height: 1.9;
  font-size: 1.1rem;
}

.googlepolicy li {
  color: #3676ba;
  margin-left: 1.5em;
  text-indent: -1.5em;
}

.googlepolicy li a {
  text-decoration: underline;
}

@media only screen and (min-width: 520px) {
  html {
    font-size: 15px;
  }

  .grid-container01,
  .grid-container02,
  .grid-container05,
  .grid-container06 {
    width: 80%;
  }

  .grid-container03,
  .grid-container04 {
    width: 85%;
  }

  .grid-container99 {
    width: 100%;
  }

  .anchor {
    margin-top: -85px;
    padding-top: 85px;
  }

  /*   改行
--------------------------------------- */
  .br-ip::before {
    content: "";
  }

  .br-ip-tab::before {
    content: "";
  }

  /*   drawer
--------------------------------------- */
  .drawer-hamburger {
    width: 30px !important;
    padding: 30px 30px 38px 18px !important;
  }

  .drawer-hamburger-icon:before {
    top: -9px !important;
  }

  .drawer-hamburger-icon:after {
    top: 9px !important;
  }

  .drawer-navbar .drawer-nav {
    margin-top: 85px !important;
  }

  .menu-title {
    font-size: 10px;
  }

  .drawer-open .menu-title::before {
    font-size: 10px;
  }

  /*   header
--------------------------------------- */
  .sp__header {
    height: 85px;
  }

  .sp__home {
    height: 85px;
  }

  /* .sp__tel {
        width: 80px;
        height: 80px;
        padding: 12px 23px 12px 23px;
        right: 80px;
    } */

  .sp__menu {
    width: 80px;
    height: 80px;
  }

  .header__logo {
    width: 60%;
  }

  /* header */
  .header__space {
    margin-top: 80px;
  }

  .header__img {
    height: 34rem;
  }

  .header__img--sp {
    height: 39rem;
  }

  .header__img__under {
    padding-top: 5rem;
  }

  .header__message {
    left: 3rem;
  }

  /*   1ページ目
--------------------------------------- */
  .treatment__box {
    margin: 0.6rem;
    padding: 0.8rem 0.6rem;
  }
}

@media only screen and (min-width: 768px) {
  html {
    font-size: 13px;
  }

  .grid-container01 {
    width: 85%;
  }

  .grid-container02 {
    width: 82%;
  }

  .grid-container03 {
    /*width: 85%;*/
    width: 95%;
  }

  .grid-container04 {
    width: 90%;
  }

  .grid-container05,
  .grid-container06 {
    width: 80%;
  }

  .grid-container99 {
    width: 85%;
  }

  .anchor {
    margin-top: -6rem;
    padding-top: 6rem;
  }

  .anchor02 {
    margin-top: -10rem;
    padding-top: 10rem;
  }

  .pc-mode {
    display: block;
  }

  .sp-mode {
    display: none;
  }

  .pc-inline {
    display: inline;
  }

  .left-center {
    text-align: center;
  }

  .center-left {
    text-align: left;
  }

  .center-right {
    text-align: right;
  }

  .text-kerning-sp {
    font-feature-settings: "zero";
  }

  .text-kerning-pc {
    font-feature-settings: "palt";
  }

  /*   bg
--------------------------------------- */
  .bg-pattern {
    background-image: url(../img/01-back-left.png),
      url(../img/01-back-right.png);
    background-size: 30rem, 30rem;
  }

  .bg-header {
    background-position: left top;
    background-size: 100%;
  }

  .bg-footer {
    background-image: url("../img/99-footer-bg.png");
  }

  .bg-news {
    background-image: url("../img/01-news-bg.png");
    background-size: 100%;
  }

  /*   text(768～)
--------------------------------------- */
  .cmn__title01 {
    font-size: 2rem;
  }

  .cmn__title02 {
    font-size: 0.8rem;
  }

  .cmn__title03 {
    font-size: 1.5rem;
  }

  .cmn__title04 {
    font-size: 1.1rem;
  }

  .cmn__title05 {
    font-size: 1.3rem;
  }

  .cmn__title06 {
    font-size: 1.6rem;
  }

  .cmn__title07 {
    font-size: 1rem;
  }

  .cmn__text01 {
    font-size: 0.9rem;
  }

  .cmn__text02 {
    font-size: 0.8rem;
  }

  /*   改行
--------------------------------------- */
  .br-sp::before,
  .br-sp-space::before {
    content: "";
  }

  .br-tab01::before,
  .br-ip-tab::before {
    content: "\A";
    white-space: pre;
  }

  .br-pc::before {
    content: "\A";
    white-space: pre;
  }

  .br-sptab {
    display: none;
  }

  /*   スペース
--------------------------------------- */
  .top05--sp,
  .top10--sp,
  .top20--sp,
  .top40--sp,
  .top50--sp,
  .top60--sp,
  .top80--sp {
    padding-top: 0;
  }

  .bottom40--sp {
    padding-bottom: 0;
  }

  .bottom55--pc {
    padding-bottom: 2.75rem;
  }

  /*   行間,文字間
--------------------------------------- */
  .line01_2--sp,
  .line01_4--sp,
  .line01_6--sp,
  .line01_8--sp,
  .line02--sp,
  .line-deduction {
    line-height: 1;
  }

  .line02--pc {
    line-height: 2;
  }

  /*   button
--------------------------------------- */
  .round-50 {
    border-radius: 2.5rem;
  }

  /* button */
  .button__text01 {
    font-size: 0.9rem;
  }

  .button__common {
    padding: 0 1em 0 2em;
  }

  .button__common01 {
    width: 20em;
  }

  .button__common02 {
    width: 21em;
  }

  .button__oralsurgery {
    width: 50%;
  }

  /* round */
  .title__color01 {
    padding: 0.6em 0;
  }

  .title__color02 {
    padding: 1em 0;
  }

  .title__color03 {
    padding: 1.5em 0;
  }

  .title__color04 {
    padding: 1em 1em;
  }

  .title__color05 {
    padding: 0.6em 1em;
  }

  /*   flexbox
--------------------------------------- */
  .flex-item-center-sp {
    display: block;
  }

  .flex-menu {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

  .flex-column-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

  .flex-row-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .flex-justify-around-between {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .flex-justify-center-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .flex-justify-start-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .flex-align-center-strech,
  .flex-align-start-strech {
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
  }

  .flex-align-start-center,
  .flex-align-end-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .flex-align-center-start,
  .flex-align-end-start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  .flex-align-center-end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .flex-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }

  .flex-wrap-sp {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .flex-button>div {
    margin-right: 1.5rem;
  }

  .flex-50 {
    width: 50%;
  }

  /*   list
--------------------------------------- */
  .list__text {
    font-size: 0.9rem;
  }

  .check__list {
    width: 50%;
  }

  /*   header
--------------------------------------- */
  /* menu */
  .sp__header {
    display: none;
  }

  .pc__header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    width: 100%;
    background-color: #ffffff;
  }

  .pc__menu {
    width: 100%;
    height: 5.5rem;
    padding-bottom: 0.5rem;
  }

  .pc__menu__inner {
    width: 100%;
    margin: 0 auto;
    transition: 0.3s;
  }

  .header__logo {
    display: block;
    width: 22%;
    padding: 1.5rem 0;
    margin-left: 6.725%;
  }

  .header__menu {
    width: 58%;
    margin-right: 6.725%;
  }

  .header__menu__inner {
    transition: all 0.5s ease 0s;
    display: none;
    /* background: rgba(48, 66, 79, 0.9); */
    width: 100%;
    position: absolute;
    top: 3.5rem;
    left: 0;
    padding: 1.1em 0 1.5em;
    z-index: 9999;
  }

  .header__nav:hover .header__menu__inner {
    display: block;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
  }

  .navdrop {
    background-color: rgba(111, 161, 210, 0.9);
    padding: 1.5rem 0 2rem 0;
    margin: 0 auto;
  }

  .navdrop__menu>li {
    border-right: 1px solid #a1c2e2;
    padding: 0 2.5rem;
  }

  .navdrop__menu>li:last-child {
    border-right: none;
  }

  .navdrop__menu a:visited {
    color: #ffffff;
  }

  .menu__text01 {
    display: block;
    font-size: 0.9rem;
    padding-bottom: 2px;
    margin-bottom: -2px;
  }

  .menu__text01::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.5em;
    width: 0%;
    height: 2px;
    background: var(--color-primary);
    z-index: -1;
    transition: all 0.4s;
  }

  .menu__text01:hover::after {
    width: 100%;
    z-index: 99;
  }

  .menu__line01:hover::after {
    width: 4em;
  }

  .menu__line02:hover::after {
    width: 6em;
  }

  .menu__text02 {
    font-size: 0.9rem;
  }

  /* header */
  .header__space {
    margin-top: 5.5rem;
  }

  .header__img {
    height: 33rem;
  }

  .header__img--pc {
    display: block;
    max-width: 95%;
    height: 36rem;
    margin: 0 auto;
  }

  .header__img--sp {
    display: none;
  }

  .header__img__under {
    padding-top: 3rem;
  }

  .header__message {
    top: 33%;
    /* width: calc(86.55% - 4rem); */
    left: auto;
    right: 38%;
  }

  .header__title01 {
    font-size: 1.3rem;
  }

  .header__title02 {
    font-size: 1.9375rem;
  }

  .header__career {
    right: 7%;
    bottom: 1.5rem;
  }

  /*   footer
---------------------------------- */
  /* footer01 */
  .footer__h1 {
    font-size: 0.8rem;
  }

  .footer__logo {
    width: 70%;
  }

  .footer__left {
    width: 50%;
    padding-right: 5%;
    padding-bottom: 4rem;
  }

  .footer__right {
    width: 50%;
  }

  .footer__tel01 {
    font-size: 1.4rem;
  }

  .footer__tel02 {
    font-size: 0.9rem;
  }

  .footer__web {
    font-size: 0.9rem;
    margin-top: 1em;
  }

  .footer__line {
    padding: 0.5rem 1rem;
    width: auto;
    margin: 0;
  }

  .footer__line__text {
    font-size: 1.25rem;
  }

  .footer__table th {
    width: 20%;
  }

  .footer__table td {
    width: 80%;
  }

  .footer__text01 {
    font-size: 0.9rem;
  }

  /* footer02 */
  .footer__text02 {
    font-size: 0.9rem;
  }

  .footer__text03 {
    font-size: 0.85rem;
  }

  .footer__menu>ul {
    width: auto;
  }

  .footer__menu>ul:first-child {
    width: 28%;
  }

  .footer__menu>ul:nth-child(2) {
    /*width: 17%;*/
    width: 25%;
  }

  .footer__menu>ul:last-child {
    width: 55%;
  }

  .footer__menu>ul:first-child>li {
    width: 13rem;
  }

  .footer__menu>ul:nth-child(2)>li {
    /*width: 6rem;*/
    width: 11rem;
  }

  .footer__menu>ul:last-child>li {
    width: 27rem;
  }

  .copy__text {
    font-size: 0.7rem;
    padding-bottom: 2em;
  }

  /*  news
---------------------------------------*/
  .post__title01 {
    font-size: 0.8rem;
  }

  .post__title02 {
    font-size: 0.65rem;
  }

  .post__title03 {
    font-size: 0.9rem;
  }

  /* single */
  .cat-box>ul {
    padding: 0 0 0 1rem;
  }

  .cat-box>ul>li {
    padding-left: 1.7em;
    margin: 0 2em 0 0;
  }

  /* sidebar */
  .blog__main {
    width: 67%;
  }

  .blog__side {
    width: 33%;
    padding-left: 9%;
    padding-top: 0;
  }

  .side__list h2 {
    font-size: 1.2rem;
  }

  /*  content
--------------------------------------- */
  /* features */
  .features__num {
    font-size: 2.5rem;
  }

  .features__title {
    font-size: 1.3rem;
  }

  /* treatmentflow */
  .flow__box {
    padding: 2rem 2rem 2.5rem 2rem;
  }

  .flow__box>div:first-child {
    width: 35%;
  }

  .flow__box>div:last-child {
    width: 60%;
  }

  .visitingflow__box {
    padding: 1.8rem 1.8rem 2rem 1.8rem;
  }

  /* 下層ページ */
  .medicalcontents__box01>div:first-child {
    width: 44%;
  }

  .medicalcontents__box01>div:last-child {
    width: 50%;
  }

  .medicalcontents__box02>div:first-child {
    width: 66%;
  }

  .medicalcontents__box02>div:last-child {
    width: 30%;
  }

  .medicalcontents__box03>div:first-child {
    width: 30%;
  }

  .medicalcontents__box03>div:last-child {
    width: 65%;
  }

  .medicalcontents__list01 li {
    width: 32%;
  }

  .medicalcontents__title01 {
    font-size: 1rem;
  }

  .medicalcontents__list02 li {
    width: 29%;
    margin: 0;
    padding-bottom: 0;
  }

  .medicalcontents__list03 li {
    padding: 2.5rem 2.25rem 2.75rem 2.25rem;
    margin-bottom: 3.2rem;
  }

  .medicalcontents__list03 li>div:first-child {
    width: 26%;
  }

  .medicalcontents__list03 li>div:last-child {
    width: 70%;
  }

  .medicalcontents__list04 li {
    margin-bottom: 3.5rem;
  }

  .medicalcontents__list04 li>div:first-child {
    width: 30%;
  }

  .medicalcontents__list04 li>div:last-child {
    width: 65%;
  }

  /* table */
  .cost__table02,
  .cost__note {
    width: 60%;
    margin: 0 auto;
  }

  .cost__table02 th {
    width: 48%;
  }

  .cost__table02 td {
    width: 52%;
  }

  /*   1ページ目
--------------------------------------- */
  /* news */
  .covid__text {
    font-size: 0.9rem;
    padding: 0.5em 0.5em 0.5em 1em;
    width: 40em;
    margin: 0 auto;
  }

  .covid__arrow {
    margin-left: 1em;
  }

  .event__box {
    width: 48%;
  }

  .event__box--sp {
    margin-top: 0;
  }

  .event__title01 {
    font-size: 2.589rem;
  }

  .event__title02 {
    font-size: 0.839rem;
  }

  .event__title03 {
    font-size: 3.3rem;
  }

  .event__title04 {
    font-size: 1rem;
  }

  .event__title05 {
    font-size: 1.2845rem;
  }

  .event__title06 {
    font-size: 0.862rem;
    padding: 0 0.1em 0.2em 0.1em;
  }

  .event__list li:first-child {
    padding-right: 0.5em;
  }

  .event__list__text {
    font-size: 0.8rem;
  }

  .news__img img {
    height: 10.5rem;
  }

  .news__box {
    padding: 1rem 1.5rem;
  }

  .news__title01 {
    font-size: 0.7rem;
  }

  /* features */
  .features__text01 {
    font-size: 0.95rem;
  }

  .features__list {
    width: 100%;
  }

  .features__list li {
    width: 30%;
    margin-right: 5%;
  }

  .features__list li:nth-child(3),
  .features__list li:last-child {
    margin-right: 0;
  }

  /* treatment */
  .treatment__list01 li {
    width: 19%;
  }

  .treatment__list01 li:nth-child(13),
  .treatment__list01 li:nth-child(14),
  .treatment__list01 li:nth-child(15) {
    display: list-item;
  }

  .treatment__box {
    margin: 0.6rem;
    padding: 0.8rem 0.4rem;
  }

  .treatment__title01 {
    font-size: 1.045rem;
  }

  .treatment__img {
    width: 5em;
  }

  /*   2ページ目
--------------------------------------- */
  /* guide */
  .guide__box01 div:first-child {
    width: 43%;
  }

  .guide__box01 div:last-child {
    width: 52%;
  }

  .guide__box02 {
    padding: 2.5rem 15%;
  }

  .guide__title01 {
    font-size: 1.05rem;
  }

  .guide__box03 a {
    width: 48%;
    height: 3.25rem;
  }

  .guide__box03 a:last-child {
    margin-top: 0;
  }

  .guide__tel {
    font-size: 1.4875rem;
  }

  .guide__web {
    font-size: 1rem;
  }

  .guide__treatmenttime {
    width: 72%;
  }

  /*   3ページ目
--------------------------------------- */
  /* features */
  .bg-features01 {
    width: 75%;
  }

  .bg-features02 {
    width: 75%;
  }

  .features__box {
    width: 100%;
  }

  .features__box>div:first-child {
    width: 47%;
  }

  .features__box>div:last-child {
    width: 48%;
  }

  /*   4ページ目
--------------------------------------- */
  /* deduction */
  .deduction__box01>div:first-child {
    width: 64%;
  }

  .deduction__box01>div:last-child {
    width: 30%;
  }

  .deduction__img {
    width: 100%;
    padding-top: 0;
  }

  .deduction__title {
    height: 6.3rem;
  }

  .deduction__text {
    padding: 0.1em 0.3em 0.2em 0.3em;
  }

  .deduction__title01 {
    font-size: 1.1rem;
  }

  .deduction__title02 {
    font-size: 1.5rem;
  }

  .deduction__text01 {
    font-size: 0.9rem;
  }

  .deduction__text02 {
    font-size: 0.8rem;
  }

  .deduction__text03 {
    font-size: 0.8rem;
    padding: 0 0.1em;
  }

  .deduction__text04 {
    font-size: 0.8rem;
  }

  .deduction__item01 {
    width: 21%;
  }

  .deduction__item02 {
    width: 37%;
  }

  .deduction__symbol01 {
    width: 2.2%;
  }

  .case__text01 {
    font-size: 0.9345rem;
  }

  .case__text02 {
    font-size: 1.7rem;
  }

  .case__text03 {
    font-size: 1.1rem;
  }

  .case__space01 {
    padding: 0.5em 0;
    width: 5em;
  }

  .case__space02 {
    padding: 0.3em;
  }

  .case__box>div:first-child {
    width: 28%;
    padding-right: 5%;
  }

  .tax__table,
  .tax__table tr {
    width: 100%;
  }

  .tax__table,
  .tax__table th,
  .tax__table td {
    border: 1.0448px solid #838383;
  }

  .tax__table th {
    padding: 0.8em 1.5em;
  }

  .tax__table th.tax__space01 {
    padding: 1.5em;
  }

  .tax__table td {
    padding: 0.5em 1.5em;
  }

  .tax__text01 {
    font-size: 1rem;
  }

  .tax__text02 {
    font-size: 0.8rem;
  }

  .tax__text03 {
    font-size: 1.05rem;
  }

  .tax__text04 {
    font-size: 0.9rem;
  }

  .tax__text05 {
    font-size: 1.1rem;
  }

  .tax__plus {
    width: 1em;
    margin: 0 0.3em;
  }

  .tax_space {
    padding-right: 0.5em;
  }

  .deduction__box02 {
    padding: 2.25rem 2rem 4.5rem 2rem;
  }

  .deduction__box03 {
    padding: 2.25rem 2rem 2.75rem 2rem;
  }

  .deduction__box02>div:first-child,
  .deduction__box03>div:first-child {
    width: 30%;
  }

  .deduction__box02>div:last-child,
  .deduction__box03>div:last-child {
    width: 70%;
  }

  /*   5ページ目
--------------------------------------- */
  /* facility */
  .facility__list li {
    width: 45%;
  }

  .facility__list--last {
    display: list-item;
  }

  /*   6ページ目
--------------------------------------- */
  /* doctor */
  .doctor__title01 {
    font-size: 1.7rem;
  }

  .doctor__title02 {
    font-size: 0.9rem;
  }

  .doctor__title03 {
    font-size: 1.4rem;
  }

  .doctor__title04 {
    font-size: 0.7rem;
  }

  .doctor__box01>div:first-child {
    width: 58%;
  }

  .doctor__box01>div:last-child {
    width: 35%;
  }

  .doctor__box02>div:first-child {
    width: 58%;
  }

  .doctor__box02>div:last-child {
    width: 30%;
  }

  /* greeting */
  .staff__text01 {
    font-size: 0.75rem;
  }

  .staff__text02 {
    font-size: 0.8rem;
  }

  .staff__text03 {
    font-size: 0.75rem;
  }

  .greeting__doctor {
    width: 35%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    padding-bottom: 0;
  }

  .greeting__box {
    padding: 4rem 1rem 4rem 4rem;
    margin-top: 2rem;
    width: 68%;
    margin: 0 0 0 auto;
    z-index: 99;
  }

  .greeting__career {
    width: calc(68% - 4rem);
    margin: 0 0 0 auto;
  }

  .greeting__career th {
    width: 25%;
  }

  .greeting__career td {
    width: 75%;
  }

  /* staff */
  .staff__img {
    width: 70%;
  }

  /*   7ページ目
--------------------------------------- */
  /* career */
  .career__title {
    font-size: 1.25rem;
    width: 25%;
    padding: 1em 0;
  }

  .career__title01 {
    font-size: 1.471rem;
  }

  .career__title02 {
    font-size: 1.05rem;
  }

  .career__title03 {
    font-size: 1.2rem;
  }

  .career__text01 {
    font-size: 1rem;
  }

  .career__box01 {
    padding: 2rem 1rem 3rem 1rem;
  }

  .career__box02>div {
    width: 48%;
  }

  .career__list01 li:nth-child(odd) {
    width: 53%;
  }

  .career__list01 li:nth-child(even) {
    width: 47%;
  }

  .career__box03 {
    width: 67.5%;
    padding: 1.75rem 1rem 2rem 1rem;
  }

  .career__box04::before,
  .career__box04::after {
    height: 4.25rem;
    width: 3.5px;
  }

  .career__box04::before {
    transform: rotate(-32.5deg);
  }

  .career__box04::after {
    transform: rotate(32.5deg);
  }

  /* recruit */
  .recruit__box {
    padding: 1.25rem 2.5rem;
  }

  .career__table th {
    width: 25%;
    padding: 0 5%;
  }

  .career__table td {
    width: 75%;
  }

  .recruit__title {
    font-size: 1rem;
  }

  /*   8ページ目
--------------------------------------- */
  /* prevention */
  .prevention__title01 {
    font-size: 1.2rem;
  }

  .prevention__list01 li {
    width: 47%;
  }

  /* exam */
  .exam__title01 {
    font-size: 2rem;
  }

  .exam__box {
    padding: 2rem 1rem;
    width: 95%;
    margin: 0 auto;
  }

  /*   9ページ目
--------------------------------------- */
  /* reason01 */
  .caries__box01>div:first-child {
    width: 33%;
    padding-top: 0.5rem;
    margin: 0;
  }

  .caries__box01>div:last-child {
    width: 65%;
  }

  /* periodontal */
  .periodontal__box>div:first-child {
    width: 40%;
  }

  .periodontal__box>div:last-child {
    width: 54%;
  }

  /* reason02 */
  .reason__text {
    font-size: 0.7rem;
  }

  .caries__box02>div:first-child {
    width: 26%;
    padding-right: 3%;
    margin: 0;
  }

  .caries__box02>div:last-child {
    width: 65%;
  }

  /*   10ページ目
--------------------------------------- */

  /*   11ページ目
--------------------------------------- */
  /* please */
  .please__box {
    width: 90%;
    margin: 0 auto;
  }

  .please__box dt {
    padding: 0;
    width: 10em;
  }

  .please__box dd {
    padding: 1rem 1rem;
    width: calc(100% - 10em);
  }

  /* area */
  .area__box01 {
    padding: 2rem 2.5rem;
  }

  .area__box02 div:first-child {
    width: 55%;
  }

  .area__box02 div:last-child {
    width: 40%;
  }

  .area__box03 {
    padding: 2.5rem 2rem 2rem 2rem;
  }

  .area__box03 a {
    width: 35%;
    height: 3.25rem;
  }

  .area__title {
    font-size: 1.05rem;
  }

  /*   12ページ目
--------------------------------------- */
  /* difference */
  .difference__box dt {
    padding: 0;
    width: 8em;
  }

  .difference__box dd {
    padding: 1rem 2rem;
    width: calc(100% - 8em);
  }

  /* type */
  .type__text {
    width: calc(100% - 5rem);
    padding: 0;
  }

  .type__title01 {
    padding: 0.2em 0 0.5em 0;
  }

  .whitening-type__cost {
    width: 90%;
    margin: 0 auto;
  }

  .whitening-type__cost th {
    width: 25%;
    padding: 0.8em 1em;
  }

  .whitening-type__cost th.cost__title01 {
    width: 35%;
  }

  .whitening-type__cost td {
    width: 40%;
    padding: 0.8em 1em;
  }

  .whitening-type__cost__space {
    padding-right: 1.5em;
  }

  .whitening-type__cost__text {
    width: 90%;
    margin: 0 auto;
  }

  /* whitening02 */
  .whitening-type__cost__sm {
    width: 60%;
    margin: 0 auto;
  }

  .whitening-type__cost__sm th {
    width: 48%;
  }

  .whitening-type__cost__sm td {
    width: 52%;
  }

  /*   13ページ目
--------------------------------------- */
  /* type */
  .type__list>li {
    width: 48%;
  }

  .implant-type__cost01,
  .implant-type__cost__text {
    width: 90%;
    margin: 0 auto;
  }

  .implant-type__cost01 th {
    width: 20%;
    padding: 0.8em 1em;
  }

  .implant-type__cost01 th.cost__title02 {
    width: 40%;
  }

  .implant-type__cost01 td {
    width: 40%;
    padding: 0.8em 1em;
  }

  .implant-type__cost__space {
    padding-right: 1.5em;
  }

  /* implant */
  .implant__text {
    font-size: 0.95rem;
  }

  .implant-type__cost02 {
    width: 90%;
    margin: 0 auto;
  }

  .implant-type__cost02 th,
  .implant-type__cost02 td {
    width: 50%;
    padding: 0.8em 1em;
  }

  /*   14ページ目
--------------------------------------- */
  /* recommendation */
  .recommendation__list li {
    width: 47%;
  }

  /* notes */
  .notes__box {
    width: 90%;
    margin: 0 auto;
  }

  .notes__box dt {
    padding: 0;
    width: 10em;
  }

  .notes__box dd {
    padding: 1rem 1.9rem;
    width: calc(100% - 10em);
  }

  /*   15ページ目
--------------------------------------- */
  /* therapy */
  .therapy__box {
    width: 85%;
    margin: 0 auto;
  }

  .therapy__box dt {
    padding: 0;
    width: 8em;
  }

  .therapy__box dd {
    padding: 1rem 1rem 1rem 2rem;
    width: calc(100% - 8em);
  }

  /*   動き
---------------------------------- */
  .delay01-pc {
    transition-delay: 0.3s;
  }

  .delay02-pc {
    transition-delay: 0.6s;
  }

  /* タイトル */
  .hero__title--slide01 {
    animation-name: hero-slide01;
    animation-duration: 1s;
  }

  .hero__title--slide02 {
    animation-name: hero-slide02;
    animation-duration: 1.7s;
    animation-delay: 1s;
  }

  .hero__title--slide03 {
    animation-name: hero-slide03;
    animation-duration: 1.2s;
    animation-delay: 2.7s;
  }

  @keyframes hero-slide01 {
    0% {
      width: 0%;
    }

    100% {
      width: 11em;
    }
  }

  @keyframes hero-slide02 {
    0% {
      width: 0%;
    }

    100% {
      width: 100%;
    }
  }

  @keyframes hero-slide03 {
    0% {
      width: 0%;
    }

    100% {
      width: 13.25em;
    }
  }

  /* loading */
  .loading__img {
    width: 20%;
    /* padding-top: 15vh; */
  }

  .loading__text {
    font-size: 1.25rem;
  }

  .scroll__text {
    font-size: 0.7rem;
  }

  /*   swiper
--------------------------------------- */
  .swiper-button-prev {
    background: url(../img/05-gallery-prev.png) no-repeat center center / contain;
    left: 11%;
    top: 45%;
  }

  .swiper-button-next {
    background: url(../img/05-gallery-next.png) no-repeat center center / contain;
    right: 11%;
    top: 45%;
  }

  /*   googlemap枠
---------------------------------- */
  .ggmap {
    padding-top: 100%;
  }

  /*   pagetop設定
---------------------------------- */
  .fixed--sp {
    display: none;
  }

  .fixed--pc {
    display: block;
    position: fixed;
    right: 0;
    bottom: auto;
    top: 5.5rem;
    width: auto;
    z-index: 1000;
  }

  .fixed--pc a {
    display: block;
    padding: 1rem 0.5rem;
  }

  .fixed--pc a img {
    display: block;
    width: 1.9rem;
  }

  /* .pagetop {
        display: none;
        bottom: 5px;
        right: 0;
        width: 80px;
    } */
  .googlepolicy {
    font-size: 0.9rem;

  }
}

/*  Desktop Layout: 769px to a max of 1232px.  Inherits styles from: Mobile Layout and Tablet Layout.  */

@media only screen and (min-width: 1024px) {
  html {
    font-size: 15px;
  }

  .grid-container01 {
    width: 80%;
  }

  .grid-container02 {
    width: 77%;
  }

  .grid-container03 {
    /*width: 80%;*/
    width: 90%;
  }

  .grid-container04 {
    width: 88%;
  }

  .grid-container05 {
    width: 80%;
  }

  .grid-container06 {
    width: 75%;
  }

  .grid-container99 {
    width: 80%;
  }

  /*   text
--------------------------------------- */

  /*   改行 
--------------------------------------- */
  .br-tab01::before,
  .br-sp02::before {
    content: "";
  }

  .br-pc02::before {
    content: "\A";
    white-space: pre;
  }

  .br-ip-tab::before {
    content: "";
  }

  /*   行間,文字間 
--------------------------------------- */
  .line01_6--sp02,
  .line02--sp02 {
    line-height: 1;
  }

  .text-space20 {
    letter-spacing: 0.008em;
  }

  .text-space25 {
    letter-spacing: 0.0175em;
  }

  .text-space50 {
    letter-spacing: 0.025em;
  }

  .text-space80 {
    letter-spacing: 0.04em;
  }

  .text-space100 {
    letter-spacing: 0.05em;
  }

  .text-space150 {
    letter-spacing: 0.1em;
  }

  .text-space200 {
    letter-spacing: 0.15em;
  }

  .text-space300 {
    letter-spacing: 0.25em;
  }

  /*   list
--------------------------------------- */
  .check__list {
    width: 47%;
  }

  /*   header
--------------------------------------- */
  /* header */
  .header__img {
    height: 35rem;
  }

  .header__img--pc {
    max-width: 90%;
    height: 39rem;
  }

  .header__img__under {
    padding-top: 4rem;
  }

  .header__message {
    right: 42%;
  }

  /*   footer
--------------------------------------- */
  /* footer01 */
  .footer__tel01 {
    font-size: 1.4875rem;
  }

  .footer__tel02 {
    font-size: 0.9915rem;
  }

  .footer__line__text {
    font-size: 1.3rem;
  }

  /* footer02 */
  .footer__menu {
    width: 95%;
    margin: 0 auto;
  }

  /*   1ページ目
--------------------------------------- */
  /* treatment */
  .treatment__list01 li {
    width: 18%;
  }

  .treatment__box {
    margin: 0.6rem;
    padding: 1rem 0.6rem;
  }

  /*   4ページ目
--------------------------------------- */
  /* deduction */
  .deduction__box02 {
    padding: 2.25rem 2.5rem 4.5rem 2.5rem;
  }

  .deduction__box03 {
    padding: 2.25rem 2.5rem 2.75rem 2.5rem;
  }

  .deduction__box02>div:first-child,
  .deduction__box03>div:first-child {
    width: 28%;
  }

  .deduction__box02>div:last-child,
  .deduction__box03>div:last-child {
    width: 72%;
  }

  .deduction__list__text {
    font-size: 0.9rem;
    font-feature-settings: "palt";
  }

  /*   7ページ目
--------------------------------------- */
  /* career */
  .career__box04::before,
  .career__box04::after {
    height: 4.25rem;
    width: 5px;
  }

  /*   8ページ目
--------------------------------------- */
  /* exam */
  .exam__box {
    width: 90%;
  }

  /*   11ページ目
--------------------------------------- */
  /* area */
  .area__box02 div:first-child {
    width: 45%;
  }

  .area__box02 div:last-child {
    width: 45%;
  }

  /*   14ページ目
--------------------------------------- */
  /* notes */
  .notes__box dt {
    width: 14em;
  }

  .notes__box dd {
    width: calc(100% - 14em);
  }


}

@media only screen and (min-width: 1366px) {

  /*   header
--------------------------------------- */
  .header__career {
    right: 16%;
  }
}

@media only screen and (min-width: 1440px) {
  html {
    font-size: 18px;
  }

  .grid-container01 {
    width: 75%;
  }

  .grid-container02 {
    width: 72%;
  }

  .grid-container03 {
    width: 75%;
  }

  .grid-container04 {
    width: 85%;
  }

  .grid-container05,
  .grid-container06 {
    width: 70%;
  }

  .grid-container99 {
    width: 75%;
  }

  /*   行間,文字間 
--------------------------------------- */
  .line01_6--sp03 {
    line-height: 1;
  }

  /*   改行 
--------------------------------------- */
  .br-sp03::before {
    content: "";
  }

  /*   header
--------------------------------------- */
  /* header */
  .header__img {
    height: 38rem;
  }

  .header__img--pc {
    max-width: 86.55%;
    height: 42rem;
  }

  .header__img__under {
    padding-top: 4rem;
  }

  .header__message {
    right: 48%;
  }

  .header__career {
    right: 11%;
  }

  /*   footer
--------------------------------------- */

  /*   contents
--------------------------------------- */
  /* 下層ページ */
  .medicalcontents__list01 li {
    width: 30%;
  }

  /*   1ページ目
--------------------------------------- */
  /* news */
  .event__title03 {
    font-size: 3.8345rem;
  }

  .event__title04 {
    font-size: 1.191rem;
  }

  /* treatment */
  .treatment__list01 li {
    width: 17%;
  }

  .treatment__box {
    margin: 0.6rem;
    padding: 1rem 0.6rem;
  }

  /*   3ページ目
--------------------------------------- */
  .features__title {
    font-size: 1.4rem;
  }

  /*   4ページ目
--------------------------------------- */
  /* deduction */
  .deduction__text {
    padding: 0.1em 0.5em 0.2em 0.5em;
  }

  .deduction__title01 {
    font-size: 1.203rem;
  }

  .deduction__title02 {
    font-size: 1.64rem;
  }

  .deduction__text01 {
    font-size: 0.9rem;
  }

  .deduction__text02 {
    font-size: 0.875rem;
  }

  .deduction__text03 {
    font-size: 0.875rem;
    padding: 0 0.2em;
  }

  .deduction__text04 {
    font-size: 0.875rem;
  }

  .deduction__item02 {
    width: 35.5%;
  }

  /*   8ページ目
--------------------------------------- */
  /* prevention */
  .prevention__title01 {
    font-size: 1.3rem;
  }

}

@media only screen and (min-width: 1536px) {
  html {
    font-size: 20px;
  }

  .grid-container01 {
    width: 77%;
  }

  .grid-container02 {
    width: 72%;
  }

  .grid-container03 {
    width: 75%;
  }

  .grid-container04 {
    width: 85%;
  }

  .grid-container05,
  .grid-container06 {
    width: 68.75%;
  }

  .grid-container99 {
    width: 75%;
  }

  .text-kerning-nomal {
    font-feature-settings: unset;
  }

  /*   header
--------------------------------------- */
  /* header */
  .header__img {
    height: 37.5rem;
  }

  .header__img--pc {
    height: 41rem;
  }

  .header__img__under {
    padding-top: 3.5rem;
  }

  .header__message {
    right: 47%;
  }
}

@media only screen and (min-width: 1920px) {
  html {
    font-size: 26px;
  }

  .grid-container01 {
    width: 75%;
    max-width: 1800px;
  }

  .grid-container02 {
    width: 72%;
    max-width: 1700px;
  }

  .grid-container03 {
    /*width: 75%;*/
    width: 80%;
    max-width: 1800px;
  }

  .grid-container04 {
    width: 85%;
    max-width: 1900px;
  }

  .grid-container05,
  .grid-container06 {
    width: 70%;
    max-width: 1700px;
  }

  .grid-container99 {
    width: 75%;
    max-width: 1800px;
  }

  /*   flexbox
--------------------------------------- */
  .flex-button>div {
    margin-right: 0.85rem;
  }

  /*   header
--------------------------------------- */
  .header__career {
    right: 9%;
  }

  /*   1ページ目
--------------------------------------- */
  /* news */
  .event__title03 {
    font-size: 3.5rem;
  }

  .event__title04 {
    font-size: 1.1rem;
  }
}

@media only screen and (min-width: 2560px) {
  html {
    font-size: 30px;
  }

  /*   header
--------------------------------------- */
  .header__career {
    right: 12%;
  }
}