/******************************************************************
Theme Name: CUBE GAMMA THEME
Theme URI: http://cube096.com
Description: CUBEが自信をもってお届けするレスポンシブウェブデザインテーマ
Author: CUBE CO.,LTD.
Author URI: http://cube096.com
Version: beta
Tags: fluid-layout, responsive-layout, accessibility-ready, translation-ready, microformats, rtl-language-support
*/

/* ------------------------------ */
/* CSS変数/カスタムプロパティ */
/* ------------------------------ */
:root {
  --leading-trim: calc((1em - 1lh) / 2);
  --font-size__base: 16;
  --font-family__gothic: "Zen Kaku Gothic New", sans-serif;
  --font-family__mincho: "Zen Old Mincho", sans-serif;
  --font-family__en: "Marcellus", sans-serif;
  --font-family__noto-sans: "Noto Sans JP", sans-serif;
  --font-family__noto-serif: "Noto Serif", sans-serif;
  --max-width__base: 1920;
  --width__contents: 1200;
  --space-inline__base: 25;
  --space__section--lg: 128;
  --space__section--md: 96;
  --space__section--sm: 64;
  --space__section--xs: 48;
  --color__text: #333;
  --color__main: #f89c1b;
  --color__main-light: #f7bc1a;
  --color__main-lightest: #fdf5e3;
  --color__ivory: #fbfaf6;
  --color__gray: #91887e;
  --opacity__hover: 0.7;
  --duration__base: 0.3s;

  --_128: 128;
  --_96: 96;
  --_80: 80;
  --_61: 61;
  --_48: 48;
  --_45: 45;
  --_37: 37;
  --_32: 32;
  --_24: 24;
  --_14: 14;
}
@media (max-width: 820px) {
  :root {
    --space-inline__base: 19;
    --space__section--lg: 64;
    --space__section--md: 48;
    --space__section--sm: 32;
    --space__section--xs: 24;

    --_128: 80;
    --_96: 64;
    --_80: 56;
    --_61: 42;
    --_48: 36;
    --_45: 32;
    --_37: 24;
    --_32: 20;
    --_24: 20;
    --_14: 12;
  }
}
@media (max-width: 640px) {
  :root {
    --max-width__base: 500;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}
* {
  margin: 0;
}
html,
body {
  height: 100%;
}
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}
input,
button,
textarea,
select {
  font: inherit;
}
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}
#root,
#__next {
  isolation: isolate;
}
ol,
ul {
  list-style-type: none;
  margin: 0;
}
legend,
menu,
ol,
ul {
  padding: 0;
}
a {
  color: var(--color__text);
  text-decoration: none;
}
p {
  overflow-wrap: break-word;
  text-align: justify;
}
body {
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  font-style: normal;
}
body img {
  max-width: 100%;
  height: auto;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  /*--- ▼英字見出し、数字 ---*/
  /*font-family: 'Cinzel', serif;*/
  /*font-family: 'Open Sans', sans-serif;*/
  /*font-family: 'Lato', sans-serif;*/
  /*font-family: 'Gilda Display', serif;*/
  /*font-family: 'Cinzel', serif;*/

  /*--- ▼日本語見出し ---*/
  /*font-family: 'Noto Sans JP', sans-serif;*/
  /*font-family: 'Noto Serif JP', serif;*/
  /*font-family: 'Zen Maru Gothic', sans-serif;*/
  /*font-family: 'Zen Old Mincho', serif;*/

  font-weight: 400;
  line-height: 1.3;
  font-style: normal;
}
table {
  border-collapse: collapse;
}

/* recaptcha badge
----------------------------------------------------------- */
.grecaptcha-badge {
  z-index: 10000;
  bottom: 75px !important;
}
/* ページネーション
----------------------------------------------------------- */
/*アーカイブ用*/
.nav-links {
  display: -webkit-flex;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.nav-links .page-numbers {
  display: block;
  width: 45px;
  height: 45px;
  line-height: 45px;
  text-align: center;
  background-color: #fff;
  transition: all ease 0.5s;
  border-radius: 3px;
  border: 1px solid #d5d5d5;
  margin: 0 5px;
}
.nav-links .page-numbers.current,
.nav-links .page-numbers:hover {
  background-color: #f2f2f2;
}
.nav-below {
  display: -webkit-flex;
  display: flex;
  justify-content: center;
}
.next.page-numbers,
.prev.page-numbers {
  padding: 0 5px;
}
/*シングル用*/
.single .nav-below {
  display: inherit;
  margin-top: 45px;
}
.single .nav-below:after {
  content: "";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}
.single .nav-below a {
  background-color: #fff;
  text-decoration: none;
  padding: 5px;
  font-size: 0.9em;
  line-height: 1.5;
  transition: all ease 0.5s;
  border: 1px solid #d5d5d5;
}
.single .nav-below a:hover {
  background-color: #fff8f0;
}
.single .nav-below .prev {
  padding-left: 65px;
  position: relative;
}
.single .nav-below .next {
  padding-right: 65px;
  position: relative;
}
.single .nav-below .prev::before,
.single .nav-below .next::before {
  content: "";
  width: 40px;
  height: 40px;
  background-color: var(--color__main);
  border-radius: 20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.single .nav-below .prev::before {
  left: 10px;
}
.single .nav-below .next::before {
  right: 10px;
}
.single .nav-below .prev::after,
.single .nav-below .next::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}
.single .nav-below .prev::after {
  left: 25px;
  border-right: 7px solid #fff;
  border-left: 0;
}
.single .nav-below .next::after {
  right: 25px;
  border-left: 7px solid #fff;
  border-right: 0;
}
.prev {
  width: 48%;
  float: left;
}
.next {
  width: 48%;
  float: right;
  text-align: right;
}
.prev_title,
.next_title {
  font-size: 12px;
}
.next p {
  text-align: right;
}
.next p,
.prev p {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1;
  margin-top: 5px;
}
.prev img {
  float: left;
  margin-right: 10px;
}
.next img {
  float: right;
  margin-left: 10px;
}
.prevAndNextLeft a:before {
  content: "\f053";
  margin-right: 5px;
  font-family: FontAwesome;
}
.prevAndNextRight a:after {
  content: "\f054";
  margin-left: 10px;
  font-family: FontAwesome;
}
.prevAndNextLeft {
  width: 50%;
  float: left;
}
.prevAndNextRight {
  width: 50%;
  float: left;
}
.prevAndNextLeft {
  text-align: left;
}
.prevAndNextRight {
  text-align: right;
}
/*
 animation
----------------------------------------------------------- */
.fadein {
  opacity: 0.1;
  transition: all ease 1s;
  -webkit-transition: all ease 1s;
  -moz-transition: all ease 1s;
}
.on .fadein,
.on.fadein {
  opacity: 1;
}
.totop {
  opacity: 0.1;
  transform: translateY(30px);
  transition: all 1s;
}
.on .totop,
.on.totop {
  opacity: 1;
  transform: translateY(0);
}
.fadeinleft {
  opacity: 0.1;
  -webkit-transform: translateX(-50px);
  transform: translateX(-50px);
  transition: all ease 1s;
  -webkit-transition: all ease 1s;
  -moz-transition: all ease 1s;
}
.on .fadeinleft,
.on.fadeinleft {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}
.fadeinright {
  opacity: 0.1;
  -webkit-transform: translateX(50px);
  transform: translateX(50px);
  transition: all ease 1s;
  -webkit-transition: all ease 1s;
  -moz-transition: all ease 1s;
}
.on .fadeinright,
.on.fadeinright {
  opacity: 1;
  -webkit-transform: translateX(0px);
  transform: translateX(0px);
}
.no2 {
  transition-delay: 0.3s;
}
.no3 {
  transition-delay: 0.6s;
}
.no4 {
  transition-delay: 0.9s;
}
.no5 {
  transition-delay: 1.2s;
}
/*
 Head
----------------------------------------------------------- */
.header {
  width: 100%;
}
.header_logo {
  transition: opacity ease var(--duration__base);
}
.header_logo:hover {
  opacity: 0.7;
}

/*
 gNavi
----------------------------------------------------------- */
.navwrap {
  width: 100%;
  background-color: var(--color__ivory);
  position: fixed;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
  top: 0;
  left: 0;
  z-index: 998;
  transition: all ease 0.5s;
}
/* サブページのヘッダー */
.navwrap:not(:has(h1)) {
  filter: drop-shadow(0 3px 6px rgba(145, 136, 126, 0.08));
  border-radius: 0 0 10px 10px;
}
.navwrap p svg,
.navwrap h1 svg {
  height: 63px;
  width: auto;
  margin-left: clamp(15px, 2.4vw, 50px);
}
.navwrap > ul {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  align-items: center;
}
.navwrap > ul > li {
  margin-inline: calc(20rem / var(--font-size__base, 16));
  text-align: center;
  transition: all ease 0.5s;
  position: relative;
}
.navwrap > ul > li:last-child {
  margin-right: clamp(15px, 2.5vw, 50px);
}
.navwrap > ul > li p {
  display: inline-block;
  padding: 20px 0;
}
.navwrap > ul > li:hover > p {
  color: var(--color__main);
}
.navwrap ul li ul {
  position: absolute;
  top: 68px;
  left: 50%;
  transform: translateX(-50%) scaleY(0);
  transform-origin: center top;
  z-index: 8999;
  display: block;
  background-color: #fff;
  width: 190px;
  transition: all ease 0.5s;
}
.navwrap ul li:hover ul {
  transform: translateX(-50%) scaleY(1);
}
.navwrap ul li ul {
  border: 1px solid var(--color__main);
  box-sizing: border-box;
}
.navwrap ul li ul li {
  font-size: 14px;
  transition: all ease 0.5s;
}
.navwrap ul li ul li:not(:last-child) {
  border-bottom: 1px dashed var(--color__main);
}
.navwrap ul li ul li:hover {
  background-color: #fff8f0;
}
.navwrap ul li ul li a {
  padding: 10px;
  width: 100%;
}
.navwrap * {
  transition: all ease 0.5s;
}
.top_back {
  height: 45px;
  width: 45px;
  border-radius: 25px;
  background-color: var(--color__main);
  position: fixed;
  right: 15px;
  bottom: 15px;
  display: grid;
  place-content: center;
  z-index: 10000;
  opacity: 0;
  transition: all ease 0.5s;
}
.top_back.view {
  opacity: 1;
}
.top_back img {
  height: 13px;
  width: auto;
}
/* パンくずリスト
----------------------------------------------------------- */
.breadcrumb__list {
  display: flex;
  width: min(90%, 1200px);
  margin-inline: auto;
  flex-wrap: wrap;
  font-size: 14px;
}
.breadcrumb__item:not(:last-child)::after {
  content: "/";
  margin: 0 0.3rem;
}
.breadcrumb__item a {
  color: #9d9d9d;
}
.breadcrumb__item:last-child a {
  color: #222;
}
/*
共通
----------------------------------------------------------- */
.pc {
  display: block;
}
br.pc {
  display: inherit;
}
.sp {
  display: none;
}
br.sp {
  display: none;
}
.pc1100 {
  display: block;
}
br.pc1100 {
  display: inherit;
}
.sp1100 {
  display: none;
}
br.sp1100 {
  display: none;
}
.pc640 {
  display: block;
}
br.pc640 {
  display: inherit;
}
.sp640 {
  display: none;
}
br.sp640 {
  display: none;
}
/* .inner {
  width: min(90%, 1200px);
  margin-inline: auto;
  padding: clamp(50px, 6.8vw, 130px) 0;
} */
.flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.flex .img img {
  width: 100%;
  height: auto;
}
#main {
  overflow: hidden;
}
#container {
  position: relative;
}
.more_btn {
  display: block;
  background-color: var(--color__main);
  width: min(100%, 250px);
  color: #fff;
  transition: all ease 0.5s;
  text-align: center;
  padding: 15px;
  position: relative;
  margin: 0 5px 5px 0;
}
.more_btn::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent #fff transparent;
  border-width: 0px 0px 10px 10px;
  position: absolute;
  inset: auto 5px 5px auto;
  transition: all ease 0.5s;
}
.more_btn::after {
  content: "";
  width: 100%;
  height: 100%;
  top: 5px;
  left: 5px;
  border: 1px solid var(--color__main);
  position: absolute;
  transition: all ease 0.5s;
  z-index: -1;
}
.more_btn:hover::before {
  inset: auto 2px 2px auto;
}
.more_btn:hover::after {
  top: 0;
  left: 0;
}
.anchor {
  padding-top: clamp(80px, 7.8vw, 150px);
  margin-top: calc(clamp(80px, 7.8vw, 150px) * -1);
}
.tac {
  text-align: center;
}
.tal {
  text-align: left;
}
.tar {
  text-align: right;
}
.taj {
  text-align: justify;
}
.linkbox {
  position: relative;
  z-index: 5;
}
.linkbox.tac a {
  margin: 0 auto;
}
.linkbox.tar a {
  margin: 0 0 0 auto;
}
.no_link {
  pointer-events: none !important;
}
.pt0 {
  padding-top: 0 !important;
}
.pb0 {
  padding-bottom: 0 !important;
}
.txt_only {
  width: 100% !important;
}
.txt_link {
  text-decoration: underline;
  transition: all ease 0.5s;
}
.txt_link:hover {
  opacity: 0.7;
}
.img_hover {
  overflow: hidden;
}
.img_hover img {
  transition: all ease 0.5s;
}
.img_hover:hover img {
  transform: scale(1.2, 1.2);
}
.js-accordion > li {
  position: relative;
}
.js-accordion > li .ttl {
  position: relative;
}
.js-accordion > li .btn {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  z-index: 1;
}
.js-accordion .ttl::before,
.js-accordion .ttl::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 50px;
  transform: translateY(-50%);
  transition: all ease 0.3s;
  background-image: url("./library/images/qa_open.svg");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  padding: 5px;
}
.js-accordion .ttl::after {
  background-image: url("./library/images/qa_close.svg");
  opacity: 0;
}
.js-accordion .open .ttl::before {
  opacity: 0;
}
.js-accordion .open .ttl::after {
  opacity: 1;
}
.js-accordion .box {
  display: none;
}
.js-modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 10005;
  backface-visibility: hidden;
}
.js-modal .wrap {
  width: 100%;
  height: 100%;
}
.js-modal .wrap_box {
  height: 100%;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(57, 53, 42, 0.7);
}
.js-modal .scloll_area {
  transform: scale(0.5);
  transition: all ease 1s;
}
.js-modal.open .scloll_area {
  transform: scale(1);
}
.js-modal .content {
  width: 100%;
  height: auto;
  height: 85vh;
  padding: 60px 100px;
  position: relative;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: #fff;
}
.js-modal .js-sclollarea {
  width: min(90%, 1200px);
  margin: 30px;
  max-height: 90%;
  position: relative;
}
.js-modal .js-modalclose {
  cursor: pointer;
  z-index: 100000;
  position: absolute;
  top: 30px;
  right: 30px;
  width: 28px;
  height: 28px;
  background-image: url("./library/images/modal_close.svg");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  transition: all ease 0.5s;
}
.js-modal .js-modalclose:hover {
  transform: rotate(90deg);
}
.js-tabcontent {
  display: none;
}
/*
 TOP
----------------------------------------------------------- */

