        /* バナー型リンク - デスクトップ（1025px以上） */
.zirconia-link-banner {
    background: #fff;
    border-radius: 15px;
    padding: 35px;
    margin: 50px auto;
    text-align: center;
    position: relative;
    border: 2px solid #f03800;
}

        .zirconia-link-banner::before,
        .zirconia-link-banner::after {
            content: '🦷';
            position: absolute;
            font-size: 24px;
            opacity: 0.3;
        }

        .zirconia-link-banner::before {
            top: 15px;
            left: 20px;
        }

        .zirconia-link-banner::after {
            bottom: 15px;
            right: 20px;
        }

.zirconia-link-banner p {
    font-size: 18px;
    color: var(--txt-color-01);
    font-weight: bolder;
    margin-bottom: 20px;
    line-height: 1.6;
}

        .zirconia-link-banner .metal-free {
            background: white;
            color: var(--txt-color-02);
            padding: 3px 12px;
            border-radius: 20px;
            font-weight: 700;
            display: inline-block;
            margin: 0 5px;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
            white-space: nowrap;
        }

        .zirconia-link-banner .btn {
            display: inline-block;
            background: #f03800;
            color: white;
            padding: 12px 35px;
            border-radius: 25px;
            text-decoration: none;
            font-weight: bold;
            font-size: 15px;
            transition: all 0.3s ease;
            box-shadow: 0 4px 12px rgba(76, 175, 80, 0.3);
            white-space: nowrap;
        }

        .zirconia-link-banner .btn:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 16px rgba(76, 175, 80, 0.4);
        }

        .zirconia-link-banner .btn::after {
            content: ' →';
            margin-left: 5px;
            font-size: 16px;
        }

        /* タブレット対応（1024px以下） */
        @media screen and (max-width: 1024px) {
            .zirconia-link-banner {
                padding: 30px 25px;
                margin: 40px auto;
                max-width: 90%;
            }

            .zirconia-link-banner p {
                font-size: 17px;
                margin-bottom: 18px;
            }

            .zirconia-link-banner .metal-free {
                padding: 3px 10px;
                font-size: 15px;
                margin: 0 3px;
            }

            .zirconia-link-banner .btn {
                padding: 11px 30px;
                font-size: 14px;
            }

            .zirconia-link-banner::before,
            .zirconia-link-banner::after {
                font-size: 20px;
            }
        }

        /* スマートフォン対応（599px以下） */

@media screen and (max-width:599px) {
 
            .zirconia-link-banner p {
                font-size: 16px;
                margin-bottom: 15px;
                line-height: 1.7;
            }


            .zirconia-link-banner {
                padding: 25px 20px;
                margin: 30px auto;
                max-width: 100%;
                border-radius: 12px;
            }

            .zirconia-link-banner::before,
            .zirconia-link-banner::after {
                display: none; /* スマホでは装飾アイコンを非表示 */
            }

            .zirconia-link-banner p {
                font-size: 18px;
                margin-bottom: 15px;
                line-height: 1.7;
            }

            /* スマホでは改行を入れて読みやすく */
            .zirconia-link-banner .text-wrapper {
                display: block;
            }

            .zirconia-link-banner .metal-free {
                display: block;
                padding: 4px 12px;
                font-size: 14px;
                margin: 0 auto 10px;
                width: fit-content;
            }

            .zirconia-link-banner .implant-name {
                display: block;
                margin-bottom: 8px;
            }

            .zirconia-link-banner .btn {
                padding: 10px 28px;
                font-size: 14px;
                display: block;
                width: fit-content;
                margin: 0 auto;
            }

            .zirconia-link-banner .btn::after {
                font-size: 14px;
            }
}

/* 2025/10/18 */

.cmn-child-01 .link-color a{
  color: #0077dd;
}



/* --- accordion (scoped) --- */
        /* アコーディオン対応のリスト項目 */
        .accordion-item {
            position: relative;
        }

        /* メインリンクとボタンのラッパー */
        .accordion-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        /* 既存のリンクスタイルを維持 */
        .accordion-header > a {
            flex: 1;
            color: inherit;
            text-decoration: none;
        }

        /* プラス/マイナスボタン */
        .accordion-toggle {
            width: 20px;
            height: 20px;
            background: #fff;
            border: 1px solid #ddd;
            border-radius: 3px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            margin-left: 10px;
            transition: all 0.3s ease;
            flex-shrink: 0;
        }

        .accordion-toggle:hover {
            background: var(--back-color-02);
            border-color: var(--back-color-02);
        }

        /* プラス/マイナスアイコン */
        .accordion-toggle::before,
        .accordion-toggle::after {
            content: '';
            position: absolute;
            background: #bbbbbb;
            transition: all 0.3s ease;
        }

        .accordion-toggle::before {
            width: 10px;
            height: 2px;
        }

        .accordion-toggle::after {
            width: 2px;
            height: 10px;
        }

        .accordion-toggle:hover::before,
        .accordion-toggle:hover::after {
            background: white;
        }

        /* 開いた状態（マイナス表示） */
        .accordion-item.active .accordion-toggle {
            background: var(--back-color-02);
            border-color: var(--back-color-02);
        }

        .accordion-item.active .accordion-toggle::before,
        .accordion-item.active .accordion-toggle::after {
            background: white;
        }

        .accordion-item.active .accordion-toggle::after {
            height: 0;
        }

        /* サブメニュー */
        .accordion-content {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease;
        }

        .accordion-item.active .accordion-content {
            max-height: 300px;
        }

        .accordion-content ul {
            padding-left: 20px;
            padding-top: 5px;
            padding-bottom: 5px;
            list-style: none;
        }

        .accordion-content li {
            position: relative;
            padding-left: 15px;
        }

        .accordion-content li::before {
            content: '└';
            position: absolute;
            left: 0;
            color: #999;
        }

        .accordion-content a {
            color: inherit;
            text-decoration: none;
            display: block;
            padding: 3px 0;
        }

        .accordion-content a:hover {
            color: #4CAF50;
        }

        /* NEWバッジ */
        .new-badge {
            background: #ff4444;
            color: white;
            font-size: 10px;
            padding: 2px 5px;
            border-radius: 3px;
            margin-left: 5px;
            font-weight: bold;
            display: inline-block;
            animation: pulse 2s infinite;
        }

        @keyframes pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }
        

@media screen and (max-width:1024px) {
 .accordion-item .accordion-content{
    max-height: inherit;
 }
 
  .accordion-item .accordion-toggle{
    display: none;
  }
 
 .accordion-item .accordion-content ul li a::before{
   display: none;
 }
 
 .accordion-item .accordion-content ul li a {
   padding-left: 5px;
 }
 
.cmn-header-01 .nav li.dropdown li+li.up-mt-0{
  margin-top: 0px;
}
 
}

 .cmn-header-01 .nav li.up-mt-0{
   margin-top: 0px;
 }

@media screen and (min-width:1025px) {
 .cmn-header-01 .accordion-content a::before{
  display: none;
}

 .cmn-header-01 .nav li.dropdown .accordion-content a{
  padding-left: 5px;
}
}
