/*
Theme Name: PanicPeace
Theme URI: https://panicpeace.com
Author: PanicPeace
Author URI: https://panicpeace.com
Description: Custom child theme for PanicPeace.com - Calm tools for anxious minds. Built on Astra with a warm, organic, grounding visual identity.
Template: astra
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: panicpeace
*/

/* ==========================================================================
   PanicPeace Brand Identity
   Color Palette:
     - Primary Background: #FAF9F6 (Off-White/Cream)
     - Primary Text: #3D4045 (Soft Charcoal)
     - Brand Primary: #7A9E7E (Sage Green)
     - Brand Secondary: #4A5A6A (Dusty Navy)
     - Warmth Accent: #C17C5C (Muted Terracotta)
   Typography:
     - Headings: Lora (serif)
     - Body: Inter (sans-serif)
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties
   -------------------------------------------------------------------------- */
:root {
    --pp-bg: #FAF9F6;
    --pp-text: #3D4045;
    --pp-sage: #7A9E7E;
    --pp-sage-hover: #6A8D6D;
    --pp-sage-light: #e8f0e9;
    --pp-terracotta: #C17C5C;
    --pp-terracotta-hover: #AD6D4E;
    --pp-navy: #4A5A6A;
    --pp-navy-light: #eef0f3;
    --pp-border: #E2E8F0;
    --pp-border-light: #EDF2F7;
    --pp-content-width: 700px;
    --pp-wide-width: 1100px;
    --pp-radius: 6px;
    --pp-font-heading: 'Lora', Georgia, 'Times New Roman', serif;
    --pp-font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

/* --------------------------------------------------------------------------
   Global Resets & Base Styles
   -------------------------------------------------------------------------- */
html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body,
body.flavor-flavor {
    background-color: var(--pp-bg) !important;
    color: var(--pp-text) !important;
    font-family: var(--pp-font-body) !important;
    font-size: 17px;
    line-height: 1.75;
    letter-spacing: -0.01em;
}

/* --------------------------------------------------------------------------
   Typography — Headings
   -------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title,
.ast-archive-title,
.site-title,
.widget-title {
    font-family: var(--pp-font-heading) !important;
    color: var(--pp-navy) !important;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: -0.02em;
}

h1, .entry-title {
    font-size: clamp(1.8rem, 4vw, 2.4rem);
    font-weight: 700;
    margin-bottom: 0.5em;
}

h2 {
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    margin-top: 2em;
    margin-bottom: 0.6em;
}

h3 {
    font-size: clamp(1.15rem, 2.5vw, 1.4rem);
    margin-top: 1.8em;
    margin-bottom: 0.5em;
}

h4 {
    font-size: clamp(1.05rem, 2vw, 1.2rem);
    margin-top: 1.5em;
    margin-bottom: 0.4em;
}

/* --------------------------------------------------------------------------
   Typography — Body & Prose
   -------------------------------------------------------------------------- */
p {
    margin-bottom: 1.4em;
    color: var(--pp-text);
}

.entry-content p,
.entry-content li,
.entry-content td,
.entry-content dd {
    font-size: 17px;
    line-height: 1.8;
}

.entry-content ul,
.entry-content ol {
    margin-bottom: 1.5em;
    padding-left: 1.5em;
}

.entry-content li {
    margin-bottom: 0.5em;
}

.entry-content blockquote {
    border-left: 3px solid var(--pp-sage);
    background: var(--pp-sage-light);
    margin: 2em 0;
    padding: 1.2em 1.5em;
    border-radius: var(--pp-radius);
    font-style: italic;
    color: var(--pp-text);
}

.entry-content blockquote p:last-child {
    margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   Links
   -------------------------------------------------------------------------- */
a,
.entry-content a {
    color: var(--pp-sage);
    text-decoration: underline;
    text-decoration-color: rgba(122, 158, 126, 0.3);
    text-underline-offset: 2px;
    transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

a:hover,
a:focus,
.entry-content a:hover,
.entry-content a:focus {
    color: var(--pp-terracotta);
    text-decoration-color: var(--pp-terracotta);
}

/* Nav links should not have underline */
.main-navigation a,
.ast-header-navigation a,
.menu-item a,
.site-title a,
.site-header a {
    text-decoration: none;
}

.main-navigation a:hover,
.ast-header-navigation a:hover,
.menu-item a:hover {
    color: var(--pp-sage) !important;
}

/* --------------------------------------------------------------------------
   Site Header
   -------------------------------------------------------------------------- */
.site-header,
.ast-primary-header,
.main-header-bar,
.ast-primary-header-bar {
    background-color: var(--pp-bg) !important;
    border-bottom: 1px solid var(--pp-border) !important;
    box-shadow: none !important;
}

.main-header-bar {
    padding: 0.8em 0;
}

.site-title a,
.ast-site-identity .site-title a {
    font-family: var(--pp-font-heading) !important;
    color: var(--pp-text) !important;
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: -0.02em;
}

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

.site-description {
    font-family: var(--pp-font-body) !important;
    color: var(--pp-sage) !important;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.01em;
}

/* Header navigation */
.main-header-menu > .menu-item > a,
.ast-header-sections-navigation .menu-item > a {
    font-family: var(--pp-font-body) !important;
    color: var(--pp-text) !important;
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    padding: 0 1em;
}

.main-header-menu > .menu-item > a:hover,
.main-header-menu > .menu-item.current-menu-item > a {
    color: var(--pp-sage) !important;
}

/* --------------------------------------------------------------------------
   Content Layout — Narrow Reading Column
   -------------------------------------------------------------------------- */
.ast-container {
    max-width: var(--pp-wide-width) !important;
}

/* Single post / page content area */
.single .site-content .ast-container,
.page .site-content .ast-container {
    max-width: var(--pp-content-width) !important;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

/* Full-width layout for single posts */
.single .site-content #primary,
.page .site-content #primary {
    width: 100% !important;
    max-width: var(--pp-content-width);
    margin: 0 auto;
    float: none !important;
}

/* Archive / blog listing */
.archive .ast-container,
.blog .ast-container {
    max-width: 900px !important;
}

/* Remove sidebar on single posts */
.single #secondary,
.page #secondary {
    display: none;
}

/* Content area spacing */
.site-content {
    padding-top: 2em;
    padding-bottom: 3em;
}

/* --------------------------------------------------------------------------
   Post Entry Styles
   -------------------------------------------------------------------------- */
.entry-title a {
    color: var(--pp-text) !important;
    text-decoration: none;
}

.entry-title a:hover {
    color: var(--pp-sage) !important;
}

/* Post meta */
.entry-meta,
.entry-meta a,
.ast-blog-single-element .post-meta,
.post-meta {
    font-family: var(--pp-font-body) !important;
    color: var(--pp-navy) !important;
    font-size: 0.85rem;
    font-weight: 400;
}

.entry-meta a:hover {
    color: var(--pp-sage) !important;
}

/* Category labels */
.cat-links a,
.entry-meta .cat-links a,
.ast-blog-single-element .cat-links a {
    color: var(--pp-sage) !important;
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.wp-block-button__link,
button,
input[type="submit"],
.ast-button,
.menu-toggle,
.ast-custom-button,
a.wp-block-button__link {
    background-color: var(--pp-sage) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: var(--pp-radius) !important;
    font-family: var(--pp-font-body) !important;
    font-weight: 500;
    font-size: 0.95rem;
    padding: 0.7em 1.5em !important;
    box-shadow: none !important;
    transition: background-color 0.2s ease, transform 0.1s ease;
    cursor: pointer;
    text-decoration: none !important;
    letter-spacing: 0.01em;
}

.wp-block-button__link:hover,
button:hover,
input[type="submit"]:hover,
.ast-button:hover,
a.wp-block-button__link:hover {
    background-color: var(--pp-sage-hover) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
}

/* Outline button variation */
.wp-block-button.is-style-outline .wp-block-button__link {
    background-color: transparent !important;
    color: var(--pp-sage) !important;
    border: 2px solid var(--pp-sage) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
    background-color: var(--pp-sage) !important;
    color: #ffffff !important;
}

/* --------------------------------------------------------------------------
   Cards & Content Blocks
   -------------------------------------------------------------------------- */
.wp-block-group,
.wp-block-cover {
    border-radius: var(--pp-radius);
}

/* Blog listing cards */
.ast-separate-container .ast-article-post,
.ast-separate-container .ast-article-single {
    background-color: #ffffff;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    box-shadow: none !important;
    padding: 2em;
    margin-bottom: 1.5em;
}

.ast-separate-container .ast-article-single {
    border: none;
    background-color: transparent;
    padding: 0;
}

/* Plain container style for posts */
.ast-plain-container .ast-article-post {
    margin-bottom: 2em;
    padding-bottom: 2em;
    border-bottom: 1px solid var(--pp-border);
}

/* --------------------------------------------------------------------------
   Forms
   -------------------------------------------------------------------------- */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
    background-color: #ffffff;
    border: 1px solid var(--pp-border) !important;
    border-radius: var(--pp-radius);
    padding: 0.65em 1em;
    font-family: var(--pp-font-body);
    font-size: 0.95rem;
    color: var(--pp-text);
    transition: border-color 0.2s ease;
    box-shadow: none !important;
    width: 100%;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
    border-color: var(--pp-sage) !important;
    outline: none;
    box-shadow: 0 0 0 2px rgba(122, 158, 126, 0.15) !important;
}

/* Validation states - no red, use navy or soft amber */
.wpcf7-not-valid,
input.error,
textarea.error {
    border-color: var(--pp-navy) !important;
}

.wpcf7-not-valid-tip,
.error-message {
    color: var(--pp-navy) !important;
    font-size: 0.85rem;
}

/* Search form */
.search-form {
    display: flex;
    gap: 0.5em;
}

.search-field {
    flex: 1;
}

/* --------------------------------------------------------------------------
   Tables
   -------------------------------------------------------------------------- */
.entry-content table {
    border-collapse: collapse;
    width: 100%;
    margin: 1.5em 0;
    font-size: 0.95rem;
}

.entry-content table th {
    background-color: var(--pp-sage-light);
    font-family: var(--pp-font-body);
    font-weight: 600;
    color: var(--pp-text);
    padding: 0.75em 1em;
    text-align: left;
    border: 1px solid var(--pp-border);
}

.entry-content table td {
    padding: 0.75em 1em;
    border: 1px solid var(--pp-border);
    vertical-align: top;
}

.entry-content table tr:nth-child(even) td {
    background-color: rgba(253, 251, 247, 0.5);
}

/* --------------------------------------------------------------------------
   Images & Media
   -----------------------------------------------------------------------
   Cascade context (load order, highest to lowest priority):
     1. WordPress core block CSS  — sets .wp-block-image img rules,
        display:table on aligned figures, :where(figcaption) margins.
     2. Astra inline <style>      — .entry-content .wp-block-image
        { margin-top:2em; margin-bottom:3em } (same specificity as ours,
        but injected after stylesheet; we must use !important to win).
     3. This stylesheet           — child theme overrides.
   ----------------------------------------------------------------------- */

/* Base image styles — responsive, rounded, block-level */
.entry-content img {
    border-radius: var(--pp-radius);
    height: auto;
    max-width: 100%;
    display: block;
}

/* Non-block-editor figures only. WordPress core already zeros out
   figure margin globally; Gutenberg figures are handled below. */
figure:not(.wp-block-image):not([class*="wp-block"]) {
    margin: 2em 0;
}

/* ---- WordPress block images (.wp-block-image = the outer figure) ----
   !important on both margin values is required to win over Astra's inline
   <style> rule: .entry-content .wp-block-image { margin-top:2em;
   margin-bottom:3em } which has identical specificity but loads after
   our stylesheet. Without !important Astra's 3em bottom margin wins. */
.entry-content .wp-block-image {
    margin-top: 2em !important;
    margin-bottom: 2.5em !important;
}

/* After a paragraph — same comfortable breathing room */
.entry-content p + .wp-block-image {
    margin-top: 2em !important;
}

/* After a heading — tighter gap so image reads as belonging to that section */
.entry-content h2 + .wp-block-image,
.entry-content h3 + .wp-block-image,
.entry-content h4 + .wp-block-image {
    margin-top: 1em !important;
}

/* Paragraph that follows an image — restore readable spacing */
.entry-content .wp-block-image + p {
    margin-top: 0.5em;
}

/* Heading that follows an image — generous separation */
.entry-content .wp-block-image + h2,
.entry-content .wp-block-image + h3,
.entry-content .wp-block-image + h4 {
    margin-top: 2em !important;
}

/* Back-to-back images — prevent gap runaway */
.entry-content .wp-block-image + .wp-block-image {
    margin-top: 1.5em !important;
}

/* Inner nested figure (legacy markup, WP <6.3) — no double margin */
.entry-content .wp-block-image figure {
    margin: 0;
}

/* Images inside .wp-block-image — full column width, consistent rounding */
.entry-content .wp-block-image img,
.entry-content figure.wp-block-image img {
    width: 100%;
    height: auto;
    border-radius: var(--pp-radius);
    display: block;
}

/* ---- Captions ----
   WordPress core sets .wp-block-image :where(figcaption)
   { margin-top:0.5em; margin-bottom:1em } via :where() (zero specificity).
   Our rule wins without !important. */
.entry-content figcaption,
.entry-content .wp-element-caption,
figcaption,
.wp-element-caption {
    font-size: 0.85rem;
    color: var(--pp-navy);
    text-align: center;
    margin-top: 0.5em;
    margin-bottom: 0;
    padding: 0 0.5em;
    font-style: italic;
    line-height: 1.5;
}

/* ---- Alignment ----
   WordPress core sets display:table on .alignleft/.alignright figures
   so captions work via caption-side. We preserve that and only
   adjust margins and max-width. */
.entry-content .wp-block-image.alignleft {
    float: left;
    margin-top: 0.5em !important;
    margin-right: 1.5em !important;
    margin-bottom: 1em !important;
    margin-left: 0 !important;
    max-width: 50%;
}

.entry-content .wp-block-image.alignright {
    float: right;
    margin-top: 0.5em !important;
    margin-right: 0 !important;
    margin-bottom: 1em !important;
    margin-left: 1.5em !important;
    max-width: 50%;
}

.entry-content .wp-block-image.aligncenter {
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center;
}

/* --------------------------------------------------------------------------
   Callout / Notice Boxes (wp-block-group with background)
   -------------------------------------------------------------------------- */
.wp-block-group.has-background {
    border-radius: var(--pp-radius);
    padding: 1.5em;
}

/* Medical disclaimer box styling */
.pp-disclaimer,
.medical-disclaimer,
.wp-block-group.is-style-disclaimer {
    background-color: #f4f5f7 !important;
    border-left: 3px solid var(--pp-navy);
    border-radius: var(--pp-radius);
    padding: 1.2em 1.5em;
    margin: 2em 0;
    font-size: 0.9rem;
    color: var(--pp-navy);
    line-height: 1.6;
}

/* Info callout */
.pp-callout,
.wp-block-group.is-style-callout {
    background-color: var(--pp-sage-light);
    border-left: 3px solid var(--pp-sage);
    border-radius: var(--pp-radius);
    padding: 1.2em 1.5em;
    margin: 2em 0;
}

/* --------------------------------------------------------------------------
   Site Footer
   -------------------------------------------------------------------------- */
.site-footer,
.ast-footer-overlay,
.ast-small-footer,
.site-below-footer-wrap,
.ast-footer-copyright,
footer.site-footer {
    background-color: var(--pp-navy) !important;
    color: rgba(255, 255, 255, 0.85) !important;
}

.site-footer a,
.ast-small-footer a,
.ast-footer-copyright a {
    color: var(--pp-terracotta) !important;
    text-decoration: none;
}

.site-footer a:hover,
.ast-small-footer a:hover {
    color: #ffffff !important;
}

.site-footer .widget-title {
    color: #ffffff !important;
}

/* Footer disclaimer */
.pp-footer-disclaimer {
    background-color: rgba(0, 0, 0, 0.15);
    padding: 1.2em 1.5em;
    text-align: center;
    font-size: 0.8rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.7);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.pp-footer-disclaimer p {
    margin: 0;
    color: rgba(255, 255, 255, 0.7);
}

/* Main footer content area */
.pp-footer-main {
    max-width: var(--pp-wide-width);
    margin: 0 auto;
    padding: 2.5em 1.5em 1.5em;
    text-align: center;
}

.pp-footer-main .pp-footer-brand {
    font-family: var(--pp-font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 0.3em;
}

.pp-footer-main .pp-footer-tagline {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 1.5em;
}

.pp-footer-main .pp-footer-nav {
    display: flex;
    justify-content: center;
    gap: 1.5em;
    flex-wrap: wrap;
    margin-bottom: 1.5em;
}

.pp-footer-main .pp-footer-nav a {
    font-size: 0.9rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.85) !important;
}

.pp-footer-main .pp-footer-nav a:hover {
    color: var(--pp-terracotta) !important;
}

.pp-footer-copyright-text {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.5);
}

/* --------------------------------------------------------------------------
   Breadcrumbs
   -------------------------------------------------------------------------- */
.ast-breadcrumbs,
.ast-breadcrumbs-wrapper {
    font-size: 0.8rem;
    color: var(--pp-navy);
}

.ast-breadcrumbs a {
    color: var(--pp-sage);
    text-decoration: none;
}

.ast-breadcrumbs a:hover {
    color: var(--pp-terracotta);
}

/* --------------------------------------------------------------------------
   Post Navigation
   -------------------------------------------------------------------------- */
.post-navigation .nav-links a {
    color: var(--pp-sage);
    text-decoration: none;
    font-weight: 500;
}

.post-navigation .nav-links a:hover {
    color: var(--pp-terracotta);
}

/* Pagination */
.ast-pagination a,
.page-links a {
    color: var(--pp-sage);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 0.4em 0.8em;
    text-decoration: none;
    transition: all 0.2s ease;
}

.ast-pagination a:hover,
.page-links a:hover {
    background-color: var(--pp-sage);
    color: #ffffff;
    border-color: var(--pp-sage);
}

.ast-pagination .current,
.page-links > span:not(.page-links-title) {
    background-color: var(--pp-sage);
    color: #ffffff;
    border: 1px solid var(--pp-sage);
    border-radius: var(--pp-radius);
    padding: 0.4em 0.8em;
}

/* --------------------------------------------------------------------------
   Comments
   -------------------------------------------------------------------------- */
.comments-area {
    margin-top: 3em;
    padding-top: 2em;
    border-top: 1px solid var(--pp-border);
}

.comment-body {
    padding: 1.5em;
    margin-bottom: 1em;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    background: #ffffff;
}

.comment-meta .comment-author {
    font-weight: 600;
    color: var(--pp-text);
}

.comment-metadata a {
    color: var(--pp-navy);
    font-size: 0.85rem;
    text-decoration: none;
}

/* --------------------------------------------------------------------------
   Widgets
   -------------------------------------------------------------------------- */
.widget {
    margin-bottom: 2em;
}

.widget-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1em;
    padding-bottom: 0.5em;
    border-bottom: 2px solid var(--pp-sage);
}