/*
 contact
----------------------------------------------------------- */
.cont_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 60px;
}
.cont_list li {
  width: 32%;
  text-align: center;
  background-color: #bebebe;
  color: #fff;
  padding: 10px;
  border-radius: 5px;
  font-weight: bold;
}
.cont_page {
  background-color: var(--color__main) !important;
}
.cont_list li:nth-of-type(2) {
  margin: 0 2%;
}
.wpcf7 dl,
.mw_wrap dl {
  width: 100%;
  margin-bottom: 30px;
}
.wpcf7 dt,
.mw_wrap dt {
  width: 100%;
  margin-bottom: 3px;
}
.wpcf7 dt span,
.mw_wrap dt span {
  color: #e43836;
  padding-left: 1em;
  font-size: 11px;
}
.wpcf7 dd,
.mw_wrap dd {
  width: 100%;
}
.wpcf7 dl.form_sub,
.mw_wrap dl.form_sub {
  margin-bottom: 10px;
}
.wpcf7 dl.form_sub dt p,
.mw_wrap dl.form_sub dt p {
  font-size: 16px;
}
.wpcf7 dt.form_sub_ttl,
.mw_wrap dt.form_sub_ttl {
  margin-bottom: 5px;
}
.wpcf7-list-item {
  margin: 0 1em 0 0;
  display: block;
  margin-bottom: 5px;
}
.wpcf7-date {
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #d9e2e9;
  padding: 5px;
  font-size: 0.9rem;
  min-height: 38px;
}
.wpcf7 .subbtn,
.mw_wrap .subbtn {
  width: fit-content;
  margin: 30px auto 0;
}
.wpcf7 .flex,
.mw_wrap .flex {
  justify-content: center;
}
.wpcf7 .flex .subbtn,
.mw_wrap .flex .subbtn {
  margin: 30px 15px 0;
}
.subbtn input {
  width: 300px;
  padding: 10px;
  color: #fff;
  border-style: none;
  background-color: var(--color__main);
  border-radius: 5px;
  transition: all ease 0.5s;
}
.subbtn input:hover {
  opacity: 0.7;
}
.wpcf7 .flex .subbtn:first-of-type input,
.mw_wrap .flex .subbtn:first-of-type input {
  background-color: #fff8f0;
  color: #222;
}
.wpcf7-text,
.mw_txt {
  width: 100%;
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #d9e2e9;
  padding: 5px;
  font-size: 0.9rem;
  min-height: 38px;
}
.wpcf7-text:focus,
.wpcf7-textarea:focus {
  background-color: #fafeff;
}
.wpcf7-select,
.mw_select,
.wpcf7-file,
.me_file {
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #d9e2e9;
  padding: 5px 10px;
  font-size: 0.9rem;
  min-height: 38px;
}
.wpcf7-textarea,
.mw_area {
  width: 100%;
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #d9e2e9;
  padding: 5px;
  font-size: 0.9rem;
}
.wpcf7 dd .sub,
.mw_wrap dd .sub {
  font-size: 14px;
}
.shonin .wpcf7-list-item {
  margin: 15px auto 0;
  text-align: center;
  display: block;
  font-size: 14px;
}
.wpcf7 .flex,
.mw_wrap .flex {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.wpcf7 .flex .subbtn,
.mw_wrap .flex .subbtn {
  margin: 30px 15px 0;
}
.wpcf7 .flex .subbtn:first-of-type input,
.mw_wrap .flex .subbtn:first-of-type input {
  background-color: #cccccc;
}
.priva {
  margin-top: 30px;
  font-size: 14px;
}
.priva p {
  text-align: left;
}
.priva h3 {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 5px;
}
.priva h3 span {
  font-size: 14px;
  margin-left: 15px;
  display: inline-block;
}
.priva ul {
  width: 100%;
  overflow-y: scroll;
  height: 250px;
  border: 1px solid #d9e2e9;
  background: #fff;
  padding: 20px;
}
.priva li:not(:last-child) {
  margin-bottom: 20px;
}
.priva li h4 {
  margin-bottom: 5px;
  padding-bottom: 5px;
  border-bottom: 1px solid #2b1a02;
  font-size: 14px;
  font-weight: 500;
}
.privabtn {
  text-align: center;
  margin-top: 30px;
  font-weight: bold;
}
/*
 エントリー
----------------------------------------------------------- */
.entry_area .inner {
  width: min(90%, 1000px);
  margin-inline: auto;
  padding: 100px 0;
}
.entry_fi {
  padding: 80px 100px;
  background-color: #f7fafc;
}
.entry_fi .wpcf7 {
  width: auto;
  margin: 0;
  max-width: 100%;
}
.entry_fi .wpcf7 dt p,
.entry_fi .mw_wrap dt p,
.entry_fi .address p {
  font-size: 15px;
}
.entry_fi .address > div > p,
.wpcf7 .sub_ttl p,
.mw_wrap .sub_ttl p {
  font-size: 15px;
}
.entry_fi .wpcf7-list-item {
  display: inline-block;
}
.entry_fi .birth > p {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.entry_fi .birth > p .wpcf7-select {
  width: 150px;
}
.entry_fi .birth > p small {
  padding: 0 10px;
}
.entry_fi .address,
.entry_fi .check .wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.entry_fi .address > div {
  width: 49%;
}
.entry_fi .address > div .wpcf7-select {
  width: 100%;
}
.entry_fi .check .wpcf7-list-item {
  width: 49%;
  display: block;
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #d9e2e9;
  font-size: 0.9rem;
  margin-right: 0;
}
.entry_fi .check .wpcf7-list-item label {
  width: 100%;
  height: 100%;
  display: block;
  padding: 5px 10px;
}
.entry_fi .file .sub {
  font-size: 14px;
}
.entry_fi .wpcf7-file {
  width: 100%;
  margin-bottom: 5px;
}
/*
 news index-archives page（サイドバー無し）
----------------------------------------------------------- */
.archivetitle {
  font-size: clamp(20px, 1.6vw, 30px);
  margin: 0 auto clamp(8px, 0.8vw, 15px);
  width: 100%;
  font-weight: 500;
}
.archivetitle span {
  font-size: clamp(17px, 1vw, 20px);
  padding-right: clamp(8px, 0.8vw, 15px);
}
.g_list {
  width: min(100%, 1200px);
  margin: 0 auto clamp(25px, 2.6vw, 50px);
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  padding: 10px 15px 10px 112px;
  background: #fff8f0;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);
  position: relative;
}
.g_list p {
  padding: 10px 0;
  position: absolute;
  top: 10px;
  left: 15px;
  font-weight: bold;
  line-height: 1;
}
.g_list .box {
  padding: 5px;
}
.g_list .box a {
  color: #000;
  background: #fff;
  padding: 3px 10px;
  font-size: 0.9rem;
  transition: all ease 0.5s;
  -webkit-transition: all ease 0.5s;
  -moz-transition: all ease 0.5s;
}
.g_list .box a:hover {
  background: var(--color__main);
  color: #fff;
}
.bcontwrap ul {
  display: grid;
  gap: clamp(25px, 2.6vw, 50px);
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: clamp(30px, 2.3vw, 45px);
}
.bcontwrap ul li {
  position: relative;
  transition: all ease 0.5s;
  background-color: #fff8f0;
  display: grid;
}
.bcontwrap ul li > a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.bcontwrap ul li .img {
  overflow: hidden;
}
.bcontwrap ul li .img img {
  aspect-ratio: 5/3;
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: all ease 0.5s;
}
.bcontwrap ul li:hover .img img {
  transform: scale(1.2, 1.2);
}
.bcontwrap ul li .txt {
  padding: clamp(15px, 1.3vw, 25px);
  display: flex;
  flex-direction: column;
}
.bcontwrap ul li .txt span:first-of-type {
  font-size: 14px;
  margin-bottom: 5px;
  color: #999;
  line-height: 1.3;
}
.bcontwrap ul li .txt h3 {
  font-size: 16px;
  margin-bottom: 5px;
  font-weight: 600;
  transition: all ease 0.5s;
}
.bcontwrap ul li:hover .txt h3 {
  color: var(--color__main);
}
.bcontwrap ul li .txt p:not(.more) {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: #535353;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 10px;
}
.bcontwrap ul li .txt .more {
  text-align: center;
  padding-top: 14px;
  margin-top: auto;
  line-height: 1.3;
  border-top: 1px solid #cecece;
  font-size: 14px;
  color: #535353;
  transition: all ease 0.5s;
  display: block;
}
.bcontwrap ul li:hover .txt .more {
  color: var(--color__main);
}
.bcontwrap ul li .txt .cat {
  margin-bottom: 15px;
}
.news_info {
  margin-bottom: 30px;
}
.news_info span:first-of-type {
  margin-right: 5px;
  font-weight: normal;
  font-size: 15px;
}
.cat a {
  color: #fff;
  padding: 3px 10px;
  font-size: 14px;
  white-space: nowrap;
  margin: 3px 5px 3px 0;
  font-weight: normal;
  transition: all ease 0.5s;
  display: inline-block;
  line-height: 1.3;
  background-color: var(--color__main);
}
.cat a:hover {
  background-color: var(--color__main);
  color: #fff;
}
.ttl_maru {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 10px;
  color: var(--color__main);
  position: relative;
  padding-left: 23px;
}
.ttl_maru::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  padding: 5px;
  border-radius: 10px;
  background-color: #fff;
  border: 4px solid var(--color__main);
}
.list_wrap {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.l_cotent {
  width: 70%;
  margin-right: 5%;
}
.news_list {
  margin-bottom: clamp(30px, 2.3vw, 45px);
}
.news_list > li {
  background-color: #fff;
  padding: 20px;
  border: 1px solid #ccc;
  border-left: 9px solid var(--color__main);
  margin-bottom: 20px;
  position: relative;
  transition: all ease 0.5s;
}
.news_list > li:hover {
  background-color: #fff8f0;
}
.news_list > li > a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.news_list .news_info {
  margin-bottom: 0;
}
/*アイキャッチなしの場合は削除*/
.news_list > li dl {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.news_list > li dt {
  width: 30%;
}
.news_list > li dt img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/*アイキャッチなしの場合は削除 ここまで*/
.news_list > li dd {
  width: 67%;
  /*▼アイキャッチなしの場合*/
  /*width: 100%;*/
}
.news_list > li dd a:hover {
  opacity: 0.7;
}
.news_list > li dd .news_info {
  padding-top: 5px;
  border-top: 1px solid #ccc;
  margin-bottom: 0;
}
.news_list > li dd h3 {
  font-size: 20px;
  background: none;
  padding-left: 0;
  text-align: justify;
  margin-bottom: 5px;
}
.news_list > li dd p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-bottom: 10px;
  color: #555;
  font-size: 14px;
  line-height: 1.5;
}
.sidebar {
  width: 25%;
}
.widgettitle {
  padding: 0 0 5px 12px;
  margin-bottom: 10px;
  border-bottom: 1px solid #ccc;
  position: relative;
  padding-left: 15px;
}
.widgettitle::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  padding: 5px;
  border-radius: 6px;
  background-color: var(--color__main);
}
.widget ul:not(.children) {
  margin-bottom: 30px;
}
.widget ul li:not(:last-child) a {
  margin-bottom: 10px;
}
.widget ul li a {
  width: 100%;
  font-size: 0.9rem;
  display: block;
  padding-left: 25px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  position: relative;
  transition: all ease 0.5s;
  -webkit-transition: all ease 0.5s;
  -moz-transition: all ease 0.5s;
}
.widget ul li a::before {
  content: "▶";
  font-size: 10px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.widget ul li a:hover {
  color: var(--color__main);
}
#archives-dropdown-2 {
  width: 100%;
  font-size: 0.9rem;
  padding: 10px 15px;
  border: 0px;
  background-color: #f0f0f0;
}
/* news single page
----------------------------------------------------------- */
.stitle {
  font-size: 22px;
  font-weight: 500;
  line-height: 1.3;
  color: var(--color__main);
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid #ccc;
  position: relative;
  text-align: justify;
}
.stitle::before {
  content: "";
  background-color: var(--color__main);
  bottom: -1px;
  position: absolute;
  left: 0;
  width: 50px;
  height: 1px;
}
.singlecont a {
  text-decoration: underline;
  color: inherit;
  font-weight: inherit;
}
.singlecont h1,
.singlecont h2,
.singlecont h3,
.singlecont h4,
.singlecont h5,
.singlecont h6 {
  line-height: inherit;
  font-weight: bold;
}
/*.singlecont {
overflow:auto;
}
.singlecont h1 {
font-size:20px;
line-height: 1.3;
color: var(--color__main);
padding-bottom: 10px;
margin-bottom: 10px;
border-bottom: 1px solid #ccc;
position: relative;
}
.singlecont h1::before{
content: "";
height: 1px;
width: 50px;
background-color: var(--color__main);
position: absolute;
bottom: -0.5px;
left: 0;
}
.singlecont h2 {
font-size:18px;
padding-bottom: 10px;
margin-bottom: 15px;
position: relative;
color: var(--color__main);
text-align: justify;
}
.singlecont h3 {
border-left: 1px solid var(--color__main);
padding: 0 10px;
margin-bottom:16px;
color: var(--color__main);
background: none;
}
.singlecont h4 {
background: var(--color__main);
color: #FFF;
padding: 1px 10px 0;
margin-bottom:16px;
}
.singlecont h5 {
border-bottom: 1px dashed var(--color__main);
margin-bottom:16px;
font-size: 16px;
color: var(--color__main);
}
.singlecont h6 {
margin-bottom:16px;
font-size: 16px;
color: var(--color__main);
}
.singlecont p{
text-align: justify;
}
.singlecont img{
margin-bottom:16px;
height: auto;
max-width: 100%;
}
.singlecont a{
text-decoration: underline;
}
.singlecont ul {
list-style: disc;
list-style-position: inside;
}
.singlecont ol {
list-style: decimal;
list-style-position: inside;
}
.singlecont ul li,
.singlecont ol li {
text-indent: -1em;
padding-left: 1em;
}
.singlecont .aligncenter {
display: block;
margin-left: auto;
margin-right: auto;
}
.singlecont .alignleft {
float: left;
margin: 10px 15px 10px 0;
}
.singlecont .alignright {
float: right;
margin: 10px 0 10px 15px;
}*/
/*
 foot
----------------------------------------------------------- */
.cop {
  width: 100%;
  padding: 5px;
  background-color: #000;
  color: #fff;
  font-size: 12px;
  text-align: center;
}
/*
 smartphone menu btn
----------------------------------------------------------- */
.spnavbtn {
  position: fixed;
  top: 4%;
  right: 2%;
  z-index: 999;
  text-align: center;
  padding: 12px 10px 5px 11px;
  cursor: pointer;
  display: none;
  background: var(--color__main);
}
.nav-trigger,
.nav-trigger span {
  display: inline-block;
  transition: all ease 0.5s;
  box-sizing: border-box;
}
.nav-trigger {
  position: relative;
  width: 30px;
  height: 18px;
}
.nav-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
  border-radius: 20px;
}
.nav-trigger span:nth-of-type(1) {
  top: 0;
}
.nav-trigger span:nth-of-type(2) {
  top: 8px;
}
.nav-trigger span:nth-of-type(3) {
  bottom: 0;
}
/*
 smartphone menu btn click
----------------------------------------------------------- */
.spnavbtn .activete {
  font-size: 0.9em;
  opacity: 0;
}
.spnavbtn .activete:before {
  content: "";
}
.nav-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(8px) rotate(-45deg);
  transform: translateY(8px) rotate(-45deg);
}
.nav-trigger.active span:nth-of-type(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-menu-bar02 0.8s forwards;
  animation: active-menu-bar02 0.8s forwards;
}
@-webkit-keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
.nav-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-8px) rotate(45deg);
  transform: translateY(-8px) rotate(45deg);
}
/*
 smartphone menu btn click area
----------------------------------------------------------- */
.spnav {
  position: relative;
  z-index: 999;
}
.sp_close {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  z-index: 998;
  display: none;
}
.sp_close.open {
  display: inherit;
}
.spnav .trigger {
  width: 300px;
  height: 100%;
  transition: all ease 0.5s;
  position: fixed;
  top: 0;
  left: -300px;
  color: rgba(255, 255, 255, 0);
  overflow-y: scroll;
}
.spnav .open {
  width: 300px;
  max-width: 80%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  color: rgba(150, 150, 150, 1);
  overflow-y: scroll;
  -webkit-backdrop-filter: saturate(140%) blur(20px) brightness(130%);
  backdrop-filter: saturate(140%) blur(20px) brightness(130%);
  background: rgba(255, 255, 255, 0.7);
}
.spnav .trigger > p {
  width: 100%;
  padding: 15px;
  text-align: center;
}
.spnav .trigger > p img {
  height: 40px;
  width: auto;
  margin: 0 auto;
}
.spnav .trigger > ul > li {
  border-bottom: 1px solid rgba(250, 157, 44, 0.5);
  text-align: center;
  color: #231815;
  font-size: 0.9rem;
  transition: all ease 0.5s;
}
.spnav .trigger > ul > li:last-child {
  border-bottom: 1px solid rgba(250, 157, 44, 0.5);
}
.spnav ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 0 10px;
  height: 48px;
  transition: all ease 0.5s;
  line-height: 1.2;
}
.spnav ul li a:hover,
.spnav .navright:hover {
  background: #fff;
  color: #969696;
}
.spnav ul li.open_btn p {
  cursor: pointer;
  padding: 12px 0;
  text-align: center;
  font-size: 0.9rem;
}
.spnav ul li.open_btn span {
  font-size: 0.7em;
  position: relative;
  top: -1px;
  padding: 1em 0 1em 1em;
  color: var(--color__main);
}
.spnav ul li ul {
  display: none;
}
.spnav ul li ul li {
  border-top: 1px solid rgba(250, 157, 44, 0.2);
}
.spnav ul li ul li:last-child {
  border-bottom: none;
}
@media screen and (max-width: 1600px) {
  /*
 header
----------------------------------------------------------- */
}
@media screen and (max-width: 1400px) {
  /*
 header
----------------------------------------------------------- */
}
@media screen and (max-width: 1200px) {
  /*
 header
----------------------------------------------------------- */
}
@media screen and (max-width: 1100px) {
  .pc1100 {
    display: none;
  }
  br.pc1100 {
    display: none;
  }
  .sp1100 {
    display: block;
  }
  br.sp1100 {
    display: inherit;
  }
  /*
 header
----------------------------------------------------------- */
  .navwrap {
    height: 60px;
  }
  .navwrap ul {
    display: none;
  }

  .navwrap p svg,
  .navwrap h1 svg {
    height: 40px;
    width: auto;
    margin-left: clamp(15px, 2.4vw, 50px);
  }
  /*
 top
----------------------------------------------------------- */
  /*
 subpage共通
----------------------------------------------------------- */
  /*
 news
----------------------------------------------------------- */
  .news_list > li dd h3 {
    font-size: 18px;
  }
  .news_list > li dd p {
    margin-bottom: 15px;
  }
  .news_list > li dd .info {
    padding-top: 15px;
  }
  /*
 smartphone menu btn
----------------------------------------------------------- */
  .spnavbtn {
    top: 10px;
    right: 10px;
    padding: 10px 10px 5px 11px;
    display: block;
  }
  .nav-trigger {
    width: 30px;
  }
  /*
 エントリー
----------------------------------------------------------- */
  .entry_area .inner {
    padding: 70px 0;
  }
  .entry_fi {
    padding: 40px 50px;
  }
  /*
 footer
----------------------------------------------------------- */
  .footer .info p:not(:first-of-type) {
    margin-top: 5px;
  }
  .footer .info p,
  .footer .sitemap a {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 820px) {
  .pc {
    display: none;
  }
  br.pc {
    display: none;
  }
  .sp {
    display: block;
  }
  br.sp {
    display: inherit;
  }
  .flex-prev {
    display: none !important;
  }
  .flex-next {
    display: none !important;
  }
  body {
    font-size: 0.9rem;
  }
  /*
 top
----------------------------------------------------------- */
  /*
 subpage共通
----------------------------------------------------------- */
  /*
 エントリー
----------------------------------------------------------- */
  .entry_area .inner {
    padding: 50px 0;
  }
  .entry_fi {
    padding: 30px;
  }
  .entry_fi .birth > p .wpcf7-select {
    width: 130px;
  }
  /*
 news index-archives page
----------------------------------------------------------- */
  .bcontwrap ul {
    grid-template-columns: repeat(2, 1fr);
  }
  /* news single page
----------------------------------------------------------- */
  .l_cotent {
    width: 100%;
    margin: 0;
  }
  .sidebar {
    width: 100%;
    margin-top: 40px;
  }
  /*
 ページネーション
----------------------------------------------------------- */
  .prev,
  .next {
    width: 100%;
    margin: 0 0 5px;
  }
  .next {
    float: right;
  }
  .single .nav-below {
    margin-top: 40px;
  }
  /*
 contact
----------------------------------------------------------- */
  .cont_list {
    margin-bottom: 30px;
  }
  .cont_list li {
    font-size: 0.9rem;
    padding: 5px;
    line-height: 25px;
  }
  .wpcf7 dl,
  .mw_wrap dl {
    width: 100%;
    display: block;
    border-top: 0px dashed #ccc;
    margin-bottom: 15px;
  }
  .mwform-tel-field input[type="text"],
  .mwform-zip-field input[type="text"] {
    display: inline-block;
    width: 26%;
  }
  .priva ul {
    font-size: 0.9rem;
  }
  .priva li p,
  .priva li h4 {
    font-size: 0.9rem !important;
  }
  /*
 foot
----------------------------------------------------------- */
  .footer .info {
    width: 100%;
  }
  .footer .sitemap {
    width: 100%;
  }
  .footer .flex {
    display: none;
  }
}
@media screen and (max-width: 640px) {
  .pc640 {
    display: none;
  }
  br.pc640 {
    display: none;
  }
  .sp640 {
    display: block;
  }
  br.sp640 {
    display: inherit;
  }
  .top_back {
    display: none;
  }
  /*
 top
----------------------------------------------------------- */
  /*
 subpage共通
----------------------------------------------------------- */
  /*
 エントリー
----------------------------------------------------------- */
  .entry_area .inner {
    padding: 40px 0;
  }
  .entry_fi {
    padding: 20px;
  }
  .entry_fi .birth > p small {
    padding: 0 5px;
  }
  .entry_fi .birth > p .wpcf7-select {
    width: 75px;
  }
  .entry_fi .check .wpcf7-list-item {
    width: 100%;
  }
  /*
 news
----------------------------------------------------------- */
  .bcontwrap ul {
    grid-template-columns: repeat(1, 1fr);
  }
  .news_list > li dd h3 {
    font-size: 17px;
  }
  .news_list > li {
    padding: 15px;
  }
  .news_list > li dt {
    width: 100%;
    margin: 0 auto 15px;
  }
  .news_list > li dd {
    width: 100%;
  }
  .news_list > li dd p {
    margin-bottom: 10px;
  }
  .news_list > li dd .info {
    padding-top: 10px;
  }
  /*
 foot
----------------------------------------------------------- */

  /* FV Scroll Animation */
  .fv__scroll-area {
    position: absolute;
    right: 30px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 10;
  }

  .fv__scroll-circle {
    width: 40px;
    height: 40px;
    margin-bottom: 10px;
    animation: bounce 2s infinite;
  }

  .fv__scroll-circle img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .fv__scroll-line {
    width: 1px;
    height: 60px;
    background-color: #666;
    margin-bottom: 10px;
  }

  .fv__scroll-text {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 12px;
    color: #666;
    letter-spacing: 2px;
  }

  @keyframes bounce {
    0%,
    20%,
    50%,
    80%,
    100% {
      transform: translateY(0);
    }
    40% {
      transform: translateY(-10px);
    }
    60% {
      transform: translateY(-5px);
    }
  }
}

/* ------------------------------ */
/* 基本スタイル */
/* ------------------------------ */
html {
  --_font-size: var(--font-size__base);
  font-size: calc(var(--_font-size) * 1px);
}
@media (max-width: 1200px) {
  html {
    font-size: calc(var(--_font-size) / 1200 * 100vw);
  }
}
@media (max-width: 820px) {
  html {
    font-size: calc(var(--_font-size) * 1px);
  }
}
@media (max-width: 375px) {
  html {
    font-size: calc(var(--_font-size) / 375 * 100vw);
  }
}

body {
  font-family: var(--font-family__gothic);
  color: var(--color__text);
  font-size: calc(16rem / var(--font-size__base));
  font-weight: 400;
  font-feature-settings: "palt" 1;
  background-color: var(--color__ivory);
}

/* ------------------------------ */
/* 共通コンポーネント */
/* ------------------------------ */

/* PCでのみ表示 */
@media (max-width: 820px) {
  .only-pc {
    display: none !important;
  }
}

/* スマホでのみ表示 */
@media (min-width: 821px) {
  .only-sp {
    display: none !important;
  }
}

/* テキストの改行 */
.wbr {
  word-break: keep-all;
  overflow-wrap: anywhere;
}

/* スクリーンリーダー用 */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* インナーコンテナ */
.inner {
  --_max-width: 1200;
  --_padding-inline: var(--space-inline__base, 25);
  --_padding-right: var(--_padding-inline);
  --_padding-left: var(--_padding-inline);
  --_padding-inline__total: calc(var(--_padding-right) + var(--_padding-left));
  max-width: calc(
    var(--_max-width) * 1px + var(--_padding-inline__total) / 16 * 1rem
  );
  margin-inline: auto;
  padding-right: calc(var(--_padding-right) / 16 * 1rem);
  padding-left: calc(var(--_padding-left) / 16 * 1rem);
}

@media screen and (max-width: 820px) {
  .inner {
    --_max-width: var(--max-width__base);
  }
}

/* セクションヘッダー */
.section-header {
  --_dot-size: 12;
  --_column-gap: 16;
}

.section-header_en {
  display: flex;
  align-items: center;
  column-gap: calc(var(--_column-gap) * 1rem / var(--font-size__base, 16));
  font-family: var(--font-family__en);
  font-size: calc(28rem / var(--font-size__base, 16));
}

.section-header_dot {
  display: block;
  width: calc(var(--_dot-size) * 1rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__main);
  border-radius: 50%;
  margin-top: calc(-4rem / var(--font-size__base, 16));
}

.section-header_ja {
  display: block;
  font-family: var(--font-family__mincho);
  font-weight: 700;
  font-size: calc(16rem / var(--font-size__base, 16));
  padding-top: calc(3rem / var(--font-size__base, 16));
  padding-left: calc(
    (var(--_dot-size) + var(--_column-gap)) * 1rem / var(--font-size__base, 16)
  );
}

.section-header--white .section-header_en {
  color: #fff;
}

.section-header--white .section-header_dot {
  background-color: #fff;
}

.section-header--white .section-header_ja {
  color: #fff;
}

/* CTAボタン */
.cta-btn {
  --_color__main-default: var(--color__main);
  --_color__sub-default: #fff;
  --_color__main: var(--_color__main-default);
  --_color__sub: var(--_color__sub-default);
  --_duration: var(--duration__base);

  position: relative;
  display: grid;
  grid-template-columns: 1fr calc(46rem / var(--font-size__base, 16));
  align-items: center;
  background-color: var(--_color__main);
  color: var(--_color__sub);
  text-decoration: none;
  max-width: calc(447rem / var(--font-size__base, 16));
  padding-block: calc(16rem / var(--font-size__base, 16));
  padding-right: calc(24rem / var(--font-size__base, 16));
  padding-left: calc(36rem / var(--font-size__base, 16));
  transition: background-color var(--_duration);
}

.cta-btn_left {
  display: flex;
  align-items: center;
  column-gap: calc(16rem / var(--font-size__base, 16));
}

.cta-btn_text {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
}

.cta-btn_right {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.cta-btn_line {
  display: block;
  width: 1px;
  height: calc(48rem / var(--font-size__base, 16));
  background-color: var(--_color__sub);
}

.cta-btn_arrow {
  display: grid;
  place-items: center;
  width: calc(24rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: var(--_color__sub);
  transition: scale var(--_duration) ease;
}

.cta-btn_arrow svg {
  width: calc(10rem / var(--font-size__base, 16));
}

.cta-btn_arrow svg path {
  fill: var(--_color__main);
  stroke: var(--_color__main);
}

.cta-btn--sub {
  --_color__main-default: #f1efea;
  --_color__sub-default: var(--color__text);
}

.cta-btn--sub .cta-btn_text {
  font-size: calc(16rem / var(--font-size__base, 16));
}

@media (any-hover: hover) {
  .cta-btn:hover {
    background-color: var(--color__main-light);
  }

  .cta-btn:hover .cta-btn_arrow {
    scale: 1.1;
  }

  .cta-btn--sub:hover {
    background-color: var(--color__main-lightest);
  }
}

.cta-btn.cta-btn--text-lg {
  padding-left: calc(24rem / var(--font-size__base, 16));
}

.cta-btn.cta-btn--text-lg .cta-btn_text {
  font-size: calc(24rem / var(--font-size__base, 16));
}

/* グレーのボタン */
.btn {
  --_color__main: #f1efea;
  --_color__sub: var(--color__gray);
  --_duration: var(--duration__base);

  position: relative;
  display: grid;
  grid-template-columns: 1fr calc(40rem / var(--font-size__base, 16));
  align-items: center;
  background-color: var(--_color__main);
  color: var(--_color__sub);
  text-decoration: none;
  padding-block: calc(16rem / var(--font-size__base, 16));
  padding-inline: calc(24rem / var(--font-size__base, 16));
  transition: background-color var(--_duration);
}

.btn_left {
}

.btn_text {
  color: var(--color__text);
  font-size: calc(16rem / var(--font-size__base, 16));
}

.btn_icon-title {
  display: flex;
  align-items: center;
  column-gap: calc(16rem / var(--font-size__base, 16));
}

.btn_icon svg path {
  fill: var(--_color__sub);
}

.btn_title {
  font-family: var(--font-family__noto-serif);
  font-size: calc(24rem / var(--font-size__base, 16));
}

.btn_right {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.btn_line {
  display: block;
  width: 1px;
  height: calc(67rem / var(--font-size__base, 16));
  background-color: var(--_color__sub);
}

.btn_arrow {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: var(--_color__sub);
  transition: scale var(--_duration) ease;
}

.btn_arrow svg {
  width: calc(10rem / var(--font-size__base, 16));
}

.btn_arrow svg path {
  fill: #fff;
  stroke: #fff;
}

.btn:hover {
  background-color: var(--color__main-lightest);
}

.btn:hover .btn_arrow {
  scale: 1.1;
}

/* スケジュール */
.fv_schedule .schedule {
  filter: drop-shadow(0 0 5px rgba(145, 136, 126, 0.08));
}

.schedule {
  background-color: #fff;
  padding-top: calc(8rem / var(--font-size__base, 16));
  padding-bottom: calc(22rem / var(--font-size__base, 16));
  padding-inline: calc(19rem / var(--font-size__base, 16));
}

.schedule_table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-family__mincho);
}

.schedule_table tr {
  border-bottom: 1px solid #dbd7cc;
}

.schedule_table th,
.schedule_table td {
  padding-block: calc(14rem / var(--font-size__base, 16));
  padding-inline: calc(16rem / var(--font-size__base, 16));
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}

.schedule_table th {
  background-color: var(--color-bg-light);
  color: var(--color-text-sub);
  font-weight: 500;
}

.schedule_table tbody td {
  padding-block: calc(20rem / var(--font-size__base, 16));
}

.schedule_time {
  font-weight: 500;
}

.schedule_open {
  font-family: var(--font-family__noto-sans);
  color: var(--color__main);
  font-weight: 700;
}

.schedule_closed {
  font-family: var(--font-family__noto-sans);
  color: #dbd7cc;
}

.schedule_note {
  font-size: calc(14rem / var(--font-size__base, 16));
  padding-top: calc(20rem / var(--font-size__base, 16));
}

/* 水平線（左が点、右が線） */
.hr {
  --_dot-size: 6;
  --_column-gap: 4;
  --_width__total: calc(var(--_dot-size) + var(--_column-gap));

  position: relative;
  height: calc(var(--_dot-size) * 1rem / var(--font-size__base, 16));
}

.hr::before {
  content: "";
  display: block;
  width: calc(var(--_dot-size) * 1rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__main);
}

.hr::after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: calc(
    100% - (var(--_width__total) * 1rem / var(--font-size__base, 16))
  );
  height: 1px;
  background-color: rgba(112, 112, 112, 0.5);
}

/* 水平線（右が点、左が線） */
.hr-reverse {
  --_dot-size: 6;
  --_column-gap: 4;
  --_width__total: calc(var(--_dot-size) + var(--_column-gap));

  position: relative;
  height: calc(var(--_dot-size) * 1rem / var(--font-size__base, 16));
}

.hr-reverse::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: calc(
    100% - (var(--_width__total) * 1rem / var(--font-size__base, 16))
  );
  height: 1px;
  background-color: rgba(112, 112, 112, 0.5);
}

