/* ============================
   Agent Comment & Profile Manager
   フロント用CSS — Figma準拠
   ============================ */

/* ========================================
   1. 吹き出しパーツ [staff_comment]
   ======================================== */

/* --- PC: Grid レイアウト --- */
.sc-comment-box {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    grid-template-rows: auto 1fr !important;
    column-gap: 32px !important;
    row-gap: 8px !important;
    margin: 2em 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}
.sc-comment-box + .sc-comment-box {
    margin-top: 40px !important;
}

/* アバター（PC: 左列に2行分） */
.sc-comment-avatar {
    grid-column: 1 !important;
    grid-row: 1 / 3 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    align-self: start !important;
    flex-shrink: 0 !important;
}
.sc-comment-avatar img {
    width: 100px !important;
    height: 100px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
    border: 1px solid #ccc !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

/* バッジ共通 */
.sc-comment-badge {
    background: #21272D !important;
    color: #fff !important;
    font-weight: bold !important;
    line-height: 1.4 !important;
    border-radius: 2px !important;
    white-space: nowrap !important;
    display: inline-block !important;
    box-sizing: border-box !important;
}
/* PC: 写真下バッジ */
.sc-comment-badge--under {
    font-size: 14px !important;
    letter-spacing: 1.96px !important;
    padding: 2px 20px !important;
}
/* SP: インラインバッジ（PCでは非表示） */
.sc-comment-badge--inline {
    display: none !important;
}

/* メタ情報（PC: 右列1行目） */
.sc-comment-meta {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: flex !important;
    align-items: flex-end !important;
    gap: 8px !important;
    white-space: nowrap !important;
    align-self: end !important;
}
.sc-comment-meta-name {
    display: contents !important;
}
.sc-comment-name {
    font-size: 16px !important;
    font-weight: bold !important;
    color: #333 !important;
    letter-spacing: 0.64px !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}
.sc-comment-title {
    font-size: 12px !important;
    font-weight: bold !important;
    color: #8d96a3 !important;
    letter-spacing: 0.48px !important;
    line-height: 1.4 !important;
}

/* 吹き出しバブル（PC: 右列2行目） */
.sc-comment-bubble {
    grid-column: 2 !important;
    grid-row: 2 !important;
    position: relative !important;
    background: rgba(199, 199, 199, 0.15) !important;
    border-radius: 0 8px 8px 8px !important;
    padding: 16px 24px !important;
    align-self: start !important;
    width: fit-content !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}
/* PC: 左向き三角矢印 */
.sc-comment-bubble::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: -20px !important;
    width: 0 !important;
    height: 0 !important;
    border-style: solid !important;
    border-width: 0 20px 16px 0 !important;
    border-color: transparent rgba(199, 199, 199, 0.15) transparent transparent !important;
}
.sc-comment-bubble p {
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.4 !important;
    letter-spacing: 0.64px !important;
    margin: 0 !important;
    padding: 0 !important;
}
.sc-comment-bubble p + p {
    margin-top: 10px !important;
}

/* --- SP: 吹き出し下段レイアウト --- */
@media (max-width: 599px) {
    .sc-comment-box {
        grid-template-columns: 56px 1fr !important;
        grid-template-rows: auto auto !important;
        column-gap: 10px !important;
        row-gap: 0 !important;
    }
    .sc-comment-avatar {
        grid-column: 1 !important;
        grid-row: 1 !important;
        gap: 0 !important;
    }
    .sc-comment-avatar img {
        width: 56px !important;
        height: 56px !important;
    }
    .sc-comment-badge--under {
        display: none !important;
    }
    .sc-comment-badge--inline {
        display: inline-block !important;
        font-size: 10px !important;
        letter-spacing: 1.4px !important;
        padding: 2px 8px !important;
    }
    .sc-comment-meta {
        grid-column: 2 !important;
        grid-row: 1 !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        align-self: center !important;
        gap: 4px !important;
        white-space: normal !important;
    }
    .sc-comment-meta-name {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }
    .sc-comment-name {
        font-size: 14px !important;
        letter-spacing: 0.56px !important;
    }
    .sc-comment-title {
        font-size: 12px !important;
        letter-spacing: 0.48px !important;
    }
    .sc-comment-bubble {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        margin-top: 16px !important;
        border-radius: 8px !important;
        padding: 16px !important;
    }
    /* SP: 上向き三角矢印 */
    .sc-comment-bubble::before {
        top: -8px !important;
        left: 16px !important;
        border-width: 0 12px 8px 12px !important;
        border-color: transparent transparent rgba(199, 199, 199, 0.15) transparent !important;
    }
    .sc-comment-bubble p {
        font-size: 14px !important;
        letter-spacing: 0.56px !important;
    }
}

/* --- PC: 右寄せ --- */
.sc-comment-box--right {
    grid-template-columns: 1fr auto !important;
}
.sc-comment-box--right .sc-comment-avatar {
    grid-column: 2 !important;
    grid-row: 1 / 3 !important;
}
.sc-comment-box--right .sc-comment-meta {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-content: flex-end !important;
}
.sc-comment-box--right .sc-comment-bubble {
    grid-column: 1 !important;
    grid-row: 2 !important;
    border-radius: 8px 0 8px 8px !important;
    justify-self: end !important;
}
.sc-comment-box--right .sc-comment-bubble::before {
    left: auto !important;
    right: -20px !important;
    border-width: 0 0 16px 20px !important;
    border-color: transparent transparent transparent rgba(199, 199, 199, 0.15) !important;
}