.widget ul {
    list-style: none;
    padding: 0;
}

.widget ul li {
    padding: 0.4em 0;
    border-bottom: 1px solid var(--pp-border-light);
}

.widget ul li a {
    text-decoration: none;
    color: var(--pp-text);
    font-size: 0.9rem;
}

.widget ul li a:hover {
    color: var(--pp-sage);
}

/* --------------------------------------------------------------------------
   Scroll to Top
   -------------------------------------------------------------------------- */
#ast-scroll-top {
    background-color: var(--pp-sage) !important;
    color: #ffffff !important;
    border-radius: var(--pp-radius) !important;
    box-shadow: none !important;
}

#ast-scroll-top:hover {
    background-color: var(--pp-sage-hover) !important;
}

/* --------------------------------------------------------------------------
   Table of Contents (if using Rank Math TOC)
   -------------------------------------------------------------------------- */
.wp-block-rank-math-toc-block {
    background: var(--pp-sage-light);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.5em 2em;
    margin: 2em 0;
}

.wp-block-rank-math-toc-block nav > ul {
    list-style: none;
    padding: 0;
}

.wp-block-rank-math-toc-block a {
    text-decoration: none;
    color: var(--pp-text);
    font-size: 0.93rem;
}

.wp-block-rank-math-toc-block a:hover {
    color: var(--pp-sage);
}