.hr-reverse::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: calc(var(--_dot-size) * 1rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__main);
}

.orange-circle {
  width: calc(12rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  border-radius: 50%;
  background: linear-gradient(135deg, #f89c1b 0%, #fde350 100%);
  filter: drop-shadow(0 0 5px #ffa700);
  transform: translateZ(0);
}

/* heading */
.heading_title {
  display: flex;
  column-gap: calc(16rem / var(--font-size__base, 16));
}
.heading_title-top,
.heading_title-bottom {
  display: contents;
}
.heading_icon {
  width: calc(12rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__main);
  border-radius: 50%;
  align-self: start;
  flex-shrink: 0;
  margin-top: calc(-5rem / var(--font-size__base, 16));
}
.heading_title-ja {
  font-family: var(--font-family__mincho);
  font-size: calc(28rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(56 / 28);
  margin-block: var(--leading-trim);
}

.heading_line {
  width: calc(16rem / var(--font-size__base, 16));
  height: 1px;
  background-color: var(--color__gray);
  align-self: end;
  margin-bottom: calc(13rem / var(--font-size__base, 16));
}

.heading_title-en {
  font-family: var(--font-family__en);
  font-size: calc(16rem / var(--font-size__base, 16));
  color: var(--color__gray);
  align-self: end;
  line-height: calc(28 / 16);
}

.heading_hr {
  padding-top: calc(38rem / var(--font-size__base, 16));
}

/* heading-line */
.heading-line {
  --_width: 48;
  --_gap: 16;

  position: relative;
  font-family: var(--font-family__mincho);
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 700;
  padding-left: calc(
    (var(--_width) + var(--_gap)) * 1rem / var(--font-size__base, 16)
  );
}

.heading-line::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: calc(var(--_width) * 1rem / var(--font-size__base, 16));
  height: 2px;
  background: linear-gradient(to right, #f89c1b, #ffe200);
}

/* svg */
.svg-arrow-right {
  width: calc(7rem / var(--font-size__base, 16));
}

/* heading-topic */
.heading-topic {
  display: grid;
  background-color: #f1efea;
  border-left: 2px solid var(--color__main);
  padding-left: calc(18rem / var(--font-size__base, 16));
  padding-right: calc(8rem / var(--font-size__base, 16));
  padding-top: calc(9rem / var(--font-size__base, 16));
  padding-bottom: calc(11rem / var(--font-size__base, 16));
}

.heading-topic_en {
  font-family: var(--font-family__en);
  color: var(--color__gray);
  font-size: calc(16rem / var(--font-size__base, 16));
}

.heading-topic_ja {
  font-family: var(--font-family__mincho);
  font-size: calc(24rem / var(--font-size__base, 16));
  font-weight: 700;
  padding-top: calc(6rem / var(--font-size__base, 16));
}

/* services */
.services_tabs {
  margin-top: calc(40rem / var(--font-size__base, 16));
}

/* tabs */
.tabs {
  background-color: #f1efea;
  padding-top: calc(16rem / var(--font-size__base, 16));
}

.tabs_inner {
}

.tabs_list {
  display: flex;
  justify-content: space-between;
  column-gap: calc(9rem / var(--font-size__base, 16));
}

.tabs_item {
  width: 100%;
}

.tabs_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: calc(60rem / var(--font-size__base, 16));
  column-gap: calc(16rem / var(--font-size__base, 16));
  color: var(--color__gray);
  background-color: #e8e5df;
  border: 0;
  border-radius: 5px 5px 0 0;
  cursor: pointer;
  text-align: left;
}

.tabs_link[aria-selected="true"] {
  color: var(--color__text);
  background-color: var(--color__ivory);
}

.tabs_link svg {
  margin-top: calc(4rem / var(--font-size__base, 16));
}

/* list */
.list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: calc(48rem / var(--font-size__base, 16));
  row-gap: calc(20rem / var(--font-size__base, 16));
}

.list_item {
  display: grid;
  align-items: center;
  background-color: #f1efea;
  border: 1px solid rgba(145, 136, 126, 0.5);
  padding-block: calc(6rem / var(--font-size__base, 16));
  padding-left: calc(24rem / var(--font-size__base, 16));
  padding-right: calc(18rem / var(--font-size__base, 16));
}

.list_text {
  font-size: calc(18rem / var(--font-size__base, 16));
  line-height: calc(32 / 18);
}

/*
   subpage共通
  ----------------------------------------------------------- */
.sub_fv {
  margin-top: var(--height__header);
}

.sub-fv_image {
  position: relative;
  z-index: -1;
}

.sub-fv_image img {
  width: 100%;
  object-fit: cover;
  object-position: center bottom;
}

.sub-fv_image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #f2f1ef;
  opacity: 0.45;
}

.sub-fv_image::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(640rem / var(--font-size__base, 16));
  height: calc(32rem / var(--font-size__base, 16));
  background-image: url("./library/images/sub_fv-img-bottom.webp");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.sub-fv_content {
  background-color: var(--color__ivory);
  padding-top: calc(8rem / var(--font-size__base, 16));
}

.sub-fv_title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: calc(2rem / var(--font-size__base, 16));
  font-family: var(--font-family__mincho);
  font-size: calc(38rem / var(--font-size__base, 16));
  font-weight: 700;
}

