/*
 * ===================================================================
 * MyBlogBuilder Official Theme CSS
 * Version: 2.0 (mbb-style)
 * Updated: 2025-08-05
 * Author: MyBlogBuilder
 * Description: This stylesheet provides all necessary styles for
 * content generated by the MyBlogBuilder prompt.
 * ===================================================================
 */

/* 1. 기본 설정 및 변수 정의 (Global Settings & Variables)
------------------------------------------------------------------- */
:root {
    /* Color Palette */
    --mbb-color-primary: #1abc9c;        /* Main Teal */
    --mbb-color-primary-dark: #1a5a4d;  /* Dark Green-Teal */
    --mbb-color-accent-orange: #ff6f00;   /* Bright Orange for Questions */
    --mbb-color-accent-yellow: #db9d00;   /* Yellowish Orange */
    --mbb-color-text-dark: #333333;       /* Main text color */
    --mbb-color-text-light: #5f5f5f;       /* Lighter text, answers */
    --mbb-color-text-white: #ffffff;       /* White text */
    --mbb-color-grey-bg: #f8f9fa;         /* Light grey background */
    --mbb-color-grey-border: #e9ecef;       /* Light grey border */
    --mbb-color-grey-medium: #7a7a7a;     /* Medium Grey for Answer Head */
    --mbb-color-blue-bg: #e2f7ff;         /* Code block background */
    --mbb-color-blue-border: #6d6d6d;       /* Code block border */

    /* Typography */
    --mbb-font-main: 'S-CoreDream-5Medium', 'Apple SD Gothic Neo', 'Noto Sans KR', sans-serif;
    
    /* Spacing & Radius */
    --mbb-spacing-small: 8px;
    --mbb-spacing-medium: 16px;
    --mbb-spacing-large: 24px;
    --mbb-border-radius: 8px;
}

/* 2. 게시물 기본 구조 (Article Base Structure)
------------------------------------------------------------------- */
.mbb-article-body {
    font-family: var(--mbb-font-main);
    color: var(--mbb-color-text-dark);
    word-break: keep-all;
}

.mbb-article-body h1,
.mbb-article-body h2,
.mbb-article-body h3 {
    font-weight: 600; /* Titles should be bolder */
}

.mbb-header {
    margin-bottom: var(--mbb-spacing-large);
    border-bottom: 1px solid var(--mbb-color-grey-border);
    padding-bottom: var(--mbb-spacing-large);
}

.mbb-summary {
    background-color: var(--mbb-color-grey-bg);
    border: 1px solid var(--mbb-color-grey-border);
    border-left: 5px solid var(--mbb-color-primary);
    padding: var(--mbb-spacing-medium);
    margin-top: var(--mbb-spacing-large);
    border-radius: var(--mbb-border-radius);
    font-size: 0.95em;
    color: var(--mbb-color-text-light);
}

.mbb-prologue {
    font-size: 1.1em;
    line-height: 1.7;
    color: var(--mbb-color-text-dark);
    margin-bottom: 40px;
}

.mbb-section {
    margin-bottom: 40px;
}

.mbb-paragraph {
    font-size: 1em;
    line-height: 1.8;
    color: var(--mbb-color-text-light);
    margin-top: 0;
    margin-bottom: var(--mbb-spacing-medium);
}

.mbb-subtitle {
    font-size: 1.2em;
    margin-top: var(--mbb-spacing-large);
    margin-bottom: var(--mbb-spacing-small);
    border-bottom: 2px solid var(--mbb-color-grey-border);
    padding-bottom: var(--mbb-spacing-small);
}


/* 3. 본문 구성 요소 (Content Components)
------------------------------------------------------------------- */

/* Info & Warning Boxes */
.mbb-box {
    margin: var(--mbb-spacing-large) 0;
    padding: var(--mbb-spacing-medium);
    border-radius: var(--mbb-border-radius);
    background-color: var(--mbb-color-grey-bg);
    border: 1px solid var(--mbb-color-grey-border);
}

.mbb-box.mbb-tip {
    border-left: 5px solid var(--mbb-color-primary);
}

.mbb-box.mbb-warning {
    border-left: 5px solid var(--mbb-color-accent-orange);
}

/* Example & Case Study Boxes */
.mbb-example, .mbb-case-study {
    margin: var(--mbb-spacing-large) 0;
    padding: var(--mbb-spacing-medium);
    border: 1px dashed var(--mbb-color-grey-border);
    background-color: #fdfdfd;
    border-radius: var(--mbb-border-radius);
}

/* Table */
.mbb-table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--mbb-spacing-large) 0;
    font-size: 0.9em;
}

.mbb-table th, .mbb-table td {
    border: 1px solid var(--mbb-color-grey-border);
    padding: var(--mbb-spacing-small) var(--mbb-spacing-medium);
    text-align: left;
}

.mbb-table th {
    background-color: var(--mbb-color-grey-bg);
    font-weight: 600;
}

.mbb-table tbody tr:nth-of-type(even) {
    background-color: #fcfcfc;
}

/* Highlight & Code */
.mbb-highlight {
    background-color: #fff1b8;
    padding: 0.1em 0.3em;
    border-radius: 4px;
}

.mbb-code-block {
    background-color: var(--mbb-color-blue-bg);
    border: 1px solid var(--mbb-color-blue-border);
    border-radius: var(--mbb-border-radius);
    padding: var(--mbb-spacing-medium);
    margin: var(--mbb-spacing-large) 0;
    font-size: 0.9em;
    overflow-x: auto;
}

.mbb-code-block code {
    background-color: transparent !important;
    font-family: 'Consolas', 'Monaco', monospace !important;
}


/* 4. Q&A (FAQ Section)
------------------------------------------------------------------- */
.mbb-faq-section {
    margin-top: 40px;
    padding-top: 20px;
    border-top: 2px solid var(--mbb-color-grey-border);
}

.mbb-faq-item {
    margin-bottom: var(--mbb-spacing-large);
}

.mbb-question, .mbb-answer {
    display: flex;
    align-items: flex-start; /* Align items to the top */
}

.mbb-question {
    margin-bottom: var(--mbb-spacing-medium);
}

.mbb-q-head, .mbb-a-head {
    flex-shrink: 0; /* Prevent the head from shrinking */
    display: inline-flex;
    justify-content: center;
    align-items: center;
    color: var(--mbb-color-text-white);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    font-weight: 600;
    font-size: 14px;
    margin-right: var(--mbb-spacing-medium);
}

.mbb-q-head {
    background-color: var(--mbb-color-primary);
}

.mbb-a-head {
    background-color: var(--mbb-color-grey-medium);
}

.mbb-q-text, .mbb-a-text {
    flex-grow: 1; /* Allow text to take remaining space */
}

.mbb-q-text {
    font-weight: 600;
    color: var(--mbb-color-accent-orange);
    font-size: 1.1em;
    padding-top: 5px;
}

.mbb-a-text {
    font-weight: 400;
    color: var(--mbb-color-text-light);
    line-height: 1.8;
    padding-top: 5px;
}

.mbb-a-text p {
    margin: 0;
}


/* 5. 반응형 디자인 (Responsive Design)
------------------------------------------------------------------- */
@media (max-width: 768px) {
    .mbb-prologue {
        font-size: 1em;
    }

    .mbb-q-head, .mbb-a-head {
        width: 30px;
        height: 30px;
        font-size: 12px;
        margin-right: var(--mbb-spacing-small);
    }
    
    .mbb-q-text {
        font-size: 1em;
    }

    .mbb-a-text {
        font-size: 0.95em;
    }
}