/* --------------------------------------------------------------------------
   Selection
   -------------------------------------------------------------------------- */
::selection {
    background-color: var(--pp-sage-light);
    color: var(--pp-text);
}

::-moz-selection {
    background-color: var(--pp-sage-light);
    color: var(--pp-text);
}

/* --------------------------------------------------------------------------
   Mobile Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
    body {
        font-size: 16px;
    }

    .single .site-content .ast-container,
    .page .site-content .ast-container {
        padding-left: 1.2rem;
        padding-right: 1.2rem;
    }

    .entry-content p,
    .entry-content li {
        font-size: 16px;
        line-height: 1.75;
    }

    h1, .entry-title {
        font-size: 1.6rem;
    }

    h2 {
        font-size: 1.3rem;
    }

    h3 {
        font-size: 1.1rem;
    }

    .ast-separate-container .ast-article-post {
        padding: 1.5em;
    }

    .pp-footer-main .pp-footer-nav {
        flex-direction: column;
        gap: 0.8em;
        align-items: center;
    }

    .main-header-bar {
        padding: 0.6em 0;
    }

    /* Images on mobile — slightly tighter overall, but preserve breathing room
       around section headings and between adjacent images */
    .entry-content .wp-block-image {
        margin-top: 1.5em !important;
        margin-bottom: 1.75em !important;
    }

    .entry-content p + .wp-block-image {
        margin-top: 1.75em !important;
    }

    .entry-content h2 + .wp-block-image,
    .entry-content h3 + .wp-block-image,
    .entry-content h4 + .wp-block-image,
    .entry-content .wp-block-heading + .wp-block-image {
        margin-top: 1.5em !important;
    }

    .entry-content .wp-block-image + h2,
    .entry-content .wp-block-image + h3,
    .entry-content .wp-block-image + h4,
    .entry-content .wp-block-image + .wp-block-heading {
        margin-top: 2.25em !important;
    }

    .entry-content .wp-block-image + .wp-block-image {
        margin-top: 1.75em !important;
    }

    /* Float images become full-width on mobile */
    .entry-content .wp-block-image.alignleft,
    .entry-content .wp-block-image.alignright {
        float: none;
        max-width: 100%;
        margin: 1.5em 0 !important;
    }

    /* Featured image spacing on mobile */
    .pp-featured-image,
    .single-post .post-thumb,
    .single-post .featured-image {
        margin-bottom: 1.5rem;
        border-radius: 8px;
    }
}