.sub-fv_subtitle {
  color: var(--color__gray);
  font-family: var(--font-family__en);
  font-size: calc(16rem / var(--font-size__base, 16));
  font-weight: 400;
  padding-top: calc(8rem / var(--font-size__base, 16));
}

.sub-fv_circle {
  display: grid;
  place-items: center;
  padding-top: calc(24rem / var(--font-size__base, 16));
}

/* ------------------------------ */
/* header */
/* ------------------------------ */

.arrow-link {
  position: relative;
  display: flex;
  align-items: center;
  column-gap: calc(10rem / var(--font-size__base, 16));
  padding-block: calc(40rem / var(--font-size__base, 16));
}

.arrow-link_text {
  position: relative;
}

.arrow-link_text::after {
  position: absolute;
  bottom: 1px;
  left: 0;
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: var(--color__main);
  transition: width var(--duration__base) ease;
}

.arrow-link:hover .arrow-link_text {
  color: var(--color__main);
}

.arrow-link:hover .arrow-link_text::after {
  width: 100%;
}

.arrow-link:hover .arrow-link_icon {
  background-color: var(--color__main);
  transform: scale(calc(20 / 16));
}

.arrow-link_icon {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  height: calc(16rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
  border-radius: 50%;
  transition:
    background-color var(--duration__base) ease,
    transform var(--duration__base) ease;
}

/* icon-btn */
.icon-btn {
  position: relative;
  display: flex;
  align-items: center;
  column-gap: calc(10rem / var(--font-size__base, 16));
  background-color: var(--color__main);
  border-radius: 100px;
  padding-block: calc(8rem / var(--font-size__base, 16));
  padding-inline: calc(21rem / var(--font-size__base, 16));
}

.icon-btn_text {
  position: relative;
  color: #fff;
}

.icon-btn:hover {
  background-color: var(--color__main-light);
}

.icon-btn:hover .icon-btn_icon {
  transform: scale(calc(20 / 16));
}

.icon-btn_icon {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  height: calc(16rem / var(--font-size__base, 16));
  background-color: #fff;
  border-radius: 50%;
  transition:
    background-color var(--duration__base) ease,
    transform var(--duration__base) ease;
}

.icon-btn_icon svg path {
  fill: var(--color__main);
  stroke: var(--color__main);
}

/* ------------------------------ */
/* toppage.php */
/* ------------------------------ */

/* ファーストビューセクション */
.fv {
  --_height__slider: 818;
  position: relative;
  width: 100%;
  height: calc(
    (var(--_height__slider) + var(--space__section--md)) * 1rem /
      var(--font-size__base, 16)
  );
  background-color: var(--color__ivory);
  margin-top: var(--height__header);
  padding-bottom: calc(
    var(--space__section--md) * 1rem / var(--font-size__base, 16)
  );
}

.fv_slider-overlay {
  position: absolute;
  z-index: 1;
  mix-blend-mode: screen;
  top: calc(-128rem / var(--font-size__base, 16));
  right: 0;
  width: calc(1920rem / var(--font-size__base, 16));
  height: calc(1041rem / var(--font-size__base, 16));
}

.fv_slider {
  --_speed: 58s;
  --_delay: 0s;
  --_width__viewport: 1920;
  --_width__slide: 1054;
  --_space__gap: 48;

  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  display: flex;
  overflow: hidden;
}
.fv_slider-items {
  animation: loop-slider-left var(--_speed) infinite linear var(--_delay) both;
  display: flex;
}
.fv_slider-item {
  max-width: calc(
    (var(--_width__slide) + var(--_space__gap)) * 1rem /
      var(--font-size__base, 16)
  );
  width: calc(
    (
      (var(--_width__slide) + var(--_space__gap)) / var(--_width__viewport) *
        100vw
    )
  );
  padding-inline: calc(
    (var(--_space__gap) / 2) / var(--_width__viewport) * 100vw
  );
}
.fv_slider-item img {
  display: block;
  width: 100%;
  aspect-ratio: var(--_width__slide) / 818;
}

.fv_container {
  position: relative;
  z-index: 2;
  height: 100%;
}

.fv_container .inner {
  height: 100%;
}

.fv_content {
  position: relative;
  max-width: 600px;
  height: 100%;
  background-color: var(--color__ivory);
  padding-block: calc(37rem / var(--font-size__base, 16));
}

.fv_text-area {
  position: relative;
  padding-inline: calc(40rem / var(--font-size__base, 16));
}

.fv_text-area::before {
  content: "";
  position: absolute;
  top: calc(-4rem / var(--font-size__base, 16));
  right: calc(61rem / var(--font-size__base, 16));
  background-image: url("./library/images/fv_circle.webp");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  width: calc(94rem / var(--font-size__base, 16));
  aspect-ratio: 1;
}

.fv_main-copy {
  font-family: var(--font-family__mincho);
  font-size: calc(38rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(76 / 38);
}

.fv_sub-copy {
  font-family: var(--font-family__en);
  padding-top: calc(21rem / var(--font-size__base, 16));
}

.fv_scroll-indicator {
  margin-top: calc(10rem / var(--font-size__base, 16));
  padding-bottom: calc(40rem / var(--font-size__base, 16));
}

.fv_scroll-text {
  font-size: 14px;
  color: var(--color__gray);
  letter-spacing: 0.2em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

.fv_schedule {
  padding-inline: calc(24rem / var(--font-size__base, 16));
}

/* スクロールインジケーター */
.scroll-indicator_container {
  display: grid;
  align-items: end;
  background-image: url("./library/images/fv_decoration.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  aspect-ratio: 600 / 236;
  padding-top: calc(30rem / var(--font-size__base, 16));
  padding-inline: calc(30rem / var(--font-size__base, 16));
}

.scroll-indicator_element {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: calc(40rem / var(--font-size__base, 16));
  bottom: calc(-8rem / var(--font-size__base, 16));
}

.scroll-indicator_circle {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: calc(30rem / var(--font-size__base, 16));
  height: calc(30rem / var(--font-size__base, 16));
}

.scroll-indicator_line {
  width: 2px;
  height: calc(139rem / var(--font-size__base, 16));
  background-color: rgba(145, 136, 126, 0.3);
}

.scroll-indicator_text {
  font-family: var(--font-family__en);
  writing-mode: vertical-rl;
  color: var(--color__gray);
  padding-top: calc(10rem / var(--font-size__base, 16));
  padding-left: calc(3rem / var(--font-size__base, 16));
}

/* スクロールインジケーターアニメーション */
.scroll-indicator_circle {
  animation: circleScrollMove 2s ease-out infinite;
}

@keyframes circleScrollMove {
  0% {
    transform: translate(-50%, -50%);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  85% {
    transform: translate(-50%, calc(139rem / var(--font-size__base, 16) - 50%));
    opacity: 0;
  }
  100% {
    transform: translate(-50%, -50%);
    opacity: 0;
  }
}

/* 初めての方へセクション */
.beginners {
  position: relative;
  background-color: var(--color__ivory);
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.beginners::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: calc(360rem / var(--font-size__base, 16));
  aspect-ratio: 360 / 640;
  background-image: url("./library/images/top_beginners-left.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.beginners::after {
  position: absolute;
  top: 0;
  right: 0;
  content: "";
  display: block;
  width: calc(360rem / var(--font-size__base, 16));
  aspect-ratio: 360 / 513;
  background-image: url("./library/images/top_beginners-right.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.beginners_inner {
  --_max-width: 1728;
}

.beginners_container {
  position: relative;
  z-index: 1;
  background-color: #fff;
}

.beginners_content {
  --_width--left: 448;
  --_width--center: 239;
  --_width--right: 752;
  --_column-gap: 60;

  --_width--total: calc(
    var(--_width--left) + var(--_width--center) + var(--_width--right) +
      (var(--_column-gap) * 2)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--center) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc(var(--_column-gap) / var(--_width--total) * 100%);
  padding-block: calc(64rem / var(--font-size__base, 16));
  padding-inline: calc(80rem / var(--font-size__base, 16));
}

.beginners_left-image {
  padding-top: calc(48rem / var(--font-size__base, 16));
}

.beginners_right {
  display: grid;
  align-items: center;
  padding-left: calc(4rem / var(--font-size__base, 16));
}

.beginners_main-title {
  font-family: var(--font-family__mincho);
  font-size: calc(28rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(56 / 28);
}

.beginners_description {
  line-height: calc(32 / 16);
  padding-top: calc(24rem / var(--font-size__base, 16));
}

.beginners_cta {
  padding-top: calc(
    var(--space__section--xs) * 1rem / var(--font-size__base, 16)
  );
}

/* 診療科目セクション */
.treatment {
  background-color: var(--color__ivory);
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.treatment_header {
  margin-bottom: 60px;
  position: relative;
}

.treatment_title {
  display: flex;
  align-items: baseline;
  gap: 15px;
}

.treatment_title-en {
  font-size: 32px;
  color: var(--color__main);
  font-weight: 400;
  position: relative;
}

.treatment_title-en::before {
  content: "";
  position: absolute;
  left: -25px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background-color: var(--color__main);
  border-radius: 50%;
}

.treatment_title-ja {
  font-size: 18px;
  font-weight: 400;
}

.treatment_grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-left: 1px solid #dbd7cc;
  border-right: 1px solid #dbd7cc;
  margin-top: calc(51rem / var(--font-size__base, 16));
}

.treatment_grid::before,
.treatment_grid::after {
  position: absolute;
  content: "";
  top: 0;
  left: calc(50% - 50vw);
  width: 100vw;
  height: 1px;
  background-color: #dbd7cc;
}

.treatment_grid::after {
  top: auto;
  bottom: 0;
}

.treatment_card {
  position: relative;
  border-right: 1px solid #dbd7cc;
  border-bottom: 1px solid #dbd7cc;
}

/* 各行の最後の項目の右ボーダーを削除 */
.treatment_card:nth-child(3n) {
  border-right: none;
}

/* 最後の行の下ボーダーを削除 */
.treatment_card:nth-last-child(-n + 3) {
  border-bottom: none;
}

/* treatment_card-dotsを使用したグリッド交差点ドット */
.treatment_card-dots {
  --_dot-size: 6;
  --_dot-border-width: 4;
  --_dot-total-width: calc((var(--_dot-size) + (var(--_dot-border-width) * 2)));
  --_dot-offset: calc(var(--_dot-total-width) / -2);

  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.treatment_card-dot {
  position: absolute;
  width: calc(var(--_dot-total-width) * 1rem / var(--font-size__base));
  height: calc(var(--_dot-total-width) * 1rem / var(--font-size__base));
  background-color: var(--color__main);
  border: calc(var(--_dot-border-width) * 1rem / var(--font-size__base)) solid
    var(--color__ivory);
}

/* 各ドットを4隅に配置 */
.treatment_card-dot:nth-child(1) {
  top: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  left: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.treatment_card-dot:nth-child(2) {
  top: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  right: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.treatment_card-dot:nth-child(3) {
  bottom: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  left: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.treatment_card-dot:nth-child(4) {
  bottom: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  right: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

/* 必要に応じて追加ドット用のラッパーdivを追加 */
.treatment_grid-dots {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.treatment_card-link {
  display: block;
  padding-block: calc(32rem / var(--font-size__base, 16));
  padding-inline: calc(47rem / var(--font-size__base, 16));
  transition: background-color var(--duration__base) ease;
}

.treatment_card-image {
  display: grid;
  place-items: center;
  overflow: hidden;
  aspect-ratio: 304 / 200;
  background-color: #edebe3;
}

.treatment_card-image img {
  max-width: calc(234rem / var(--font-size__base, 16));
  aspect-ratio: 234 / 162;
  transition: transform var(--duration__base) ease;
}

.treatment_card-title {
  font-family: var(--font-family__mincho);
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(32 / 18);
  padding-top: calc(18rem / var(--font-size__base, 16));
}

.treatment_card-more {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: calc(8rem / var(--font-size__base, 16));
  text-decoration: none;
  margin-top: calc(15rem / var(--font-size__base, 16));
  padding-top: calc(15rem / var(--font-size__base, 16));
  transition: color var(--duration__base) ease;
  font-family: var(--font-family__en);
  background-image: linear-gradient(
    to right,
    rgba(145, 136, 126, 0.5) 2px,
    transparent 2px
  );
  background-size: 4px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  color: var(--color__gray);
}

.treatment_card-arrow {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__gray);
  border-radius: 50%;
  transition:
    background-color var(--duration__base) ease,
    transform var(--duration__base) ease;
}

.treatment_card-link:hover .treatment_card-image {
  background-color: var(--color__main-light);
}

.treatment_card-link:hover .treatment_card-image img {
  transform: scale(1.1);
}

.treatment_card-link:hover .treatment_card-more {
  color: var(--color__main);
}

.treatment_card-link:hover .treatment_card-arrow {
  background-color: var(--color__main);
  transform: scale(1.1);
}

/* 歯ぎしり・食いしばり */
p + .symptoms-comparison {
  margin-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
}
.symptoms-comparison {
  position: relative;
  z-index: 1;
  padding-inline: calc(50rem / var(--font-size__base, 16));
}
.symptoms-comparison::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("./library/images/services_symptoms-comparison-bg.webp");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}
.symptoms-comparison_inner {
  --_max-width: 784;
}
.symptoms-comparison_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: calc(48rem / var(--font-size__base, 16));
}
.symptoms-section {
  padding: calc(24rem / var(--font-size__base, 16));
}
.symptoms-section--current {
  background-color: #f1efea;
}
.symptoms-section--progression {
  background-color: #e8e5df;
}
.symptoms-section_header {
}
.symptoms-section_title {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
  line-height: calc(32 / 18);
}
.symptoms-section_divider {
  padding-top: calc(10rem / var(--font-size__base, 16));
}
.symptoms-list {
}
.symptoms-list_items {
  display: grid;
  row-gap: calc(7rem / var(--font-size__base, 16));
  padding-top: calc(16rem / var(--font-size__base, 16));
}
.symptoms-list_item {
  display: flex;
  column-gap: calc(16rem / var(--font-size__base, 16));
  line-height: calc(32 / 16);
}

.symptoms-list_item::before {
  content: "";
  display: inline-block;
  width: calc(6rem / var(--font-size__base, 16));
  height: calc(6rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
  margin-top: 0.8em;
  flex-shrink: 0;
}
.symptoms-list_note {
}

/* ごあいさつセクション */
.greeting {
  position: relative;
  background-color: var(--color__main);
  padding-top: calc(
    var(--space__section--md) * 1rem / var(--font-size__base, 16)
  );
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
  border-radius: 0 calc(100rem / var(--font-size__base, 16)) 0 0;
}

.greeting::before {
  content: "";
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: calc(751rem / var(--font-size__base, 16));
  aspect-ratio: 751 / 615;
  background-image: url("./library/images/top_greeting-overlay.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  mix-blend-mode: screen;
}

.greeting_inner {
  position: relative;
  z-index: 1;
}

.greeting_container {
  position: relative;
}

/* ごあいさつスライダー - CSSアニメーション */
.greeting_slider {
  --_speed: 25s;
  --_delay: 0s;
  --_width__viewport: 1920;
  --_width__slide: 400;
  --_space__gap: 48;

  position: absolute;
  bottom: 0;
  left: 0;
  width: 100vw;
  margin-bottom: 0;
  margin-inline: calc(-50vw + 50%);
  display: flex;
  overflow: hidden;
}

.greeting_slider-items {
  animation: loop-slider-left var(--_speed) infinite linear var(--_delay) both;
  display: flex;
}

.greeting_slider-item {
  max-width: calc(
    (var(--_width__slide) + var(--_space__gap)) * 1rem /
      var(--font-size__base, 16)
  );
  width: calc(
    (
      (var(--_width__slide) + var(--_space__gap)) / var(--_width__viewport) *
        100vw
    )
  );
  padding-inline: calc(
    (var(--_space__gap) / 2) / var(--_width__viewport) * 100vw
  );
}

.greeting_slider-item img {
  display: block;
  width: 100%;
  aspect-ratio: 400 / 500;
  object-fit: cover;
}

.greeting_content {
  position: relative;
  z-index: 1;

  --_width--left: 600;
  --_width--right: 600;
  --_column-gap: 0;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
  padding-top: calc(48rem / var(--font-size__base, 16));
}

.greeting_title {
  color: #fff;
  font-family: var(--font-family__mincho);
  font-size: calc(28rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(56 / 28);
}

.greeting_right {
  color: #fff;
  background-color: var(--color__main);
  padding-inline: calc(48rem / var(--font-size__base, 16));
}

.greeting_subtitle {
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 500;
  line-height: calc(32 / 20);
}

.greeting_description {
  font-weight: 500;
  line-height: calc(32 / 16);
  padding-top: calc(28rem / var(--font-size__base, 16));
}

/* 特徴セクション */
.feature {
  background-color: var(--color__ivory);
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.feature_header {
  margin-bottom: 60px;
  position: relative;
}

.feature_title {
  display: flex;
  align-items: baseline;
  gap: 15px;
}

.feature_title-en {
  font-size: 32px;
  color: var(--color-primary);
  font-weight: 400;
  position: relative;
}

.feature_title-en::before {
  content: "";
  position: absolute;
  left: -25px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background-color: var(--color-primary);
  border-radius: 50%;
}

.feature_title-ja {
  font-size: 18px;
  color: var(--color-text-main);
  font-weight: 400;
}

.feature_content {
  position: relative;
}

.feature_content::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(331rem / var(--font-size__base, 16));
  aspect-ratio: 331 / 1073;
  background-image: url("./library/images/top_feature-left.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.feature_content::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(331rem / var(--font-size__base, 16));
  aspect-ratio: 331 / 1073;
  background-image: url("./library/images/top_feature-right.webp");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.feature_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  position: relative;
  border-left: 1px solid #dbd7cc;
  border-right: 1px solid #dbd7cc;
  margin-top: calc(51rem / var(--font-size__base, 16));
}

.feature_grid::before,
.feature_grid::after {
  position: absolute;
  content: "";
  top: 0;
  left: calc(50% - 50vw);
  width: 100vw;
  height: 1px;
  background-color: #dbd7cc;
}

.feature_grid::after {
  top: auto;
  bottom: 0;
}

.feature_card {
  padding-block: calc(48rem / var(--font-size__base, 16));
  padding-inline: calc(24rem / var(--font-size__base, 16));
  position: relative;
  border-right: 1px solid #dbd7cc;
  border-bottom: 1px solid #dbd7cc;
}

.feature_card-image {
  flex-shrink: 0;
  overflow: hidden;
}

.feature_card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-color: #f0f0f0;
}

.feature_card-content {
  padding-top: calc(28rem / var(--font-size__base, 16));
}

.feature_card-title {
  font-family: var(--font-family__mincho);
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(32 / 18);
  margin-block: calc((1em - 1lh) / 2);
}

.feature_card-highlight {
  color: var(--color__main);
}

.feature_card-number-wrapper {
  padding-top: calc(14rem / var(--font-size__base, 16));
}

.feature_card-number {
  display: inline-block;
  color: var(--color__gray);
  background-color: rgba(145, 136, 126, 0.1);
  border-radius: 12px;
  font-family: var(--font-family__en);
  font-size: calc(14rem / var(--font-size__base, 16));
  font-weight: 500;
  padding-block: calc(2rem / var(--font-size__base, 16));
  padding-inline: calc(10rem / var(--font-size__base, 16));
}

.feature_card-number span {
  font-family: var(--font-family__noto-serif);
}

.feature_card-text {
  line-height: calc(32 / 16);
  padding-top: calc(18rem / var(--font-size__base, 16));
  padding-right: calc(20rem / var(--font-size__base, 16));
}

/* 特徴カードドット */
.feature_card-dots {
  --_dot-size: 6;
  --_dot-border-width: 4;
  --_dot-total-width: calc((var(--_dot-size) + (var(--_dot-border-width) * 2)));
  --_dot-offset: calc(var(--_dot-total-width) / -2);

  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.feature_card-dot {
  position: absolute;
  width: calc(var(--_dot-total-width) * 1rem / var(--font-size__base));
  height: calc(var(--_dot-total-width) * 1rem / var(--font-size__base));
  background-color: var(--color__main);
  border: calc(var(--_dot-border-width) * 1rem / var(--font-size__base)) solid
    var(--color__ivory);
}

.feature_card-dot:nth-child(1) {
  top: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  left: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.feature_card-dot:nth-child(2) {
  top: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  right: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.feature_card-dot:nth-child(3) {
  bottom: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  left: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

.feature_card-dot:nth-child(4) {
  bottom: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
  right: calc(var(--_dot-offset) * 1rem / var(--font-size__base));
}

/* 2列目の右ボーダーを削除 */
.feature_card:nth-child(2n) {
  border-right: none;
}

.feature_cta {
  padding-top: calc(60rem / var(--font-size__base, 16));
}

.feature_cta .cta-btn {
  margin-inline: auto;
}

/* ナビゲーションカードセクション */
.top_nav-cards {
  background-color: #fff;
}
.nav-cards {
  position: relative;
  padding-block: calc(
    var(--space__section--sm) * 1rem / var(--font-size__base, 16)
  );
}

.nav-cards::after {
  content: "";
  position: absolute;
  bottom: calc(-32rem / var(--font-size__base, 16));
  left: 50%;
  transform: translateX(-50%);
  width: calc(640rem / var(--font-size__base, 16));
  height: calc(32rem / var(--font-size__base, 16));
  background-image: url(./library/images/top_nav-cards-bottom.webp);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.nav-cards_inner.inner {
  --_max-width: 1920;
}

.nav-cards_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.nav-cards_card {
  text-align: center;
}

.nav-cards_card-link {
  display: block;
  height: 100%;
  padding-block: calc(46rem / var(--font-size__base, 16));
  transition: background-color 0.3s ease;
}

.nav-cards_card-link:hover {
  background-color: var(--color__main-lightest);
}

.nav-cards_card-link:hover .nav-cards_card-more {
  color: var(--color__main);
}

.nav-cards_card-link:hover .nav-cards_card-arrow {
  transform: scale(1.1);
}

.nav-cards_card:not(:last-child) {
  border-right: 1px solid rgba(112, 112, 112, 0.5);
}

.nav-cards_card-title-en {
  display: inline;
  font-family: var(--font-family__en);
  color: var(--color__main);
  font-size: calc(28rem / var(--font-size__base, 16));
}

.nav-cards_card-title-ja {
  display: block;
  font-family: var(--font-family__mincho);
  font-size: calc(16rem / var(--font-size__base, 16));
  font-weight: 700;
  padding-top: calc(9rem / var(--font-size__base, 16));
}

.nav-cards_card-line {
  width: calc(40rem / var(--font-size__base, 16));
  height: 1px;
  background-color: var(--color__gray);
  margin-top: calc(32rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.nav-cards_card-text {
  line-height: calc(32 / 16);
  text-align: center;
  padding-top: calc(48rem / var(--font-size__base, 16));
  padding-inline: calc(8rem / var(--font-size__base, 16));
}

.nav-cards_card-more {
  display: inline-flex;
  align-items: center;
  gap: calc(10rem / var(--font-size__base, 16));
  text-decoration: none;
  transition: color var(--duration__base) ease;
  margin-top: calc(46rem / var(--font-size__base, 16));
  font-family: var(--font-family__en);
}

.nav-cards_card-arrow {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__main);
  border-radius: 50%;
  transition: transform var(--duration__base) ease;
}

.nav-cards_card-more:hover .nav-cards_card-arrow {
  transform: scale(1.1);
}

/* フルイメージセクション */
.full-image {
  position: relative;
  z-index: -1;
}

.full-image_image {
  position: relative;
}

.full-image_image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(157, 120, 68, 0.4);
  z-index: 1;
}

/* 左に突き抜けた画像 */
.left-image {
}

.left-image_image {
  margin-left: calc(-50vw + 50%);
}

/* お知らせセクション */
.news {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.news_header {
  margin-bottom: 60px;
  display: flex;
  align-items: center;
  gap: 15px;
}

.news_dot {
  width: 8px;
  height: 8px;
  background-color: var(--color-primary);
  border-radius: 50%;
  flex-shrink: 0;
}

.news_title {
  display: flex;
  align-items: baseline;
  gap: 15px;
}

.news_title-en {
  font-size: 32px;
  color: var(--color-primary);
  font-weight: 400;
}

.news_title-ja {
  font-size: 18px;
  color: var(--color-text-main);
  font-weight: 400;
}

.news_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(48rem / var(--font-size__base, 16));
  padding-top: calc(48rem / var(--font-size__base, 16));
}

.news_card {
  position: relative;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 6;
  gap: 0;
}

.news_card-link {
  position: absolute;
  z-index: 1;
  inset: 0;
  transition: background-color var(--duration__base) ease;
}

.news_card-link:hover ~ .news_card-header img {
  transform: scale(1.1);
}

.news_card-link:hover ~ .news_card-title {
  color: var(--color__main);
}

.news_card-link:hover ~ .news_card-more {
  color: var(--color__main);
}

.news_card-link:hover ~ .news_card-more .news_card-arrow {
  background-color: var(--color__main);
  transform: scale(1.1);
}

.news_card-content {
  position: relative;
  z-index: 2;
}

.news_card-header {
  position: relative;
  overflow: hidden;
  aspect-ratio: 368 / 224;
}

.news_card-header img {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration__base) ease;
}

.news_card-label {
  display: block;
  font-size: 12px;
  color: var(--color__gray);
  margin-bottom: 8px;
  letter-spacing: 0.1em;
}

.news_card-clinic {
  font-size: 18px;
  color: var(--color-text-main);
  font-weight: 400;
  margin: 0;
}

.news_card-date {
  display: block;
  color: var(--color__gray);
  padding-top: calc(16rem / var(--font-size__base, 16));
}

.news_card-title {
  font-size: calc(16rem / var(--font-size__base, 16));
  line-height: calc(32 / 16);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news_card-hr {
  margin-top: calc(18rem / var(--font-size__base, 16));
}

.news_card-more {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: calc(8rem / var(--font-size__base, 16));
  color: var(--color__gray);
  text-decoration: none;
  transition: color var(--duration__base) ease;
  font-family: var(--font-family__en);
  margin-top: calc(-40rem / var(--font-size__base, 16));
}

.news_card-arrow {
  display: grid;
  place-items: center;
  width: calc(18rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  background-color: var(--color__gray);
  border-radius: 50%;
  text-align: center;
  transition: transform var(--duration__base) ease;
}

.news_cta {
  padding-top: calc(5rem / var(--font-size__base, 16));
}

.news_cta .cta-btn {
  margin-inline: auto;
}

/* ------------------------------ */
/* フッターセクション */
/* ------------------------------ */
.footer {
  background: linear-gradient(to right, #f8e8d1 0%, #fcf4e7 100%);
}

.footer_inner {
  padding-top: calc(
    var(--space__section--md) * 1rem / var(--font-size__base, 16)
  );
  padding-bottom: calc(80rem / var(--font-size__base, 16));
}

.footer_container {
  --_width--left: 552;
  --_width--right: 600;
  --_column-gap: 48;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
}

.footer_info {
  display: grid;
  row-gap: calc(20rem / var(--font-size__base, 16));
}

.footer_clinic-logo {
  max-width: calc(192rem / var(--font-size__base, 16));
}

.footer_details {
  line-height: calc(32 / 16);
}

.footer_phone {
}

.footer_schedule-container {
  background-color: #fff;
  padding-block: calc(24rem / var(--font-size__base, 16));
  padding-inline: calc(19rem / var(--font-size__base, 16));
}

.footer_map-container {
  height: 100%;
}

.footer_map-container iframe {
  width: 100%;
  height: 100%;
}

.footer_hr {
  padding-top: calc(48rem / var(--font-size__base, 16));
}

.footer_menu {
  padding-top: calc(44rem / var(--font-size__base, 16));
}

.footer_copyright {
  /* 背景色グラデーション：左右 #FFCF80、中央 #F89C1B */
  background: linear-gradient(to right, #ffcf80 0%, #f89c1b 50%, #ffcf80 100%);
  padding-block: calc(6rem / var(--font-size__base, 16));
}

.footer_copyright-text {
  text-align: center;
  font-family: var(--font-family__noto-serif);
  color: #fff;
}

/* フッターメニュー */
.footer-menu {
  width: 100%;
}

.footer-menu_inner {
  display: flex;
  justify-content: space-between;
}

.footer-menu_section {
  display: flex;
  flex-direction: column;
}

.footer-menu_title {
  font-family: var(--font-family__mincho);
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 700;
}

.footer-menu_content {
}

.footer-menu_list {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: calc(32rem / var(--font-size__base, 16));
  row-gap: calc(16rem / var(--font-size__base, 16));
  padding-top: calc(24rem / var(--font-size__base, 16));
}

.footer-menu_item {
  position: relative;
  padding-left: 1.5em;
}

.footer-menu_item::before {
  content: "ー";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color__main);
}

.footer-menu_link {
  transition: color var(--duration__base) ease;
}

.footer-menu_link:hover {
  color: var(--color__main);
}

/* ------------------------------ */
/* page-services.php */
/* ------------------------------ */
.services_content {
  background-color: var(--color__ivory);
  padding-top: calc(var(--_80) * 1rem / var(--font-size__base, 16));
  padding-bottom: calc(var(--_128) * 1rem / var(--font-size__base, 16));
}

.services_content p {
  line-height: calc(32 / 16);
}

/* 余白 */
.heading + * {
  margin-top: calc(var(--_37) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-line {
  margin-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
}

p + .care {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

p + .heading-line {
  margin-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
}

.heading-line + .care {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.heading-line + .implant-flow {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.heading-line + .comparison-flow {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-topic {
  margin-top: calc(var(--_96) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-topic + p {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-line + .list {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.services_content .care + p {
  padding-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.services_content .list + p {
  margin-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-line + .dental-progression {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.services_content .dental-progression + p {
  margin-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.services_content p + .hr-reverse {
  margin-top: calc(var(--_45) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-topic + .image-text {
  margin-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.services_content .heading-topic + .treatment-comparison {
  margin-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
}

/* care */
.care {
  background-color: #f1efea;
  padding-block: calc(40rem / var(--font-size__base, 16));
}

.care_inner {
}

.care_heading {
  font-family: var(--font-family__mincho);
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(32 / 20);
  text-align: center;
  padding-inline: calc(
    var(--space-inline__base) * 1rem / var(--font-size__base, 16)
  );
}

.care_heading svg {
  color: var(--color__main);
  margin-top: calc(20rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.care_items {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding-top: calc(31rem / var(--font-size__base, 16));
}

.care_item {
  padding-block: calc(25rem / var(--font-size__base, 16));
}

.care_item-inner {
  display: grid;
  place-items: center;
  max-width: calc(304rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.care_item svg {
  color: var(--color__main);
  margin-top: calc(20rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.care_item:not(:first-child) {
  border-left: 1px solid rgba(145, 136, 126, 0.5);
}

.care_icon {
  width: calc(98rem / var(--font-size__base, 16));
  aspect-ratio: 1;
}

.care_icon svg {
  width: 100%;
  height: 100%;
}

.care_number {
  font-family: var(--font-family__en);
  color: var(--color__gray);
  background-color: rgba(145, 136, 126, 0.1);
  border-radius: 100px;
  line-height: 1;
  margin-top: calc(10rem / var(--font-size__base, 16));
  padding-block: calc(2rem / var(--font-size__base, 16));
  padding-right: calc(10rem / var(--font-size__base, 16));
  padding-left: calc(8rem / var(--font-size__base, 16));
}

.care_title {
  font-size: calc(18rem / var(--font-size__base, 16));
  line-height: calc(32 / 18);
  text-align: center;
  padding-top: calc(3rem / var(--font-size__base, 16));
}

p.care_description {
  line-height: calc(29 / 16);
  padding-top: calc(20rem / var(--font-size__base, 16));
  padding-inline: calc(16rem / var(--font-size__base, 16));
}

/* requests */
p + .requests {
  padding-top: calc(20rem / var(--font-size__base, 16));
}

.requests {
}

.requests_inner {
}

.requests_heading {
  font-family: var(--font-family__mincho);
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: calc(32 / 20);
  text-align: center;
  padding-inline: calc(
    var(--space-inline__base) * 1rem / var(--font-size__base, 16)
  );
}

.requests_heading svg {
  color: var(--color__main);
  margin-top: calc(20rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.requests_items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: calc(48rem / var(--font-size__base, 16));
}

.requests_item {
  background-color: #f1efea;
  border: 1px solid rgba(145, 136, 126, 0.5);
  padding-block: calc(30rem / var(--font-size__base, 16));
}

.requests_item-inner {
  display: grid;
  place-items: center;
  max-width: calc(304rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.requests_item svg {
  color: var(--color__main);
  margin-top: calc(20rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.requests_icon {
  width: calc(98rem / var(--font-size__base, 16));
  aspect-ratio: 1;
}

.requests_icon svg {
  width: 100%;
  height: 100%;
}

.requests_number {
  font-family: var(--font-family__en);
  color: var(--color__gray);
  background-color: rgba(145, 136, 126, 0.1);
  border-radius: 100px;
  line-height: 1;
  margin-top: calc(10rem / var(--font-size__base, 16));
  padding-right: calc(10rem / var(--font-size__base, 16));
  padding-left: calc(8rem / var(--font-size__base, 16));
}

.requests_title {
  font-size: calc(18rem / var(--font-size__base, 16));
  line-height: calc(32 / 18);
  text-align: center;
  padding-top: calc(3rem / var(--font-size__base, 16));
}

.new-patient .requests_description {
  line-height: calc(29 / 16);
  padding-top: calc(14rem / var(--font-size__base, 16));
  padding-inline: calc(16rem / var(--font-size__base, 16));
}

.preventive-dentistry_hr {
  margin-top: calc(var(--_45) * 1rem / var(--font-size__base, 16));
}

.preventive-dentistry .image-text {
  padding-top: calc(var(--_61) * 1rem / var(--font-size__base, 16));
}

.image-text {
  --_width--left: 568;
  --_width--right: 600;
  --_column-gap: 32;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
}

.image-text.image-text--sm-image {
  --_width--left: 240;
  --_width--right: 912;
  --_column-gap: 48;
}

.image-text img {
  width: 100%;
}

.image-text_left {
}

.image-text_name-upper {
  padding-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.image-text_name {
  font-family: var(--font-family__mincho);
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 700;
  padding-top: calc(10rem / var(--font-size__base, 16));
}

.image-text_box {
  background-color: #f1efea;
  margin-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
  padding: calc(var(--_24) * 1rem / var(--font-size__base, 16));
  line-height: calc(32 / 16);
}

.image-text_title {
  font-family: var(--font-family__mincho);
  color: var(--color__main);
  font-size: calc(var(--_24) * 1rem / var(--font-size__base, 16));
  line-height: calc(48 / 24);
  font-weight: 700;
}

.image-text_text {
  line-height: calc(32 / 16);
  padding-top: calc(var(--_14) * 1rem / var(--font-size__base, 16));
}

/* dental-progression */
.dental-progression {
  position: relative;
  z-index: 1;
}

.dental-progression::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  background-image: url(library/images/services_dental-progression-arrow.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.dental-progression_inner {
  padding-right: calc(72rem / var(--font-size__base, 16));
}

.dental-progression_stages {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: calc(32rem / var(--font-size__base, 16));
}

.dental-progression_stages-tab-top,
.dental-progression_stages-tab-bottom {
  display: contents;
}

.dental-progression_stage {
}

.dental-progression_illustration {
  position: relative;
  display: grid;
  align-items: end;
  width: 100%;
  height: calc(203rem / var(--font-size__base, 16));
  background-color: #edebe3;
}

.dental-progression_illustration-label {
  position: absolute;
  top: calc(10rem / var(--font-size__base, 16));
  right: calc(10rem / var(--font-size__base, 16));
}

.dental-progression_label {
  color: #fff;
  font-size: calc(20rem / var(--font-size__base, 16));
  font-weight: 500;
  text-align: center;
  padding-block: calc(8rem / var(--font-size__base, 16));
  padding-inline: calc(8rem / var(--font-size__base, 16));
}

.dental-progression_label--01 {
  background-color: #92d35d;
}

.dental-progression_label--02 {
  background-color: #f8be46;
}

.dental-progression_label--03 {
  background-color: #ff7e42;
}

.dental-progression_label--04 {
  background-color: #f9292e;
}

.dental-progression_label--05 {
  background-color: #b01f1a;
}

/* implant-flow */
.implant-flow {
  position: relative;
  z-index: 1;
}

.implant-flow::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  background-image: url(library/images/services_implant-flow-arrow.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.implant-flow_inner {
  display: grid;
  row-gap: calc(32rem / var(--font-size__base, 16));
  padding-bottom: calc(64rem / var(--font-size__base, 16));
}

.implant-flow_step {
  background-color: #fff;
  padding-block: calc(24rem / var(--font-size__base, 16));
  padding-right: calc(48rem / var(--font-size__base, 16));
  padding-left: calc(24rem / var(--font-size__base, 16));
}

.implant-flow_step-header {
  display: flex;
  align-items: center;
  column-gap: calc(12rem / var(--font-size__base, 16));
}

.implant-flow_step-number {
  font-family: var(--font-family__en);
  color: var(--color__gray);
  padding-block: calc(3rem / var(--font-size__base, 16));
  padding-inline: calc(12rem / var(--font-size__base, 16));
  background-color: rgba(145, 136, 126, 0.1);
  border-radius: 100px;
  flex-shrink: 0;
}

.implant-flow_step-title {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
}

.implant-flow .hr-reverse {
  margin-top: calc(12rem / var(--font-size__base, 16));
}

.hr-reverse + .implant-flow_description {
  padding-top: calc(9rem / var(--font-size__base, 16));
}

/* フォントファミリー */
.ff-noto-serif {
  font-family: var(--font-family__noto-serif);
}

/* フォントウェイト */
.fw-700 {
  font-weight: 700;
}
.fw-500 {
  font-weight: 500;
}

/* 色 */
.color-main {
  color: var(--color__main);
}

.color-gray {
  color: var(--color__gray);
}

/* treatment-comparison */
.treatment-comparison {
}

.treatment-comparison_inner {
}

.treatment-comparison_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(48rem / var(--font-size__base, 16));
}

.treatment-comparison_item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  row-gap: 0;
}

.treatment-comparison_header {
}

.treatment-comparison_title {
  font-family: var(--font-family__mincho);
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 700;
  text-align: center;
}

.treatment-comparison_header svg {
  color: var(--color__main);
  margin-top: calc(24rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.treatment-comparison_illustration {
  margin-top: calc(24rem / var(--font-size__base, 16));
}

.treatment-comparison .comparison-content {
  margin-top: calc(24rem / var(--font-size__base, 16));
}

.treatment-comparison_content-wrapper {
  display: contents;
}

.comparison-content {
  background-color: #f1efea;
  padding-block: calc(20rem / var(--font-size__base, 16));
  padding-inline: calc(24rem / var(--font-size__base, 16));
}

.comparison-content_title {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
}

.comparison-content_hr {
  padding-top: calc(8rem / var(--font-size__base, 16));
}

.comparison-content_list {
  display: grid;
  row-gap: calc(8rem / var(--font-size__base, 16));
  padding-top: calc(16rem / var(--font-size__base, 16));
}

.comparison-content_item {
  display: flex;
  column-gap: calc(16rem / var(--font-size__base, 16));
  line-height: calc(32 / 16);
}

.comparison-content_item::before {
  content: "";
  display: inline-block;
  width: calc(6rem / var(--font-size__base, 16));
  height: calc(6rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
  margin-top: 0.8em;
  flex-shrink: 0;
}

.comparison-content--disadvantages {
  background-color: #e8e5df;
}

.news_lists {
  padding-top: calc(
    var(--space__section--md) * 1rem / var(--font-size__base, 16)
  );
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.fixed-btn {
  position: fixed;
  z-index: 1000;
  bottom: calc(24rem / var(--font-size__base, 16));
  right: calc(48rem / var(--font-size__base, 16));
  display: flex;
  column-gap: calc(16rem / var(--font-size__base, 16));
  background-color: var(--color__main-light);
  border-radius: 100px;
  padding-block: calc(9rem / var(--font-size__base, 16));
  padding-inline: calc(14rem / var(--font-size__base, 16));
  filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.1));
}

.fixed-btn_btn {
  position: relative;
  display: flex;
  align-items: center;
  column-gap: calc(24rem / var(--font-size__base, 16));
  padding-right: calc(32rem / var(--font-size__base, 16));
}
.fixed-btn_btn::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: calc(45rem / var(--font-size__base, 16));
  height: calc(45rem / var(--font-size__base, 16));
  background-color: #fff;
  border-radius: 100px;
  transition: width var(--duration__base) ease;
}
.fixed-btn_btn:not(:last-child)::after {
  content: "：";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: -0.4em;
  transform: translateY(-50%);
  color: #fff;
}
.fixed-btn_icon {
  display: grid;
  place-items: center;
  width: calc(45rem / var(--font-size__base, 16));
  aspect-ratio: 1;
  color: var(--color__main-light);
}
.fixed-btn_icon svg {
  width: calc(24rem / var(--font-size__base, 16));
}
.fixed-btn_text {
  color: #fff;
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 700;
}

.fixed-btn_btn:hover .fixed-btn_text {
  color: var(--color__main-light);
}

.fixed-btn_btn:hover::before {
  width: 100%;
}

/* 404 */
.page-404_content {
  padding-block: calc(80rem / var(--font-size__base, 16));
}

.page-404_content p {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
  text-align: center;
}

@media (max-width: 820px) {
  /* ------------------------------ */
  /* トップページ */
  /* ------------------------------ */
  /* 固定ボタン */
  .fixed-btn {
    bottom: calc(16rem / var(--font-size__base, 16));
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    max-width: calc(350rem / var(--font-size__base, 16));
    width: 100%;
    column-gap: calc(8rem / var(--font-size__base, 16));
    padding-block: calc(8rem / var(--font-size__base, 16));
    padding-inline: calc(8rem / var(--font-size__base, 16));
  }
  .fixed-btn_btn {
    column-gap: calc(4rem / var(--font-size__base, 16));
    padding-right: calc(8rem / var(--font-size__base, 16));
  }
  .fixed-btn_btn::before {
    width: calc(28rem / var(--font-size__base, 16));
    height: calc(28rem / var(--font-size__base, 16));
  }
  .fixed-btn_icon {
    width: calc(28rem / var(--font-size__base, 16));
  }
  .fixed-btn_icon svg {
    width: calc(16rem / var(--font-size__base, 16));
  }
  .fixed-btn_text {
    font-size: calc(12rem / var(--font-size__base, 16));
    padding-bottom: calc(2rem / var(--font-size__base, 16));
  }

  /* ファーストビュー */
  .fv {
    height: auto;
  }
  .fv_container {
    height: auto;
  }
  .fv_content {
    max-width: 100%;
    padding-block: calc(24rem / var(--font-size__base, 16));
  }

  .fv_slider {
    --_width__viewport: 375;
    --_width__slide: 400;
    --_space__gap: 24;

    position: static;
  }

  .fv_slider-item img {
    aspect-ratio: 483 / 608;
    object-fit: cover;
  }

  .fv_text-area {
    padding-inline: 0;
  }

  .fv_text-area::before {
    top: calc(-6rem / var(--font-size__base, 16));
    right: calc(-12rem / var(--font-size__base, 16));
    width: calc(70rem / var(--font-size__base, 16));
  }

  .fv_main-copy {
    font-size: calc(28rem / var(--font-size__base, 16));
  }

  .fv_sub-copy {
    font-size: calc(14rem / var(--font-size__base, 16));
    padding-top: calc(31rem / var(--font-size__base, 16));
  }

  .fv_image {
    margin-inline: calc(-50vw + 50%);
    padding-top: calc(13rem / var(--font-size__base, 16));
  }

  .fv_image img {
    width: 100%;
    margin-inline: auto;
  }

  /* 初めての方へ */
  .beginners {
  }
  .beginners::after {
    top: auto;
    bottom: 0;
  }

  .beginners_inner {
    --_max-width: var(--max-width__base);
  }

  .beginners_content {
    display: block;
    padding-block: calc(48rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .beginners_left-image {
    padding-top: calc(48rem / var(--font-size__base, 16));
  }
  .beginners_main-title {
    font-size: calc(20rem / var(--font-size__base, 16));
    padding-top: calc(24rem / var(--font-size__base, 16));
  }
  .beginners_description {
    padding-top: calc(24rem / var(--font-size__base, 16));
  }
  .beginners_cta {
    padding-top: calc(24rem / var(--font-size__base, 16));
  }
  .beginners_right {
    padding-left: 0;
  }

  /* 診療科目 */
  .treatment_grid {
    display: block;
    margin-top: calc(48rem / var(--font-size__base, 16));
  }
  .treatment_card {
    border-right: 0;
    border-bottom: 0;
  }
  .treatment_card:not(:first-child) {
    border-top: 1px solid #dbd7cc;
  }

  .treatment_card-link {
    padding-block: calc(28rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }

  /* ご挨拶 */
  .greeting {
    padding-top: calc(58rem / var(--font-size__base, 16));
    padding-bottom: calc(54rem / var(--font-size__base, 16));
  }
  .greeting_content {
    display: block;
  }
  .greeting_title {
    font-size: calc(20rem / var(--font-size__base, 16));
  }
  .greeting_right {
    background-color: transparent;
    padding-top: calc(48rem / var(--font-size__base, 16));
    padding-inline: 0;
  }
  .greeting_slider {
    --_width__viewport: 375;
    --_width__slide: 338;
    --_space__gap: 41;

    position: static;
    margin-top: calc(64rem / var(--font-size__base, 16));
  }

  /* 5つの特徴 */
  .feature_content::before {
    opacity: 0.5;
  }
  .feature_content::after {
    opacity: 0.5;
  }

  .feature_card-content {
    padding-top: calc(16rem / var(--font-size__base, 16));
  }
  .feature_card-title {
  }
  .feature_card-text {
    padding-top: calc(16rem / var(--font-size__base, 16));
  }
  .feature_cta {
    padding-top: calc(48rem / var(--font-size__base, 16));
  }

  /* カードナビゲーション */
  .nav-cards {
    padding-block: 0;
  }
  .nav-cards_grid {
    display: block;
  }
  .nav-cards_card {
  }
  .nav-cards::after {
    --_scale-down: 0.4;
    bottom: calc(-32rem * var(--_scale-down) / var(--font-size__base, 16));
    width: calc(640rem * var(--_scale-down) / var(--font-size__base, 16));
    height: calc(32rem * var(--_scale-down) / var(--font-size__base, 16));
  }
  .nav-cards_card-link {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .nav-cards_card:not(:last-child) {
    border-right: 0;
    border-bottom: 1px solid #dbd7cc;
  }
  .nav-cards_card-text {
    padding-top: calc(32rem / var(--font-size__base, 16));
  }

  /* カードナビゲーション下の画像 */
  .full-image_image img {
    min-height: calc(200rem / var(--font-size__base, 16));
    object-fit: cover;
  }

  /* お知らせ */
  .news_grid {
    grid-template-columns: 1fr;
    row-gap: calc(32rem / var(--font-size__base, 16));
  }
  .news_card {
    display: block;
    border: 1px solid #dbd7cc;
  }
  .news_card-date {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .news_card-title {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .news_card-hr {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .news_card-more {
    margin-top: calc(16rem / var(--font-size__base, 16));
    padding-bottom: calc(24rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .news_cta {
    padding-top: calc(28rem / var(--font-size__base, 16));
  }

  /* フッター */
  .footer_inner {
    padding-block: calc(48rem / var(--font-size__base, 16));
  }
  .footer_container {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }
  .footer_map-container {
    aspect-ratio: 16 / 9;
  }
  .footer_hr {
    padding-top: calc(48rem / var(--font-size__base, 16));
  }
  .footer-menu_inner {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: calc(32rem / var(--font-size__base, 16));
  }
  .footer-menu_section {
  }
  .footer-menu_title {
  }
  .footer-menu_content {
  }
  .footer-menu_list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: calc(10rem / var(--font-size__base, 16));
  }
  .footer-menu_item {
    font-size: calc(14rem / var(--font-size__base, 16));
  }

  /* schedule */
  .schedule {
    padding-inline: calc(14rem / var(--font-size__base, 16));
  }
  .schedule_table th,
  .schedule_table td {
    padding-block: calc(12rem / var(--font-size__base, 16));
    padding-inline: calc(8rem / var(--font-size__base, 16));
    padding-inline: calc(7rem / var(--font-size__base, 16));
  }
  .schedule_table th {
    font-size: calc(12rem / var(--font-size__base, 16));
  }
  .schedule_table td {
    font-size: calc(12rem / var(--font-size__base, 16));
  }
  .schedule_note {
    font-size: calc(12rem / var(--font-size__base, 16));
  }

  /* ------------------------------ */
  /* 診療案内ページ */
  /* ------------------------------ */
  /* サブページのファーストビュー */
  .sub-fv_image img {
    height: calc(200rem / var(--font-size__base, 16));
  }
  .sub-fv_image::after {
    --_scale-down: 0.6;
    width: calc(640rem * var(--_scale-down) / var(--font-size__base, 16));
    height: calc(32rem * var(--_scale-down) / var(--font-size__base, 16));
  }
  .sub-fv_title {
    font-size: calc(28rem / var(--font-size__base, 16));
  }
  .sub-fv_subtitle {
    font-size: calc(14rem / var(--font-size__base, 16));
  }

  /* 診療案内のタブ */
  .services_tabs {
    margin-top: calc(32rem / var(--font-size__base, 16));
    padding-top: 0;
  }
  .services_tabs .tabs_inner {
    padding-block: calc(16rem / var(--font-size__base, 16));
  }
  .services_tabs .tabs_list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(6rem / var(--font-size__base, 16));
  }
  .services_tabs .tabs_item {
  }

  .services_tabs .tabs_link {
    font-size: calc(12rem / var(--font-size__base, 16));
    column-gap: calc(8rem / var(--font-size__base, 16));
    border-radius: 5px;
  }

  .services_tabs .tabs_link svg {
    width: calc(7rem / var(--font-size__base, 16));
    margin-top: calc(2rem / var(--font-size__base, 16));
  }

  /* heading */
  .heading_title {
    column-gap: calc(16rem / var(--font-size__base, 16));
  }
  .heading_title:has(.heading_title-top) {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: calc(16rem / var(--font-size__base, 16));
  }
  .heading_title-top {
    display: flex;
    column-gap: calc(16rem / var(--font-size__base, 16));
  }
  .heading_title-bottom {
    display: flex;
    column-gap: calc(16rem / var(--font-size__base, 16));
    padding-left: calc(24rem / var(--font-size__base, 16));
  }
  .heading_icon {
    width: calc(8rem / var(--font-size__base, 16));
  }
  .heading_title-ja {
    font-size: calc(24rem / var(--font-size__base, 16));
  }
  .heading_title-en {
  }
  .heading_hr {
    padding-top: calc(24rem / var(--font-size__base, 16));
  }

  /* heading-topic */
  .heading-topic {
    padding-top: calc(11rem / var(--font-size__base, 16));
    padding-left: calc(12rem / var(--font-size__base, 16));
  }
  .heading-topic_en {
    font-size: calc(14rem / var(--font-size__base, 16));
  }
  .heading-topic_ja {
    font-size: calc(20rem / var(--font-size__base, 16));
    line-height: 1.5;
    padding-top: calc(4rem / var(--font-size__base, 16));
  }

  /* care */
  .care {
    padding-block: calc(32rem / var(--font-size__base, 16));
  }
  .care_heading {
    font-size: calc(18rem / var(--font-size__base, 16));
  }
  .care_item-inner {
    max-width: calc(400rem / var(--font-size__base, 16));
  }

  /* image-text */
  .image-text {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }
  .image-text_left {
  }
  .image-text_right {
  }
  .image-text_title {
    font-size: calc(20rem / var(--font-size__base, 16));
  }
  .image-text_text {
    padding-top: calc(16rem / var(--font-size__base, 16));
  }

  /* list */
  .list {
    grid-template-columns: 1fr;
    row-gap: calc(16rem / var(--font-size__base, 16));
  }
  .list_item {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }

  /* 歯周病の進行 */
  .dental-progression::before {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-image: url(library/images/services_dental-progression-arrow-down.webp);
    width: calc(56rem / var(--font-size__base, 16));
  }
  .dental-progression_inner {
    position: relative;
    z-index: -1;
    padding-right: 0;
    padding-bottom: calc(91rem / var(--font-size__base, 16));
  }
  .dental-progression_stages {
    grid-template-columns: 1fr;
    row-gap: calc(32rem / var(--font-size__base, 16));
  }
  .dental-progression_stage {
  }
  .dental-progression_illustration img {
    max-width: calc(200rem / var(--font-size__base, 16));
    margin-inline: auto;
  }
  .dental-progression_label {
    font-size: calc(16rem / var(--font-size__base, 16));
  }

  /* heading-line */
  .heading-line {
    --_width: 32;
    --_gap: 8;
    font-size: calc(18rem / var(--font-size__base, 16));
  }

  /* implant-flow */
  .implant-flow_inner {
    row-gap: calc(28rem / var(--font-size__base, 16));
  }
  .implant-flow_step {
    padding-block: calc(28rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .implant-flow_step-header {
    display: block;
  }
  .implant-flow_step-number {
    font-size: calc(14rem / var(--font-size__base, 16));
  }
  .implant-flow_step-title {
    font-size: calc(16rem / var(--font-size__base, 16));
    padding-top: calc(14rem / var(--font-size__base, 16));
    line-height: 2;
  }
  .implant-flow .hr-reverse {
    margin-top: calc(8rem / var(--font-size__base, 16));
  }
  .implant-flow::after {
    width: calc(56rem / var(--font-size__base, 16));
    background-image: url(library/images/services_dental-progression-arrow-down.webp);
    background-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
  }

  /* treatment-comparison */
  .treatment-comparison_grid {
    grid-template-columns: 1fr;
  }

  /* comparison-content */
  .comparison-content {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .treatment-comparison_item {
    grid-template-rows: unset;
    grid-row: unset;
  }
  .comparison-content_title {
  }
  .comparison-content_text {
  }

  /* implant  */
  .implant .image-text_left {
  }
  .implant .image-text_left img {
    aspect-ratio: 16 / 9;
    object-fit: contain;
    background-color: #f0efeb;
  }
}

@media (max-width: 820px) and (min-width: 641px) {
  /* treatment */
  .treatment_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .treatment_card:nth-child(2n) {
    border-left: 1px solid #dbd7cc;
  }
  /* treatment-comparison */
  .treatment-comparison_illustration {
    max-width: calc(368rem / var(--font-size__base, 16));
    margin-inline: auto;
  }
  .treatment-comparison_content-wrapper {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: calc(15rem / var(--font-size__base, 16));
  }
  /* dental-progression */
  .dental-progression::before {
    content: none;
  }
  .dental-progression_stages-tab-top,
  .dental-progression_stages-tab-bottom {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: calc(32rem / var(--font-size__base, 16));
    padding-inline: calc(43rem / var(--font-size__base, 16));
  }
  .dental-progression_stages-tab-top::before,
  .dental-progression_stages-tab-bottom::before {
    --height: 56;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 100%;
  }
  .dental-progression_stages-tab-top::before {
    background-color: #e8e4d2;
    height: calc(var(--height) / 820 * 100vw);
  }
  .dental-progression_stages-tab-bottom::before {
    height: calc(var(--height) * 1rem / var(--font-size__base, 16));
    background-image: url(library/images/services_dental-progression-arrow-tab.webp);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
  }
  .dental-progression_illustration {
    height: calc(203 / 820 * 100vw);
  }
  .dental-progression_illustration img {
    max-width: 100%;
  }
  .dental-progression_inner {
    padding-bottom: 0;
  }

  /* tabs */
  .services_tabs .tabs_link {
    font-size: calc(14rem / var(--font-size__base, 16));
  }

  /* care */
  .care_items {
    grid-template-columns: repeat(2, 1fr);
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }

  .care_item:not(:first-child) {
    border-left: 0;
  }
  .care_item:nth-child(2n) {
    border-left: 1px solid #dbd7cc;
  }
  .care_item:nth-child(n + 3) {
    border-top: 1px solid #dbd7cc;
  }

  /* 歯ぎしり・食いしばり */
  .symptoms-comparison {
    padding-inline: calc(40rem / var(--font-size__base, 16));
  }
  .symptoms-comparison_grid {
    column-gap: calc(24rem / var(--font-size__base, 16));
  }
}

/* ------------------------------ */
/* 当院について */
/* ------------------------------ */
/* 院長あいさつ */
.about_greeting {
  padding-top: calc(
    var(--space__section--md) * 1rem / var(--font-size__base, 16)
  );
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.about-greeting .image-text {
  --_width--left: 552;
  --_column-gap: 48;
}

/* わたしたちは、患者様の人生にそっと光を添える存在でありたいと願っています。 */
.about_wishes {
  background-color: #f1efea;
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.wishes_inner {
  position: relative;
  z-index: 1;
}

.wishes_bg {
  position: relative;
}

.wishes_bg::before,
.wishes_bg::after {
  content: "";
  position: absolute;
  width: calc(331rem / var(--font-size__base, 16));
  height: calc(1073rem / var(--font-size__base, 16));
  background-image: url(./library/images/top_feature-left.webp);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.wishes_bg::before {
  bottom: 0;
}

.wishes_bg::after {
  top: 0;
  right: 0;
  background-image: url(./library/images/top_feature-right.webp);
}

.wishes_content {
  background-color: #fff;
  padding-bottom: calc(
    var(--space__section--sm) * 1rem / var(--font-size__base, 16)
  );
}

.wishes_content-heading {
}

.wishes_image {
  position: relative;
}

.wishes_image img {
}

.wishes_image::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: calc(640rem / var(--font-size__base, 16));
  height: calc(32rem / var(--font-size__base, 16));
  background-image: url("./library/images/about_wishes-img-bottom.webp");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.wishes_content-heading-text {
  padding-top: calc(48rem / var(--font-size__base, 16));
}

.wishes_content-title {
  text-align: center;
  font-size: calc(20rem / var(--font-size__base, 16));
  line-height: calc(32 / 20);
}

.wishes_content-subtitle {
  color: var(--color__gray);
  font-size: calc(16rem / var(--font-size__base, 16));
  text-align: center;
  line-height: calc(32 / 16);
  padding-top: calc(11rem / var(--font-size__base, 16));
}

.wishes_content-circle {
  display: grid;
  place-items: center;
  padding-top: calc(24rem / var(--font-size__base, 16));
}

.wishes-cards {
  padding-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
  padding-inline: calc(48rem / var(--font-size__base, 16));
}

.wishes-cards_items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(48rem / var(--font-size__base, 16));
}

.wishes-cards_item {
  background-color: #fbfaf6;
  padding-block: calc(32rem / var(--font-size__base, 16));
  padding-inline: calc(48rem / var(--font-size__base, 16));
}

.wishes-cards_item-title {
  font-size: calc(18rem / var(--font-size__base, 16));
  text-align: center;
  line-height: calc(32 / 18);
}

.wishes-cards svg {
  color: var(--color__main);
  margin-top: calc(14rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.wishes-cards_item-text {
  line-height: calc(29 / 16);
  padding-top: calc(16rem / var(--font-size__base, 16));
}

.loop-text-slider {
  --_speed: 50s;
  --_delay: 0s;
  --_space__gap: 103;

  display: flex;
  overflow: hidden;
  white-space: nowrap;
}
.loop-text-slider_items {
  animation: loop-slider-left var(--_speed) infinite linear var(--_delay) both;
  display: flex;
}
.loop-text-slider_item {
  color: #e8e5df;
  font-size: calc(145rem / var(--font-size__base, 16));
  font-family: var(--font-family__en);
  padding-inline: calc(
    (var(--_space__gap) / 2) * 1rem / var(--font-size__base, 16)
  );
}

/* 当院の理念 */
.about_concept {
  padding-top: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.concept_content-box {
  padding-top: calc(var(--_37) * 1rem / var(--font-size__base, 16));
}

.concept_content-heading {
  display: grid;
  grid-template-columns:
    1fr
    calc(96rem / var(--font-size__base, 16))
    1fr
    calc(96rem / var(--font-size__base, 16))
    1fr;
  align-items: center;
}

.concept_image {
  width: 100%;
}

.concept_image img {
  width: 100%;
}

/* アコーディオン */
.js-accordion_button {
  width: 100%;
}

.js-accordion_panel {
  display: grid;
  grid-template-rows: 0fr; /* 初期状態で高さを0に */
  transition: grid-template-rows 0.3s; /* スムーズなアニメーション */
}

.js-accordion_panel > div {
  overflow: hidden; /* 子要素がはみ出ないように */
}

.js-accordion_panel:not([hidden]) {
  grid-template-rows: 1fr; /* 開いた状態では高さを自動調整 */
}

.accordion {
}
.accordion:last-child .accordion_panel {
  border-bottom: 1px solid var(--color__gray);
}
.accordion_button {
  display: grid;
  grid-template-columns:
    calc(56rem / var(--font-size__base, 16))
    calc(12rem / var(--font-size__base, 16))
    1fr
    calc(24rem / var(--font-size__base, 16));
  align-items: center;
  column-gap: calc(66rem / var(--font-size__base, 16));
  text-align: left;
  background-color: transparent;
  border: 0;
  border-top: 1px solid var(--color__gray);
  padding-block: calc(40rem / var(--font-size__base, 16));
  padding-left: calc(12rem / var(--font-size__base, 16));
  padding-right: calc(32rem / var(--font-size__base, 16));
}

.accordion_button-title {
  font-size: calc(28rem / var(--font-size__base, 16));
  line-height: calc(32 / 28);
}

.accordion_button-circle {
  aspect-ratio: 1;
  background: linear-gradient(to bottom, #71aa71 0%, #a5e6a8 100%);
  border-radius: 50%;
  filter: drop-shadow(0 0 5px #91cf93);
}

.accordion_button-circle--red {
  background: linear-gradient(to bottom, #ff4e4e 0%, #ffacdf 100%);
  filter: drop-shadow(0 0 5px #ff6e7e);
}

.accordion_button-circle--blue {
  background: linear-gradient(to bottom, #8488fd 0%, #a8e4ff 100%);
  filter: drop-shadow(0 0 5px #96b6fe);
}

.accordion_button-text {
  font-size: calc(18rem / var(--font-size__base, 16));
  line-height: calc(32 / 18);
}
.accordion_button-icon {
  --_icon-size: 24;

  width: calc(var(--_icon-size) * 1rem / var(--font-size__base, 16));
  height: calc(var(--_icon-size) * 1rem / var(--font-size__base, 16));
  border-radius: 50%;
  position: relative;
}

.accordion_button-icon::before,
.accordion_button-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: calc(var(--_icon-size) * 1rem / var(--font-size__base, 16));
  height: calc(1rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
}

.accordion_button-icon::after {
  width: calc(1rem / var(--font-size__base, 16));
  height: calc(var(--_icon-size) * 1rem / var(--font-size__base, 16));
  transition: rotate var(--duration__base);
}

.accordion_button-heading {
  display: contents;
}

.accordion_button-icon-box {
  display: contents;
}

.accordion_panel-content {
  padding-bottom: calc(24rem / var(--font-size__base, 16));
}

.accordion_panel-content-texts {
  display: grid;
  grid-template-columns:
    calc(56rem / var(--font-size__base, 16))
    calc(12rem / var(--font-size__base, 16))
    1fr
    calc(24rem / var(--font-size__base, 16));
  align-items: center;
  column-gap: calc(66rem / var(--font-size__base, 16));
  width: 100%;
  text-align: left;
  background-color: transparent;
  border: 0;
  padding-left: calc(12rem / var(--font-size__base, 16));
  padding-right: calc(32rem / var(--font-size__base, 16));
}

.accordion_panel-content-text {
  line-height: calc(32 / 16);
  padding-right: calc(8rem / var(--font-size__base, 16));
}

.accordion_panel-content-bottom {
  display: grid;
  justify-content: center;
  padding-top: calc(64rem / var(--font-size__base, 16));
}
.accordion_panel-content-close {
  border: 0;
  background-color: transparent;
  color: var(--color__gray);
  cursor: pointer;
}
.accordion_panel-content-close:hover {
  color: var(--color__main);
}

/* アコーディオンが開いているとき */
.accordion_button[aria-expanded="true"] .accordion_button-icon {
}

.accordion_button[aria-expanded="true"] .accordion_button-icon::after {
  rotate: 90deg;
}

/* 交通アクセス */
.about_access {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.about_access .heading-underdot {
  padding-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.access_inner > p {
  line-height: calc(32 / 16);
}

.heading-underdot_text {
  font-size: calc(18rem / var(--font-size__base, 16));
}

.heading-underdot_icon {
  margin-top: calc(20rem / var(--font-size__base, 16));
}

.heading-underdot_icon svg {
  color: var(--color__main);
}

.heading-underdot + p {
  padding-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

/* ご予約方法 */
.about_reservation {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.columns-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(48rem / var(--font-size__base, 16));
}

.columns-3_item {
}

.columns-3_item > * {
  height: 100%;
}

@media (max-width: 820px) {
  /* wishes */
  .wishes_image img {
  }
  .wishes_image::after {
    --_scale-down: 0.6;
    width: calc(640rem * var(--_scale-down) / var(--font-size__base, 16));
    height: calc(32rem * var(--_scale-down) / var(--font-size__base, 16));
  }
  .wishes_content-heading-text {
    padding-top: calc(37rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .wishes_content-title {
    font-size: calc(18rem / var(--font-size__base, 16));
    text-align: left;
  }
  .wishes_content-subtitle {
    font-size: calc(14rem / var(--font-size__base, 16));
    text-align: left;
  }
  .wishes-cards {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .wishes-cards_items {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }
  .wishes-cards_item {
    padding-inline: calc(16rem / var(--font-size__base, 16));
  }

  /* loop-text-slider */
  .loop-text-slider {
    --_width__viewport: 375;
    --_width__slide: 750;
    --_space__gap: 24;
  }

  /* concept */
  .concept_content-heading {
    grid-template-columns: 1fr;
  }

  /* accordion */
  .accordion_button {
    grid-template-columns: 1fr;
    column-gap: calc(24rem / var(--font-size__base, 16));
    row-gap: calc(20rem / var(--font-size__base, 16));
    padding-inline: 0;
  }
  .accordion_button-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    column-gap: calc(16rem / var(--font-size__base, 16));
    row-gap: calc(20rem / var(--font-size__base, 16));
  }
  .accordion_button-icon-box {
    display: flex;
    align-items: center;
    column-gap: calc(66rem / var(--font-size__base, 16));
  }
  .accordion_button-title {
    font-size: calc(20rem / var(--font-size__base, 16));
  }
  .accordion_button-circle {
    width: calc(12rem / var(--font-size__base, 16));
  }
  .accordion_button-text {
  }
  .accordion_button-icon {
    --_icon-size: 17;
  }
  .accordion_panel-content-texts {
    grid-template-columns: 1fr;
    padding-left: 0;
    padding-right: 0;
  }

  /* access */
  .access_map iframe {
    aspect-ratio: 16 / 9;
    max-width: 100%;
    width: 100%;
    height: 100%;
  }
}

/* ------------------------------ */
/* 初めての方へ */
/* ------------------------------ */
.heading-main {
  font-family: var(--font-family__mincho);
  color: var(--color__main);
  font-size: calc(24rem / var(--font-size__base, 16));
  font-weight: 700;
  line-height: 2;
}

/*
   初めての方へ
  ----------------------------------------------------------- */
.new-patient_anchor-list {
  margin-top: calc(40rem / var(--font-size__base, 16));
}

.new-patient p {
  line-height: calc(32 / 16);
}

.anchor-list {
  background-color: #f1efea;
}
.anchor-list_inner {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: calc(11rem / var(--font-size__base, 16));
  padding-block: calc(16rem / var(--font-size__base, 16));
}
.anchor-list_link {
  display: grid;
  grid-template-columns: 1fr calc(8rem / var(--font-size__base, 16));
  align-items: center;
  column-gap: calc(15rem / var(--font-size__base, 16));
  background-color: var(--color__ivory);
  border-radius: calc(2rem / var(--font-size__base, 16));
  padding-block: calc(18rem / var(--font-size__base, 16));
  padding-inline: calc(16rem / var(--font-size__base, 16));
}
.anchor-list_link svg {
  color: var(--color__gray);
}

.anchor-list_link:hover {
  color: var(--color__main);
}

.anchor-list_link:hover svg {
  color: var(--color__main);
}

/* 初めてご来院される方へ */
.new-patient_for-beginners {
  padding-top: calc(var(--_80) * 1rem / var(--font-size__base, 16));
  padding-bottom: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.new-patient_for-beginners .image-text {
  padding-top: calc(8rem / var(--font-size__base, 16));
}

/* 当院の考え */
.new-patient_thoughts {
  position: relative;
  background-color: #f1efea;
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.new-patient_thoughts::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: calc(331rem / var(--font-size__base, 16));
  height: 100%;
  background-image: url(library/images/new-patient_thoughts-left.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.new-patient_thoughts::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: calc(331rem / var(--font-size__base, 16));
  height: 100%;
  background-image: url(library/images/new-patient_thoughts-right.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.new-patient_thoughts .heading-main + p {
  padding-top: calc(var(--_24) * 1rem / var(--font-size__base, 16));
}

.thoughts {
  position: relative;
  z-index: 1;
}

/* 患者様へのお願い */
.new-patient_patient-requests {
  padding-top: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

/* 従来の治療と現在の治療 */
.new-patient_treatment-comparison {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.comparison-flow {
  position: relative;
  z-index: 1;
}

.comparison-flow::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  background-image: url(library/images/services_implant-flow-arrow.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.comparison-flow_inner {
  display: grid;
  row-gap: calc(26rem / var(--font-size__base, 16));
  padding-bottom: calc(64rem / var(--font-size__base, 16));
}

.comparison-flow_step {
  background-color: #e8e5df;
  padding-top: calc(32rem / var(--font-size__base, 16));
  padding-bottom: calc(28rem / var(--font-size__base, 16));
  padding-inline: calc(48rem / var(--font-size__base, 16));
}

.comparison-flow_step:nth-child(2) {
  background-color: #f1efea;
}

.comparison-flow_header {
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
}

.comparison-flow .hr-reverse {
  margin-top: calc(12rem / var(--font-size__base, 16));
}

.comparison-flow_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: calc(16rem / var(--font-size__base, 16));
  row-gap: calc(8rem / var(--font-size__base, 16));
  padding-top: calc(21rem / var(--font-size__base, 16));
}

.comparison-flow_item {
  display: flex;
  column-gap: calc(16rem / var(--font-size__base, 16));
  line-height: calc(32 / 16);
}

.comparison-flow_item::before {
  content: "";
  display: inline-block;
  width: calc(6rem / var(--font-size__base, 16));
  height: calc(6rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
  margin-top: 0.8em;
  flex-shrink: 0;
}

/* 治療までの流れ */
.new-patient_process {
  background-color: #f1efea;
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.new-patient_process .tabs {
  padding-top: 0;
}

/* 処置に入る前に */
.new-patient_before-starting {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

/* 毎日のケアについて */
.new-patient_daily-care {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.new-patient_daily-care {
  position: relative;
  background-color: #f1efea;
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.new-patient_daily-care::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: calc(331rem / var(--font-size__base, 16));
  height: 100%;
  background-image: url(library/images/new-patient_thoughts-left.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.new-patient_daily-care::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: calc(331rem / var(--font-size__base, 16));
  height: 100%;
  background-image: url(library/images/new-patient_thoughts-right.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* メンテナンス・定期検診 */
.new-patient_maintenance {
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.maintenance {
}

.columns-2-box {
  background-color: #f1efea;
  border: 1px solid rgba(145, 136, 126, 0.5);
}
.columns-2-box_inner {
  --_width--left: 276;
  --_width--right: 922;
  --_column-gap: 0;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
  align-items: center;
  padding-block: calc(40rem / var(--font-size__base, 16));
  padding-inline: calc(48rem / var(--font-size__base, 16));
}
.columns-2-box--access .columns-2-box_inner {
  --_width--left: 240;
  --_width--right: 960;
}
.columns-2-box_left {
  color: var(--color__main);
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 700;
}
.columns-2-box_right {
  border-left: 1px solid rgba(112, 112, 112, 0.5);
  padding-block: calc(var(--_24) * 1rem / var(--font-size__base, 16));
  padding-left: calc(64rem / var(--font-size__base, 16));
}
.columns-2-box_right-title {
  display: flex;
  align-items: center;
  column-gap: calc(10rem / var(--font-size__base, 16));
  font-size: calc(20rem / var(--font-size__base, 16));
}

.columns-2-box_right-title svg {
  margin-top: calc(2rem / var(--font-size__base, 16));
}

.columns-2-box_right-title + p {
  padding-top: calc(10rem / var(--font-size__base, 16));
}

.columns-2-box_right-title:nth-child(n + 2) {
  padding-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.columns-2-box_right-note {
  font-size: calc(14rem / var(--font-size__base, 16));
  line-height: 1.8;
  padding-top: calc(12rem / var(--font-size__base, 16));
}

/* 外観の画像 */
.new-patient_exterior {
}

/* 最後に */
.new-patient_last {
  padding-top: calc(
    var(--space__section--sm) * 1rem / var(--font-size__base, 16)
  );
}

/* ループ */
.new-patient_loop {
  padding-top: calc(59rem / var(--font-size__base, 16));
  padding-bottom: calc(163rem / var(--font-size__base, 16));
}

.loop-image-slider {
  --_speed: 50s;
  --_delay: 0s;
  --_width__viewport: 1920;
  --_width__slide: 1544;
  --_space__gap: 87;

  display: flex;
  overflow: hidden;
}
.loop-image-slider_items {
  animation: loop-slider-left var(--_speed) infinite linear var(--_delay) both;
  display: flex;
}
.loop-image-slider_item {
  max-width: calc(
    (var(--_width__slide) + var(--_space__gap)) * 1rem /
      var(--font-size__base, 16)
  );
  width: calc(
    (
      (var(--_width__slide) + var(--_space__gap)) / var(--_width__viewport) *
        100vw
    )
  );
  padding-inline: calc(
    (var(--_space__gap) / 2) / var(--_width__viewport) * 100vw
  );
}
.loop-image-slider_item img {
  display: block;
  width: 100%;
}

@keyframes loop-slider-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

/* 余白 */
.heading-main + p {
  padding-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

.comparison-flow + .hr-reverse {
  margin-top: calc(var(--_45) * 1rem / var(--font-size__base, 16));
}

.hr-reverse + p {
  padding-top: calc(var(--_61) * 1rem / var(--font-size__base, 16));
}

p + .columns-2-box {
  margin-top: calc(var(--_32) * 1rem / var(--font-size__base, 16));
}

/* 病院概要 */
.about_outline {
  background-color: #f1efea;
  padding-block: calc(
    var(--space__section--lg) * 1rem / var(--font-size__base, 16)
  );
}

.outline_content {
  display: grid;
  row-gap: calc(16rem / var(--font-size__base, 16));
}

.grid-table {
}
.grid-table_inner {
}
.grid-table_item {
  --_width--left: 268;
  --_width--right: 932;
  --_column-gap: 0;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
  min-height: calc(58rem / var(--font-size__base, 16));
}

.grid-table_item dt {
  display: flex;
  align-items: center;
  font-size: calc(18rem / var(--font-size__base, 16));
  font-weight: 500;
  color: #fff;
  background-color: var(--color__main);
  padding-inline: calc(32rem / var(--font-size__base, 16));
  padding-block: calc(13rem / var(--font-size__base, 16));
}

.grid-table_item dd {
  display: flex;
  align-items: center;
  line-height: calc(32 / 16);
  padding-inline: calc(48rem / var(--font-size__base, 16));
  background-color: #fff;
  padding-block: calc(13rem / var(--font-size__base, 16));
}

.new-patient_content {
  background-color: var(--color__ivory);
  padding-block: calc(
    var(--space__section--sm) * 1rem / var(--font-size__base, 16)
  );
  padding-inline: calc(
    var(--space__section--xs) * 1rem / var(--font-size__base, 16)
  );
}

/* step */
.step {
}

.step_container {
  display: grid;
  row-gap: calc(67rem / var(--font-size__base, 16));
}

.step_item {
  --_width--left: 249;
  --_width--right: 823;
  --_column-gap: 32;
  --_width--total: calc(
    var(--_width--left) + var(--_column-gap) + var(--_width--right)
  );

  display: grid;
  grid-template-columns:
    calc(var(--_width--left) / var(--_width--total) * 100%)
    calc(var(--_width--right) / var(--_width--total) * 100%);
  column-gap: calc((var(--_column-gap) / var(--_width--total)) * 100%);
}

.step_image {
  position: relative;
}

.step_item:not(:first-child) .step_image::before {
  content: "";
  position: absolute;
  top: calc((-24rem - 16rem) / var(--font-size__base, 16));
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: calc(19rem / var(--font-size__base, 16));
  height: calc(16rem / var(--font-size__base, 16));
  background-image: url(library/images/new-patient_step-arrow.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.step_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.step_content {
  position: relative;
  padding-bottom: calc(29rem / var(--font-size__base, 16));
}

.step_number {
  font-family: var(--font-family__en);
  color: var(--color__main);
}

.step_title {
  font-family: var(--font-family__mincho);
  font-size: calc(24rem / var(--font-size__base, 16));
  font-weight: 700;
  padding-top: calc(8rem / var(--font-size__base, 16));
}

.step_description {
  line-height: calc(32 / 16);
  padding-top: calc(24rem / var(--font-size__base, 16));
}

.step_arrow {
  display: flex;
  justify-content: center;
  align-items: center;
}

.step_arrow-icon {
  width: 0;
  height: 0;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 18px solid var(--color-main);
}

.step .hr-reverse {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}

.new-patient_second-visit .step_item:nth-child(2) {
  margin-top: calc(-29rem / var(--font-size__base, 16));
}

/* 3回目のご来院 */
p + .third-visit-cards {
  padding-top: calc(var(--_48) * 1rem / var(--font-size__base, 16));
}

.third-visit-cards {
}

.third-visit-cards_items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(48rem / var(--font-size__base, 16));
}

.third-visit-cards_item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}

.third-visit-cards_item-title {
  display: flex;
  align-items: center;
  column-gap: calc(10rem / var(--font-size__base, 16));
  font-size: calc(18rem / var(--font-size__base, 16));
}

.third-visit-cards_item-title svg {
  color: var(--color__main);
}

.third-visit-cards_box {
  background-color: #f1efea;
  border: 1px solid rgba(145, 136, 126, 0.5);
  margin-top: calc(14rem / var(--font-size__base, 16));
  padding-block: calc(32rem / var(--font-size__base, 16));
  padding-inline: calc(48rem / var(--font-size__base, 16));
}

.third-visit-cards_item-subtitle {
  font-size: calc(18rem / var(--font-size__base, 16));
  text-align: center;
  line-height: calc(32 / 18);
}

.third-visit-cards_item-icon svg {
  color: var(--color__main);
  margin-top: calc(20rem / var(--font-size__base, 16));
  margin-inline: auto;
}

.third-visit-cards_item-text {
  line-height: calc(29 / 16);
  padding-top: calc(20rem / var(--font-size__base, 16));
}

.third-visit-cards_more {
  display: flex;
  justify-content: end;
  border-top: 1px solid rgba(112, 112, 112, 0.5);
  margin-top: calc(24rem / var(--font-size__base, 16));
  padding-top: calc(22rem / var(--font-size__base, 16));
}

.third-visit-cards_more a {
  display: flex;
  align-items: center;
  column-gap: calc(10rem / var(--font-size__base, 16));
  color: var(--color__gray);
  transition: color var(--duration__base) ease;
  font-family: var(--font-family__en);
}

.third-visit-cards_more-icon {
  display: grid;
  place-items: center;
  width: calc(16rem / var(--font-size__base, 16));
  height: calc(16rem / var(--font-size__base, 16));
  background-color: var(--color__gray);
  border-radius: 50%;
  transition: background-color var(--duration__base) ease;
}

.third-visit-cards_more-icon svg {
  color: #fff;
}

.third-visit-cards_more a:hover {
  color: var(--color__main);
}

.third-visit-cards_more a:hover .third-visit-cards_more-icon {
  background-color: var(--color__main);
}

@media (max-width: 820px) {
  /* ------------------------------ */
  /* 初めての方へ */
  /* ------------------------------ */
  /* .anchor-list */
  .anchor-list_inner {
    grid-template-columns: repeat(2, 1fr);
  }
  .anchor-list_link {
    font-size: calc(12rem / var(--font-size__base, 16));
    column-gap: calc(6rem / var(--font-size__base, 16));
    padding-inline: calc(8rem / var(--font-size__base, 16));
  }
  .anchor-list_link svg {
    margin-top: calc(3rem / var(--font-size__base, 16));
  }

  /* new-patient_for-beginners */
  .new-patient_for-beginners .image-text {
    padding-top: 0;
  }

  /* heading-main */
  .heading-main {
    font-size: calc(20rem / var(--font-size__base, 16));
  }

  /* comparison-flow */
  .comparison-flow_step {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }

  .comparison-flow_list {
    grid-template-columns: 1fr;
    padding-top: calc(16rem / var(--font-size__base, 16));
  }

  .comparison-flow_item {
  }

  /* process */
  .process .tabs_link {
    text-align: center;
    font-size: calc(14rem / var(--font-size__base, 16));
    column-gap: calc(6rem / var(--font-size__base, 16));
    padding-inline: calc(16rem / var(--font-size__base, 16));
  }

  .process .tabs_link::before {
    width: calc(16rem / var(--font-size__base, 16));
    height: calc(16rem / var(--font-size__base, 16));
  }

  /* third-visit-cards */
  .third-visit-cards_box {
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .third-visit-cards_items {
    column-gap: calc(24rem / var(--font-size__base, 16));
  }

  /* new-patient */
  .new-patient_thoughts::before,
  .new-patient_thoughts::after {
    opacity: 0.5;
    width: calc(165rem / var(--font-size__base, 16));
  }

  .new-patient_daily-care::before,
  .new-patient_daily-care::after {
    opacity: 0.5;
    width: calc(165rem / var(--font-size__base, 16));
  }

  /* columns-2-box */
  .columns-2-box_inner {
    grid-template-columns: 1fr;
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .columns-2-box_right {
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(112, 112, 112, 0.5);
    margin-top: calc(24rem / var(--font-size__base, 16));
    padding-bottom: 0;
  }

  /* left-image */
  .left-image_image img {
    /* height: calc(130rem / var(--font-size__base, 16));
      object-fit: cover; */
  }

  /* new-patient_loop */
  .new-patient_loop {
    padding-top: calc(32rem / var(--font-size__base, 16));
    padding-bottom: calc(64rem / var(--font-size__base, 16));
  }

  /* loop-image-slider */
  .loop-image-slider {
    --_width__viewport: 375;
    --_width__slide: 750;
    --_space__gap: 24;
  }

  /* grid-table */
  .grid-table_item {
    --_width--left: 100;
    --_width--right: 237;
  }
  .grid-table_item dt {
    font-size: calc(16rem / var(--font-size__base, 16));
    padding-inline: calc(16rem / var(--font-size__base, 16));
  }
  .grid-table_item dd {
    padding-inline: calc(16rem / var(--font-size__base, 16));
  }
  .grid-table_item dd + dd {
    padding-top: calc(12rem / var(--font-size__base, 16));
  }

  /* columns-3 */
  .columns-3 {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }

  /* step */
  .step_item {
    --_width--left: 550;
    --_width--right: 600;
    --_column-gap: 40;
  }

  /* requests */
  .requests_items {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }

  .requests_item-inner {
    max-width: calc(640rem / var(--font-size__base, 16));
  }
}

@media (max-width: 640px) {
  /* 歯ぎしり・食いしばり */
  .symptoms-comparison::before {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: calc(56rem / var(--font-size__base, 16));
    height: 100%;
    background-image: url(library/images/services_dental-progression-arrow-down.webp);
    background-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
  }
  .symptoms-comparison {
    padding-inline: 0;
  }
  .symptoms-comparison_inner {
    padding-inline: 0;
    padding-bottom: calc(64rem / var(--font-size__base, 16));
  }
  .symptoms-comparison_grid {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }
  /* step */
  .step_item {
    grid-template-columns: 1fr;
    row-gap: calc(24rem / var(--font-size__base, 16));
  }

  .new-patient_second-visit .step_item:nth-child(2) {
    margin-top: 0;
  }

  /* feature */
  .feature_grid {
    display: block;
    margin-top: calc(48rem / var(--font-size__base, 16));
  }
  .feature_card {
    border-right: 0;
    border-bottom: 0;
    padding-block: calc(28rem / var(--font-size__base, 16));
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .feature_card:not(:first-child) {
    border-top: 1px solid #dbd7cc;
  }

  /* care */
  .care_items {
    grid-template-columns: 1fr;
    padding-inline: calc(
      var(--space-inline__base) * 1rem / var(--font-size__base, 16)
    );
  }
  .care_item:not(:first-child) {
    border-left: 0;
    border-top: 1px solid #dbd7cc;
  }

  /* third-visit-cards */
  .third-visit-cards_items {
    grid-template-columns: 1fr;
  }

  /* sub-fv */
  .sub-fv_image::after {
    --_scale-down: 0.4;
  }

  /* wishes */
  .wishes_image::after {
    --_scale-down: 0.4;
  }

  /* requests */
  .requests_item-inner {
    max-width: calc(400rem / var(--font-size__base, 16));
  }
	.footer_copyright-text {
		font-size: 12px;
	}
}
