@charset "utf-8";
* {
    margin: 0;
    padding: 0;
}

body {
font-family: "メイリオ","ヒラギノ角ゴ ProN",sans-serif;
line-height: 1.7;
}


/* Start of Selection */
@media screen and (min-width: 640px) { /* 画面の幅が640px以上の場合に適用されるスタイル */
    .br-sp { /* .br-spクラスに対するスタイル */
    display: none; /* このクラスの要素を非表示にする */
    }
}

/* Start of Selection */
*, *:before, *:after { /* すべての要素とその疑似要素に対するスタイル */
    -webkit-box-sizing: border-box; /* 要素のボックスサイズをborder-boxに設定（Webkitブラウザ用） */
    -moz-box-sizing: border-box; /* 要素のボックスサイズをborder-boxに設定（Mozillaブラウザ用） */
    -o-box-sizing: border-box; /* 要素のボックスサイズをborder-boxに設定（Operaブラウザ用） */
    -ms-box-sizing: border-box; /* 要素のボックスサイズをborder-boxに設定（Microsoftブラウザ用） */
    box-sizing: border-box; /* 要素のボックスサイズをborder-boxに設定 */
}
/* リンク設定
------------------------------------------------------------*/
a { /* aタグ（リンク）に対するスタイル */
    margin: 0; /* マージンを0に設定 */
    padding: 0; /* パディングを0に設定 */
    text-decoration: none; /* テキストの装飾をなしに設定 */
    outline: 0; /* アウトラインをなしに設定 */
    vertical-align: baseline; /* 垂直方向の位置を基線に設定 */
    background: transparent; /* 背景を透明に設定 */
    font-size: 100%; /* フォントサイズを100%に設定 */
    color: #000; /* テキストの色を黒に設定 */
}
a:hover { /* aタグがホバー状態のときのスタイル */
    opacity: 0.7; /* 透明度を0.7に設定 */
}
/**** Clearfix ****/
nav .panel:after, #mainNav:after, .newsTitle:after, .bg:after, .post:after { /* 特定の要素の後に表示される疑似要素に対するスタイル */
    content: ""; /* 疑似要素の内容を空に設定 */
    display: table; /* 疑似要素をテーブルとして表示 */
    clear: both; /* フロートを解除 */
}
nav .panel, #mainNav, .newsTitle, .bg, .post { /* 特定の要素に対するスタイル */
    zoom: 1; /* ズームを1に設定（IE用のclearfixハック） */
}
/* フォーム
------------------------------------------------------------*/
input[type="text"], input[type="email"], textarea { /* テキスト入力、メール入力、テキストエリアに対するスタイル */
    vertical-align: middle; /* 垂直方向の位置を中央に設定 */
    max-width: 90%; /* 最大幅を90%に設定 */
    line-height: 30px; /* 行の高さを30pxに設定 */
    height: 30px; /* 高さを30pxに設定 */
    padding: 1px 5px; /* パディングを上下1px、左右5pxに設定 */
    border: 1px solid #d4d4d7; /* 枠線を#d4d4d7の1pxの実線に設定 */
    border-radius: 3px; /* 角を3px丸める */
    -webkit-border-radius: 3px; /* 角を3px丸める（Webkitブラウザ用） */
    -moz-border-radius: 3px; /* 角を3px丸める（Mozillaブラウザ用） */
    font-size: 100%; /* フォントサイズを100%に設定 */
    color: #555; /* テキストの色を#555に設定 */
    background: #fcfcfc; /* 背景色を#fcfcfcに設定 */
}
textarea { /* テキストエリアに対する追加スタイル */
    height: auto; /* 高さを自動に設定 */
    line-height: 1.5; /* 行の高さを1.5に設定 */
}
input[type="submit"], input[type="reset"], input[type="button"] { /* 送信ボタン、リセットボタン、通常ボタンに対するスタイル */
    padding: 3px 10px; /* パディングを上下3px、左右10pxに設定 */
    background: #2A2A2A; /* 背景色を#2A2A2Aに設定 */
    border: 0; /* 枠線をなしに設定 */
    border-radius: 3px; /* 角を3px丸める */
    -webkit-border-radius: 3px; /* 角を3px丸める（Webkitブラウザ用） */
    -moz-border-radius: 3px; /* 角を3px丸める（Mozillaブラウザ用） */
    line-height: 1.5; /* 行の高さを1.5に設定 */
    font-size: 100%; /* フォントサイズを100%に設定 */
    font-weight: bold; /* フォントの太さを太字に設定 */
    color: #fff; /* テキストの色を白に設定 */
}
input[type="submit"]:hover, input[type="reset"]:hover, input[type="button"]:hover { /* 送信ボタン、リセットボタン、通常ボタンがホバー状態のときのスタイル */
    cursor: pointer; /* カーソルをポインターに変更 */
    background: #74c24b; /* 背景色を#74c24bに変更 */
}
*:first-child + html input[type="submit"] { /* 特定の条件を満たす送信ボタンに対するスタイル */
    padding: 3px; /* パディングを3pxに設定 */
}
/* レイアウト
------------------------------------------------------------*/

.menu { /* .menuクラスに対するスタイル */
    text-align: center; /* テキストを中央揃えに設定 */
}
.menu img { /* .menuクラス内のimgタグに対するスタイル */
    width: 70%; /* 幅を70%に設定 */
}
.menu2 { /* .menu2クラスに対するスタイル */
    text-align: center; /* テキストを中央揃えに設定 */
    width: 100%; /* 幅を100%に設定 */
}
.menu2 img { /* .menu2クラス内のimgタグに対するスタイル */
    width: 49.5%; /* 幅を49.5%に設定 */
    margin: 10px 0 0 0; /* マージンを上10px、右0、下0、左0に設定 */
}
#footer { /* #footer IDに対するスタイル */
    clear: both; /* フロートを解除 */
}
/*---------------レスポンシブ対応-------------------*/
@media only screen and (max-width : 1024px) { /* 画面の幅が1024px以下の場合に適用されるスタイル */
    .inner { /* .innerクラスに対するスタイル */
    padding: 0 5px; /* パディングを上下0、左右5pxに設定 */
    font-size: 95%; /* フォントサイズを95%に設定 */
    }
}
@media only screen and (max-width : 414px) { /* 画面の幅が414px以下の場合に適用されるスタイル */
    .inner { /* .innerクラスに対するスタイル */
    margin: 0 auto; /* マージンを上下0、左右自動に設定（中央揃え） */
    width: 96%; /* 幅を96%に設定 */
    }
}

/* End of Selection */
a {
    margin: 0;
    padding: 0;
    text-decoration: none;
    outline: 0;
    vertical-align: baseline;
    background: transparent;
    font-size: 100%;
    color: #000; /* テキストの色を黒に設定 */
}
a:hover, a:active { /* aタグがホバーまたはアクティブ状態のときのスタイル */
    -webkit-transition: opacity 0.7s; /* 透明度の変化を0.7秒でアニメーション（Webkitブラウザ用） */
    -moz-transition: opacity 0.7s; /* 透明度の変化を0.7秒でアニメーション（Mozillaブラウザ用） */
    -o-transition: opacity 0.7s; /* 透明度の変化を0.7秒でアニメーション（Operaブラウザ用） */
    outline: none; /* アウトラインをなしに設定 */
    color: #999; /* テキストの色を変更 */
}
a:hover {
    opacity: 0.7;
}


/* レイアウト
------------------------------------------------------------*/
#footer {
    clear: both;
}
/*---------------レスポンシブ対応-------------------*/
@media only screen and (max-width : 1024px) {
    .inner {
    padding: 0 5px;
    font-size: 95%;
    }
}
@media only screen and (max-width : 414px) {
    .inner {
    margin: 0 auto;
    width: 96%;
    }
    #content3 .ma, .content3 .ma {
    margin: 2em 0 0;
    }
}

#dropmenu {
    list-style-type: none;
    padding: 0;
}
#dropmenu ul {
    text-align: center;
    width: 100%;
}
#dropmenu li {
    display: inline-block;
    position: relative;
}
#dropmenu li a {
    margin: 0;
    color: #7E7E7f;
    font-size: 14px;
}
#dropmenu li:hover > a {
    opacity: 0.7;
}
#dropmenu > li:hover > a {
    border-radius: 3px 3px 0 0;
}
#dropmenu li ul {
    list-style: none;
    position: absolute;
    top: 160%;
    left: 0;
    margin: 0;
    padding: 0;
    border-radius: 0 0 3px 3px;
}
#dropmenu li:last-child ul {
    width: 100%
}
#dropmenu li ul li {
    overflow: hidden;
    width: 200px;
    height: 0;
    margin-top: -10px;
    color: #fff;
}
#dropmenu li ul li a {
    padding: 10px 5px;
    text-align: left;
    font-size: 14px;
    font-weight: normal;
}
#dropmenu li:hover ul li {
    overflow: visible;
    height: 40px;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
}
#dropmenu li:hover ul li:first-child {
    border-top: 0;
}
#dropmenu li:hover ul li:last-child {
    border-bottom: 0;
}
#dropmenu li:hover ul li:last-child a {
    border-radius: 0 0 3px 3px;
}


@media only screen and (max-width:400px) {
    #dropmenu li a {
    float: none;
    margin: 0;
    color: #7E7E7f;
    padding: 0 0 0 20px;
    font-size: 18px;
    }
    #block-menu-back {
    max-width: 100%;
    background-color: #E6E6E6;
    position: relative;
    }

}
@media only screen and (max-width:320px) {
    #dropmenu ul {
    margin: 0 0 0 0;
    }
    #dropmenu li {
    width: 90%;
    position: relative;
    display: inline-block;
    margin: 0;
    padding: 20px 30px 0 0;
    text-align: left;
    }
    #dropmenu li a {
    float: none;
    margin: 0;
    color: #7E7E7f;
    padding: 0 30px 0 0;
    font-size: 14px;
    }
    #dropmenu li ul {
    list-style: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin: 0;
    padding: 0 0 0 20px;
    }
    #dropmenu li ul li {
    overflow: hidden;
    width: 160px;
    height: 0;
    margin-top: -10px;
    color: #fff;
    }
    .f-img {
    clear: both;
    width: 100%;
    float: none;
    }
    #dropmenu li {
    width: 90%;
    text-align: center;
    }
    #dropmenu li a {
    float: none;
    margin: 0;
    color: #7E7E7f;
    padding: 0 0 0 20px;
    font-size: 18px;
    }
    #block-menu-back {
    max-width: 100%;
    background-color: #E6E6E6;
    position: relative;
    }

}
/*---------------レスポンシブ対応-------------------*/
@media only screen and (max-width : 1024px) {
    .inner{
    width: 100%;
    }
}
.link img {
    width: 100%;
}
.link {
    width: 54% !important;
    margin: 0 auto 20px !important;
    border: 1px solid #CCCCCC;
}
@media only screen and (max-width : 414px) {
    /*デンタルローンページ終了*/
    .link {
    width: 100% !important;
    }
}
.img img {
    max-width: 100%;
}
.img {
    width: 58%;
    margin: 0 auto;
    padding: 30px 0 10px;
}

/*---------------レスポンシブ対応-------------------*/

@media only screen and (max-width : 414px) {
    .img {
    width: 100%;
    margin: 0 auto;
    padding: 30px 0 30px;
    }
}
/*/*----------------------------------------------------
    PCサイトcss
----------------------------------------------------*/
@media screen and (min-width: 600px) {
    /*/////////////PC用のCSSをここに作成してください。/////////////*/
    /*/////////////必ず中括弧の中に作成してください。/////////////*/
    .inner {
    clear: both;
    margin: 0 auto;
    width: 1200px;
    max-width: 100%;
    }
}
/* 2022/05 追従フッター改修 追加CSS ←2023/02編集 */

@media screen and (max-width: 1279px) {
    .show-pc {
    display: none;
    }
    .show-sp {
    display: block;
    }
}
/* 2023年2月 追従フッター改修と渋谷新宿削除 追加CSS */
#footer {
    margin: 50px auto 0;
}
#footer #dropmenu ul {
    list-style: none;
}
#footer #dropmenu li {
    list-style: none;
    margin: 0 15px 15px;
    padding: 0;
}
#footer #dropmenu li a {
    padding: 0 10px;
}
.sp-fixed-footer {
    box-sizing: border-box;
    width: 100%;
}
.sp-fixed-footer ul {
    box-sizing: border-box;
    display: flex;
    justify-content: space-between;
    list-style: none;
    margin: 0;
    width: 100%;
}
.sp-fixed-footer ul li {
    box-sizing: border-box;
    font-size: 16px;
    list-style: none;
    margin: 0;
    padding: 11px 0;
    text-align: center;
    width: 60%;
    border-radius: 10px;
    background: #F5769C; 
    font-weight: 600;
}
.sp-fixed-footer ul li a img {
    filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.70));
}
.sp-fixed-footer ul li a{
    color: #FFF ;
    align-items: center;
    justify-content: center;
    display: flex;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.70);
    font-weight: 550;
}
.sp-fixed-footer ul li:last-child {
    width: 40%;
    border-radius: 10px;
    background: #4CBED9;
}
.sp-fixed-footer ul li .fixedfooter-icon {
    padding-right: 6px;
    align-items: center;
    justify-content: center;
    display: flex;
}




.sp-fixed-footer2 {
    box-sizing: border-box;
    width: 55%;
    position: fixed; /* 画面に固定 */
    right: 0; /* 右側に配置 */
    bottom: 0; /* 下部に配置 */
}
.sp-fixed-footer2 ul {
    box-sizing: border-box;
    display: flex;
    justify-content: space-between;
    list-style: none;
    margin: 0;
    width: 100%;
}
.sp-fixed-footer2 ul li {
    box-sizing: border-box;
    font-size: 16px;
    list-style: none;
    margin: 0;
    padding: 8px 0;
    text-align: center;
    width: 60%;
    border-radius: 10px;
    font-weight: 600;
}
.sp-fixed-footer2 ul li a img {
    filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.40));
}
.sp-fixed-footer2 ul li a{
    color: #FFF ;
    align-items: center;
    justify-content: center;
    display: flex;
    text-shadow: 0px 2px 2px rgba(0, 0, 0, 0.40);
}
.sp-fixed-footer2 ul li:last-child {
    width: 100%;
    border-radius: 8px;
    background: #ff4e83;
    border: 1px solid rgba(255, 255, 255, 0.8); /* 白色の枠線を透明度50%に設定 */
}
.sp-fixed-footer2 ul li .fixedfooter-icon {
    padding-right: 6px;
    align-items: center;
    justify-content: center;
    display: flex;
}



#mainNav li.show-sp {
    display: none;
}

@media screen and (max-width: 1024px) {
    #mainNav li.show-sp {
    display: block;
    }
}
@media screen and (max-width: 768px) {
    #footer #dropmenu li {
    margin: 0 10px 15px;
    }
    #footer #dropmenu li a {
    padding: 0;
    }
}
@media screen and (max-width: 599px) {
    .show-pc {
        display: none;
    }
    .show-pc600 {
    display: none;
    }
    .show-sp599 {
    display: block;
    }
    #footer {
    margin-top: 60px;
    }
    #footer #dropmenu {
    height: auto;
    }
    #footer #dropmenu li {
    width: 90%;
    }
    #footer #dropmenu li a {
    color: #7E7E7F;
    font-size: 18px;
    }
    .f-img {
    padding-bottom: 65px;
    }
    #dropmenu li.show-pc600 {
    display: none;
    }
}
@media (max-width: 500px) {
    h1.clinic-name {
    font-size: 10px;
    }
}
.f-img {
    width: 100%;
    float: left;
    text-align: center;
  }

  .f-img img {
    text-align: center;
    width: 80%;
    padding: 0;
  }
  
  @media screen and (min-width: 550px) {
    .f-img img {
      width: 60%;
    }
  }
@media only screen and (max-width:400px) {
    .f-img {
        clear: both;
        width: 100%;
        float: none;
        text-align: center;
        margin: 0;
      }
}
@media only screen and (max-width:320px) {
    .f-img {
        clear: both;
        width: 100%;
        float: none;
      }
}
@media screen and (max-width: 599px) {
.f-img {
    padding-bottom: 65px;
  }
  
.sp-fixed-footer {
    box-sizing: border-box;
    width: 100%;
}
}

.fixed {
    display: block; /* display: none; を block に変更 */
    position: fixed;
    z-index: 100;
    left: 0;
    right: 0;
    bottom: 0;
}

.fixed2 {
    display: block; /* display: none; を block に変更 */
    position: fixed;
    z-index: 9999;
    right: 0;
    bottom: 0;
}
/* PCサイズで非表示 */
@media screen and (min-width: 601px) {
    .sp-fixed-footer {
        display: none; /* PCサイズで非表示 */
    }
    .fixed2 {
        display: none; /* PCサイズで非表示 */
    }
}

/* ↓20240615ここからshika↓ */
.hero-image img {
    width: 100%; /* 画像の横幅を親要素の幅に合わせる */
    height: auto; /* 縦のサイズを自動調整してアスペクト比を保持 */
    display: block; /* ブロックレベル要素として表示 */
    margin: 0 auto; /* 横方向のマージンを自動で設定して中央揃え */
    object-fit: cover;
    max-width: 1300px;
}
/* Hero Section */
.hero-intro { position: relative; padding: 60px 0 25px; background: white; }
.hero-intro-bg { position: absolute; inset: 0; z-index: 0; }
.hero-intro-bg img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.75);}
.hero-intro-bg::after { content: ''; position: absolute; inset: 0; background: rgba(0, 0, 0, 0.1); z-index: 1; }
.hero-intro-content { position: relative; z-index: 10; }
.hero-intro-catchphrase { font-weight: 600; line-height: 1.5; text-shadow: 3px 3px 6px rgba(0, 0, 0, 0.6), 0 0 20px rgba(255, 255, 255, 0.5); color: white; }
.hero-intro-description { text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8), -1px -1px 4px rgba(0, 0, 0, 0.3),0 0 15px rgba(255, 255, 255, 0.4); color: white; }

/* Hero Intro 100 - 画面の横幅100%に収まるように画像を配置 */
.hero-intro-100 { 
    position: relative; 
    padding: 0; 
    background: white; 
    width: 100%; 
    overflow: hidden; 
}
.hero-intro-100 img { 
    width: 100%; 
    height: auto; 
    display: block; 
    object-fit: cover; 
}

/* ↑Hero Section */

/* Hero Section */
.hero-intro-2 { position: relative; padding: 45px 0 25px 0; background: white; }
.hero-intro-bg-2 { 
    position: absolute; 
    inset: 0; 
    z-index: 0; 
    max-width: 1200px; 
    margin: 0 auto; 
    overflow: hidden;
  }
  
  .hero-intro-bg-2 img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    filter: brightness(0.75);
  }
  
  .hero-intro-bg-2::after { 
    content: ''; 
    position: absolute; 
    inset: 0; 
    z-index: 1; 
  }
.hero-intro-content-2 { position: relative; z-index: 10; }
.hero-intro-catchphrase-2 { 
  font-weight: 600; 
  line-height: 1.5; 
  text-shadow: 3px 3px 6px rgba(0, 0, 0, 0.8), 0 0 20px rgba(255, 255, 255, 0.5); 
  color: white; 
  margin-top: 110px;
  padding-top: 0px;
}
.hero-intro-description-2 { text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9), 0 0 15px rgba(255, 255, 255, 0.9); color: white; }




/* 院内紹介ページ用レスポンシブデザイン */
@media (min-width: 768px) {
    .container-1200 { padding: 0 30px; }
    .hero-intro { padding: 80px 0; }
    .hero-intro-buttons { flex-direction: row; justify-content: center; gap: 15px; }
    .hero-intro-buttons .margin-top-10 { margin-top: 0 !important; }
    .reasons-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; }
    .reason-card { margin-top: 0 !important; }
    .section-title-divider { width: 50px; height: 1px; background-color: #4a8d9e; margin: 10px auto 0;}
    .section-title-divider-200 { width: 200px; height: 1.5px; background-color: #4a8d9e; margin: 15px auto 0;}
}

@media (min-width: 768px) {
    .container-1200 { padding: 0 30px; }
    .hero-intro-2 { padding: 110px 0 30px 0; }
    .hero-intro-buttons-2 { flex-direction: row; justify-content: center; gap: 15px; }
    .hero-intro-buttons-2 .margin-top-10 { margin-top: 0 !important; }
    .reasons-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; }
    .reason-card-2 { margin-top: 0 !important; }
    .section-title-divider-2 { width: 50px; height: 1px; background-color: #4a8d9e; margin: 10px auto 0;}
    .hero-intro-catchphrase-2 { margin-top: 120px;}
      .hero-intro-bg-2 img { 
        mask: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%),
              linear-gradient(to bottom, black 0%, black 86%, transparent 100%);
        -webkit-mask: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%),
                      linear-gradient(to bottom, black 0%, black 86%, transparent 100%);
      }
      .hero-intro-bg-2::after { 
        background: linear-gradient(to right, white 0%, transparent 4%, transparent 96%, white 100%),
                    linear-gradient(to bottom, transparent 2%, transparent 98%, white 100%);
      }
}

@media (min-width: 1024px) {
    .reasons-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
    .reasons-grid-2 { grid-template-columns: repeat(3, 1fr); }
}
/* ↑Hero Section 2 */



/*↓topページ6つの理由*/
.reasons-container {
    display: flex; /* フレックスボックスを使用 */
    flex-wrap: wrap; /* 子要素を折り返す */
    gap: 5px; /* 要素間の隙間を15pxに設定 */
    justify-content: center; /* 子要素を中央揃え */
    max-width: 1600px; 
    margin: 0 auto; /* 中央揃え */
}

.reasons-item {
    background-color: white; /* 背景色を白に設定 */
    border: 1px solid #ddd; /* 枠線を設定 */
    width: calc(100% - 30px); /* 両サイドの15pxのパディングを考慮 */
    max-width: 400px; /* 最大幅を300pxに設定 */
    text-align: center; /* テキストを中央揃え */
    flex: 1 1 calc(50% - 30px); /* レスポンシブ対応 */
    box-shadow: 1px 2px 2px rgba(87, 87, 87, 0.25);
    margin: 8px 15px 30px 15px ; 
    color: #0b0b0b; /* 文字の色を黒に設定 */
}

@media (min-width: 769px) {
    .reasons-item {
        width: calc(50% - 10px); /* 2列に分けるための幅を設定 */
        margin: 15px 15px 30px 15px ; 
        
    }
}

.reasons-title {
    color: #907030;
    text-align: center;
    font-weight: bold; 
    font-size: 16px;
    ;
}

.reasons-title-14 {
    color: #907030;
    text-align: center;
    font-weight: bold; 
    font-size: 14px;
    ;
}
@media screen and (min-width: 601px) and (max-width: 1000px) {
    .reasons-title {
        font-size: 20px;
    }
    .reasons-title-14 {
        font-size: 18px;
    }
}
@media screen and (min-width: 1001px) {
    .reasons-title {
        font-size: 24px;
        }
    .reasons-title-14 {
        font-size: 20px;
    }
}

.reasons-item {
    text-align: center;
    background-color: #FFFFFF;
    border: 1px solid #ddd;
}
.large-number {
    font-size: 1.3em; /* ここで希望のサイズに調整してください */
    font-weight: bold; 
}
.reasons-item-image {
    width: 100%;
    height: auto;
    display: block; /* 画像の下の余白を消す */
}


.reasons-item-title{
    color: #00A7CE;
}

.reasons-item-description {
    padding: 3px 5px 15px;
}

/*↑6つの理由ここまで*/

/* ↓Reasons　医院紹介ページ */
.reason-card { 
    background: white; 
    border-radius: 8px; 
    overflow: hidden; 
    box-shadow: 0 2px 20px rgba(0,0,0,0.08); 
    display: flex; 
    flex-direction: column; 
    height: 100%; 
}

.reason-card a {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
}
.reason-image { width: 100%; height: auto; overflow: hidden; }
.reason-image img { width: 100%; height: 100%; object-fit: cover; }
.reason-content { 
    padding: 10px 10px 10px; 
    display: flex; 
    flex-direction: column; 
    flex: 1; 
    height: 100%;
}
.reason-header { display: flex; align-items: center; }

.reason-description { 
    flex: 1; 
    margin-bottom: 15px; 
    min-height: 0;
    line-height: 1.8;
}
.reason-card .btn { 
    margin-top: auto; 
    align-self: flex-end; 
    width: 100%; 
    flex-shrink: 0;
}

@media (min-width: 768px) {
    .reason-content{
      display:flex;
      flex-direction:column;
      height:100%;
    }
  
    .button-wrapper{
      margin-top:auto; /* ←これでボタンが下に揃う */
    }
  }
  
/* ↑Reasons　医院紹介ページ */



/* ↓治療例*/
.case-item {
    border: 1px solid #ddd;
    margin: 2px 0px 10px 0px;
    background-color: #f9f9f9;
  }
  
  .case-item h3 {
    margin: 8px;
  }
  
  .case-item .case-images {
    display: block; /* 縦一列に並べるために block に変更 */
  }
  
  .case-item .case-images img {
    width: 100%; /* 横幅いっぱいにする */
  }
  
  .case-item p {
    margin: 5px;
  }
  

/* ↑治療例*/

/*↓院長あいさつ*/
.message-content {
    margin: 4px 15px;
    border: 1px solid #ddd;
}
.message-content p {
    padding: 6px 12px 0px 12px;
}
/*↑院長あいさつ*/

/*↓お知らせ*/
.infomation-container  h2{
    text-align: center;
    margin-top: 70px;
}
.info-item {
    margin: 12px 0 ;
}
/*↑お知らせ*/

