@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap");
/*基本設定
----------------------------------------------------*/
body {
  margin: 0;
  padding: 0;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", sans-serif;
  color: #1e1e1e;
  line-height: 2;
  font-size: 15px;
  -webkit-text-size-adjust: 100%;
  position: relative;
}

html {
  overflow-y: scroll;
}

a {
  color: #dc5f5f;
  text-decoration: underline;
}

a:hover {
  color: #dc5f5f;
  text-decoration: none;
  opacity: 0.8;
}

img {
  border: 0;
}

h1, h2, h3, h4, h5, p {
  margin: 0;
  padding: 0;
  font-weight: normal;
}

ul, li, dl, dt, dd {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

table {
  width: 100%;
  border: 0;
}

figure {
  margin: 0;
  padding: 0;
  line-height: 0;
}

.clear {
  clear: both;
}

.fix {
  min-height: 1px;
}

.fix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

* html .fix {
  height: 1px;
  /*\*/
  /*/
height: auto;
overflow: hidden;
/**/
}

.red {
  color: #f73609;
}

/*section p
----------------------------------------------------*/
.section {
  margin: 0 0 30px 0;
  width: 100%;
}

.inner {
  width: 100%;
}

.ml30 {
  margin-left: 30px;
}

.mr30 {
  margin-right: 30px;
}

.btm0 {
  margin-bottom: 0 !important;
}

.btm5 {
  margin-bottom: 5px;
}

.btm10 {
  margin-bottom: 10px;
}

.btm15 {
  margin-bottom: 15px;
}

.btm20 {
  margin-bottom: 20px;
}

.btm25 {
  margin-bottom: 25px;
}

.btm30 {
  margin-bottom: 30px !important;
}

.btm40 {
  margin-bottom: 40px;
}

.top5 {
  margin-top: 5px;
}

.top10 {
  margin-top: 10px;
}

.top20 {
  margin-top: 20px;
}

.top30 {
  margin-top: 30px;
}

.f10 {
  font-size: 10px;
}

.f12 {
  font-size: 12px !important;
}

.f13 {
  font-size: 13px !important;
}

.f14 {
  font-size: 14px;
}

.f18 {
  font-size: 18px !important;
}

p.l11 {
  line-height: 1.1;
}

p.l13 {
  line-height: 1.3;
}

.m0 {
  margin: 0 !important;
}

.tar {
  text-align: right;
}

.tac {
  text-align: center;
}

.f-l {
  float: left;
}

.f-r {
  float: right;
}

.lh15 {
  line-height: 1.5;
}

.hover a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
}

.list_disc {
  margin-left: 20px;
}

.list_disc li {
  list-style: disc;
}

.list_num {
  margin-left: 20px;
  margin-bottom: 20px;
}

.list_num li {
  list-style-type: decimal;
}

.text_ul01 {
  font-weight: bold;
  color: #dc5f5f;
  text-decoration: underline;
}

.marker {
  font-size: 1.5em;
  background: #f8e859;
  display: inline;
  font-weight: bold;
}

.flex, .flex_sp_rev {
  -js-display: flex;
  display: flex;
  justify-content: space-between;
  align-content: space-between;
  flex-wrap: wrap;
}

.bold {
  font-weight: bold;
}

.strong01 {
  color: #dc5f5e;
}

.strong02 {
  font-size: 24px;
  font-weight: bold;
  color: #dc5f5e;
  background: linear-gradient(transparent 80%, #c3a17c 80%);
}

.strong03 {
  font-weight: bold;
  color: #dc5f5e;
}

.strong04{
  font-weight: bold;
  text-decoration: underline;
}

/*ヘッダー
----------------------------------------------------*/
.h_wrap {
  width: 95%;
  max-width: 1050px;
  margin: 0 auto;
  padding: 0 2.5%;
}

.h_copy {
  margin-top: 8px;
  display: block;
}

.h_copy h1 {
  font-size: 12px;
  line-height: 1.5;
  color: #222;
}

.h_conts {
  margin: 16px auto 24px;
  display: flex;
  justify-content: space-between;
}

.h_logo {
  margin-top: 40px;
}

.h_logo img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.h_tel_contact {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  margin-left: 15px;
}

.h_tel {
  margin-top: 3px;
}

.h_tel_num {
  line-height: 0;
  margin-bottom: 12px;
}

.h_tel_num img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.h_tel_text dl {
  display: flex;
  font-size: 12px;
  color: #414141;
}

.h_tel_text dl dt {
  width: 6em;
}

.h_tel_text dl dd {
  width: calc(100% - 4em);
}

.h_tel_text p {
  font-size: 12px;
  color: #6f6f6f;
  line-height: 18px;
  margin-top: 5px;
}

.h_tel_text p:first-of-type {
  margin-top: 0;
}

.h_contact {
  margin-left: 25px;
}

.h_contact_btn {
  display: block;
  margin-bottom: 12px;
}

.h_contact_btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#d6c498+0,96642d+100 */
  background: #d6c498;
  /* Old browsers */
  background: -moz-linear-gradient(top, #d6c498 0%, #96642d 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #d6c498 0%, #96642d 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #d6c498 0%, #96642d 100%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  color: #fff;
  padding: 20px 25px;
  text-align: center;
  line-height: 0;
  font-size: 15px;
  font-weight: bold;
  text-decoration: none;
  font-family: "Noto Serif JP", serif;
}

.h_contact_btn a img {
  margin-right: 8px;
  vertical-align: sub;
}

.h_map {
  background: url("../images/common/h_map.png") no-repeat 2px 0px;
  padding: 0 0 6px 30px;
  font-size: 12px;
  line-height: 18px;
}

.h_access {
  background: url("../images/common/h_access.png") no-repeat 2px 4px;
  padding: 0 0 6px 30px;
  margin-top: 0px;
  font-size: 12px;
  line-height: 18px;
}

#sp_head, #sp_top {
  display: none;
}

/*ナビ
----------------------------------------------------*/
.h_nav {
  margin-top: 32px;
}

