/*
Theme Name: PixelPanda Blog Theme
Theme URI: https://pixelpanda.ai
Description: Custom child theme for PixelPanda Blog matching the main site dark branding
Author: PixelPanda
Author URI: https://pixelpanda.ai
Template: twentytwentyfive
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pixelpanda-theme
*/

/* =====================================================
   PixelPanda Dark Theme Variables
   ===================================================== */

:root {
    --pp-primary: #8b5cf6;
    --pp-primary-dark: #7c3aed;
    --pp-primary-light: #a78bfa;
    --pp-secondary: #94a3b8;
    --pp-bg: #0a0a1a;
    --pp-bg-card: #12122a;
    --pp-bg-elevated: #1a1a35;
    --pp-bg-input: #0f0f25;
    --pp-border: #1e1e3a;
    --pp-border-light: #2a2a4a;
    --pp-text: #e2e8f0;
    --pp-text-muted: #94a3b8;
    --pp-text-dim: #64748b;
    --pp-heading: #ffffff;
    --pp-green: #10b981;
    --pp-green-dark: #059669;
}

/* =====================================================
   Global Styles
   ===================================================== */

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
    color: var(--pp-text) !important;
    background-color: var(--pp-bg) !important;
    overflow-x: hidden;
}

.wp-site-blocks {
    overflow-x: hidden;
}

/* =====================================================
   Post Content - Centering Everything
   ===================================================== */

.wp-block-post-content {
    max-width: 720px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 20px;
    padding-right: 20px;
}

