.case-detail-hero { padding: 80px 20px 40px; text-align: center; }
.case-detail-hero h1 { font-size: 48px; color: #111; font-family: 'title-font', cursive; margin-bottom: 20px; }
.case-detail-hero .subtitle { font-size: 22px; color: #ed5848; font-weight: bold; }
.main-visual { width: 80%; max-width: 800px; margin: 20px auto 60px; line-height: 0; }
.main-visual img { width: 100%; height: auto; max-height: 500px; object-fit: cover; border-radius: 15px; box-shadow: 0 10px 40px rgba(0,0,0,0.06); }
.content-section { max-width: 1000px; margin: 0 auto 80px; padding: 0 20px; }
.case-card { display: flex; align-items: center; gap: 50px; background: #fff; padding: 40px; border-radius: 20px; border: 1px solid #eee; margin-bottom: 40px; }
.case-card.reverse { flex-direction: row-reverse; }
.card-img-box { width: 48%; border-radius: 12px; overflow: hidden; }
.card-img-box img { width: 100%; height: auto; display: block; }
.case-card .text-box { width: 52%; padding-top: 10px; }
.case-card h4 { font-size: 26px; color: #ed5848; margin-bottom: 20px; font-weight: bold; word-break: keep-all; line-height: 1.4; }
.case-card p { font-size: 18px; color: #555; line-height: 1.8; word-break: keep-all; }
.case-card ul { margin-top: 20px; padding-left: 20px; }
.case-card li { font-size: 17px; color: #666; margin-bottom: 12px; list-style: disc; }
@media (max-width: 768px) { .case-card { flex-direction: column !important; padding: 30px 20px; } .card-img-box, .case-card .text-box { width: 100%; } .case-detail-hero h1 { font-size: 32px; } }
