/*
 * Page Content Styles
 * Used by: page.php (Privacy Policy, Terms, Refund, etc.)
 * Targets: .prose-content (matches page.php wrapper)
 */

/* ═══════════ BASE ═══════════ */
.prose-content {
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.8;
}

.prose-content p {
    margin-bottom: 1.25em;
    line-height: 1.85;
}

.prose-content > *:first-child { margin-top: 0; }
.prose-content > *:last-child { margin-bottom: 0; }

/* ═══════════ HEADINGS ═══════════ */
.prose-content h1,
.prose-content h2,
.prose-content h3,
.prose-content h4,
.prose-content h5,
.prose-content h6 {
    color: var(--text-primary);
    font-weight: 600;
    line-height: 1.3;
    margin-top: 2.5em;
    margin-bottom: 0.75em;
}

.prose-content h1 { font-size: 1.875rem; }
.prose-content h2 {
    font-size: 1.5rem;
    padding-bottom: 0.5em;
    border-bottom: 1px solid var(--border-subtle);
}
.prose-content h3 { font-size: 1.25rem; }
.prose-content h4 { font-size: 1.125rem; }

.prose-content h1:first-child,
.prose-content h2:first-child,
.prose-content h3:first-child { margin-top: 0; }

/* ═══════════ LINKS ═══════════ */
.prose-content a {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.15s;
}

.prose-content a:hover {
    color: var(--text-primary);
    text-decoration-thickness: 2px;
}

/* ═══════════ STRONG / EMPHASIS ═══════════ */
.prose-content strong,
.prose-content b {
    color: var(--text-primary);
    font-weight: 600;
}

.prose-content em { font-style: italic; }

.prose-content small {
    font-size: 0.875em;
    color: var(--text-muted);
}

/* ═══════════ LISTS ═══════════ */
.prose-content ul,
.prose-content ol {
    margin-bottom: 1.5em;
    padding-left: 1.5em;
}

.prose-content li {
    margin-bottom: 0.6em;
    line-height: 1.75;
}

.prose-content ul > li { list-style-type: disc; }
.prose-content ol > li { list-style-type: decimal; }
.prose-content li::marker { color: var(--accent); }

.prose-content li > ul,
.prose-content li > ol {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
}

/* ═══════════ BLOCKQUOTES ═══════════ */
.prose-content blockquote {
    margin: 2em 0;
    padding: 1.25em 1.5em;
    border-left: 4px solid var(--accent);
    background: var(--bg-secondary);
    border-radius: 0 12px 12px 0;
    color: var(--text-secondary);
    font-style: italic;
}

.prose-content blockquote p:last-child { margin-bottom: 0; }

/* ═══════════ HORIZONTAL RULE ═══════════ */
.prose-content hr {
    border: none;
    border-top: 1px solid var(--border-subtle);
    margin: 2.5em 0;
}

/* ═══════════ TABLES ═══════════ */
.prose-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 2em 0;
    font-size: 0.875rem;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    overflow: hidden;
}

.prose-content thead { background: var(--bg-secondary); }

.prose-content th {
    padding: 12px 16px;
    text-align: left;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border-subtle);
}

.prose-content td {
    padding: 12px 16px;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-subtle);
    vertical-align: top;
}

.prose-content tbody tr:last-child td { border-bottom: none; }
.prose-content tbody tr:hover { background: rgba(29,78,216,0.02); }

/* ═══════════ CODE ═══════════ */
.prose-content code {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    padding: 2px 7px;
    border-radius: 5px;
    font-family: 'SF Mono','Fira Code',monospace;
    font-size: 0.85em;
    color: var(--accent);
}

.prose-content pre {
    background: var(--bg-primary);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 1.25em 1.5em;
    margin: 2em 0;
    overflow-x: auto;
}

.prose-content pre code {
    background: none;
    border: none;
    padding: 0;
    color: var(--text-secondary);
}

/* ═══════════ IMAGES ═══════════ */
.prose-content img {
    max-width: 100%;
    height: auto;
    border-radius: 10px;
    margin: 1.5em 0;
    border: 1px solid var(--border-subtle);
}

.prose-content figcaption {
    text-align: center;
    font-size: 0.8125rem;
    color: var(--text-muted);
    margin-top: 0.75em;
    font-style: italic;
}

/* ═══════════ CALLOUT BOXES ═══════════ */
.prose-content .callout {
    padding: 1.25em 1.5em;
    border-radius: 10px;
    margin: 2em 0;
    border-left: 4px solid;
}

.prose-content .callout p:last-child { margin-bottom: 0; }
.prose-content .callout-info { background: rgba(29,78,216,0.06); border-left-color: var(--primary,#1d4ed8); }
.prose-content .callout-success { background: rgba(16,185,129,0.06); border-left-color: var(--success,#10b981); }
.prose-content .callout-warning { background: rgba(245,158,11,0.06); border-left-color: var(--warning,#f59e0b); }
.prose-content .callout-danger { background: rgba(239,68,68,0.06); border-left-color: var(--error,#ef4444); }

/* ═══════════ ACCORDION ═══════════ */
.prose-content details {
    margin-bottom: 1em;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    overflow: hidden;
}

.prose-content summary {
    padding: 14px 18px;
    font-weight: 600;
    color: var(--text-primary);
    cursor: pointer;
    background: var(--bg-secondary);
    transition: background 0.15s;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 8px;
}

.prose-content summary::-webkit-details-marker { display: none; }

.prose-content summary::before {
    content: '';
    width: 20px;
    height: 20px;
    border-radius: 6px;
    background: var(--bg-primary);
    border: 1px solid var(--border-subtle);
    flex-shrink: 0;
    transition: transform 0.2s;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}

.prose-content details[open] summary::before { transform: rotate(180deg); }
.prose-content summary:hover { background: rgba(29,78,216,0.04); }
.prose-content details > div,
.prose-content details > p { padding: 16px 18px; color: var(--text-secondary); line-height: 1.7; }

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width: 768px) {
    .prose-content { font-size: 14px; }
    .prose-content h1 { font-size: 1.5rem; }
    .prose-content h2 { font-size: 1.25rem; }
    .prose-content h3 { font-size: 1.125rem; }
    .prose-content blockquote { padding: 1em 1.25em; margin: 1.5em 0; }
    .prose-content pre { padding: 1em; border-radius: 8px; }
    .prose-content table { font-size: 0.8125rem; }
    .prose-content th, .prose-content td { padding: 10px 12px; }
    .prose-content img.alignleft,
    .prose-content img.alignright { float: none; max-width: 100%; margin: 1em 0; }
}

/* ═══════════ PRINT ═══════════ */
@media print {
    .prose-content { font-size: 12pt; line-height: 1.6; color: #000; }
    .prose-content h1, .prose-content h2, .prose-content h3, .prose-content h4 { color: #000; page-break-after: avoid; }
    .prose-content a { color: #000; text-decoration: underline; }
    .prose-content a[href]::after { content: " (" attr(href) ")"; font-size: 0.85em; color: #666; }
    .prose-content blockquote { border-left-color: #999; background: #f5f5f5; }
    .prose-content .callout { border-left-color: #999; background: #f5f5f5; }
}