/*↓access,map*/
.text-center {
    text-align: center;
}

.text-center-pink {
    text-align: center;
    position: relative;
  }

.text-center-pink::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 2px;
  background-color: rgb(206, 167, 178);
}

.text-center-mintblue {
    text-align: center;
    position: relative;
  }

.text-center-mintblue::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 2px;
  background-color: rgb(132, 194, 192);
}
    
.tel a {
    color: inherit; /* 親要素の色を継承する */
    color: #005dc0
}

.simple-title {
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #222222;
}

.simple-title-005 {
  font-weight: 600;
  letter-spacing: 0.05em;
  color: #222222;
}

.access-contactcontainer {
    width: 100%;
    margin: 0 auto;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    background: #fff;
  }
.map iframe {
    width: 100%;
    height: 250px;
}
.phone-link {
    color: #686868;
}
.consultation-hours {
    margin-left: auto; /* 左のマージンを自動に設定 */
    margin-right: auto; /* 右のマージンを自動に設定 */
  }
  
  .consultationday {
      width: 95%;
      text-align: center;
      margin: 10px auto; 
      border-collapse: collapse;
      }
  
  .consultationday, .consultationday th, .consultationday td {
    font-weight: 300; /* テーブル内のテキストを細字に設定 */
  }
  
  .consultationday,
  .consultationday th,
  .consultationday td {
      border: 1px solid black;
  }
  
  .consultationday {
      width: 100%; /* テーブルの幅を100%に設定 */
      border-collapse: collapse; /* ボーダーの重なりを解消 */
  }
  
  .consultationday th,
  .consultationday td {
      text-align: center; /* テキストを中央揃えにする */
      padding: 8px; /* セルの内側にパディングを追加 */
  }
  
  .consultationday td.closed-day {
      background-color: #efefef; /* 薄いグレーの背景色 */
  }
  
      
  
  .copyright {
    background-color: black;
    color: white;
    text-align: center;
    padding: 8px;
    font-size: 8px;
}
  
  /*↓access,map*/
  .map iframe {
    width: 100%;
    height: 250px;
    display: block;
    margin: 0 auto;
  }
  /*↑map*/
/*↑map*/

/*↓フッター*/
@media (max-width: 600px) {
    body::after {
        content: "";
        display: block;
        height: calc(46px + env(safe-area-inset-bottom));
        background: #000;
    }
}
/*↑フッター*/

/* ↓Access 医院紹介ページ*/
.access-card { background: white; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 20px rgba(0,0,0,0.08); }
.map-container { position: relative; width: 100%; height: 250px; background: #f5f5f5; }
.map-iframe { width: 100%; height: 100%; border: none; }
.access-info { padding: 25px; }
.address-line { line-height: 1.6; }
.postal-code { font-weight: 500; }
.station-info { font-weight: 500; }
.contact-section { border-top: 1px solid #f0f0f0; }
.phone-label { color: #777; }
.phone-number { font-weight: 600; text-decoration: none; }
/* ↑Access 医院紹介ページ*/



/*↓分院のご案内*/

/*↑分院のご案内*/

/*cure*/
/* 画像とテキストを含むコンテナのスタイル */
.cure-main-image-container {
    position: relative; /* テキストを画像の上に重ねるために必要 */
    text-align: center; /* テキストを中央揃えにする */
    color: white; /* テキストの色を白にする */
    max-width: 1100px;
    margin: 0 auto; /* 中央揃え */
}

.cure-main-image-container img {
    width: 100%; /* 画像の幅をコンテナに合わせる */
    height: auto; /* 画像の高さを自動調整する */
    display: block; /* 画像をブロック要素として表示 */
}

.cure-main-image-container::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4); /* 透明度50%の黒色 */
    pointer-events: none; /* 背景の上にある要素の操作を妨げない */
    z-index: 1; /* オーバーレイの重なり順序を設定 */
}

.cure-main-image-container h2 {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 600;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
}

.cure-main-image-container2 {
    position: relative; /* テキストを画像の上に重ねるために必要 */
    text-align: center; /* テキストを中央揃えにする */
    color: white; /* テキストの色を白にする */
    max-width: 1100px;
    margin: 0 auto; /* 中央揃え */
}

.cure-main-image-container2 img {
    width: 100%; /* 画像の幅をコンテナに合わせる */
    height: auto; /* 画像の高さを自動調整する */
    display: block; /* 画像をブロック要素として表示 */
}

.cure-main-image-container2::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3); /* 透明度50%の黒色 */
    pointer-events: none; /* 背景の上にある要素の操作を妨げない */
    z-index: 1; /* オーバーレイの重なり順序を設定 */
}

.cure-main-image-container2 h2 {
        position: absolute; /* テキストを絶対位置にする */
        top: 50%; /* コンテナの縦中央に配置 */
        left: 50%; /* コンテナの横中央に配置 */
        transform: translate(-50%, -50%); /* テキストを中央に揃える */
        padding: 10px; /* テキスト周りの余白を設定 */
        width: 100%; /* テキストの横幅を100%に設定 */
        text-align: center; /* テキストを中央揃えにする */
        font-weight: 600;
        z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
    }
.cure-main-image-container2 h3 {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

.cure-main-image-container2 p {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

@media (min-width: 1000px) {
    .cure-main-image-container2 h2 {
        font-size: 1.7em; /* フォントサイズを通常の1.2倍に設定 */
    }
    .cure-main-image-container2 h3 {
        font-size: 1.7em; /* フォントサイズを通常の1.2倍に設定 */
    }
    .cure-main-image-container2 p {
        font-size: 1.7em; /* フォントサイズを通常の1.2倍に設定 */
    }
}


.cure-main-image-container-3 {
    position: relative; /* テキストを画像の上に重ねるために必要 */
    text-align: center; /* テキストを中央揃えにする */
    color: white; /* テキストの色を白にする */
    max-width: 1100px;
    margin: 0 auto; /* 中央揃え */
}

.cure-main-image-container-3 img {
    width: 100%; /* 画像の幅をコンテナに合わせる */
    height: auto; /* 画像の高さを自動調整する */
    display: block; /* 画像をブロック要素として表示 */
}

.cure-main-image-container-3::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* 透明度50%の黒色 */
    pointer-events: none; /* 背景の上にある要素の操作を妨げない */
    z-index: 1; /* オーバーレイの重なり順序を設定 */
}

.cure-main-image-container-3 h2 {
        position: absolute; /* テキストを絶対位置にする */
        top: 50%; /* コンテナの縦中央に配置 */
        left: 50%; /* コンテナの横中央に配置 */
        transform: translate(-50%, -50%); /* テキストを中央に揃える */
        padding: 10px; /* テキスト周りの余白を設定 */
        width: 100%; /* テキストの横幅を100%に設定 */
        text-align: center; /* テキストを中央揃えにする */
        font-weight: 600;
        z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
    }
.cure-main-image-container-3 h3 {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

.cure-main-image-container-3 p {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}



@media (min-width: 1000px) {
    .cure-main-image-container-3 h2 {
        font-size: 1.7em; /* フォントサイズを通常の1.2倍に設定 */
    }

}

.cure-main-image-container-4 {
    position: relative; /* テキストを画像の上に重ねるために必要 */
    text-align: center; /* テキストを中央揃えにする */
    color: white; /* テキストの色を白にする */
    max-width: 1100px;
    margin: 0 auto; /* 中央揃え */
}

.cure-main-image-container-4 img {
    width: 100%; /* 画像の幅をコンテナに合わせる */
    height: auto; /* 画像の高さを自動調整する */
    display: block; /* 画像をブロック要素として表示 */
}

.cure-main-image-container-4::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* 透明度50%の黒色 */
    pointer-events: none; /* 背景の上にある要素の操作を妨げない */
    z-index: 1; /* オーバーレイの重なり順序を設定 */
}

.cure-main-image-container-4 h2 {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 600;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

.cure-main-image-container-4 h3 {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

.cure-main-image-container-4 p {
    position: absolute; /* テキストを絶対位置にする */
    top: 50%; /* コンテナの縦中央に配置 */
    left: 50%; /* コンテナの横中央に配置 */
    transform: translate(-50%, -50%); /* テキストを中央に揃える */
    padding: 10px; /* テキスト周りの余白を設定 */
    width: 100%; /* テキストの横幅を100%に設定 */
    text-align: center; /* テキストを中央揃えにする */
    font-weight: 550;
    z-index: 2; /* テキストの重なり順序をオーバーレイより前に設定 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* 文字にシャドーを追加 */
}

@media (min-width: 768px) {
    .cure-main-image-container-4 img {
        mask: linear-gradient(to right, transparent 0%, black 2%, black 98%, transparent 100%),
              linear-gradient(to bottom, black 0%, black 90%, transparent 100%);
        -webkit-mask: linear-gradient(to right, transparent 0%, black 2%, black 98%, transparent 100%),
                      linear-gradient(to bottom, black 0%, black 90%, transparent 100%);
    }
    .cure-main-image-container-4::after {
        background-color: rgba(0, 0, 0, 0.6);
        background-image: linear-gradient(to right, white 0%, transparent 1%, transparent 99%, white 100%),
                          linear-gradient(to bottom, transparent 0%, transparent 95%, white 100%);
    }
}

@media (min-width: 1000px) {
    .cure-main-image-container-4 h2 {
        font-size: 1.7em; /* フォントサイズを通常の1.2倍に設定 */
    }
}

.main-image-container {
    position: relative; /* テキストを画像の上に重ねるために必要 */
    text-align: center; /* テキストを中央揃えにする */
    color: white; /* テキストの色を白にする */
}

.main-image-container img {
    width: 100%; /* 画像の幅をコンテナに合わせる */
    height: auto; /* 画像の高さを自動調整する */
    display: block; /* 画像をブロック要素として表示 */
}

.image-box {
    max-width: 100%;
  }
.image-box img {
    width: 100%;
    height: auto;
    display: block;
}

.image-box-70 {
    max-width: 70%;
    margin: 0 auto;
}
.image-box-70 img {
    width: 100%;
    height: auto;
    display: block;
    margin-top: 5px;
}

.image-box-80 {
    max-width: 80%;
    margin: 0 auto;
}
.image-box-80 img {
    width: 100%;
    height: auto;
    display: block;
}

.image-box-90 {
    max-width: 90%;
    margin: 0 auto;
}
.image-box-90 img {
    width: 100%;
    height: auto;
    display: block;
}



.image-box-max600 {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
  }
.image-box-max600 img {
    width: 100%;
    height: auto;
    display: block;
}
/*cure*/
.cure-item {
    border: 1px solid #ddd;
    background-color: #fff;
    box-shadow: 0 3px 3px rgba(117, 117, 117, 0.1);
}

.cure-item img {
    max-width: 100%;
    height: auto;
    display: block;
}

.cure-item h2 {
    margin-top: 8px;
}

.cure-item p {
    padding: 0px 5px 8px 5px;
}
/*↑cureページ*/
/*インビザラインページ*/
.invisalign-images img {
    max-width: 100%;
    height: auto;
  }

  .recommend {
    background:  #efe8e1; 
    padding: 1px 10px 30px 10px;
    margin-top: 1%;
}

  .recommend h3 {
    margin: 10px 0 10px 25px;
    color: #02938f;
    font-weight: 600;
  }
  
  .recommend-list {
    background: #ffffff;
    padding: 10px;
    border-radius: 10px;
    text-align: left;
    list-style: none;
  }
  
  .recommend-list li {
    margin: 8px 0;
    position: relative;
    padding-left: 18px;
    line-height: 1.7;
    align-items: flex-start;
    font-size: 1.05em;
    padding-bottom: 10px;
  }
  
  .recommend-list li::before {
    content: '●';
    color: #0ABAB5;
    position: absolute;
    left: 0;
    top: 0.8em;
    font-size: 0.5em;
    font-weight: 600;
    filter: drop-shadow(0.5px 0.5px 0px rgba(0, 167, 206, 0.8));
    padding-bottom: 10px;
    flex-shrink: 0;
    margin-right: 8px;
  }
  @media (min-width: 768px) {
        .recommend-list {
        padding: 10px 20px;
        }
        .recommend-list li {
            padding-left: 22px;
        }
  }
  

.recommend-list2 {
    background: #ffffff;
    border-radius: 10px;
    text-align: left;
    list-style: none;
    padding: 8px;
}

.recommend-list2 li {
    position: relative;
    line-height: 1.5;
}

.recommend-list2 li::before {
    content: '•';
    color: #0ABAB5;
    left: 0;
    top: 50%; 
    font-size: 1.8em; 
}

.recommend-check {
    background: #ffffff;
    padding: 15px;
    border-radius: 10px;
    text-align: left;
    list-style: none;
}
ul.recommend-check li {
    position: relative;
    padding-left:20px;
    margin-bottom: 18px;
    line-height: 1.6;
}

ul.recommend-check li::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 0;
    width: 11px;
    height: 7px;
    border-left: 3px solid #0ABAB5;
    border-bottom: 2px solid #0ABAB5;
    transform: rotate(-45deg);;
}

@media (min-width: 768px) {
    .recommend-check {
        padding: 15px 20px;
    }
    ul.recommend-check li::before {
        top: 8px;
        width: 13px;
        height: 8px;
        border-left: 3px solid #0ABAB5;
        border-bottom: 2px solid #0ABAB5;
      }
      ul.recommend-check li {
        padding-left: 22px;
      }
}
/*インビザラインページ*/
/* シミュレーション動画 */
.simulation-videos {
    display: flex;
    flex-direction: column;
    width: 100%; /* 親要素の幅を100%に設定 */
}

.simulation-videos iframe {
    width: 100%;
    height: auto; /* 高さを自動に設定 */
    aspect-ratio: 16 / 9; /* アスペクト比を維持 */
    border: none; /* 境界線を削除 */
}
/*ワイヤー矯正*/
.wire-item {
    border: 1px solid #ddd;
    background-color: #fff;
    margin-top: 20px;
    box-shadow: 0 3px 3px rgba(117, 117, 117, 0.1);
}

.wire-item img {
    max-width: 100%;
    height: auto;
    display: block;
}

.wire-item h2 {
    margin-top: 8px;
}

.wire-item p {
    padding: 0px 10px;
}
/*↑ワイヤー矯正*/
/*↓料金表*/
.orthodontics-price-table {
    width: 100%;
    overflow-x: auto;
    border-collapse: collapse;
    margin: 5px 0;
    table-layout: fixed; /* 列幅を固定 */
    font-size: 0.85rem;
}

.orthodontics-price-table table {
    width: 100%;
    border-collapse: collapse;
}

.orthodontics-price-table th, .orthodontics-price-table td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
    height: 50px; /* セルの高さを固定 */
}
.orthodontics-price-table th {
    background-color: rgb(250, 245, 247);
    ;
}

.orthodontics-price-table th:nth-child(1), .orthodontics-price-table td:nth-child(1) {
    width: 60%; /* 1列目の幅を60%に設定 */
}

.orthodontics-price-table th:nth-child(2), .orthodontics-price-table td:nth-child(2) {
    width: 40%; /* 2列目の幅を40%に設定 */
}

.price-table {
    width: 100%;
    overflow-x: auto;
    border-collapse: collapse;
    margin: 5px 0;
    table-layout: fixed; /* 列幅を固定 */
    font-size: 0.85rem;
}

.price-table table {
    width: 100%;
    border-collapse: collapse;
}

.price-table th, .price-table td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
    height: 50px; /* セルの高さを固定 */
    font-weight: 500;
}

.price-table th:nth-child(1), .price-table td:nth-child(1) {
    width: 55%; 
}

.price-table th:nth-child(2), .price-table td:nth-child(2) {
    width: 45%; 
}

.price-table th {
    background-color: #faf5f7;
}

.price-table td {
    text-align: right;
}

.tax-included {
    display: block;
    color: #888;
    font-size: 0.7em;
}

.price-table-2 {
    width: 100%;
    overflow-x: auto;
    border-collapse: collapse;
    margin: 5px 0;
    table-layout: fixed;
}

.price-table-2 table {
    width: 100%;
    border-collapse: collapse;
}

.price-table-2 th,
.price-table-2 td {
    border: 1px solid #ddd;
    padding: 8px;
    height: 50px;
}

.price-table-2 th:nth-child(1),
.price-table-2 td:nth-child(1) {
    width: 40%;
    background-color: #f1fbff; /* 水色 */
    text-align: left;
}

.price-table-2 th:nth-child(2),
.price-table-2 td:nth-child(2) {
    width: 35%;
    background-color: #f8f3eb; /* 淡いオレンジ */
    text-align: right;
}

.price-table-2 th:nth-child(3),
.price-table-2 td:nth-child(3) {
    width: 25%;
    background-color: #ffffff; /* 通常白 */
    text-align: right;
}


.price-table-3 {
    width: 100%;
    overflow-x: auto;
    border-collapse: collapse;
    margin: 5px 0;
    table-layout: fixed; /* 列幅を固定 */
}

.price-table-3 table {
    width: 100%;
    border-collapse: collapse;
}

.price-table-3 th, .price-table-3 td {
    border: 1px solid #ddd;
    padding: 6px 8px;
    text-align: left;
    height: 50px; /* セルの高さを固定 */
    font-size: 0.825rem;
}

.price-table-3 th:nth-child(1), .price-table-3 td:nth-child(1) {
    width: 45%; 
}

.price-table-3 th:nth-child(2), .price-table-3 td:nth-child(2) {
    width: 55%; 
}

.price-table-3 th {
    background-color: #f1fbff;
}

.price-table-3 td {
    text-align: right;
}

@media (min-width: 600px) {
.price-table-3 th, .price-table-3 td {
    font-size: 1rem;
}
}

.price-table-69 table {
    width: 100%;
    border-collapse: collapse;
}

.price-table-69 th, .price-table-69 td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
    height: 50px; /* セルの高さを固定 */
}

.price-table-69 th:nth-child(1), .price-table-69 td:nth-child(1) {
    width: 69%; 
}

.price-table-69 th:nth-child(2), .price-table-69 td:nth-child(2) {
    width: 31%; 
}

.price-table-69 th {
    background-color: #f1fbff;
}

.price-table-69 td {
    text-align: right;
}



.desktop-table {
    display: block;
    margin-bottom: 1.5rem;
}

.pricing-table {
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 0.5rem;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.table-header {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    border-bottom: 1px solid #e5e7eb;
}

.table-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
}

.table-row:not(:last-child) {
    border-bottom: 1px solid #e5e7eb;
}

.header-cell {
    padding: 1rem;
    border-right: 1px solid #e5e7eb;
}

.header-cell:last-child {
    border-right: none;
}


.cell:last-child {
    border-right: none;
}

.center {
    text-align: center;
}

.discount-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    white-space: nowrap;
}

.badge {
    background-color: #e95e52;
    color: white;
    font-size: 0.75rem;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    font-weight: 500;
}

.price-main {
    font-size: 1.125rem;
    font-weight: 600;
    color: #1f2937;
}

.price-tax {
    font-size: 0.875rem;
    color: #6b7280;
}

.discount-info {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.price-crossed {
    font-size: 0.875rem;
    color: #9ca3af;
    text-decoration: line-through;
}

.price-discounted {
    font-size: 1.125rem;
    font-weight: 600;
    color: #f14a41;
}

/* Mobile cards */
.mobile-cards {
    display: none;
    gap: 1rem;
}

.treatment-card {
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 0.2rem;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
    padding: 0.8rem;
}

.treatment-card h3 {
    font-weight: 500;
    color: #1f2937;
    margin-bottom: 0.75rem;
}

.card-content {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

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

.discount-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.price-info {
    text-align: right;
}


/* Note section */


.explanation-header h2 {
    font-size: 1rem;
    font-weight: 500;
    color: #1f2937;
}

.explanation-content {
    border-left: 4px solid #d1d5db;
    padding-left: 1rem;
}

.explanation-content p {
    font-size: 0.875rem;
    color: #374151;
    margin-bottom: 0.75rem;
}

.explanation-content p:last-child {
    margin-bottom: 0;
}

/* Responsive design */
@media (min-width: 768px) {
    .container {
        padding: 2rem;
    }
    
    .content {
        max-width: 80rem;
    }
    
    .header {
        margin-bottom: 2rem;
    }
    
    .header h1 {
        font-size: 1.25rem;
    }
    
    .note {
        font-size: 0.875rem;
        margin-bottom: 2rem;
    }
    
    .diamond-icon {
        width: 1rem;
        height: 1rem;
    }
    
    .explanation-header h2 {
        font-size: 1.125rem;
    }
    
    .explanation-content {
        padding-left: 1.5rem;
    }
    
    .explanation-content p {
        font-size: 1rem;
    }
    
    .explanation {
        margin-top: 2rem;
    }
}

@media (max-width: 767px) {
    .desktop-table {
        display: none;
    }
    
    .mobile-cards {
        display: flex;
        flex-direction: column;
    }
}

@media (min-width: 768px) {
    .mobile-cards {
        display: block;
    }
}

/*↑料金表*/

/*監修*/
.profile-container {
    background-color: #ffffff;
    border-radius: 10px;
    padding: 40px 20px 20px;
    margin: 90px auto 0;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    position: relative;
    border: 1px solid #d1d1d1; /* 細い線を追加 */
}

.profile-container2 {
    background-color: #ffffff;
    border-radius: 10px;
    padding: 10px 20px 0px;
    margin: 90px auto 0;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    position: relative;
    border: 1px solid #d1d1d1; /* 細い線を追加 */
}

.profile-title {
    background-color: #606060;
    color: #ffffff;
    padding: 10px 30px;
    border-radius: 20px;
    display: inline-block;
    font-weight: bold;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
}

.profile-content {
    display: flex;
    align-items: flex-start;
    margin-top: 10px;
}
.profile-image {
    width: 86px;
    height: 86px;
    border-radius: 50%;
    margin-right: 20px;
}
@media (min-width: 768px) {
    .profile-image {
        width: 110px;
        height: 110px;
    }
}
.profile-info {
    flex: 1;
}
.profile-name {
    font-weight: bold;
    color: #1f1f1f;
    margin: 0 0 10px 0;
}
.profile-position {
    margin: 10px 0 8px 0;
    color: #2a2a2a;
}
.profile-description {
    line-height: 1.6;
    margin-bottom: 30px;
    margin-top: 4px;
}
.profile-link {
    display: block;
    background-color: #f0f0f0;
    color: #333333;
    text-decoration: none;
    padding: 10px 20px;
    border-radius: 5px;
    margin-top: 20px;
    text-align: center;
}
/*↑監修*/

/*↓理由ポイント*/
.reason-point-container {
    margin: 0 auto;
}
.reason-point-title {
    font-size: 1.5rem;
    font-weight: bold;
    text-align: center;
    margin-bottom: 2rem;
}
.reason-point-content {
    padding: 10px;
}
.reason-point-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    background-color: #f6f4e5;
    color: #596578;
    border-radius: 0.25rem;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.reason-point-note {
    font-size: 0.7rem;
    color: #878787;
}
/*↑理由ポイント*/

/*↓solid-container*/
.gray-solid-container {
    background-color: #ffffff;
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(141, 141, 141, 0.1);
    position: relative;
    border: 1px solid #d1d1d1; 
}
/*↑solid-container*/

/*title-solid*/
.title-solid-gold::after {
    content: '';
    display: block;
    width: 80px;
    height: 3px;
    background-color: #B99D6D;
    margin: 6px auto 0;
}

.title-thin-solid-gold::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background-color: #B99D6D;
    margin: 5px auto 0;
}

.title-thin-solid-lightblue::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: linear-gradient(to right,  #7ac7d8, #a8c1e6);
    margin: 5px auto 0;
}

.title-thin-solid-pink::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: rgb(197, 129, 148);
    margin: 5px auto 0;
}

.title-thin-solid-mintblue::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #4ab6ab;
    margin: 5px auto 0;
}

.title-underline-lightblue {
    display: block;
    margin: 0 auto;
    width: fit-content;
    color: #333;
    border-bottom: 2px solid #7ac7d8;
}



/*titlesolid*/

/* モバイル版のスタイル（デフォルト） */
.global-container {
    padding-left: 15px;
    padding-right: 15px;
  }

