@charset "utf-8";
/* CSS Document */
/* 103
---------------------------------------------------------- */
.html-frame span.border-br {
  display: inline-block;
  padding: 0 2px 2px 0;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-bottom: 1px solid #222;
  border-right: 1px solid #222;
  vertical-align: middle;
}
.html-frame span.border-tl {
  display: inline-block;
  padding: 2px 0 0 2px;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-top: 1px solid #222;
  border-left: 1px solid #222;
  vertical-align: middle;
}
.html-frame span.border-tr {
  display: inline-block;
  padding: 2px 2px 0 0;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-top: 1px solid #222;
  border-right: 1px solid #222;
  vertical-align: middle;
}
.html-frame span.border-bl {
  display: inline-block;
  padding: 0 0 2px 2px;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-bottom: 1px solid #222;
  border-left: 1px solid #222;
  vertical-align: middle;
}
.html-frame span.border-bc, .html-frame span.border-bc2, .html-frame span.border-bc3, .html-frame span.border-bc4, .html-frame span.border-bc5 {
  display: inline-block;
  padding: 0 0 2px 2px;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-bottom: 1px solid #222;
  vertical-align: middle;
  position: relative;
}
.html-frame span.border-bc:after {
  content: "";
  width: 1px;
  height: 100%;
  line-height: 1;
  border-left: 1px solid #222;
  position: absolute;
  left: 3px;
  right: 0;
  bottom: 0;
  margin: auto;
}
.html-frame span.border-bc2:after {
  content: "";
  width: 1px;
  height: 100%;
  line-height: 1;
  border-left: 1px solid #222;
  position: absolute;
  left: 0;
  right: 1em;
  bottom: 0;
  margin: auto;
}
.html-frame span.border-bc3:after {
  content: "";
  width: 1px;
  height: 100%;
  line-height: 1;
  border-left: 1px solid #222;
  position: absolute;
  left: 1em;
  right: 2px;
  bottom: 0;
  margin: auto;
}
.html-frame span.border-bc4:after {
  content: "";
  width: 1px;
  height: 100%;
  line-height: 1;
  border-left: 1px solid #222;
  position: absolute;
  left: 1.6em;
  right: 2px;
  bottom: 0;
  margin: auto;
}
.html-frame span.border-bc5:after {
  content: "";
  width: 1px;
  height: 100%;
  line-height: 1;
  border-left: 1px solid #222;
  position: absolute;
  left: 1.4em;
  right: 2px;
  bottom: 0;
  margin: auto;
}
.html-frame span.border-tc2 {
  position: relative;
  display: inline-block;
  padding: 2px 0 0;
  margin: 0 2px 2px 2px;
  line-height: 1;
  border-top: 1px solid #222;
  vertical-align: bottom;
}
.html-frame span.border-tc2::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 1em;
  top: 0;
  left: 60%;
  background-color: #333;
}
.html-frame span.border-cross {
  position: relative;
  display: inline-block;
  margin: 0 2px;
  overflow: hidden;
  vertical-align: top;
}
.html-frame span.border-cross::before {
  display: block;
  position: absolute;
  content: "";
  width: 1px;
  height: 2.4em;
  top: 0;
  left: 50%;
  background-color: #333;
}
.html-frame span.border-cross::after {
  display: block;
  position: absolute;
  content: "";
  width: 100px;
  height: 1px;
  top: 50%;
  left: 0;
  background-color: #333;
}
.indent01 {
  display: inline-block;
  text-indent: -1em;
  padding-left: 1em;
}
span.kenten {
  position: relative;
  padding-top: 0.2em;
}
span.kenten::before {
  position: absolute;
  content: "";
  width: 0.2em;
  height: 0.2em;
  border-radius: 50%;
  background-color: #555;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
}
.fColor--purple01 {
  color: #a3599b;
}
.fColor--red01 {
  color: #df0025;
}
.fColor--pink01 {
  color: #E4007F;
}
sub {
  vertical-align: sub;
  color: #333 !important;
}
/* 1 */
.html-frame--103-1 {}
.html-frame--103-1 h4.title01 {
  color: #a3599b;
}
.html-frame--103-1 h5.title01 {
  color: #00AEEF;
}
.html-frame--103-1 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
  margin: 40px -12px 20px;
}
.html-frame--103-1 .photolist01 ul li {
  width: 393px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: -30px 12px 20px;
  padding-top: 30px;
  line-height: 1.3;
  overflow: hidden;
}
.html-frame--103-1 .photolist01 ul li.col3 {
  width: 810px;
}
.html-frame--103-1 .photolist01 ul li img {
  margin-bottom: 8px;
}
/* 2 */
.html-frame--103-2 {}
.html-frame--103-2 h4.title01 {
  color: #bc8873;
}
.html-frame--103-2 h5.title01 {
  color: #bc8873;
}
.html-frame--103-2 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
  margin: 40px -12px 20px;
  overflow: hidden;
}
.html-frame--103-2 h5.title01 + ul {
  margin-top: 15px;
}
.html-frame--103-2 .photolist01 ul li {
  width: 254px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: -30px 12px 20px;
  padding-top: 30px;
  line-height: 1.3;
}
.html-frame--103-2 .photolist01 ul li.col2 {
  width: 532px;
}
.html-frame--103-2 .photolist01 ul li img {
  margin-bottom: 8px;
}
/* 3 */
.html-frame--103-3 {}
.html-frame--103-3 h4.title01 {
  color: #B37761;
}
.html-frame--103-3 h5.title01 {
  color: #E60012;
}
.html-frame--103-3 h5.title02 {
  color: #00A0E9;
}
.html-frame--103-3 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
  margin: 40px -12px 20px;
  overflow: hidden;
}
.html-frame--103-3 .photolist01 ul li {
  width: 393px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: -30px 12px 20px;
  padding-top: 30px;
  line-height: 1.3;
}
.html-frame--103-3 .photolist01 ul li img {
  margin-bottom: 8px;
}
/* 4 */
.html-frame--103-4 {}
.html-frame--103-4 h4.title01 {
  color: #B37761;
}
.html-frame--103-4 h4.title01 span {
  font-size: 12px;
  color: #00AEEF;
  display: inline-block;
  width: 12em;
  text-align: center;
  padding: 3px 0;
  border-top: 2px solid #00AEEF;
  border-bottom: 2px solid #00AEEF;
}
.html-frame--103-4 h5.title01 {
  color: #00AEEF;
}
.html-frame--103-4 h6.title01 {
  color: #00AEEF;
}
.html-frame--103-4 h6.title01 span {
  color: #333;
}
.html-frame--103-4 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
  margin: 40px -12px 20px;
  overflow: hidden;
}
.html-frame--103-4 .photolist01 ul li {
  width: 254px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: -30px 12px 20px;
  padding-top: 30px;
  line-height: 1.3;
}
.html-frame--103-4 .photolist01 ul li.col2 {
  width: 532px;
}
.html-frame--103-4 .photolist01 ul li.clear {
  clear: both;
}
.html-frame--103-4 .photolist01 ul li img {
  margin-bottom: 8px;
}
.html-frame--103-4 .sup01 {
  display: inline-block;
  border: 1px solid #333;
  padding: 3px 5px;
}
/* 5 */
.html-frame--103-5 {}
.html-frame--103-5 h4.title01 {
  color: #6390AA;
}
.html-frame--103-5 h5.title01 {
  color: #00AEEF;
}
.html-frame--103-5 h5.title02 {
  border-top: 2px solid #00AEEF;
  border-bottom: 2px solid #00AEEF;
  color: #00AEEF;
  padding: 3px 1em;
}
.html-frame--103-5 h6.title01 {
  color: #00AEEF;
}
.html-frame--103-5 h6.title01 span {
  color: #333333;
}
.html-frame--103-5 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
  margin: 40px -12px 20px;
  overflow: hidden;
}
.html-frame--103-5 .photolist01 ul li {
  width: 254px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: -30px 12px 20px;
  padding-top: 30px;
  line-height: 1.3;
}
.html-frame--103-5 .photolist01 ul li.col1-5 {
  width: 393px;
}
.html-frame--103-5 .photolist01 ul li.col3 {
  width: 810px;
}
.html-frame--103-5 .photolist01 ul li.end {
  margin-right: 254px;
}
.html-frame--103-5 .photolist01 ul li.icon {
  position: relative;
}
.html-frame--103-5 .photolist01 ul li.icon::after {
  position: absolute;
  display: block;
  content: "";
  background: url("/dentalmagazine/wp-content/uploads/sites/2/2001/10/103-5_icon_arrow01.jpg") 0 0 no-repeat;
  background-size: 24px auto;
  width: 24px;
  height: 10px;
  top: 50%;
  right: -24px;
  transform: translate(0, 50%);
}
.html-frame--103-5 .photolist01 ul li.supText {
  position: relative;
  height: calc(174px + 1.3em);
}
.html-frame--103-5 .photolist01 ul li.supText span {
  position: absolute;
  bottom: 0;
}
.html-frame--103-5 .photolist01 ul li img {
  margin-bottom: 8px;
}
/* 6 */
.html-frame--103-6 h4.title01 {
  margin-bottom: 15px !important;
}
.html-frame--103-6 h4.title01_mb3 {
  margin-bottom: 3px !important;
}
.html-frame--103-6 {
  padding-bottom: 150px !important;
  background-image: url("/dentalmagazine/wp-content/uploads/sites/2/2001/10/103-6_bg01.jpg"), url("/dentalmagazine/wp-content/uploads/sites/2/2001/10/103-6_bg02.jpg");
  background-size: contain, contain;
  background-position: center top, center bottom;
  background-repeat: no-repeat, no-repeat;
}
.html-frame--103-6 .text-section.overflow {
  padding: 15px 15px 0 0;
  background: rgba(255, 255, 255, 0.75);
  overflow: hidden;
}
.html-frame--103-6 .photolist01 ul {
  font-size: 0;
  letter-spacing: 0;
}
.html-frame--103-6 .photolist01 ul li {
  width: 200px;
  display: inline-block;
  vertical-align: top;
  font-size: 11px;
  letter-spacing: 0.01em;
  margin: 0 24px 0 0;
  line-height: 1.3;
}
.html-frame--103-6 .photolist01 ul li.col3 {
  width: 254px;
}
.html-frame--103-6 .photolist01 ul li img {
  margin-bottom: 8px;
}
.html-frame--103-6 .title_story01 {
  color: #008865 !important;
  font-size: 20px !important;
  font-weight: bold !important;
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
  text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.6);
  margin: -6px 0 50px;
}
.html-frame--103-6 .title_story01 img {
  margin: 20px 0 50px -15px;
  display: block;
}
.html-frame--103-6 .text-literature {
  margin-bottom: 15px !important;
  font-feature-settings: "palt";
  overflow: hidden;
}
.html-frame--103-6 span.float-image01--r {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.5;
  width: 254px;
  float: right;
  margin: 5px 0 15px 20px;
  display: block;
}
.html-frame--103-6 span.float-image02--r {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.3;
  width: 300px;
  float: right;
  margin: 5px 0 15px 20px;
  display: block;
}
.html-frame--103-6 span.float-image03--r {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.3;
  width: 380px;
  float: right;
  margin: 5px 0 15px 20px;
  display: block;
}
.html-frame--103-6 span.float-image01--l {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.5;
  width: 180px;
  float: left;
  margin: 5px 20px 15px 0;
  display: block;
}
.html-frame--103-6 span.float-image01--l span.name {
  font-size: 20px;
  font-weight: 700 !important;
}
.html-frame--103-6 span.float-image02--l {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.5;
  width: 300px;
  float: left;
  margin: 5px 20px 15px 0;
  display: block;
}
.html-frame--103-6 span.float-image03--l {
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.5;
  width: 393px;
  float: left;
  margin: 5px 20px 15px 0;
  display: block;
}
.html-frame--103-6 span.float-image01--r span.name {
  font-size: 16px;
  font-weight: 700 !important;
}
.html-frame--103-6 span.float-image01--r img, .html-frame--103-6 span.float-image02--r img, .html-frame--103-6 span.float-image03--r img, .html-frame--103-6 span.float-image01--l img, .html-frame--103-6 span.float-image02--l img, .html-frame--103-6 span.float-image03--l img {
  width: 100%;
  height: auto;
  margin: 0 0 8px;
}
.html-frame--103-6 .photoshot {
  font-size: 11px !important;
}