@media (max-width: 544px) {
    .single .site-content .ast-container,
    .page .site-content .ast-container {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .entry-content blockquote {
        margin-left: 0;
        margin-right: 0;
        padding: 1em 1.2em;
    }
}

/* --------------------------------------------------------------------------
   Astra Overrides — Remove harsh shadows, ensure warm tones
   -------------------------------------------------------------------------- */
.ast-separate-container .ast-article-post,
.ast-separate-container .ast-article-single,
.ast-separate-container .comments-area,
.ast-separate-container .ast-author-meta {
    box-shadow: none !important;
}

/* Override any Astra inline color styles */
.ast-primary-header-bar,
.site-header,
body .ast-builder-layout-element {
    background-color: var(--pp-bg) !important;
}

/* Override Astra's default blue links */
a,
.ast-single-post .entry-content a,
.ast-comment-list .comment-content a {
    color: var(--pp-sage);
}

/* Ensure no pure black anywhere */
body, p, li, td, th, span, div {
    color: var(--pp-text);
}

/* Override Astra's content background on separate container */
.ast-separate-container {
    background-color: var(--pp-bg) !important;
}

.ast-separate-container .site-content > .ast-container {
    background-color: transparent;
}

/* --------------------------------------------------------------------------
   Astra Global Colors Override
   -------------------------------------------------------------------------- */
body {
    --ast-global-color-0: var(--pp-sage);
    --ast-global-color-1: var(--pp-sage-hover);
    --ast-global-color-2: var(--pp-text);
    --ast-global-color-3: var(--pp-text);
    --ast-global-color-4: var(--pp-bg);
    --ast-global-color-5: var(--pp-bg);
    --ast-global-color-6: var(--pp-border);
    --ast-global-color-7: var(--pp-border-light);
    --ast-global-color-8: var(--pp-navy);
}

/* --------------------------------------------------------------------------
   Print Styles
   -------------------------------------------------------------------------- */
@media print {
    body {
        background: #ffffff !important;
        color: #000000 !important;
        font-size: 12pt;
    }

    .site-header,
    .site-footer,
    .pp-footer-disclaimer,
    #ast-scroll-top,
    .post-navigation,
    .comments-area {
        display: none !important;
    }

    .entry-content a::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        color: #666;
    }
}