/*↓marginスタイル*/
.margin-reset {
    margin: 0;
}
.margin-top-3 {
    margin-top: 3px;
}
.margin-top-5 {
    margin-top: 5px;
}
.margin-top-8 {
    margin-top: 8px;
}
.margin-top-10 {
    margin-top: 10px;
}
.margin-top-12 {
    margin-top: 12px;
}
.margin-top-15 {
    margin-top: 15px;
}
.margin-top-20 {
    margin-top: 20px;
}
.margin-top-25 {
    margin-top: 25px;
}
.margin-top-30 {
    margin-top: 30px;
}
.margin-top-35 {
    margin-top: 35px;
}
.margin-top-40 {
    margin-top: 40px;
}
.margin-top-50 {
    margin-top: 50px;
}
.margin-top-60 {
    margin-top: 60px;
}
.margin-top-70 {
    margin-top: 70px;
}
.margin-top-80 {
    margin-top: 80px;
}
.margin-top-90 {
    margin-top: 90px;
}
.margin-top-100 {
    margin-top: 100px;
}
.margin-top-110 {
    margin-top: 110px;
}
.margin-top-120 {
    margin-top: 120px;
}
.margin-top-130 {
    margin-top: 130px;
}   
.margin-top-140 {
    margin-top: 140px;
}
.margin-top-150 {
    margin-top: 150px;
}
.margin-top-160 {
    margin-top: 160px;
}
.margin-top-170 {
    margin-top: 170px;
}
.margin-top-180 {
    margin-top: 180px;
}
.margin-top-190 {
    margin-top: 190px;
}
.margin-top-200 {
    margin-top: 200px;
}
.margin-bottom-3 {
    margin-bottom: 3px;
}
.margin-bottom-5 {
    margin-bottom: 5px;
}
.margin-bottom-10 {
    margin-bottom: 10px;
}
.margin-bottom-15 {
    margin-bottom: 15px;
}
.margin-bottom-20 {
    margin-bottom: 20px;
}
.margin-bottom-25 {
    margin-bottom: 25px;
}
.margin-bottom-30 {
    margin-bottom: 30px;
}
.margin-bottom-40 {
    margin-bottom: 40px;
}
.margin-bottom-50 {
    margin-bottom: 50px;
}
.margin-bottom-60 {
    margin-bottom: 60px;
}
.margin-bottom-70 {
    margin-bottom: 70px;
}
.margin-bottom-80 {
    margin-bottom: 80px;
}
.margin-bottom-90 {
    margin-bottom: 90px;
}
.margin-bottom-100 {
    margin-bottom: 100px;
}
.margin-left-right-10 {
    margin-left: 10px;
    margin-right: 10px;
}
.margin-left-right-13 {
    margin-left: 13px;
    margin-right: 13px;
}
.margin-left-right-14 {
    margin-left: 14px;
    margin-right: 14px;
}

.margin-left-right-15 {
    margin-left: 15px;
    margin-right: 15px;
}
.margin-left-right-20 {
    margin-left: 20px;
    margin-right: 20px;
}
.margin-left-right-25 {
    margin-left: 25px;
    margin-right: 25px;
}
.margin-left-right-30 {
    margin-left: 30px;
    margin-right: 30px;
}
.margin-left-right-35 {
    margin-left: 35px;
    margin-right: 35px;
}
.margin-left-right-40 {
    margin-left: 40px;
    margin-right: 40px;
}
.margin-left-5 {
    margin-left: 5px;
}
.margin-left-7 {
    margin-left: 7px;
}
.margin-left-10 {
    margin-left: 10px;
}
.margin-left-15 {
    margin-left: 15px;
}
.margin-left-20 {
    margin-left: 20px;
}
.margin-left-25 {
    margin-left: 25px;
}
.margin-left-30 {
    margin-left: 30px;
}
.margin-left-35 {
    margin-left: 35px;
}
.margin-left-40 {
    margin-left: 40px;
}
.margin-left-45 {
    margin-left: 45px;
}
.margin-left-50 {
    margin-left: 50px;
}
.margin-left-55 {
    margin-left: 55px;
}
.margin-left-60 {
    margin-left: 60px;
}
.margin-left-70 {
    margin-left: 70px;
}
.margin-left-80 {
    margin-left: 80px;
}
.margin-left-90 {
    margin-left: 90px;
}
.margin-left-100 {
    margin-left: 100px;
}
.margin-right-15 {
    margin-right: 15px;
}

@media screen and (max-width: 389px) {
    .margin-left-right-15 {
        margin-left: 10px;
        margin-right: 10px;
    }
    .margin-left-right-20 {
        margin-left: 15px;
        margin-right: 15px;
    }
    .margin-left-right-25 {
        margin-left: 20px;
        margin-right: 20px;
    }
    .margin-left-right-30 {
        margin-left: 25px;
        margin-right: 25px;
    }
    .margin-left-right-35 {
        margin-left: 30px;
        margin-right: 30px;
    }
    .margin-left-right-40 {
        margin-left: 35px;
        margin-right: 35px;
    }
}
/*↑marginスタイル*/
/*↓padiingスタイル*/
.padding-top-5 {
    padding-top: 5px;
}
.padding-top-10 {
    padding-top: 10px;
}
.padding-top-15 {
    padding-top: 15px;
}
.padding-top-20 {
    padding-top: 20px;
}
.padding-top-25 {
    padding-top: 25px;
}
.padding-top-30 {
    padding-top: 30px;
}
.padding-top-35 {
    padding-top: 35px;
}
.padding-top-40 {
    padding-top: 40px;
}
.padding-top-50 {
    padding-top: 50px;
}
.padding-top-60 {
    padding-top: 60px;
}
.padding-top-70 {
    padding-top: 70px;
}
.padding-top-80 {
    padding-top: 80px;
}
.padding-top-90 {
    padding-top: 90px;
}
.padding-top-100 {
    padding-top: 100px;
}
.padding-top-110 {
    padding-top: 110px;
}
.padding-top-120 {
    padding-top: 120px;
}
.padding-top-130 {
    padding-top: 130px;
}
.padding-top-140 {
    padding-top: 140px;
}
.padding-top-150 {
    padding-top: 150px;
}
.padding-bottom-5 {
    padding-bottom: 5px;
}
.padding-bottom-10 {
    padding-bottom: 10px;
}
.padding-bottom-15 {
    padding-bottom: 15px;
}
.padding-bottom-20 {
    padding-bottom: 20px;
}
.padding-bottom-25 {
    padding-bottom: 25px;
}
.padding-bottom-30 {
    padding-bottom: 30px;
}
.padding-bottom-35 {
    padding-bottom: 35px;
}
.padding-bottom-40 {
    padding-bottom: 40px;
}
.padding-bottom-45 {
    padding-bottom: 45px;
}
.padding-bottom-50 {
    padding-bottom: 50px;
}
.padding-bottom-60 {
    padding-bottom: 60px;
}
.padding-bottom-70 {
    padding-bottom: 70px;
}
.padding-bottom-80 {
    padding-bottom: 80px;
}
.padding-bottom-90 {
    padding-bottom: 90px;
}
.padding-bottom-100 {
    padding-bottom: 100px;
}
.padding-bottom-110 {
    padding-bottom: 110px;
}
.padding-bottom-120 {
    padding-bottom: 120px;
}
/*↑paddingスタイル*/
@media screen and (min-width: 768px) and (max-width: 1199px) {
    .margin-left-right-15 {
        margin-left: 20px;
        margin-right: 20px;
    }
    .margin-left-right-20 {
        margin-left: 25px;
        margin-right: 25px;
    }
    .margin-left-right-25 {
        margin-left: 30px;
        margin-right: 30px;
    }
    .margin-left-right-30 {
        margin-left: 35px;
        margin-right: 35px;
    }
    .margin-left-right-35 {
        margin-left: 40px;
        margin-right: 40px;
    }
    .margin-left-right-40 {
        margin-left: 45px;
        margin-right: 45px;
    }
    .margin-top-3 {
        margin-top: 5px;
    }
    .margin-top-5 {
        margin-top: 7px;
    }
    .margin-top-8 {
        margin-top: 10px;
    }
    .margin-top-10 {
        margin-top: 12px;
    }
    .margin-top-12 {
        margin-top: 14px;
    }
    .margin-top-15 {
        margin-top: 18px;
    }
    .margin-top-20 {
        margin-top: 24px;
    }
    .margin-top-25 {
        margin-top: 28px;
    }
    .margin-top-30 {
        margin-top: 36px;
    }
    .margin-top-35 {
        margin-top: 42px;
    }
    .margin-top-40 {
        margin-top: 46px;
    }
    .margin-top-50 {
        margin-top: 60px;
    }
    .margin-top-60 {
        margin-top: 74px;
    }
    .margin-top-70 {
        margin-top: 88px;
    }
    .margin-top-80 {
        margin-top: 102px;
    }
    .margin-top-90 {
        margin-top: 110px;
    }
    .margin-top-100 {
        margin-top: 118px;
    }
    .margin-top-110 {
        margin-top: 126px;
    }
    .margin-top-120 {
        margin-top: 134px;
    }
    .margin-top-130 {
        margin-top: 142px;
    }
    .margin-top-140 {
        margin-top: 160px;
    }
    .margin-top-150 {
        margin-top: 170px;
    }
    .margin-top-160 {
        margin-top: 180px;
    }
    .margin-top-170 {
        margin-top: 190px;
    }
    .margin-top-180 {
        margin-top: 200px;
    }
    .margin-top-190 {
        margin-top: 210px;
    }
    .margin-top-200 {
        margin-top: 220px;
    }
    .margin-bottom-5 {
        margin-bottom: 10px;
    }
    .margin-bottom-10 {
        margin-bottom: 20px;
    }
    .margin-bottom-15 {
        margin-bottom: 28px;
    }
    .margin-bottom-20 {
        margin-bottom: 35px;
    }
    .margin-bottom-25 {
        margin-bottom: 40px;
    }
    .margin-bottom-30 {
        margin-bottom: 50px;
    }
    .margin-bottom-40 {
        margin-bottom: 60px;
    }
    .margin-bottom-50 {
        margin-bottom: 70px;
    }
    .margin-bottom-60 {
        margin-bottom: 80px;
    }
    .margin-bottom-70 {
        margin-bottom: 90px;
    }
    .margin-bottom-80 {
        margin-bottom: 100px;
    }
    .margin-bottom-90 {
        margin-bottom: 110px;
    }
    .margin-bottom-100 {
        margin-bottom: 120px;
    }
    .margin-left-5 {
        margin-left: 8px;
    }
    .margin-left-7 {
        margin-left: 12px;
    }
    .margin-left-10 {
        margin-left: 15px;
    }
    .margin-left-15 {
        margin-left: 20px;
    }
    .margin-left-20 {
        margin-left: 25px;
    }
    .margin-left-25 {
        margin-left: 30px;
    }
    .margin-left-30 {
        margin-left: 35px;
    }
    .margin-left-35 {
        margin-left: 40px;
    }
    .margin-left-45 {
        margin-left: 45px;
    }
    .margin-left-55 {
        margin-left: 65px;
    }
    .margin-left-60 {
        margin-left: 70px;
    }
    .margin-left-70 {
        margin-left: 78px;
    }
    .margin-left-80 {
        margin-left: 90px;
    }
    .margin-left-90 {
        margin-left: 100px;
    }
    .margin-left-100 {
        margin-left: 110px;
    }
    
    .padding-left-right-5 {
        padding-left: 5px;
        padding-right: 5px;
    }
    .padding-left-right-10 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .margin-left-right-15 {
        margin-left: 15px;
        margin-right: 15px;
    }
    .margin-left-right-20 {
        margin-left: 20px;
        margin-right: 25px;
    }
    .margin-left-right-25 {
        margin-left: 25px;
        margin-right: 25px;
    }
    .margin-left-right-30 {
        margin-left: 30px;
        margin-right: 30px;
    }
    .margin-left-right-35 {
        margin-left: 35px;
        margin-right: 35px;
    }
    .margin-left-right-40 {
        margin-left: 40px;
        margin-right: 40px;
    }
    .padding-left-right-5 {
        padding-left: 5px;
        padding-right: 5px;
    }
    .padding-left-right-10 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .padding-left-right-15 {
        padding-left: 15px;
        padding-right: 15px;
    }
    .padding-left-right-20 {
        padding-left: 20px;
        padding-right: 20px;
    }
    .padding-left-right-25 {
        padding-left: 25px;
        padding-right: 25px;
    }
    .padding-left-right-30 {
        padding-left: 30px;
        padding-right: 30px;
    }
    .padding-left-right-35 {
        padding-left: 35px;
        padding-right: 35px;
    }
    .padding-top-5 {
        padding-top: 7px;
    }
    .padding-top-10 {
        padding-top: 13px;
    }
    .padding-top-15 {
        padding-top: 20px;
    }
    .padding-top-20 {
        padding-top: 24px;
    }
    .padding-top-25 {
        padding-top: 30px;
    }
    .padding-top-30 {
        padding-top: 36px;
    }
    .padding-top-40 {
        padding-top: 48px;
    }
    .padding-top-50 {
        padding-top: 60px;
    }
    .padding-top-60 {
        padding-top: 72px;
    }
    .padding-top-70 {
        padding-top: 84px;
    }
    .padding-top-80 {
        padding-top: 96px;
    }
    .padding-top-90 {
        padding-top: 108px;
    }
    .padding-top-100 {
        padding-top: 120px;
    }
    .padding-top-110 {
        padding-top: 128px;
    }
    .padding-top-120 {
        padding-top: 134px;
    }
    .padding-top-130 {
        padding-top: 144px;
    }
    .padding-top-140 {
        padding-top: 158px;
    }
    .padding-top-150 {
        padding-top: 170px;
    }
    .padding-bottom-5 {
        padding-bottom: 7px;
    }
    .padding-bottom-10 {
        padding-bottom: 12px;
    }
    .padding-bottom-15 {
        padding-bottom: 18px;
    }
    .padding-bottom-20 {
        padding-bottom: 24px;
    }
    .padding-bottom-25 {
        padding-bottom: 30px;
    }
    .padding-bottom-30 {
        padding-bottom: 36px;
    }
    .padding-bottom-35 {
        padding-bottom: 42px;
    }
    .padding-bottom-40 {
        padding-bottom: 48px;
    }
    .padding-bottom-45 {
        padding-bottom: 54px;
    }
    .padding-bottom-50 {
        padding-bottom: 60px;
    }
    .padding-bottom-60 {
        padding-bottom: 72px;
    }
    .padding-bottom-70 {
        padding-bottom: 84px;
    }
    .padding-bottom-80 {
        padding-bottom: 96px;
    }
    .padding-bottom-90 {
        padding-bottom: 108px;
    }
    .padding-bottom-100 {
        padding-bottom: 120px;
    }
    .padding-bottom-110 {
        padding-bottom: 128px;
    }
    .padding-bottom-120 {
        padding-bottom: 134px;
    }
}

@media screen and (min-width: 1200px) {
    .margin-top-3 {
        margin-top: 5px;
    }
    .margin-top-5 {
        margin-top: 8px;
    }
    .margin-top-8 {
        margin-top: 12px;
    }
    .margin-top-10 {
        margin-top: 15px;
    }
    .margin-top-12 {
        margin-top: 18px;
    }
    .margin-top-15 {
        margin-top: 22px;
    }
    .margin-top-20 {
        margin-top: 28px;
    }
    .margin-top-25 {
        margin-top: 33px;
    }
    .margin-top-30 {
        margin-top: 38px;
    }   
    .margin-top-35 {
        margin-top: 43px;
    }
    .margin-top-40 {
        margin-top: 48px;
    }
    .margin-top-50 {
        margin-top: 63px;
    }
    .margin-top-60 {
        margin-top: 78px;
    }
    .margin-top-70 {
        margin-top: 88px;
    }
    .margin-top-80 {
        margin-top: 98px;
    }
    .margin-top-90 {
        margin-top: 110px;
    }
    .margin-top-100 {
        margin-top: 125px;
    }
    .margin-top-110 {
        margin-top: 140px;
    }
    .margin-top-120 {
        margin-top: 150px;
    }
    .margin-top-130 {
        margin-top: 160px;
    }
    .margin-top-140 {
        margin-top: 170px;
    }
    .margin-top-150 {
        margin-top: 180px;
    }
    .margin-top-160 {
        margin-top: 190px;
    }
    .margin-top-170 {
        margin-top: 200px;
    }
    .margin-top-180 {
        margin-top: 210px;
    }
    .margin-top-190 {
        margin-top: 220px;
    }
    .margin-top-200 {
        margin-top: 230px;
    }
    .margin-bottom-3 {
        margin-bottom: 5px;
    }
    .margin-bottom-5 {
        margin-bottom: 8px;
    }
    .margin-bottom-10 {
        margin-bottom: 15px;
    }
    .margin-bottom-15 {
        margin-bottom: 25px;
    }
    .margin-bottom-20 {
        margin-bottom: 30px;
    }
    .margin-bottom-25 {
        margin-bottom: 40px;
    }
    .margin-bottom-30 {
        margin-bottom: 50px;
    }
    .margin-bottom-40 {
        margin-bottom: 60px;
    }
    .margin-bottom-50 {
        margin-bottom: 70px;
    }
    .margin-bottom-60 {
        margin-bottom: 80px;
    }
    .margin-bottom-70 {
        margin-bottom: 90px;
    }
    .margin-bottom-80 {
        margin-bottom: 100px;
    }
    .margin-bottom-90 {
        margin-bottom: 110px;
    }
    .margin-bottom-100 {
        margin-bottom: 120px;
    }
    .margin-left-right-15 {
        margin-left: 15px;
        margin-right: 15px;
    }
    .margin-left-right-20 {
        margin-left: 20px;
        margin-right: 20px;
    }
    .margin-left-right-25 {
        margin-left: 25px;
        margin-right: 25px;
    }
    .margin-left-right-30 {
        margin-left: 30px;
        margin-right: 30px;
    }
    .margin-left-right-35 {
        margin-left: 35px;
        margin-right: 35px;
    }
    .margin-left-right-40 {
        margin-left: 40px;
        margin-right: 40px;
    }
    .margin-left-5 {
        margin-left: 8px;
    }
    .margin-left-7 {
        margin-left: 10px;
    }
    .margin-left-10 {
        margin-left: 15px;
    }
    .margin-left-15 {
        margin-left: 20px;
    }
    .margin-left-20 {
        margin-left: 25px;
    }
    .margin-left-25 {
        margin-left: 30px;
    }
    .margin-left-30 {
        margin-left: 40px;
    }
    .margin-left-35 {
        margin-left: 45px;
    }
    .margin-left-40 {
        margin-left: 50px;
    }
    .margin-left-45 {
        margin-left: 55px;
    }
    .margin-left-50 {
        margin-left: 60px;
    }
    .margin-left-55 {
        margin-left: 65px;
    }
    .margin-left-60 {
        margin-left: 70px;
    }
    .margin-left-70 {
        margin-left: 85px;
    }
    .margin-left-80 {
        margin-left: 95px;
    }
    .margin-left-90 {
        margin-left: 110px;
    }
    .margin-left-100 {
        margin-left: 120px;
    }

    .padding-top-5 {
        padding-top: 8px;
    }
    .padding-top-10 {
        padding-top: 16px;
    }
    .padding-top-15 {
        padding-top: 24px;
    }
    .padding-top-20 {
        padding-top: 32px;
    }
    .padding-top-25 {
        padding-top: 40px;
    }
    .padding-top-30 {
        padding-top: 48px;
    }
    .padding-top-40 {
        padding-top: 60px;
    }
    .padding-top-50 {
        padding-top: 72px;
    }
    .padding-top-60 {
        padding-top: 84px;
    }
    .padding-top-70 {
        padding-top: 90px;
    }
    .padding-top-80 {
        padding-top: 102px;
    }
    .padding-top-90 {
        padding-top: 114px;
    }
    .padding-top-100 {
        padding-top: 126px;
    }
    .padding-top-110 {
        padding-top: 134px;
    }
    .padding-top-120 {
        padding-top: 140px;
    }
    .padding-top-130 {
        padding-top: 150px;
    }
    .padding-top-140 {
        padding-top: 164px;
    }
    .padding-top-150 {
        padding-top: 180px;
    }
    .padding-bottom-5 {
        padding-bottom: 10px;
    }
    .padding-bottom-10 {
        padding-bottom: 15px;
    }
    .padding-bottom-15 {
        padding-bottom: 25px;
    }
    .padding-bottom-20 {
        padding-bottom: 35px;
    }
    .padding-bottom-25 {
        padding-bottom: 36px;
    }
    .padding-bottom-30 {
        padding-bottom: 42px;
    }
    .padding-bottom-35 {
        padding-bottom: 48px;
    }
    .padding-bottom-40 {
        padding-bottom: 54px;
    }
    .padding-bottom-45 {
        padding-bottom: 60px;
    }
    .padding-bottom-50 {
        padding-bottom: 72px;
    }
    .padding-bottom-60 {
        padding-bottom: 84px;
    }
    .padding-bottom-70 {
        padding-bottom: 90px;
    }
    .padding-bottom-80 {
        padding-bottom: 102px;
    }
    .padding-bottom-90 {
        padding-bottom: 114px;
    }
    .padding-bottom-100 {
        padding-bottom: 126px;
    }
    .padding-bottom-110 {
        padding-bottom: 134px;
    }
    .padding-bottom-120 {
        padding-bottom: 140px;
    }
}


/*↓paddingスタイル*/
.margin-top-3 {
    margin-top: 3px;
  }
.padding-top-5 {
    padding-top: 5px;
}
.padding-top-10 {
    padding-top: 10px;
}
.padding-top-15 {
    padding-top: 15px;
}
.padding-top-20 {
    padding-top: 20px;
}
.padding-top-25 {
    padding-top: 25px;
}
.padding-top-30 {
    padding-top: 30px;
}
.padding-top-40 {
    padding-top: 40px;
}
.padding-top-50 {
    padding-top: 50px;}

.padding-bottom-5 {
    padding-bottom: 5px;
}
.padding-bottom-10 {
    padding-bottom: 10px;
}
.padding-bottom-15 {
    padding-bottom: 15px;
}
.padding-bottom-20 {
    padding-bottom: 20px;
}

@media screen and (min-width: 769px) {
    .padding-top-5 {
        padding-top: 8px;
    }
    .padding-top-10 {
        padding-top: 15px;
    }
    .padding-top-15 {
        padding-top: 23px;
    }
    .padding-top-20 {
        padding-top: 30px;
    }
    .padding-top-25 {
        padding-top: 38px;
    }
    .padding-top-30 {
        padding-top: 45px;
    }
    .padding-top-40 {
        padding-top: 60px;
    }
    .padding-top-50 {
        padding-top: 75px;
    }
    .padding-bottom-5 {
        padding-bottom: 8px;
    }
    .padding-bottom-10 {
        padding-bottom: 15px;
    }
    .padding-bottom-15 {
        padding-bottom: 23px;
    }
    .padding-bottom-20 {
        padding-bottom: 30px;
    }   
    .padding-bottom-30 {
        padding-bottom: 45px;
    }
}

/*↓textスタイル*/
.text-center {
    text-align: center;
}
.font-color-gold {
    color: #a77f3c;
}
.fontsize-0-5 {
    font-size: 0.5rem;
}
.fontsize-0-6 {
    font-size: 0.6rem;
}
.fontsize-0-7 {
    font-size: 0.7rem;
}
.fontsize-0-8 {
    font-size: 0.8rem;
}
.fontsize-0-9 {
    font-size: 0.9rem;
}
.fontsize-1-0 {
    font-size: 1.0rem;
}
.fontsize-1-1 {
    font-size: 1.1rem;
}
.fontsize-1-2 {
    font-size: 1.2rem;
}
.fontsize-1-3 {
    font-size: 1.3rem;
}
.fontsize-1-4 {
    font-size: 1.4rem;
}
.fontsize-1-5 {
    font-size: 1.5rem;
}
.fontsize-1-6 {
    font-size: 1.6rem;
}
.fontsize-1-7 {
    font-size: 1.7rem;
}
.fontsize-1-8 {
    font-size: 1.8rem;
}
.fontsize-1-9 {
    font-size: 1.9rem;
}
.fontsize-2-0 {
    font-size: 2.0rem;
}
/*↑textスタイル*/


strong {
    color: #353535;
    font-weight: 600;
}

.strong-550 {
    color: #0f0f0f;
    font-weight: 550;
  }