.wp-block-post-content > * {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.wp-block-post-content .wp-block-image {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center;
}

.wp-block-post-content .wp-block-image img {
    max-width: 100% !important;
    height: auto !important;
    display: block;
    margin-left: auto;
    margin-right: auto;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

.wp-block-post-content figure {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.wp-block-post-content figure img {
    max-width: 100% !important;
    height: auto !important;
}

.wp-block-post-content iframe,
.wp-block-post-content embed,
.wp-block-post-content object {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: block;
}

.wp-block-post-content .wp-block-columns {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.wp-block-post-content .wp-block-group {
    max-width: 100% !important;
}

/* =====================================================
   Header Styles
   ===================================================== */

.wp-block-site-title a {
    color: #ffffff !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    transition: color 0.15s ease;
}

.wp-block-site-title a:hover {
    color: var(--pp-primary) !important;
}

header a {
    text-decoration: none !important;
}

header a:hover {
    text-decoration: underline !important;
}

/* =====================================================
   Blog Card Styles
   ===================================================== */

.blog-card {
    transition: all 0.25s ease;
    overflow: hidden;
    background: var(--pp-bg-card) !important;
    border-color: var(--pp-border) !important;
}

.blog-card:hover {
    border-color: var(--pp-border-light) !important;
    box-shadow: 0 8px 30px -5px rgba(139, 92, 246, 0.15), 0 4px 10px -5px rgba(0, 0, 0, 0.3);
    transform: translateY(-4px);
}

.blog-card .wp-block-post-featured-image img {
    transition: transform 0.3s ease;
}

.blog-card:hover .wp-block-post-featured-image img {
    transform: scale(1.03);
}

.blog-card .wp-block-post-title a {
    color: #ffffff !important;
    text-decoration: none !important;
    transition: color 0.15s ease;
}

.blog-card:hover .wp-block-post-title a {
    color: var(--pp-primary-light) !important;
}

.blog-card .wp-block-post-excerpt {
    color: var(--pp-text-muted) !important;
    line-height: 1.6;
}

.blog-card .wp-block-post-excerpt .wp-block-post-excerpt__excerpt {
    color: var(--pp-text-muted) !important;
}

.blog-card .wp-block-post-date {
    color: var(--pp-text-dim) !important;
}

.blog-card .wp-block-post-featured-image {
    overflow: hidden;
    border-radius: 12px 12px 0 0;
}

/* =====================================================
   Typography
   ===================================================== */

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
    color: var(--pp-heading) !important;
    font-weight: 600;
    line-height: 1.3;
}

a {
    color: var(--pp-primary);
    text-decoration: none;
    transition: color 0.15s ease;
}

a:hover {
    color: var(--pp-primary-light);
}

p {
    color: var(--pp-text);
}

/* =====================================================
   Buttons
   ===================================================== */

.wp-block-button__link,
.wp-element-button {
    background-color: var(--pp-primary) !important;
    color: white !important;
    border-radius: 8px !important;
    padding: 0.875rem 1.75rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all 0.2s ease;
    border: none !important;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
    background-color: var(--pp-primary-dark) !important;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.35);
    transform: translateY(-1px);
}

/* =====================================================
   Post Content Typography
   ===================================================== */

.wp-block-post-content {
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--pp-text) !important;
}

.wp-block-post-content p {
    margin-bottom: 1.5rem;
    color: var(--pp-text) !important;
}

/* Blockquotes */
.wp-block-quote {
    border-left: 4px solid var(--pp-primary) !important;
    background: var(--pp-bg-elevated) !important;
    padding: 1.5rem 2rem !important;
    margin: 2rem 0;
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: var(--pp-text) !important;
}

/* Code Blocks */
.wp-block-code {
    background: var(--pp-bg-elevated) !important;
    border-radius: 8px !important;
    padding: 1.25rem !important;
    border: 1px solid var(--pp-border) !important;
}

code {
    background: var(--pp-bg-elevated);
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-size: 0.9rem;
    color: var(--pp-primary-light);
}

/* Lists */
.wp-block-post-content ul,
.wp-block-post-content ol {
    padding-left: 1.5rem;
    margin-bottom: 1.5rem;
    color: var(--pp-text);
}

.wp-block-post-content li {
    margin-bottom: 0.5rem;
    color: var(--pp-text);
}

/* Tables */
.wp-block-table table {
    border-color: var(--pp-border) !important;
}

.wp-block-table td,
.wp-block-table th {
    border-color: var(--pp-border) !important;
    color: var(--pp-text);
}

.wp-block-table th {
    color: var(--pp-heading);
}

/* =====================================================
   Pagination
   ===================================================== */

.wp-block-query-pagination-numbers a,
.wp-block-query-pagination-next a,
.wp-block-query-pagination-previous a {
    background: var(--pp-bg-elevated) !important;
    color: var(--pp-text-muted) !important;
    padding: 0.5rem 1rem !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    transition: all 0.15s ease;
    border: 1px solid var(--pp-border) !important;
}

.wp-block-query-pagination-numbers a:hover,
.wp-block-query-pagination-next a:hover,
.wp-block-query-pagination-previous a:hover {
    background: var(--pp-primary) !important;
    color: white !important;
    border-color: var(--pp-primary) !important;
}

.wp-block-query-pagination-numbers .current {
    background: var(--pp-primary) !important;
    color: white !important;
}

/* =====================================================
   Footer Styles
   ===================================================== */

footer a {
    color: inherit !important;
    opacity: 0.8;
}

footer a:hover {
    opacity: 1;
}

/* =====================================================
   Post Navigation
   ===================================================== */

.wp-block-post-navigation-link a {
    color: var(--pp-primary) !important;
    font-weight: 500;
}

.wp-block-post-navigation-link a:hover {
    color: var(--pp-primary-light) !important;
}

/* =====================================================
   Separator
   ===================================================== */

.wp-block-separator {
    border-color: var(--pp-border) !important;
    background-color: var(--pp-border) !important;
    color: var(--pp-border) !important;
}

/* =====================================================
   Post Date & Meta (outside cards)
   ===================================================== */

.wp-block-post-date {
    color: var(--pp-text-dim) !important;
}

.wp-block-post-terms a {
    color: var(--pp-primary) !important;
}

.wp-block-post-terms a:hover {
    color: var(--pp-primary-light) !important;
}

/* =====================================================
   Responsive Design
   ===================================================== */

@media (max-width: 1024px) {
    .wp-block-post-template.columns-3 > li {
        width: calc(50% - 1rem) !important;
    }
}

@media (max-width: 768px) {
    .wp-block-post-template.columns-3 > li {
        width: 100% !important;
    }

    h1.wp-block-heading {
        font-size: 1.75rem !important;
    }

    .blog-card {
        margin-bottom: 1rem;
    }

    .wp-block-post-content {
        padding-left: 15px;
        padding-right: 15px;
    }
}

/* =====================================================
   Misc
   ===================================================== */

::selection {
    background: var(--pp-primary);
    color: white;
}

html {
    scroll-behavior: smooth;
}

/* Override any WordPress default white backgrounds */
.has-base-background-color {
    background-color: var(--pp-bg) !important;
}

.has-contrast-color {
    color: var(--pp-text) !important;
}

.has-contrast-background-color {
    background-color: #080816 !important;
}

/* Ensure accent color text works in dark mode */
.has-accent-4-color {
    color: var(--pp-text-dim) !important;
}

.has-accent-3-color {
    color: var(--pp-text-muted) !important;
}