/* --------------------------------------------------------------------------
   Hamburger / Mobile Menu Toggle - override generic button styles
   -------------------------------------------------------------------------- */
button.menu-toggle,
button.menu-toggle.ast-mobile-menu-trigger-minimal {
    background-color: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 4px 8px !important;
    box-shadow: none !important;
    color: var(--pp-charcoal) !important;
}

button.menu-toggle svg,
button.menu-toggle .ast-menu-svg,
button.menu-toggle .mobile-menu-toggle-icon {
    fill: var(--pp-charcoal) !important;
    color: var(--pp-charcoal) !important;
}

button.menu-toggle:hover,
button.menu-toggle:focus {
    background-color: transparent !important;
    color: var(--pp-sage) !important;
}

button.menu-toggle:hover svg,
button.menu-toggle:focus svg {
    fill: var(--pp-sage) !important;
    color: var(--pp-sage) !important;
}

/* Fix hamburger menu icon visibility on mobile */
.ast-header-break .ast-mobile-header-wrap .ast-below-header-bar .ast-below-header-sections,
.ast-header-break .ast-mobile-header-wrap .ast-main-header-bar .ast-main-header-sections {
    display: flex !important;
}

/* Ensure hamburger icon is visible */
.ast-button-wrap .ast-below-header-trigger .ast-below-header-trigger-icon,
.ast-button-wrap .ast-above-header-trigger .ast-above-header-trigger-icon,
.ast-button-wrap .ast-main-header-trigger .ast-main-header-trigger-icon {
    color: #FAF9F6 !important;
}