/* スマートフォンおよび小型タブレット（768pxまで） */
@media (max-width: 768px) {
    /* ここにスマートフォンと小型タブレット用のスタイルを記述 */
    /*↓固定fontスタイル*/
    p {
      font-size: 14px;
    }
    h2 {
      font-size: 16px;
    }
    h3 {
      font-size: 16px;
    }
    h4 {
      font-size: 16px;
    }
    /*↑固定fontスタイル*/
    /*↓可変fontスタイル*/
    .fontsize-8 {
        font-size: 8px;
    }
    .fontsize-9 {
        font-size: 9px;
    }
    .fontsize-10 {
        font-size: 10px;
    }
    .fontsize-10-5 {
        font-size: 10.5px;
    }   
    .fontsize-11 {
        font-size: 11px;
    }
    .fontsize-11-5 {
        font-size: 11.5px;
    }
    .fontsize-12 {
        font-size: 12px;
    }
    .fontsize-12-5 {
        font-size: 12.5px;
    }
    .fontsize-13 {
        font-size: 13px;
    }
    .fontsize-13-5 {
        font-size: 13.5px;
    }
    .fontsize-14 {
        font-size: 14px;
    }
    .fontsize-14-5 {
        font-size: 14.5px;
    }
    .fontsize-15 {
        font-size: 15px;
    }
    .fontsize-15-5 {
        font-size: 15.5px;
    }
    .fontsize-16 {
        font-size: 16px;
    }
    .fontsize-16-5 {
        font-size: 16.5px;
    }
    .fontsize-17 {
        font-size: 17px;
    }
    .fontsize-17-5 {
        font-size: 17.5px;
    }
    .fontsize-18 {
        font-size: 18px;
    }
    .fontsize-18-5 {
        font-size: 18.5px;
    }
    .fontsize-19 {
        font-size: 19px;
    }
    .fontsize-19-5 {
        font-size: 19.5px;
    }
    .fontsize-20 {
        font-size: 20px;
    }
    .fontsize-20-5 {
        font-size: 20.5px;
    }
    .fontsize-21 {
        font-size: 21px;
    }
    .fontsize-21-5 {
        font-size: 21.5px;
    }
    .fontsize-22 {
        font-size: 22px;
    }
    .fontsize-22-5 {
        font-size: 22.5px;
    }
    .fontsize-23 {
        font-size: 23px;
    }
    .fontsize-23-5 {
        font-size: 23.5px;
    }
    .fontsize-24 {
        font-size: 24px;
    }
    .fontsize-24-5 {
        font-size: 24.5px;
    }
    .fontsize-25 {
        font-size: 25px;
    }
    .fontsize-26 {
        font-size: 26px;
    }
  }
  /*↑可変fontスタイル*/
  
  /*文字サイズ（769px以上） */
  @media (min-width: 769px) {
    .global-container{
        max-width: 900px;
        margin: 0 auto; /* コンテンツを中央に配置 */
    }
    p {
        font-size: 15px;
    }
    h2 {
        font-size: 20px;

      }
    h3 {
        font-size: 20px;
      }
    h4 {
    font-size: 16px;
    }
      .fontsize-8 {
        font-size: 9px;
    }
    .fontsize-9 {
        font-size: 10px;
    }
    .fontsize-9-5 {
        font-size: 10.5px;
    }
    .fontsize-10 {
        font-size: 11px;
    }
    .fontsize-10-5 {
        font-size: 11.8px;
    }
    .fontsize-11 {
        font-size: 12.5px;
    }
    .fontsize-11-5 {
        font-size: 13px;
    }
    .fontsize-12 {
        font-size: 13.5px;
    }
    .fontsize-12-5 {
        font-size: 14px;
    }
    .fontsize-13 {
        font-size: 14.5px;
    }
    .fontsize-13-5 {
        font-size: 15px;
    }
    .fontsize-14 {
        font-size: 16px;
    }
    .fontsize-14-5 {
        font-size: 16.5px;
    }
    .fontsize-15 {
        font-size: 17px;
    }
    .fontsize-15-5 {
        font-size: 17.5px;
    }
    .fontsize-16 {
        font-size: 18px;
    }
    .fontsize-16-5 {
        font-size: 18.5px;
    }
    .fontsize-17 {
        font-size: 19px;
    }
    .fontsize-17-5 {
        font-size: 19.5px;
    }
    .fontsize-18 {
        font-size: 21px;
    }
    .fontsize-18-5 {
        font-size: 21.5px;
    }
    .fontsize-19 {
        font-size: 22px;
    }
    .fontsize-19-5 {
        font-size: 22.5px;
    }
    .fontsize-20 {
        font-size: 23px;
    }
    .fontsize-20-5 {
        font-size: 23.5px;
    }
    .fontsize-21 {
        font-size: 24px;
    }
    .fontsize-21-5 {
        font-size: 24.5px;
    }
    .fontsize-22 {
        font-size: 25px;
    }
    .fontsize-22-5 {
        font-size: 25.5px;
    }
    .fontsize-23 {
        font-size: 26px;
    }
    .fontsize-23-5 {
        font-size: 26.5px;
    }
    .fontsize-24 {
        font-size: 27px;
    }
    .fontsize-24-5 {
        font-size: 27.5px;
    }
    .fontsize-25 {
        font-size: 28px;
    }
    .fontsize-26 {
        font-size: 29px;
    }
  }
@media (min-width: 1200px) {
    p {
        font-size: 16px;
    }
    h2 {
        font-size: 22px;
    }
    h3 {
        font-size: 20px;
    }
    h4 {
        font-size: 18px;
    }
    .fontsize-9-5 {
        font-size: 11.5px;
    }
    .fontsize-10 {
        font-size: 12px;
    }
    .fontsize-10-5 {
        font-size: 12.5px;
    }
    .fontsize-11 {
        font-size: 13px;
    }
    .fontsize-11-5 {
        font-size: 13.5px;
    }
    .fontsize-12 {
        font-size: 14px;
    }
    .fontsize-12-5 {
        font-size: 15px;
    }
    .fontsize-13 {
        font-size: 15.5px;
    }
    .fontsize-13-5 {
        font-size: 16px;
    }
    .fontsize-14 {
        font-size: 16.5px;
    }
    .fontsize-14-5 {
        font-size: 17px;
    }   
    .fontsize-15 {
        font-size: 17.5px;
    }
    .fontsize-15-5 {
        font-size: 18px;
    }
    .fontsize-16 {
        font-size: 19px;
    }
    .fontsize-16-5 {
        font-size: 20px;
    }
    .fontsize-17 {
        font-size: 21px;
    }
    .fontsize-17-5 {
        font-size: 21.5px;
    }
    .fontsize-18 {
        font-size: 22px;
    }
    .fontsize-18-5 {
        font-size: 22.5px;
    }
    .fontsize-19 {
        font-size: 23px;
    }
    .fontsize-19-5 {
        font-size: 23.5px;
    }
    .fontsize-20 {
        font-size: 25px;
    }
    .fontsize-20-5 {
        font-size: 24.5px;
    }
    .fontsize-21 {
        font-size: 26px;
    }
    .fontsize-21-5 {
        font-size: 25.5px;
    }
    .fontsize-22 {
        font-size: 27px;
    }
    .fontsize-22-5 {
        font-size: 26.5px;
    }
    .fontsize-23 {
        font-size: 29px;
    }
    .fontsize-23-5 {
        font-size: 27.5px;
    }
    .fontsize-24 {
        font-size: 30px;
    }
    .fontsize-24-5 {
        font-size: 28.5px;
    }
    .fontsize-25 {
        font-size: 31px;
    }
    .fontsize-26 {
        font-size: 32px;
    }
}
/*レスポンシブ*/
/* 画面幅が716pxを超えた場合のスタイル */
@media (min-width: 800px) {
    .container-max800 {
        max-width: 800px;
        margin: 0 auto; /* コンテンツを中央に配置 */
        padding-left: 15px;
        padding-right: 15px;
    }
}
@media (min-width: 850px) {
    .container-max850 {
        max-width: 850px;
        margin: 0 auto; /* コンテンツを中央に配置 */
        padding-left: 15px;
        padding-right: 15px;
    }
}
@media (min-width: 900px) {
    .container-max900 {
        max-width: 900px;
        margin: 0 auto; /* コンテンツを中央に配置 */
        padding-left: 15px;
        padding-right: 15px;
    }
}
@media (min-width: 960px) {
    .container-max960 {
        max-width: 960px;
        margin: 0 auto; /* コンテンツを中央に配置 */
    }
}
@media (min-width: 1100px) {
    .container-max1100 {
        max-width: 1100px;
        margin: 0 auto; /* コンテンツを中央に配置 */
    }
    .container-max1260 {
        max-width: 1260px;
        margin: 0 auto; /* コンテンツを中央に配置 */
    }
    
}

.container-max1050 {
    max-width: 1050px;
    margin: 0 auto; /* コンテンツを中央に配置 */
}
.container-max1000 {
    max-width: 1000px;
    margin: 0 auto; /* コンテンツを中央に配置 */
}
.container-max-900 {
    max-width: 900px;
    margin: 0 auto; /* コンテンツを中央に配置 */
}
.container-max600 {
    max-width: 600px;
    margin: 0 auto;
}
.container-max700 {
    max-width: 700px;
    margin: 0 auto;
    padding-left: 15px;
    padding-right: 15px;
}
.container-max750 {
    max-width: 750px;
    margin: 0 auto;
    padding-left: 15px;
    padding-right: 15px;
}
.container-max-1200 {
    max-width: 1200px;
    margin: 0 auto;
}
.container-max-1300 {
    max-width: 1300px;
    margin: 0 auto;
}
.container-max-1400 {
    max-width: 1400px;
    margin: 0 auto;
}
.container-max-1600 {
    max-width: 1600px;
    margin: 0 auto;
}
.container-max-1700 {
    max-width: 1700px;
    margin: 0 auto;
}

.container-max-1800 {
    max-width: 1800px;
    margin: 0 auto;
}

.container-1200 {
    max-width: 1200px;
    margin: 0 auto;
}
.container-1280 {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 15px;
}
.container-1300 {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 15px;
}
.container-1360 {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 15px;
}

.container-1360-0 {
    max-width: 1360px;
    margin: 0 auto;
}

.container-1500 {
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 15px;
}
.container-800 {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 15px;
}

/*↑レスポンシブ*/

/*↓装飾*/
.vertical-bar::before {
    content: ""; /* 空のコンテンツを生成 */
    display: inline-block; /* インラインブロック要素として表示 */
    width: 6px; /* 幅を4ピクセルに設定 */
    height: 22px; 
    background-color: rgba(0, 167, 206, 1); /* 背景色を指定 */
    margin-right: 5px; /* 縦棒とテキストの間のスペース */
    vertical-align: top; /* 縦方向の位置を中央に揃える */
}
.vertical-bar {
    line-height: 22px; /* or adjust to match the height */
}
.vertical-bar-gold::before {
    content: ""; /* 空のコンテンツを生成 */
    display: inline-block; /* インラインブロック要素として表示 */
    width: 6px; /* 幅を4ピクセルに設定 */
    height: 22px; 
    background: #B99D6D;
    margin-right: 5px; /* 縦棒とテキストの間のスペース */
    vertical-align: top; /* 縦方向の位置を中央に揃える */
}
.vertical-bar-gold {
    line-height: 22px; /* or adjust to match the height */
}
.border-left-title-lightblue {
    border-left: 4px solid #00A7CE;
    padding-left: 10px;
}

.border-left-mintblue {
    border-left: 4px solid #6cd5cb;
    padding-left: 10px;
}

.border-left-title-lightblue-2 {
    border-left: 3px solid #00a8cecb;
    padding-left: 10px;
}

.border-left-title-gold {
    border-left: 4px solid #B99D6D;
    padding-left: 10px;
}
@media screen and (min-width: 769px) {
    .vertical-bar::before { 
        height: 26px; 
        margin-right: 6px;
    }
    .vertical-bar {
        line-height: 26px; /* or adjust to match the height */
    }
    .vertical-bar-gold::before {
        height: 26px;
        margin-right: 6px;
    }
    .vertical-bar {
        line-height: 26px; /* or adjust to match the height */
    }
}
.button-container img {
    vertical-align: text-top;
    margin-left: 8px;
}
.solid-gray {
    border: 1px solid #e0e0e0; /* ゴールドの囲いを追加 */
}

.font-lightblue-title {
    background-color: #31b7d6; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 10px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
}