.h_nav ul {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.h_nav ul li {
  width: calc(100% / 7 - 1px);
  border-left: 1px dotted #50361a;
  text-align: center;
  padding: 12px 0;
}

.h_nav ul li:last-child {
  width: calc(100% / 7 - 2px);
  border-right: 1px dotted #50361a;
}

.h_nav ul li a {
  color: #1e1e1e;
  text-decoration: none;
}

/*ナビ
----------------------------------------------------*/
#scroll_menu {
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #f2aeae;
  padding: 15px 0;
  position: fixed;
  top: -86px;
  z-index: 99999;
  opacity: 0;
  transition: top 0.15s linear 0s, opacity 0.15s linear 0s;
}

.scroll_menu_wrap {
  width: 95%;
  max-width: 1050px;
  margin: 0 auto;
  padding: 0 2.5%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
}

.scroll_logo p {
  line-height: 0;
}

.scroll_logo img {
  width: 100%;
  max-width: 240px;
  height: 100%;
}

.scroll_menu ul {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.scroll_menu ul li {
  margin-left: 20px;
  line-height: 1.2;
}

.scroll_menu ul li a {
  font-size: 14px;
  color: #212121;
  text-decoration: none;
}

/*main-image
----------------------------------------------------*/
#mainimage {
  width: 100%;
  max-height: 100%;
  max-height: 573px;
  background: url("../images/top/bg_mainimage.png") no-repeat center center/cover;
}

#mainimage p {
  text-align: center;
  line-height: 0;
}

#mainimage p img {
  width: 100%;
  max-width: 1229px;
}

.mainimage_sp {
  display: none;
}

.mainimage_selectconts {
  background: url(../images/top/bg01.png) repeat center center;
  padding: 30px 0 !important;
}

.mainimage_select {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.mainimage_select li {
  width: 100%;
}

.mainimage_select li img {
  width: auto;
  max-width: 100%;
  vertical-align: bottom;
}

/*common
----------------------------------------------------*/
#main {
  position: relative;
}

.bg_masu01 {
  background: url("../images/common/bg_masu.png") repeat left top;
}

.bg_pink01 {
  background: #f2eded;
}

.bg_pink02 {
  background: #f2aeae;
}

.bg_pink03 {
  background: #fff8f5;
}

.mainconts {
  padding: 64px 0 72px;
}

.main_conts_wrap {
  width: 95%;
  max-width: 1050px;
  padding: 0 2.5%;
  margin: 0 auto;
}

.main_conts_wrap p {
  margin-bottom: 1em;
}

.main_conts_wrap p:last-of-type {
  margin-bottom: 0;
}

.ttl01 {
  font-size: 36px;
  font-weight: 700;
  color: #402a1a;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  position: relative;
  padding-bottom: 8px;
  margin-bottom: 48px;
}

.ttl01:after {
  content: "";
  display: block;
  width: 30px;
  height: 2px;
  background: #db5f5e;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 0;
}

.ttl02 {
  font-size: 28px;
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
  text-shadow: 1px  1px 0px #ffffff,
 -1px  1px 0px #ffffff,
 1px -1px 0px #ffffff,
 -1px -1px 0px #ffffff,
 1px  0px 0px #ffffff,
 0px  1px 0px #ffffff,
 -1px  0px 0px #ffffff,
 0px -1px 0px #ffffff;
  margin-bottom: 16px;
}

.ttl02 span {
  background: linear-gradient(transparent 70%, #c3a17c 70%);
  padding: 0 8px;
}

.ttl03 {
  font-size: 36px;
  font-weight: 700;
  color: #402a1a;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  position: relative;
  padding-bottom: 8px;
  margin-bottom: 16px;
}

.ttl03:after {
  content: "";
  display: block;
  width: 30px;
  height: 2px;
  background: #db5f5e;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 0;
}

.ttl03sub {
  font-size: 19px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #402a1a;
  text-align: center;
  margin-bottom: 40px;
}

.ttl04 {
  border-left: 5px solid #4b577d;
  box-sizing: border-box;
  background: #fafafa;
  padding: 12px 16px;
  font-size: 24px;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  margin-bottom: 32px;
}

.ttl05 {
  font-size: 40px;
  font-weight: 600;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 32px;
}

.ttl05 span {
  display: block;
}

.ttl06 {
  font-size: 26px;
  font-weight: 700;
  color: #402a1a;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  position: relative;
  padding-bottom: 8px;
  margin-bottom: 32px;
}

.ttl06:after {
  content: "";
  display: block;
  width: 30px;
  height: 2px;
  background: #db5f5e;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 0;
}

.ttl07 {
  font-size: 24px;
  font-weight: 700;
  color: #402a1a;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  margin-bottom: 12px;
}

.tbl01 {
  display: block;
}

.tbl01 tbody {
  display: block;
}

.tbl01 tbody tr {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  border-top: 1px solid #e7e7e7;
}

.tbl01 tbody tr:last-of-type {
  border-bottom: 1px solid #e7e7e7;
}

.tbl01 tbody tr th, .tbl01 tbody tr td {
  padding: 20px;
  font-size: 18px;
}

.tbl01 tbody tr th {
  width: 10em;
  background: #ff9500;
  color: #fff;
}

.tbl01 tbody tr td {
  background: #fff;
  width: calc(100% - 10em);
}

.pink01 {
  color: #fb6a00;
}

.br {
  display: block;
}

.list01 {
  border: 1px solid #402a1a;
  background: #fff;
  padding: 40px;
  box-sizing: border-box;
}

.list01 ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.list01 ul li {
  font-size: 20px;
  color: #402a1a;
  margin-right: 0px;
  position: relative;
	width: 320px;!important;
}

.list01 ul li a {
  color: #402a1a;
	
}

.list01 ul li:before {
  content: "◆";
}

.list02{
  margin-bottom: 1em;
}

.list02 li{
  position: relative;
  padding-left: 16px;
  text-decoration: underline;
}

.list02 li:before{
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  background: #402a1a;
  position: absolute;
  left: 0;
  top: 10px;
  border-radius: 100px;

}

.img01 img{
  width: auto;
  max-width: 100%;
  height: auto;
}

/*トップページ
----------------------------------------------------*/
/* こんな症状ありませんか？ */
.syoujou_wrap{
  display: flex;
  justify-content: space-between;
}

.syoujou_conts{
  width: calc(100% / 3 - 12px);
  margin-left: 25px;
  box-sizing: border-box;
  border: 1px solid #c9c2b5;
  padding: 16px;
  background: #fff;
}

.syoujou_conts:first-of-type{
  margin-left: 0;
}

.syoujou_ttl{
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  color: #402a1a;
  font-family: "Noto Serif JP", serif;
}

.syoujou_img{
  margin: 12px auto 16px;
  text-align: center;
}

.syoujou_img img{
  width: auto;
  max-width: 100%;
  height: auto;
}

/* 他院と当院の違い */
.comparison_list table{
  border: 1px solid #c9c2b5;
  border-collapse: collapse;
}

.comparison_list table thead,
.comparison_list table thead tr,
.comparison_list table thead tr th,
.comparison_list table thead tr td,
.comparison_list table tbody,
.comparison_list table tbody tr,
.comparison_list table tbody tr th,
.comparison_list table tbody tr td{
  border: 1px solid #c9c2b5;
}

.comparison_list table thead tr th,
.comparison_list table thead tr td,
.comparison_list table tbody tr th,
.comparison_list table tbody tr td{
  box-sizing: border-box;
  padding: 16px;
  background: #fff;
}

.comparison_list table thead tr th,
.comparison_list table thead tr td{
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}

.comparison_list table thead tr td:last-of-type,
.comparison_list table tbody tr td:last-of-type{
  background: #fffcfc;
}

.comparison_list table thead tr td:last-of-type{
  color: #f2aeae;
}

.comparison_list table tbody tr th{
  width: 20%;
}

.comparison_list table tbody tr th,
.comparison_list table tbody tr td{
  line-height: 1.5;
}

.comparison_list table tbody tr td:first-of-type p span{
  font-weight: bold;
}

.comparison_list table tbody tr td:last-of-type p span {
  font-weight: bold;
  color: #f2aeae;
  text-decoration: underline;
}

.comparison_list-memo{
  display: none;
}

/* 当院の強み */
.strongpoint_wrap {
  display: flex;
}

.strongpoint_conts {
  display: flex;
  flex-direction: column;
  width: calc(100% / 3 - 12px);
  margin-right: 25px;
  box-shadow: 0 0 20px rgba(130, 93, 92, 0.2);
  background: #fff;
  border-radius: 6px 6px 0 0;
}

.strongpoint_conts:last-of-type {
  margin-right: 0;
}

.strongpoint_ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 600;
  box-sizing: border-box;
  padding: 24px 12px;
  color: #fff;
  border-radius: 6px 6px 0 0;
}

