/* Start custom CSS for html, class: .elementor-element-75d0720 *//* --- プロフェッショナル・スタイル：フォント強制・画像対応版 --- */

.pro-case-study, .pro-case-study * {
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif !important;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
}

.pro-case-study {
    max-width: 900px;
    margin: 40px auto;
    background: #ffffff;
    color: #2d3748;
    line-height: 1.7;
    border: 1px solid #e2e8f0;
}

/* ヘッダー */
.pro-header { background: #003366; color: #ffffff; padding: 60px 40px; text-align: center; }
.pro-tag { display: inline-block; font-size: 0.8rem; letter-spacing: 0.1em; font-weight: bold; color: #ffcc00; margin-bottom: 15px; }
.pro-header h1 { margin: 0; font-size: 1.8rem; font-weight: 700; color: #ffffff !important; line-height: 1.3; }
.pro-header h1 small { display: block; font-size: 1rem; font-weight: 400; margin-top: 10px; opacity: 0.8; }

/* セクション共通 */
.pro-content { padding: 40px; }
.pro-section { margin-bottom: 60px; }
.pro-h2 { font-size: 1.4rem; font-weight: 700; border-left: 6px solid #003366; padding-left: 15px; margin-bottom: 20px; color: #003366 !important; }
.pro-p { font-size: 0.95rem; margin-bottom: 1.2rem; color: #2d3748 !important; }
.pro-p-bold { font-weight: bold; margin-bottom: 5px; font-size: 1rem; }
.pro-p-small { font-size: 0.85rem; color: #4a5568 !important; margin: 0; }

/* 画像エリアの調整（imgタグ用） */
.pro-img-area {
    margin: 30px 0;
    text-align: center;
}
.pro-img-area img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    display: block;
    margin: 0 auto;
}

/* 業務フロー */
.pro-step-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.pro-step-card { background: #f8fafc; padding: 25px; border-radius: 8px; border: 1px solid #e2e8f0; position: relative; }
.pro-step-card.highlight-card { border: 2px solid #003366; background: #fff; }
.step-label { display: inline-block; font-size: 0.7rem; font-weight: bold; background: #003366; color: #fff; padding: 2px 8px; border-radius: 3px; margin-bottom: 10px; }

/* テーブル */
.pro-table { width: 100%; border-collapse: collapse; margin-top: 10px; }
.pro-table th, .pro-table td { border: 1px solid #e2e8f0; padding: 12px 15px; text-align: left; font-size: 0.9rem; }
.pro-table th { background: #f8fafc; color: #003366; font-weight: bold; }

/* 費用カード（横並び） */
.pro-cost-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.cost-card-item { padding: 25px; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; text-align: center; }
.cost-card-item.highlight-border { border: 2px solid #003366; background: #fff; }
.cost-label { display: block; font-size: 0.85rem; font-weight: bold; color: #64748b; margin-bottom: 5px; }
.cost-val { display: block; font-size: 1.6rem; font-weight: 700; color: #003366; margin-bottom: 5px; }
.pro-p-xs { font-size: 0.75rem; color: #718096; margin: 0; }

/* カスタマイズ詳細 */
.pro-custom-box { background: #fff; border: 1px solid #e2e8f0; border-left: 5px solid #003366; padding: 20px; border-radius: 0 8px 8px 0; margin-bottom: 20px; }
.pro-h3 { margin-top: 0; font-size: 1.1rem; color: #003366 !important; font-weight: bold; }
.pro-ul { padding-left: 18px; margin-top: 10px; }
.pro-ul li { font-size: 0.9rem; margin-bottom: 6px; color: #2d3748 !important; }
.pro-note { color: #718096; font-size: 0.8rem; display: block; margin-top: 5px; }

/* プラグイングリッド */
.pro-tool-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 15px; }
.pro-tool-card {
    display: block; text-decoration: none; color: inherit; border: 1px solid #e2e8f0;
    padding: 15px; border-radius: 8px; background: #fff; transition: 0.2s;
}
.pro-tool-card:hover { border-color: #003366; transform: translateY(-3px); }
.pro-h4 { margin: 8px 0 5px; color: #003366 !important; font-size: 0.95rem; font-weight: bold; }
.rank-badge { font-size: 0.65rem; font-weight: bold; color: #fff; padding: 1px 5px; border-radius: 2px; }
.rank-badge.s { background: #e53e3e; }
.rank-badge.a { background: #38a169; }

/* 拡張提案 */
.pro-bg-light { background: #f8fafc; padding: 30px; border-radius: 8px; }
.pro-ext-item { margin-bottom: 20px; border-bottom: 1px solid #e2e8f0; padding-bottom: 15px; }
.pro-ext-item:last-child { border-bottom: none; margin-bottom: 0; }
.pro-h5 { color: #d32f2f !important; margin: 0 0 5px; font-size: 0.95rem; font-weight: bold; }

/* ビフォーアフター */
.pro-ba { display: flex; gap: 20px; }
.ba-box { flex: 1; padding: 20px; border-radius: 8px; }
.ba-box.before { background: #f1f5f9; }
.ba-box.after { background: #003366; color: #fff; }
.ba-box.after p { color: #fff !important; }
.ba-label { font-weight: bold; font-size: 0.7rem; margin-bottom: 8px; display: block; opacity: 0.8; }

/* CTA・ボタン */
.pro-cta { text-align: center; background: #003366; color: #fff; padding: 60px 40px; }
.pro-h3-white { color: #ffffff !important; font-size: 1.3rem; margin-bottom: 10px; }
.pro-p-white { color: rgba(255,255,255,0.8) !important; font-size: 0.95rem; }
.pro-cta-btn {
    display: inline-block; background: #ffcc00; color: #1a202c !important; padding: 15px 40px;
    border-radius: 4px; text-decoration: none; font-weight: bold; font-size: 1.1rem; margin-top: 20px;
}
.pro-btn-center { text-align: center; margin-top: 20px; }
.pro-outline-btn {
    display: inline-block; padding: 10px 25px; border: 2px solid #003366; color: #003366 !important;
    text-decoration: none; font-weight: bold; border-radius: 4px; font-size: 0.9rem;
}

/* スマホ対応 */
@media (max-width: 650px) {
    .pro-step-grid, .pro-cost-grid, .pro-ba { grid-template-columns: 1fr; }
    .pro-content { padding: 30px 20px; }
}/* End custom CSS */