/* ============================
   Base64 전용 스타일 (리밸런싱)
   - 카드 내부 여백 증가
   - 섹션 간 간격 증가
   - 버튼/입력/그리드 간격 정리
   ============================ */

.base64-card {
    padding: 18px 16px 20px; /* 기존 8 4 16 → 답답함 해소 */
}

/* 상단 제목 아래 설명과 첫 그리드가 너무 붙지 않게 */
.base64-card > .small {
    margin-bottom: 12px;
}

.b64-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;              /* 기존 14 → 살짝 여유 */
    margin-top: 14px;       /* 기존 10 → 여유 */
}

@media (min-width: 900px) {
    .b64-grid {
        grid-template-columns: 1fr 1fr;
        gap: 20px;          /* 기존 16 → 여유 */
    }

    .base64-card {
        max-width: 980px;
        margin: 0 auto;
    }
}

.b64-col {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 16px;          /* 기존 12 → 여유 */
}

.b64-label {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 8px;     /* 기존 6 → 조금 더 */
    display: block;
}

.b64-textarea {
    width: 100%;
    min-height: 190px;      /* 기존 170 → 답답함 완화 */
    resize: vertical;
    padding: 12px 12px;     /* 기존 10 12 → 여유 */
    border-radius: 10px;
    border: 1px solid #d0d7de;
    background: #fff;
    font-size: 14px;
    line-height: 1.65;
}

/* 버튼 줄: 위아래 간격 좀 더 */
.b64-actions {
    display: flex;
    gap: 10px;              /* 기존 8 */
    margin-top: 12px;       /* 기존 10 */
    flex-wrap: wrap;        /* 좁은 화면에서 자연스럽게 */
}

.b64-actions button {
    flex: 1 1 140px;        /* 모바일에서 너무 길게 늘어나는 느낌 완화 */
    padding: 10px 0;        /* 기존 9 */
    font-size: 14px;
}

/* 데스크톱: 버튼 폭 고정 + 높이 안정 */
@media (min-width: 900px) {
    .b64-actions {
        gap: 10px;
    }
    .b64-actions button {
        flex: 0 0 auto;
        width: 132px;       /* 기존 120 → 살짝 */
    }
}

.b64-meta {
    margin-top: 10px;       /* 기존 8 */
    font-size: 13px;
    color: #6b7280;
}

/* 구분선도 위/아래 여유 늘리기 */
.b64-divider {
    margin: 26px 0 18px;    /* 기존 18/14 → 더 시원하게 */
    border: none;
    border-top: 1px solid #e5e7eb;
}

/* 파일 영역 */
.b64-file-row {
    display: flex;
    flex-direction: column;
    gap: 10px;              /* 기존 8 */
    margin-top: 12px;       /* 기존 10 */
}

.b64-file-row input[type="file"] {
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid #d0d7de;
    background: #fff;
}

.b64-file-row button {
    padding: 11px 0;
    font-size: 14px;
}

/* 데스크톱에서 파일 input / 버튼이 너무 붙지 않게 */
@media (min-width: 768px) {
    .b64-file-row {
        flex-direction: row;
        align-items: center;
        gap: 12px;
    }

    .b64-file-row input[type="file"] {
        flex: 1 1 auto;
    }

    .b64-file-row button {
        width: 240px;       /* 기존 220 → 약간 더 */
        flex: 0 0 auto;
    }
}


/* ============================
   설명 / FAQ (다른 도구와 톤 맞추기 + 간격 개선)
   ============================ */

.info-section,
.faq-section {
    max-width: 760px;       /* 기존 720 → 본문은 살짝 넓어도 좋음 */
    margin: 48px auto 0;    /* 기존 40 → 섹션 간 여백 */
    padding: 0 16px;
}

.info-section h2,
.faq-section h2 {
    font-size: 22px;
    font-weight: 800;       /* 조금 더 제목감 */
    margin-bottom: 14px;    /* 기존 16 → 살짝 타이트하게 */
}

.info-section p {
    margin-bottom: 12px;
    line-height: 1.75;      /* 기존 1.7 → 가독성 */
    color: #444;
    font-size: 14px;
}

.info-list {
    margin: 10px 0 16px;    /* 기존 8/14 */
    padding-left: 18px;
    font-size: 14px;
    color: #444;
}

.info-list li {
    margin-bottom: 6px;     /* 기존 3 → 덜 답답 */
}

/* FAQ */
.faq-item {
    border-bottom: 1px solid #e5e7eb;
    padding: 10px 0;        /* 기존 6 → 여유 */
}

.faq-question {
    position: relative;
    width: 100%;
    background: #f9fafb;
    border: 1px solid #e5e7eb;   /* 버튼도 카드처럼 보이게 */
    text-align: left;
    padding: 12px 12px 12px 34px; /* 기존 10/30 */
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    line-height: 1.45;
    color: #111827;
    border-radius: 10px;
}

.faq-question::before {
    content: "▶";
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 11px;
    color: #6b7280;
}

.faq-item.active .faq-question::before {
    content: "▼";
}

.faq-question:hover {
    background: #eef2ff;
}

.faq-question:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.28);
}

.faq-answer {
    display: none;
    padding: 10px 6px 6px;  /* 기존 6/12 → 버튼과 간격 */
    color: #555;
    font-size: 14px;
    line-height: 1.75;
}

.faq-item.active .faq-answer {
    display: block;
}

/* 모바일 최적화 */
@media (max-width: 600px) {
    .base64-card {
        padding: 16px 12px 18px;
    }

    .info-section,
    .faq-section {
        margin-top: 38px;
        padding: 0 12px;
    }

    .info-section h2,
    .faq-section h2 {
        font-size: 20px;
    }

    .faq-question {
        font-size: 14px;
        padding: 11px 10px 11px 32px;
    }

    .info-section p,
    .faq-answer,
    .info-list {
        font-size: 13px;
    }
}
