/* ==========================================================
   【ナンバーワンサイト】共通マスターCSS
   ========================================================== */

/* 1. ベース設定（背景と文字色） */
html, body {
    background-color: #050505 !important;
    color: #ffffff !important;
    margin: 0;
    padding: 0;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", sans-serif;
}

/* 2. ヘッダー（一番上で固定・中央揃え） */
.site-header {
    width: 100%;
    background-color: rgba(10, 10, 10, 0.95); /* 少し透け感のある黒 */
    border-bottom: 2px solid #00ff41;
    padding: 20px 0;
    text-align: center;
    position: sticky;
    top: 0;
    z-index: 1000; /* 常に一番手前に表示 */
}

.logo {
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    color: #ffffff;
    margin: 0;
}

.tagline {
    font-size: 0.75rem;
    color: #00ff41;
    font-weight: bold;
    margin-top: 5px;
}

/* 3. コンテナ（ここでメインを中央に配置し、バナーの幅を確保） */
.container {
    display: flex;
    justify-content: center; /* メインをど真ん中に */
    width: 100%;
    /* 左右にバナーの太さ(200px)分の余白を空ける！これで細くならない */
    padding: 0 200px; 
    box-sizing: border-box;
}

/* 4. 左右の太いバナー（スクロール対応版） */
.side-banner {
    position: fixed;
    top: 85px;         /* ヘッダーのすぐ下から開始（君の設定をキープ！） */
    width: 200px;
    height: calc(100vh - 85px); /* 画面の下まで（君の設定をキープ！） */
    background-color: #111111;
    border-left: 1px solid #333;
    border-right: 1px solid #333;
    padding: 30px 10px;
    z-index: 100;
    
    /* 中身を縦に並べるための設定 */
    display: flex;
    flex-direction: column;

    /* ★ここから追加！はみ出た分をスクロールさせる魔法 */
    overflow-y: auto; 

    /* ★スクロールバー自体は隠す（マウスホイールやスワイプで動く） */
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* Chrome, Safari 用のスクロールバー非表示設定（必ず上の } の外に書く！） */
.side-banner::-webkit-scrollbar {
    display: none;
}

.left-banner { left: 0; }
.right-banner { right: 0; }

/* バナー内のタイトル（セットで迷いを断つ、など） */
.banner-label {
    font-size: 0.85rem;
    color: #00ff41;
    text-align: center;
    font-weight: bold;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #333;
}

/* 5. メインコンテンツ（情報エリア） */
main.main-content {
    flex: 1;
    width: 100%;
    max-width: 850px; /* ここを広げた！読みやすくゆったりした幅 */
    padding: 40px 20px;
}

/* 6. バナー内のネオンボタン */
.side-nav .nav-item {
    display: block;
    color: #ffffff;
    text-decoration: none;
    background-color: #1a1a1a;
    padding: 15px 10px;
    margin-bottom: 10px;
    border-radius: 4px;
    text-align: center;
    font-size: 0.9rem;
    border: 1px solid #333;
    transition: 0.3s;
}

.side-nav .nav-item:hover {
    border-color: #00ff41;
    color: #00ff41;
    box-shadow: 0 0 10px rgba(0, 255, 65, 0.3);
    transform: translateX(5px);
}
/* ==========================================================
   メインコンテンツ：ランキングカード（全ジャンル共通）
========================================================== */

/* カード全体の大枠 */
.rank-item {
    background-color: #111111;
    border: 1px solid #333333;
    border-radius: 8px;
    padding: 30px;
    margin-bottom: 40px;
    position: relative;
    transition: 0.3s;
}

.rank-item:hover {
    border-color: #00ff41;
    box-shadow: 0 5px 20px rgba(0, 255, 65, 0.1);
}