.strongpoint_ttl span {
  font-size: 64px;
  margin-left: 10px;
  line-height: 1;
}

.strongpoint_ttl01 {
  background: #f2aeae;
}

.strongpoint_ttl02 {
  background: #c3a17c;
}

.strongpoint_ttl03 {
  background: #4b577d;
}

.strongpoint_textarea {
  background: #fff;
  flex-direction: column;
  box-sizing: border-box;
  padding: 32px;
}

.strongpoint_img {
  text-align: center;
  margin-bottom: 12px;
}

.strongpoint_text {
  font-size: 25px;
  font-weight: bold;
  font-family: "Noto Serif JP", serif;
  text-align: center;
}

.strongpoint_text p {
  line-height: 1.6;
  font-weight: 700;
}

/* 患者さんとの２ショット */
.strongreview{
  margin-top: 40px;
}

.strongreview_wrap{
  box-sizing: border-box;
  padding: 40px;
  background: #fff;
  box-shadow: 0 0 20px rgb(130 93 92 / 20%);
}

.strongreview_ttl01conts{
  display: flex;
  justify-content: center;
  flex-direction: column-reverse;
}

.strongreview_ttl01{
  display: block;
  font-size: 32px;
  font-weight: bold;
  font-family: "Noto Serif JP", serif;
  color: #402a1a;
  line-height: 1.5;
  text-align: center;
  margin-top: 8px;
}

.strongreview_ttl01sub{
  display: flex;
  justify-content: center;
  width: 100%;
  max-width: 240px;
  margin: 0 auto;
  background: #402a1a;
  color: #fff;
  font-size: 18px;
  box-sizing: border-box;
  padding: 4px;
  margin-bottom: 24px;
}

.strongreview_textarea{
  margin-top: 32px;
}

/* covd-19 */
.covd-19 {
  box-sizing: border-box;
  border: 4px solid #dc5f5e;
  padding: 32px;
}

.covd-19_list ul {
  display: flex;
  flex-wrap: wrap;
}

.covd-19_list ul li {
  background: url(../images/top/icon_nayami.png) no-repeat left top;
  padding-left: 36px;
  margin-bottom: 16px;
  margin-right: 24px;
}

.covd-19_text01 {
  font-size: 18px;
  text-align: center;
  margin-top: 12px;
}

/* メディア掲載 */
.media_conts{
    box-sizing: border-box;
    border: 4px solid #dc5f5e;
    padding: 32px;
    background: #fff;
}

.media_conts .ttl02{
  line-height: 1.7;
}

.media_conts02{
    box-sizing: border-box;
}

.media_img{
  text-align: center;
}

.media_img img{
  width: auto;
  max-width: 100%;
  height: auto;
}

.media_memo{
  margin-top: 16px;
  font-size: 14px;
  text-align: center;
}

.media_detailbtn{
  margin-top: 16px;
  text-align: center;
}

.media_detailbtn a{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 400px;
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  background: #f2aeae;
  padding: 8px 24px;
  border-radius: 4px;
  text-decoration: none;
  margin: 0 auto;
  box-sizing: border-box;
}

.media_detailbtn a img{
  width: auto;
  max-width: 24px;
  height: 100%;
  margin-right: 12px;
}

/* ごあいさつ */
.first_aisatsuconts {
  display: flex;
}

.first_img {
  width: 250px;
}

.first_img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.first_movie{
  margin-top: 40px;
}

.first_movie iframe{
  width: 100%;
  min-height: 480px;
}

.first_mystory {
  margin-top: 40px;
  border-top: 1px solid #d9d4d4;
  padding-top: 40px;
}

.first_text {
  width: calc(100% - 290px);
  margin-left: 40px;
}

.first_mystoryconts {
  display: flex;
  flex-direction: row-reverse;
  margin-top: 64px;
}

.first_mystoryconts:first-of-type {
  margin-top: 0;
}

.first_mystory-img {
  width: 314px;
}

.first_mystory-img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.first_mystory-img p {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.5;
}