.ast-button-wrap .menu-toggle-icon {
    color: #FAF9F6 !important;
    fill: #FAF9F6 !important;
}

/* Alternative selector for Astra hamburger */
.main-header-bar-wrap .menu-toggle-icon {
    color: #FAF9F6 !important;
    fill: #FAF9F6 !important;
}

/* Force icon lines to be visible */
.ast-mobile-header-wrap .ast-button-wrap .menu-toggle-icon svg,
.ast-mobile-header-wrap .ast-button-wrap .menu-toggle-icon path {
    fill: #FAF9F6 !important;
    color: #FAF9F6 !important;
}

/* Mobile hamburger menu - force visible icon */
.ast-mobile-header-wrap .ast-button-wrap .menu-toggle-icon,
.ast-mobile-header-wrap .ast-button-wrap .ast-below-header-trigger-icon,
.ast-mobile-header-wrap .ast-button-wrap .ast-main-header-trigger-icon {
    color: #FAF9F6 !important;
    fill: #FAF9F6 !important;
}

/* Target the SVG icon specifically */
.ast-mobile-header-wrap .ast-button-wrap svg,
.ast-mobile-header-wrap .ast-button-wrap svg path,
.ast-mobile-header-wrap .menu-toggle-icon svg {
    fill: #FAF9F6 !important;
}