.font-mintblue-title {
    background: linear-gradient(45deg, #70cec3, #6cc3b4);
    color: white;
    padding: 10px;
    text-align: center;
    letter-spacing: 0.05em;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(21, 21, 21, 0.3);
    text-shadow: 1px 1px 2px rgba(17, 17, 17, 0.5), -0.5px -1px rgba(21, 21, 21, 0.1);
}

.font-lightblue-title-6 {
    background-color: #31b7d6; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
    font-weight: 550;
    letter-spacing: 0.05em;
    box-shadow: 0 2px 8px rgba(21, 21, 21, 0.3);
    text-shadow: 
        -1px -1px 0 rgba(0, 0, 0, 0.1),
        1px -1px 0 rgba(17, 17, 17, 0.1),
        -1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 2px rgba(17, 17, 17, 0.1);
}
.font-lightblue-title-6-radius {
    background-color: #31b7d6; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 8px; /* 内側の余白を追加 */
    border-radius: 7px 7px 0 0; /* 右上と左上の角を丸くする */
    text-align: center; /* テキストを中央揃え */
    box-shadow: 0 2px 8px rgba(21, 21, 21, 0.3);
    text-shadow: 
        -1px -1px 0 rgba(17, 17, 17, 0.1),
        1px -1px 0 rgba(17, 17, 17, 0.1),
        -1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 2px rgba(17, 17, 17, 0.1);
}
.font-lightblue-title-6-radius-4 {
    background-color: #31b7d6; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
    border-radius: 4px 4px 0 0; /* 右上と左上の角を丸くする */
}

.font-mintblue-title-6-radius {
    background-color: #67d4ca; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 8px; /* 内側の余白を追加 */
    border-radius: 7px 7px 0 0; /* 右上と左上の角を丸くする */
    text-align: center; /* テキストを中央揃え */
    box-shadow: 0 2px 8px rgba(21, 21, 21, 0.3);
    text-shadow: 
        -1px -1px 0 rgba(17, 17, 17, 0.1),
        1px -1px 0 rgba(17, 17, 17, 0.1),
        -1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 0 rgba(17, 17, 17, 0.1),
        1px 1px 2px rgba(17, 17, 17, 0.1);
}
.font-lightblue-title-6-radius-4 {
    background-color: #0ABAB5; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
    border-radius: 4px 4px 0 0; /* 右上と左上の角を丸くする */
}

.font-gold-title-6-radius4 {
    background-color: #dbc68e; /* 背景色を指定 */
    color: rgb(49, 49, 49); /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
    border-radius: 4px 4px 0 0; /* 右上と左上の角を丸くする */
}
.font-gold-title-6 {
    background-color: #dbc68e; /* 背景色を指定 */
    color: rgb(49, 49, 49); /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
}
.font-gold-title-8 {
    background-color: #dbc68e; /* 背景色を指定 */
    color: rgb(45, 45, 45); /* テキスト色を白に */
    padding: 8px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
    letter-spacing: 0.05em; /* 文字間隔を調整 */
    text-shadow: 
        -0.5px -0.5px 0 rgba(255, 255, 255, 0.5),
        0.5px -0.5px 0 rgba(255, 255, 255, 0.5),
        -0.5px 0.5px 0 rgba(255, 255, 255, 0.5),
        0.5px 0.5px 0 rgba(255, 255, 255, 0.5),
        2px 2px 4px rgba(255, 255, 255, 0.8); /* 文字に薄く細い黒枠とシャドウを追加 */
}

.gold-title-7 {
    background: linear-gradient(135deg, #dbc68e 0%, #c9b37a 100%);
    color: #3b3b3b;
    padding: 6px 15px;
    text-align: center;
    border-top: 3px solid #caaf71;
    border-bottom: 3px solid #caaf71;
    box-shadow: 0 2px 8px rgba(255, 252, 246, 0.6);
    text-shadow: 
        -1px -1px 0 rgb(255, 255, 255, 0.3),
        1px -1px 0 rgb(255, 255, 255, 0.3),
        -1px 1px 0 rgb(255, 255, 255, 0.3),
        1px 1px 0 rgb(255, 255, 255, 0.3),
        2px 2px 4px rgba(255, 255, 255, 0.3);
}

.gold-title {
    background-color: #b8aa6f; /* 背景色を指定 */
    color: white; /* テキスト色を白に */
    padding: 8px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
}
.black-title {
    background-color: #3186a7; /* 背景色を指定し、透明度を追加 */
    color: white; /* テキスト色を白に */
    padding: 6px; /* 内側の余白を追加 */
    text-align: center; /* テキストを中央揃え */
}
.solid-item {
    border: 1px solid #ddd;
    background-color: #fff;
    box-shadow: 0 2px 2px rgba(226, 226, 226, 0.1);
}
.solid-item p {
    margin: 6px 12px;
}
/*↑装飾*/
/*↓fontスタイル*/
.font-gold {
    color: #907030;
}
.font-gold-600 {
    color: #907030;
    font-weight: 600;
}
.font-gray {
    color: #2f2f2f;
}
.font-gray-600 {
    color: #2f2f2f;
    font-weight: 600;
}
.font-lightgray {
    color: #454545;
}
.font-lightgray-2 {
    color: #666666;
}
.font-lightblue {
    color: #008ead;
}
.font-lightblue2 {
    color: #0d90ad;
}
.font-lightblue3 { color: #4a8d9e; }

.font-lightblue-600 {
    color: #0d90ad;
    font-weight: 600;
}

.font-mintblue-600 {
    color: #077c79;
    font-weight: 600;
}

.font-lightgray-550 {
    color: #555;
    font-weight: 550;
}

.font-lightgray-600 {
    color: #555;
    font-weight: 600;
}
.font-lightgray-600-2 {
    color: #5d5d5d;
    font-weight: 600;
}
.font-pink-600 {
    color: #FF179E;
    font-weight: 600;
}
.font-orange-550 {
    color: rgb(231, 69, 0);
    font-weight: 550;
    letter-spacing: 0.01em;
}
.font-weight-550 {
    font-weight: 550;
}
.font-weight-600 {
    font-weight: 600;
}
.font-weight-700 {
    font-weight: 700;
}
.font-weight-800 {
    font-weight: 800;
}
.font-mincho {
    font-family: 'Sawarabi Mincho', serif;
}

/*↓ボタン*/
.btn { border: none; padding: 8px 18px; border-radius: 4px; font-weight: 300; cursor: pointer; text-decoration: none; display: inline-block; transition: all 0.3s ease; }
.btn-dark {
    font-weight: 550;
    letter-spacing: 0.04em;
    background: #5c5c5c;
    color: white;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 1);
    border: 2px solid rgba(167, 167, 167, 0.33);
  }
.btn-dark:hover { background: #555; }
.btn-primary { font-weight: 600; letter-spacing: 0.04em; background: #50aac1; color: white; text-shadow: 1px 1px 2px rgba(24, 24, 24, 0.8); border: 2px solid rgba(205, 247, 255, 0.33); }
.btn-primary:hover { background: #3a7c8c; }
.btn-gradient { background: linear-gradient(135deg, #a0d8e6, #c0d3f0); color: white; }
.btn-gradient:hover { background: linear-gradient(135deg, #90c8d6, #b0c3e0); }
.btn-outline { background: transparent; border: 1px solid #e0e0e0; color: #474747; }
.btn-outline:hover { border-color: #4a8d9e; color: #4a8d9e; background: #f5f5f5; }
.btn-full { width: 100%; }

.btn-lightblue-gradient {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    max-width: 300px;
    margin: 20px auto;
    padding: 6px 16px;
    border-radius: 4px;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, #5eb8c9, #8aadd6);
    color: #fff;
    font-size: 16px;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    text-decoration: none;
    transition: opacity 0.2s;
  }

  .btn-lightblue-gradient:hover {
    opacity: 0.9;
  }

  .btn-lightblue-gradient-text {
    flex: 1;
    text-align: center;
    font-weight: 550;
  }

  .btn-lightblue-gradient-arrow {
    font-size: 22px;
    font-weight: 400;
    margin-right: 20px;
  }


  .btn-gold-gradient {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    max-width: 80%;
    margin: 20px auto;
    padding: 6px 16px;
    border-radius: 4px;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, #d1bb81, #c1a664);
    color: #fff;
    font-size: 16px;
    text-shadow:   2px 0 6px rgba(0,0,0,.2),
    -1px 0 1px rgba(0,0,0,.1),
     0 2px 4px rgba(0,0,0,.2),
     0 -1px 1px rgba(0,0,0,.1);
    text-decoration: none;
    transition: opacity 0.2s;
  }

  .btn-gold-gradient:hover {
    opacity: 0.9;
  }

  .btn-gold-gradient-text {
    flex: 1;
    text-align: center;
    font-weight: 550;
  }

  .btn-gold-gradient-arrow {
    font-size: 22px;
    font-weight: 500;
    margin-right: 20px;
  }
/* スタイル9: グラデーションボーダー＋エレガント */
.cta-button {
    width: 100%;
    padding: 10px 16px;
    font-size: 15px;
    font-weight: 550;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    letter-spacing: 0.8px;
    position: relative;
    display: inline-block;
    text-decoration: none;
    text-align: center;
    box-sizing: border-box;
}

.pmt-price-btn {
    display: block;
    width: 100%;
    padding: 14px;
    background-color: #999999;
    border: 2px solid rgba(209, 223, 219, 0.33);
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    margin: 15px 0 40px 0;
    transition: opacity 0.2s;
    border-radius: 4px;
    letter-spacing: 0.05em;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .2);
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4);
  }

  

  .pmt-price-btn:hover {
    opacity: 0.9;
  }

  .pmt-price-btn-2 {
    display: block;
    width: 100%;
    padding: 12px 0;
    background: linear-gradient(45deg, #89b0bb, #72a5ba);
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 15px;
    margin: 15px auto 40px;
    transition: opacity 0.2s;
    border-radius: 8px;
    letter-spacing: 0.08em;
    font-weight: 600;
    box-shadow: 0 1px 8px rgba(0, 0, 0, .1);
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.4);
  }

@media screen and (min-width: 769px) {
    .cta-button {
        padding: 11px 20px;
        font-size: 16px;
    }
  .btn-gold-gradient {
    padding: 10px 20px;
    font-size: 18px;
    margin: 30px auto;

  }
  .pmt-price-btn {
    padding: 12px;
    font-size: 18px;
    margin: 26px 0 40px 0;
  }
  .pmt-price-btn-2 {
    padding: 12px;
    font-size: 18px;
    margin: 26px 0 40px 0;
  }

}

.btn-gold {
    background: #ffffff;
    color: #927830 !important;
    border-radius: 14px;
    position: relative;
    font-weight: 600;
}

.btn-gold::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 10px;
    padding: 1.5px;
    background:  #c2a647;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    background-size: 300% 300%;
    animation: gradientShift 3s ease infinite;
}

@keyframes gradientShift {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

.btn-gold .fontsize-22 {
    position: absolute;
    right: 30px;
    top: 46%;
    transform: translateY(-50%);
    font-size: 22px;
    transition: transform 0.3s ease;
    font-weight: 400;
}

@media screen and (min-width: 769px) {
    .btn-gold .fontsize-22 {
        right: 30px;
        font-size: 22px;
    }
}

.btn-gold:hover {
    background: linear-gradient(135deg, #C9A961 0%, #B8973D 100%);
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(201, 169, 97, 0.2);
}

.btn-gold:hover .fontsize-14 {
    transform: translateY(-50%) translateX(5px);
}

.btn-gold:active {
    transform: scale(0.98);
}

.button-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}


/* カード内になじむ、控えめなボタン */
.btn-steplink {
    display: block;
    width: 100%;
    padding: 12px 16px;
    border-radius: 10px;
  
    /* 主張しすぎない薄い背景と枠 */
    background: #f6f9fc;
    border: 1px solid #e6edf3;
  
    /* 文字も少し落ち着かせる */
    color: #3f5563;
    font-weight: 600;
  
    text-align: center;
    text-decoration: none;
    cursor: pointer;
  
    transition: background .2s ease, border-color .2s ease, transform .06s ease;
  }
  
  .btn-steplink-orange:hover {
    background: #E86800;
    border-color: #d8e6f2;
  }
  
  .btn-steplink-orange:active {
    transform: translateY(1px);
  }
  
  .btn-steplink-orange:focus-visible {
    outline: 3px solid rgba(120, 170, 210, .35);
    outline-offset: 3px;
  }

  .btn-steplink-orange {
    display: block;
    width: 100%;
    padding: 12px 16px;
    border-radius: 10px;
    background: #FF7A00;
    border: 1px solid #e6edf3;
  
    color: #FFFFFF;
    font-weight: 600;
  
    text-align: center;
    text-decoration: none;
    cursor: pointer;
  
    transition: background .2s ease, border-color .2s ease, transform .06s ease;
  }
  
  .btn-steplink:hover {
    background: #eef5fb;
    border-color: #d8e6f2;
  }
  
  .btn-steplink:active {
    transform: translateY(1px);
  }
  
  .btn-steplink:focus-visible {
    outline: 3px solid rgba(120, 170, 210, .35);
    outline-offset: 3px;
  }

.button-container {
    text-align: center;
    margin: 14px 0;
}

.button-container-0 {
    text-align: center;
}


.button-gray {
    display: inline-block;
    width: auto;
    padding: 8px 30px;
    background-color:rgb(124, 124, 124);
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    font-weight: 550;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    text-shadow: 1px 1px 2px rgba(55, 55, 55, 0.4);
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.25);
}
.button-gray :hover {
    background-color: rgba(85, 85, 85, 1); /* 濃い灰色に設定 */
}

.button-light-blue {
    display: inline-block;
    width: auto;
    padding: 6px 14px;
    background-color: rgba(0, 168, 202, 1);
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    text-shadow: 1px 1px 2px rgba(55, 55, 55, 0.4);
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.25);
}

.button-lightblue-gradient {
    display: inline-block;
    width: auto;
    padding: 6px 14px;
    background:linear-gradient(to right,  #65a4ba, #8ca1c1);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
}

.button-light-blue-2 {
    display: inline-block;
    width: auto;
    padding: 6px 18px;
    background-color: rgb(78, 185, 207);
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    text-shadow: 1px 1px 2px rgba(55, 55, 55, 0.4);
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.25);
}

.button-light-blue-3 {
    display: inline-block;
    width: auto;
    padding: 8px 30px;
    background-color: rgba(0, 168, 202, 1);
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    text-shadow: 1px 1px 2px rgba(55, 55, 55, 0.4);
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.25);
}

.button-light-blue:hover {
    background-color: #0056b3; /* ホバー時の背景色を設定 */
}
.button-light-blue-2:hover {
    background-color: #0056b3; /* ホバー時の背景色を設定 */
}
.button-gold {
    display: inline-block;
    width: auto;
    padding: 4px 8px;
    background-color: #cabb74;;
    color: #ffffff;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
}
.button-gold:hover {
    background-color: #79791e; /* ホバー時の背景色を設定 */
}

.button-orange {
    display: inline-block;
    width: auto;
    padding: 8px 14px;
    background-color:#ff8000;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4);
    box-shadow:0 2px 8px rgba(0,0,0,.25);
}

.button-orange-14 {
    display: inline-block;
    width: auto;
    padding: 8px 14px;
    background-color:#ff8000;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 14px;
    cursor: pointer;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4);
    box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.button-gray :hover {
    background-color: rgb(183, 7, 7); /* 濃い灰色に設定 */
}
.button-pink {
    display: inline-block;
    width: auto;
    padding: 6px 12px;
    background-color:#FF5FA7;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
}
.button-pink :hover {
    background-color: rgb(183, 7, 7); /* 濃い灰色に設定 */
}
@media screen and (min-width: 769px) and (max-width: 1199px) {
    .button-light-blue {
        padding: 8px 16px;
        font-size: 20px;
    }
    .button-light-blue-2 {
        padding: 8px 22px;
        font-size: 20px;
    }
    .button-lightblue-gradient {
        padding: 8px 18px;
        font-size: 20px;
    }
    .button-gray {
        padding: 6px 14px;
        font-size: 18px;
    }
    .button-gold {
        padding: 8px 16px;
        font-size: 20px;
    }
    .button-orange {
        padding: 8px 16px;
        font-size: 20px;
    }
    .button-pink {
        padding: 8px 16px;
        font-size: 20px;
    }
    .button-container {
        margin: 14px 0;
    }
}

@media screen and (min-width: 1200px) {
    .button-light-blue {
        padding: 10px 18px;
        font-size: 22px;
    }
    .button-light-blue-2 {
        padding: 10px 24px;
        font-size: 22px;
    }
    .button-gray {
        padding: 6px 14px;
        font-size: 19px;
    }
    .button-gold {
        padding: 8px 18px;
        font-size:22px;
    }
    .button-orange {
        padding: 8px 18px;
        font-size:22px;
    }
    .button-pink {
        padding: 8px 18px;
        font-size:22px;
    }
    .button-container {
        margin: 18px 0;
    }
}

.gray-background {
    background-color:rgb(243, 243, 243);
}
.background-light-blue
 {
    background-color:rgb(241, 238, 220);
}
.hide-top-1px {
    position: relative;
    top: -2px;
    clip-path: inset(2px 0 0 0);
  }
/*↑装飾*/

/* ヘッダー */
/* ハンバーガーメニューを開いた際に白透明度77%をかける*/
.page-overlay {
    visibility: hidden; /* デフォルトでは見えない */
    opacity: 0; /* デフォルトでは透明 */
    position: fixed; /* ページ全体に固定 */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.77); /* 白色で透明度77% */
    z-index: 999; /* メニューよりも低いが、他の要素よりは高いz-index */
    transition: opacity 0.6s ease; /* opacityは0.6秒かけて変化 */
  }
  
  .page-overlay.active {
    visibility: visible; /* 見えるようにする */
    opacity: 1; /* 完全に不透明にする */
  }
  
  .global-container {
    position: relative;/* コンテナを相対位置に設定。この設定により、内部の絶対位置要素（ハンバーガーメニューなど）がこの要素に対して位置が決定される */
    max-width: 1000px;
    margin: auto;
  }
  
  
  
  /* ハンバーガーメニューを開いた際に白透明度77%をかける */
  .page-overlay {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.77);
    z-index: 999;
    transition: opacity 0.6s ease;
  }
  
  .page-overlay.active {
    visibility: visible;
    opacity: 1;
  }
  
  .global-container {
    position: relative;
    max-width: 1000px;
    margin: auto;
  }

@media (max-width: 1279px) {
  .nav {
    visibility: hidden;
    position: fixed;
     top: 50px;
     right: 0;
     width:100%;
     height: calc(100vh);
     transform: translateX(100%);
     transition: transform .6s ease, visibility 0s .6s;
     background: linear-gradient(to bottom, #d9ebe8, #ffffff);
     z-index: 1001;
  } 
  /* .nav ul.menu-item li {
    border-bottom: 1px solid #eae1c7; 
    padding: 1.2px 0px;
}
.nav ul.menu-item li a {
    padding: 12px 30px 12px 16px;
}

.nav ul.menu-list .list {
    padding-left: 28px; 
    background: url(images/sub1.png) no-repeat 32px 10px;
    border-top: 1px solid #d4c7a3; 
}
.nav ul.menu-list li.list:last-child {
    background: url(images/subLast.png) no-repeat 29px 18px;
}
.nav ul.menu-item li.with-top-border {
    border-top: 1px solid #eae1c7; 
}
.nav ul.menu-item li.no-bottom-border {
    border-bottom: none; 
}
.nav ul.menu-list li {
    border-bottom: none; 
}
 .list img {
    margin-right: 7px;
    vertical-align: text-bottom;
} */
}
@media (min-width: 630px) and (max-width: 1279px) {
    .nav {
       width: 100%;
    } 
}
  
  .nav.active {
    visibility: visible;
    transform: translateX(0); /* アクティブ時に左へスライド */
    transition: transform .3s ease;
    position: fixed;
  }
  
  
  .nav ul {
    list-style: none;
  }
  
  /* .nav ul li {
    white-space: nowrap;
  } */
  
  /* .nav ul li a {
    color: inherit;
    text-decoration: none;
  } */
  
  
  /* メニュートグルのスタイル */
  .menu-toggle {
    position: fixed;
    right: 10px;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    cursor: pointer;
    z-index: 1000;
  }
  
  /* バーのスタイル */
  .bar {
    display: block;
    width: 25px;
    height: 2px;
    margin: 2.5px auto;
    background-color: #333;
    transition: all 0.3s ease;
  }
  
  
  /* ビューポートの幅が390px以下の場合 */
  @media (max-width: 430px) {
    .bar {
      width: 25px;
      height: 2px;
      margin: 3px auto;
    }
    /* .nav ul li {
        font-size: 15px;
      }
      .menu-list .list {
        font-size: 13px; 
    } */
  }
  
  
  @media (min-width: 430px) and (max-width: 960px) {
    .bar {
      width: 30px;
      height: 2.4px;
      margin: 3.3px auto;
    }
    /* .nav ul li {
        font-size: 16px;
      }
      .menu-list .list {
        font-size: 14px;
    } */
  }
  
  
  /* ビューポートの幅が961px以上の場合 */
  @media (min-width: 961px) {
    .bar {
      width: 33px;
      height: 3px;
      margin: 3px auto;
    }
    /* .nav ul li {
        font-size: 17px;
      }
    .menu-list .list {
        font-size: 15px;
    } */
  }
  /* デフォルトスタイル */
  .menu-toggle.active .bar:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }
  
  .menu-toggle.active .bar:nth-child(2) {
    opacity: 0; /* 2番目のバーを非表示に */
  }
  
  .menu-toggle.active .bar:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
  }
  
  
  /* ビューポートの幅が390px以下の場合のメニュートグルの変更スタイル */
  @media (max-width: 430px) {
    .menu-toggle.active .bar:nth-child(1) {
      transform: translateY(8px) rotate(45deg);
    }
  
    .menu-toggle.active .bar:nth-child(3) {
      transform: translateY(-8px) rotate(-45deg);
    }
  }
  
  /* ビューポートの幅が390px以上1000px以下の場合のメニュートグルの変更スタイル */
  @media (min-width: 430px) {
    .menu-toggle.active .bar:nth-child(1) {
      transform: translateY(8.8px) rotate(45deg);
    }
  
    .menu-toggle.active .bar:nth-child(3) {
      transform: translateY(-8.8px) rotate(-45deg);
    }
  }

  header {
    display: flex;
    align-items: center;
    position: fixed;
    height: 80px; /* ビューポートに応じて変更する */
    top: 0; /* ページの最上部に固定 */
    left: 0; /* ページの最左部から開始 */
    right: 0; /* ページの最右部から開始 */
    width: 100%; /* 幅を100%に設定して画面全体に広がるようにする */
    margin-left: auto; /* 左のマージンを自動に設定 */
    margin-right: auto; /* 右のマージンを自動に設定 */
    z-index: 1000; /* 他の要素より前面に表示 */
    background-color: #fff;
  }
  
  .main-title {
    /* display: block;
    margin-top: 2px;
    margin-left: 5px;
    font-size: 9px;
    color: #808080; */
    position: absolute;
    top: 3px;   
    left: 4px;
    margin: 0;
    font-size: 8.5px;
    color: #808080;
    line-height: 1;
  }

  .logo img,
  .menu-toggle img {
    height: auto;
  }
  header .logo {
    /* display: flex;
    align-items: center;
    height: 100%;  */
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    top: 9px; 
  }
  
  header .logo a {
    display: flex;
    align-items: center;
    height: 100%;
  }
  
  /* ビューポートの幅に応じてヘッダーの高さを変更 */
  /* ビューポートの幅が390px以下の場合 */
  @media (max-width: 440px) {
    header {
      height: 50px; /* ヘッダーの高さを50pxに固定 */
    }
    .logo img {
      height: 32px;
    }
    .nav {
      top: 50px; /* ヘッダーの高さに応じて動的に変更 */
    }
    main {
        padding-top: 50px;
  }
}
  
  @media (min-width: 440px) and (max-width: 630px) {
    header {
      /* ヘッダーの高さを動的に調整 */
      height: 52px;
    }
  
    main {
        padding-top: 52px;
  }
    .logo img {
      /* ロゴの高さを動的に調整 */
      height:35px;
    }
    .nav {
      top: 52px; /* デスクトップビューでのヘッダーの高さに合わせる */
    }
    .main-title {
        font-size: 10px;
    }
  }

/* ビューポートの幅が631px以上1279px以下の場合 */
@media (min-width: 631px) and (max-width: 1279px) {
    header {
        /* ヘッダーの高さを動的に調整 */
        height: 60px;
    }
    
    main {
        padding-top: 60px;
    }
    .logo img {
        /* ロゴの高さを動的に調整 */
        height:40px;
    }
    .nav {
        top: 60px; /* デスクトップビューでのヘッダーの高さに合わせる */
    }
    .main-title {
        font-size: 11px;
    }
}
@media (min-width: 1280px) {
    header {
        /* ヘッダーの高さを動的に調整 */
        height: 60px;
    }
    header .logo {
        left: 5%;
        top: 14px; 
      }
    
    main {
        padding-top: 60px;
    }
    .logo img {
        /* ロゴの高さを動的に調整 */
        height:45px;
    }
    .nav {
        top: 60px; /* デスクトップビューでのヘッダーの高さに合わせる */
    }
    .main-title {
        font-size: 11px;
        margin-left: 4%;
    }
    
}
  
  /* ビューポートの幅が1920px以上の場合 */
  /* @media (min-width: 1920px) {
    header {
      height: 80px;
      margin-left: 1920;
    }
    main {
      padding-top: 80px;
  }
    .logo img {
      height: 65px; 
    }
    header .logo {
        left: 10%;
        top: 14px; 
      }
.main-title {
        font-size: 11.5px;
        margin-left: 5%;
    }
  } */
  /* ヘッダー終了 */

  .header-container {
    display: flex; /* フレックスボックスを使用して子要素を配置します */
    flex-direction: column; /* 子要素を縦に並べます */
}

.logo-menu {
    display: flex; /* フレックスボックスを使用して子要素を配置します */
    justify-content: space-between; /* 子要素の間にスペースを均等に配置します */
    width: 100%; /* コンテナの幅を100%に設定します */
    align-items: center; /* 子要素を縦方向に中央揃えにします */
}

.logo {
    flex: 1; /* コンテナ内でロゴが利用するスペースを設定します（他のflex要素と同じ比率でスペースを分け合います） */
}

.menu-text {
    font-size: 9px; /* テキストのサイズを調整 */
    color: #333; /* テキストの色を設定 */
    text-align: center;
}
@media (min-width: 960px) {    
.menu-text {
    font-size: 12px; /* テキストのサイズを調整 */
    color: #333; /* テキストの色を設定 */
    text-align: center;
}
}

/* 1280px以上のビューポートのスタイル */
@media (min-width: 1280px) {
    header {
        display: flex;
        align-items: center; /* 上下中央揃え */
        justify-content: space-between; /* 要素を両端に配置 */
        height: 68px; /* ヘッダーの高さ */
        padding: 0px; /* 左右にパディングを追加 */
    }
    main {
        padding-top: 68px;
    }
    .main-title {
        margin-top: 6px;
      }
    .logo img {
        /* ロゴの高さを動的に調整 */
        height:42px;
    }
    .logo {
      visibility: visible; /* ロゴを表示 */
      flex: 0 0 auto; /* ロゴのサイズが内容に基づいて決まるように */
      margin-left: 3%;
    }
    .nav {
        visibility: visible; /* ナビゲーションを表示 */
        display: flex; /* ナビゲーションメニューを横一列に配置 */
        align-items: center; /* 上下中央揃え */
        top: 0; /* ヘッダーの高さに合わせる */
        position: relative; /* 相対位置に変更 */
    }
    .nav .menu-item {
        list-style: none; /* リストのスタイルをなくす */
        display: flex;
        padding: 0 22px;
    }
    .nav .menu-item .list a {
        text-decoration: none;
        color: #333; /* リンクの色 */
        font-size: 11px;
    }
    .menu-toggle {
        display: none; /* ハンバーガーメニューを非表示にする */
    }
    .list img {
        display: none;
    }
    /* サブメニューの初期状態を非表示に */
    .menu-list {
        display: none;
        position: absolute; /* 親要素に対して絶対位置に配置 */
        background-color: #e7dfc8;
        z-index: 1; /* 他の要素より前面に表示 */
        margin-top: 70px;
    }

    /* 親メニューにホバーしたときにサブメニューを表示 */
    .list.cure-menu:hover .menu-list {
        display: block;
    }

    /* サブメニューのスタイル */
    .nav .menu-item .cure-menu .menu-list .list {
        margin: 0; /* サブメニューの左マージンをリセット */
    }
    .menu-list .list {
        white-space: nowrap; /* テキストが折り返されないようにする */
        font-size: 14px; /* フォントサイズを調整 */
        border-bottom: 1px solid #f1e9da; /* 下に1pxの線を追加 */
    }

    /* サブメニューのリンクのスタイル */
    .nav .menu-item .menu-list .list a {
        color: #333; /* リンクの色を設定 */
        text-decoration: none; /* テキストの装飾をなしにする */
        padding: 14px 18px; /* パディングを追加して要素の大きさを調整 */
        display: block; /* ブロック要素として表示 */
        width: 100%; /* 幅を100%に設定 */
        height: 100%; /* 高さを100%に設定 */
        box-sizing: border-box; /* パディングとボーダーを含めてサイズを計算 */
    }

    .menu-list .list a:hover {
        background-color: #f1efde; /* ホバー時の背景色を設定 */
    }
    /* 親メニューの位置を相対位置に設定 */
    .list.cure-menu {
        position: relative;
    }
    .show-sp {
        display: none;
    }
}
@media (min-width: 1500px) {
    header {
        height: 68px; /* ヘッダーの高さ */
        padding: 0 10px; /* 左右にパディングを追加 */
    }
    main {
        padding-top: 68px;
    }
    .logo img {
        /* ロゴの高さを動的に調整 */
        height:42px;
    }
    .nav .menu-item .list a {
        font-size: 13px;
    }
}
@media (min-width: 1800px) {
    header {
        height: 68px; /* ヘッダーの高さ */
        padding: 0 30px; /* 左右にパディングを追加 */
    }
    main {
        padding-top: 68px;
    }
    .logo img {
        /* ロゴの高さを動的に調整 */
        height:44px;
    }
    .nav .menu-item .list a {
        font-size: 15px;
    }
}

/* ... existing styles ... */
.image-box-container-flex {
    display: flex;
    justify-content: space-between;
    gap: 0px 4px;
  }
  .image-box-container-flex .image-box {
    flex: 1;
  }
  /* ... existing styles ... */



  /* ... ジュエリー×マウスピース矯正 ... */

  .image-gallery2 {
    display: flex; /* フレックスボックスを使用して要素を横並びにする */
    justify-content: space-between; /* 各要素の間に均等なスペースを配置 */
    margin: 0; /* 余白を0に設定 */
    padding: 0; /* 余白を0に設定、ただし次のスタイルで上書きされます */
  }

  .image-container {
    flex: 1; /* フレックスアイテムが利用可能なスペースを均等に占めるように設定 */
    padding: 3px; /* 左右に3pxのパディングを追加 */
    margin: 0; /* 余白を0に設定 */
  }


/* ↓症例紹介ページ */
.treatment-cases-container {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* Breadcrumb styles */
.breadcrumb-list {
    display: flex;
    align-items: center;
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.breadcrumb-item {
    display: flex;
    align-items: center;
    color: #565656;
}

.breadcrumb-link {
    color: #666666;
    text-decoration: none;
}

.breadcrumb-link:hover {
    color: #333333;
}

.breadcrumb-separator {
    margin: 0 0.5rem;
    color: #666666;
}

/* Page title */
.page-title {
    font-weight: bold;
    text-align: center;
    margin-bottom: 1.8rem;
    color: #313131;
}

/* Category section */
.treatment-cases-section {
    max-width: 48rem;
    margin: 0 auto;
}

.treatment-cases-title {
    font-size: 1.2rem;
    text-align: center;
    margin-bottom: 1rem;
}

.treatment-cases-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding: 1rem;
}

@media (min-width: 640px) {
    .treatment-cases-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .treatment-cases-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}
.treatment-case-content {
    padding: 0.6rem 1rem;
}

/* Responsive */
@media (max-width: 560px) {

    .treatment-cases-grid {
        grid-template-columns: repeat(2, 1fr);
        padding: 0;
    }

    .treatment-case-content {
        padding: 0.3rem 0.5rem;
    }
}

.category-button {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    border-radius: 9999px;
    border: 1px solid #e5e7eb;
    background: white;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    color: inherit;
}


.category-button.active {
    background: linear-gradient(to right,  #7ac7d8, #a8c1e6);
    color: white;
    border: none;
}

.category-button:not(.active):hover {
    background-color: #f9fafb;
}

.category-button-2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    border-radius: 9999px;
    border: 1px solid #e5e7eb;
    background: white;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    color: inherit;
}
.category-button-2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    border-radius: 9999px;
    border: 1px solid #e5e7eb;
    background: white;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    color: inherit;
}

.category-button-2.active {
    background: linear-gradient(to right,  #7ac7d8, #a8c1e6);
    color: white;
    border: none;
}

.category-button-2:not(.active):hover {
    background-color: #f9fafb;
}


.category-name {
    font-size: 0.8rem;
    font-weight: 500;
}

.category-description {
    font-size: 0.5rem;
    opacity: 0.9;
}
@media (min-width: 380px) {
    .category-description {
        font-size: 0.5rem;
    }
}
@media (min-width: 600px) {
    .category-description {
        font-size: 0.7rem;
    }
    .category-button {
        min-height: 44px;
    }
}


/* Selected category */
.selected-category {
    text-align: center;
    margin: 0.8rem 0 0.6rem;
}

.selected-category-name {
    font-weight: 500;
    display: inline-block;
}

.selected-category-underline {
    width: 3rem;
    height: 1px;
    background-color: rgb(0, 109, 168);
    margin: 0.3rem auto 0;
}
/* お悩み別セクション - 修正版タブスタイル */
.concerns-section {
    max-width: 48rem;
    margin: 3rem auto 0;
}

.concerns-title {
    font-size: 1.2rem;
    text-align: center;
    margin-bottom: 0.6rem;
}

.concerns-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem;
}

.concern-button {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    color: #666;
}

.concern-button.active {
    color: #4a8eaa;
    border-color: #7ac7d8;
    background-color: #f0f7fa;
}

.concern-button:hover {
    color: #4a8eaa;
    border-color: #a8c1e6;
    background-color: #f0f7fa;
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.concern-name {
    font-size: 0.95rem;
    font-weight: 500;
}

@media (max-width: 640px) {
    .concern-button {
        padding: 0.5rem 1rem;
        font-size: 0.85rem;
    }
    
    .concerns-grid {
        padding: 0;
    }
}
/* Case card */
.treatment-case-card {
    background: white;
    border-radius: 0.5rem;
    border: 1px solid #e5e7eb;
    margin-bottom: 2rem;
}

.treatment-case-card-0 {
    background: white;
    border-radius: 0.5rem;
    border: 1px solid #e5e7eb;
}

.treatment-case-header {
    
    border-bottom: 1px solid #e5e7eb;
    position: relative;
}

.treatment-case-category {
    display: inline-block;
    padding: 0.25rem 1rem;
    background: linear-gradient(135deg, rgb(189 151 162), rgb(189 123 141));
    color: white;
    font-size: 14px;
    font-weight: 550;
    border-bottom-right-radius: 0.375rem;
    top: 0;
    left: 0;
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.1);
    text-shadow: 
        -1px -1px 0 rgba(55, 55, 55, 0.1),
        1px -1px 0 rgba(55, 55, 55, 0.1),
        -1px 1px 0 rgba(55, 55, 55, 0.1),
        1px 1px 0 rgba(55, 55, 55, 0.1),
        1px 1px 2px rgba(55, 55, 55, 0.1);
}

.treatment-case-category-mintblue{
    display: inline-block;
    padding: 0.25rem 1rem;
    background: linear-gradient(45deg, #6fbab3, #3db9ad);
    color: white;
    font-size: 14px;
    font-weight: 550;
    border-bottom-right-radius: 0.375rem;
    top: 0;
    left: 0;
    box-shadow: 0 2px 8px rgba(55, 55, 55, 0.1);
    text-shadow: 
        -1px -1px 0 rgba(55, 55, 55, 0.1),
        1px -1px 0 rgba(55, 55, 55, 0.1),
        -1px 1px 0 rgba(55, 55, 55, 0.1),
        1px 1px 0 rgba(55, 55, 55, 0.1),
        1px 1px 2px rgba(55, 55, 55, 0.1);
}


.treatment-case-title {
    font-size: 14px;
    font-weight: 500;
    color: #333333;
    padding: 0.15rem 1rem;
}



/* Before/After images */
.before-after {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.4rem;
}

.before,
.after {
    width: 50%;
    position: relative;
}

.before img,
.after img {
    width: 100%;
    height: auto;
    display: block;  
}
.image-label {
    width: 100%;
    padding: 0.1rem;
    text-align: center;
    color: white;
    font-size: 13px;
    font-weight: 550;
    letter-spacing: 0.05em; /* テキストの感覚、少し開けたい */
}

.before-label {
    background-color: rgba(107, 114, 128, 0.7);
}

.after-label {
    background: linear-gradient(to right, rgba(197, 160, 94, 0.8), rgba(218, 193, 124, 0.8));
}







/* 画像2つ横並び */
.image-row {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .image-item {
    width: calc(50% - 8px);
    text-align: center;
  }
  
  .image-item picture {
    display: block;
    width: 100%;
  }
  
  .image-item img {
    width: 100%;
    height: auto;
    display: block;
  }
  
  .image-caption {
    margin-top: 8px;
    color: #242424;
  }

/* Case details */
.case-details {
    padding: 0 0.25rem;
}

.case-description {
    font-size: 10.5px;
    line-height: 1.5;
    margin-bottom: 0.3rem;
}

.section {
    margin: 0.1rem 0;
}

.section-title {
    font-size: 9.5px;
    font-weight: 500;
}

.treatment-list {
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 0.875rem;
}

.separator {
    border: 0;
    border-top: 1px solid #e5e7eb;
    margin: 0 0;
}

.details-link {
    display: inline-block;
    color: #4a8eaa;
    text-decoration: none;
    font-size: 0.8rem;
    transition: color 0.2s;
}

.details-link:hover {
    color: #31667d;;
}

.lightblue-link {
    display: inline-block;
    color: #4a8eaa;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.lightblue-link:hover {
    color: #31667d;;
}




.blue-link {
    display: inline-block;
    color: blue;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.blue-link:hover {
    color: #0056b3;
}

.blue-link-1 {
    display: inline-block;
    color: blue;
    font-size: 1rem;
    text-decoration: none;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.blue-link:hover {
    color: #0056b3;
}

.blue-link-2 {
    display: inline-block;
    color: rgb(0, 53, 226);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.blue-link-2:hover {
    color: #0056b3;
}

.darkblue-link {
    display: inline-block;
    color: rgb(0, 0, 137);
    text-decoration: none;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.darkblue-link:hover {
    color: rgb(0, 0, 100);
}

.lightblue-link-free {
    display: inline-block;
    color: #4a8eaa;
    text-decoration: none;
    transition: color 0.2s;
}

.lightblue-link:hover {
    color: #31667d;;
}

.lightblue-link-8 {
    display: inline-block;
    color: #4a8eaa;
    text-decoration: none;
    font-size: 0.8rem;
    transition: color 0.2s;
    text-decoration: underline; 
    text-underline-offset:2px;
}

.lightblue-link-8:hover {
    color: #31667d;;
}

@media (min-width: 768px) {
    .treatment-case-category {
        font-size: 18px;
    }
    .treatment-case-category-mintblue {
        font-size: 18px;
    }
    .treatment-case-title {
        font-size: 19px;
        padding: 0.6rem 1rem;
    }
    .image-label {
        font-size: 14px;
    }
    .case-description {
        font-size: 13px;
        margin-bottom: 0.2rem;
    }
    .section-title {
        font-size: 13px;
    }
    .treatment-case-card {
        margin-bottom: 3rem;
    }
    .details-link {
        font-size: 1rem;
    }
    .lightblue-link {
        font-size: 1.05rem;
    }
    .lightblue-link-8 {
        font-size: 0.9rem;
    }
}

/* タブ機能のために追加したCSS */
.treatment-case-card.hidden {
    display: none !important;
  }
.treatment-case-card-0.hidden {
    display: none !important;
  }
/* ↑症例紹介ページ */


/* ↓スライダー機能のスタイル */
/* Slider wrapper with navigation */
.slider-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 0 auto;
}

/* Slider container */
.slider-container {
  position: relative;
  overflow: hidden;
  width: 100%;
}

/* Slider items */
.slider-item {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.slider-item.active {
  display: block;
  opacity: 1;
}

/* Navigation buttons */
.slider-nav {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid #7ac7d8;
  background: white;
  color: #7ac7d8;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  z-index: 10;
}

.slider-nav:hover {
  background: linear-gradient(to right, #7ac7d8, #a8c1e6);
  color: white;
  border-color: transparent;
  transform: scale(1.1);
}

.slider-nav:active {
  transform: scale(0.95);
}

.slider-nav svg {
  width: 24px;
  height: 24px;
}

/* Pagination dots */
.slider-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

.pagination-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: #d1d5db;
  cursor: pointer;
  transition: all 0.3s;
  padding: 0;
}

.pagination-dot:hover {
  background: #9ca3af;
  transform: scale(1.2);
}

.pagination-dot.active {
  background: linear-gradient(to right, #7ac7d8, #a8c1e6);
  width: 12px;
  height: 12px;
}

/* Responsive adjustments */
@media (max-width: 640px) {
  .slider-nav {
    width: 36px;
    height: 36px;
  }

  .slider-nav svg {
    width: 20px;
    height: 20px;
  }

  .slider-wrapper {
    gap: 0.5rem;
  }

  .pagination-dot {
    width: 8px;
    height: 8px;
  }

  .pagination-dot.active {
    width: 10px;
    height: 10px;
  }
}
/* ↑スライダー機能のスタイル */



/* ↓i：注意書きテキストデザイン */
.notice {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    background-color: rgb(243 243 243 / 80%);
    padding: 0.6rem 1rem 1.2rem;
    border-radius: 0.5rem;
    margin: 0 auto;
  }
  
  .notice-icon {
    flex-shrink: 0;
    padding-top: 3px;
    color: #3179ec;
    display: flex; /* 追加：アイコンの配置を制御 */
    align-items: center; /* 追加：アイコンの配置を制御 */
    justify-content: center; /* 追加：アイコンの配置を制御 */
  }
@media (min-width: 769px) {
  .notice-icon {
    padding-top: 18.8px;
  }
}  
  .notice-content {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
  }
  
  
  .notice-text {
    color: #2e353e;
  }


  .notice-red {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    background-color: #fff9f8cc;
    padding: 0.8rem 0.5rem 0.8rem;
    border-radius: 0.5rem;
    margin: 0 auto;
    border: 1px solid #efc8c3; /* 縁を追加 */
  }
  
  .notice-icon-red {
    flex-shrink: 0;
    padding-top: 3px;
    color: #ea6c5b;
    display: flex; /* 追加：アイコンの配置を制御 */
    align-items: center; /* 追加：アイコンの配置を制御 */
    justify-content: center; /* 追加：アイコンの配置を制御 */
  }
@media (min-width: 769px) {
  .notice-icon-red {
    padding-top: 5px;
  }
}  
  .notice-content {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
  }

/* ↑i：注意書きテキストデザイン */

/* 画像のスタイル */
.image-container img {
    width: 100%; /* 画像の横幅を親要素の幅に合わせる */
    height: auto; /* 縦のサイズを自動調整してアスペクト比を保持 */
    display: block;
}
.image-container {
    width: calc(30% - 10px); /* 3列のレイアウト、ギャップを引いた値 */
    box-sizing: border-box; /* ボーダーやパディングを幅と高さに含める */
    text-align: center; /* テキスト中央揃え */
}
.image-container img {
    width: 100%; /* 幅を100%に設定 */
    height: auto; /* 高さを自動調整 */
    object-fit: cover; /* コンテナに合わせて調整 */
    display: block;
  }

@media (max-width: 600px) {
    .image-container {
      width: 100%;
    }
}

/* 画像コンテナ内の要素のスタイル（共通） */
.image-container {
    text-align: center; /* テキストを中央揃えに設定 */
}
  

  /* ... ジュエリー×マウスピース矯正 ... */










/* ここでh1のスタイルだった部分をクラスに置き換え */
.flow-title {
    text-align: center;
    margin-bottom: 40px;
    color: #333;
    font-size: 24px;
    position: relative;
}

.flow-title::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 2px;
    background: linear-gradient(135deg, #4299e1, #3182ce);
}

.step {
    background: white;
    border-radius: 5px;
    padding: 15px;
    margin-bottom: 15px;
    position: relative;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.step-header {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
    gap: 12px;
}

.step-number {
    background: linear-gradient(135deg, rgb(227 193 202), rgb(208 151 168));
    color: white;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(66, 153, 225, 0.2);
}

.label {
    font-size: 13px;
    font-weight: 500;
    opacity: 0.9;
    letter-spacing: 0.5px;
}

.number {
    font-size: 28px;
    font-weight: bold;
    line-height: 1;
}

.step-title {
    font-size: 18px;
    margin: 0;
    color: #333333;
    font-weight: 600;
    letter-spacing: 0.3px;
}

.step-description {
    margin: 0 0 15px;
    color: #414141;
    font-size: 15px;
}

@media (max-width: 600px) {
    .step-number {
        width: 44px; /* 70px * 0.7 */
        height: 44px; /* 70px * 0.7 */
    }

    .label {
        font-size: 9px; /* 13px * 0.7 */
    }

    .number {
        font-size: 16px;
    }

    .step-title {
        font-size: 15px; 
    }

    .step-description {
        font-size: 14px;
        margin: 0 5px 5px;
    }
}

.illustration {
    height: 250px;
    background: #F8FBFD;
    border-radius: 8px;
    position: relative;
    overflow: hidden;
}

.scene {
    position: relative;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
}

.arrow {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 26px 35px 0 35px;
    border-color: rgb(220, 183, 194) transparent transparent;
    position: absolute;
    bottom: -21px;
    left: 50%;
    transform: translateX(-50%);
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1));
    z-index: 1; /* Add z-index to ensure arrow appears above next step */
}

.arrow-2 {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 21px 38px 0 38px;
    border-color: #addbed transparent transparent transparent;
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1));
    margin: 6px 0 4px 0;
}

@media (min-width: 480px) {

.arrow-2 {
    border-width: 28px 56px 0 56px;
    margin: 10px 0 8px 0;
}
}

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

@media (min-width: 768px) {
    .step {
        padding: 20px 30px;
        margin-bottom: 25px;
    }

    .counseling-desk {
        width: 350px;
    }

    .tablet {
        width: 320px;
        height: 220px;
    }

    .step-title {
        font-size: 20px;
    }

    .step-description {
        font-size: 16px;
    }
    .arrow {
        border-width: 40px 50px 0 50px;
        bottom: -33px;
    }
}




 /* 診療時間表専用のスタイル */
 .hour-container {
    width: 100%;
    background-color: white;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    overflow: hidden;
  }

  .hour-content {
  }

  .hour-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed;
  }

  .hour-table th {
    text-align: left;
    font-weight: 500;
    color: #202020;
    padding: 12px 16px;
    border-bottom: 1px solid #f5efcf;
    letter-spacing: 0.05em;
    background-color: rgba(202, 187, 116, 0.24);
  }

  .hour-table td {
    padding: 16px;
    border-bottom: 1px solid #f5efcf;
    text-align: left;
  }

  .hour-table tr:last-child td {
    border-bottom: none;
  }

  .hour-day-label {
    display: inline-block;
    font-weight: 500;
    color: #202020;
  }

  .hour-time-cell {
    color: #202020;
  }
  /* 休診日と予約ボタンのコンテナ */
  .hour-bottom-section {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
  }
  .hour-holiday-info {
    border-radius: 8px;
    padding: 0px 10px;
    margin-bottom: 20px;
  }

  /* 休診日のアイコンと文字の高さも揃える */
  .hour-holiday-title-wrapper {
    display: flex;
    align-items: center;
    height: 24px; /* 診療時間と同じ高さに統一 */
  }

  .hour-holiday-icon {
    width: 20px;
    height: 20px; 
    color: #e7da9d;
    margin-right: 12px; 
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hour-holiday-title {
    font-weight: 600;
    color: #484848;
    line-height: 1; /* 行の高さを調整して完全に中央揃えにする */
    display: flex;
    align-items: center;
    height: 100%; /* 親要素の高さに合わせる */
  }
  .hour-holiday-text {
    color: #202020;
  }

  .hour-cta-container {
    display: flex;
    justify-content: center;
  }
  /* レスポンシブ対応 */
  @media (max-width: 600px) {
    .hour-content {
      }
  
    .hour-table th, .hour-table td {
      padding: 10px 0 10px 15px;
    }
    
    .hour-title-icon, .hour-holiday-icon {
      width: 20px;
      height: 20px;
      margin-right: 8px;
    }

    .hour-holiday-title-wrapper {
      height: 20px; /* モバイル用にアイコンと同じ高さに調整 */
    }
    
    .hour-table {
      width: 100%;
    }
    
    .hour-table th:first-child,
    .hour-table td:first-child {
      width: 33%;
    }
    
    .hour-table th:nth-child(2),
    .hour-table td:nth-child(2) {
      width: 67%;
    }
  }
  @media (min-width: 600px) {
    .hour-bottom-section {
      flex-direction: row;
      align-items: center;
    }

    .hour-holiday-info {
      width: 45%;
    }

    .hour-cta-container {
      width: 55%;
      display: flex;
      justify-content: flex-start;
      padding-left: 10%;
    }
  }














.nav-divider {
    height: 1px;
    background-color: #d1d5db;
    width: 100%;
    margin: 0.25rem 0;
}
.nav-divider-05 {
    height: 0.5px;
    background-color: #d0d0d0;
    width: 100%;
}

/* コンテンツセクション */
.content-container {
    max-width: 48rem;
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
}

.content-section {
    scroll-margin-top: 4rem;
}

.content-card {
    background-color: white;
    border-radius: 0.75rem;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    border: 2px solid #eaf2ff;

    overflow: hidden;
    padding: 6px 8px;
}


.content-header {
    padding: 6px 0;
}

@media (min-width: 640px) {
    .content-card {
    padding: 12px 20px;
    }
    .content-header {
        padding: 12px 0;
    }
}

.content-header h2 {
    color: rgb(83, 83, 83);
    font-size: 16px;
    font-weight: 700;
    margin: 0;
}

@media (min-width: 640px) {
    .content-header h2 {
        font-size: 20px;
    }
}



.content-text p {
    color: #242a33;
}

.title-lightblue {
    color: #809ac4;
    position: relative;
    padding-bottom: 4px;
    letter-spacing: 0.05em;
}
.title-lightblue-line {
    /* テキストスタイル */
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #00A7CE;
    position: relative;
    display: inline-block;
    padding-bottom: 3px;
  }
  
  /* 下線の装飾 */
  .title-lightblue-line::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1.6px;
    background: linear-gradient(
      to right,
      rgba(106, 141, 216, 0.2),
      rgba(106, 192, 216, 0.8),
      rgba(106, 141, 216, 0.2)
    );
  }


  .title-lightblue-line-2 {
    /* テキストスタイル */
    color: #00A7CE;
    font-weight: 600;
    position: relative;
    display: inline-block;
    padding-bottom: 5px;
  }
  
  .title-lightblue-line-2::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 180px;
    height: 2px;
    background: linear-gradient(to right, #03a5cabd, transparent);
  }

  .numbering-gold {
    font-family: 'Meiryo', 'メイリオ', sans-serif;
    font-size: 17px;
    font-weight: bold;
    color: #2C3E50;
    letter-spacing: 0.05em;
    display: flex;
    align-items: center;
    gap: 12px;
}

.numbering-gold::before {
    content: attr(data-number);
    display: inline-block;
    font-size: 13px;
    color: #C9A961;
    background: rgba(207, 186, 140, 0.1);
    padding: 4px 10px;
    border-radius: 4px;
    font-weight: bold;
}

.feature-section {
    text-align: center;
  }
  
  .feature-title {
    font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;
    font-size: 20px;
    font-weight: 600;
    color: #3e3e3e;
    letter-spacing: 0.04em;
    margin: 0;
    line-height: 1.4;
  }


  .feature-title-6 {
    font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;
    font-size: 20px;
    font-weight: 600;
    color: #3e3e3e;
    letter-spacing: 0.06em;
    margin: 0;
    line-height: 1.4;
  }

  .feature-title-18 {
    font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;
    font-size: 18px;
    font-weight: 600;
    color: #3e3e3e;
    letter-spacing: 0.06em;
    margin: 0;
    line-height: 1.5;
  }

  .feature-title-21 {
    font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;
    font-size: 21px;
    font-weight: 600;
    color: #3e3e3e;
    letter-spacing: 0.06em;
    margin: 0;
    line-height: 1.4;
  }



  .feature-clinic {
    font-size: 13px;
    font-weight: 700;
    color: #383838;
    letter-spacing: 0.08em;
  }

  .feature-clinic-14 {
    font-size: 14px;
    font-weight: 550;
  }
  
  .feature-title .feature-gold {
    color: #927830;
    font-weight: 500;
    margin: 0 4px;
    font-size: 22px;
  }
  
  .feature-line {
    width: 64px;
    height: 1px;
    background-color: #927830;
    margin: 0px auto 0;
  }

  .feature-line-8 {
    width: 78px;
    height: 1px;
    background-color: #6ccac1;
    margin: 8px auto 0;
  }

  .feature-line-mintblue-8 {
    width: 78px;
    height: 1px;
    background-color: #089792;
    margin: 8px auto 0;
  }

  /* Tablet (768px~) */
  @media (min-width: 768px) {

    .feature-title {
        font-size: 26px;
        color: #414141;
        line-height: 1.3;
    }
    .feature-title-21 {
      font-size: 26px;
    }

    .feature-title .feature-clinic {
      font-size: 15px;
    }

    .feature-title .feature-gold {
      font-size: 34px;
      margin: 0 6px;
    }

    .feature-line {
      width: 80px;
      margin: 12px auto 0;
    }
    .feature-title-6 {
        font-size: 26px;
        line-height: 1.5;
      }
    
      .feature-title-18 {
        font-size: 24px;
        line-height: 1.5;
      }
      .feature-title-21 {
        font-size: 26px;
      }
  }

  /* Desktop (1024px~) */
  @media (min-width: 1024px) {

    .feature-title {
      font-size: 28px;
      line-height: 1.3;
    color: #414141;

    .feature-title-21 {
        font-size: 28px;
      }

    }
    .feature-title-6 {
        font-size: 28px;
      }
    
      .feature-title-18 {
        font-size: 26px;
      }

    .feature-title .feature-clinic {
      font-size: 20px;
    }

    .feature-title .feature-gold {
      font-size: 40px;
      margin: 0 8px;
    }

    .feature-line {
      width: 96px;
      margin: 16px auto 0;
    }
  }

/* ↑タイトルデザイン */

/* ↓リストデザイン */
.diamond-gold {
    list-style: none;
    padding: 16px 4px 8px;
}
  
.diamond-gold li {
    position: relative;
    padding-left: 16px;
    font-size: 14px;
    color: #212121;
    line-height: 1.6;
    margin-bottom: 10px;
}

.diamond-gold li::before {
    content: '◆';
    position: absolute;
    left: 0;
    top: 3px;
    color: #bfab7f;
    font-size: 10px;
}

.diamond-gold li .text-13-5 {
    font-size: 13.5px;
}

.diamond-gold li .text-13 {
    font-size: 13px;
}

.diamond-gold .sub-text-10 {
    font-size: 10px;
    color: #464646;
}
.diamond-gold .sub-text-11 {
    font-size: 11px;
    color: #464646;
}
.diamond-gold .sub-text-12 {
    font-size: 12px;
    color: #464646;
}
.diamond-gold .sub-text-14 {
    font-size: 14px;
    color: #464646;
    line-height: 3.0;
}

@media (min-width: 1150px) {
.diamond-gold li::before {
    font-size: 11px;
    top: 4px;
}
    .diamond-gold li {
        font-size: 15px;
        line-height: 1.8;
        padding-left: 18px;
      }
      .sub-text-11 {
        font-size: 13px;
      }


}
/* ↑リストデザイン */




/* 目次 */

.toc-001 {
    padding: 0.5em 0.5em 0.5em 2em;
    border: 1px solid #999;
    background-color: #f7f7f7;
    color: #333333;
}

.toc-001 div {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 5px 0;
}

.toc-001 div::before {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 5px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M8 4H21V6H8V4ZM3 3.5H6V6.5H3V3.5ZM3 10.5H6V13.5H3V10.5ZM3 17.5H6V20.5H3V17.5ZM8 11H21V13H8V11ZM8 18H21V20H8V18Z' fill='%23333'%3E%3C/path%3E%3C/svg%3E");
    content: '';
}

.toc-001 label::after {
    margin-left: 5px;
    font-size: .8em;
    color: #166c9d;
    content: "[開く]";
    cursor: pointer;
}

.toc-001:has(:checked) label::after {
    content: "[閉じる]";
}

.toc-001 input {
    display: none;
}

.toc-001 ol {
    list-style-type: decimal;
    margin: 0;
    padding: 0 1.2em;
    overflow: hidden;
}

.toc-001 > ol {
    height: 0;
}

.toc-001:has(:checked) > ol {
    height: auto;
}

.toc-001 ol ol {
    margin-top: 5px;
}

.toc-001 li {
    padding: 5px 0;
}

.toc-001 a {
    color: #166c9d;
}


.toc-002 {
    padding: 0.5em 0.5em 0.5em 1.5em;
    border: 1px solid #999;
    background-color: #f7f7f7;
    color: #333333;
}

.toc-002 div {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 5px 0;
}


.toc-002 ol {
    list-style-type: decimal;
    margin: 0;
    padding: 0 1.2em;
    overflow: hidden;
}

.toc-002 ol ol {
    margin-top: 5px;
}

.toc-002 li {
    padding: 5px 0;
}

.toc-002 a {
    color: #166c9d;
}


/* タイトルデザイン */
.border-left-title-mintblue {
    padding: .35em .7em;
    border-left: 5px solid #6cd5cb;;
    background: linear-gradient(135deg, #f9fcfc, #f6f7fab3);
    font-weight: 600;
    color: #086665;
} 

.border-left-title-mintblue-02 {
    padding: .35em .7em;
    border-left: 5px solid #6cd5cb;;
    background: #f3fafa;
    font-weight: 600;
    color: #3b3b3b;
} 


.border-left-title-lightblue-01 {
    padding: .35em .7em;
    border-left: 5px solid #31b7d6;
    background
    : linear-gradient(135deg, #f8fcfc, #f6f7fab3);
    color: #242424;
    font-weight: 600;
    color: #0090b0;
}   
.border-left-title-lightblue-02 {
    padding: .4em .7em;
    border-left: 5px solid #31b7d6;
    background
    : linear-gradient(135deg, #eefefe, #f4f8fd);
    color: #464646;
    font-weight: 600;
}   

.border-left-title-lightblue-07 {
    padding: .7em .7em;
    border-left: 5px solid #31b7d6;
    background
    : linear-gradient(135deg, #f8fcfc, #f6f7fa);
    color: #161616;
    font-weight: 600;
    color: #0090b0;
}   

.border-left-title-gold-01 {
    padding: .4em .7em;
    border-left: 5px solid #B99D6D;
    background
    : linear-gradient(135deg, #fbfbf4, #fefcf8);
    color: #363636;
    font-weight: 600;
}  

.title-lightblue-border {
    border-bottom: 3px solid #f2f2f2;
}

.title-lightblue-border span {
    display: inline-block;
    position: relative;
    padding: 0 .4em .2em;
    color: #393939;
    font-weight: 600;
}

.title-lightblue-border span::before {
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 2.5px;
    background-color: #38adc78d;
    content: '';
}

/* 共通デザイン（見た目はここで固定） */
.title-lightblue-underline {
  position: relative;
  border-bottom: 3px solid #f2f2f2;
  padding: 0 .4em .2em;
  color: #313131;
  font-weight: 600;
}

/* 水色ライン（共通） */
.title-lightblue-underline::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  height: 2.5px;
  background-color: #38adc78d;
  width: var(--accent-w, 220px); /* デフォルト180px */
}

@media (min-width: 768px) {
  .title-lightblue-underline::after {
    width: var(--accent-w-md, var(--accent-w, 260px));
  }
}

/* 末尾がpxのクラスで長さだけ変更 */
.title-lightblue-underline-100 { --accent-w: 100px; --accent-w-md: 140px; }
.title-lightblue-underline-120 { --accent-w: 120px; --accent-w-md: 160px; }
.title-lightblue-underline-140 { --accent-w: 140px; --accent-w-md: 180px; }
.title-lightblue-underline-160 { --accent-w: 160px; --accent-w-md: 200px; }
.title-lightblue-underline-180 { --accent-w: 180px; --accent-w-md: 220px; }
.title-lightblue-underline-200 { --accent-w: 200px; --accent-w-md: 240px; }
.title-lightblue-underline-220 { --accent-w: 220px; --accent-w-md: 260px; }
.title-lightblue-underline-240 { --accent-w: 240px; --accent-w-md: 280px; }
.title-lightblue-underline-260 { --accent-w: 260px; --accent-w-md: 300px; }
.title-lightblue-underline-280 { --accent-w: 280px; --accent-w-md: 320px; }
.title-lightblue-underline-300 { --accent-w: 300px; --accent-w-md: 340px; }
.title-lightblue-underline-320 { --accent-w: 320px; --accent-w-md: 360px; }
.title-lightblue-underline-340 { --accent-w: 340px; --accent-w-md: 380px; }
.title-lightblue-underline-360 { --accent-w: 360px; --accent-w-md: 400px; }


.title-lightblue-underline-2 {
  position: relative;
  border-bottom: 3px solid #f2f2f2;
  padding: 0.1em 0;
  color: #007c98;
  font-weight: 600;
}

/* 水色ライン（共通） */
.title-lightblue-underline-2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  height: 2.5px;
  background-color: #38adc78d;
  width: var(--accent-w, 220px); /* デフォルト180px */
}

@media (min-width: 768px) {
  .title-lightblue-underline-2::after {
    width: var(--accent-w-md, var(--accent-w, 260px));
  }
}

/* 末尾がpxのクラスで長さだけ変更 */
.title-lightblue-underline-2-100 { --accent-w: 100px; --accent-w-md: 140px; }
.title-lightblue-underline-2-120 { --accent-w: 120px; --accent-w-md: 160px; }
.title-lightblue-underline-2-140 { --accent-w: 140px; --accent-w-md: 180px; }
.title-lightblue-underline-2-160 { --accent-w: 160px; --accent-w-md: 200px; }
.title-lightblue-underline-2-180 { --accent-w: 180px; --accent-w-md: 220px; }
.title-lightblue-underline-2-200 { --accent-w: 200px; --accent-w-md: 240px; }
.title-lightblue-underline-2-220 { --accent-w: 220px; --accent-w-md: 260px; }
.title-lightblue-underline-2-240 { --accent-w: 240px; --accent-w-md: 280px; }
.title-lightblue-underline-2-260 { --accent-w: 260px; --accent-w-md: 300px; }
.title-lightblue-underline-2-280 { --accent-w: 280px; --accent-w-md: 320px; }
.title-lightblue-underline-2-300 { --accent-w: 300px; --accent-w-md: 340px; }
.title-lightblue-underline-2-320 { --accent-w: 320px; --accent-w-md: 360px; }
.title-lightblue-underline-2-340 { --accent-w: 340px; --accent-w-md: 380px; }
.title-lightblue-underline-2-360 { --accent-w: 360px; --accent-w-md: 400px; }


.title-lightblue-underline-2 {
  position: relative;
  border-bottom: 3px solid #f2f2f2;
  padding: 0.1em 0;
  color: #007c98;
  font-weight: 600;
}

/* 水色ライン（共通） */
.title-lightblue-underline-2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  height: 2.5px;
  background-color: #38adc78d;
  width: var(--accent-w, 220px); /* デフォルト180px */
}

@media (min-width: 768px) {
  .title-lightblue-underline-2::after {
    width: var(--accent-w-md, var(--accent-w, 260px));
  }
}

/* 末尾がpxのクラスで長さだけ変更 */
.title-lightblue-underline-2-100 { --accent-w: 100px; --accent-w-md: 140px; }
.title-lightblue-underline-2-120 { --accent-w: 120px; --accent-w-md: 160px; }
.title-lightblue-underline-2-140 { --accent-w: 140px; --accent-w-md: 180px; }
.title-lightblue-underline-2-160 { --accent-w: 160px; --accent-w-md: 200px; }
.title-lightblue-underline-2-180 { --accent-w: 180px; --accent-w-md: 220px; }
.title-lightblue-underline-2-200 { --accent-w: 200px; --accent-w-md: 240px; }
.title-lightblue-underline-2-220 { --accent-w: 220px; --accent-w-md: 260px; }
.title-lightblue-underline-2-240 { --accent-w: 240px; --accent-w-md: 280px; }
.title-lightblue-underline-2-260 { --accent-w: 260px; --accent-w-md: 300px; }
.title-lightblue-underline-2-280 { --accent-w: 280px; --accent-w-md: 320px; }
.title-lightblue-underline-2-300 { --accent-w: 300px; --accent-w-md: 340px; }
.title-lightblue-underline-2-320 { --accent-w: 320px; --accent-w-md: 360px; }
.title-lightblue-underline-2-340 { --accent-w: 340px; --accent-w-md: 380px; }
.title-lightblue-underline-2-360 { --accent-w: 360px; --accent-w-md: 400px; }

.title-mintblue-underline {
    position: relative;
    border-bottom: 3px solid #f2f2f2;
    padding: 0.1em 0;
    color: #077c79;
    font-weight: 600;
  }
  
  /* 水色ライン（共通） */
  .title-mintblue-underline::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 2px;
    background-color: #79d6ce;
    width: var(--accent-w, 220px); /* デフォルト180px */
  }
  
  @media (min-width: 768px) {
    .title-mintblue-underline::after {
      width: var(--accent-w-md, var(--accent-w, 260px));
    }
  }
  
  /* 末尾がpxのクラスで長さだけ変更 */
  .title-mintblue-underline-100 { --accent-w: 100px; --accent-w-md: 140px; }
  .title-mintblue-underline-120 { --accent-w: 120px; --accent-w-md: 160px; }
  .title-mintblue-underline-140 { --accent-w: 140px; --accent-w-md: 180px; }
  .title-mintblue-underline-160 { --accent-w: 160px; --accent-w-md: 200px; }
  .title-mintblue-underline-180 { --accent-w: 180px; --accent-w-md: 220px; }
  .title-mintblue-underline-200 { --accent-w: 200px; --accent-w-md: 240px; }
  .title-mintblue-underline-220 { --accent-w: 220px; --accent-w-md: 260px; }
  .title-mintblue-underline-240 { --accent-w: 240px; --accent-w-md: 280px; }
  .title-mintblue-underline-260 { --accent-w: 260px; --accent-w-md: 300px; }
  .title-mintblue-underline-280 { --accent-w: 280px; --accent-w-md: 320px; }
  .title-mintblue-underline-300 { --accent-w: 300px; --accent-w-md: 340px; }
  .title-mintblue-underline-320 { --accent-w: 320px; --accent-w-md: 360px; }
  .title-mintblue-underline-340 { --accent-w: 340px; --accent-w-md: 380px; }
  .title-mintblue-underline-360 { --accent-w: 360px; --accent-w-md: 400px; }


  .title-orange-underline {
    position: relative;
    border-bottom: 3px solid #f2f2f2;
    padding: 0.1em 0;
    color: #e9532a;
    font-weight: 600;
  }
  
  /* 水色ライン（共通） */
  .title-orange-underline::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 2px;
    background-color: #f98566;
    width: var(--accent-w, 220px); /* デフォルト180px */
  }

.title-lightblue-underline-diamond {
    position: relative;
    border-bottom: 3px solid #f2f2f2;
    padding: 0 .4em .2em 1.8em;
    color: #313131;
    font-weight: 600;
  }
  
  .title-lightblue-underline-diamond::before {
    content: "";
    position: absolute;
    left: 0.4em;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    width: 12px;
    height: 12px;
    background-color: #9ed8e5;
    border: 2px solid #b8e6f0;
  }
  
  .title-lightblue-underline-diamond::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 2.5px;
    background-color: #38adc78d;
    width: var(--accent-w, 220px);
  }


.treatment-heading {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: 0;
  }

  /* 内部要素のラッパー */
  .treatment-heading__content {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 24px 0; 
  }

  /* 番号部分のスタイル */
  .treatment-heading__number {
    font-size: 1.6rem;  
    color: rgba(48, 172, 255, 0.7); 
    letter-spacing: -0.025em; 
    line-height: 1;
    flex-shrink: 0;
    display: block;
  }

  /* テキスト部分のスタイル */
  .treatment-heading__text { 
    color: #334155; 
    letter-spacing: 0.025em; 
    flex: 1;
    display: block;
  }

  /* 下線のスタイル (spanに変更してh2内に配置) */
  .treatment-heading__bar {
    display: block;
    height: 3px; 
    width: 100%;
    background-color: #f1f5f9; 
    position: relative;
    margin-top: 4px; 
  }

  .treatment-heading__bar-fill {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 70%;
    background-color: #93c5fd; /* bg-blue-300相当 */
  }

  
/* タイトルデザイン ↑*/


/* ページオフセット */
#laminate-veneer {
    scroll-margin-top: 70px;
}

/* ↑ページオフセット */

/* パンくずリスト */
.breadcrumb-001 {
    display: flex;
    gap: 0 10px;
    list-style: none;
    padding: 0;
    font-size: .9em;
}

.breadcrumb-001 li {
    display: flex;
    align-items: center;
}

/* .breadcrumb-001 li:first-child::before {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 4px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 20C20 20.5523 19.5523 21 19 21H5C4.44772 21 4 20.5523 4 20V11L1 11L11.3273 1.6115C11.7087 1.26475 12.2913 1.26475 12.6727 1.6115L23 11L20 11V20ZM11 13V19H13V13H11Z' fill='%23525252'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    content: '';
} */

.breadcrumb-001 li:not(:last-child)::after {
    display: inline-block;
    transform: rotate(45deg);
    width: .3em;
    height: .3em;
    margin-left: 10px;
    border-top: 1px solid #525252;
    border-right: 1px solid #525252;
    content: '';
}

.breadcrumb-001 a {
    color: #525252;
    text-decoration: none;
}
/* ↑パンクズリスト */


mark {
    background: linear-gradient(transparent 70%, #ffee9a 80%);
    font-weight: bold;
    color: #3a3a3a;
  }

  /* 更新日 */
  .date-container {
    display: inline-flex;
    align-items: center;
    padding: 10px 8px;
    gap: 6px;
}

.clock-icon {
    width: 16px;
    height: 16px;
    color: #666666;
    flex-shrink: 0;
}

.date-text {
    color: #666666;
    font-size: 13px;
    font-weight: 400;
    white-space: nowrap;
    margin: 0;
    line-height: 1.2;
}

/* Responsive design */
@media (min-width: 600px) {
    .date-container {
        padding: 14px 14px;
    }
    
    .date-text {
        font-size: 15px;
    }
    
    .clock-icon {
        width: 18px;
        height: 18px;
    }
}
/* 更新日 ↑ */



/* 歯科医師紹介 */
.title-underline-lightblue {
    display: block;
    margin: 0 auto;
    width: fit-content;
    color: #333;
    border-bottom: 2px solid #7ac7d8;
}

.doctor-profile {
  background: white;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  overflow: hidden;
  border: 1px solid #e9e9e9;
}

.doctor-image {
  width: 100%;
  height: auto;
  max-height: 400px;
  overflow: hidden;
  position: relative;
}

.doctor-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.doctor-info {
  padding: 20px 10px;
}

@media (min-width: 600px) {
  .doctor-info {
    padding: 30px 25px;
  }
}

.doctor-header {
  display: flex;
  align-items: center;
}

.doctor-position {
  background: linear-gradient(135deg, #83cdc6, #41c7bb);
  color: white;
  padding: 5px 10px;
  border-radius: 20px;
  font-weight: 500;
  margin-right: 15px;
}

.doctor-name {
  font-weight: 600;
  color: #414141;
}

.doctor-background h4 {
  color: #414141;
}

.doctor-background ul {
  list-style-type: none;
  padding-left: 0;
}

.doctor-background li {
  margin-bottom: 5px;
  padding-left: 15px;
  position: relative;
  line-height: 1.6;
}

.doctor-background li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #83cdc6;
  font-size: 22px;
  line-height: 0.9; 
}

/* ↑歯科医師紹介 */



/* 基本情報 */
.basic-info-table {
    width: 100%;
    overflow-x: auto;
    border-collapse: collapse;
    table-layout: fixed; /* 列幅を固定 */
    border-radius: 8px;
    border: 1px solid #ddd; /* テーブル全体にボーダーを追加 */
}

.basic-info-table table {
    width: 100%;
    border-collapse: collapse;
    border-radius: 8px; /* テーブルにもborder-radiusを追加 */
    overflow: hidden; /* 角丸を適用するために必要 */
}

.basic-info-table th, .basic-info-table td {
    border: 1px solid #e9e9e9;
    padding: 8px;
    text-align: left;
    height: 50px; /* セルの高さを固定 */
}
.basic-info-table th {
    background-color: rgba(202, 187, 116, 0.24);
}

.basic-info-table th:nth-child(1), .basic-info-table td:nth-child(1) {
    width: 28%; /* 1列目の幅を60%に設定 */
}

.basic-info-table th:nth-child(2), .basic-info-table td:nth-child(2) {
    width: 72%; /* 2列目の幅を40%に設定 */
}


/* ↑基本情報 */

/* Info & Schedule 医院紹介ページ*/
.info-schedule-card { background: white; border-radius: 8px; padding: 15px; box-shadow: 0 2px 20px rgba(0,0,0,0.08); }
.info-table, .schedule-table { width: 100%; border-collapse: collapse; }
.info-table th, .info-table td, .schedule-table th, .schedule-table td { text-align: left; padding: 8px 4px; border-bottom: 1px solid #f0f0f0; vertical-align: top; }
.info-table th, .schedule-table th { font-weight: 500; width: 100px; }
.info-table a { color: #4a8d9e; text-decoration: none; font-weight: 500; }
.schedule-header { display: flex; align-items: center; }
.schedule-icon { width: 20px; height: 20px; margin-right: 10px; color: #4a8d9e; }
.schedule-title { font-weight: 500; }
.holiday-header { display: flex; align-items: center; }
.holiday-icon { width: 16px; height: 16px; margin-right: 8px; color:#4a8d9e; }

/* ↑Info & Schedule */

/*↓通院中割引の料金表示用スタイル */
.treatment-table {
    width: 100%;
    border-collapse: collapse;
    margin: 30px 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f0f0f0;
}

.treatment-table thead {
    background: linear-gradient(135deg, #c2e4eb, #cedef6);
}

.treatment-table th {
    padding: 20px 12px;
    text-align: center;
    border-right: 1px solid #e2e8f0;
    letter-spacing: 0.5px;
    font-weight: 600;
    color: #2d3748;
    white-space: nowrap;
}

.treatment-table th:last-child {
    border-right: none;
}

.treatment-table td {
    padding: 20px 16px;
    text-align: center;
    border-bottom: 1px solid #f5f5f5;
    border-right: 1px solid #e2e8f0;
    vertical-align: middle;
    line-height: 1.6;
}

.treatment-table td:last-child {
    border-right: none;
}

.treatment-table tbody tr:last-child td {
    border-bottom: none;
}

.treatment-table tbody tr:hover {
    background-color: #fafbfc;
    transition: background-color 0.2s ease;
}

/* 治療内容のセル */
.treatment-table td:first-child {
    text-align: left;
    font-weight: 500;
    color: #2d3748;
    font-size: 15px;
    padding-left: 20px;
    width: 40%;
}

/* 料金情報のセル */
.treatment-table td:nth-child(2),
.treatment-table td:nth-child(3) {
    text-align: center;
    padding: 20px 8px;
    width: 30%;
}

/* 割引バッジ */
.treatment-table .badge {
    background: linear-gradient(135deg, #e95e52, #f56565);
    color: white;
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 6px;
    font-weight: 600;
    display: inline-block;
    margin-bottom: 8px;
    box-shadow: 0 2px 4px rgba(233, 94, 82, 0.3);
}

/* 料金表示 */
.treatment-table .price-main {
    font-size: 18px;
    font-weight: 700;
    color: #1a202c;
    margin-bottom: 4px;
    letter-spacing: 0.5px;
}

.treatment-table {
    font-size: 13px;
    color: #718096;
    font-weight: 400;
}

.treatment-table .price-crossed-small {
    font-size: 13px;
    color: #a0aec0;
    text-decoration: line-through;
    margin-right: 8px;
    font-weight: 400;
}

.treatment-table .price-discounted {
    font-size: 18px;
    font-weight: 700;
    color: #e53e3e;
    letter-spacing: 0.5px;
}

/* 料金情報のコンテナ */
.treatment-table .price-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.treatment-table .discount-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.treatment-table .discount-info-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-bottom: 4px;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
    .treatment-table {
        margin: 20px 0;
        border-radius: 10px;
    }
    
    .treatment-table th {
        padding: 16px 8px;
        border-right: 1px solid #e2e8f0;
    }
    
    .treatment-table th:last-child {
        border-right: none;
    }
    
    .treatment-table td {
        padding: 16px 8px;
        border-right: 1px solid #e2e8f0;
    }
    
    .treatment-table td:last-child {
        border-right: none;
    }
    
    .treatment-table td:first-child {
        padding-left: 12px;
        font-size: 14px;
        width: 40%;
    }
    
    .treatment-table td:nth-child(2),
    .treatment-table td:nth-child(3) {
        padding: 16px 6px;
        width: 30%;
    }
    
    .treatment-table .price-main {
        font-size: 16px;
        padding-top: 30px;
    }
    
    .treatment-table .price-tax-small,
    .treatment-table .price-crossed-small {
        font-size: 12px;
    }
    
    .treatment-table .price-discounted {
        font-size: 16px;
    }
    
    .treatment-table .badge {
        font-size: 10px;
        padding: 3px 6px;
    }
}

@media (max-width: 480px) {
    .treatment-table {
        margin: 15px 0;
        border-radius: 8px;
    }
    
    .treatment-table th {
        padding: 14px 6px;
        border-right: 1px solid #e2e8f0;
    }
    
    .treatment-table th:last-child {
        border-right: none;
    }
    
    .treatment-table td {
        padding: 12px 6px;
        border-right: 1px solid #e2e8f0;
    }
    
    .treatment-table td:last-child {
        border-right: none;
    }
    
    .treatment-table td:first-child {
        padding-left: 8px;
        font-size: 13px;
    }
    
    .treatment-table td:nth-child(2),
    .treatment-table td:nth-child(3) {
        padding: 12px 4px;
    }
    
    .treatment-table .price-main {
        font-size: 15px;
    }
    
    .treatment-table .price-tax-small,
    .treatment-table .price-crossed-small {
        font-size: 11px;
    }
    
    .treatment-table .price-discounted {
        font-size: 15px;
    }
    
    .treatment-table .badge {
        font-size: 9px;
        padding: 2px 5px;
    }
}

/* テーブル形式の料金表示用スタイル */


/* Section */
.section-white { background: white; }
.section-beige { background: #f7f3e8; }
.section-title-divider { width: 45px; height: 1px; background-color: #4a8d9e; margin: 5px auto 0;}
.section-title-divider-200 { width:  100px; height: 1.2px; background-color: #4a8d9e; margin: 10px auto 0;}

/* ↑Section */




 /*ヘッダー */
        .header {
            padding: 12px 16px;
            text-align: center;
            background: linear-gradient(to bottom, #e8dcc0, #e2d6b2);
        }

        .header-text {
            font-size: 12px;
            color: #242930;
            margin-bottom: 4px;
            padding-top: 16px;
            text-align: center;
        }

 /*↑ヘッダー */

 /*グローバルナビゲーション 20250926*/

        .booking-button {
            width: auto;
            max-width: fit-content;
            background: linear-gradient(to right, #f472b6, #ec4899);
            color: white;
            font-weight: 500;
            padding: 12px 46px 12px 46px;
            margin: 0 auto 16px auto;
            border: none;
            cursor: pointer;
            display: block;
            align-items: center;
            justify-content: center;
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
            transition: all 0.3s ease;
            text-decoration: none;
            border-radius: 6px;
            text-align: center;
        }

        .booking-button:hover {
            background: linear-gradient(to right, #ec4899, #db2777);
        }

        .free-badge {
            background: white;
            color: #ec4899;
            padding: 5px 8px;
            font-size: 15px;
            font-weight: 600;
            border-radius: 2px;
            white-space: nowrap;
            margin-right: 4px;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.1);
        }

        .booking-text {
            font-weight: 700;
            font-size: 15px;
            white-space: nowrap;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
            line-height: 1;
        }

        .chevron-right {
            width: 16px;
            height: 16px;
            margin-left: 8px;
            vertical-align: middle;
        }

        .phone-section {
            text-align: center;
        }

        .phone-text {
            font-size: 12px;
            color: #242930;
        }

        .phone-container {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            margin-bottom: 16px;
        }

        .phone-icon {
            width: 21px;
            height: 21px;
        }

        .phone-number {
            font-size: 22px;
            font-weight: bold;
            color: #00a7ce;
            text-decoration: none;
        }

        /* Menu Sections */
        .menu-divider {
            border-top: 1.5px solid #bccfcd;
            background: #fffcf4;
        }

        .menu-item {
            backdrop-filter: blur(4px);
        }

        .menu-link {
            display: flex;
            align-items: center;
            justify-content: space-between;
            text-decoration: none;
            color: inherit;
            transition: background-color 0.2s;
        }

        .menu-link:hover {
            background: rgba(255, 255, 255, 0.5);
        }

        /* Other Menu Items */
        .other-menu-item {
            background: #fff9ea;
            backdrop-filter: blur(4px);
        }

        .other-menu-link {
            display: flex;
            align-items: center;
            text-decoration: none;
            color: inherit;
            transition: background-color 0.2s;
            padding: 14px 15px;
            margin: 0 2px;
        }

        .other-menu-link:hover {
            background: rgba(255, 255, 255, 0.5);
        }

        .other-menu-icon {
            margin-right: 12px;
            display: flex;
        }

        .other-menu-icon svg {
            vertical-align: middle;
            display: block;
        }

        .other-menu-text {
            color: #242b35;
            font-weight: 600;
            font-size: 15.5px;
            line-height: 1;
            display: flex;
            align-items: center;
        }
        @media screen and (min-width: 1280px) {

        .other-menu-text {
            font-size: 12px;
            color: #353b44;
            margin: 0;
        }
        .other-menu-link {
            padding: 0px 0px;
        }
        }
        .menu-content {
            display: flex;
            align-items: center;
        }

        .menu-icon {
            margin-right: 11px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .menu-icon img {
            vertical-align: middle;
            display: block;
        }

        .menu-text {
            font-weight: 600;
        }

        .chevron-down {
            width: 16px;
            height: 16px;
            color: #374151;
        }

        /* Treatment Grid */
        .treatment-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 0;
        }

        .treatment-item {
            background: #fffcf4;
            backdrop-filter: blur(4px);
            border-top: 1px solid #e8dcc0;
        }



        .treatment-link {
            display: block;
            padding: 7px 0px 7px 50px;
            text-decoration: none;
            color: inherit;
            transition: background-color 0.2s;
        }

        .treatment-link:hover {
            background: rgba(255, 255, 255, 0.5);
        }
        .treatment-label {
            font-size: 13.5px;
            color: #181a1e;
            font-weight: 550;
            letter-spacing: 0.5px;
        }
        .treatment-subtitle {
            font-size: 12.5px;
            color: #181a1e;
            line-height: 1.2;
            font-weight: 550;
        }

         /* 治療メニューリンクとトグルボタンのコンテナ */
         .menu-link-container {
             display: flex;
             align-items: center;
             justify-content: space-between;
             width: 100%;
         }

         .menu-link-container .menu-link {
             flex: 1;
             text-decoration: none;
             color: inherit;
             transition: background-color 0.2s;
             padding: 14px 15px;
         }

         .menu-link-container .menu-link:hover {
             background: rgba(255, 255, 255, 0.5);
         }

         /* トグルボタンのスタイル */
         .toggle-treatments-btn {
             background: none;
             border: none;
             cursor: pointer;
             display: flex;
             align-items: center;
             justify-content: center;
             transition: background-color 0.2s;
         }

         .toggle-treatments-btn:hover {
             background: rgba(255, 255, 255, 0.5);
         }

         .toggle-treatments-btn .chevron-down {
             transition: transform 0.3s ease;
             width: 20px;
             height: 20px;
             color: #374151;
         }

                  .toggle-treatments-btn.expanded .chevron-down {
             transform: rotate(180deg);
         }


         /* 1280px以上でシンプルな横並びレイアウトに変更 */
         @media screen and (min-width: 1280px) {
             .menu-item {
                 display: flex;
                 flex-direction: row;
                 flex-wrap: nowrap;
                 gap: 0;
                 padding: 0 10px;
                 align-items: stretch;
             }
             
             .nav .list {
                 flex: 1;
                 min-width: 0;
                 border: none;
                 margin: 0;
                 display: flex;
             }
             
             .nav .cure-menu {
                 position: relative;
             }
             
             .nav .header-item {
                 display: none;
             }
             
             .nav .menu-divider {
                 border: none;
                 background: white;
                 flex: 1;
             }
             
             .menu-link,
             .other-menu-link {
                 text-align: center;
                 justify-content: center;
                 background: white;
                 width: 100%;
                 display: flex;
                 align-items: center;
                 min-height: 60px;
             }
             
             .menu-link-container {
                 flex-direction: row; 
                 width: 100%;
                 display: flex;
                 align-items: stretch;
             }
             
             .menu-link-container .menu-link {
                 border: none;
                 flex: 1;
                 text-align: center;
                 justify-content: center;
             }
             
             .toggle-treatments-btn {
                 padding: 15px 12px;
                 background: white;
                 border: none;
                 flex: 0 0 auto;
                 display: flex;
                 align-items: center;
                 justify-content: center;
                 min-height: 60px;
             }
             
             .treatment-grid-item {
                 position: absolute;
                 top: 100%;
                 left: 0;
                 right: 0;
                 background: white;
                 border: 1px solid #e8dcc0;
                 border-radius: 8px;
                 box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
                 z-index: 1000;
                 opacity: 0;
                 visibility: hidden;
                 transform: translateY(-10px);
                 transition: all 0.3s ease;
                 display: block;
                 max-height: none !important;
                 overflow: visible !important;
             }
             
             /* .cure-menuまたはその子要素にホバーしたときに表示 */
             .nav .cure-menu:hover .treatment-grid-item,
             .nav .cure-menu .menu-link-container:hover ~ .treatment-grid-item,
             .nav .cure-menu .toggle-treatments-btn:hover ~ .treatment-grid-item,
             .nav .cure-menu .treatment-grid-item:hover {
                 opacity: 1 !important;
                 visibility: visible !important;
                 transform: translateY(0);
                 max-height: none !important;
                 overflow: visible !important;
                 display: block !important;
             }
            

             .nav .treatment-grid {
                 display: grid;
                 grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
                 gap: 0;
                 padding: 0;
             }
             
             .nav .treatment-item {
                 border: none;
                 border-right: 1px solid #e8dcc0;
                 border-bottom: 1px solid #e8dcc0;
                 background: white;
                 width: 340px;
             }
             
             .nav .treatment-link {
                 padding: 15px;
                 background: white;
             }
             
             .nav .other-menu-text {
                 font-size: 11.2px;
                 white-space: nowrap;
                 margin: 0;
             }
             
             .nav .menu-icon,
             .nav .menu-icon img,
             .nav .other-menu-icon,
             .nav .other-menu-icon img {
                 display: none !important;
             }
         }
         @media screen and (min-width: 1350px) {
            .nav .other-menu-text {
                font-size: 12px;
            }
         }

         @media screen and (min-width: 1550px) {
            nav.nav .other-menu-text {
                font-size: 12.5px;
            }
         }

        #treatment-grid {
          margin: 0;
          background: #fff;
          border: 1px solid #eee;
          box-shadow: 0 8px 24px rgba(0,0,0,.08);
        }

        /* グリッドの並び（お好みで） */
        @media (max-width: 1279px){
          #treatment-grid { 
            display: none;   /* ← 初期は閉じる */
          }
          #treatment-grid.is-open {
            display: grid;
          }
        }
      
        .pc-only { display: none; }

        @media (min-width: 1280px) {
          .pc-only { display: flex; }
          .pc-hide { display:none !important; }
        }
        @media (max-width:1279px){
          .nav { 
            padding-bottom: 150px; 
            overflow-y: auto;
            overflow-x: hidden;
        }
        }

 /*↑グローバルナビゲーション 20250926*/



   .features-container {
      max-width: 1200px;
      padding: 0 20px;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 10px;
      justify-items: center;
    }

    .feature-item {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 16px;
      text-align: center;
    }

    .icon-circle {
      width: 60px;
      height: 60px;
      border-radius: 50%;
      background: linear-gradient(135deg, #7ac7d8, #a8c1e6);
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 4px 12px rgba(122, 199, 216, 0.3);
    }

    .icon-circle svg {
      width: 35px;
      height: 35px;
      color: white;
    }

    .feature-text {
      font-size: 15px;
      font-weight: 600;
      background: linear-gradient(135deg, #368ea2, #7094ca);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      width: 130px;
    }

    @media (max-width: 550px) {
      /* Changed to 2x2 grid layout for mobile */
      .features-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
        padding: 0 30px;
      }

      .icon-circle {
        width: 48px;
        height: 48px;
      }

      .icon-circle svg {
        width: 24px;
        height: 24px;
      }

      .feature-text {
        font-size: 13px;
        width: 110px;
      }
      
      .feature-item {
        gap: 8px;
      }
    }

        @media (min-width: 551px) and (max-width: 768px) {
      /* Changed to 2x2 grid layout for mobile */
      .features-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 25px;
        padding: 0 60px;
      }

      .icon-circle {
        width: 55px;
        height: 55px;
      }

      .icon-circle svg {
        width: 28px;
        height: 28px;
      }

      .feature-text {
        font-size: 15px;
        width: 120px;
      }
      
      .feature-item {
        gap: 12px;
      }
    }

        /* ↓治療メニュートグル 20260126*/
/* トグルボタン */
.toggle-treatments-btn {
    background: none;
    border: none;
    border-left: 1px solid #e0e0e0;
    cursor: pointer;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

/* 塗りつぶし丸 +/- アイコン */
.toggle-treatments-btn .toggle-icon {
    position: relative;
    width: 28px;
    height: 28px;
    background-color: #c9a86c;
    border-radius: 50%;
    transition: all 0.3s ease;
}

.toggle-treatments-btn .toggle-icon::before,
.toggle-treatments-btn .toggle-icon::after {
    content: '';
    position: absolute;
    background-color: #fff;
    transition: all 0.3s ease;
}

/* 横線 */
.toggle-treatments-btn .toggle-icon::before {
    width: 14px;
    height: 2.5px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* 縦線 */
.toggle-treatments-btn .toggle-icon::after {
    width: 2.5px;
    height: 14px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* テキスト */
.toggle-treatments-btn .toggle-text {
    font-size: 13px;
    color: #8b7355;
    font-weight: 500;
    transition: all 0.3s ease;
    min-width: 100px;
    text-align: left;
}

/* 開いた時：− に変化（expanded に変更） */
.toggle-treatments-btn.expanded .toggle-icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
    opacity: 0;
}

/* 治療メニューグリッド */
#treatment-grid {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

#treatment-grid.is-open {
    max-height: 1000px;
}



        /* ↑治療メニュートグル 20260126*/


        /* サブメニュー */
        #treatment-grid {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease;
            background-color: #fffef8;
        }


        .submenu-item {
            padding: 14px 20px 14px 52px;
            border-top: 1px solid #f0e6d3;
            color: #555;
            font-size: 14px;
            cursor: pointer;
            transition: background-color 0.2s;
        }

        .submenu-item:hover {
            background-color: #fff8e8;
        }

     /* ↓治療メニュー紹介 */
  
      .menu-section-header {
        text-align: center;
      }
  
      .menu-section-subtitle {
        color: rgba(20, 20, 20, 0.9);
        line-height: 1.6;
      }
  
      .menu-treatment-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 2rem;
      }
  
      .menu-treatment-card {
        background: white;
        border: 1px solid #e5e5e5;
        border-radius: 0.5rem;
        overflow: hidden;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
      }
  
      .menu-card-header {
        padding: 0.8rem 1rem;
        border-bottom: 1px solid #e5e5e5;
      }
  

  
      .menu-card-content {
        padding: 0.6rem 0.6rem;
      }
  
      .menu-card-description {
        font-size: 1rem;
        color: rgba(15, 15, 15, 0.8);
        line-height: 1.6;
      }
  
      .menu-price-section {
        display: flex;
        align-items: baseline;
        gap: 0.5rem;
      }
  
      .menu-price {
        font-weight: 600;
        color: #614e37;
        font-size: 0.9rem;
      }
  
      .menu-period {
        font-size: 0.8rem;
        color: rgba(37, 37, 37, 0.9);
      }
  
      .menu-features-list {
        list-style: none;
     }
  
      .menu-features-list li {
        display: flex;
        align-items: start;
        gap: 0.4rem;
        margin-bottom: 0.5rem;
        font-size: 0.8rem;
        color: rgba(26, 26, 26, 0.95);
      }
  
      .menu-bullet {
        width: 0.375rem;
        height: 0.375rem;
        background-color: #00A7CE;
        border-radius: 50%;
        margin-top: 0.5rem;
        flex-shrink: 0;
      }
  
      .menu-card-button {
        width: 100%;
        padding: 0.625rem 1rem;
        background: transparent;
        border: 1px solid #e5e5e5;
        border-radius: 0.375rem;
        font-size: 0.875rem;
        font-weight: 500;
        color: #1a1a1a;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
        transition: background-color 0.2s, border-color 0.2s;
      }
  
      .menu-card-button:hover {
        background-color: #f5f5f5;
        border-color: #d4d4d4;
      }
  
      .menu-arrow-icon {
        width: 1rem;
        height: 1rem;
      }
  
      @media (min-width: 1024px) {
  
        .menu-treatment-grid {
          grid-template-columns: repeat(3, 1fr);
          gap: 0.9rem;
        }
      }

     /* ↑治療メニュー紹介 */
     .br-inline span {
        display: inline-block;
      }
      
      /* ↓チェックリスト */
      ul.check {
        padding: 0;
        list-style: none;
      }
      
      ul.check li {
        position: relative;
        padding-left: 22px;
        margin-bottom: 8px;
        line-height: 1.6;
      }
      
      ul.check li::before {
        content: "";
        position: absolute;
        top: 4px;
        left: 0;
        width: 12px;
        height: 8px;
        border-left: 3px solid #59a6e0d7;
        border-bottom: 3px solid #59a6e0d7;
        transform: rotate(-45deg);
      }

      /* ↑チェックリスト */


      /* ↓レスポンシブ非表示 */
      @media (min-width: 460px) {
        .display-none-600 {
            display: none;
        }
    }

      /* ↑レスポンシブ非表示 */
    
/* ↓ページ内目次 */
      .toc-tile{
        --line:#2ca4b487;
        display:grid;
        grid-template-columns:1fr 1fr;
        background:#fff;
      
        /* ここが「左右のパディングっぽい余白」を消す */
        margin-left:0;
        margin-right:0;
      }
      
      /* 1マス */
      .toc-item{
        position: relative;
        display:flex;
        align-items:center;
        justify-content:center;  /* 文字を中央 */
        text-align:center;
      
        padding:11px 44px 11px 14px; /* 右に矢印分の余白を確保 */
        text-decoration:none;
        color:#0f0f0f;
        font-weight:550;
        line-height:1.35;
      
        border-bottom:1px solid var(--line);
        background:#fafafa;
      }
      
      /* 左列だけ中央の縦線 */
      .toc-item:nth-child(2n+1){
        border-right:1px solid var(--line);
      }
      
      /* 右側に固定する矢印 */
      .toc-item::after{
        content:"";
        position:absolute;
        right:14px;            /* 右端からの距離 */
        top:50%;
        width:9px;
        height:9px;
        transform:translateY(-50%) rotate(45deg);
        border-right:2px solid #66b8c7;   /* SBCっぽく黒 */
        border-bottom:2px solid #66b8c7;
      }
      
      /* 余った1つを横幅100%に */
      .toc-item.is-full{
        grid-column:1 / -1;
        border-right:none;      /* 念のため */
      }
      /* 上の線を出す（1行目の2つ） */
      .toc-item:nth-child(1),
      .toc-item:nth-child(2){
        border-top:1px solid var(--line);
      }
      
      /* 余った1つが先頭行に来ることも一応ケア */
      .toc-item.is-full:first-child{
        border-top:1px solid var(--line);
      }
      
      
      @media (min-width:1080px){
        .toc-tile{
          display:flex;
          align-items:stretch;
          justify-content:center;
          gap:0;
          border:0;
        }
      
        .toc-item{
          flex:1 1 0;
          min-width:0;
          padding: 6px 10px;
      
          /* border:0 !important; ←これを消す */
          border:0; /* まず全部消す（important無し） */
        }
      
        /* 要素と要素の間だけ縦線（確実に出す） */
        .toc-item + .toc-item{
          border-left:1px solid var(--line);
        }
      
        .toc-item::after{ content:none; }
      
        .toc-item.is-full{ grid-column:auto; }
        
      }
      
      @media (min-width:1080px){
        /* PCではSP用の線を全部無効化してから、縦線だけ付ける */
        .toc-item{
          border:0; /* いったん全部消す */
          margin-top: 15px;
          font-size: 14px;
          background:#ffffff00;
        }
      
        /* SP用：左列の border-right を完全に消す（これが太線の原因） */
        .toc-item:nth-child(2n+1){
          border-right:0;
        }
      
        /* SP用：1行目の border-top を完全に消す（上の線が残る原因） */
        .toc-item:nth-child(1),
        .toc-item:nth-child(2),
        .toc-item.is-full:first-child{
          border-top:0;
        }
      
        /* PCは「要素間の縦線」だけ付ける */
        .toc-item + .toc-item{
          border-left:1px solid var(--line);
        }
      }



      /* 目次（toc-blue） */
    .toc-blue {
      background: #fff;
    }

    .toc-blue-heading {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 16px;
    }

    .toc-blue-title {
      font-size: 17px;
      font-weight: 600;
      color: #333;
      padding-left: 12px;
      border-left: 4px solid #0ABAB5;
    }

    .toc-blue-line {
      flex: 1;
      height: 1px;
      background: linear-gradient(90deg, #0ABAB5, transparent);
    }

    .toc-blue-nav ul {
      list-style: none;
      display: grid;
      grid-template-columns: 1fr;
      gap: 4px;
    }

    .toc-blue-nav li a {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 6px 12px;
      background: #f9fbfc;
      border-radius: 6px;
      text-decoration: none;
      transition: all 0.25s ease;
      border: 1px solid #e8f2f4;
    }

    .toc-blue-nav li a:hover {
      background: rgba(31, 183, 214, 0.08);
      border-color: rgba(90, 200, 216, 0.3);
    }

    .toc-blue-number {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      font-size: 10px;
      font-weight: 600;
      color: #0ABAB5;
      background: rgba(90, 200, 216, 0.06);
      transition: all 0.25s ease;
      flex-shrink: 0;
      line-height: 1;
    }

    .toc-blue-nav li a:hover .toc-blue-number {
      color: #fff;
      background: #0ABAB5;
    }

    .toc-blue-text {
      flex: 1;
      font-size: 14px;
      font-weight: 500;
      color: #333;
      transition: color 0.25s ease;
      line-height: 1.4;
      letter-spacing: 0.04em;
    }

    .toc-blue-nav li a:hover .toc-blue-text {
      color: #0ABAB5;
    }

    @media (min-width: 601px) {

      .toc-blue-heading {
        margin-bottom: 20px;
      }

      .toc-blue-nav li a {
        padding: 5px 14px;
        gap: 10px;
      }

      .toc-blue-number {
        width: 26px;
        height: 26px;
      }
    }

    
/* ↑ページ内目次 */


/* ↓無料カウンセリング */

  .counseling-wrapper {
    max-width: 800px;
    margin: 0 auto;
  }

  /* ========================================
     パターン1: クラシック・エレガント
  ======================================== */
  .counseling-1 {
    background: #ffffff;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 
      0 1px 3px rgba(0,0,0,0.04),
      0 8px 32px rgba(0,0,0,0.06);
    border: 1px solid #e9e9e9;
    position: relative;
    width: 100%;
  }

  .counseling-1::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: rgb(206, 167, 178);
  }

  .counseling-1 .counseling-title {
    font-family: 'Shippori Mincho', serif;
    font-size: 21px;
    font-weight: 550;
    color: #262626;
    letter-spacing: 0.18em;
    text-align: center;
    margin-bottom: 11px;
    margin-top: 11px;
  }

  .counseling-1 .counseling-title-19 {
    font-family: 'Shippori Mincho', serif;
    font-size: 19px;
    font-weight: 550;
    color: #262626;
    letter-spacing: 0.08em;
    text-align: center;
    margin-bottom: 8px;
    margin-top: 8px;
  }


  .counseling-1 .counseling-content {
    padding: 8px 12px;
  }

  .counseling-1 .counseling-description {
    font-size: 14px;
    line-height: 1.8
    color: #333;
    text-align: center;
    margin-bottom: 10px;
  }

  .counseling-1 .counseling-features {
    margin-bottom: 32px;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .counseling-1 .counseling-feature-item {
    font-size: 13px;
    font-weight: 300;
    color: #333;
    padding: 8px 0;
    border-bottom: 1px solid #f5f5f5;
    display: flex;
    align-items: center;
    gap: 16px;
  }

  .counseling-1 .counseling-feature-item:first-child {
    border-top: 1px solid #f5f5f5;
  }

  .counseling-1 .counseling-feature-num {
    font-family: 'Josefin Sans', sans-serif;
    font-size: 10px;
    color: rgb(8, 151, 146);
    margin-left: 5px;
  }

  .counseling-btn {
    display: block;
    width: 100%;
    padding: 12px;
    background: linear-gradient(180deg, #f9a825 0%, #f58220 100%);
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.15em;
    border-radius: 6px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .4);
    transition: all 0.3s ease;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4);
  }

  .counseling-btn:hover {
    background: linear-gradient(180deg, #ffb300 0%, #f9a825 100%);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(245, 130, 32, 0.5);
  }

  .counseling-note {
    font-size: 12px;
    color: #666666;
    text-align: center;
  }
  .counseling-note-11 {
    font-size: 11px;
    color: #333;
    text-align: center;
  }

.counseling-note-black {
    font-size: 12px;
    color: #333;
    text-align: center;
  }
  .counseling-note-black-11 {
    font-size: 11px;
    color: #333;
    text-align: center;
  }




  .counseling-check {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0px 11px;
    list-style: none;
    font-size: 11.5px;
    color: #333;
    text-align: center;
    letter-spacing: 0.05em;
  }

  .counseling-check li {
    display: flex;
    align-items: center;
    gap: 2px;
  }

  .counseling-check li::before {
    content: "✓";
    color: #f9a825;
  }

 
  @media (min-width: 768px) {
    .counseling-check {
      font-size: 13px;
      gap: 8px 28px;
    }
    .counseling-1 .counseling-title {
      font-size: 26px;
    }
    .counseling-1 .counseling-description {
        font-size: 15px;
    }
    .counseling-1 .counseling-feature-item {
        font-size: 15px;
    }
    .counseling-1 .counseling-content {
        padding: 10px 30px;
    }
    .counseling-1 .counseling-feature-num {
        font-size: 13px;
        margin-left: 20px;
    }
    .counseling-note {
        font-size: 13px;
      }
      .counseling-note-11 {
        font-size: 12px;
      }
    
    .counseling-note-black {
        font-size: 13px;
      }
      .counseling-note-black-11 {
        font-size: 12px;
      }

  }


  @media (min-width: 1024px) {
    .counseling-check {
      font-size: 14px;
      gap: 8px 36px;
    }
    .counseling-1 .counseling-title {
      font-size: 28px;
      margin-bottom: 10px;
      margin-top: 10px;
    }
    .counseling-1 .counseling-feature-item {
        font-size: 16px;
    }
    .counseling-1 .counseling-description {
        font-size: 16px;
    }
    .counseling-1 .counseling-content {
        padding: 10px 50px;
    }
    .counseling-1 .counseling-feature-num {
        font-size: 14px;
        margin-left: 20px;
    }
    .counseling-note {
        font-size: 14px;
      }
      .counseling-note-11 {
        font-size: 13px;
      }
    
    .counseling-note-black {
        font-size: 14px;
      }
      .counseling-note-black-11 {
        font-size: 13px;
      }
  }


  /* ===== 無料サービスリスト ===== */
  .pmt-free-box {
    background-color: #fafaf9;
    padding: 20px;
    margin-bottom: 12px;
    border-radius: 5px;
  }

  .pmt-free-list {
    list-style: none;
  }

  .pmt-free-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 14px;
    color: #44403c;
    margin-bottom: 8px;
  }

  .pmt-free-list li:last-child {
    margin-bottom: 0;
  }

  .pmt-free-list li::before {
    content: "●";
    color: rgb(170, 119, 135);
    font-size: 10px;
    margin-top: 4px;
    flex-shrink: 0;
  }

  @media (min-width: 768px) {
    .pmt-free-list li {
        gap: 12px;
        font-size: 15px;
        margin-bottom: 10px;
      }
    
      .pmt-free-list li::before {
        font-size: 11px;
        margin-top: 4px;
      }
  }
  @media (min-width: 1024px) {
    .pmt-free-list li {
        gap: 12px;
        font-size: 17px;
        margin-bottom: 12px;
      }
    
      .pmt-free-list li::before {
        font-size: 12px;
        margin-top: 3px;
      }
  }

  /* ===== 料金表ボタン ===== */


  /* ===== 区切り線 ===== */
  .pmt-divider {
    border: none;
    border-top: 1px solid #f5f5f4;
  }

  /* ===== お支払い方法 ===== */
  .pmt-method {
    border-left: 1px solid #6ccac1;   
    padding-left: 16px;
    margin-bottom: 24px;
  }

  .pmt-method:last-child {
    margin-bottom: 0;
  }

  .pmt-method-header {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 8px;
  }

  .pmt-method-num {
    font-size: 12px;
    font-weight: 500;
    color: rgb(8, 151, 146);
  }

  .pmt-method-title {
    font-size: 14px;
    font-weight: 700;
    color: #1c1917;
  }

  .pmt-method-list {
    list-style: none;
  }

  .pmt-method-list li {
    font-size: 13px;
    color: #57534e;
    margin-bottom: 4px;
  }

  .pmt-method-sub {
    font-size: 12px;
    color: #a8a29e;
    margin-top: 8px;
  }

  @media (min-width: 768px) {
    .pmt-method-title {
        font-size: 15px;
      }
      .pmt-method-num {
        font-size: 15px;
      }

    .pmt-method-list li {
        font-size: 15px;
      }
  }
  @media (min-width: 1024px) {
    .pmt-method-title {
        font-size: 16px;
      }
      .pmt-method-num {
        font-size: 16px;
      }
    .pmt-method-list li {
        font-size: 16px;
      }
  }



  /* ===== アコーディオン ===== */
  .pmt-accordion-btn {
    width: 100%;
    padding: 8px;
    background: none;
    border: none;
    border-top: 1px solid #e7e5e4;
    border-bottom: 1px solid #e7e5e4;
    font-size: 12px;
    color: #57534e;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: px;
    transition: background-color 0.2s;
    letter-spacing: 0.04em;
    background-color: #fafaf9e6;
  }

  .pmt-accordion-arrow {
    font-size: 10px;
    color: #beac7c;
    transition: transform 0.3s;
    margin-left: 3px;
  }

  .pmt-accordion-arrow.open {
    transform: rotate(180deg);
  }

  .pmt-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
  }

  .pmt-accordion-content.open {
    max-height: 2000px;
    transition: max-height 0.5s ease-in;
  }

  .pmt-example-card {
    background-color: #fafaf9;
    padding: 16px;
    margin-bottom: 16px;
  }

  .pmt-example-card:last-child {
    margin-bottom: 0;
  }

  .pmt-example-card-title {
    font-size: 14px;
    font-weight: 500;
    color: #1c1917;
    margin-bottom: 8px;
  }

  .pmt-example-card-text {
    font-size: 14px;
    color: #57534e;
    margin-bottom: 4px;
  }

  .pmt-example-highlight {
    color: #796328;
    font-weight: 500;
  }

  .pmt-example-group {
    margin: 8px 0;
  }
  .pmt-example-title {
    font-size: 15px;
    font-weight: 500;
    color: #796328;
    margin: 12px 0 0 16px;
    letter-spacing: 0.05em;
  }


  /* ===== CTA ===== */
  .pmt-cta {
    background-color: #fafaf9;
    padding: 24px;
  }

  .pmt-cta-title {
    font-family: 'Noto Serif JP', serif;
    font-size: 16px;
    color: #1c1917;
    text-align: center;
    margin-bottom: 8px;
  }

  .pmt-cta-text {
    font-size: 14px;
    color: #78716c;
    text-align: center;
    margin-bottom: 24px;
  }

  .pmt-cta-features {
    display: flex;
    justify-content: center;
    gap: 16px;
    font-size: 12px;
    color: #78716c;
    margin-bottom: 24px;
  }

  .pmt-cta-primary {
    display: block;
    width: 100%;
    padding: 16px;
    background-color: #927830;
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 12px;
    transition: opacity 0.2s;
  }

  .pmt-cta-primary:hover {
    opacity: 0.9;
  }

  .pmt-cta-secondary {
    display: block;
    width: 100%;
    padding: 14px;
    background-color: #fff;
    border: 1px solid #bfab7f;
    color: #57534e;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    transition: background-color 0.2s;
  }

  .pmt-cta-secondary:hover {
    background-color: #fafaf9;
  }



  .pmt-title-10 {
    display: flex;
    align-items: center;
    gap: 16px;
    font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", serif;
    color: #1c1917;
    letter-spacing: 0.1em;
  }

  .title-leftline-gold {
    width: 32px;
    height: 1px;
    background: #927830;
  }

  .title-leftline-pink {
    width: 32px;
    height: 1px;
    background: rgb(197, 129, 148);
  }

  .title-leftline-mintblue {
    width: 32px;
    height: 1px;
    background: #6ccac1;
  }
  /* ↑明朗会計・無料サービス・お支払い方法 */


  /* ↓TOPページ治療メニュー */
  .dental-container {
    max-width: 1300px;
    margin: 0 auto;
    padding: 28px 15px 5px;
  }

  /* Header */
  .dental-header {
    text-align: center;
    margin-bottom: 20px;
  }

  .dental-header-subtitle {
    font-size: 13px;
    color: #666;
    letter-spacing: 0.1em;
    margin-bottom: 4px;
    margin-top: 6px;
  }

  .dental-header-desc {
    font-size: 13px;
    color: #222;
    line-height: 1.9;
  }

  .dental-header-desc small {
    font-size: 11px;
    color: #555;
  }

  /* Grid */
  .dental-menu-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .dental-menu-grid li {
    display: block;
  }

  /* Card */
  .dental-card {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    display: block;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
  }

  .dental-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
    transform: translateY(-3px);
  }

  .dental-card:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  }

  .dental-card-img {
    position: relative;
    overflow: hidden;
    background: #f0f0f0;
  }

  .dental-image-box {
    max-width: 100%;
    display: block;
  }

  .dental-image-box img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.4s ease;
  }

  .dental-card:hover .dental-image-box img {
    transform: scale(1.03);
  }

  .dental-card-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    background: #2d9caa;
    color: white;
    font-size: 10px;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 3px;
    letter-spacing: 0.05em;
  }

  .dental-card-body {
    padding: 8px 12px 14px;
  }

  .dental-card-title {
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 1px;
    line-height: 1.3;
  }
  .dental-card-title-14 {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 1px;
    line-height: 1.3;
  }

  .dental-card-sub {
    font-size: 10px;
    color: #2d9caa;
    letter-spacing: 0.03em;
    margin-bottom: 4px;
    min-height: 1em;
  }

  .dental-card-desc {
    font-size: 11px;
    color: #222;
    line-height: 1.6;
  }

  .dental-card-desc-top-22 {
    margin-top: 22px;
  }

  /* Responsive */
  @media (min-width: 600px) {
    .dental-container {
      padding: 35px 20px 10px;
    }

    .dental-header {
      margin-bottom: 15px;
    }

    .feature-title {
      font-size: 24px;
    }

    .dental-header-subtitle {
      font-size: 14px;
    }

    .dental-header-desc {
      font-size: 14px;
    }

    .dental-menu-grid {
      gap: 20px;
    }

    .dental-card-badge {
      top: 10px;
      left: 10px;
      font-size: 11px;
      padding: 3px 10px;
    }

    .dental-card-body {
      padding: 12px 18px 18px;
    }

    .dental-card-title {
      font-size: 18px;
      font-weight: 600;
      margin-bottom: 3px;
    }

    .dental-card-sub {
      font-size: 11px;
      margin-bottom: 6px;
    }

    .dental-card-desc {
      font-size: 14px;
      color: #222;
      line-height: 1.7;
    }
  }

  @media (min-width: 800px) {
    .dental-container {
      padding: 40px 20px 5px;
    }

    .dental-header {
      margin-bottom: 30px;
    }

    .feature-title {
      font-size: 27px;
    }

    .dental-menu-grid {
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
  }

  @media (min-width: 1100px) {
    .dental-menu-grid {
      grid-template-columns: repeat(4, 1fr);
    }
    .dental-card-desc-top-22 {
        margin-top: 26px;
      }
  }
  /* ↑TOPページ治療メニュー */


/* 症例スライド↓ */
.treatment-slider-container {
    margin: 0 auto;
    position: relative;
    padding: 0 30px;
    overflow: hidden;
    max-width: 890px;
}

.treatment-slides-wrapper {
    overflow: hidden;
    position: relative;
    border-radius: 10px;
    width: 100%;
}

.treatment-slides {
    display: flex;
    transition: transform 0.5s ease;
    width: 100%;
}

.treatment-slide {
    width: 100%;
    flex-shrink: 0;
    box-sizing: border-box;
}

.treatment-nav-button {
    position: absolute;
    top: 45%;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    /* background: linear-gradient(to right, #ff2c41f4, #f08181); */

    background: linear-gradient(to right, #ff7a88, #f2acef);
    border: none;
    color: white;
    font-size: 34px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    transform-origin: center;
}

.treatment-nav-button:active {
    transform: scale(0.6);
}

.treatment-nav-button.prev {
    left: 5px;
}

.treatment-nav-button.next {
    right: 5px;
}

.treatment-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    height: 12px;
}

.treatment-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #ddd;
    cursor: pointer;
    transition: all 0.3s ease;
}

.treatment-dot.active {
    background: linear-gradient(to right, #7ac7d8, #a8c1e6);
    width: 32px;
    border-radius: 16px;
}



/* Tablet styles */
@media (min-width: 460px) {
    .treatment-nav-button {
    top: 335px;
}

    .treatment-slider-container {
        padding: 0 60px;
    }

    .treatment-nav-button {
        width: 58px;
        height: 58px;
        font-size: 36px;
    }

    .treatment-nav-button.prev {
        left: 18px;
    }

    .treatment-nav-button.next {
        right: 18px;
    }
    .treatment-slides-wrapper {
        height: 400px;
    }
}

@media (min-width: 550px) {
    .treatment-slides-wrapper {
        height: 440px;
    }
}

@media (min-width: 650px) {
    .treatment-slides-wrapper {
        height: 460px;
    }
}
/* Desktop styles */
@media (min-width: 768px) {

    .treatment-dots {
        gap: 10px;
        height: 12px;
    }

    .treatment-dot {
        width: 12px;
        height: 12px;
    }

    .treatment-dot.active {
        width: 40px;
        border-radius: 20px;
    }
    .treatment-slides-wrapper {
        height: 575px;
    }
}


@media (min-width: 460px) {
    .before-after-flex-600 {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 8px;
    }

    
}
@media (max-width: 459px) {
    .margin-30-sp-599 {
        margin-left: 30px;
        margin-right: 30px;
    }
}
/* 症例スライド */


/* ↓背景色バックグラウンド */
.bg-graypink {
    background-color: rgb(251, 246, 248);
}



/* ↑背景色バックグラウンド */