/* --- SP: 右寄せ --- */
@media (max-width: 599px) {
    .sc-comment-box--right {
        grid-template-columns: 1fr 56px !important;
    }
    .sc-comment-box--right .sc-comment-avatar {
        grid-column: 2 !important;
        grid-row: 1 !important;
    }
    .sc-comment-box--right .sc-comment-meta {
        grid-column: 1 !important;
        grid-row: 1 !important;
        align-items: flex-end !important;
    }
    .sc-comment-box--right .sc-comment-bubble {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        border-radius: 8px !important;
        justify-self: end !important;
    }
    .sc-comment-box--right .sc-comment-bubble::before {
        left: auto !important;
        right: 16px !important;
        border-width: 0 12px 8px 12px !important;
        border-color: transparent transparent rgba(199, 199, 199, 0.15) transparent !important;
    }
}


/* ========================================
   2. 著者プロフィール [agent_profile]
   ======================================== */

/* --- カード外枠 --- */
.ap-card {
    position: relative !important;
    background: rgba(199, 199, 199, 0.15) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 24px 40px !important;
    margin: 2em 0 !important;
    overflow: hidden !important;
    border: none !important;
}

/* --- PC: Flex レイアウト --- */
.ap-card-inner {
    display: flex !important;
    align-items: center !important;
    position: relative !important;
}

/* 左カラム: 写真 + バッジ */
.ap-card-left {
    flex-shrink: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
}
.ap-card-left img {
    width: 100px !important;
    height: 100px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
    border: 1px solid #ccc !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}
.ap-card-badge {
    background: #21272D !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: bold !important;
    letter-spacing: 1.96px !important;
    padding: 2px 20px !important;
    border-radius: 4px !important;
    line-height: 1.4 !important;
    white-space: nowrap !important;
    display: inline-block !important;
}

/* 縦区切り線 */
.ap-card-divider {
    width: 1px !important;
    align-self: stretch !important;
    background: #dfdfdf !important;
    margin: 0 40px !important;
    flex-shrink: 0 !important;
}

/* 右カラム: テキストコンテンツ */
.ap-card-right {
    flex-grow: 1 !important;
    position: relative !important;
    overflow: visible !important;
    min-width: 0 !important;
}

/* ウォーターマーク */
.ap-card-watermark {
    position: absolute !important;
    top: -10px !important;
    left: 0 !important;
    font-size: 60px !important;
    font-weight: bold !important;
    color: #fff !important;
    letter-spacing: 2.4px !important;
    line-height: 1.4 !important;
    pointer-events: none !important;
    user-select: none !important;
    white-space: nowrap !important;
}

/* 名前エリア */
.ap-card-name-area {
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    margin-bottom: 16px !important;
    position: relative !important;
    z-index: 1 !important;
    flex-wrap: wrap !important;
}
.ap-card-name {
    font-size: 20px !important;
    font-weight: bold !important;
    color: #333 !important;
    letter-spacing: 0.04em !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}
.ap-card-title {
    font-size: 14px !important;
    font-weight: bold !important;
    color: #8d96a3 !important;
    letter-spacing: 0.04em !important;
    line-height: 1.4 !important;
    white-space: nowrap !important;
}

/* プロフィール文 */
.ap-card-desc {
    position: relative !important;
    z-index: 1 !important;
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.6 !important;
    letter-spacing: 0.64px !important;
}
.ap-card-desc p {
    margin: 0 0 10px !important;
    font-size: 16px !important;
}
.ap-card-desc p:last-child {
    margin-bottom: 0 !important;
}

/* 詳しく見るボタン */
.ap-card-btn-area {
    margin-top: 24px !important;
    position: relative !important;
    z-index: 1 !important;
}
.ap-card-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    width: 160px !important;
    padding: 12px 24px !important;
    border: 1px solid #d7e0ec !important;
    border-radius: 4px !important;
    color: #333 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: bold !important;
    letter-spacing: 0.56px !important;
    background: #fff !important;
    transition: background 0.2s, color 0.2s, border-color 0.2s !important;
    box-sizing: border-box !important;
    line-height: 1.4 !important;
}
.ap-card-btn::after {
    content: '\f105' !important;
    font-family: 'Font Awesome 6 Free' !important;
    font-weight: 900 !important;
    font-size: 16px !important;
    line-height: 1 !important;
    color: #00a3ab !important;
    position: absolute !important;
    left: calc(100% - 24px) !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
}
.ap-card-btn:hover {
    background: #333 !important;
    color: #fff !important;
    border-color: #333 !important;
}
.ap-card-btn:hover::after {
    color: #fff !important;
}

/* --- SP --- */
@media (max-width: 599px) {
    .ap-card {
        padding: 40px 20px !important;
    }
    .ap-card-inner {
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
    }
    .ap-card-left img {
        width: 95px !important;
        height: 95px !important;
    }
    .ap-card-badge {
        font-size: 14px !important;
    }
    .ap-card-divider {
        display: none !important;
    }
    .ap-card-right {
        width: 100% !important;
        margin-top: 40px !important;
        overflow: hidden !important;
    }
    .ap-card-watermark {
        font-size: 42px !important;
        top: -24px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
    }
    .ap-card-name-area {
        flex-direction: column !important;
        align-items: center !important;
        gap: 8px !important;
    }
    .ap-card-name {
        font-size: 20px !important;
        letter-spacing: 0.8px !important;
    }
    .ap-card-title {
        font-size: 12px !important;
        letter-spacing: 0.48px !important;
    }
    .ap-card-desc {
        text-align: left !important;
    }
    .ap-card-btn-area {
        text-align: center !important;
    }
    .ap-card-btn {
        width: 295px !important;
        min-width: auto !important;
    }
}
