@charset "UTF-8";
:root {
  --scrollbar: 0px;
  /* color */
  --color-primary: #072948;
  --color-secondary: #8C1F3C;
  --color-text: #231815;
  --main_txt: #231815;
  --white: #fff;
  --gray_01: #D9E1E6;
  --gray_02: #777777;
  --gray_03: #D8DDE6;
  --bg_gray_01: #EBEDEF;
  --beiju_01: #E6E4E1;
  --beiju_02: #CBB693;
  --beiju_03: #B08B4E;
  --beiju_04: #876938;
  --red_01: #804552;
  --red_02: #7F2B49;
  --red_03: #E5CFD7;
  --orange_01: #AA5C33;
  --orange_02: #DC6A2E;
  --orange_03: #F3E5DA;
  --blue_01: #3F4D6B;
  --blue_02: #3569A1;
  --blue_03: #072948;
  --blue_04: #687F97;
  --blue_05: #167DBC;
  --blue_06: #1DA5E0;
  --blue_07: #D4EDFA;
  --darkblue_01: #14212D;
  --navy_01: #3A5B9B;
  --navy_02: #CFDBE5;
  --bg_kasou: #F2F2F2;
  --box-bg: #FFFFFF66;
  --section-border: 1px solid #3569A1;
  --color-border: #B5BFD1;
  --color-attention: #cc0000;
  /* gradient */
  --gradient-blue: linear-gradient(90deg, #0C4685 0%, #05203C 100%);
  --gradient-blue-row: linear-gradient(180deg, #0C4685 0%, #05203C 100%);
  --gradient-black: linear-gradient(90deg, #37393E 0%, #101214 100%);
  --gra_black_01: linear-gradient(180deg, #33363C 0%, #101214 100%);
  --gradient-takatsuki: linear-gradient(90deg, #A23C65 0%, #601C30 100%);
  --gradient-takatsuki-270: linear-gradient(270deg, #A23C65 0%, #601C30 100%);
  --gradient-takatsuki-row: linear-gradient(180deg, #A23C65 0%, #601C30 100%);
  --clinic-nav-gradient-takatsuki: linear-gradient(90deg, #8E425A 0%, #541228 100%);
  --gradient-takatsuki-: linear-gradient(90deg, #A23C65 0%, #601C30 100%);
  --gradient-yao: linear-gradient(90deg, #D87729 0%, #9E5011 100%);
  --gradient-yao-270: linear-gradient(270deg, #D87729 0%, #9E5011 100%);
  --gradient-yao-row: linear-gradient(180deg, #D87729 0%, #9E5011 100%);
  --clinic-nav-gradient-yao: linear-gradient(90deg, #DE852B 0%, #B7492A 100%);
  --gra_orange_01: linear-gradient(270deg, #D87729 0%, #9E5011 100%);
  --gra_orange_02: linear-gradient(90deg, #E78019 0%, #B7492A 100%);
  --gradient-matsubara: linear-gradient(90deg, #1F81BF 0%, #09588A 100%);
  --gradient-matsubara-270: linear-gradient(270deg, #1F81BF 0%, #09588A 100%);
  --gradient-matsubara-row: linear-gradient(180deg, #1F81BF 0%, #09588A 100%);
  --clinic-nav-gradient-matsubara: linear-gradient(270deg, #09588A 0%, #1F81BF 100%);
  --gra_blue_02: linear-gradient(270deg, #1F81BF 0%, #09588A 100%);
  --gra_blue_03: linear-gradient(90deg, #0F95D9 0%, #09588A 100%);
  --network-bg-gradient: linear-gradient(180deg, #0C4685 0%, #05203C 100%), linear-gradient(180deg, #33363C 0%, #101214 100%);
  --footer-bg-gradient: linear-gradient(90deg, #203D5D 0%, #14283F 100%);
  /* font */
  --main-family: YakuHanJP, "Noto Sans JP", sans-serif;
  --main-family-weight: 400;
  --main-family-bold: 500;
  --main-line-height: 1.8;
  --main-letter-spacing: 0.06em;
  --title-family: YakuHanMP, "Noto Serif JP", serif;
  --title-family-weight: 600;
  --title-line-height: 1.6;
  --title-letter-spacing: 0.04em;
  --cor-garamond: "Cormorant Garamond", serif;
  --eb-garamond: "EB Garamond", serif;
  --roboto: "Roboto", sans-serif;
  /* hover デフォルト */
  --opacity-hover: 0.6;
  --transition-hover: all 0.3s ease;
  /* leading-trim を反映 
  margin-block: var(--leading-trim); */
  --leading-trim: calc((1em - 1lh) / 2);
}
@media (min-width: 768px) {
  :root {
    --main-line-height: 2;
    --main-letter-spacing: 0.08em;
  }
}

@supports not (top: 1lh) {
  :root {
    --leading-trim: 0px;
  }
}
:root {
  /* clinic設定 */
  --color-seiyukai: var(--blue_03);
  --color-takatsuki: #8C1F3C;
  --color-yao: #CC6E10;
  --color-matsubara: var(--blue_05);
  --clinic-gradient: var(--gradient-blue);
  --clinic-gradient-row: var(--gradient-blue-row);
  --clinic_nav-gradient: var(--clinic-gradient-row);
  --color-clinic: var(--blue_02);
  --color-clinic-icon: var(--navy_01);
  --color-h3: #3A70DD;
  --color-clinic-bg: var(--navy_02);
  --color-clinic-secondary: var(--navy_01);
  --color-clinic-txt: var(--blue_03);
}

/* 高槻院 */
.header._takatsuki,
.header._takatsuki .btn_tel .icon,
.header_btn ._takatsuki,
.clinic_nav_wrap._takatsuki,
.sec-clinic_info._takatsuki,
.page-template-template-takatsuki {
  --clinic-gradient: var(--gradient-takatsuki);
  --clinic-gradient-row: var(--gradient-takatsuki-row);
  --clinic_nav-gradient: var(--clinic-gradient-row);
  --color-clinic: var(--red_02);
  --color-h3: #9F3E5F;
  --color-clinic-bg: var(--red_03);
  --color-clinic-secondary: var(--color-clinic);
  --color-clinic-icon: var(--color-clinic);
  --color-clinic-txt: var(--color-clinic);
  --color-clinic_nav-hover: #96415F;
  --color-header_btn_sp: var(--color-clinic);
  --day-surgery-border: var(--color-takatsuki);
  --clinic_info_logo-size: calc( 460 / var(--sp_calc));
  --color-clinic-logo: #6C1318;
}
@media (min-width: 768px) {
  .header._takatsuki,
  .header._takatsuki .btn_tel .icon,
  .header_btn ._takatsuki,
  .clinic_nav_wrap._takatsuki,
  .sec-clinic_info._takatsuki,
  .page-template-template-takatsuki {
    --clinic_nav-gradient: linear-gradient(90deg, #8E425A 0%, #541228 100%);
  }
}

/* 八尾院 */
.header._yao,
.header._yao .btn_tel .icon,
.header_btn ._yao,
.clinic_nav_wrap._yao,
.sec-clinic_info._yao,
.page-template-template-yao {
  --clinic-gradient: var(--gradient-yao);
  --clinic-gradient-row: var(--gradient-yao-row);
  --clinic_nav-gradient: var(--clinic-gradient-row);
  --color-clinic: var(--orange_01);
  --color-h3: var(--color-clinic);
  --color-clinic-bg: var(--orange_03);
  --color-clinic-secondary: var(--color-clinic);
  --color-clinic-icon: var(--orange_02);
  --color-clinic-txt: var(--color-clinic);
  --color-clinic_nav-hover: #D89755;
  --color-header_btn_sp: var(--color-clinic);
  --day-surgery-border: var(--color-yao);
  --clinic_info_logo-size: calc( 512 / var(--sp_calc));
  --color-clinic-logo: var(--orange_01);
}
@media (min-width: 768px) {
  .header._yao,
  .header._yao .btn_tel .icon,
  .header_btn ._yao,
  .clinic_nav_wrap._yao,
  .sec-clinic_info._yao,
  .page-template-template-yao {
    --clinic_nav-gradient: linear-gradient(90deg, #DE852B 0%, #B7492A 100%);
  }
}

/* 松原院 */
.header._matsubara,
.header._matsubara .btn_tel .icon,
.header_btn ._matsubara,
.clinic_nav_wrap._matsubara,
.sec-clinic_info._matsubara,
.page-template-template-matsubara {
  --clinic-gradient: var(--gradient-matsubara);
  --clinic-gradient-row: var(--gradient-matsubara-row);
  --clinic_nav-gradient: var(--clinic-gradient-row);
  --color-clinic: var(--blue_05);
  --color-h3: var(--blue_06);
  --color-clinic-bg: var(--blue_07);
  --color-clinic-secondary: var(--color-clinic);
  --color-clinic-icon: var(--blue_06);
  --color-clinic-txt: var(--color-clinic);
  --color-clinic_nav-hover: #4C93CD;
  --color-header_btn_sp: var(--blue_02);
  --day-surgery-border: var(--color-matsubara);
  --clinic_info_logo-size: calc( 512 / var(--sp_calc));
  --color-clinic-logo: var(--blue_02);
}
@media (min-width: 768px) {
  .header._matsubara,
  .header._matsubara .btn_tel .icon,
  .header_btn ._matsubara,
  .clinic_nav_wrap._matsubara,
  .sec-clinic_info._matsubara,
  .page-template-template-matsubara {
    --clinic_nav-gradient: linear-gradient(270deg, #09588A 0%, #1F81BF 100%);
  }
}

.page-template-template-matsubara .consul {
  --color-clinic: var(--blue_02);
}

/**/
body {
  --vw100: calc(100vw - var(--scrollbar));
  /* sp size 
  calc( SPpx / var(--sp_calc)) */
  --spsize: 390;
  --sp_calc: var(--spsize) * var(--vw100);
  /* container */
  --container-size: 1200;
  --container-width: calc( var(--container-size) * 1px );
  --container-padding-size: 20;
  --container: (var(--container-size) + var(--container-padding-size) * 2 );
  --container-px: calc(var(--container-size) + var(--container-padding-size) * 2 * 1px);
  --under-size: 1100;
  --under-width: 1100px;
  --design-size: 1920;
  --design-width: (var(--design-size) * 1px);
  /* 余白 */
  /* カード型ボックスのマージン等、不明点あり */
  --body-padding: calc( var(--container-padding-size) / var(--sp_calc));
  --section-padding: calc(30 / var(--sp_calc));
  --box-margin: calc(40 / var(--sp_calc));
  --item-margin: calc(30 / var(--sp_calc));
  --box-padding: var(--item-margin) calc(24 / var(--sp_calc));
  --note-padding: calc(30 / var(--sp_calc)) calc(20 / var(--sp_calc));
  --img-margin: calc(30 / var(--sp_calc));
  --btn-margin: var(--px-18);
  /* clamp用 
  clamp( 最小値 , calc( 15 / var(--clamp-pc)) , 最大値) */
  --clamp-pc: (var(--container-size) + var(--container-padding-size) * 2 ) * var(--vw100) ;
  /* fontsize */
  --main-size: calc(17 / var(--sp_calc));
  --h1-size: calc(25 / var(--sp_calc));
  --h1-sub-size: calc(20 / var(--sp_calc));
  --h2-size: calc(30 / var(--sp_calc));
  --h3-size: calc(24 / var(--sp_calc));
  --h4-size: calc(22 / var(--sp_calc));
  --h5-size: calc(20 / var(--sp_calc));
  --h6-size: calc(18 / var(--sp_calc));
  --tel-size: calc(28 / var(--sp_calc));
  --tel-weight: 500;
  /* px */
  --px-1: calc(1 / var(--sp_calc));
  --px-2: calc(2 / var(--sp_calc));
  --px-3: calc(3 / var(--sp_calc));
  --px-4: calc(4 / var(--sp_calc));
  --px-5: calc(5 / var(--sp_calc));
  --px-6: calc(6 / var(--sp_calc));
  --px-7: calc(7 / var(--sp_calc));
  --px-8: calc(8 / var(--sp_calc));
  --px-9: calc(9 / var(--sp_calc));
  --px-10: calc(10 / var(--sp_calc));
  --px-11: calc(11 / var(--sp_calc));
  --px-12: calc(12 / var(--sp_calc));
  --px-13: calc(13 / var(--sp_calc));
  --px-14: calc(14 / var(--sp_calc));
  --px-15: calc(15 / var(--sp_calc));
  --px-16: calc(16 / var(--sp_calc));
  --px-17: calc(17 / var(--sp_calc));
  --px-18: calc(18 / var(--sp_calc));
  --px-19: calc(19 / var(--sp_calc));
  --px-20: calc(20 / var(--sp_calc));
  --px-21: calc(21 / var(--sp_calc));
  --px-22: calc(22 / var(--sp_calc));
  --px-24: calc(24 / var(--sp_calc));
  --px-25: calc(25 / var(--sp_calc));
  --px-28: calc(28 / var(--sp_calc));
  --px-30: calc(30 / var(--sp_calc));
  --px-33: calc(33 / var(--sp_calc));
  --px-34: calc(34 / var(--sp_calc));
  --px-35: calc(35 / var(--sp_calc));
  --px-40: calc(40 / var(--sp_calc));
  --px-45: calc(45 / var(--sp_calc));
  --px-46: calc(46 / var(--sp_calc));
  --px-48: calc(48 / var(--sp_calc));
  --px-50: calc(50 / var(--sp_calc));
  --px-51: calc(51 / var(--sp_calc));
  --px-55: calc(55 / var(--sp_calc));
  --px-60: calc(60 / var(--sp_calc));
  --px-65: calc(65 / var(--sp_calc));
  --px-70: calc(70 / var(--sp_calc));
  --px-75: calc(75 / var(--sp_calc));
  --px-78: calc(78 / var(--sp_calc));
  --px-80: calc(80 / var(--sp_calc));
  --px-85: calc(85 / var(--sp_calc));
  --px-90: calc(90 / var(--sp_calc));
  --px-95: calc(95 / var(--sp_calc));
  --px-100: calc(100 / var(--sp_calc));
  --px-200: calc(200 / var(--sp_calc));
  /* ドロップシャドウ */
  --box-shadow: 0px 0px var(--px-25) 0px #64696F26;
  /* 高さ計算用 */
  --header-h: calc(54 / var(--sp_calc));
  --header_btn-h: calc(40 / var(--sp_calc));
  --clinic_nav-h: calc(60 / var(--sp_calc));
  /* top画像のはみ出し計算 */
  --negative-margin: calc( (var(--container-padding-size)) * -1px);
}
@media (min-width: 768px) {
  body {
    --container-padding-size: 40;
  }
}
@media (min-width: 768px) {
  body {
    --body-padding: calc(var(--container-padding-size) * 1px);
    --section-padding: 50px;
    --box-margin: 50px;
    --item-margin: 40px;
    --box-padding: var(--item-margin) 60px;
    --note-padding: 30px 40px;
    --img-margin: 60px;
  }
}
@media (min-width: 768px) {
  body {
    --main-size: 20px;
    --h1-size: 50px;
    --h1-sub-size: 34px;
    --h2-size: 44px;
    --h3-size: 28px;
    --h4-size: 26px;
    --h5-size: 22px;
    --h6-size: 20px;
    --tel-size: 32px;
  }
}
@media (min-width: 768px) {
  body {
    --px-1: 1px;
    --px-2: 2px;
    --px-3: 3px;
    --px-4: 4px;
    --px-5: 5px;
    --px-6: 6px;
    --px-7: 7px;
    --px-8: 8px;
    --px-9: 9px;
    --px-10: 10px;
    --px-11: 11px;
    --px-12: 12px;
    --px-13: 13px;
    --px-14: 14px;
    --px-15: 15px;
    --px-16: 16px;
    --px-17: 17px;
    --px-18: 18px;
    --px-19: 19px;
    --px-20: 20px;
    --px-21: 21px;
    --px-22: 22px;
    --px-24: 24px;
    --px-25: 25px;
    --px-28: 28px;
    --px-30: 30px;
    --px-33: 33px;
    --px-34: 34px;
    --px-35: 35px;
    --px-40: 40px;
    --px-45: 45px;
    --px-46: 46px;
    --px-48: 48px;
    --px-50: 50px;
    --px-51: 51px;
    --px-55: 55px;
    --px-60: 60px;
    --px-65: 65px;
    --px-70: 70px;
    --px-75: 75px;
    --px-78: 78px;
    --px-80: 80px;
    --px-85: 85px;
    --px-90: 90px;
    --px-95: 95px;
    --px-100: 100px;
    --px-200: 200px;
  }
}
@media (min-width: 768px) {
  body {
    --header-h: 94px;
    --header_btn-h: 35px;
    --clinic_nav-h: 100px;
    --header_min-h: 64px;
    --clinic_nav_min-h: 42px;
  }
}
@media (min-width: 768px) {
  body {
    --negative-margin: calc( (100vw - var(--container-width)) / 2 * -1);
  }
}
@media (min-width: 768px) and (max-width: 1280px) {
  body {
    --negative-margin: calc( (var(--container-padding-size)) * -1px);
  }
}

html {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
  font-size: 54.69%;
}
@media (min-width: 768px) {
  html {
    font-size: 62.5%;
  }
}

body {
  color: var(--main_txt);
  background: var(--bg_kasou);
  font-family: var(--main-family);
  font-weight: 400;
  font-size: var(--main-size);
  line-height: 1.6;
  letter-spacing: 0.08em;
  -webkit-font-smoothing: antialiased;
}
@media (min-width: 768px) {
  body:not(.wp-editor) {
    min-width: calc(var(--container-width) + var(--container-padding-size) * 2 * 1px);
  }
}
body.wp-editor {
  background: none;
}

a {
  word-break: break-all;
}

@media (hover: hover) {
  a {
    transition: var(--transition-hover);
  }
  a:hover {
    cursor: pointer;
    opacity: var(--opacity-hover);
  }
}
*:focus {
  outline: none;
}

.clearfix {
  overflow: hidden;
}
.clearfix:last-child {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .clearfix img {
    display: block;
    margin-inline: auto;
  }
}

.clearfix:after {
  clear: both;
  content: "";
  display: block;
}

img,
svg {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

a[href^="tel:"] {
  color: inherit;
  text-decoration: none;
}

@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    text-decoration: none;
  }
}
input[type=text],
input[type=email],
input[type=tel],
input[type=password],
textarea,
select,
button {
  box-shadow: none;
  border: 1px solid var(--color-border);
  width: auto;
}

input[type=submit],
button {
  background: #0f406c;
  border-color: #0f406c;
  color: #fff;
}
input[type=submit]:hover,
button:hover {
  opacity: var(--opacity-hover);
}

.alignleft,
.alignright,
.aligncenter {
  margin-bottom: calc(30 / var(--sp_calc));
}
@media (max-width: 767px) {
  .alignleft,
  .alignright,
  .aligncenter {
    display: block;
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  .alignleft,
  .alignright,
  .aligncenter {
    margin-bottom: 10px;
  }
}
.aligncenter {
  display: block;
  margin-inline: auto;
  max-width: 100%;
}
@media (min-width: 768px) {
  .aligncenter {
    margin-bottom: var(--box-margin);
  }
}

@media (min-width: 768px) {
  .alignleft,
  .alignright {
    max-width: 420px;
    margin-bottom: 10px;
  }
  .alignleft {
    float: left;
    margin-right: 60px;
  }
  .alignright {
    float: right;
    margin-left: 60px;
  }
}
@media (min-width: 768px) {
  .sp {
    display: none !important;
  }
  .spbasic {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .pc {
    display: none !important;
  }
  br.sp,
  span.sp {
    display: inline !important;
  }
  span.br {
    display: inline-block !important;
  }
  span.spdb {
    display: inline-block;
  }
}
@media (min-width: 421px) {
  .spmin {
    display: none !important;
  }
}
@media (max-width: 420px) {
  .spbasic {
    display: none !important;
  }
}
.container,
.gutters,
.mce-content-body {
  max-width: calc(100% - var(--body-padding) * 2);
  margin-inline: auto;
  width: var(--under-width);
}

._clinic_home.mce-content-body {
  max-width: 100%;
  width: 100%;
}
._clinic_home.mce-content-body .container {
  width: var(--container-width);
}

._clinic_home .container,
.sec_network .container {
  width: var(--container-width);
}

@media (min-width: 768px) {
  body.archive .contents, body.single .contents {
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  body.contents-column-two .contents {
    display: flex;
    justify-content: space-between;
  }
  body.contents-column-two .contents #main {
    width: 72%;
  }
  body.contents-column-two .contents #aside {
    width: 23.5%;
  }
}

.flexbox {
  display: flex;
}
.flexbox._wrap {
  flex-wrap: wrap;
}

.dib {
  display: inline-block;
}

@media (max-width: 767px) {
  .pcbr {
    display: none !important;
  }
  .spbr {
    display: block;
  }
}
@media (max-width: 767px) {
  .row:not(:first-of-type) {
    margin-top: 5%;
  }
  .row:first-of-type {
    margin-top: 0;
  }
  .row .col_2:not(:first-of-type), .row .col_3:not(:first-of-type), .row .col_4:not(:first-of-type), .row .col_5:not(:first-of-type), .row .col_6:not(:first-of-type) {
    margin-top: 5%;
  }
  .row.sp_col_2 {
    display: flex;
    flex-wrap: wrap;
  }
  .row.sp_col_2 .col_2, .row.sp_col_2 .col_3, .row.sp_col_2 .col_4, .row.sp_col_2 .col_5, .row.sp_col_2 .col_6 {
    width: 49%;
    margin-right: 2%;
  }
  .row.sp_col_2 .col_2:not(:first-child), .row.sp_col_2 .col_3:not(:first-child), .row.sp_col_2 .col_4:not(:first-child), .row.sp_col_2 .col_5:not(:first-child), .row.sp_col_2 .col_6:not(:first-child) {
    margin-top: 0;
  }
  .row.sp_col_2 .col_2:nth-child(2n), .row.sp_col_2 .col_3:nth-child(2n), .row.sp_col_2 .col_4:nth-child(2n), .row.sp_col_2 .col_5:nth-child(2n), .row.sp_col_2 .col_6:nth-child(2n) {
    margin-right: 0;
  }
  .row.sp_col_2 .col_2:nth-child(n+3), .row.sp_col_2 .col_3:nth-child(n+3), .row.sp_col_2 .col_4:nth-child(n+3), .row.sp_col_2 .col_5:nth-child(n+3), .row.sp_col_2 .col_6:nth-child(n+3) {
    margin-top: 2%;
  }
  .row.sp_col_2 .col_2:last-child, .row.sp_col_2 .col_3:last-child, .row.sp_col_2 .col_4:last-child, .row.sp_col_2 .col_5:last-child, .row.sp_col_2 .col_6:last-child {
    margin-right: 0;
  }
  .row.sp_col_3 {
    display: flex;
    flex-wrap: wrap;
  }
  .row.sp_col_3 .col_2, .row.sp_col_3 .col_3, .row.sp_col_3 .col_4, .row.sp_col_3 .col_5, .row.sp_col_3 .col_6 {
    width: 32%;
    margin-right: 2%;
  }
  .row.sp_col_3 .col_2:not(:first-child), .row.sp_col_3 .col_3:not(:first-child), .row.sp_col_3 .col_4:not(:first-child), .row.sp_col_3 .col_5:not(:first-child), .row.sp_col_3 .col_6:not(:first-child) {
    margin-top: 0;
  }
  .row.sp_col_3 .col_2:nth-child(3n), .row.sp_col_3 .col_3:nth-child(3n), .row.sp_col_3 .col_4:nth-child(3n), .row.sp_col_3 .col_5:nth-child(3n), .row.sp_col_3 .col_6:nth-child(3n) {
    margin-right: 0;
  }
  .row.sp_col_3 .col_2:nth-child(n+4), .row.sp_col_3 .col_3:nth-child(n+4), .row.sp_col_3 .col_4:nth-child(n+4), .row.sp_col_3 .col_5:nth-child(n+4), .row.sp_col_3 .col_6:nth-child(n+4) {
    margin-top: 2%;
  }
  .row.sp_col_3 .col_2:last-child, .row.sp_col_3 .col_3:last-child, .row.sp_col_3 .col_4:last-child, .row.sp_col_3 .col_5:last-child, .row.sp_col_3 .col_6:last-child {
    margin-right: 0;
  }
}
@media (min-width: 768px) {
  .row {
    display: flex;
    flex-wrap: wrap;
  }
  .row .col_2 {
    width: 48%;
    margin-right: 4%;
  }
  .row .col_2:nth-child(2n) {
    margin-right: 0;
  }
  .row .col_2:nth-child(n+3) {
    margin-top: 4%;
  }
  .row .col_2:last-child {
    margin-right: 0;
  }
  .row .col_3 {
    width: 32%;
    margin-right: 2%;
  }
  .row .col_3:nth-child(3n) {
    margin-right: 0;
  }
  .row .col_3:nth-child(n+4) {
    margin-top: 2%;
  }
  .row .col_3:last-child {
    margin-right: 0;
  }
  .row .col_4 {
    width: 23.5%;
    margin-right: 2%;
  }
  .row .col_4:nth-child(4n) {
    margin-right: 0;
  }
  .row .col_4:nth-child(n+5) {
    margin-top: 2%;
  }
  .row .col_4:last-child {
    margin-right: 0;
  }
  .row .col_5 {
    width: 18.4%;
    margin-right: 2%;
  }
  .row .col_5:nth-child(5n) {
    margin-right: 0;
  }
  .row .col_5:nth-child(n+6) {
    margin-top: 2%;
  }
  .row .col_5:last-child {
    margin-right: 0;
  }
  .row .col_6 {
    width: 15%;
    margin-right: 2%;
  }
  .row .col_6:nth-child(6n) {
    margin-right: 0;
  }
  .row .col_6:nth-child(n+7) {
    margin-top: 2%;
  }
  .row .col_6:last-child {
    margin-right: 0;
  }
  .row.reverse {
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .row.reverse .col_2 {
    width: 48%;
    margin-right: 4%;
  }
  .row.reverse .col_2:first-child {
    margin-right: 0;
  }
  .row.gap_row {
    gap: 20px 2%;
  }
  .row.gap_row .col_2 {
    width: 49%;
  }
  .row.gap_row .col_2, .row.gap_row .col_3, .row.gap_row .col_4, .row.gap_row .col_5, .row.gap_row .col_6 {
    margin: 0;
  }
  .row.gap_row.reverse .col_2 {
    width: 49%;
  }
}
.row {
  margin-bottom: calc(var(--main-size) * 3.125);
}
.row:last-child {
  margin-bottom: 0;
}
.row.cols_center {
  justify-content: center;
  gap: 2%;
}
.row.cols_center .btnstyle {
  width: 100%;
  max-width: 280px;
}
@media (max-width: 767px) {
  .row.cols_center .btnstyle {
    margin-left: auto;
    margin-right: auto;
  }
}
.row.cols_center > * {
  flex: 0 1 auto;
}

.box_border .row:last-child,
.box_bg .row:last-child {
  margin-bottom: 0;
}

/* header_wrap */
.header_wrap {
  position: sticky;
  top: 0;
  left: 0;
}
@media (min-width: 768px) {
  .header_wrap {
    display: flex;
    flex-direction: column-reverse;
  }
}

.header_btn,
.header {
  background: var(--darkblue_01);
  display: flex;
}

/* header_btn */
.header_btn {
  border-bottom: var(--px-1) solid var(--gray_02);
  height: var(--header_btn-h);
  position: relative;
}
.header_btn > li {
  display: flex;
  flex: 1 1 auto;
  width: 100%;
  background: var(--clinic-gradient-row);
}
@media (min-width: 768px) {
  .header_btn > li {
    flex: 0 0 auto;
    width: 200px;
  }
}
.header_btn > li a {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  border-right: var(--px-1) solid var(--gray_02);
  color: var(--white);
  font-size: calc(15 / var(--sp_calc));
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.3;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
@media (min-width: 768px) {
  .header_btn > li a {
    font-size: 17px;
    letter-spacing: 0.06em;
    line-height: 1;
  }
}
@media (min-width: 768px) {
  .header_btn > li ul.inner {
    display: none;
  }
}
@media (max-width: 767px) {
  .header_btn._seiyukai > li {
    background: none;
  }
  .header_btn._seiyukai > li > a {
    justify-content: flex-start;
    position: relative;
    padding-left: calc(18 / var(--sp_calc));
    background: var(--clinic-gradient-row);
  }
  .header_btn._seiyukai > li > a::after {
    position: absolute;
    content: "";
    display: block;
    background: url(../img/common/arrow-header_btn.svg) no-repeat center/contain;
    width: calc(12.67 / var(--sp_calc));
    height: calc(12.67 / var(--sp_calc));
    right: calc(11.67 / var(--sp_calc));
    top: 0;
    bottom: 0;
    margin: auto;
    left: auto;
    transition: transform 0.3s ease;
  }
  .header_btn._seiyukai > li ul.inner {
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--white);
    width: 100%;
    display: flex;
    transition: opacity 0.3s ease;
    opacity: 0;
    pointer-events: none;
  }
  .header_btn._seiyukai > li ul.inner li {
    flex: 1 1 auto;
    width: 100%;
    color: var(--color-clinic);
    font-weight: 500;
    font-size: calc(15 / var(--sp_calc));
    line-height: 1;
    letter-spacing: 0.06em;
    text-align: center;
  }
  .header_btn._seiyukai > li ul.inner li:first-child {
    border-right: var(--px-1) solid var(--gray_03);
  }
  .header_btn._seiyukai > li ul.inner li a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: calc(10 / var(--sp_calc));
    background: var(--white);
    border: none;
    color: var(--color-header_btn_sp);
    width: 100%;
    height: calc(46 / var(--sp_calc));
    padding: 0;
    position: relative;
  }
  .header_btn._seiyukai > li ul.inner li a::before, .header_btn._seiyukai > li ul.inner li a::after {
    content: "";
    background: var(--color-header_btn_sp);
  }
  .header_btn._seiyukai > li ul.inner li a::before {
    aspect-ratio: 1;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: cover;
    mask-size: cover;
    -webkit-mask-position: center;
    mask-position: center;
    background-position: center;
  }
  .header_btn._seiyukai > li ul.inner li a::after {
    position: absolute;
    width: calc(9 / var(--sp_calc));
    aspect-ratio: 1;
    -webkit-clip-path: polygon(100% 0, 0% 100%, 100% 100%);
            clip-path: polygon(100% 0, 0% 100%, 100% 100%);
    right: calc(5 / var(--sp_calc));
    bottom: calc(5 / var(--sp_calc));
    top: auto;
    left: auto;
  }
  .header_btn._seiyukai > li ul.inner li a .letterspacing {
    letter-spacing: -0.075em;
    margin-left: -0.05em;
  }
  .header_btn._seiyukai > li ul.inner li a .letterspacing-minus {
    letter-spacing: -0.2em;
    margin-right: 0.15em;
  }
  .header_btn._seiyukai > li ul.inner li._tel a {
    font-family: var(--roboto);
    font-size: calc(19 / var(--sp_calc));
    letter-spacing: 0.04em;
  }
  .header_btn._seiyukai > li ul.inner li._tel a::before {
    content: "";
    width: calc(20 / var(--sp_calc));
    height: calc(20 / var(--sp_calc));
    -webkit-mask-image: url(../img/icon/icon_tel.svg);
    mask-image: url(../img/icon/icon_tel.svg);
  }
  .header_btn._seiyukai > li ul.inner li._web a::before {
    content: "";
    width: calc(21 / var(--sp_calc));
    height: calc(21 / var(--sp_calc));
    -webkit-mask-image: url(../img/icon/icon_web.svg);
    mask-image: url(../img/icon/icon_web.svg);
  }
  .header_btn._seiyukai > li.onclick > a::after {
    transform: rotate(180deg);
  }
  .header_btn._seiyukai > li.onclick ul.inner {
    opacity: 1;
    pointer-events: all;
  }
}
.header_btn._takatsuki a, .header_btn._yao a, .header_btn._matsubara a {
  background: none;
}
.header_btn._takatsuki ul.inner, .header_btn._yao ul.inner, .header_btn._matsubara ul.inner {
  display: none;
}
.header_btn._takatsuki ._yao a, .header_btn._takatsuki ._matsubara a, .header_btn._yao ._takatsuki a, .header_btn._yao ._matsubara a, .header_btn._matsubara ._takatsuki a, .header_btn._matsubara ._yao a {
  background: #5B646E;
  transition: background-color 0.3s ease;
}
@media (hover: hover) and (min-width: 768px) {
  .header_btn._seiyukai .item {
    transition: opacity 0.3s ease;
  }
  .header_btn._seiyukai .item:hover {
    opacity: 0.8;
  }
}
@media (hover: hover) {
  .header_btn:not(._seiyukai) ._takatsuki a:hover,
  .header_btn:not(._seiyukai) ._yao a:hover,
  .header_btn:not(._seiyukai) ._matsubara a:hover {
    background: none;
  }
  .header_btn a {
    transition: opacity 0.3s ease;
  }
  .header_btn a:hover {
    opacity: 1;
  }
  .header_btn._takatsuki ._takatsuki, .header_btn._yao ._yao, .header_btn._matsubara ._matsubara {
    transition: opacity 0.3s ease;
  }
  .header_btn._takatsuki ._takatsuki:hover, .header_btn._yao ._yao:hover, .header_btn._matsubara ._matsubara:hover {
    opacity: 0.8;
  }
  .header_btn._seiyukai .item a {
    transition: opacity 0.3s ease;
  }
  .header_btn._seiyukai .item a:hover {
    opacity: 0.8;
  }
}

/* header */
.header {
  display: flex;
  align-items: center;
  height: var(--header-h);
  padding: calc(15.5 / var(--sp_calc)) 0 calc(15.5 / var(--sp_calc)) calc(12 / var(--sp_calc));
}
@media (min-width: 768px) {
  .header {
    padding: 0 0 0 24px;
  }
}
.header .header_logo {
  --gap: calc(8 / var(--sp_calc));
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--gap);
  line-height: 1;
}
@media (min-width: 768px) {
  .header .header_logo {
    --gap: clamp( 15.3px , calc( 15.3 / var(--clamp-pc)) , 22px);
  }
}
@media (min-width: 768px) {
  .header .header_logo .logo_seiyukai img {
    width: clamp(172.35px, 172.35 / var(--clamp-pc), 247.75px);
  }
}
.header .header_logo .logo_clinic {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--gap);
}
.header .header_logo .logo_clinic::before {
  content: "";
  display: block;
  flex: 0 0 auto;
  width: calc(0.5 / var(--sp_calc));
  height: calc(18 / var(--sp_calc));
  background: rgba(255, 255, 255, 0.6980392157);
}
@media (min-width: 768px) {
  .header .header_logo .logo_clinic::before {
    width: 1px;
    height: clamp(25px, 25 / var(--clamp-pc), 36px);
  }
}
.header .header_logo._seiyukai .logo_seiyukai img {
  width: calc(165.16 / var(--sp_calc));
}
@media (min-width: 768px) {
  .header .header_logo._seiyukai .logo_seiyukai img {
    width: 247.75px;
  }
}
@media (hover: hover) {
  .header .header_logo a:hover {
    opacity: 1;
  }
}
@media (max-width: 767px) {
  .header._takatsuki .logo_seiyukai img {
    width: calc(123.87 / var(--sp_calc));
  }
  .header._takatsuki .logo_clinic img {
    width: calc(116.77 / var(--sp_calc));
  }
  .header._yao .logo_seiyukai img, .header._matsubara .logo_seiyukai img {
    width: calc(116 / var(--sp_calc));
  }
  .header._yao .logo_clinic img, .header._matsubara .logo_clinic img {
    width: calc(129.44 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .header._takatsuki .logo_clinic img {
    width: clamp(162.33px, 162.33 / var(--clamp-pc), 233.53px);
  }
  .header._yao .logo_clinic img {
    width: clamp(190.94px, 190.94 / var(--clamp-pc), 283.53px);
  }
  .header._matsubara .logo_clinic img {
    width: clamp(190.94px, 197.24 / var(--clamp-pc), 283.53px);
  }
}
@media (max-width: 767px) {
  .header .main_nav {
    opacity: 0;
    pointer-events: none;
    position: fixed;
    left: 0;
    top: calc(var(--header-h) + var(--header_btn-h));
    width: var(--vw100);
    height: calc(100dvh - var(--header-h) - var(--header_btn-h) - var(--clinic_nav-h));
    transition: opacity 0.3s ease;
    z-index: 200;
    background: #363945;
    overscroll-behavior: none;
  }
  .header .main_nav.open {
    opacity: 1;
    pointer-events: all;
    overflow-y: overlay;
    overscroll-behavior: contain;
  }
}
@media (min-width: 768px) {
  .header .main_nav {
    margin-left: auto;
  }
}
@media (max-width: 767px) {
  .header._seiyukai .main_nav {
    height: calc(100dvh - var(--header-h) - var(--header_btn-h));
  }
}
.header .btn_tel .icon,
.header .sp_nav_toggle {
  flex: 0 0 auto;
  width: calc(54 / var(--sp_calc));
  aspect-ratio: 1;
}
.header .btn_tel {
  --txt-width: 231px;
  border-radius: 5px 0 0 5px;
}
.header .btn_tel a {
  text-decoration: none;
  display: flex;
}
.header .btn_tel .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--clinic-gradient-row);
}
.header .btn_tel .icon svg {
  width: calc(19.74 / var(--sp_calc));
  aspect-ratio: 1;
  fill: var(--white);
}
@media (max-width: 767px) {
  .header .btn_tel {
    margin-left: auto;
  }
  .header .btn_tel .txt {
    display: none;
  }
}
@media (min-width: 768px) {
  .header .btn_tel {
    position: fixed;
    right: calc(var(--txt-width) * -1);
    top: 187px;
    overflow: hidden;
    transition: right 0.3s ease;
    box-shadow: 0px 4px 20px 0px rgba(36, 37, 37, 0.2509803922);
  }
  .header .btn_tel.active {
    right: 0;
  }
  .header .btn_tel .icon {
    width: 73px;
  }
  .header .btn_tel .icon svg {
    width: 29px;
  }
  .header .btn_tel .txt {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding-left: 20px;
    gap: 5px;
    width: var(--txt-width);
    background: var(--beiju_01);
  }
  .header .btn_tel .telnum {
    background: var(--beiju_01);
    color: var(--color-clinic-logo);
    font-family: var(--roboto);
    font-weight: 500;
    font-size: 28px;
    margin-block: var(--leading-trim);
    line-height: 1;
    letter-spacing: 0.04em;
  }
  .header .btn_tel .reception_hours {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.06em;
  }
}
.header .sp_nav_toggle {
  background: #8796A5;
  color: #fff;
  padding-top: calc(10 / var(--sp_calc));
  position: relative;
  margin-left: auto;
}
.header .sp_nav_toggle .txt {
  display: block;
  font-family: var(--cor-garamond);
  font-weight: 600;
  font-size: calc(13 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
  padding-top: calc(2 / var(--sp_calc));
}
.header .sp_nav_toggle .line {
  position: absolute;
  background: var(--white);
  width: calc(34 / var(--sp_calc));
  height: calc(1 / var(--sp_calc));
  top: calc(31 / var(--sp_calc));
  left: 0;
  right: 0;
  margin: auto;
  transition: transform 0.3s ease;
}
.header .sp_nav_toggle .line + .line {
  top: calc(39 / var(--sp_calc));
}
.header .sp_nav_toggle.open .line {
  transform: rotate(18deg);
  transform-origin: 50% 50%;
  transform-origin: calc(4 / var(--sp_calc)) 0;
}
.header .sp_nav_toggle.open .line + .line {
  transform: rotate(-18deg);
}
@media (min-width: 768px) {
  .header .sp_nav_toggle {
    display: none;
  }
}
@media (hover: hover) {
  .header .sp_nav_toggle:hover {
    cursor: pointer;
  }
}
.header .btn_tel + .sp_nav_toggle {
  margin-left: 0;
}

@media (max-width: 767px) {
  .main_nav.open::-webkit-scrollbar {
    display: none;
  }
}

.main_nav_menu {
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  /* SP */
  /* PC */
}
.main_nav_menu a {
  text-decoration: none;
  font-feature-settings: "palt";
}
.main_nav_menu a .kerning {
  font-feature-settings: normal;
}
.main_nav_menu .item._btn a,
.main_nav_menu .item .navlink a, .main_nav_menu .item > a {
  color: #fff;
}
@media (max-width: 767px) {
  .main_nav_menu {
    padding: calc(14 / var(--sp_calc)) calc(30 / var(--sp_calc)) calc(env(safe-area-inset-bottom) + 40 / var(--sp_calc));
  }
  .main_nav_menu .item {
    /* _clinic */
  }
  .main_nav_menu .item .navlink a {
    font-size: calc(18 / var(--sp_calc));
    letter-spacing: 0.04em;
    line-height: 1;
    display: flex;
    align-items: center;
    padding: calc(16 / var(--sp_calc)) calc(30 / var(--sp_calc)) calc(16 / var(--sp_calc)) calc(6 / var(--sp_calc));
    border-bottom: calc(1 / var(--sp_calc)) solid var(--gray_02);
  }
  .main_nav_menu .item .navlink.onclick a {
    border-bottom-color: transparent;
  }
}
@media (max-width: 767px) and (hover: hover) {
  .main_nav_menu .item:not(._btn):not(._clinic_item) .navlink {
    transition: var(--transition-hover);
  }
  .main_nav_menu .item:not(._btn):not(._clinic_item) .navlink:hover {
    background-color: var(--beiju_03);
  }
  .main_nav_menu .item:not(._btn):not(._clinic_item) .navlink:hover a {
    opacity: 1;
  }
}
@media (max-width: 767px) {
  .main_nav_menu .item .navlink,
  .main_nav_menu .item .navlink a {
    display: block;
    position: relative;
  }
  .main_nav_menu .item .navlink::before, .main_nav_menu .item .navlink::after,
  .main_nav_menu .item .navlink a::before,
  .main_nav_menu .item .navlink a::after {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .main_nav_menu .item .navlink::before {
    width: calc(22 / var(--sp_calc));
    height: calc(22 / var(--sp_calc));
    border-radius: 50%;
    background: var(--gray_02);
    right: calc(4 / var(--sp_calc));
  }
  .main_nav_menu .item .navlink a::before, .main_nav_menu .item .navlink a::after {
    width: calc(10 / var(--sp_calc));
    height: calc(1 / var(--sp_calc));
    background: var(--beiju_01);
    right: calc(10 / var(--sp_calc));
    transition: var(--transition-hover);
  }
  .main_nav_menu .item .navlink a::after {
    transform: rotate(90deg);
  }
  .main_nav_menu .item .navlink.onclick a::after {
    transform: rotate(0);
  }
  .main_nav_menu .item._facility a::before {
    background: url(../img/common/arrow_nav-sp.svg) no-repeat center center/contain;
    width: calc(8 / var(--sp_calc));
    height: calc(8 / var(--sp_calc));
  }
  .main_nav_menu .item._facility a::after {
    display: none;
  }
  .main_nav_menu .item .title {
    display: none;
  }
  .main_nav_menu .item .submenu-wrap {
    display: none;
    border-bottom: calc(1 / var(--sp_calc)) solid var(--gray_02);
  }
  .main_nav_menu .item .submenu-wrap .nav_title {
    background: #53595F;
    border-left: calc(3 / var(--sp_calc)) solid var(--beiju_03);
    color: var(--white);
    font-size: calc(16 / var(--sp_calc));
    line-height: 1;
    letter-spacing: 0.04em;
    padding: calc(13 / var(--sp_calc)) calc(20 / var(--sp_calc)) calc(13 / var(--sp_calc)) calc(15 / var(--sp_calc));
    position: relative;
  }
  .main_nav_menu .item .submenu-wrap .nav_title::before, .main_nav_menu .item .submenu-wrap .nav_title::after {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    right: calc(10 / var(--sp_calc));
    margin: auto;
    width: calc(10 / var(--sp_calc));
    height: calc(1 / var(--sp_calc));
    background: var(--beiju_01);
  }
  .main_nav_menu .item .submenu-wrap .nav_title::after {
    transform: rotate(90deg);
    transition: var(--transition-hover);
  }
  .main_nav_menu .item .submenu-wrap .nav_title.onclick::after {
    transform: rotate(0);
  }
}
@media (max-width: 767px) and (hover: hover) {
  .main_nav_menu .item .submenu-wrap .nav_title:hover {
    cursor: pointer;
  }
}
@media (max-width: 767px) {
  .main_nav_menu .item .submenu_inner {
    display: block;
    padding-bottom: var(--px-16);
  }
  .main_nav_menu .item .flex2,
  .main_nav_menu .item .flex1 {
    box-shadow: 0px calc(4 / var(--sp_calc)) calc(20 / var(--sp_calc)) 0px rgba(36, 37, 37, 0.2509803922);
  }
  .main_nav_menu .item .flexbox .sub-menu {
    display: none;
  }
  .main_nav_menu .item .flexbox .sub-menu + .nav_title,
  .main_nav_menu .item .flexbox > div + div {
    margin-top: calc(8 / var(--sp_calc));
  }
  .main_nav_menu .item .sub-menu {
    background: var(--white);
    display: block;
    padding: calc(8 / var(--sp_calc)) calc(20 / var(--sp_calc)) calc(20 / var(--sp_calc));
  }
  .main_nav_menu .item .sub-menu a {
    display: block;
    color: var(--main_txt);
    font-size: calc(15 / var(--sp_calc));
    line-height: 1;
    border-bottom: calc(1 / var(--sp_calc)) solid var(--gray_01);
    padding: calc(13 / var(--sp_calc)) calc(20 / var(--sp_calc)) calc(13 / var(--sp_calc)) calc(8 / var(--sp_calc));
    position: relative;
  }
  .main_nav_menu .item .sub-menu a::after {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    right: calc(4 / var(--sp_calc));
    margin: auto;
    background: url(../img/common/arrow_subnav-sp.svg) no-repeat center center/contain;
    width: calc(10 / var(--sp_calc));
    height: calc(10 / var(--sp_calc));
  }
  .main_nav_menu .item .sub-menu br {
    display: none;
  }
  .main_nav_menu .item._professionals {
    margin-top: calc(20 / var(--sp_calc));
  }
  .main_nav_menu .item._professionals .btn {
    border-bottom: calc(1 / var(--sp_calc)) solid var(--white);
  }
  .main_nav_menu .item._recruit {
    margin-bottom: calc(20 / var(--sp_calc));
  }
  .main_nav_menu .item._btn .btn {
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
  }
  .main_nav_menu .item._btn .btn a {
    padding: calc(20 / var(--sp_calc)) calc(30 / var(--sp_calc)) calc(20 / var(--sp_calc)) calc(10 / var(--sp_calc));
    border-bottom: none;
  }
  .main_nav_menu .item._btn._professionals .btn {
    background-image: url(../img/common/nav_btn_professionals_bg_sp.jpg);
  }
  .main_nav_menu .item._btn._recruit .btn {
    background-image: url(../img/common/nav_btn_recruit_bg_sp.jpg);
  }
  .main_nav_menu .item._btn .submenu-wrap {
    border-bottom: none;
  }
  .main_nav_menu .item._btn .sub-menu {
    margin-bottom: 0;
  }
  .main_nav_menu .item._clinic_item {
    display: flex;
  }
  .main_nav_menu .item._clinic_item._takatsuki {
    --clinic-color: var(--red_01);
  }
  .main_nav_menu .item._clinic_item._yao {
    --clinic-color: var(--orange_01);
  }
  .main_nav_menu .item._clinic_item._matsubara {
    --clinic-color: var(--blue_02);
  }
  .main_nav_menu .item._clinic_item + ._clinic_item {
    margin-top: calc(10 / var(--sp_calc));
  }
  .main_nav_menu .item._clinic_item a {
    color: var(--clinic-color);
  }
}
@media (max-width: 767px) and (hover: hover) {
  .main_nav_menu .item._clinic_item a:hover {
    opacity: 0.7;
  }
}
@media (max-width: 767px) {
  .main_nav_menu .item._clinic_item .img {
    flex: 0 0 auto;
    width: calc(145 / var(--sp_calc));
  }
  .main_nav_menu .item._clinic_item .txt {
    flex: 1 1 auto;
    background: var(--white);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 calc(16 / var(--sp_calc));
  }
  .main_nav_menu .item._clinic_item .name {
    color: var(--clinic-color);
    font-size: calc(18 / var(--sp_calc));
    line-height: 1;
    letter-spacing: 0.08em;
    padding-bottom: calc(6 / var(--sp_calc));
    border-bottom: calc(1 / var(--sp_calc)) solid currentColor;
    position: relative;
    text-align: left;
  }
  .main_nav_menu .item._clinic_item .name::after {
    position: absolute;
    content: "";
    background: currentColor;
    -webkit-mask-image: url(../img/common/arrow_subnav-sp.svg);
    mask-image: url(../img/common/arrow_subnav-sp.svg);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: cover;
    mask-size: cover;
    width: calc(10 / var(--sp_calc));
    height: calc(10 / var(--sp_calc));
    top: 0;
    bottom: calc(4 / var(--sp_calc));
    right: calc(4 / var(--sp_calc));
    margin: auto;
  }
  .main_nav_menu .item._clinic_item .telnum {
    color: var(--clinic-color);
    font-family: var(--roboto);
    font-weight: 500;
    font-size: calc(21 / var(--sp_calc));
    margin-block: var(--leading-trim);
    line-height: 1;
    letter-spacing: 0.04em;
    margin-top: calc(10 / var(--sp_calc));
  }
  .main_nav_menu .item._clinic_item .reception_hours {
    color: var(--main_txt);
    font-family: var(--main-family);
    font-weight: var(--main-family-weight);
    font-size: calc(13 / var(--sp_calc));
    line-height: 1;
    letter-spacing: 0.06em;
    margin-top: calc(6 / var(--sp_calc));
  }
  .main_nav_menu .item._clinic_item._takatsuki .name,
  .main_nav_menu .item._clinic_item._takatsuki .telnum {
    color: var(--red_01);
  }
}
@media (min-width: 768px) {
  .main_nav_menu {
    height: 100%;
    display: flex;
    position: relative;
  }
  .main_nav_menu .item {
    display: flex;
    align-items: center;
    justify-content: center;
    height: var(--header-h);
    position: relative;
    /* pc sub-menu */
  }
  .main_nav_menu .item .navlink {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
  }
  .main_nav_menu .item .navlink a, .main_nav_menu .item > a {
    flex: 0 0 auto;
    position: relative;
    overflow: hidden;
  }
  .main_nav_menu .item .navlink a .kerning, .main_nav_menu .item > a .kerning {
    letter-spacing: -0.1em;
  }
  .main_nav_menu .item .navlink a::after, .main_nav_menu .item > a::after {
    position: absolute;
    content: "";
    background: var(--beiju_02);
    width: 100%;
    height: 1px;
    bottom: 0;
    right: 100%;
    transition: right 0.3s ease;
  }
  .main_nav_menu .item:not(._btn) .navlink {
    position: relative;
  }
  .main_nav_menu .item:not(._btn) .navlink::before {
    position: absolute;
    content: "";
    background: var(--white);
    opacity: 0.3;
    width: 1px;
    height: 18px;
    top: 0;
    bottom: 0;
    left: -0.5px;
    margin: auto;
  }
  .main_nav_menu .item:not(._btn):first-child .navlink::before {
    display: none;
  }
}
@media (min-width: 768px) and (hover: hover) {
  .main_nav_menu .item .navlink a:hover {
    opacity: 1;
  }
  .main_nav_menu .item:hover {
    opacity: 1;
  }
  .main_nav_menu .item:hover .navlink a::after {
    right: 0;
  }
}
@media (min-width: 768px) {
  .main_nav_menu .item._txt .navlink {
    padding: 0 clamp(13.33px, 13.33 / var(--clamp-pc), 26px);
  }
  .main_nav_menu .item._btn {
    background: var(--beiju_04);
    width: clamp(146px, 146 / var(--clamp-pc), 177px);
    transition: background-color 0.3s ease;
    align-items: unset;
    justify-content: unset;
  }
  .main_nav_menu .item._btn .btn {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .main_nav_menu .item._btn .btn a::after {
    display: none;
  }
}
@media (min-width: 768px) and (hover: hover) {
  .main_nav_menu .item._btn:hover {
    opacity: 1;
    background: var(--beiju_03);
  }
  .main_nav_menu .item._btn:hover .btn {
    cursor: pointer;
  }
}
@media (min-width: 768px) {
  .main_nav_menu .item._btn:not(._recruit) {
    border-right: 1px solid var(--beiju_02);
  }
  .main_nav_menu .item._sp {
    display: none;
  }
  .main_nav_menu .item .submenu-wrap {
    opacity: 0;
    transition: var(--transition-hover);
    pointer-events: none;
    top: 83px;
    position: absolute;
    background: #1D2333;
    box-shadow: 0px 0px 20px 0px rgba(28, 30, 37, 0.6509803922);
  }
  .main_nav_menu .item .submenu-wrap .title {
    display: flex;
    justify-content: center;
    flex-direction: column;
    gap: 13px;
    height: 100px;
    padding-left: 30px;
    background: var(--blue_02);
    color: var(--white);
    text-shadow: 0px 4px 12px rgba(29, 27, 40, 0.2588235294);
    margin: 0;
  }
  .main_nav_menu .item .submenu-wrap .title .jp {
    font-weight: 600;
    font-size: 23px;
    line-height: 1;
    letter-spacing: 0.08em;
  }
  .main_nav_menu .item .submenu-wrap .title .en {
    font-family: var(--cor-garamond);
    font-weight: 600;
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.03em;
  }
  .main_nav_menu .item .submenu-wrap .submenu_inner {
    padding: 20px 40px;
  }
  .main_nav_menu .item .submenu-wrap .submenu_inner.flexbox {
    display: flex;
    gap: 30px;
  }
  .main_nav_menu .item .submenu-wrap .submenu_inner .flex2 {
    width: 414px;
  }
  .main_nav_menu .item .submenu-wrap .submenu_inner .flex2 .sub-menu {
    -moz-column-count: 2;
         column-count: 2;
  }
  .main_nav_menu .item .submenu-wrap .nav_title {
    color: var(--beiju_03);
    font-size: 20px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    padding-bottom: 8px;
    border-bottom: 1px solid currentColor;
    margin-bottom: 12px;
  }
  .main_nav_menu .item .submenu-wrap .sub-menu + .nav_title {
    margin-top: 30px;
  }
  .main_nav_menu .item .submenu-wrap .sub-menu {
    gap: 4px 12px;
  }
  .main_nav_menu .item .submenu-wrap .sub-menu li {
    padding: 2px 0;
  }
  .main_nav_menu .item .submenu-wrap .sub-menu a {
    --fontsize: 18px;
    --lineheight: 1.5;
    display: inline-block;
    font-size: var(--fontsize);
    line-height: var(--lineheight);
    letter-spacing: 0.02em;
    position: relative;
    padding-left: 14px;
    transition: opacity 0.3s ease;
  }
  .main_nav_menu .item .submenu-wrap .sub-menu a::before {
    position: absolute;
    content: "";
    display: block;
    left: 0;
    top: calc(var(--fontsize) * var(--lineheight) / 2); /* 14px */
    width: 6px;
    height: 2px;
    background: var(--beiju_02);
  }
}
@media (min-width: 768px) and (hover: hover) {
  .main_nav_menu .item .submenu-wrap .sub-menu a:hover {
    opacity: 0.7;
  }
}
@media (min-width: 768px) {
  .main_nav_menu .item .submenu-wrap a {
    color: var(--white);
  }
  .main_nav_menu .item._clinic .submenu-wrap, .main_nav_menu .item._activity .submenu-wrap {
    width: 704px;
    left: -200px;
  }
  .main_nav_menu .item._clinic .sub-menu, .main_nav_menu .item._activity .sub-menu {
    display: block grid;
    grid-template-columns: repeat(3, 1fr);
  }
  .main_nav_menu .item._clinic .submenu-wrap {
    left: -200px;
  }
  .main_nav_menu .item._clinic .title {
    background-image: url(../img/common/nav_title_bg_clinic.jpg);
  }
  .main_nav_menu .item._activity .title {
    background-image: url(../img/common/nav_title_bg_activity.jpg);
  }
  .main_nav_menu .item._diseases .submenu-wrap {
    width: 740px;
    left: -300px;
  }
  .main_nav_menu .item._diseases .flex1 {
    width: 216px;
  }
  .main_nav_menu .item._diseases .title {
    background-image: url(../img/common/nav_title_bg_disease.jpg);
  }
  .main_nav_menu .item._surgery .submenu-wrap {
    width: 789px;
    left: -400px;
  }
  .main_nav_menu .item._surgery .flex1 {
    width: 265px;
  }
  .main_nav_menu .item._surgery .title {
    background-image: url(../img/common/nav_title_bg_surgery.jpg);
  }
  .main_nav_menu .item._professionals .submenu-wrap, .main_nav_menu .item._recruit .submenu-wrap {
    width: 280px;
  }
  .main_nav_menu .item._professionals .submenu-wrap .sub-menu a, .main_nav_menu .item._recruit .submenu-wrap .sub-menu a {
    --fontsize: calc(21.6px);
    color: var(--beiju_02);
  }
  .main_nav_menu .item._professionals .submenu-wrap {
    left: -51px;
  }
  .main_nav_menu .item._professionals .title {
    background-image: url(../img/common/nav_title_bg_professionals.jpg);
  }
  .main_nav_menu .item._recruit .submenu-wrap {
    right: 0;
  }
  .main_nav_menu .item._recruit .title {
    background-image: url(../img/common/nav_title_bg_recruit.jpg);
  }
  .main_nav_menu .item.active .submenu-wrap {
    opacity: 1;
    pointer-events: all;
  }
  .main_nav_menu .item._clinic_item {
    display: none;
  }
}

@media (min-width: 768px) {
  .header_wrap {
    height: calc(var(--header-h) + var(--header_btn-h));
    justify-content: flex-end;
  }
  .header_wrap .header {
    transition: var(--transition-hover);
  }
  .header_wrap .main_nav_menu .item {
    transition: var(--transition-hover);
  }
  .header_wrap.is-sticky .header {
    height: var(--header_min-h);
  }
  .header_wrap.is-sticky .main_nav_menu .item {
    height: var(--header_min-h);
  }
  .header_wrap.is-sticky .main_nav_menu .item .submenu-wrap {
    top: 53px;
  }
}
.clinic_nav_wrap {
  --btn-web-reserve-width: calc( 97.5 / var(--sp_calc));
  background: var(--clinic_nav-gradient);
}
@media (max-width: 767px) {
  .clinic_nav_wrap {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    display: flex;
  }
}
@media (min-width: 768px) {
  .clinic_nav_wrap {
    position: sticky;
    top: calc(var(--header_min-h) + var(--header_btn-h));
    left: 0;
    height: var(--clinic_nav-h);
    background: none;
  }
}
.clinic_nav_wrap a {
  color: var(--white);
  font-family: var(--title-family);
  font-weight: 600;
  text-decoration: none;
  text-align: center;
}
@media (max-width: 767px) {
  .clinic_nav_wrap a {
    font-size: calc(13 / var(--sp_calc));
    line-height: 1;
    letter-spacing: 0.03em;
  }
}
@media (min-width: 768px) {
  .clinic_nav_wrap a {
    font-weight: 500;
  }
}

.clinic_nav {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .clinic_nav {
    max-width: 1419px;
  }
}
.clinic_nav li {
  flex: 1 1 auto;
  position: relative;
}
@media (min-width: 768px) {
  .clinic_nav li {
    flex: 0 0 auto;
  }
}
@media (max-width: 767px) {
  .clinic_nav li {
    width: 100%;
  }
  .clinic_nav li._pc {
    display: none;
  }
  .clinic_nav li._pc_icon a {
    padding: 0;
    justify-content: center;
    line-height: 1.5;
  }
  .clinic_nav li._pc_icon .svg-icons {
    display: none;
  }
}
@media (max-width: 767px) {
  .clinic_nav .nav-item._pc {
    display: none;
  }
  .clinic_nav .nav-item._pc_icon .svg-icons {
    display: none;
  }
}
.clinic_nav a {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: calc(9.5 / var(--sp_calc)) 0;
  width: 100%;
  height: var(--clinic_nav-h);
  position: relative;
  transition: background-color 0.3s ease;
}
@media (min-width: 768px) {
  .clinic_nav a {
    padding: 18px 0 11px;
    width: clamp(200px, 200 / var(--clamp-pc), 236px);
    font-size: 20px;
    letter-spacing: 0.08em;
  }
}
.clinic_nav a .svg-icons {
  fill: var(--white);
  width: auto;
  height: calc(20 / var(--sp_calc));
}
@media (min-width: 768px) {
  .clinic_nav a .svg-icons {
    height: 28px;
  }
}
.clinic_nav a::before, .clinic_nav a::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: var(--px-1);
  height: calc(48 / var(--sp_calc));
  background: #fff;
  opacity: 0.3;
}
@media (min-width: 768px) {
  .clinic_nav a::before, .clinic_nav a::after {
    height: 64px;
  }
}
.clinic_nav a::after {
  display: none;
  left: auto;
  right: 0;
}
.clinic_nav li:last-child a::after {
  display: block;
}
@media (max-width: 767px) {
  .clinic_nav .nav-item._sp_noborder_left a::before {
    display: none;
  }
  .clinic_nav .nav-item._sp_noborder_right a::after {
    display: none;
  }
}
@media (hover: hover) {
  .clinic_nav a:hover {
    opacity: 1;
    background: var(--color-clinic_nav-hover);
  }
}
@media (min-width: 768px) {
  .clinic_nav {
    position: relative;
  }
  .clinic_nav::before {
    position: absolute;
    content: "";
    height: 100%;
    width: max(var(--vw100), var(--container-width) + var(--container-padding-size) * 2px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--clinic_nav-gradient);
  }
  .clinic_nav a {
    transition: var(--transition-hover);
  }
  .clinic_nav a::before, .clinic_nav a::after {
    transition: var(--transition-hover);
  }
  .clinic_nav .svg-icons {
    transition: var(--transition-hover);
  }
  .clinic_nav_wrap.is-sticky .clinic_nav a {
    justify-content: center;
    padding: 0;
    height: var(--clinic_nav_min-h);
  }
  .clinic_nav_wrap.is-sticky .clinic_nav a::before, .clinic_nav_wrap.is-sticky .clinic_nav a::after {
    height: 35px;
  }
  .clinic_nav_wrap.is-sticky .clinic_nav .svg-icons {
    display: none;
    overflow: hidden;
  }
  .clinic_nav_wrap.is-sticky .clinic_nav .svg-icons > * {
    overflow: hidden;
  }
}

@media (max-width: 767px) {
  .clinic_nav_wrap._takatsuki .clinic_nav {
    width: calc(100% - var(--btn-web-reserve-width) / var(--sp_calc));
  }
  .clinic_nav_wrap._takatsuki .clinic_nav ._pc_takatsuki {
    display: none;
  }
}

.btn_webreserve {
  --icon-width: 100%;
  --svg-width: calc( 26 / var(--sp_calc));
}
@media (min-width: 768px) {
  .btn_webreserve {
    --icon-width: 43px;
    --svg-width: 24px;
  }
}
.btn_webreserve a {
  text-decoration: none;
  color: var(--white);
}
@media (hover: hover) {
  .btn_webreserve a:hover {
    opacity: 1;
  }
}
.btn_webreserve .icon {
  width: var(--icon-width);
  height: var(--svg-width);
  position: relative;
}
.btn_webreserve .icon::before, .btn_webreserve .icon::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
}
.btn_webreserve .icon::after {
  background: url(../img/icon/icon_web_reserve_sp.svg) no-repeat center center/contain;
  background-size: var(--svg-width);
  left: 0;
  top: 0;
}
@media (max-width: 767px) {
  .btn_webreserve {
    flex: 0 0 auto;
    width: var(--btn-web-reserve-width);
    background: linear-gradient(180deg, #D1AA68 -32.58%, #603F08 100.91%);
  }
  .btn_webreserve a {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: calc(9.5 / var(--sp_calc)) 0;
    width: 100%;
    height: var(--clinic_nav-h);
  }
  .btn_webreserve .icon {
    transform: translateY(calc(2.5 / var(--sp_calc) * -1));
  }
}
@media (max-width: 767px) and (hover: hover) {
  .btn_webreserve a:hover {
    background: var(--beiju_03);
  }
}
@media (min-width: 768px) {
  .btn_webreserve {
    position: fixed;
    top: 270px;
    right: 0;
    border-radius: 5px 0 0 5px;
    border: 1px solid var(--beiju_02);
    border-right: none;
    overflow: hidden;
    box-shadow: 0px 4px 20px 0px rgba(36, 37, 37, 0.25);
  }
  .btn_webreserve a {
    background: linear-gradient(180deg, #D1AA68 -32.58%, #603F08 100.91%);
    width: 73px;
    height: 186px;
    display: flex;
    padding: 10px 20px 15px 20px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
    font-size: 19px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.08em;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .btn_webreserve a::before {
    content: "";
    display: block;
    width: 297px;
    aspect-ratio: 1;
    border-radius: 50%;
    position: absolute;
    left: 50%;
    top: 30px;
    background: linear-gradient(180deg, #C8A975 0%, #755116 61.54%);
    transform: translateX(-50%);
    transition: top 0.3s ease;
  }
  .btn_webreserve .icon,
  .btn_webreserve .txt {
    position: relative;
  }
  .btn_webreserve .icon {
    width: var(--icon-width);
    height: var(--icon-width);
  }
  .btn_webreserve .icon::before, .btn_webreserve .icon::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
  }
  .btn_webreserve .icon::before {
    width: var(--icon-width);
    height: var(--icon-width);
    background: linear-gradient(0deg, #18191B 0%, #4C5058 100%);
    transition: width 0.3s ease, height 0.3s ease;
  }
  .btn_webreserve .icon::after {
    width: 48px;
    height: 48px;
    background: linear-gradient(180deg, #A23C65 0%, #601C30 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
  }
  .btn_webreserve .icon .icon-inner {
    width: var(--icon-width);
    height: var(--icon-width);
    display: block;
    position: relative;
    z-index: 1;
  }
  .btn_webreserve .icon .icon-inner::before {
    position: absolute;
    content: "";
    width: var(--icon-width);
    height: var(--icon-width);
    top: 50%;
    left: 50%;
    transform: translate(-47%, -50%);
    background: url(../img/icon/icon_web_reserve.svg) no-repeat center center;
    background-size: auto var(--svg-width);
  }
  .btn_webreserve .txt {
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
@media (min-width: 768px) and (hover: hover) {
  .btn_webreserve a:hover::before {
    top: -55px;
  }
  .btn_webreserve a:hover .icon::before {
    width: 48px;
    height: 48px;
  }
  .btn_webreserve a:hover .icon::after {
    opacity: 1;
  }
}

/* mainimage */
.sec_mainimage {
  --height: calc( 710 / var(--sp_calc));
  --img-height: calc( 509 / var(--sp_calc));
  --icl-bottom: calc( 81 / var(--sp_calc));
  --pagination-bottom: calc( 162 / var(--sp_calc) * -1);
  overflow: hidden;
  position: relative;
}
.sec_mainimage._seiyukai {
  --height: calc( 750 / var(--sp_calc));
  --img-height: calc( 565 / var(--sp_calc));
}
@media (max-width: 767px) {
  .sec_mainimage._seiyukai {
    --icl-bottom: calc( 65 / var(--sp_calc));
    --pagination-bottom: calc( 165 / var(--sp_calc) * -1);
  }
}
@media (min-width: 768px) {
  .sec_mainimage {
    --height: calc( 100svh - var(--header-h) - var(--header_btn-h) - var(--clinic_nav-h));
    --min-height: calc( 720px - var(--header-h) - var(--header_btn-h) - var(--clinic_nav-h));
    --icl-bottom: 20px;
    --pagination-bottom: 14px;
  }
  .sec_mainimage._seiyukai {
    --height: calc( 100svh - var(--header-h) - var(--header_btn-h));
    --min-height: calc( 720px - var(--header-h) - var(--header_btn-h));
    --icl-bottom: 60px;
  }
}
.sec_mainimage .mainimage.splide {
  visibility: visible;
}
@media (max-width: 767px) {
  .sec_mainimage::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: linear-gradient(180deg, #0C4685 0%, #072B52 100%);
  }
  .sec_mainimage .mainimage_wrap {
    padding-bottom: calc(201 / var(--sp_calc));
    height: var(--height);
  }
}
@media (min-width: 768px) {
  .sec_mainimage {
    background: #14212D;
  }
  .sec_mainimage .mainimage_wrap {
    width: calc(var(--vw100) + clamp(140px, 140 / var(--clamp-pc), 210px));
  }
}
@media (min-width: 768px) and (max-width: 1280px) {
  .sec_mainimage .mainimage_wrap {
    width: calc(var(--container-width) + var(--container-padding-size) * 2px + 140px);
  }
}
.sec_mainimage .bnr_icl {
  position: absolute;
  right: 0;
  bottom: var(--icl-bottom);
  z-index: 100;
  background: #18191B;
  color: var(--beiju_02);
  text-decoration: none;
  display: flex;
  height: calc(120 / var(--sp_calc));
  width: 100%;
  box-shadow: 0px var(--px-4) var(--px-20) 0px rgba(28, 30, 37, 0.6509803922);
  transition: var(--transition-hover);
}
.sec_mainimage .bnr_icl .img {
  overflow: hidden;
}
.sec_mainimage .bnr_icl .img img {
  transition: var(--transition-hover);
  width: calc(150 / var(--sp_calc));
  height: calc(120 / var(--sp_calc));
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .sec_mainimage .bnr_icl .img img {
    width: 160px;
    height: 130px;
  }
}
.sec_mainimage .bnr_icl .txt {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  font-family: var(--title-family);
  font-weight: 600;
  font-size: calc(28 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.06em;
  padding-left: calc(15 / var(--sp_calc));
  position: relative;
}
.sec_mainimage .bnr_icl .txt .flexbox {
  flex-direction: column;
  gap: var(--px-10);
}
.sec_mainimage .bnr_icl .txt .sub,
.sec_mainimage .bnr_icl .txt .min {
  display: block;
}
.sec_mainimage .bnr_icl .txt .sub {
  font-size: calc(16 / var(--sp_calc));
  letter-spacing: 0.06em;
}
.sec_mainimage .bnr_icl .txt .min {
  font-size: calc(15 / var(--sp_calc));
  letter-spacing: 0.06em;
}
.sec_mainimage .bnr_icl .txt::after {
  position: absolute;
  content: "";
  display: block;
  background: var(--beiju_03);
  -webkit-clip-path: polygon(100% 0, 0% 100%, 100% 100%);
          clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  width: var(--px-14);
  aspect-ratio: 1;
  right: var(--px-5);
  bottom: var(--px-5);
  transition: var(--transition-hover);
}
@media (min-width: 768px) {
  .sec_mainimage .bnr_icl {
    height: 130px;
    width: 452px;
  }
  .sec_mainimage .bnr_icl .txt {
    font-size: 32px;
    padding-left: 30px;
  }
  .sec_mainimage .bnr_icl .txt .sub {
    font-size: 20px;
  }
  .sec_mainimage .bnr_icl .txt .min {
    font-size: 18px;
  }
}
@media (hover: hover) {
  .sec_mainimage .bnr_icl:hover {
    opacity: 1;
    background: #3C3F44;
  }
  .sec_mainimage .bnr_icl:hover .img img {
    transform: scale(1.1);
  }
  .sec_mainimage .bnr_icl:hover .txt::after {
    bottom: var(--px-2);
    right: var(--px-2);
  }
}

.mainimage img {
  width: 100%;
}
@media (max-width: 767px) {
  .mainimage img {
    height: var(--img-height);
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media (min-width: 768px) {
  .mainimage {
    height: var(--height);
    min-height: var(--min-height);
  }
  .mainimage img {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: top center;
       object-position: top center;
    height: var(--height);
    min-height: var(--min-height);
  }
}
.mainimage picture {
  display: block;
  overflow: hidden;
  width: 100%;
  rotate: 0.0001deg;
  filter: blur(0px);
}
.mainimage .splide__slide img {
  will-change: transform;
  transition: all 1.4s linear;
  transform-origin: top center;
  backface-visibility: hidden;
  rotate: 0.0001deg;
  filter: blur(0px);
}
.mainimage .splide__slide.is-active img {
  transition: transform 12s cubic-bezier(0.77, 0, 0.175, 1), filter 1.4s linear;
  rotate: 0.0001deg;
  filter: blur(0px);
  transform: scale(1.1);
  transition-delay: 0s;
}
.mainimage .splide__slide img {
  width: 100%;
}
@media (min-width: 768px) {
  .mainimage picture {
    background-color: #B6B6B6;
  }
  .mainimage .splide__slide img {
    mix-blend-mode: multiply;
  }
  .mainimage.is-initialized .splide__slide.is-prev img {
    filter: blur(0px) grayscale(100%);
  }
  .mainimage.is-initialized .splide__slide.is-active img {
    filter: none;
    mix-blend-mode: normal;
  }
}
.mainimage .slide_1 img {
  -o-object-position: right center;
     object-position: right center;
}
.mainimage .splide__pagination {
  margin: 0;
  bottom: var(--pagination-bottom);
  left: calc(20 / var(--sp_calc));
  right: auto;
  padding: 0;
  position: absolute;
  z-index: 1;
}
.mainimage .splide__pagination li + li {
  margin-left: var(--px-1);
}
@media (min-width: 768px) {
  .mainimage .splide__pagination {
    left: 42px;
  }
}
.mainimage .splide__pagination__page {
  position: relative;
  width: var(--px-24);
  height: var(--px-24);
  background: none;
  border: none;
  margin: 0;
  padding: 0;
  cursor: pointer;
  transform: rotate(90deg);
}
.mainimage .splide__pagination__page .dot {
  position: absolute;
  top: 50%;
  left: 50%;
  width: var(--px-8);
  height: var(--px-8);
  background: #ffffff;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  opacity: 0.5;
}
.mainimage .splide__pagination__page.is-active .dot {
  opacity: 1;
}
.mainimage .progress-ring {
  transform: scale(-1, 1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
}
.mainimage .progress-ring__bg {
  fill: none;
}
.mainimage .progress-ring__bar {
  fill: none;
  stroke-dasharray: 62.8; /* 2πr = 2*π*10 */
  stroke-dashoffset: 0;
  transition: stroke-dashoffset linear;
}
.mainimage .splide__pagination__page.is-active .progress-ring__bar {
  stroke: #ffffff;
  stroke-dashoffset: 62.8;
}
.mainimage .splide__pagination__page.is-active .progress-ring__bg {
  stroke: rgba(255, 255, 255, 0.6); /* 背景用リング */
}
.mainimage .slide_item {
  position: relative;
}
.mainimage .is-active .catch {
  opacity: 1;
}

.catch_wrap {
  position: absolute;
  width: 100%;
  left: 0;
}
@media (max-width: 767px) {
  .catch_wrap {
    bottom: 0;
    padding-bottom: calc(81 / var(--sp_calc) + 120 / var(--sp_calc));
  }
  .catch_wrap .splide__slide {
    display: flex;
    align-items: flex-end;
  }
}
@media (min-width: 768px) {
  .catch_wrap {
    height: 100%;
    top: 0;
    display: flex;
    align-items: center;
  }
}

.mainimage_catch {
  opacity: 0;
  transition: opacity 1s;
  transition-delay: 0.5s;
}
.mainimage_catch.is-initialized {
  opacity: 1;
}
.mainimage_catch::before {
  position: absolute;
  content: "";
  display: block;
  width: calc(374.5 / var(--sp_calc));
  height: calc(213.59 / var(--sp_calc));
  background-image: url(../img/mainimage/mainimage_catch_bg_sp.png);
  background-size: contain;
  background-position: right center;
}
@media (max-width: 767px) {
  .mainimage_catch::before {
    right: 0;
    bottom: calc(172 / var(--sp_calc) * -1);
  }
}
@media (min-width: 768px) {
  .mainimage_catch::before {
    top: 0;
  }
}
@media (min-width: 768px) {
  .mainimage_catch::before {
    width: 809px;
    height: 461px;
    background-image: url(../img/mainimage/mainimage_catch_bg.png);
    left: 58px;
    top: -108px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch {
    position: relative;
  }
  .mainimage_catch .slide_item {
    display: flex;
    align-items: flex-end;
    padding-left: calc(20 / var(--sp_calc));
    padding-bottom: calc(26 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch {
    width: 100%;
    height: 100%;
    height: 481px;
    /* padding-left: clamp( calc(140px - 64px) , calc( 140 / 1280 * 100vw - 64px ) , calc(210px - 64px));*/
    padding-left: clamp(56px, 10.9375vw - 64px - 20px, 126px);
  }
}
@media (min-width: 768px) and (max-width: 1280px) {
  .mainimage_catch {
    /*padding-left: calc(140px - 64px);*/
    padding-left: 56px;
  }
}
.mainimage_catch.is-initialized .splide__slide .slide_item {
  opacity: 0;
  transition: opacity 1s;
  transition-delay: 1s;
}
.mainimage_catch.is-initialized .splide__slide.is-active .slide_item {
  opacity: 1;
}
.mainimage_catch .catch {
  transition: var(--transition-hover);
  transition-delay: 0.6s;
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
}
@media (max-width: 767px) {
  .mainimage_catch .catch {
    left: calc(20 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch .catch {
    padding: 20px 20px 0 20px;
  }
}
@media (min-width: 768px) and (max-height: 780px) {
  .mainimage_catch .catch {
    scale: 0.9;
  }
}
.mainimage_catch .catch .catch_main {
  color: rgba(255, 255, 255, 0.9490196078);
}
.mainimage_catch .catch .catch_main.en,
.mainimage_catch .catch .catch_main .en {
  font-family: var(--cor-garamond);
  font-weight: 600;
  font-size: calc(40 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0;
  text-shadow: 0px calc(1.66 / var(--sp_calc)) calc(8.32 / var(--sp_calc)) 0px rgba(36, 37, 37, 0.2509803922);
}
@media (min-width: 768px) {
  .mainimage_catch .catch .catch_main.en,
  .mainimage_catch .catch .catch_main .en {
    font-size: 72px;
    text-shadow: 0px var(--px-4) var(--px-20) rgba(36, 37, 37, 0.2509803922);
  }
}
.mainimage_catch .catch .catch_main.jp {
  text-shadow: 0px var(--px-2) var(--px-8) rgba(36, 37, 37, 0.9019607843), 0px var(--px-2) var(--px-8) rgba(36, 37, 37, 0.9490196078);
  line-height: 1.1;
  letter-spacing: 0.06em;
}
@media (min-width: 768px) {
  .mainimage_catch .catch .catch_main.jp {
    text-shadow: 0px 0px var(--px-20) rgba(36, 37, 37, 0.8980392157);
  }
}
.mainimage_catch .catch .point {
  color: var(--white);
  font-weight: 600;
  font-size: calc(23 / var(--sp_calc));
  line-height: 1.64;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  .mainimage_catch .catch .point {
    font-size: 34px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .catch .point .bg._sp {
    display: table;
    background: linear-gradient(270deg, rgba(200, 169, 117, 0) 0%, #B89863 26.28%, #755116 100%);
    padding: 0 calc(30 / var(--sp_calc)) 0 calc(10 / var(--sp_calc));
    margin-top: calc(6 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch .catch .point .bg._pc {
    display: table;
    background: linear-gradient(270deg, rgba(200, 169, 117, 0) 0%, #B89863 26.28%, #755116 100%);
    padding: 0 60px 0 10px;
  }
  .mainimage_catch .catch .point .bg._pc + ._pc {
    margin-top: 8px;
  }
}
.mainimage_catch .catch .point._white {
  color: var(--beiju_04);
}
.mainimage_catch .catch .point._white .bg {
  background: rgba(255, 255, 255, 0.8509803922);
  box-shadow: 0px var(--px-4) var(--px-15) 0px rgba(57, 61, 75, 0.4509803922);
}
@media (max-width: 767px) {
  .mainimage_catch .catch .point._white .bg._sp {
    padding-right: calc(7 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch .catch .point._white .bg._sp {
    background: none;
    box-shadow: none;
  }
  .mainimage_catch .catch .point._white .bg._pc {
    background: rgba(255, 255, 255, 0.8509803922);
    padding-right: 10px;
  }
}
.mainimage_catch .catch .txt {
  color: var(--white);
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  font-size: calc(16 / var(--sp_calc));
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-shadow: 0px var(--px-4) var(--px-15) text rgba(57, 61, 75, 0.2509803922);
}
@media (min-width: 768px) {
  .mainimage_catch .catch .txt {
    font-size: 26px;
  }
}
@media (min-width: 768px) {
  .mainimage_catch .slide_1 .catch,
  .mainimage_catch .slide_2 .catch,
  .mainimage_catch .slide_3 .catch,
  .mainimage_catch .slide_4 .catch {
    min-height: 432px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_1 {
    padding-bottom: calc(72 / var(--sp_calc));
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_1 .catch {
    top: calc(210 / var(--sp_calc));
  }
}
.mainimage_catch .slide_1 .catch .point {
  margin-top: calc(10 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mainimage_catch .slide_1 .catch .en {
    font-size: 72px;
  }
  .mainimage_catch .slide_1 .catch .point {
    margin-top: 40px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_2 {
    padding-bottom: calc(30 / var(--sp_calc));
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_2 .catch {
    top: calc(210 / var(--sp_calc));
  }
}
.mainimage_catch .slide_2 .catch .en {
  font-size: calc(40 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0;
}
.mainimage_catch .slide_2 .catch .jp {
  display: table;
  font-size: calc(28 / var(--sp_calc));
  line-height: 1.1;
  letter-spacing: 0.06em;
}
.mainimage_catch .slide_2 .catch .point {
  font-size: calc(23 / var(--sp_calc));
  margin-top: calc(16 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mainimage_catch .slide_2 .catch .en {
    font-size: 72px;
    line-height: 1;
  }
  .mainimage_catch .slide_2 .catch .jp {
    font-size: 60px;
  }
  .mainimage_catch .slide_2 .catch .point {
    font-size: 34px;
    line-height: 1.64;
    letter-spacing: 0.08em;
    margin-top: 30px;
  }
  .mainimage_catch .slide_2 .catch .point .wide {
    letter-spacing: 0.1em;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_3 .catch {
    top: calc(290 / var(--sp_calc));
  }
}
.mainimage_catch .slide_3 .catch .txt {
  font-size: calc(20 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.08em;
}
.mainimage_catch .slide_3 .catch .txt .para {
  display: block;
  line-height: 1;
  padding-left: 0.5em;
  position: relative;
}
.mainimage_catch .slide_3 .catch .txt .para + .para {
  margin-top: var(--px-9);
}
.mainimage_catch .slide_3 .catch .txt .para::before {
  position: absolute;
  content: "-";
  display: block;
  left: 0;
  top: 0.2em;
}
.mainimage_catch .slide_3 .catch .txt .normal {
  text-shadow: 0px 0px var(--px-10) rgba(0, 12, 56, 0.6);
}
.mainimage_catch .slide_3 .catch .txt .cases {
  font-size: calc(16 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.1em;
  text-shadow: 0px 0px var(--px-9) #3A6DC5, 0px 0px var(--px-9) #3A6DC5, 0px 0px var(--px-9) #3A6DC5;
}
.mainimage_catch .slide_3 .catch .txt .cases .num {
  font-size: calc(26 / var(--sp_calc));
}
.mainimage_catch .slide_3 .catch .txt .sub {
  font-size: calc(18 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.1em;
  margin-top: calc(5 / var(--sp_calc));
}
.mainimage_catch .slide_3 .catch .txt .sub .cases {
  font-size: calc(16 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.1em;
}
.mainimage_catch .slide_3 .catch .txt .sub .cases .num {
  font-size: calc(22 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.1em;
}
.mainimage_catch .slide_3 .catch .txt .ex {
  font-family: var(--main-family);
  font-weight: 500;
  font-size: calc(13 / var(--sp_calc));
  line-height: 1.8;
  letter-spacing: 0.06em;
  display: block;
  margin-top: var(--px-7);
}
@media (max-width: 767px) {
  .mainimage_catch .slide_3 .catch .catch_main {
    display: none;
  }
  .mainimage_catch .slide_3 .catch .txt {
    margin-top: calc(7 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch .slide_3 .catch .point {
    margin-top: 22px;
  }
  .mainimage_catch .slide_3 .catch .txt {
    font-size: 26px;
    margin-top: 7px;
  }
  .mainimage_catch .slide_3 .catch .txt .cases {
    font-size: 24px;
  }
  .mainimage_catch .slide_3 .catch .txt .cases .num {
    font-size: 34px;
  }
  .mainimage_catch .slide_3 .catch .txt .sub {
    font-size: 24px;
    margin-top: 7.5px;
  }
  .mainimage_catch .slide_3 .catch .txt .sub .cases {
    font-size: 20px;
  }
  .mainimage_catch .slide_3 .catch .txt .sub .cases .num {
    font-size: 28px;
  }
  .mainimage_catch .slide_3 .catch .txt {
    font-size: 26px;
  }
  .mainimage_catch .slide_3 .catch .txt .ex {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_4 .catch {
    top: calc(259 / var(--sp_calc));
  }
}
.mainimage_catch .slide_4 .catch .txt {
  margin-top: var(--px-10);
}
@media (max-width: 767px) {
  .mainimage_catch .slide_4 .catch .catch_main {
    display: none;
  }
}
@media (min-width: 768px) {
  .mainimage_catch .slide_4 .catch .point {
    margin-top: 22px;
  }
  .mainimage_catch .slide_4 .catch .txt {
    margin-top: 10px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .slide_5 .catch {
    top: calc(147 / var(--sp_calc));
  }
}
@media (min-width: 768px) {
  .mainimage_catch .slide_5 .catch {
    padding-top: 40px;
  }
}
.mainimage_catch .slide_5 .catch .catch_main {
  font-family: var(--title-family);
  font-weight: 600;
  font-size: calc(26 / var(--sp_calc));
  line-height: 1.5;
  letter-spacing: 0.06em;
}
.mainimage_catch .slide_5 .catch .catch_main .min {
  font-size: calc(20 / var(--sp_calc));
  letter-spacing: 0.06em;
}
.mainimage_catch .slide_5 .catch .point {
  font-size: calc(20 / var(--sp_calc));
  letter-spacing: 0.01em;
  margin-top: var(--px-10);
}
.mainimage_catch .slide_5 .catch .point .num {
  font-size: calc(25 / var(--sp_calc));
}
.mainimage_catch .slide_5 .catch .point .min {
  font-size: calc(16 / var(--sp_calc));
}
.mainimage_catch .slide_5 .catch .point .sub {
  font-size: calc(18 / var(--sp_calc));
}
.mainimage_catch .slide_5 .catch .point .sub .min {
  font-size: calc(16 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mainimage_catch .slide_5 .catch .catch_main {
    font-size: 50px;
  }
  .mainimage_catch .slide_5 .catch .catch_main .min {
    font-size: 40px;
  }
  .mainimage_catch .slide_5 .catch .point {
    font-size: 30px;
    margin-top: 20px;
  }
  .mainimage_catch .slide_5 .catch .point .num {
    font-size: 34px;
  }
  .mainimage_catch .slide_5 .catch .point .min {
    font-size: 24px;
  }
  .mainimage_catch .slide_5 .catch .point .sub {
    font-size: 23px;
  }
  .mainimage_catch .slide_5 .catch .point .sub .min {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .mainimage_catch .ls-minus {
    letter-spacing: 0.07em !important;
  }
}

.mce-content-body {
  --p-line-height: 1.8;
}
@media (min-width: 768px) {
  .mce-content-body {
    --p-line-height: 2;
  }
}
.mce-content-body a {
  color: var(--color-clinic);
}
.mce-content-body a[href^="tel:"] {
  color: inherit;
}
.mce-content-body .color {
  color: var(--color-clinic);
}
.mce-content-body p {
  letter-spacing: 0.06em;
  line-height: var(--p-line-height);
}
.mce-content-body p + p {
  margin-top: calc(0.75em * var(--p-line-height));
}
@media (min-width: 768px) {
  .mce-content-body p {
    letter-spacing: 0.08em;
  }
}
@media (min-width: 768px) {
  .mce-content-body a[href^="tel:"] {
    color: inherit;
    pointer-events: none;
    text-decoration: none;
  }
}
.mce-content-body hr {
  border: none;
  height: 0;
  margin: 0 auto 0;
  display: block;
}
.mce-content-body b, .mce-content-body strong {
  font-weight: var(--main-family-bold);
}
.mce-content-body sup {
  font-size: calc(var(--main-size) * 0.65);
  vertical-align: super;
}
.mce-content-body sub {
  font-size: calc(var(--main-size) * 0.65);
  vertical-align: sub;
}
.mce-content-body blockquote {
  border: 1px solid #ccc;
  margin-top: calc(var(--main-size) * 1.5);
  padding: calc(var(--main-size) * 1.8);
  position: relative;
}
.mce-content-body blockquote::before, .mce-content-body blockquote::after {
  display: block;
  position: absolute;
  content: "format_quote";
  width: calc(var(--main-size) * 2);
  height: calc(var(--main-size) * 2);
  font-family: "Material Icons";
  font-size: calc(var(--main-size) * 2);
  white-space: nowrap;
  word-wrap: normal;
  color: #ccc;
}
.mce-content-body blockquote::before {
  top: calc(var(--main-size) * 1);
  left: calc(var(--main-size) * 0.75);
  transform: rotate(-180deg);
}
.mce-content-body blockquote::after {
  right: calc(var(--main-size) * 0.75);
  bottom: calc(var(--main-size) * 1);
}
.mce-content-body table {
  width: 100%;
}
.mce-content-body p.error404 {
  margin-bottom: 10rem;
  margin-top: 7.5rem;
  text-align: center;
}
@media (max-width: 767px) {
  .mce-content-body p.error404 {
    margin-top: 5rem;
    margin-bottom: 5rem;
  }
}

/* margin-bottom */
.under-page {
  /* margin-top */
}
.under-page .mce-content-body {
  padding-bottom: var(--section-padding);
}
.under-page .mce-content-body .title,
.under-page .mce-content-body p.title,
.under-page .mce-content-body .title p {
  font-weight: 600;
  color: var(--color-clinic-txt);
  margin-bottom: var(--btn-margin);
}
.under-page div + .box_bg,
.under-page div + .box_border, .under-page h2 + .box_bg,
.under-page h2 + .box_border, .under-page h3 + .box_bg,
.under-page h3 + .box_border, .under-page h4 + .box_bg,
.under-page h4 + .box_border, .under-page h5 + .box_bg,
.under-page h5 + .box_border, .under-page h6 + .box_bg,
.under-page h6 + .box_border, .under-page p + .box_bg,
.under-page p + .box_border, .under-page ul + .box_bg,
.under-page ul + .box_border, .under-page ol + .box_bg,
.under-page ol + .box_border, .under-page dl + .box_bg,
.under-page dl + .box_border, .under-page table + .box_bg,
.under-page table + .box_border, .under-page section + .box_bg,
.under-page section + .box_border {
  margin-top: var(--box-margin);
}
.under-page div + ._access_by,
.under-page div + .googlemap, .under-page h2 + ._access_by,
.under-page h2 + .googlemap, .under-page h3 + ._access_by,
.under-page h3 + .googlemap, .under-page h4 + ._access_by,
.under-page h4 + .googlemap, .under-page h5 + ._access_by,
.under-page h5 + .googlemap, .under-page h6 + ._access_by,
.under-page h6 + .googlemap, .under-page p + ._access_by,
.under-page p + .googlemap, .under-page ul + ._access_by,
.under-page ul + .googlemap, .under-page ol + ._access_by,
.under-page ol + .googlemap, .under-page dl + ._access_by,
.under-page dl + .googlemap, .under-page table + ._access_by,
.under-page table + .googlemap, .under-page section + ._access_by,
.under-page section + .googlemap {
  margin-top: var(--item-margin);
}
.under-page p + ul,
.under-page p + ol,
.under-page p + table,
.under-page p + div:has(h3),
.under-page p + .columns,
.under-page .bg-block + .columns,
.under-page .bg-block + div:has(h3),
.under-page ul + ul,
.under-page .border-table + p {
  margin-top: var(--box-margin);
}
.under-page .bg-block p + ul,
.under-page .bg-block p + ol,
.under-page .bg-block p + table {
  margin-top: calc(0.75em * var(--p-line-height));
}
.under-page .bg-block + p {
  margin-top: var(--item-margin);
}
.under-page .btnstyle + p:not([class]) {
  margin-top: var(--box-margin);
}
.under-page .surgery_bg .border-block,
.under-page .surgery_bg .bg-block,
.under-page .surgery_bg .box_bg,
.under-page .bg-block .border-block,
.under-page .bg-block .bg-block,
.under-page .bg-block .box_bg,
.under-page .flow-block .border-block,
.under-page .flow-block .bg-block,
.under-page .flow-block .box_bg,
.under-page .box_bg .border-block,
.under-page .box_bg .bg-block,
.under-page .box_bg .box_bg,
.under-page .box_border .border-block,
.under-page .box_border .bg-block,
.under-page .box_border .box_bg {
  margin-top: var(--box-margin);
}
.under-page .block-inner + .block-inner, .under-page .block-inner + .bg-block, .under-page .block-inner + .block,
.under-page .bg-block + .block-inner,
.under-page .bg-block + .bg-block,
.under-page .bg-block + .block,
.under-page .block + .block-inner,
.under-page .block + .bg-block,
.under-page .block + .block {
  margin-top: var(--box-margin);
}
.under-page p + .bg-block {
  margin-top: var(--box-margin);
}
.under-page .ul_circle + .ul_circle, .under-page .ul_circle + .ul_arrow, .under-page .ul_circle + .ul_check, .under-page .ul_circle + .ol_circle, .under-page .ul_circle + .ol_decimal,
.under-page .ul_arrow + .ul_circle,
.under-page .ul_arrow + .ul_arrow,
.under-page .ul_arrow + .ul_check,
.under-page .ul_arrow + .ol_circle,
.under-page .ul_arrow + .ol_decimal,
.under-page .ul_check + .ul_circle,
.under-page .ul_check + .ul_arrow,
.under-page .ul_check + .ul_check,
.under-page .ul_check + .ol_circle,
.under-page .ul_check + .ol_decimal,
.under-page .ol_circle + .ul_circle,
.under-page .ol_circle + .ul_arrow,
.under-page .ol_circle + .ul_check,
.under-page .ol_circle + .ol_circle,
.under-page .ol_circle + .ol_decimal,
.under-page .ol_decimal + .ul_circle,
.under-page .ol_decimal + .ul_arrow,
.under-page .ol_decimal + .ul_check,
.under-page .ol_decimal + .ol_circle,
.under-page .ol_decimal + .ol_decimal {
  margin-top: var(--box-margin);
}
.under-page ol + p {
  margin-top: var(--box-margin);
}
.under-page table + .note, .under-page ul + .note, .under-page p + .note {
  font-size: var(--px-14);
  line-height: 1.8;
  letter-spacing: 0.04em;
  margin-top: var(--px-20);
}
@media (min-width: 768px) {
  .under-page table + .note, .under-page ul + .note, .under-page p + .note {
    font-size: 17px;
  }
}
.under-page p + p.note {
  margin-top: var(--px-6);
}

.mt-box-margin {
  margin-top: var(--box-margin);
}

/* under */
.page_title_wrap h1,
.breadcrumb ol {
  margin-left: calc(var(--container-padding-size) / var(--sp_calc));
  margin-right: calc(var(--container-padding-size) / var(--sp_calc));
}
@media (min-width: 768px) {
  .page_title_wrap h1,
  .breadcrumb ol {
    margin-inline: auto;
    width: min(1420px, 100% - var(--container-padding-size) * 2 * 1px);
  }
}
@media (min-width: 1680px) {
  .page_title_wrap h1,
  .breadcrumb ol {
    margin-inline: auto;
    width: calc(100% - 260px);
  }
}

/* page_title */
.page_title_wrap {
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  position: relative;
  background: url(../../assets/img/common/under_title_sp.jpg) no-repeat center center/cover;
  height: calc(220 / var(--sp_calc));
  padding-bottom: calc(22.8 / var(--sp_calc));
}
@media (min-width: 768px) {
  .page_title_wrap {
    height: 400px;
    padding-bottom: 35px;
  }
}
.page_title_wrap:before, .page_title_wrap:after {
  display: none;
}
.page_title_wrap .page_title {
  color: #fff;
  z-index: 1;
  font-family: var(--title-family);
  font-size: var(--h1-size);
  font-weight: var(--title-family-weight);
  line-height: var(--title-line-height);
  letter-spacing: var(--main-letter-spacing);
}
.page_title_wrap .page_title .jp,
.page_title_wrap .page_title .en {
  display: block;
}
.page_title_wrap .page_title .en {
  font-family: var(--cor-garamond);
  font-size: var(--h1-sub-size);
  line-height: 1.5;
  letter-spacing: 0;
  text-transform: uppercase;
}
.page_title_wrap._takatsuki {
  background-image: url(../../takatsuki/assets/img/common/under_title_sp.jpg);
}
.page_title_wrap._yao {
  background-image: url(../../yao/assets/img/common/under_title_sp.jpg);
}
.page_title_wrap._matsubara {
  background-image: url(../../matsubara/assets/img/common/under_title_sp.jpg);
}
@media (min-width: 768px) {
  .page_title_wrap {
    background-image: url(../../assets/img/common/under_title.jpg);
  }
  .page_title_wrap._takatsuki {
    background-image: url(../../takatsuki/assets/img/common/under_title.jpg);
  }
  .page_title_wrap._yao {
    background-image: url(../../yao/assets/img/common/under_title.jpg);
  }
  .page_title_wrap._matsubara {
    background-image: url(../../matsubara/assets/img/common/under_title.jpg);
  }
}

/* breadcrumb */
.breadcrumb {
  --color-default: #FFFFFFB2;
  --color-hover: #FFFFFF;
  --padding-bread: calc( 3.5 / var(--sp_calc));
  background: var(--blue_03);
  font-size: calc(14 / var(--sp_calc));
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.06em;
  margin-block: var(--leading-trim);
  padding-top: calc(14 / var(--sp_calc));
  padding-bottom: calc(14 / var(--sp_calc));
}
@media (min-width: 768px) {
  .breadcrumb {
    --padding-bread: 8px;
  }
}
.breadcrumb li {
  display: inline-block;
  padding: var(--padding-bread) 0;
}
.breadcrumb li.current {
  color: var(--beiju_02);
}
.breadcrumb li a {
  color: var(--color-default);
  text-decoration: none;
}
@media (hover: hover) {
  .breadcrumb li a:hover {
    color: var(--color-hover);
    text-decoration: underline;
    text-underline-offset: var(--px-3);
  }
}
.breadcrumb li .svg-icons {
  fill: var(--color-default);
  width: var(--px-7);
  aspect-ratio: 5.414/9.414;
  margin: 0 var(--px-10);
}
@media (min-width: 768px) {
  .breadcrumb {
    font-size: 16px;
    padding-top: 20px;
    padding-bottom: 20px;
  }
}

/* 本文 */
.mce-content-body {
  /* h2 */
  /* h3 */
  /* h4 */
  /* h5 */
  /* h6 */
  /* margin-top */
}
.mce-content-body h2, .mce-content-body h3, .mce-content-body h4, .mce-content-body h5, .mce-content-body .text-large {
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  line-height: var(--title-line-height);
  position: relative;
}
.mce-content-body h2._sanserif, .mce-content-body h3._sanserif, .mce-content-body h4._sanserif, .mce-content-body h5._sanserif, .mce-content-body .text-large._sanserif {
  font-family: var(--main-family);
  font-weight: var(--main-family-bold);
}
.mce-content-body h3, .mce-content-body h4, .mce-content-body h5 {
  letter-spacing: var(--title-letter-spacing);
}
.mce-content-body h2 {
  font-size: var(--h2-size);
  letter-spacing: 0.08em;
  text-align: center;
  margin-top: var(--section-padding);
  padding-top: var(--section-padding);
  margin-bottom: calc(30 / var(--sp_calc));
  padding-bottom: var(--px-10);
}
.mce-content-body h2::before, .mce-content-body h2::after {
  position: absolute;
  content: "";
  display: block;
}
.mce-content-body h2::before {
  background: var(--blue_02);
  width: var(--vw100);
  height: var(--px-1);
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.mce-content-body h2::after {
  background: var(--color-clinic);
  width: calc(40 / var(--sp_calc));
  height: calc(2 / var(--sp_calc));
  bottom: 0;
  left: 0;
  right: 0;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .mce-content-body h2 {
    margin-bottom: 50px;
  }
  .mce-content-body h2::before {
    min-width: calc(var(--container-padding-size) * 2px + var(--container-width));
  }
  .mce-content-body h2::after {
    width: 70px;
    height: 3px;
  }
}
.mce-content-body h2._has_en {
  padding-bottom: 0;
  text-align: left;
}
.mce-content-body h2._has_en .en {
  color: #BABABA;
  font-family: var(--cor-garamond);
  font-size: calc(35 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0;
  display: block;
  margin-bottom: calc(14 / var(--sp_calc));
}
.mce-content-body h2._has_en .jp {
  font-size: calc(30 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.06em;
  display: block;
}
@media (min-width: 768px) {
  .mce-content-body h2._has_en .en {
    font-size: 60px;
    margin-bottom: 20px;
  }
  .mce-content-body h2._has_en .jp {
    font-size: 44px;
  }
}
.mce-content-body h2._has_en::after {
  display: none;
}
.mce-content-body h2._has_en._mb_short {
  margin-bottom: var(--px-30);
}
.mce-content-body .h3 {
  display: block;
}
.mce-content-body h2._noborder,
.mce-content-body .block:has(.link_anchor) + h2,
.mce-content-body .block:has(.link_anchor) + .h3 h2,
.mce-content-body div:has(.link_anchor) + div h2,
.mce-content-body .link_anchor + h2,
.mce-content-body .link_anchor + div h2,
.mce-content-body .block:has(.link_anchor) + section > h2,
.mce-content-body .link_anchor + .section > h2,
.mce-content-body .h2:first-child h2,
.mce-content-body .h3:first-child h2, .mce-content-body > h2:first-child {
  padding-top: 0;
}
.mce-content-body h2._noborder::before,
.mce-content-body .block:has(.link_anchor) + h2::before,
.mce-content-body .block:has(.link_anchor) + .h3 h2::before,
.mce-content-body div:has(.link_anchor) + div h2::before,
.mce-content-body .link_anchor + h2::before,
.mce-content-body .link_anchor + div h2::before,
.mce-content-body .block:has(.link_anchor) + section > h2::before,
.mce-content-body .link_anchor + .section > h2::before,
.mce-content-body .h2:first-child h2::before,
.mce-content-body .h3:first-child h2::before, .mce-content-body > h2:first-child::before {
  background: transparent;
}
.mce-content-body h3 {
  background: var(--blue_03);
  color: var(--white);
  font-size: var(--h3-size);
  margin-bottom: var(--px-30);
  padding: calc(10 / var(--sp_calc));
  padding-left: var(--px-25);
}
.mce-content-body h3::before {
  position: absolute;
  content: "";
  display: block;
  background: var(--color-h3);
  width: var(--px-5);
  height: var(--px-34);
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  border-radius: 0 var(--px-3) var(--px-3) 0;
}
@media (min-width: 768px) {
  .mce-content-body h3 {
    padding-top: 12px;
    padding-bottom: 12px;
  }
}
.mce-content-body h4,
.mce-content-body h3.h4 {
  background: none;
  padding: 0;
  border-bottom: var(--px-1) solid var(--blue_02);
  color: inherit;
  font-size: var(--h4-size);
  margin-bottom: var(--px-30);
  padding-bottom: calc(12 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mce-content-body h4,
  .mce-content-body h3.h4 {
    padding-bottom: 16px;
  }
}
.mce-content-body h5,
.mce-content-body h3.h5,
.mce-content-body h4.h5,
.mce-content-body h6.h5 {
  background: var(--blue_01);
  color: var(--white);
  font-size: var(--h5-size);
  margin-bottom: calc(24 / var(--sp_calc));
  padding: calc(6 / var(--sp_calc)) calc(12 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mce-content-body h5,
  .mce-content-body h3.h5,
  .mce-content-body h4.h5,
  .mce-content-body h6.h5 {
    margin-bottom: 30px;
    padding: 8px 20px;
  }
}
.mce-content-body h6,
.mce-content-body h3.h6,
.mce-content-body h4.h6,
.mce-content-body h5.h6 {
  background: none;
  border: none;
  padding: 0;
  color: var(--color-clinic-txt);
  font-family: var(--main-family);
  font-size: var(--h6-size);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.08em;
  padding-left: var(--px-22);
  position: relative;
  margin-bottom: var(--px-16);
}
.mce-content-body h6::before,
.mce-content-body h3.h6::before,
.mce-content-body h4.h6::before,
.mce-content-body h5.h6::before {
  position: absolute;
  content: "";
  display: block;
  background: currentColor;
  width: var(--px-12);
  height: var(--px-12);
  border-radius: 50%;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.mce-content-body h6._mb_short,
.mce-content-body h3.h6._mb_short,
.mce-content-body h4.h6._mb_short,
.mce-content-body h5.h6._mb_short {
  margin-bottom: var(--px-8);
}
.mce-content-body .h4::before, .mce-content-body .h5::before {
  display: none;
}
.mce-content-body .h5 {
  margin-bottom: var(--px-18);
}
.mce-content-body .h6::before {
  top: calc(0.5lh - var(--px-12) / 2);
  bottom: auto;
}
.mce-content-body div + h3, .mce-content-body div + .h3:has(h3), .mce-content-body div + .h4:has(h3), .mce-content-body h2 + h3, .mce-content-body h2 + .h3:has(h3), .mce-content-body h2 + .h4:has(h3), .mce-content-body h3 + h3, .mce-content-body h3 + .h3:has(h3), .mce-content-body h3 + .h4:has(h3), .mce-content-body h4 + h3, .mce-content-body h4 + .h3:has(h3), .mce-content-body h4 + .h4:has(h3), .mce-content-body h5 + h3, .mce-content-body h5 + .h3:has(h3), .mce-content-body h5 + .h4:has(h3), .mce-content-body h6 + h3, .mce-content-body h6 + .h3:has(h3), .mce-content-body h6 + .h4:has(h3), .mce-content-body p + h3, .mce-content-body p + .h3:has(h3), .mce-content-body p + .h4:has(h3), .mce-content-body ul + h3, .mce-content-body ul + .h3:has(h3), .mce-content-body ul + .h4:has(h3), .mce-content-body ol + h3, .mce-content-body ol + .h3:has(h3), .mce-content-body ol + .h4:has(h3), .mce-content-body dl + h3, .mce-content-body dl + .h3:has(h3), .mce-content-body dl + .h4:has(h3), .mce-content-body table + h3, .mce-content-body table + .h3:has(h3), .mce-content-body table + .h4:has(h3), .mce-content-body section + h3, .mce-content-body section + .h3:has(h3), .mce-content-body section + .h4:has(h3) {
  margin-top: var(--box-margin);
}
.mce-content-body div + .h5, .mce-content-body h2 + .h5, .mce-content-body h3 + .h5, .mce-content-body h4 + .h5, .mce-content-body h5 + .h5, .mce-content-body h6 + .h5, .mce-content-body p + .h5, .mce-content-body ul + .h5, .mce-content-body ol + .h5, .mce-content-body dl + .h5, .mce-content-body table + .h5, .mce-content-body section + .h5 {
  margin-top: var(--item-margin);
}
@media (max-width: 767px) {
  .mce-content-body h2 + h3, .mce-content-body h2 + .h4:has(h3),
  .mce-content-body .h3:has(h2) + h3,
  .mce-content-body .h3:has(h2) + .h4:has(h3) {
    margin-top: var(--item-margin);
  }
}
.mce-content-body div + h4, .mce-content-body div + h5, .mce-content-body div + h6, .mce-content-body h2 + h4, .mce-content-body h2 + h5, .mce-content-body h2 + h6, .mce-content-body h3 + h4, .mce-content-body h3 + h5, .mce-content-body h3 + h6, .mce-content-body h4 + h4, .mce-content-body h4 + h5, .mce-content-body h4 + h6, .mce-content-body h5 + h4, .mce-content-body h5 + h5, .mce-content-body h5 + h6, .mce-content-body h6 + h4, .mce-content-body h6 + h5, .mce-content-body h6 + h6, .mce-content-body p + h4, .mce-content-body p + h5, .mce-content-body p + h6, .mce-content-body ul + h4, .mce-content-body ul + h5, .mce-content-body ul + h6, .mce-content-body ol + h4, .mce-content-body ol + h5, .mce-content-body ol + h6, .mce-content-body dl + h4, .mce-content-body dl + h5, .mce-content-body dl + h6, .mce-content-body table + h4, .mce-content-body table + h5, .mce-content-body table + h6, .mce-content-body section + h4, .mce-content-body section + h5, .mce-content-body section + h6 {
  margin-top: var(--px-30);
}
.mce-content-body .h {
  font-size: calc(20 / var(--sp_calc));
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  line-height: var(--title-line-height);
  letter-spacing: var(--title-letter-spacing);
  padding: 0;
  margin-bottom: var(--px-30);
  border: none;
}
@media (min-width: 768px) {
  .mce-content-body .h {
    font-size: 24px;
  }
}
.mce-content-body .h._dot {
  position: relative;
  padding: 0 0 0 var(--px-24);
}
.mce-content-body .h._dot::before {
  position: absolute;
  content: "";
  display: block;
  background: var(--color-clinic-secondary);
  width: var(--px-12);
  height: var(--px-12);
  border-radius: 50%;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.mce-content-body .h._color {
  color: var(--color-clinic);
}
.mce-content-body ._has_num {
  display: flex;
  align-items: center;
  gap: var(--px-18);
  padding: var(--px-12) var(--px-18);
  border: none;
  margin: 0;
  background: var(--gray_03);
  color: var(--main_txt);
  font-family: var(--main-family);
  font-weight: var(--main-family-weight);
  font-size: var(--main-size);
  line-height: 1.8;
  letter-spacing: 0.06em;
}
.mce-content-body ._has_num .num {
  color: var(--color-clinic-txt);
  font-family: var(--eb-garamond);
  font-weight: 500;
  font-size: calc(26 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0;
  margin-bottom: auto;
  margin-top: calc(2 / var(--sp_calc));
}
@media (min-width: 768px) {
  .mce-content-body ._has_num .num {
    font-size: 32px;
    margin-top: 3px;
  }
}
.mce-content-body ._has_num + ._has_num {
  margin-top: var(--px-20);
}
.mce-content-body ._has_num::before, .mce-content-body ._has_num::after {
  display: none;
}

.btnstyle {
  background: var(--gradient-black);
  display: flex;
  flex-wrap: wrap;
  gap: var(--px-18);
  width: calc(250 / var(--sp_calc));
  height: calc(51 / var(--sp_calc));
  position: relative;
}
@media (min-width: 768px) {
  .btnstyle {
    height: 54px;
    width: 280px;
  }
}
.btnstyle::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  background: var(--clinic-gradient);
  transition: var(--transition-hover);
  z-index: 0;
}
.btnstyle a {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  letter-spacing: 0.05em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  color: var(--white);
  position: relative;
  transition: var(--transition-hover);
  z-index: 2;
}
.btnstyle a::before, .btnstyle a::after {
  position: absolute;
  content: "";
  height: var(--px-1);
  background: var(--beiju_02);
  top: 0;
  bottom: 0;
  margin-top: auto;
  margin-bottom: auto;
  transition: var(--transition-hover);
}
.btnstyle a::before {
  left: 0;
  width: 0;
}
.btnstyle a::after {
  right: 0;
  width: var(--px-40);
}
.btnstyle__right, .btnstyle._right {
  margin-right: 0 !important;
}
.btnstyle__left, .btnstyle._left {
  margin-left: 0 !important;
}
.btnstyle__center, .btnstyle._center {
  margin-inline: auto;
}
@media (min-width: 768px) {
  .btnstyle._pc_right {
    margin-right: 0 !important;
  }
  .btnstyle._pc_left {
    margin-left: 0 !important;
  }
}
@media (hover: hover) {
  .btnstyle:hover::before {
    opacity: 0;
  }
  .btnstyle a:hover {
    opacity: 1;
  }
  .btnstyle a:hover::before {
    width: var(--px-40);
  }
  .btnstyle a:hover::after {
    width: 0;
  }
}
.btnstyle._common {
  background: var(--gradient-blue) !important;
}
.btnstyle._common::before {
  background: var(--gradient-black) !important;
}
.btnstyle._takatsuki::before {
  background: var(--gradient-takatsuki);
}

.mce-content-body.page-template-template-takatsuki .btnstyle::before {
  background: var(--gradient-takatsuki);
}
.mce-content-body.page-template-template-takatsuki .btnstyle, .mce-content-body.page-template-template-yao .btnstyle, .mce-content-body.page-template-template-matsubara .btnstyle {
  background: #2F333B;
}
@media (hover: hover) {
  .mce-content-body.page-template-template-takatsuki .btnstyle:hover::before, .mce-content-body.page-template-template-yao .btnstyle:hover::before, .mce-content-body.page-template-template-matsubara .btnstyle:hover::before {
    width: 0;
  }
}
.mce-content-body.page-template-template-takatsuki .sec_orthokeratology .btnstyle, .mce-content-body.page-template-template-yao .sec_orthokeratology .btnstyle, .mce-content-body.page-template-template-matsubara .sec_orthokeratology .btnstyle {
  background: var(--gradient-blue);
}
.mce-content-body.page-template-template-takatsuki .sec_orthokeratology .btnstyle::before, .mce-content-body.page-template-template-yao .sec_orthokeratology .btnstyle::before, .mce-content-body.page-template-template-matsubara .sec_orthokeratology .btnstyle::before {
  background: var(--gradient-black);
}
@media (hover: hover) {
  .mce-content-body.page-template-template-takatsuki .sec_orthokeratology .btnstyle:hover::before, .mce-content-body.page-template-template-yao .sec_orthokeratology .btnstyle:hover::before, .mce-content-body.page-template-template-matsubara .sec_orthokeratology .btnstyle:hover::before {
    width: 0;
  }
}

.under-page .mce-content-body .btnstyle {
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  min-width: calc(250 / var(--sp_calc));
  min-height: calc(51 / var(--sp_calc));
  margin-inline: auto;
}
@media (max-width: 767px) {
  .under-page .mce-content-body .btnstyle {
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  .under-page .mce-content-body .btnstyle {
    min-height: 54px;
    min-width: 280px;
  }
}
.under-page .mce-content-body .btnstyle a {
  padding: calc(17 / var(--sp_calc)) var(--px-50);
}
@media (min-width: 768px) {
  .under-page .mce-content-body .btnstyle a {
    padding-top: 18px;
    padding-bottom: 18px;
  }
}

/* margin-top */
div + ._btnstyle_wrap,
div + .btnstyle, h2 + ._btnstyle_wrap,
h2 + .btnstyle, h3 + ._btnstyle_wrap,
h3 + .btnstyle, h4 + ._btnstyle_wrap,
h4 + .btnstyle, h5 + ._btnstyle_wrap,
h5 + .btnstyle, h6 + ._btnstyle_wrap,
h6 + .btnstyle, p + ._btnstyle_wrap,
p + .btnstyle, ul + ._btnstyle_wrap,
ul + .btnstyle, ol + ._btnstyle_wrap,
ol + .btnstyle, dl + ._btnstyle_wrap,
dl + .btnstyle, table + ._btnstyle_wrap,
table + .btnstyle, section + ._btnstyle_wrap,
section + .btnstyle {
  margin-top: var(--px-30);
}

.row > .btnstyle + .btnstyle {
  margin-top: 0;
}

.under-page .mce-content-body ._btnstyle_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: var(--btn-margin);
  justify-content: flex-start;
}
.under-page .mce-content-body ._btnstyle_wrap .btnstyle {
  margin: 0;
}
.under-page .mce-content-body ._btnstyle_wrap._center {
  justify-content: center;
}
.under-page .mce-content-body ._btnstyle_wrap._right {
  justify-content: flex-end;
}
@media (max-width: 767px) {
  .under-page .mce-content-body ._btnstyle_wrap._btnstyle_bnr .btnstyle {
    width: 88%;
  }
}
.under-page .mce-content-body .btnstyle + .block-inner {
  margin-top: var(--box-margin);
}

.sitemap_box .menu {
  border-top: 1px solid #ddd;
}
.sitemap_box .menu li {
  border-bottom: 1px solid #ddd;
}
.sitemap_box .menu a {
  position: relative;
  display: block;
  padding: calc(var(--main-size) * 1.25) calc(var(--main-size) * 2.5) calc(var(--main-size) * 1.25) calc(var(--main-size) * 1.25);
  transition: 0.3s;
  text-decoration: none;
  color: var(--main_txt);
}
@media (max-width: 767px) {
  .sitemap_box .menu a {
    padding: calc(var(--main-size) * 1) calc(var(--main-size) * 2) calc(var(--main-size) * 1) calc(var(--main-size) * 1);
  }
}
.sitemap_box .menu a:hover {
  color: #0f406c;
  background: #f2f8fd;
}
.sitemap_box .menu a::after {
  position: absolute;
  content: "";
  right: calc(var(--main-size) * 1);
  top: 50%;
  width: 5px;
  height: 5px;
  border-top: 1px solid #0f406c;
  border-right: 1px solid #0f406c;
  transform: rotate(45deg);
}

.form_txt_01 {
  color: var(--color-attention);
  line-height: var(ti);
  font-size: 1.15em;
  text-align: center;
  margin-top: var(--section-padding);
}

.form_txt_02 {
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  line-height: var(--title-line-height);
  letter-spacing: var(--title-letter-spacing);
  border-bottom: var(--px-1) solid var(--blue_02);
  font-size: var(--h4-size);
  margin-bottom: var(--px-30);
  padding-bottom: calc(12 / var(--sp_calc));
  position: relative;
}
@media (min-width: 768px) {
  .form_txt_02 {
    margin-bottom: 30px;
    padding-bottom: 16px;
  }
}

dl + .form_txt_02 {
  margin-top: var(--px-30);
}

.wpcf7 {
  padding-top: var(--section-padding);
}
.wpcf7 select, .wpcf7 input, .wpcf7 textarea {
  max-width: 100%;
}
.wpcf7 input[type=text],
.wpcf7 input[type=email],
.wpcf7 input[type=tel],
.wpcf7 input[type=password],
.wpcf7 textarea,
.wpcf7 select {
  box-shadow: none;
  border: none;
  border-radius: var(--px-5);
  background: var(--white);
  padding: var(--px-12);
  width: 100%;
  line-height: 1.7;
  letter-spacing: 0.06em;
  font-family: var(--main-family);
}
@media (min-width: 768px) {
  .wpcf7 input[type=text],
  .wpcf7 input[type=email],
  .wpcf7 input[type=tel],
  .wpcf7 input[type=password],
  .wpcf7 textarea,
  .wpcf7 select {
    padding: 16px 20px;
  }
}
.wpcf7 textarea {
  width: 100%;
}
.wpcf7 select {
  background: var(--white) url("../img/default/expand_more.svg") no-repeat right var(--px-8) center;
  background-size: var(--px-24);
  min-width: 40%;
  padding: var(--px-12);
  padding-right: var(--px-24);
  width: auto;
}
.wpcf7 input[type=submit] {
  background: var(--gradient-blue);
  box-shadow: none;
  border: none;
  border-radius: var(--px-5);
  color: var(--white);
  font-family: inherit;
  font-size: inherit;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.7;
  padding: var(--px-12);
  text-align: center;
  transition: var(--transition-hover);
  width: var(--px-200);
  margin-inline: auto;
  margin-top: var(--px-20);
}
.wpcf7 input[type=submit]:not(:disabled):hover {
  opacity: var(--opacity-hover);
  cursor: pointer;
}
.wpcf7 input[type=submit]:disabled {
  background: #ddd;
  border: 1px solid var(--gray_02);
  color: var(--gray_02);
}
.wpcf7 input[type=submit]:disabled:hover {
  pointer-events: none;
}
.wpcf7 .screen-reader-response {
  margin-bottom: var(--box-margin);
  padding: var(--px-10);
  background: var(--beiju_02);
}
.wpcf7 .screen-reader-response ul {
  display: none;
}
.wpcf7 .ajax-loader {
  position: absolute !important;
}
.wpcf7 .wpcf7-spinner {
  position: absolute !important;
}
.wpcf7 .wpcf7-not-valid {
  background: var(--beiju_02);
}
.wpcf7 .wpcf7-not-valid-tip {
  color: #cc0000;
}
.wpcf7 .wpcf7-response-output.wpcf7-validation-errors {
  margin-top: 20px;
  padding: 10px;
  background: var(--beiju_02);
}
.wpcf7 .wpcf7-not-valid-tip {
  font-size: 76%;
  color: #af2223;
}
.wpcf7 .wpcf7-list-item {
  margin-left: 0;
  margin-right: var(--px-20);
}
.wpcf7 .wpcf7-list-item input {
  width: auto;
}
.wpcf7 dl .attention {
  color: var(--color-attention);
}
.wpcf7 dl dt {
  color: var(--color-clinic-txt);
  font-family: var(--main-family);
  font-size: var(--h6-size);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.08em;
  padding-left: var(--px-22);
  position: relative;
  margin-bottom: var(--px-16);
}
.wpcf7 dl dt p {
  line-height: 1.5;
  letter-spacing: 0.08em;
}
.wpcf7 dl dt::before {
  position: absolute;
  content: "";
  display: block;
  background: currentColor;
  width: var(--px-12);
  height: var(--px-12);
  border-radius: 50%;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.wpcf7 dl dt .attention {
  background: var(--color-attention);
  color: var(--white);
  font-weight: 500;
  font-size: 68%;
  line-height: 1;
  padding: 0.15em 0.5em 0.25em;
  border-radius: var(--px-4);
  margin-left: 0.5em;
}
.wpcf7 dl dd + dt {
  margin-top: var(--item-margin);
}
.wpcf7 dl dd .wpcf7-form-control-wrap + .wpcf7-form-control-wrap {
  display: block;
  margin-top: var(--px-10);
}
.wpcf7 .age input[type=text] {
  width: auto;
}
.wpcf7 .btn-style {
  text-align: center;
}

.post-password-form {
  margin-bottom: 4em;
  margin-top: 2em;
}

/* 投稿 */
.main_post_body {
  padding-bottom: var(--section-padding);
}

.entry_archive_wrap {
  padding-bottom: var(--section-padding);
}

.entry_archive {
  padding-top: var(--section-padding);
}
.entry_archive .entry_ex {
  display: flex;
  gap: calc(4 / var(--sp_calc)) calc(12 / var(--sp_calc));
  margin-bottom: var(--px-10);
}
.entry_archive .entry_ex .date {
  font-family: var(--eb-garamond);
  font-size: calc(16 / var(--sp_calc));
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.06em;
}
.entry_archive .entry_ex .cate_label a {
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(89 / var(--sp_calc));
  height: calc(22 / var(--sp_calc));
  background: var(--beiju_04);
  border-radius: var(--px-3);
  color: var(--white);
  font-weight: 500;
  font-size: calc(13 / var(--sp_calc));
  line-height: 1;
  letter-spacing: 0.04em;
  padding-bottom: calc(0.7 / var(--sp_calc));
  transition: var(--transition-hover);
  color: var(--white);
  text-decoration: none;
}
@media (min-width: 768px) {
  .entry_archive .entry_ex .cate_label a {
    padding-bottom: 3px;
  }
}
@media (min-width: 768px) {
  .entry_archive .entry_ex {
    gap: 18px;
  }
  .entry_archive .entry_ex .date {
    font-size: 20px;
  }
  .entry_archive .entry_ex .cate_label a {
    width: 104px;
    height: 26px;
    font-size: 15px;
  }
}
.entry_archive .entry_title {
  margin: 0;
  padding: 0;
  font-family: var(--title-family);
  font-weight: var(--title-family-weight);
  line-height: var(--title-line-height);
  letter-spacing: var(--title-letter-spacing);
  font-size: var(--h4-size);
  border-bottom: var(--px-1) solid var(--blue_02);
  padding-bottom: calc(12 / var(--sp_calc));
  position: relative;
  text-align: left;
}
.entry_archive .entry_title::before, .entry_archive .entry_title::after {
  display: none;
}
@media (min-width: 768px) {
  .entry_archive .entry_title {
    padding-bottom: 16px;
  }
}
.entry_archive .entry_title a {
  text-decoration: none;
  color: var(--main_txt);
}
.entry_archive .entry {
  margin-top: var(--px-20);
}
.entry_archive .entry.mce-content-body {
  max-width: 100%;
  padding-bottom: 0;
}
.entry_archive .entry p + p {
  margin-top: calc(0.35em * var(--p-line-height));
}

.pagenav_archive {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--px-10);
}
.pagenav_archive .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.2em;
  height: 1.95em;
  padding-bottom: 0.085em;
  background: var(--white);
  border: var(--px-1) solid var(--gray_02);
  border-radius: var(--px-3);
  color: var(--main_txt);
  text-decoration: none;
  font-size: var(--px-15);
  line-height: 1;
  letter-spacing: 0;
  overflow: hidden;
  transition: var(--transition-hover);
}
.pagenav_archive .page-numbers.current {
  background: var(--gradient-black);
  color: var(--white);
  font-size: 500;
}
@media (hover: hover) {
  .pagenav_archive .page-numbers:hover {
    cursor: pointer;
    background: var(--navy_01);
    color: var(--white);
    opacity: 1;
  }
  .pagenav_archive .page-numbers:hover.current {
    background: var(--gradient-black);
    opacity: var(--opacity-hover);
  }
}
@media (min-width: 768px) {
  .pagenav_archive .page-numbers {
    font-size: 16px;
  }
}

.pagenav_single {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--px-14) var(--px-30);
  font-size: calc(14 / var(--sp_calc));
}
.pagenav_single a {
  display: flex;
  align-items: center;
  gap: var(--px-5);
  color: var(--main_txt);
  text-decoration: none;
}
.pagenav_single .svg-icons {
  width: 0.5em;
  aspect-ratio: 63/107;
}
.pagenav_single .pagenav_single_next {
  margin-right: auto;
}
.pagenav_single .pagenav_single_previous {
  margin-left: auto;
}
@media (min-width: 768px) {
  .pagenav_single {
    font-size: 16px;
  }
}

.slide_main {
  position: relative;
}
.slide_main .item {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  opacity: 0;
  transition: 0.3s;
  z-index: -1;
}
.slide_main .item.active {
  opacity: 1;
  z-index: 1;
  position: inherit;
}
.slide_main .item:first-child .arrow-prev, .slide_main .item:last-child .arrow-next {
  display: none;
}
.slide_main .item .caption {
  background: rgba(0, 0, 0, 0.3);
  bottom: 0;
  color: #fff;
  font-size: 20px;
  left: 0;
  line-height: 1.6;
  padding: 13px 10px;
  position: absolute;
  text-align: center;
  width: 100%;
}
.slide_main .item img {
  margin: 0;
}
.slide_main .arrow-prev,
.slide_main .arrow-next {
  height: 60px;
  width: 40px;
  position: absolute;
  top: 50%;
  display: block;
  z-index: 2;
  margin-top: -30px;
}
.slide_main .arrow-prev:hover,
.slide_main .arrow-next:hover {
  cursor: pointer;
}
.slide_main .arrow-prev::before,
.slide_main .arrow-next::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px;
  background-image: url("../img/default/icon_slidearrow_01.svg");
}
.slide_main .arrow-prev {
  left: 10px;
}
@media (max-width: 767px) {
  .slide_main .arrow-prev {
    left: 0px;
  }
}
.slide_main .arrow-next {
  right: 10px;
}
@media (max-width: 767px) {
  .slide_main .arrow-next {
    right: 0px;
  }
}
.slide_main .arrow-next::before {
  transform: scale(-1, 1);
}
#tinymce .slide_main .item:first-child {
  opacity: 1;
  z-index: 1;
  position: inherit;
}

.slide_thumb {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  margin-bottom: 30px;
}
.slide_thumb .item {
  position: relative;
  transition: 0.3s;
}
.slide_thumb .item:hover {
  cursor: pointer;
  opacity: 0.8;
}
.slide_thumb .item.thumbnail-current:hover {
  opacity: 1;
}
.slide_thumb .item.thumbnail-current::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border: 2px solid #0f406c;
  border-radius: 0;
}
.slide_thumb .item img {
  margin: 0;
}

@media (min-width: 768px) {
  .slide_wrap_horizontal {
    display: flex;
    justify-content: space-between;
  }
  .slide_wrap_horizontal .slide_main {
    flex: 0 0 75%;
  }
  .slide_wrap_horizontal .slide_thumb {
    flex: 0 0 22%;
  }
  .slide_wrap_horizontal .slide_thumb .item {
    flex: 0 0 48%;
    margin-bottom: 4%;
    margin-right: 4%;
  }
  .slide_wrap_horizontal .slide_thumb .item:nth-child(2n) {
    margin-right: 0;
  }
}
@media (max-width: 767px) {
  .slide_wrap_horizontal .slide_main {
    margin-bottom: 1%;
  }
  .slide_wrap_horizontal .slide_thumb .item {
    width: 15.8%;
    width: 15.8333333333%;
    max-width: 15.8333333333%;
    margin-right: 1%;
    margin-bottom: 1%;
  }
  .slide_wrap_horizontal .slide_thumb .item:nth-child(6n) {
    margin-right: 0;
  }
}

.slide_wrap_vertical .slide_main {
  margin-bottom: 1%;
}
.slide_wrap_vertical .slide_thumb .item {
  width: 15.8%;
  width: 15.8333333333%;
  max-width: 15.8333333333%;
  margin-right: 1%;
  margin-bottom: 1%;
}
.slide_wrap_vertical .slide_thumb .item:nth-child(6n) {
  margin-right: 0;
}

.point_box {
  display: flex;
  flex-direction: column;
  margin-top: 60px;
}
.columns .point_box:first-child {
  margin-top: 60px;
}
.point_box p {
  margin-bottom: 30px;
}
.point_box p.image {
  margin-top: auto;
  margin-bottom: 0;
}

h4.point_title {
  margin-top: 20px;
  text-align: center;
  width: 100%;
}
h4.point_title .subtext {
  font-size: 2rem;
}

.notice_box {
  align-items: center;
}
.notice_box .notice_title {
  background: var(--bg_kasou);
  border-radius: 6px;
  padding: 25px 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) {
  .notice_box .notice_title {
    margin-right: 30px;
    flex: 2;
  }
}
@media (max-width: 767px) {
  .notice_box .notice_title {
    margin-bottom: 20px;
  }
}
.notice_box .notice_title h4 {
  color: #0f406c;
  display: block;
  position: relative;
  text-align: center;
}
.notice_box .notice_title h4::before {
  position: absolute;
  content: "";
  background: #0f406c;
  width: 100%;
  left: 0;
  bottom: 0;
  height: 1px;
}
@media (min-width: 768px) {
  .notice_box .notice_title h4 {
    margin-bottom: 0;
  }
}
.notice_box .notice_text ul, .notice_box .notice_text p {
  width: 100%;
}
.notice_box .notice_text ul:first-child, .notice_box .notice_text p:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .notice_box .notice_text {
    display: flex;
    flex-wrap: wrap;
    flex: 5;
    align-items: center;
  }
}

.icon_tags {
  padding-top: 2.5em;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5em;
}
.icon_tags a {
  background: #f1f1f1;
  border-radius: 3px;
  color: #0f406c;
  display: block;
  font-size: 92%;
  line-height: 1.25;
  padding: 0.5em 0.75em;
  text-decoration: none;
}
.icon_tags a:hover {
  background: #0f406c;
  color: #fff;
}

.entry_search_result_lead {
  display: flex;
  gap: 10px;
  font-size: 88%;
  margin-bottom: 2em;
  margin-top: 2em;
}

.entry_search_result_wrap .entry_title {
  font-size: 20px;
  margin-bottom: 0.35em;
}
@media (min-width: 768px) {
  .entry_search_result_wrap .entry_title {
    font-size: 22px;
  }
}
.entry_search_result_wrap .entry_archive {
  display: flex;
  gap: 20px;
}
.entry_search_result_wrap .entry_archive .entry_content {
  flex: 1 1 auto;
}
.entry_search_result_wrap .entry_archive .entry_thumbnail {
  flex: 0 0 min(20% , 140px);
  width: min(20% , 140px);
}
.entry_search_result_wrap .entry_archive .entry_thumbnail img {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1;
  width: 100%;
  max-width: none;
  height: auto;
}
.entry_search_result_wrap .entry_archive .entry {
  font-size: 88%;
}
.entry_search_result_wrap .link {
  font-size: 92%;
}
.entry_search_result_wrap .link::before {
  content: "［ ";
}
.entry_search_result_wrap .link::after {
  content: " ］";
}

.entry_ex_sub {
  gap: 0;
  justify-content: flex-end;
  font-size: 82%;
  margin-top: 10px;
  margin-bottom: 0;
}
.entry_ex_sub .entry_date,
.entry_ex_sub .entry_categories {
  padding-left: 0;
}
.entry_ex_sub .entry_categories::before {
  content: "｜";
}

/*****//*# sourceMappingURL=base.css.map */