/* ================================================================
   Community Deliberation — Front-end styles
   High specificity selectors to override Astra theme
   ================================================================ */

body .cd-wrap {
    max-width: 100% !important;
    margin: 0 auto !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    color: #1a1a2e !important;
}

/* ── Question header ── */
body .cd-question-header {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%) !important;
    color: #fff !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    margin-bottom: 12px !important;
}
body .cd-question-top {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
}
body .cd-question-title {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
    color: #fff !important;
    border: none !important;
    padding: 0 !important;
}
body .cd-meta {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
    flex-wrap: wrap !important;
}
body .cd-question-body {
    font-size: .9rem !important;
    opacity: .82 !important;
    margin: 8px 0 0 !important;
    line-height: 1.5 !important;
    color: #fff !important;
}
body .cd-badge {
    display: inline-block !important;
    padding: 3px 10px !important;
    border-radius: 20px !important;
    font-size: .75rem !important;
    font-weight: 600 !important;
    letter-spacing: .03em !important;
    white-space: nowrap !important;
}
body .cd-badge-open   { background: #0f3460 !important; color: #e94560 !important; border: 1px solid #e94560 !important; }
body .cd-badge-closed { background: #333 !important; color: #aaa !important; border: none !important; }
body .cd-reply-count  { font-size: .8rem !important; opacity: .65 !important; white-space: nowrap !important; color: #fff !important; }

/* ── Analysis panel ── */
body .cd-analysis-panel { margin-bottom: 10px !important; }
body .cd-toggle-analysis {
    background: none !important;
    border: 2px solid #0f3460 !important;
    color: #0f3460 !important;
    padding: 7px 16px !important;
    border-radius: 8px !important;
    font-size: .85rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    width: 100% !important;
    text-align: left !important;
}
body .cd-toggle-analysis:hover { background: #0f3460 !important; color: #fff !important; }
body .cd-analysis-content {
    border: 1px solid #e0e0e0 !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin-top: 8px !important;
    background: #fafafa !important;
}

/* ── Section title ── */
body .cd-section-title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 0 0 10px !important;
    color: #1a1a2e !important;
    border-bottom: 2px solid #e94560 !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    padding-bottom: 4px !important;
    display: inline-block !important;
    background: none !important;
}

/* ── Themes ── */
body .cd-themes-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 16px !important;
}
body .cd-theme-card {
    background: #fff !important;
    border: 1px solid #e0e0e0 !important;
    border-left: 4px solid #e94560 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
}
body .cd-theme-label  { font-weight: 700 !important; font-size: .85rem !important; margin-bottom: 3px !important; color: #1a1a2e !important; }
body .cd-theme-count  { font-size: .72rem !important; color: #e94560 !important; font-weight: 600 !important; margin-bottom: 4px !important; }
body .cd-theme-summary { font-size: .82rem !important; color: #555 !important; line-height: 1.4 !important; }

/* ── Consensus plan ── */
body .cd-plan-box {
    background: linear-gradient(135deg, #0f3460 0%, #16213e 100%) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 16px 20px !important;
    margin-top: 14px !important;
}
body .cd-plan-content { font-size: .9rem !important; line-height: 1.65 !important; opacity: .9 !important; }

/* ── Reply form ── */
body .cd-top-reply {
    background: #fff !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 8px !important;
    padding: 14px 16px !important;
    margin-bottom: 10px !important;
    border-left: 1px solid #e0e0e0 !important;
}
body .cd-top-reply h3 {
    margin: 0 0 8px !important;
    font-size: .95rem !important;
    color: #1a1a2e !important;
    border: none !important;
    padding: 0 !important;
}
body .cd-reply-input {
    width: 100% !important;
    border: 1px solid #ccc !important;
    border-radius: 6px !important;
    padding: 8px 10px !important;
    font-size: .9rem !important;
    font-family: inherit !important;
    resize: vertical !important;
    box-sizing: border-box !important;
    background: #fff !important;
}
body .cd-submit-reply {
    background: #e94560 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 7px 16px !important;
    font-size: .85rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    margin-top: 8px !important;
    display: inline-block !important;
}
body .cd-submit-reply:hover { background: #c73450 !important; }
body .cd-cancel-reply {
    background: none !important;
    border: 1px solid #ccc !important;
    border-radius: 6px !important;
    padding: 6px 14px !important;
    font-size: .85rem !important;
    cursor: pointer !important;
    margin-top: 8px !important;
    margin-left: 6px !important;
    color: #666 !important;
}
body .cd-inline-reply-form {
    background: #fff !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 8px !important;
    padding: 14px 16px !important;
    margin-top: 10px !important;
    margin-bottom: 0 !important;
    border-left: 1px solid #e0e0e0 !important;
}

/* ── Discussion ── */
body .cd-discussion { margin-top: 4px !important; }
body .cd-empty { color: #888 !important; font-style: italic !important; font-size: .9rem !important; }

/* Top-level responses */
body .cd-reply-top {
    border-left: 4px solid #e94560 !important;
    padding: 0 !important;
    margin-bottom: 12px !important;
    background: #fff !important;
    border-radius: 0 8px 8px 0 !important;
    box-shadow: 0 2px 6px rgba(0,0,0,.08) !important;
    overflow: hidden !important;
    border-top: none !important;
    border-right: none !important;
    border-bottom: none !important;
}

/* AI title bar */
body .cd-reply-title {
    background: linear-gradient(90deg, #1a1a2e 0%, #0f3460 100%) !important;
    color: #fff !important;
    font-size: .85rem !important;
    font-weight: 700 !important;
    padding: 7px 14px !important;
    letter-spacing: .02em !important;
    display: block !important;
    border: none !important;
}

body .cd-reply-top .cd-reply-header  { padding: 10px 14px 5px !important; margin-bottom: 0 !important; }
body .cd-reply-top .cd-reply-content { padding: 0 14px 2px !important; }
body .cd-reply-top .cd-reply-actions { padding: 0 14px 10px !important; }
body .cd-reply-top .cd-inline-reply-form { margin: 0 14px 10px !important; }

/* Nested comments */
body .cd-reply-child {
    border-left: 3px solid #cbd5e8 !important;
    border-top: none !important;
    border-right: none !important;
    border-bottom: none !important;
    padding: 8px 12px !important;
    margin-left: 24px !important;
    margin-bottom: 6px !important;
    background: #f4f6fb !important;
    border-radius: 0 6px 6px 0 !important;
    box-shadow: none !important;
}

body .cd-reply-header {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-bottom: 5px !important;
}
body .cd-avatar img { border-radius: 50% !important; vertical-align: middle !important; }
body .cd-reply-author { font-weight: 600 !important; font-size: .85rem !important; color: #1a1a2e !important; }
body .cd-reply-time   { font-size: .75rem !important; color: #999 !important; }
body .cd-reply-content { font-size: .9rem !important; line-height: 1.55 !important; color: #333 !important; }
body .cd-reply-actions { margin-top: 6px !important; }
body .cd-reply-btn {
    background: none !important;
    color: #0f3460 !important;
    border: 1px solid #0f3460 !important;
    padding: 4px 10px !important;
    font-size: .78rem !important;
    margin-top: 0 !important;
    cursor: pointer !important;
    border-radius: 6px !important;
}
body .cd-reply-btn:hover { background: #0f3460 !important; color: #fff !important; }

/* ── Login prompt ── */
body .cd-login-prompt {
    text-align: center !important;
    padding: 12px !important;
    background: #f0f4ff !important;
    border-radius: 8px !important;
    margin-bottom: 10px !important;
    font-size: .9rem !important;
    color: #444 !important;
}
body .cd-login-prompt a { color: #e94560 !important; font-weight: 600 !important; }

/* ── Animation ── */
body .cd-reply-new { animation: cd-fadein .3s ease !important; }
@keyframes cd-fadein {
    from { opacity: 0; transform: translateY(5px); }
    to   { opacity: 1; transform: translateY(0); }
}