.first_mystory-text {
  width: calc(100% - 354px);
  margin-right: 40px;
}

.first_list {
  margin-top: 80px;
}

.first_lasttext {
  margin-top: 40px;
}

.first_lasttext p {
  font-size: 28px;
  font-weight: bold;
  color: #4b577d;
  text-align: center;
  line-height: 1.5;
}

/* あなたは、こんな悩みはありませんか？ */
.nayami_wrap {
  padding-bottom: 0 !important;
}

.nayami_conts {
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-top: 35px;
}

.nayami_img {
  width: 100%;
  max-width: 250px;
  margin-left: 30px;
  display: flex;
}

.nayami_img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.nayami_list {
  margin-bottom: 50px;
}

.nayami_list ul li {
  background: url("../images/top/icon_nayami.png") no-repeat left top;
  padding-left: 40px;
  margin-bottom: 20px;
}

/* 当院の特徴 */
.feature_textarea {
  display: flex;
  flex-direction: row-reverse;
}

.feature_textarea-img {
  width: 314px;
}

.feature_textarea-img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.feature_textarea-img p {
  font-size: 13px;
  line-height: 1.5;
  margin-top: 8px;
}

.feature_textarea-text {
  width: calc(100% - 354px);
  margin-right: 40px;
}

.feature_conts01 {
  margin-top: 64px;
  background: #fff;
  box-sizing: border-box;
  box-shadow: 0 0 12px rgba(110, 79, 45, 0.12);
}

.feature_conts01-ttl {
  background: #4b577d;
  box-sizing: border-box;
  padding: 12px;
  font-size: 29px;
  font-weight: bold;
  color: #fff;
  text-align: center;
}

.feature_conts01-ttl span {
  font-size: 23px;
  font-weight: bold;
  text-decoration: underline;
  margin-left: 24px;
}

