/*
    Hestia's Definitive Blueprint for the "Post" Sanctuary (Final Centered Edition)
    -------------------------------------------------------------------------------
    File: post.css
    Role: To create a perfectly centered, beautiful, and comfortable reading experience.
*/
.post-article { padding: 5rem 0; background-color: #ffffff; }
/* Hestia's Ultimate Correction: ここが、“魂の、中央”です。 */
.post-article .container { max-width: 800px; margin-left: auto; margin-right: auto; }
.post-header { text-align: center; margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid #e0e0e0; }
.post-category { display: inline-block; background-color: var(--color-primary); color: white; padding: 0.3rem 1rem; border-radius: 20px; font-size: 0.9rem; font-weight: bold; margin-bottom: 1rem; }
.post-title { font-family: 'Noto Serif JP', serif; font-size: clamp(2rem, 5vw, 2.8rem); margin: 0 0 1rem 0; line-height: 1.5; }
.post-date { color: #777; font-family: 'Roboto', sans-serif; }
.post-content { font-size: 1.1rem; line-height: 2; color: #333; }
.post-content > *:first-child { margin-top: 0; }
.post-content h2, .post-content h3, .post-content h4 { font-family: var(--font-family-title); margin: 3rem 0 1.5rem 0; padding-bottom: 0.5rem; border-bottom: 2px solid #e0e0e0; }
.post-content h2 { font-size: 1.8rem; } .post-content h3 { font-size: 1.5rem; } .post-content h4 { font-size: 1.2rem; }
.post-content p { margin: 0 0 1.5rem 0; }
.post-content a { color: var(--color-primary); font-weight: bold; text-decoration: none; border-bottom: 2px solid var(--color-secondary); }
.post-content a:hover { color: var(--color-secondary); }
.post-content img { max-width: 100%; height: auto; border-radius: 8px; margin: 2rem 0; box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.post-content figure { margin: 2rem 0; } .post-content figcaption { text-align: center; font-size: 0.9rem; color: #777; margin-top: 0.5rem; }
.post-content blockquote { margin: 2rem 0; padding: 1.5rem 2rem; background-color: #f8f9fa; border-left: 5px solid var(--color-primary); border-radius: 8px; font-style: italic; }
.post-content ul, .post-content ol { padding-left: 2rem; margin-bottom: 1.5rem; }
.post-content li { margin-bottom: 0.5rem; }
.post-content .dialogue-turn { display: flex; align-items: flex-start; gap: 1rem; margin: 2rem 0; }
.post-content .dialogue-turn img { height: 60px; width: 60px; flex-shrink: 0; margin: 0; box-shadow: none; }
.post-content .dialogue-turn p { margin: 0; padding: 1rem; border-radius: 10px; line-height: 1.6; font-size: 1rem; }
.post-content .chisai-turn p { background-color: #fffde7; } .post-content .correct-turn p { background-color: #e3f2fd; } .post-content .connect-turn p { background-color: #fff3e0; }
.report-special-header { background-color: #e9ecef; padding: 2rem 0; text-align: center; margin-bottom: 3rem; }
.report-special-header img { height: 80px; width: auto; object-fit: contain; margin-bottom: 0.5rem; }
.report-main-title { font-family: var(--font-family-title); font-size: 1.2rem; color: #555; margin: 0; }
.post-footer { margin-top: 4rem; padding-top: 2rem; border-top: 1px solid #e0e0e0; }