/* ナンバーワンの証：ゴールドバッジ */
.rank-badge {
    display: inline-block;
    background: linear-gradient(135deg, #d4af37, #aa8623);
    color: #000000;
    font-weight: 900;
    padding: 6px 20px;
    border-radius: 4px;
    margin-bottom: 15px;
    font-size: 1.1rem;
    box-shadow: 0 4px 10px rgba(212, 175, 55, 0.3);
}

/* 右上のスコア表示 */
.score-area {
    position: absolute;
    top: 30px;
    right: 30px;
    text-align: right;
}

.score-label {
    display: block;
    font-size: 0.75rem;
    color: #888888;
    letter-spacing: 0.1em;
}

.score-number {
    font-size: 2.5rem;
    font-weight: 900;
    color: #ffffff;
    line-height: 1;
}

/* 証券会社名とキャッチフレーズ */
.item-name {
    font-size: 2rem;
    color: #ffffff;
    margin-bottom: 5px;
}

.catchphrase {
    font-size: 0.95rem;
    color: #bbbbbb;
    margin-bottom: 25px;
}

/* 比較スペック表（横並びのグリッド） */
.spec-table {
    display: grid;
    grid-template-columns: 1fr 1fr; /* PCでは2列に並べる */
    gap: 15px;
    margin-bottom: 25px;
}

.spec-row {
    display: flex;
    background-color: #1a1a1a;
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid #222;
}

.spec-th {
    background-color: #222222;
    padding: 12px 10px;
    font-size: 0.85rem;
    color: #aaaaaa;
    width: 35%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.spec-td {
    padding: 12px 10px;
    font-size: 0.95rem;
    color: #ffffff;
    width: 65%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 「無料」などの強調テキスト */
.spec-td.highlight {
    color: #00ff41;
    font-weight: bold;
}

/* なぜナンバーワンなのか？の解説ボックス */
.reason-box {
    border-left: 4px solid #d4af37;
    background-color: rgba(212, 175, 55, 0.05);
    padding: 20px;
    border-radius: 0 4px 4px 0;
}

.reason-title {
    font-size: 1.1rem;
    color: #d4af37;
    margin-bottom: 10px;
    font-weight: bold;
}

.reason-text {
    font-size: 0.95rem;
    color: #cccccc;
    line-height: 1.6;
}
/* ==========================================================
   ナンバーワンサイト：詳細データ装飾（メリット・口コミ・ボタン等）
   ========================================================== */

/* ページ導入部の熱いメッセージ */
.intro-text {
    font-size: 1.1rem;
    line-height: 1.8;
    color: #dddddd;
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
    background: rgba(0, 255, 65, 0.05); /* ネオングリーンの薄い背景 */
    border-radius: 8px;
    border: 1px dashed #333;
}

/* 最強のアクションボタン（迷いを断つための絶対的な導線） */
.action-area {
    text-align: center;
    margin: 30px 0;
}

.btn-primary {
    display: inline-block;
    background: linear-gradient(135deg, #00ff41, #00b32d); /* 信頼の緑グラデーション */
    color: #000000;
    font-size: 1.2rem;
    font-weight: 900;
    text-decoration: none;
    padding: 18px 40px;
    border-radius: 50px; /* 丸みを持たせてクリックしやすく */
    box-shadow: 0 5px 15px rgba(0, 255, 65, 0.4);
    transition: 0.3s;
    border: 2px solid transparent;
}

/* マウスを乗せた時に黒く反転して光る魔法 */
.btn-primary:hover {
    background: #000000;
    color: #00ff41;
    border-color: #00ff41;
    box-shadow: 0 10px 30px rgba(0, 255, 65, 0.6);
    transform: translateY(-3px);
}

.action-micro-copy {
    font-size: 0.8rem;
    color: #aaaaaa;
    margin-top: 10px;
}

/* 詳細解説：メリット・デメリットの装飾 */
.detail-section {
    margin-top: 40px;
    padding-top: 30px;
    border-top: 1px dashed #333;
}

.detail-title {
    font-size: 1.3rem;
    color: #ffffff;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
}

/* タイトルの左に四角いアクセントをつける */
.detail-title::before {
    content: "■";
    color: #00ff41;
    margin-right: 10px;
    font-size: 1.5rem;
}

.merit-list {
    list-style: none;
    padding: 0;
}

.merit-list li {
    background: #1a1a1a;
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 15px;
    border-left: 4px solid #00ff41; /* 左端に緑のライン */
}

.merit-list strong {
    display: block;
    font-size: 1.1rem;
    color: #00ff41;
    margin-bottom: 10px;
}

.merit-list p {
    font-size: 0.95rem;
    color: #cccccc;
    line-height: 1.6;
}

/* デメリット専用の装飾（赤系で注意喚起、ただしネガティブすぎないように） */
.con-section .detail-title::before {
    color: #ff4136;
}

.con-text {
    background: #1a1a1a;
    padding: 20px;
    border-radius: 8px;
    border-left: 4px solid #ff4136;
    font-size: 0.95rem;
    color: #cccccc;
    line-height: 1.6;
}

/* 口コミボックス：リアルな声を美しく見せる */
.review-box {
    margin-top: 40px;
    background: #151515;
    padding: 30px;
    border-radius: 8px;
    border: 1px solid #222;
}

.review-title {
    font-size: 1.2rem;
    color: #ffffff;
    margin-bottom: 20px;
    text-align: center;
    border-bottom: 1px solid #333;
    padding-bottom: 15px;
}

.review-item {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px dashed #333;
}

.review-item:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.review-star {
    color: #d4af37; /* 星はゴールド */
    font-size: 1.2rem;
    margin-bottom: 5px;
}

.review-score {
    color: #aaaaaa;
    font-size: 0.9rem;
}

.review-comment {
    font-size: 0.95rem;
    color: #dddddd;
    line-height: 1.6;
    font-style: italic; /* 少し斜体にして「声」っぽさを出す */
}

/* FAQ（よくある質問）：アコーディオン風のデザイン */
.faq-box {
    margin-top: 40px;
}

.faq-title {
    font-size: 1.3rem;
    color: #ffffff;
    margin-bottom: 20px;
    text-align: center;
}

.faq-list dt {
    background: #222;
    color: #00ff41;
    padding: 15px;
    font-weight: bold;
    border-radius: 4px 4px 0 0;
    margin-top: 15px;
}

.faq-list dd {
    background: #1a1a1a;
    color: #cccccc;
    padding: 15px;
    margin: 0;
    border-radius: 0 0 4px 4px;
    line-height: 1.6;
    border: 1px solid #222;
    border-top: none;
}

/* 最後の巨大アクションボタン（画面下部でトドメを刺す） */
.bottom-action {
    margin-top: 50px;
    padding-top: 40px;
    border-top: 2px solid #333;
}

.action-lead {
    font-size: 1.1rem;
    color: #d4af37;
    margin-bottom: 20px;
    font-weight: bold;
}

.large-btn {
    font-size: 1.3rem;
    padding: 20px 50px;
    width: 100%;
    max-width: 600px;
    display: block;
    margin: 0 auto; /* 真ん中に配置 */
}
/* ヘッダーのレイアウト調整（左右の空間を活かす準備） */
.header-inner {
    display: flex;
    justify-content: space-between; /* 左右と中央に分ける */
    align-items: center;
    width: 100%;
    padding: 0 20px;
}

/* 左右の空間の幅を、下のバナー（200px）と合わせることで完璧なバランスになる */
.header-left, .header-right {
    width: 200px; 
}

/* ロゴのリンク化とお洒落な発光エフェクト */
.logo a {
    color: #ffffff;
    text-decoration: none;
    transition: 0.3s;
}

.logo a:hover {
    color: #00ff41; /* マウスを乗せると緑になる */
    text-shadow: 0 0 15px rgba(0, 255, 65, 0.8); /* 強く発光する */
}
/* =========================================
   ヘッダー左右の装飾（検索・ボタン）
   ========================================= */

/* --- 左側：検索バー --- */
.search-form {
    display: flex;
    align-items: center;
    background-color: #1a1a1a; /* 背景より少し明るいグレー */
    border: 1px solid #333;
    border-radius: 20px; /* 丸みを帯びた形 */
    padding: 5px 15px;
    width: 100%;
    max-width: 200px; /* 幅を制限 */
}

.search-input {
    border: none;
    background: transparent;
    color: #fff;
    font-size: 0.85rem;
    width: 100%;
    outline: none; /* クリック時の枠線を消す */
}

.search-btn {
    background: transparent;
    border: none;
    color: #888;
    cursor: pointer;
    font-size: 1rem;
    transition: 0.3s;
}

.search-form:hover {
    border-color: #00ff41; /* ホバーで枠がネオンに光る */
}
.search-form:hover .search-btn {
    color: #00ff41; /* 虫眼鏡も光る */
}

/* --- 右側：アクションボタン --- */
.header-actions {
    display: flex;
    justify-content: flex-end; /* 右寄せ */
    gap: 10px; /* ボタン間の隙間 */
}

.action-btn {
    display: flex;
    align-items: center;
    background-color: transparent;
    border: 1px solid #333;
    color: #aaa;
    text-decoration: none;
    font-size: 0.8rem;
    padding: 6px 12px;
    border-radius: 4px;
    cursor: pointer;
    transition: 0.3s;
}

.btn-icon {
    margin-right: 5px;
    font-size: 1rem;
}

/* X（旧Twitter）ボタンのホバーリング */
.x-btn:hover {
    background-color: #000;
    border-color: #fff;
    color: #fff;
}

/* ブックマークボタンのホバーリング */
.bookmark-btn:hover {
    border-color: #d4af37; /* ゴールド */
    color: #d4af37;
}
.bookmark-btn:hover .btn-icon {
    color: #d4af37;
}
/* ==========================================
   SBI証券の詳細データ：後半戦の装飾
   ========================================== */

/* アクションエリア（口座開設ボタン周り）を中央にドカッと配置 */
.action-area {
    text-align: center;
    margin: 40px 0;
    padding: 30px;
    background: rgba(0, 255, 65, 0.05); /* うっすら緑のオーラ */
    border: 1px dashed #00ff41;
    border-radius: 8px;
}

.action-lead {
    font-size: 1.1rem;
    color: #ffffff;
    margin-bottom: 15px;
    font-weight: bold;
}

/* ユーザーの背中を押す最強のボタン */
.btn-primary {
    display: inline-block;
    background: linear-gradient(135deg, #00ff41, #00aa2b);
    color: #000000;
    font-size: 1.2rem;
    font-weight: 900;
    padding: 15px 40px;
    border-radius: 50px;
    text-decoration: none;
    transition: 0.3s;
    box-shadow: 0 5px 15px rgba(0, 255, 65, 0.3);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0, 255, 65, 0.5);
}

.action-micro-copy {
    font-size: 0.8rem;
    color: #888888;
    margin-top: 10px;
}

/* メリット・デメリットの解説エリア */
.detail-section {
    margin-top: 40px;
}

.detail-title {
    font-size: 1.3rem;
    color: #00ff41;
    border-bottom: 2px solid #333333;
    padding-bottom: 10px;
    margin-bottom: 20px;
}

/* メリットのリストのズレを直す */
.merit-list {
    list-style: none; /* デフォルトの黒ポチを消す */
    padding: 0;
    margin: 0;
}

.merit-list li {
    background-color: #1a1a1a;
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 15px;
    border-left: 4px solid #00ff41;
}

.merit-list strong {
    display: block;
    font-size: 1.1rem;
    color: #ffffff;
    margin-bottom: 10px;
}

.merit-list p {
    font-size: 0.95rem;
    color: #cccccc;
    line-height: 1.6;
}

/* デメリットエリア（赤で警告） */
.con-section .detail-title {
    color: #ff4444;
}
.con-text {
    background-color: rgba(255, 68, 68, 0.05);
    border-left: 4px solid #ff4444;
    padding: 20px;
    color: #cccccc;
    line-height: 1.6;
    border-radius: 0 8px 8px 0;
}

/* 口コミエリアのズレを直す */
.review-box {
    margin-top: 40px;
    background-color: #111111;
    border: 1px solid #333333;
    padding: 30px;
    border-radius: 8px;
}

.review-title {
    font-size: 1.2rem;
    color: #ffffff;
    text-align: center;
    margin-bottom: 25px;
}

.review-item {
    border-bottom: 1px dashed #333333;
    padding-bottom: 15px;
    margin-bottom: 15px;
}
.review-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.review-star {
    color: #d4af37;
    font-size: 1.2rem;
    margin-bottom: 5px;
}

.review-comment {
    font-size: 0.95rem;
    color: #bbbbbb;
    line-height: 1.5;
}

/* よくある質問（Q&A）のズレを直す */
.faq-box {
    margin-top: 40px;
}
.faq-list dt {
    font-weight: bold;
    color: #00ff41;
    margin-bottom: 5px;
    font-size: 1.05rem;
}
.faq-list dd {
    margin-left: 0; /* ここがズレの原因！左の余白を消す */
    margin-bottom: 20px;
    color: #cccccc;
    line-height: 1.6;
    padding-left: 20px;
    border-left: 2px solid #333333;
}
/* ==========================================
   フッター（全ページ共通）
   ========================================== */
.site-footer {
    background-color: #050505;
    border-top: 1px solid #333333;
    padding: 60px 20px 40px;
    margin-top: 80px; /* メインコンテンツとの距離 */
    text-align: center;
    width: 100%;
    clear: both; /* ズレを強制リセット */
}

.footer-inner {
    max-width: 800px;
    margin: 0 auto;
}

.footer-logo {
    font-size: 1.5rem;
    color: #ffffff;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
}

.footer-tagline {
    font-size: 0.9rem;
    color: #00ff41;
    margin-bottom: 30px;
}

.copyright {
    font-size: 0.8rem;
    color: #666666;
    border-top: 1px dashed #222222;
    padding-top: 20px;
}
/* ==========================================
   トップページ（index.html）専用デザイン
   ========================================== */

/* コンセプトエリアを超圧縮＆スタイリッシュに */
.top-hero {
    background: linear-gradient(to bottom, #111111, #050505);
    border-bottom: 1px solid #333333;
    padding: 30px 20px; /* 縦幅を大幅にカット！ */
    text-align: center;
    margin-bottom: 40px;
}

.hero-main-text {
    font-size: 3.5rem; /* 巨大すぎた文字を調整 */
    font-weight: 900;
    color: #00ff41;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
    text-shadow: 0 0 20px rgba(0, 255, 65, 0.4);
}

.hero-concept-box {
    max-width: 800px;
    margin: 0 auto;
    border: 1px dashed #00ff41;
    background: rgba(0, 255, 65, 0.05);
    padding: 20px;
    border-radius: 8px;
}

.hero-lead {
    font-size: 1.1rem;
    color: #ffffff;
    font-weight: bold;
    margin-bottom: 10px;
}

.hero-sub {
    font-size: 0.95rem;
    color: #cccccc;
    line-height: 1.6;
}

/* ジャンル一覧エリア */
.top-main-content {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px;
}

.section-title {
    font-size: 1.5rem;
    color: #ffffff;
    text-align: center;
    margin-bottom: 30px;
    border-bottom: 2px solid #333333;
    padding-bottom: 10px;
}

/* 20ジャンルを美しく並べるグリッド（魔法の整列） */
.genre-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); /* 画面幅に合わせて自動で列数を調整 */
    gap: 20px;
    margin-bottom: 60px;
}

/* クリックしたくなるジャンルパネル */
.genre-card {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #111111;
    border: 1px solid #333333;
    padding: 20px;
    border-radius: 8px;
    text-decoration: none;
    transition: 0.3s;
}

.genre-icon {
    font-size: 1.8rem;
    margin-right: 15px;
}

.genre-name {
    font-size: 1.1rem;
    color: #ffffff;
    font-weight: bold;
}

.genre-card:hover {
    background-color: #1a1a1a;
    border-color: #00ff41;
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(0, 255, 65, 0.2);
}
.genre-card:hover .genre-name {
    color: #00ff41;
}
/* ==========================================
   トップページ（ポータル仕様）左右バナーの装飾
   ========================================== */

/* --- 左バナー：カテゴリーグループ見出し --- */
.nav-group-title {
    color: #d4af37; /* ゴールドで権威性を出す */
    font-size: 0.85rem;
    font-weight: bold;
    margin: 20px 0 10px 5px;
    border-bottom: 1px dashed #333333;
    padding-bottom: 5px;
}

/* ポータルナビゲーション内のアイテム（階層を表現） */
.portal-nav .nav-item {
    padding: 10px 10px 10px 15px; /* 少し字下げして目次っぽく */
    font-size: 0.85rem;
    background-color: transparent; /* 背景は透明にしてスッキリと */
    border: none;
    border-left: 2px solid transparent; /* 左側の線の準備 */
    margin-bottom: 2px;
}

/* マウスを乗せた時、左にネオングリーンの線が走るギミック */
.portal-nav .nav-item:hover {
    background-color: #1a1a1a;
    border-left: 2px solid #00ff41; 
    transform: none; /* メニューなので横揺れはさせずプロっぽく */
    box-shadow: none;
}

/* --- 右バナー：トレンド＆ニュース --- */

/* トレンド記事の特別装飾（赤色で緊急性と熱量を出す） */
.nav-item.trending {
    background: linear-gradient(90deg, rgba(255, 68, 68, 0.1), transparent);
    border-left: 2px solid #ff4444; 
    color: #ffaaaa;
}

.nav-item.trending:hover {
    background: linear-gradient(90deg, rgba(255, 68, 68, 0.2), transparent);
    border-left-color: #ff0000;
    color: #ffffff;
    transform: none;
    box-shadow: none;
}

/* サイト更新情報（ニュースティッカー風の黒い箱） */
.news-ticker {
    background-color: #111111;
    border: 1px solid #333333;
    border-radius: 4px;
    padding: 15px;
    font-size: 0.8rem;
}

/* ニュースの1行ずつを区切る */
.news-item {
    color: #cccccc;
    margin-bottom: 12px;
    line-height: 1.5;
    border-bottom: 1px dashed #222222;
    padding-bottom: 12px;
}

.news-item:last-child {
    margin-bottom: 0;
    border-bottom: none;
    padding-bottom: 0;
}

/* 日付をデジタルっぽく目立たせる */
.news-date {
    display: inline-block;
    color: #00ff41;
    font-weight: bold;
    margin-right: 8px;
    font-family: monospace; 
}
/* =================================================================
   【修正】トップページ（index.html）の表示調整＆エフェクト
================================================================= */

/* --- 1. 横幅ハミ出し防止＆全体の引き締め --- */
/* 画面からはみ出さないように全体の最大幅を制限する */
body, html {
    overflow-x: hidden; /* 横スクロールを強制的に禁止 */
    width: 100%;
}

/* コンテンツの幅を少し狭めて中央に寄せる */
.header-inner,
.hero-inner,
.top-main-content,
.footer-inner {
    max-width: 1100px; /* 幅を1200px→1100px程度に狭める */
    width: 95%;        /* スマホなどでギリギリにならないように余白を持たせる */
    margin-left: auto;
    margin-right: auto;
}

/* --- 2. 上部の余白を詰める --- */
/* ヘッダー下の余白を削除 */
.site-header {
    margin-bottom: 0;
    padding-bottom: 10px; /* ヘッダー自体の下部余白も少し削る */
}

/* ヒーローエリア（THE NO.1の場所）の上部余白を削って上に詰める */
.top-hero {
    padding-top: 15px; /* 30pxから半分に減らす */
    margin-top: 0;
}

/* --- 3. 「THE NO.1」を崩したお洒落なグリッチ風にする --- */
.hero-main-text {
    position: relative;
    color: #ffffff; /* ベースは白 */
    /* 赤と青の影を左右にずらして「デジタルなバグ（グリッチ）」を表現 */
    text-shadow: 
        3px 0px 1px rgba(255, 0, 0, 0.7),  /* 右に赤い影 */
        -3px 0px 1px rgba(0, 204, 255, 0.7); /* 左に青い影 */
    
    font-style: italic;    /* 少し斜めにしてスピード感を出す */
    letter-spacing: 0.05em; /* 文字間を少し詰める */
    transform: skewX(-10deg); /* 全体を少し斜めに歪ませる（崩し効果） */
}
/* --- 強制引き上げ：ヘッダーとTHE NO.1の隙間を限界まで詰める --- */

.site-header {
    padding-bottom: 5px !important;
    margin-bottom: 0 !important;
}

.site-header .tagline {
    margin-bottom: 0 !important; /* ヘッダーの文字が持つ下余白を殺す */
}

.top-hero {
    padding-top: 10px !important;
    margin-top: -15px !important; /* マイナス指定で強制的に上に引っ張り上げる！ */
}

.hero-main-text {
    margin-top: 0 !important; /* ブラウザが勝手につける上の余白を殺す */
    line-height: 1 !important; /* 文字の上下の空間をギリギリまで詰める */
}
/* =================================================================
   カテゴリートップページ（ハブ画面）専用デザイン
================================================================= */

/* ヒーロー（看板）エリア：ページを開いた瞬間のインパクト */
.category-hero {
    text-align: center;
    padding: 40px 20px 50px;
    margin-bottom: 40px;
    border-bottom: 1px dashed #333333;
    background: linear-gradient(to bottom, transparent, rgba(0, 255, 65, 0.02));
}

.category-sub {
    font-size: 0.85rem;
    color: #00ff41;
    letter-spacing: 0.2em;
    margin-bottom: 10px;
    font-weight: bold;
}

.category-title {
    font-size: 2.5rem;
    color: #ffffff;
    margin-bottom: 20px;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-shadow: 0 0 15px rgba(0, 255, 65, 0.3);
}

.category-lead {
    font-size: 1rem;
    color: #cccccc;
    line-height: 1.8;
    max-width: 700px;
    margin: 0 auto;
}

/* カテゴリーリンクのグリッド配置（PCで綺麗に並べる） */
.category-link-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 25px;
    margin-bottom: 60px;
}

/* 各ランキングへのリンクカード */
.category-card {
    display: block;
    background: #111111;
    border: 1px solid #333333;
    border-radius: 8px;
    padding: 30px 25px;
    text-decoration: none;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

/* カード上部の発光ライン（君の旧デザインのアイデアをネオングリーンで継承！） */
.category-card::before {
    content: "";
    position: absolute;
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 3px;
    background: linear-gradient(to right, #00ff41, #00aa2b);
    opacity: 0;
    transition: 0.4s;
}

/* マウスホバー時のリッチな演出 */
.category-card:hover {
    background: #1a1a1a;
    transform: translateY(-8px); /* フワッと浮き上がる */
    border-color: #00ff41;
    box-shadow: 0 10px 20px rgba(0, 255, 65, 0.1);
}

.category-card:hover::before {
    opacity: 1; /* 上部のラインが光る */
}

/* カード内のテキストやアイコンの装飾 */
.card-icon {
    font-size: 2.5rem;
    margin-bottom: 15px;
}

.card-name {
    font-size: 1.3rem;
    color: #ffffff;
    margin-bottom: 15px;
    font-weight: bold;
    transition: 0.3s;
}

.category-card:hover .card-name {
    color: #00ff41; /* タイトルも緑に発光 */
}

.card-desc {
    font-size: 0.9rem;
    color: #aaaaaa;
    line-height: 1.6;
    margin-bottom: 20px;
}

/* 「ランキングを見る」の矢印アクション */
.card-arrow {
    display: inline-block;
    font-size: 0.85rem;
    color: #00ff41;
    font-weight: bold;
    letter-spacing: 0.1em;
    transition: 0.3s;
}

.category-card:hover .card-arrow {
    transform: translateX(10px); /* 矢印が右にスライドしてクリックを誘う */
}
/* =================================================================
   証券ページ専用：第2位（楽天）・第3位（マネックス）のカラー設定
================================================================= */

/* --- 第2位：楽天証券（シルバー＆レッド） --- */
.rank-2 {
    background: linear-gradient(135deg, #c0c0c0, #808080);
    color: #ffffff;
}
.score-2 {
    color: #c0c0c0;
}
.btn-rakuten {
    background: linear-gradient(135deg, #bf0000, #8a0000);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(191, 0, 0, 0.3);
}
.btn-rakuten:hover {
    box-shadow: 0 8px 25px rgba(191, 0, 0, 0.5);
}
.rakuten-reason {
    border-color: #c0c0c0;
    background-color: rgba(192, 192, 192, 0.05);
}
.rakuten-reason .reason-title {
    color: #c0c0c0;
}
.rakuten-title {
    color: #ff4444;
}
.rakuten-merit li {
    border-left-color: #bf0000;
}
.rakuten-merit strong {
    color: #ff4d4d;
}

/* --- 第3位：マネックス証券（ブロンズ＆ブルー） --- */
.rank-3 {
    background: linear-gradient(135deg, #cd7f32, #8b5a2b);
    color: #ffffff;
}
.score-3 {
    color: #cd7f32;
}
.btn-monex {
    background: linear-gradient(135deg, #0055ff, #0033aa);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 85, 255, 0.3);
}
.btn-monex:hover {
    box-shadow: 0 8px 25px rgba(0, 85, 255, 0.5);
}
.monex-reason {
    border-color: #cd7f32;
    background-color: rgba(205, 127, 50, 0.05);
}
.monex-reason .reason-title {
    color: #cd7f32;
}
.monex-title {
    color: #6699ff;
}
.monex-merit li {
    border-left-color: #0055ff;
}
.monex-merit strong {
    color: #6699ff;
}

/* =================================================================
   最終結論エリア＆フッターリンクの装飾
================================================================= */
.conclusion-area {
    margin-top: 80px;
    padding-top: 40px;
    border-top: 2px dashed #333333;
    text-align: center;
}

.conclusion-title {
    font-size: 2rem;
    color: #ffffff;
    margin-bottom: 20px;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.2);
}

.conclusion-text {
    font-size: 1.1rem;
    color: #cccccc;
    line-height: 1.8;
    margin-bottom: 40px;
}

.highlight-green {
    color: #00ff41;
    font-size: 1.3rem;
    font-weight: bold;
    border-bottom: 2px solid #00ff41;
}

/* フッターの横並びリンク */
.footer-links {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: center;
    gap: 30px;
    margin-bottom: 25px;
}
.footer-links a {
    color: #888888;
    text-decoration: none;
    font-size: 0.9rem;
    transition: 0.3s;
}
.footer-links a:hover {
    color: #00ff41;
}
/* =================================================================
   ネット銀行ページ専用：第3位（auじぶん銀行）のカラー設定
================================================================= */

/* --- 第3位：auじぶん銀行（auオレンジ） --- */
.btn-au {
    background: linear-gradient(135deg, #ff6a00, #cc5500);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(255, 106, 0, 0.3);
}
.btn-au:hover {
    box-shadow: 0 8px 25px rgba(255, 106, 0, 0.5);
    transform: translateY(-3px);
}
.au-reason {
    border-color: #ff6a00;
    background-color: rgba(255, 106, 0, 0.05);
}
.au-reason .reason-title {
    color: #ff6a00;
}
.au-title {
    color: #ff8c00;
}
.au-merit li {
    border-left-color: #ff6a00;
}
.au-merit strong {
    color: #ff8c00;
}
/* =================================================================
   クレジットカードページ専用：第2位（楽天）・第3位（JCB）のカラー設定
================================================================= */

/* --- クレカ第2位：楽天カード（楽天レッド＆シルバー） --- */
.rakuten-card .btn-rakuten {
    background: linear-gradient(135deg, #bf0000, #ff3333); /* より鮮やかな赤 */
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(191, 0, 0, 0.3);
}
.rakuten-card .btn-rakuten:hover {
    box-shadow: 0 8px 25px rgba(191, 0, 0, 0.5);
    transform: translateY(-3px);
}
.rakuten-card .rakuten-reason {
    border-color: #c0c0c0;
    background-color: rgba(192, 192, 192, 0.05);
}
.rakuten-card .rakuten-reason .reason-title {
    color: #c0c0c0;
}
.rakuten-card .rakuten-title {
    color: #ff4444;
}
.rakuten-card .rakuten-merit li {
    border-left-color: #bf0000;
}
.rakuten-card .rakuten-merit strong {
    color: #ff4d4d;
}

/* --- クレカ第3位：JCB CARD W（JCBブルー＆ブロンズ） --- */
.jcb-card .btn-jcb {
    background: linear-gradient(135deg, #0055ff, #00aaff); /* 鮮やかなブルー */
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 85, 255, 0.3);
}
.jcb-card .btn-jcb:hover {
    box-shadow: 0 8px 25px rgba(0, 85, 255, 0.5);
    transform: translateY(-3px);
}
.jcb-card .jcb-reason {
    border-color: #cd7f32;
    background-color: rgba(205, 127, 50, 0.05);
}
.jcb-card .jcb-reason .reason-title {
    color: #cd7f32;
}
.jcb-card .jcb-title {
    color: #6699ff;
}
.jcb-card .jcb-merit li {
    border-left-color: #0055ff;
}
.jcb-card .jcb-merit strong {
    color: #6699ff;
}
/* =================================================================
   仮想通貨ページ専用：第2位（bitFlyer）・第3位（GMOコイン）のカラー設定
================================================================= */

/* --- 仮想通貨第2位：bitFlyer（クリムゾンレッド） --- */
.bitflyer-card .btn-bitflyer {
    background: linear-gradient(135deg, #d3002b, #99001b);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(211, 0, 43, 0.3);
}
.bitflyer-card .btn-bitflyer:hover {
    box-shadow: 0 8px 25px rgba(211, 0, 43, 0.5);
    transform: translateY(-3px);
}
.bitflyer-card .bitflyer-reason {
    border-color: #d3002b;
    background-color: rgba(211, 0, 43, 0.05);
}
.bitflyer-card .bitflyer-reason .reason-title {
    color: #ff3366;
}
.bitflyer-card .bitflyer-title {
    color: #ff3366;
}
.bitflyer-card .bitflyer-merit li {
    border-left-color: #d3002b;
}
.bitflyer-card .bitflyer-merit strong {
    color: #ff3366;
}

/* --- 仮想通貨第3位：GMOコイン（サイバーブルー） --- */
.gmo-card .btn-gmo {
    background: linear-gradient(135deg, #0077ff, #0044cc);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 119, 255, 0.3);
}
.gmo-card .btn-gmo:hover {
    box-shadow: 0 8px 25px rgba(0, 119, 255, 0.5);
    transform: translateY(-3px);
}
.gmo-card .gmo-reason {
    border-color: #0077ff;
    background-color: rgba(0, 119, 255, 0.05);
}
.gmo-card .gmo-reason .reason-title {
    color: #3399ff;
}
.gmo-card .gmo-title {
    color: #3399ff;
}
.gmo-card .gmo-merit li {
    border-left-color: #0077ff;
}
.gmo-card .gmo-merit strong {
    color: #3399ff;
}
/* =================================================================
   FXページ専用：第2位（GMOクリック証券）・第3位（松井証券）のカラー設定
================================================================= */

/* --- FX第2位：GMOクリック証券（メタリックブルー＆シルバー） --- */
.gmofx-card .btn-gmofx {
    background: linear-gradient(135deg, #0055a4, #003366); /* 深みのあるブルー */
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 85, 164, 0.3);
}
.gmofx-card .btn-gmofx:hover {
    box-shadow: 0 8px 25px rgba(0, 85, 164, 0.5);
    transform: translateY(-3px);
}
.gmofx-card .gmofx-reason {
    border-color: #0055a4;
    background-color: rgba(0, 85, 164, 0.05);
}
.gmofx-card .gmofx-reason .reason-title {
    color: #3388dd;
}
.gmofx-card .gmofx-title {
    color: #3388dd;
}
.gmofx-card .gmofx-merit li {
    border-left-color: #0055a4;
}
.gmofx-card .gmofx-merit strong {
    color: #3388dd;
}

/* --- FX第3位：松井証券（トラッドグリーン＆ゴールド） --- */
.matsui-card .btn-matsui {
    background: linear-gradient(135deg, #006633, #004422); /* 落ち着いたグリーン */
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 102, 51, 0.3);
}
.matsui-card .btn-matsui:hover {
    box-shadow: 0 8px 25px rgba(0, 102, 51, 0.5);
    transform: translateY(-3px);
}
.matsui-card .matsui-reason {
    border-color: #006633;
    background-color: rgba(0, 102, 51, 0.05);
}
.matsui-card .matsui-reason .reason-title {
    color: #33aa66;
}
.matsui-card .matsui-title {
    color: #33aa66;
}
.matsui-card .matsui-merit li {
    border-left-color: #006633;
}
.matsui-card .matsui-merit strong {
    color: #33aa66;
}
/* =================================================================
   カードローンページ専用：第2位（アコム）・第3位（SMBCモビット）のカラー設定
================================================================= */

/* --- 第2位：アコム（アコムレッド） --- */
.acom-card .btn-acom {
    background: linear-gradient(135deg, #e60012, #b3000e);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(230, 0, 18, 0.3);
}
.acom-card .btn-acom:hover {
    box-shadow: 0 8px 25px rgba(230, 0, 18, 0.5);
    transform: translateY(-3px);
}
.acom-card .acom-reason {
    border-color: #e60012;
    background-color: rgba(230, 0, 18, 0.05);
}
.acom-card .acom-reason .reason-title {
    color: #ff4d5c;
}
.acom-card .acom-title {
    color: #ff4d5c;
}
.acom-card .acom-merit li {
    border-left-color: #e60012;
}
.acom-card .acom-merit strong {
    color: #ff4d5c;
}

/* --- 第3位：SMBCモビット（モビットブルー） --- */
.mobit-card .btn-mobit {
    background: linear-gradient(135deg, #007bb5, #005a87);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 123, 181, 0.3);
}
.mobit-card .btn-mobit:hover {
    box-shadow: 0 8px 25px rgba(0, 123, 181, 0.5);
    transform: translateY(-3px);
}
.mobit-card .mobit-reason {
    border-color: #007bb5;
    background-color: rgba(0, 123, 181, 0.05);
}
.mobit-card .mobit-reason .reason-title {
    color: #33aadd;
}
.mobit-card .mobit-title {
    color: #33aadd;
}
.mobit-card .mobit-merit li {
    border-left-color: #007bb5;
}
.mobit-card .mobit-merit strong {
    color: #33aadd;
}
/* =================================================================
   運営者情報ページ（about/index.html）専用デザイン
================================================================= */

/* 1カラム用のコンテナ（幅を絞って読みやすくする） */
.about-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 60px 20px 100px;
}

/* トップに戻るボタン */
.back-home-btn {
    color: #888888;
    text-decoration: none;
    font-size: 0.9rem;
    transition: 0.3s;
    border: 1px solid #333;
    padding: 8px 15px;
    border-radius: 4px;
}
.back-home-btn:hover {
    color: #00ff41;
    border-color: #00ff41;
}

/* ヒーローエリア */
.about-hero {
    text-align: center;
    margin-bottom: 50px;
}
.about-subtitle {
    color: #00ff41;
    font-size: 0.9rem;
    letter-spacing: 0.2em;
    margin-bottom: 10px;
}
.about-title {
    font-size: 2.5rem;
    color: #ffffff;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
}
.title-line {
    width: 60px;
    height: 3px;
    background: #00ff41;
    margin: 0 auto;
    box-shadow: 0 0 10px rgba(0, 255, 65, 0.5);
}

/* プロフィールカード */
.profile-card {
    display: flex;
    align-items: center;
    background: #111111;
    border: 1px solid #333333;
    border-left: 4px solid #00ff41;
    padding: 25px 30px;
    border-radius: 8px;
    margin-bottom: 40px;
}
.profile-icon {
    font-size: 3.5rem;
    margin-right: 25px;
    filter: drop-shadow(0 0 5px rgba(0, 255, 65, 0.3));
}
.profile-name {
    font-size: 1.5rem;
    color: #ffffff;
    margin-bottom: 5px;
}
.profile-role {
    color: #888888;
    font-size: 0.9rem;
}

/* メッセージボックス（想いを綴るエリア） */
.message-box {
    background: linear-gradient(to bottom, rgba(17, 17, 17, 0.8), rgba(0, 0, 0, 0.5));
    border: 1px dashed #444444;
    padding: 40px;
    border-radius: 12px;
    margin-bottom: 50px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}
.message-box p {
    color: #dddddd;
    font-size: 1.1rem;
    line-height: 2.0;
    margin-bottom: 25px;
    letter-spacing: 0.05em;
}
.message-box p:last-child {
    margin-bottom: 0;
}
.notice-text {
    font-size: 0.85rem !important;
    color: #888888 !important;
    border-top: 1px solid #333;
    padding-top: 20px;
    margin-top: 30px;
}

/* お問い合わせエリア */
.contact-area {
    text-align: center;
    padding: 40px;
    background: #0a0e17;
    border-radius: 8px;
}
.contact-area p {
    color: #aaaaaa;
    font-size: 1rem;
    line-height: 1.8;
    margin-bottom: 30px;
}
.outline-btn {
    background: transparent;
    border: 2px solid #00ff41;
    color: #00ff41;
}
.outline-btn:hover {
    background: rgba(0, 255, 65, 0.1);
    box-shadow: 0 0 20px rgba(0, 255, 65, 0.3);
}
/* =================================================================
   保険ページ専用：第2位（ライフネット）・第3位（ソニー損保）のカラー設定
================================================================= */

/* --- 保険第2位：ライフネット生命（スカイブルー） --- */
.lifenet-card .btn-lifenet {
    background: linear-gradient(135deg, #00bfff, #0088cc);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 191, 255, 0.3);
}
.lifenet-card .btn-lifenet:hover {
    box-shadow: 0 8px 25px rgba(0, 191, 255, 0.5);
    transform: translateY(-3px);
}
.lifenet-card .lifenet-reason {
    border-color: #00bfff;
    background-color: rgba(0, 191, 255, 0.05);
}
.lifenet-card .lifenet-reason .reason-title {
    color: #33ccff;
}
.lifenet-card .lifenet-title {
    color: #33ccff;
}
.lifenet-card .lifenet-merit li {
    border-left-color: #00bfff;
}
.lifenet-card .lifenet-merit strong {
    color: #33ccff;
}

/* --- 保険第3位：ソニー損保（ディープパープル） --- */
.sony-card .btn-sony {
    background: linear-gradient(135deg, #6600cc, #440099);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(102, 0, 204, 0.3);
}
.sony-card .btn-sony:hover {
    box-shadow: 0 8px 25px rgba(102, 0, 204, 0.5);
    transform: translateY(-3px);
}
.sony-card .sony-reason {
    border-color: #6600cc;
    background-color: rgba(102, 0, 204, 0.05);
}
.sony-card .sony-reason .reason-title {
    color: #9933ff;
}
.sony-card .sony-title {
    color: #9933ff;
}
.sony-card .sony-merit li {
    border-left-color: #6600cc;
}
.sony-card .sony-merit strong {
    color: #9933ff;
}
/* =================================================================
   ロボアドページ専用：第2位（THEO+ docomo）・第3位（ROBO PRO）のカラー設定
================================================================= */

/* --- ロボアド第2位：THEO+ docomo（ドコモレッド） --- */
.theo-card .btn-theo {
    background: linear-gradient(135deg, #e6004c, #b3003b);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(230, 0, 76, 0.3);
}
.theo-card .btn-theo:hover {
    box-shadow: 0 8px 25px rgba(230, 0, 76, 0.5);
    transform: translateY(-3px);
}
.theo-card .theo-reason {
    border-color: #e6004c;
    background-color: rgba(230, 0, 76, 0.05);
}
.theo-card .theo-reason .reason-title {
    color: #ff3377;
}
.theo-card .theo-title {
    color: #ff3377;
}
.theo-card .theo-merit li {
    border-left-color: #e6004c;
}
.theo-card .theo-merit strong {
    color: #ff3377;
}

/* --- ロボアド第3位：FOLIO ROBO PRO（サイバーシアン） --- */
.robo-card .btn-robo {
    background: linear-gradient(135deg, #00b8d9, #0088aa);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 184, 217, 0.3);
}
.robo-card .btn-robo:hover {
    box-shadow: 0 8px 25px rgba(0, 184, 217, 0.5);
    transform: translateY(-3px);
}
.robo-card .robo-reason {
    border-color: #00b8d9;
    background-color: rgba(0, 184, 217, 0.05);
}
.robo-card .robo-reason .reason-title {
    color: #33ccff;
}
.robo-card .robo-title {
    color: #33ccff;
}
.robo-card .robo-merit li {
    border-left-color: #00b8d9;
}
.robo-card .robo-merit strong {
    color: #33ccff;
}
/* =================================================================
   ビジネスカード専用：第2位（マネフォ）・第3位（セゾン）のカラー設定
================================================================= */

/* --- ビジネス第2位：マネーフォワード（ビビッドオレンジ） --- */
.mf-card .btn-mf {
    background: linear-gradient(135deg, #ff6600, #cc5200);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(255, 102, 0, 0.3);
}
.mf-card .btn-mf:hover {
    box-shadow: 0 8px 25px rgba(255, 102, 0, 0.5);
    transform: translateY(-3px);
}
.mf-card .mf-reason {
    border-color: #ff6600;
    background-color: rgba(255, 102, 0, 0.05);
}
.mf-card .mf-reason .reason-title {
    color: #ff8533;
}
.mf-card .mf-title {
    color: #ff8533;
}
.mf-card .mf-merit li {
    border-left-color: #ff6600;
}
.mf-card .mf-merit strong {
    color: #ff8533;
}

/* --- ビジネス第3位：セゾンプラチナ（プラチナシルバー＆ブラック） --- */
.saison-card .btn-saison {
    background: linear-gradient(135deg, #a6b1b8, #5e6b73);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(166, 177, 184, 0.3);
}
.saison-card .btn-saison:hover {
    box-shadow: 0 8px 25px rgba(166, 177, 184, 0.5);
    transform: translateY(-3px);
}
.saison-card .saison-reason {
    border-color: #a6b1b8;
    background-color: rgba(166, 177, 184, 0.05);
}
.saison-card .saison-reason .reason-title {
    color: #c0cdd6;
}
.saison-card .saison-title {
    color: #c0cdd6;
}
.saison-card .saison-merit li {
    border-left-color: #a6b1b8;
}
.saison-card .saison-merit strong {
    color: #c0cdd6;
}
/* =================================================================
   ポイント高還元クレカ専用：第2位（楽天）・第3位（PayPay）のカラー設定
================================================================= */

/* --- 高還元第2位：楽天カード（楽天クリムゾンレッド） --- */
.rakuten-card .btn-rakuten {
    background: linear-gradient(135deg, #bf0000, #8c0000);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(191, 0, 0, 0.3);
}
.rakuten-card .btn-rakuten:hover {
    box-shadow: 0 8px 25px rgba(191, 0, 0, 0.5);
    transform: translateY(-3px);
}
.rakuten-card .rakuten-reason {
    border-color: #bf0000;
    background-color: rgba(191, 0, 0, 0.05);
}
.rakuten-card .rakuten-reason .reason-title {
    color: #ff3333;
}
.rakuten-card .rakuten-title {
    color: #ff3333;
}
.rakuten-card .rakuten-merit li {
    border-left-color: #bf0000;
}
.rakuten-card .rakuten-merit strong {
    color: #ff3333;
}

/* --- 高還元第3位：PayPayカード（PayPayビビッドレッド） --- */
.paypay-card .btn-paypay {
    background: linear-gradient(135deg, #ff0033, #cc0029);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(255, 0, 51, 0.3);
}
.paypay-card .btn-paypay:hover {
    box-shadow: 0 8px 25px rgba(255, 0, 51, 0.5);
    transform: translateY(-3px);
}
.paypay-card .paypay-reason {
    border-color: #ff0033;
    background-color: rgba(255, 0, 51, 0.05);
}
.paypay-card .paypay-reason .reason-title {
    color: #ff4d79;
}
.paypay-card .paypay-title {
    color: #ff4d79;
}
.paypay-card .paypay-merit li {
    border-left-color: #ff0033;
}
.paypay-card .paypay-merit strong {
    color: #ff4d79;
}
/* =================================================================
   学生クレカ専用：第2位（三井住友NL）・第3位（エポス）のカラー設定
================================================================= */

/* --- 学生クレカ第2位：三井住友カード（NL）（フォレストグリーン） --- */
.smcc-nl-card .btn-smcc-nl {
    background: linear-gradient(135deg, #007042, #004d2e);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 112, 66, 0.3);
}
.smcc-nl-card .btn-smcc-nl:hover {
    box-shadow: 0 8px 25px rgba(0, 112, 66, 0.5);
    transform: translateY(-3px);
}
.smcc-nl-card .smcc-nl-reason {
    border-color: #007042;
    background-color: rgba(0, 112, 66, 0.05);
}
.smcc-nl-card .smcc-nl-reason .reason-title {
    color: #00b36b;
}
.smcc-nl-card .smcc-nl-title {
    color: #00b36b;
}
.smcc-nl-card .smcc-nl-merit li {
    border-left-color: #007042;
}
.smcc-nl-card .smcc-nl-merit strong {
    color: #00b36b;
}

/* --- 学生クレカ第3位：エポスカード（ルージュレッド） --- */
.epos-card .btn-epos {
    background: linear-gradient(135deg, #e6002d, #b30023);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(230, 0, 45, 0.3);
}
.epos-card .btn-epos:hover {
    box-shadow: 0 8px 25px rgba(230, 0, 45, 0.5);
    transform: translateY(-3px);
}
.epos-card .epos-reason {
    border-color: #e6002d;
    background-color: rgba(230, 0, 45, 0.05);
}
.epos-card .epos-reason .reason-title {
    color: #ff335e;
}
.epos-card .epos-title {
    color: #ff335e;
}
.epos-card .epos-merit li {
    border-left-color: #e6002d;
}
.epos-card .epos-merit strong {
    color: #ff335e;
}
/* =================================================================
   旅行クレカ専用：第2位（ANAアメックスG）・第3位（マイレージプラス）のカラー設定
================================================================= */

/* --- 旅行クレカ第2位：ANAアメックス・ゴールド（ゴールド＆ANAブルー） --- */
.ana-amex-card .btn-ana-amex {
    background: linear-gradient(135deg, #d4af37, #b58500);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(212, 175, 55, 0.3);
}
.ana-amex-card .btn-ana-amex:hover {
    box-shadow: 0 8px 25px rgba(212, 175, 55, 0.5);
    transform: translateY(-3px);
}
.ana-amex-card .ana-amex-reason {
    border-color: #d4af37;
    background-color: rgba(212, 175, 55, 0.05);
}
.ana-amex-card .ana-amex-reason .reason-title {
    color: #e6c24d;
}
.ana-amex-card .ana-amex-title {
    color: #e6c24d;
}
.ana-amex-card .ana-amex-merit li {
    border-left-color: #d4af37;
}
.ana-amex-card .ana-amex-merit strong {
    color: #e6c24d;
}

/* --- 旅行クレカ第3位：MileagePlusセゾン（ユナイテッド・ディープブルー） --- */
.united-saison-card .btn-united-saison {
    background: linear-gradient(135deg, #002244, #003366);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 51, 102, 0.4);
    border: 1px solid #0055a4;
}
.united-saison-card .btn-united-saison:hover {
    box-shadow: 0 8px 25px rgba(0, 51, 102, 0.6);
    transform: translateY(-3px);
    background: linear-gradient(135deg, #003366, #004488);
}
.united-saison-card .united-saison-reason {
    border-color: #004488;
    background-color: rgba(0, 51, 102, 0.1);
}
.united-saison-card .united-saison-reason .reason-title {
    color: #4d94ff;
}
.united-saison-card .united-saison-title {
    color: #4d94ff;
}
.united-saison-card .united-saison-merit li {
    border-left-color: #004488;
}
.united-saison-card .united-saison-merit strong {
    color: #4d94ff;
}
/* =================================================================
   審査不安クレカ専用：第2位（ライフカードCh）・第3位（メルカード）のカラー設定
================================================================= */

/* --- 審査不安第2位：ライフカード（Ch）（トラストブルー） --- */
.lifecard-ch .btn-lifecard {
    background: linear-gradient(135deg, #0055a4, #003366);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 85, 164, 0.3);
}
.lifecard-ch .btn-lifecard:hover {
    box-shadow: 0 8px 25px rgba(0, 85, 164, 0.5);
    transform: translateY(-3px);
}
.lifecard-ch .lifecard-reason {
    border-color: #0055a4;
    background-color: rgba(0, 85, 164, 0.05);
}
.lifecard-ch .lifecard-reason .reason-title {
    color: #3388ff;
}
.lifecard-ch .lifecard-title {
    color: #3388ff;
}
.lifecard-ch .lifecard-merit li {
    border-left-color: #0055a4;
}
.lifecard-ch .lifecard-merit strong {
    color: #3388ff;
}

/* --- 審査不安第3位：メルカード（メルカリレッド） --- */
.mercard .btn-mercard {
    background: linear-gradient(135deg, #e32c36, #b31e26);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(227, 44, 54, 0.3);
}
.mercard .btn-mercard:hover {
    box-shadow: 0 8px 25px rgba(227, 44, 54, 0.5);
    transform: translateY(-3px);
}
.mercard .mercard-reason {
    border-color: #e32c36;
    background-color: rgba(227, 44, 54, 0.05);
}
.mercard .mercard-reason .reason-title {
    color: #ff4d58;
}
.mercard .mercard-title {
    color: #ff4d58;
}
.mercard .mercard-merit li {
    border-left-color: #e32c36;
}
.mercard .mercard-merit strong {
    color: #ff4d58;
}
/* =================================================================
   即日発行クレカ専用：第3位（JCB CARD W）のカラー設定
================================================================= */

/* --- 即日発行第3位：JCB CARD W（JCBソリッドブルー） --- */
.jcbw-card .btn-jcbw {
    background: linear-gradient(135deg, #005b9f, #004070);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 91, 159, 0.3);
}
.jcbw-card .btn-jcbw:hover {
    box-shadow: 0 8px 25px rgba(0, 91, 159, 0.5);
    transform: translateY(-3px);
}
.jcbw-card .jcbw-reason {
    border-color: #005b9f;
    background-color: rgba(0, 91, 159, 0.05);
}
.jcbw-card .jcbw-reason .reason-title {
    color: #1a8cff;
}
.jcbw-card .jcbw-title {
    color: #1a8cff;
}
.jcbw-card .jcbw-merit li {
    border-left-color: #005b9f;
}
.jcbw-card .jcbw-merit strong {
    color: #1a8cff;
}
/* =================================================================
   特定経済圏クレカ専用：第1位（Amazon）・第2位（イオン）・第3位（楽天）
================================================================= */

/* --- 経済圏第1位：Amazonカード（ダーク＆オレンジ） --- */
.amazon-card .btn-primary {
    background: linear-gradient(135deg, #232f3e, #131a22);
    color: #ff9900;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.4);
    border: 1px solid #ff9900;
}
.amazon-card .btn-primary:hover {
    box-shadow: 0 8px 25px rgba(255, 153, 0, 0.4);
    transform: translateY(-3px);
    background: linear-gradient(135deg, #131a22, #000000);
}

/* --- 経済圏第2位：イオンカードセレクト（イオンマゼンタ） --- */
.aeon-card .btn-aeon {
    background: linear-gradient(135deg, #b5007d, #800058);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(181, 0, 125, 0.3);
}
.aeon-card .btn-aeon:hover {
    box-shadow: 0 8px 25px rgba(181, 0, 125, 0.5);
    transform: translateY(-3px);
}
.aeon-card .aeon-reason {
    border-color: #b5007d;
    background-color: rgba(181, 0, 125, 0.05);
}
.aeon-card .aeon-reason .reason-title {
    color: #ff33b5;
}
.aeon-card .aeon-title {
    color: #ff33b5;
}
.aeon-card .aeon-merit li {
    border-left-color: #b5007d;
}
.aeon-card .aeon-merit strong {
    color: #ff33b5;
}

/* --- 経済圏第3位：楽天カード（楽天クリムゾンレッド） --- */
.rakuten-eco-card .btn-rakuten {
    background: linear-gradient(135deg, #bf0000, #8c0000);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(191, 0, 0, 0.3);
}
.rakuten-eco-card .btn-rakuten:hover {
    box-shadow: 0 8px 25px rgba(191, 0, 0, 0.5);
    transform: translateY(-3px);
}
.rakuten-eco-card .rakuten-eco-reason {
    border-color: #bf0000;
    background-color: rgba(191, 0, 0, 0.05);
}
.rakuten-eco-card .rakuten-eco-reason .reason-title {
    color: #ff3333;
}
.rakuten-eco-card .rakuten-eco-title {
    color: #ff3333;
}
.rakuten-eco-card .rakuten-eco-merit li {
    border-left-color: #bf0000;
}
.rakuten-eco-card .rakuten-eco-merit strong {
    color: #ff3333;
}
/* =================================================================
   🏦 ネット銀行・手数料ゼロ決定戦：各銀行の専用ブランドカラー
================================================================= */

/* --- 第1位：住信SBIネット銀行（スマート・ブルー） --- */
.sbi-netbank .btn-primary {
    background: linear-gradient(135deg, #0066cc, #004c99);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 102, 204, 0.3);
    border: none;
}
.sbi-netbank .btn-primary:hover {
    box-shadow: 0 8px 25px rgba(0, 102, 204, 0.5);
    transform: translateY(-3px);
    background: linear-gradient(135deg, #005bb5, #003366);
}
.sbi-netbank .reason-box {
    border-color: #0066cc;
    background-color: rgba(0, 102, 204, 0.05);
}
.sbi-netbank .reason-box .reason-title {
    color: #005bb5;
}
.sbi-netbank .detail-title {
    color: #005bb5;
    border-bottom: 2px solid #0066cc;
}
.sbi-netbank .merit-list li {
    border-left-color: #0066cc;
}
.sbi-netbank .merit-list strong {
    color: #005bb5;
}

/* --- 第2位：SBI新生銀行（新生ティール・グリーン） --- */
.shinsei-bank .btn-primary {
    background: linear-gradient(135deg, #009988, #007766);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(0, 153, 136, 0.3);
    border: none;
}
.shinsei-bank .btn-primary:hover {
    box-shadow: 0 8px 25px rgba(0, 153, 136, 0.5);
    transform: translateY(-3px);
    background: linear-gradient(135deg, #008877, #005544);
}
.shinsei-bank .reason-box {
    border-color: #009988;
    background-color: rgba(0, 153, 136, 0.05);
}
.shinsei-bank .reason-box .reason-title {
    color: #008877;
}
.shinsei-bank .detail-title {
    color: #008877;
    border-bottom: 2px solid #009988;
}
.shinsei-bank .merit-list li {
    border-left-color: #009988;
}
.shinsei-bank .merit-list strong {
    color: #008877;
}

/* --- 第3位：auじぶん銀行（auオレンジ） --- */
.au-jibun .btn-primary {
    background: linear-gradient(135deg, #e54300, #cc3c00);
    color: #ffffff;
    box-shadow: 0 5px 15px rgba(229, 67, 0, 0.3);
    border: none;
}
.au-jibun .btn-primary:hover {
    box-shadow: 0 8px 25px rgba(229, 67, 0, 0.5);
    transform: translateY(-3px);
    background: linear-gradient(135deg, #d33e00, #b33400);
}
.au-jibun .reason-box {
    border-color: #e54300;
    background-color: rgba(229, 67, 0, 0.05);
}
.au-jibun .reason-box .reason-title {
    color: #d33e00;
}
.au-jibun .detail-title {
    color: #d33e00;
    border-bottom: 2px solid #e54300;
}
.au-jibun .merit-list li {
    border-left-color: #e54300;
}
.au-jibun .merit-list strong {
    color: #d33e00;
}
/* =================================================================
   👑 ステータス・モテる（ゴールド・プレミアム）専用スタイル
================================================================= */

/* -------------------------------------
   👑 第2位：JCBゴールド（シャンパンゴールド）
------------------------------------- */
.jcb-gold {
    border-top: 5px solid #d4af37 !important; /* 品格のあるシャンパンゴールド */
    background: linear-gradient(to bottom, #fffdf5, #ffffff) !important;
}
.jcb-gold .rank-badge {
    background: linear-gradient(135deg, #d4af37, #aa8529) !important;
    color: #fff !important;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.3) !important;
}
.jcb-gold .score-number {
    color: #d4af37 !important;
}

/* -------------------------------------
   👑 第3位：マリオット・アメックス（マットブラック）
------------------------------------- */
.marriott-amex {
    border-top: 5px solid #1a1a1a !important; /* アメックス特有の漆黒 */
    background: linear-gradient(to bottom, #fafcfd, #ffffff) !important;
}
.marriott-amex .rank-badge {
    background: linear-gradient(135deg, #2c3e50, #000000) !important; /* 漆黒とネイビーの高級感 */
    color: #fff !important;
    text-shadow: 1px 1px 2px rgba(255,255,255,0.3) !important;
}
.marriott-amex .score-number {
    color: #1a1a1a !important;
}

/* -------------------------------------
   💡 結論セクションの装飾
------------------------------------- */
.conclusion-section {
    margin-top: 50px !important;
    padding: 30px !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
    border: 2px solid #333 !important;
}
.conclusion-title {
    font-size: 1.5rem !important;
    color: #333 !important;
    border-bottom: 3px solid #ffd700 !important; /* ゴールドのアンダーライン */
    padding-bottom: 10px !important;
    margin-bottom: 20px !important;
}
.conclusion-list li {
    margin-bottom: 15px !important;
    padding-left: 1.5em !important;
    text-indent: -1.5em !important;
    line-height: 1.6 !important;
}
.conclusion-list li::before {
    content: "👑" !important; /* 結論のリストマークを王冠に */
    margin-right: 5px !important;
}