/* Hamburger lines */
.ast-button-wrap .menu-toggle-icon .ast-icon svg {
    fill: #FAF9F6 !important;
}

.ast-button-wrap .menu-toggle-icon .ast-icon {
    color: #FAF9F6 !important;
}

/* Fix site title wrapping in header */
.site-title,
.ast-site-identity .site-title,
.ast-site-title-wrap .site-title {
    white-space: nowrap !important;
    display: inline-block !important;
}

/* Ensure logo and title display properly */
.ast-site-identity {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.ast-site-identity .custom-logo-link,
.ast-site-identity .site-logo-img {
    display: inline-block !important;
    vertical-align: middle !important;
}

/* Hide site title text - logo only */
.site-title,
.ast-site-title-wrap .site-title,
.ast-site-identity .site-title {
    display: none !important;
}

/* Fix duplicate title issue - hide any extra title elements */
.entry-content h1:first-child,
.entry-content h2:first-child {
    display: none !important;
}

/* Ensure the main entry title is visible */
.entry-header .entry-title {
    display: block !important;
}

/* Logo size constraint */
.ast-site-identity .custom-logo-link img,
.custom-logo {
    max-height: 48px !important;
    width: auto !important;
    height: auto !important;
}

/* Display featured image at top of single posts */
.single-post .post-thumb,
.single-post .featured-image,
.single-post .ast-single-post-image {
    display: block !important;
    width: 100% !important;
    max-height: 400px;
    overflow: hidden;
    margin-bottom: 2rem;
    border-radius: 8px;
}

.single-post .post-thumb img,
.single-post .featured-image img,
.single-post .ast-single-post-image img {
    width: 100% !important;
    height: auto !important;
    object-fit: cover;
}

/* Display featured image at top of single posts */
.pp-featured-image {
    display: block;
    width: 100%;
    max-height: 400px;
    overflow: hidden;
    margin-bottom: 2rem;
    border-radius: 12px;
}

.pp-featured-image img,
.pp-hero-image {
    width: 100% !important;
    height: auto !important;
    max-height: 400px;
    object-fit: cover;
    border-radius: 12px;
}

/* Fix infographic header text visibility - FORCE white text with shadow */
.pp-infographic-header,
.pp-infographic-header h3,
.pp-infographic-header .pp-infographic-subtitle,
.pp-infographic-header p {
    color: #FFFFFF !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
    font-weight: 600 !important;
}

.pp-infographic-header h3 {
    font-size: 1.4rem !important;
    margin-bottom: 0.5rem !important;
}

.pp-infographic-header .pp-infographic-subtitle {
    font-size: 1rem !important;
    opacity: 0.95 !important;
}

/* Ensure header has proper contrast background */
.pp-infographic-header {
    background: linear-gradient(135deg, #4A5A6A 0%, #3D4045 100%) !important;
    padding: 1.5rem !important;
    border-radius: 12px 12px 0 0 !important;
}

/* Alternative: If using purple theme, darken it */
.pp-infographic[style*="purple"],
.pp-infographic[style*="#8B7CB3"],
.pp-infographic[style*="lavender"] .pp-infographic-header {
    background: linear-gradient(135deg, #5A4A6A 0%, #4A3A5A 100%) !important;
}

/* Force all infographic titles to be readable - EXCLUDES header (h3 in header handled separately) */
.pp-infographic .pp-phase h3,
.pp-infographic .pp-phase-title,
.pp-infographic .pp-phase h4 {
    color: #3D4045 !important;
    font-weight: 600 !important;
}

/* Phase cards text */
.pp-phase {
    color: #3D4045 !important;
}

.pp-phase p {
    color: #3D4045 !important;
    line-height: 1.6 !important;
}

/* Fix recovery infographic header (pp-rec-header) */
.pp-rec-header,
.pp-rec-header h3 {
    color: #FFFFFF !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
    font-weight: 700 !important;
}

.pp-rec-header {
    background: linear-gradient(135deg, #4A5A6A 0%, #3D4045 100%) !important;
    padding: 1.5rem !important;
    border-radius: 12px 12px 0 0 !important;
    text-align: center !important;
}

.pp-rec-header h3 {
    font-size: 1.5rem !important;
    margin-bottom: 0.5rem !important;
}

/* Fix any subtitle/text in the header */
.pp-rec-header p,
.pp-rec-header .pp-rec-subtitle {
    color: #FFFFFF !important;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
    font-size: 1rem !important;
    opacity: 0.95 !important;
}

/* CLEAN FIX: Text colors */

/* Single article pages - DARK text on light background (default) */
.single-post .entry-content,
.single-post .entry-content p,
.single-post .entry-content h1,
.single-post .entry-content h2,
.single-post .entry-content h3,
.single-post .entry-content li {
    color: #3D4045 !important;
}

/* Hero section (homepage top) - LIGHT text on dark background */
.ast-below-header-bar-wrap,
.ast-below-header-bar-wrap h1,
.ast-below-header-bar-wrap h2,
.ast-below-header-bar-wrap p {
    color: #FAF9F6 !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* Article cards on homepage - DARK text */
.ast-grid-common-wrap article .entry-content,
.ast-grid-common-wrap article .entry-content p,
.ast-grid-common-wrap article .entry-title,
.ast-grid-common-wrap article .entry-title a {
    color: #3D4045 !important;
}

/* EMERGENCY: Force all article content to be visible */
.entry-content,
.entry-content p,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content li,
.entry-content span,
.entry-content div,
.single-post .entry-content,
.single-post .entry-content *,
.single-post article .entry-content,
.single-post article .entry-content * {
    color: #3D4045 !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* FINAL FIX: All text visibility */
html body.single-post .ast-article-single .entry-content,
html body.single-post .ast-article-single .entry-content p,
html body.single-post .ast-article-single .entry-content h1,
html body.single-post .ast-article-single .entry-content h2,
html body.single-post .ast-article-single .entry-content h3,
html body.single-post .ast-article-single .entry-content h4,
html body.single-post .ast-article-single .entry-content li {
    color: #3D4045 !important;
    visibility: visible !important;
}

/* Inline elements must remain inline — never force block display */
html body.single-post .ast-article-single .entry-content strong,
html body.single-post .ast-article-single .entry-content em {
    color: #3D4045 !important;
    visibility: visible !important;
    display: inline !important;
}

/* ULTRA SPECIFIC: Force all content visible */
body.single-post .site-content .ast-container .ast-row .ast-col .ast-article-single .entry-content,
body.single-post .site-content .ast-container .ast-row .ast-col .ast-article-single .entry-content * {
    color: #3D4045 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Hero Section: dark text on light background */
.hero-section,
.hero-section h1,
.hero-section h2,
.hero-section p,
.hero-section .wp-block-heading {
    color: var(--pp-text) !important;
    text-shadow: none !important;
}


/* ==========================================================================
   YMYL SAFEGUARD: Crisis Resources Banner
   ========================================================================== */
.crisis-banner {
    background: #fef3c7; /* amber-100 */
    border-bottom: 2px solid #f59e0b; /* amber-500 */
    padding: 12px 20px;
    text-align: center;
    font-size: 0.95em;
    font-family: system-ui, -apple-system, sans-serif;
    line-height: 1.6;
    position: relative;
    z-index: 9999;
    width: 100%;
    box-sizing: border-box;
}
.crisis-banner strong {
    color: #92400e;
}
.crisis-banner a {
    color: #b45309;
    text-decoration: underline;
}
.crisis-banner a:hover {
    color: #92400e;
}
.comments-area, #comments, .comment-respond, #respond { display: none !important; }