.feature_conts-textarea {
  padding: 24px 40px;
  box-sizing: border-box;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

.feature_conts-textarea dl {
  display: flex;
  align-items: center;
  margin-bottom: 16px;
}

.feature_conts-textarea dl:last-of-type {
  margin-bottom: 0;
}

.feature_conts-textarea dl dt {
  display: flex;
  align-items: center;
  min-height: 58px;
  background: url("../images/top/icon_feature01.png") no-repeat center center;
  font-size: 14px;
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
  color: #402a1a;
}

.feature_conts-textarea dl dt span {
  font-size: 24px;
  color: #f2a0a0;
  margin-left: 4px;
}

.feature_conts-textarea dl dd {
  font-size: 20px;
  margin-left: 32px;
}

.feature_conts02 {
  margin-top: 56px;
  border: 1px solid #4b577d;
  box-sizing: border-box;
  color: #4b577d;
  background: #fff;
  padding: 32px;
}

.feature_conts02 p {
  font-size: 17px;
  font-weight: bold;
  text-align: center;
}

/* M式テクニックとは */
.mtech_conts01 p {
  margin-bottom: 1em;
}

.mtech_conts01 p:last-of-type {
  margin-bottom: 0;
}

.mtech_ttl01 {
  font-size: 30px;
  font-weight: bold;
  color: #4b577d;
  text-decoration: underline;
  text-align: center;
  margin-bottom: 24px;
}

.mtech_list01 {
  margin-top: 40px;
}

/* このようなお悩みの方が来られます */
.cometo_list {
  margin-top: 0;
  box-sizing: border-box;
  border: 5px solid #f2eded;
  border-radius: 10px;
  background: #fff;
  padding: 32px 32px 20px;
}

.cometo_list ul {
  display: flex;
  flex-wrap: wrap;
}

.cometo_list ul li {
  background: url("../images/top/icon_nayami.png") no-repeat left 3px;
  padding-left: 36px;
  font-size: 17px;
  font-weight: bold;
  color: #402410;
  margin-right: 0px;
  margin-bottom: 12px;
	width: 280px;!important;
}

.cometo_list ul li a {
  color: #402410;
}

/* 院長プロフィール */
.profile_conts {
  display: flex;
}

.profile_img {
  width: 250px;
}

.profile_img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.profile_img .profile_name {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 12px;
}

.profile_img .profile_name span {
  font-size: 20px;
}

.profile_text {
  width: calc(100% - 290px);
  margin-left: 40px;
}

.profile_text-ttl01 {
  font-size: 20px;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  margin-bottom: 16px;
}

.profile_text-ttl01 span {
  border-bottom: 1px solid;
}

.profile_list dl {
  display: flex;
}

/* 推薦者の声 */
.recoomend_conts{
  box-sizing: border-box;
  border: 5px solid #4b577d;
  border-radius: 10px;
  padding: 24px;
  background: #fff;
}

.recoomend_conts{
  margin-top: 40px;
}

.recoomend_conts:first-of-type{
  margin-top: 0;
}

.recommend_conts-ttl{
  background: url("../images/top/icon_recommend.png") no-repeat left top;
  padding-left: 112px;
  font-size: 20px;
  min-height: 120px;

  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border-bottom: 1px dashed #999;
  padding-bottom: 4px;
  margin-bottom: 24px;
}

.recommend_conts-mainttl{
  width: 100%;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.5;
}

.recommend_conts-subttl{
  width: 100%;
  font-size: 19px;
  font-weight: bold;
  line-height: 1.8;
}

.recommend_contswrap{
  display: flex;
}

.recommend_conts-img{
  width: 240px;
}

.recommend_conts-text{
  width: calc(100% - 280px);
  margin-left: 40px;
}

.recommend_conts-text p{
  font-size: 16px;
}


/* 患者様の声 */
.voice_list {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.voice_conts {
  background: #fff;
  width: calc(50% - 20px);
  max-width: 495px;
  box-shadow: 0 1px 5px #ddd;
  margin-left: 0;
  margin-right: 20px;
  margin-top: 40px;
}

.voice_conts .disease {
  background: #fff;
  color: #f9a109;
  padding: 0px 15px;
  font-size: 93%;
  display: inline-block;
}

.voice_conts:nth-child(1), .voice_conts:nth-child(2) {
  margin-top: 0;
}

.voice_conts:nth-child(2n) {
  margin-right: 0;
  margin-left: auto;
}

.voice_ttl {
  background: #f2aeae;
  padding: 15px;
  border-radius: 5px 5px 0 0;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
  line-height: 1.7;
}

.voice_subttl {
  border-top: 2px solid #fff;
  padding-top: 5px;
  margin-top: 5px;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.7;
  color: #fff;
}

.voice_img img {
  width: 100%;
}

.voice_img iframe {
  width: 100%;
  height: 27vw;
  max-height: 293px;
}

.voice_imglist{
  margin: 16px 16px 8px;
}

.voice_imglist-btn01{
  margin-bottom: 12px;
}

.voice_imglist-btn01:last-of-type{
  margin-bottom: 0;
}

.voice_imglist-btn01 a{
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 8px 8px 6px;
  color: #fff;
  background: #f2aeae;
  font-size: 18px;
  font-weight: bold;
  border-radius: 4px;
  text-decoration: none;
}

.voice_imglist-btn01 a img{
  width: auto;
  max-width: 24px;
  height: auto;
  margin-right: 8px;
  position: relative;
  top: -2px;
}

.voice_imglist li.none{
  display: none;
}

.voice_text_conts {
  background: #fff;
  padding: 8px 16px 16px;
}

.voice_text_conts dl {
  padding-top: 16px;
}

.voice_text_conts dl:first-of-type {
  padding-top: 0;
}

.voice_text {
  padding: 0 10px 10px;
}

.voice_q {
  font-size: 16px;
  background: #f2eded;
  padding: 10px 15px 10px 40px;
  border-radius: 5px;
  margin-bottom: 10px;
  line-height: 1.8;
  color: #1e1e1e;
}

.voice_q:before {
  content: "Q.";
  font-size: 1.2em;
  color: #1e1e1e;
  font-weight: bold;
  line-height: 1;
  margin-right: 5px;
  margin-left: -27px;
}

.voice_q2 {
  font-size: 16px;
  background: #f2eded;
  padding: 10px 15px 10px 15px;
  border-radius: 5px;
  margin-bottom: 10px;
  line-height: 1.8;
  color: #1e1e1e;
}


.voice_text p {
  padding: 0 15px 15px;
}

.voice_text-memo {
  border-top: 1px dashed #d8d8d8;
  padding-top: 8px;
  margin-top: 8px;
  font-size: 12px;
}

.voice_recommend_conts {
  border: 2px solid #ff9500;
  padding: 30px;
  border-radius: 10px;
  margin-top: 30px;
}

.voice_recommend_conts:first-of-type {
  margin-top: 0;
}

.voice_recommend_img {
  float: left;
  margin: 0 30px 30px 0;
}

.voice_btn{
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 8px;
  color: #fff;
  background: #999;
  border-radius: 4px;
  text-decoration: none;
  font-size: 16px;
  font-weight: bold;
  position: relative;
}

.voice_btn:after{
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 8px solid transparent;
  border-top: 10px solid #fff;
  position: absolute;
  right: 12px;
  top: calc(50% - 6px);
}

.voice_btn-conts{
  margin-top: 12px;
}

/* 選ばれる理由 */
.select_mainttl span{
  font-size: 1.4em;
  color: #f2aeae;
  font-weight: bold;
}

.select_conts{
  margin-bottom: 64px;
}

.select_conts:last-of-type{
  margin-bottom: 0;
}

.select_contsarea-lr{
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

.select_contsarea-rl{
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.select_conts-img{
  width: 314px;
}

.select_conts-text{
  width: calc(100% - 346px);
}

.select_contsarea-rl .select_conts-text{
  margin-left: 32px;
}

.select_contsarea-lr .select_conts-text{
  margin-right: 32px;
}



/* 施術の流れ */
.flow_conts01 {
  display: flex;
  flex-direction: row-reverse;
}

.flow_conts-img {
  width: 250px;
}

.flow_conts-img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.flow_conts-text {
  width: calc(100% - 290px);
  margin-right: 40px;
}

.flow_item,
.flow_caution {
  padding: 32px 40px;
  box-sizing: border-box;
  box-shadow: 0 0 12px rgba(110, 79, 45, 0.12);
  margin-top: 64px;
}

.flow_item-ttl {
  font-size: 29px;
  font-weight: bold;
  text-align: center;
  border-bottom: 1px dashed #402a1a;
  margin-bottom: 24px;
}

.flow_item-list {
  counter-reset: num;
}

.flow_item-list li {
  position: relative;
  padding-left: 44px;
  font-size: 18px;
  margin-bottom: 16px;
}

.flow_item-list li:before {
  content: counter(num);
  counter-increment: num;
  width: 35px;
  height: 35px;
  background: #4b577d;
  border-radius: 100px;
  color: #fff;
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  font-weight: bold;
}

.flow_caution-ttl {
  font-size: 29px;
  font-weight: bold;
  text-align: center;
  border-bottom: 1px dashed #402a1a;
  margin-bottom: 24px;
  color: #dc5f5e;
}

.flow_caution {
  padding: 40px;
  counter-reset: num;
}

.flow_caution dl {
  margin-top: 24px;
}

.flow_caution dl dt {
  position: relative;
  padding-left: 44px;
  font-size: 18px;
  margin-bottom: 16px;
  font-weight: bold;
  color: #dc5f5e;
  text-decoration: underline;
  line-height: 1.5;
  padding-top: 5px;
}

.flow_caution dl dt:before {
  content: counter(num);
  counter-increment: num;
  width: 35px;
  height: 35px;
  background: #dc5f5e;
  border-radius: 100px;
  color: #fff;
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  font-weight: bold;
}

.flow_caution dl dd {
  padding-left: 44px;
}

.flow_message {
  margin: 40px auto 0;
  text-align: center;
}

.flow_message p {
  font-size: 30px;
  font-weight: bold;
  color: #dc5f5e;
  line-height: 1.5;
}

/* 当院の治療について */
.treat_purpose {
  border: 1px solid #4b577d;
  box-sizing: border-box;
  padding: 40px;
  background: #fff;
  margin-bottom: 32px;
}

.treat_purpose p {
  font-size: 24px;
  font-weight: bold;
  color: #4b577d;
  text-align: center;
}

.treat_purpose p span {
  display: block;
}

.treat_text01 {
  text-align: center;
}

/* 施術料金・初回特別割引 */
.price_list {
  margin-top: 56px;
}

.price_tbl {
  display: block;
  margin-bottom: 24px;
}

.price_tbl tbody {
  display: block;
}

.price_tbl tr {
  display: flex;
  border-top: 1px solid #c9c2b5;
}

.price_tbl tr:last-of-type {
  border-bottom: 1px solid #c9c2b5;
}

.price_tbl tr th {
  display: block;
  width: 15em;
  padding: 20px;
  text-align: center;
  font-weight: bold;
  background: #fafafa;
  font-size: 18px;
}

.price_tbl tr td {
  display: block;
  width: calc(100% - 15em);
  padding: 20px;
  font-size: 18px;
  background: #fff;
}

.price_offer {
  margin-top: 50px;
}

.price_offer_text01 {
  text-align: center;
  font-size: 28px;
  font-weight: bold;
}

.price_offer_text01 span {
  background: #fb6a00;
  color: #fff;
  width: 100%;
  max-width: 580px;
  text-align: center;
  border-radius: 8px;
  padding: 8px 12px 4px;
  margin-top: 30px;
  display: block;
  position: relative;
  margin: 0 auto 16px;
}

.price_offer_text01 span:after {
  content: "";
  display: block;
  border: 15px solid transparent;
  border-top: 15px solid #fb6a00;
  position: absolute;
  bottom: -30px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 0;
  height: 0;
}

.price_offer_text01 span strong {
  font-size: 32px;
  text-align: center;
  line-height: 1.5;
}

.price_offer_limit01 {
  margin-top: 16px;
  margin-bottom: 24px;
  border-top: 2px solid #151311;
  border-bottom: 2px solid #151311;
  padding: 16px 0 12px;
}

.price_offer_limit01 p {
  font-size: 32px;
  font-weight: bold;
  text-align: center;
  line-height: 1.3;
}

.price_offer_limit01 span {
  font-size: 48px;
  color: #ff0000;
}

.price_offer_main_text {
  font-weight: bold;
  font-size: 48px;
  line-height: 1.6;
  text-align: center;
  margin-top: 40px;
}

.price_offer_main_text span {
  position: relative;
  display: inline-block;
  padding: 0;
}

.price_offer_main_text span:before {
  content: "";
  display: block;
  height: 80px;
  background: url(../images/top/bg_offer_ttl02_l.png) no-repeat left top;
  position: absolute;
  top: 10px;
  left: -70px;
  width: 44px;
}

.price_offer_main_text span:after {
  content: "";
  display: block;
  width: 44px;
  height: 80px;
  background: url(../images/top/bg_offer_ttl02_r.png) no-repeat left top;
  position: absolute;
  top: 10px;
  right: -70px;
}

.price_offer_mainimg {
  margin: 10px auto 30px;
  text-align: center;
}

.price_offer_mainimg img {
  width: auto;
  max-width: 100%;
}

.price_offer_limit02 {
  font-size: 30px;
  font-weight: bold;
  color: #282624;
  text-align: center;
  line-height: 1.5;
  background: #e2f9e9;
  display: block;
  width: calc(100% - 40px);
  padding: 20px;
  border-radius: 5px;
}

.member_num_close {
  text-decoration: line-through;
}

.member_num_limit {
  font-size: 1.5em;
  text-decoration: underline;
  color: #eb1818;
}

.offer_conts_line {
  margin-top: 20px;
}

.offer_conts_line_pc img {
  width: auto;
  max-width: 100%;
}

.offer_conts_line_sp {
  display: none;
}

.ekiten_reserve {
	background: #fff;
	padding:2% 5%;
	text-align: center;
	margin-top: 30px;
	border: solid 10px #c3a17c;
}

/* 特典 */
.gift_conts {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.gift_conts:last-of-type {
  margin-bottom: 0;
}

.gift_conts-img {
  width: 200px;
  height: 200px;
}

.gift_conts-text {
  width: calc(100% - 264px);
  margin-left: 64px;
}

.gift_conts-text .gift_conts-ttl01 {
  margin-bottom: 0;
}

.gift_conts-text .gift_conts-ttl02 {
  font-size: 24px;
  font-weight: bold;
  color: #fb6a00;
  border-bottom: 1px solid;
  display: inline-block;
  line-height: 1.5;
  margin-bottom: 12px;
}

/* なぜ、この価格なのか？ */
.conts_divide {
  margin: 40px auto;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.conts_divide_l, .conts_divide_r {
  width: 47.5%;
  background: #fff;
}

.conts_divide_ttl {
  background: #f0f0f0;
  font-size: 18px;
  font-weight: bold;
  padding: 16px 24px;
  border-radius: 8px 8px 0 0;
  text-align: left;
  line-height: 1.5;
}

.conts_divide_ttl span {
  display: block;
}

.conts_divide_r .conts_divide_ttl {
  background: #fb6a00;
  color: #fff;
}

.conts_divide_text {
  padding: 16px 24px;
  background: #fff;
  border: 1px solid #f0f0f0;
  border-top: none;
  border-radius: 0 0 8px 8px;
}

.conts_divide_false li {
  background: url("../images/top/icon_false.png") no-repeat left 4px;
  padding-left: 30px;
  margin-bottom: 12px;
}

.conts_divide_false li:last-child {
  margin-bottom: 0;
}

.conts_divide_true li {
  background: url("../images/top/icon_true.png") no-repeat left 4px;
  padding-left: 30px;
  margin-bottom: 12px;
}

.conts_divide_true li:last-child {
  margin-bottom: 0;
}

/* オファー */
.offer_ttl01 {
  text-align: center;
  color: #fff;
}

.offer_ttl01 span {
  font-family: "Noto Serif JP", serif;
  font-size: 65px;
  font-weight: 600;
  position: relative;
  padding-top: 12px;
  border-bottom: 4px solid #fff;
  position: relative;
}

.offer_ttl01 span:before, .offer_ttl01 span:after {
  content: "";
  display: block;
  width: 10vw;
  max-width: 44px;
  height: 20vw;
  max-height: 80px;
  position: absolute;
  bottom: 5px;
}

.offer_ttl01 span:before {
  background: url("../images/top/bg_offer_ttl01_l.png") no-repeat left top;
  left: -44px;
}

.offer_ttl01 span:after {
  background: url("../images/top/bg_offer_ttl01_r.png") no-repeat left top;
  right: -44px;
}

.offer_conts_ttl01 {
  font-size: 28px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  text-decoration: underline;
  letter-spacing: 0.04em;
}

.offer_conts01_img {
  margin: 56px auto;
  text-align: center;
  display: block;
}

.offer_conts01_img img {
  width: auto;
  max-width: 100%;
}

.offer_conts02 {
  width: 100%;
  box-sizing: border-box;
  background: #fff;
  padding: 24px 16px 16px;
  margin: 24px auto;
}

.offer_conts02 p {
  font-size: 56px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.04em;
  line-height: 1.2;
}

.offer_conts02 p span {
  color: #fb6a00;
}

.offer_conts03_pc, .offer_conts03_img {
  position: relative;
}

.offer_conts03_sp {
  display: none;
}

.offer_conts03_img img {
  width: auto;
  max-width: 100%;
}

.offer_telbtn {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  position: absolute;
  bottom: 1.25vw;
  left: 0;
  right: 0;
  width: 100%;
}

.offer_telbtn img {
  width: auto;
  max-width: 90vw;
}

.offer_conts04 {
  color: #fff;
  margin-top: 8px;
}

.offer_conts04 p {
  font-size: 13px;
  line-height: 2;
  margin-bottom: 0;
}

/* アクセス */
.access_movie{
  margin-top: 40px;
}

.access_movie iframe{
  width: 100%;
  max-width: 100%;
  max-height: 500px;
  height: 50vw;
}

.access_info_wrap {
  margin-top: 40px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.access_movie{
  display: block;
  width: 100%;
}

.access_map {
  width: 100%;
  max-width: 540px;
}

.access_map iframe {
  width: 540px;
  height: 395px;
}

.access_mapinfo {
  width: calc(100% - 540px);
  margin-left: 50px;
}

.access_map_conts {
  margin-bottom: 20px;
}

.access_map_conts p {
  margin-bottom: 0;
}

.access_mapinfo dl {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 1em;
}

.access_mapinfo dl:last-of-type {
  margin-bottom: 0;
}

.access_mapinfo dl dt {
  width: 5em;
}

.access_mapinfo dl dd {
  width: calc(100% - 5em);
}

.access_map_ttl01 {
  font-size: 15px;
  font-weight: bold;
}

.access_root {
  margin-top: 50px;
}

.access_rootlist {
  margin-top: 40px;
  counter-reset: guidenum;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.access_rootlist li {
  width: calc(100% / 3 - 49px);
  max-width: 300px;
  position: relative;
  margin-bottom: 25px;
  position: relative;
  text-align: center;
  vertical-align: top;
  margin-left: 100px;
  margin-left: 75px;
}

.access_rootlist li:nth-child(3n+1) {
  margin-left: 0;
}

.access_rootlist li:before {
  content: url("../images/top/access_arrow.png");
  left: -54px;
  position: absolute;
  top: 29%;
}

.access_rootlist li:first-child:before, .access_rootlist li:nth-child(3n+1):before {
  content: none;
}

.access_rootlist li img {
  width: auto;
  max-width: 100%;
}

.access_rootlist_text {
  line-height: 1.5;
  margin: 10px 0 0 2.5em;
  text-align: left;
}

.access_rootlist_text:before {
  color: #f2aeae;
  content: counter(guidenum) ".";
  counter-increment: guidenum;
  font-size: 25px;
  font-weight: bold;
  line-height: 1;
  margin-left: -1.5em;
  padding: 0 6px;
}

/* 最後に... */
.last_conts {
  display: flex;
  flex-direction: row-reverse;
}

.last_conts-img {
  width: 314px;
}

.last_conts-img img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.last_conts-text {
  width: calc(100% - 354px);
  margin-right: 40px;
}

.last_conts-text p {
  font-size: 18px;
}

/* pagetop */
#pagetop {
  position: absolute;
  bottom: 10px;
  right: 2.5%;
  line-height: 0;
}

#pagetop img {
  width: auto;
  max-width: 79px;
}

/*下層ページ
----------------------------------------------------*/
#second #header {
  border-bottom: 1px solid #f2aeae;
}

#breadcrumb {
  width: 95%;
  max-width: 1050px;
  padding: 0 2.5%;
  margin: 12px auto 0;
}

#breadcrumb ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

#breadcrumb ul li {
  font-size: 13px;
}

#breadcrumb ul li:before {
  content: ">";
  margin: 0 5px;
}

#breadcrumb ul li:first-child:before {
  content: none;
}

.contact_tel, .contact_mail {
  margin-top: 40px;
}

.contact_tel p {
  margin-bottom: 5px;
}

.contact_telnum a {
  font-size: 1.5em;
  font-weight: bold;
}

.contact_tel dl {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 10px;
}

.contact_tel dl dt {
  width: 5em;
}

.contact_tel dl dd {
  width: calc(100% - 5em);
}

.contact_form {
  width: calc(100% - 80px);
  background: #ffecec;
  padding: 30px 40px;
  margin-top: 40px;
}

.form_tbl tr {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  padding-bottom: 20px;
  border-bottom: 1px dashed;
  margin-bottom: 20px;
}

.form_tbl tr th {
  width: 100%;
  display: block;
  text-align: left;
  font-size: 18px;
  font-weight: normal;
  line-height: 1.5;
  margin-bottom: 5px;
}

.form_tbl tr td {
  width: 100%;
  display: block;
}

.form_tbl tr td input {
  font-size: 17px !important;
}

.form_tbl tr td textarea {
  font-size: 17px !important;
}

.required {
  background: #ec3838;
  padding: 0 5px;
  font-size: 0.8em;
  color: #fff;
  margin-left: 10px;
  display: inline-block;
}

.form_name {
  display: block;
  width: 100%;
  max-width: 25em;
}

.form_mail {
  display: block;
  width: 100%;
  max-width: 30em;
}

.form_tel {
  display: block;
  width: 100%;
  max-width: 10em;
}

.form_reserve01, .form_reserve02, .form_reserve03 {
  width: 100%;
  max-width: 20em;
}

.form_textarea {
  display: block;
  width: 100%;
  min-height: 200px;
}

.form_confirm {
  font-size: 16px;
  text-align: center;
}

.form_submit {
  margin-top: 15px;
  text-align: center;
}

.form_submit input {
  width: 100%;
  max-width: 500px;
  padding: 20px 0;
  margin: 0 auto;
  font-size: 25px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
  border: none;
  background: #e35656;
  border-radius: 100px;
  -webkit-appearance: none;
}

.form_submit input[disabled] {
  background: #ccc;
}

/*wordpress
----------------------------------------------------*/
.blog_conts {
  width: 95%;
  max-width: 1050px;
  padding: 20px 2.5%;
  margin: 0 auto 50px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.blog_main {
  width: calc(80% - 71px);
}

.single_date {
  background: #f2aeae none repeat scroll 0 0;
  color: #fff;
  display: inline-block;
  font-size: 13px;
  padding: 1px 10px;
}

.s_ttl01 {
  color: #7fb8de;
  font-size: 32px;
  font-weight: bold;
  line-height: 1.2;
  margin: 15px 0;
  text-align: left;
}

.blog_cat {
  border-bottom: 1px dashed #212121;
  margin-bottom: 20px;
  padding-bottom: 20px;
}

.blog_side {
  width: 20%;
  max-width: 250px;
  border-left: 1px solid #f2aeae;
  padding-left: 35px;
  margin-left: 35px;
}

.side_blog_ttl {
  color: #212121;
  font-size: 19px;
  font-weight: bold;
  margin-bottom: 5px !important;
}

.blog_single p {
  margin-bottom: 15px;
}

.blog_single img {
  width: auto;
  max-width: 100%;
  height: 100%;
}

.blog_single img.alignright {
  float: right;
  margin-left: 10px;
}

.blog_single img.alignleft {
  float: left;
  margin-right: 10px;
}

.blog_single .single_date {
  margin-bottom: 0;
}

.single_ttl {
  color: #f2aeae;
  font-size: 38px;
  font-weight: bold;
  line-height: 1.2;
  margin: 0 0 16px;
  text-align: left;
  border: solid 1px #f2aeae;
  background: #fff;
  border-radius: 6px;
  -webkit-border-radius: 6px;
  -moz-border-radius: 6px;
  padding: 2%;
}

.single_cat {
  padding-bottom: 20px;
  border-bottom: 1px dashed #212121;
  margin-bottom: 40px;
  line-height: 1;
}

.single_cat p {
  float: left;
}

.blog_single h3 {
  border-left: 10px solid #f2aeae;
  border-bottom: 1px solid #f2aeae;
  font-size: 1.6em;
  font-weight: bold;
  color: #282624;
  margin: 50px auto 25px;
  padding: 10px 0 10px 15px;
  clear: both;
}

.blog_single h4 {
  border-bottom: 1px dashed;
  font-size: 1.4em;
  font-weight: bold;
  color: #f2aeae;
  margin: 30px auto 15px;
  padding-bottom: 5px;
  clear: both;
}

.blog_single ul {
  background: none none repeat scroll 0 0;
  border: 1px solid #f2aeae;
  border-radius: 5px;
  margin-bottom: 30px;
  padding: 15px;
}

.blog_single li {
  background: url("../images/top/icon_nayami.png") no-repeat left top;
  border-bottom: 1px dashed;
  font-size: 20px;
  line-height: 1.7;
  margin-bottom: 10px;
  padding-bottom: 5px;
  padding-left: 38px;
}

.blog_single p {
  margin-bottom: 30px;
}

.wp-pagenavi {
  text-align: center;
}

.side_menu {
  margin-bottom: 30px;
}

.side_menu ul {
  border-top: 2px solid #f2aeae;
  border-bottom: 2px solid #f2aeae;
  padding: 5px 10px;
}

.side_menu li {
  border-bottom: 1px dashed #f2aeae;
  margin-top: 8px;
  padding-bottom: 5px;
  padding-left: 1.3em;
  line-height: 1.6;
  position: relative;
}

.side_menu li:before {
  content: '';
  background: url("../images/common/side_icon01.png") no-repeat left top;
  background-size: contain;
  width: 16px;
  height: 16px;
  position: absolute;
  left: 0;
  top: 2px;
}

.side_menu li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.side_menu li a {
  text-decoration: none;
}

/*フッター
----------------------------------------------------*/
#sp_pagebtm {
  display: block;
  width: 100%;
  line-height: 0;
  opacity: 1;
  position: fixed;
  left: 0;
  bottom: -300px;
  transition: all 0.4s linear 0s;
}

.sp_pagebtm-conts {
  background: rgba(255, 255, 255, 0.8);
  width: 95%;
  padding: 2.5vw 2.5%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.sp_pagebtm-tel {
  margin-right: 5px;
}

.sp_pagebtm-tel img {
  width: 100%;
  max-width: 270px;
  height: auto;
}

.sp_pagebtm-mail {
  margin-right: 5px;
}

.sp_pagebtm-mail img {
  width: 100%;
  max-width: 212px;
  height: auto;
}

.sp_btm_line img {
  width: 100%;
  max-width: 212px;
  height: auto;
}

#footer {
  background: #fff;
}

.f_wrap {
  width: 95%;
  max-width: 1050px;
  margin: 0 auto;
  padding: 40px 2.5%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.f_conts_l {
  font-size: 13px;
  line-height: 1.8;
}

.f_logo {
  margin-bottom: 20px;
}

.f_logo a:hover {
  opacity: 1;
}

.f_conts_l dl {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 5px;
}

.f_conts_l dl dt {
  width: 3em;
}

.f_conts_l dl dd {
  width: calc(100% - 3em);
}

.f_conts_r {
  display: -webkit-flex;
  display: flex;
}

.f_conts_r dl {
  margin-left: 50px;
  width: 12em;
}

.f_conts_r dl dt {
  font-size: 14px;
  font-weight: bold;
}

.f_conts_r dl dd a {
  background: url("../images/common/f_icon.png") no-repeat left 3px;
  padding-left: 20px;
  color: #1e1e1e;
  text-decoration: none;
}

.f_sns {
  width: 95%;
  max-width: 1050px;
  margin: 0 auto;
  border-top: 1px dashed #f2aeae;
  margin-top: 24px;
  padding-top: 24px;
}

.f_sns img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.f_cr {
  margin-top: 40px;
  width: 100%;
  font-size: 13px;
  background: #4b577d;
  text-align: center;
  padding: 12px 0;
  color: #fff;
}

.f_cr a {
  text-decoration: none;
}
