/*
Theme Name: Newspaper Child Theme (Savvy Money Hacks)
Theme URI: https://savvymoneyhacks.com/
Description: A custom child theme for Savvy Money Hacks personal finance blog. Tailored design for saving, earning, freebies, and reviews.
Author: Antigravity
Author URI: https://deepmind.google/
Template: Newspaper
Version: 1.0.0
*/

/* ==========================================================================
   SAVVY MONEY HACKS DESIGN SYSTEM (CSS VARIABLES)
   ========================================================================== */
:root {
    /* Color Palette */
    --savvy-blue-dark: #0F172A;      /* Trust Navy (Slate 900) */
    --savvy-blue-medium: #0284C7;    /* Actions Blue (Sky 600) */
    --savvy-blue-light: #F0F9FF;     /* Soft Sky (Sky 50) */
    --savvy-green-growth: #10B981;   /* Savings Green (Emerald 500) */
    --savvy-green-dark: #065F46;     /* Forest Green (Emerald 800) */
    --savvy-green-light: #ECFDF5;    /* Soft Mint (Emerald 50) */
    --savvy-gold-accent: #F59E0B;    /* Wealth Gold CTA (Amber 500) */
    --savvy-gold-dark: #D97706;      /* Wealth Gold Hover (Amber 700) */
    --savvy-gold-light: #FEF3C7;     /* Soft Gold Background (Amber 50) */
    --savvy-white: #FFFFFF;
    --savvy-bg-base: #F8FAFC;        /* Body Background (Slate 50) */
    
    /* Text Colors */
    --savvy-text-primary: #1E293B;   /* Slate 800 */
    --savvy-text-secondary: #64748B; /* Slate 500 */
    --savvy-text-light: #94A3B8;     /* Slate 400 */
    
    /* Shadow Systems */
    --savvy-shadow-sm: 0 1px 3px 0 rgba(15, 23, 42, 0.05);
    --savvy-shadow-md: 0 4px 6px -1px rgba(15, 23, 42, 0.05), 0 2px 4px -2px rgba(15, 23, 42, 0.05);
    --savvy-shadow-lg: 0 10px 25px -5px rgba(15, 23, 42, 0.08), 0 8px 10px -6px rgba(15, 23, 42, 0.08);
    
    /* Animation system */
    --savvy-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ==========================================================================
   TYPOGRAPHY & GLOBALS OVERRIDES (WHEN CLASSES ARE APPLIED)
   ========================================================================== */
.savvy-hero h1,
.savvy-hero h2,
.savvy-hero h3,
.savvy-trending h2,
.savvy-must-read h2,
.savvy-categories h3,
.savvy-title {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

.savvy-hero p,
.savvy-trending p,
.savvy-must-read p,
.savvy-body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

/* Ensure clean base section spacing */
.savvy-section {
    padding: 60px 0 !important;
    background-color: var(--savvy-white);
}
.savvy-section-alt {
    padding: 60px 0 !important;
    background-color: var(--savvy-bg-base);
}

/* ==========================================================================
   HOMEPAGE HERO SECTION (.savvy-hero)
   ========================================================================== */
/* The parent Row block in tagDiv Composer */
.savvy-hero {
    position: relative;
    padding: 90px 0 !important;
    background: linear-gradient(135deg, #FFFFFF 0%, #F5F9FF 50%, #ECFDF5 100%) !important;
    border-bottom: 1px solid #E2E8F0 !important;
    overflow: hidden;
}

/* Soft glowing backgrounds inside the Hero (simulating premium design) */
.savvy-hero::before {
    content: '';
    position: absolute;
    top: -10%;
    right: -5%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.08) 0%, rgba(255, 255, 255, 0) 70%);
    z-index: 0;
    pointer-events: none;
}

.savvy-hero::after {
    content: '';
    position: absolute;
    bottom: -10%;
    left: -5%;
    width: 350px;
    height: 350px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.05) 0%, rgba(255, 255, 255, 0) 70%);
    z-index: 0;
    pointer-events: none;
}

/* Ensure content sits above glow elements */
.savvy-hero > .vc_column_container {
    z-index: 1;
}

/* Headline Styling */
.savvy-hero h1,
.savvy-hero .tdb-title-text {
    font-size: 3.5rem !important;
    font-weight: 800 !important;
    color: var(--savvy-blue-dark) !important;
    line-height: 1.15 !important;
    letter-spacing: -0.03em !important;
    margin-bottom: 24px !important;
}

.savvy-hero h1 span,
.savvy-hero .tdb-title-text span {
    color: var(--savvy-green-growth) !important;
}

/* Subheadline Styling */
.savvy-hero p,
.savvy-hero .savvy-subheadline {
    font-size: 1.25rem !important;
    color: var(--savvy-text-secondary) !important;
    line-height: 1.6 !important;
    max-width: 620px;
    margin-bottom: 36px !important;
}

/* CTA BUTTONS */
.savvy-cta-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 15px 32px !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    border-radius: 8px !important;
    transition: var(--savvy-transition) !important;
    text-decoration: none !important;
    cursor: pointer !important;
    border: none !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    letter-spacing: -0.01em !important;
    box-sizing: border-box;
}

/* Primary emerald CTA */
.savvy-cta-btn-primary {
    background-color: var(--savvy-green-growth) !important;
    color: var(--savvy-white) !important;
    box-shadow: 0 4px 14px 0 rgba(16, 185, 129, 0.35) !important;
}

.savvy-cta-btn-primary:hover {
    background-color: #0D9488 !important; /* Slightly darker teal/green on hover */
    color: var(--savvy-white) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px 0 rgba(13, 148, 136, 0.45) !important;
}

/* Secondary outline CTA */
.savvy-cta-btn-secondary {
    background-color: var(--savvy-white) !important;
    color: var(--savvy-blue-dark) !important;
    border: 2px solid #E2E8F0 !important;
    margin-left: 16px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
}

.savvy-cta-btn-secondary:hover {
    background-color: var(--savvy-blue-light) !important;
    border-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-blue-medium) !important;
    transform: translateY(-2px) !important;
    box-shadow: var(--savvy-shadow-md) !important;
}

/* ==========================================================================
   TRENDING SECTION (.savvy-trending)
   ========================================================================== */
/* Styles for Newspaper Flex Block containers (tdb_flex_loop or td_block_flex) */
.savvy-trending .td-module-container {
    background: var(--savvy-white) !important;
    border: 1px solid #EAF2F9 !important;
    border-radius: 12px !important;
    padding: 16px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    transition: var(--savvy-transition) !important;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.savvy-trending .td-module-container:hover {
    transform: translateY(-5px) !important;
    box-shadow: var(--savvy-shadow-lg) !important;
    border-color: #CBD5E1 !important;
}

/* Rounded cards for images */
.savvy-trending .td-image-container {
    border-radius: 8px !important;
    overflow: hidden !important;
    margin-bottom: 16px !important;
}

/* Custom overlay or badge styles for Categories */
.savvy-trending .td-post-category {
    background-color: var(--savvy-green-light) !important;
    color: var(--savvy-green-dark) !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    padding: 5px 12px !important;
    border-radius: 6px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: var(--savvy-transition) !important;
    display: inline-block;
    margin-bottom: 8px;
}

.savvy-trending .td-post-category:hover {
    background-color: var(--savvy-green-growth) !important;
    color: var(--savvy-white) !important;
}

/* Title enhancements */
.savvy-trending .entry-title {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    margin-bottom: 12px !important;
    color: var(--savvy-blue-dark) !important;
}

.savvy-trending .entry-title a {
    color: var(--savvy-blue-dark) !important;
}

.savvy-trending .entry-title a:hover {
    color: var(--savvy-blue-medium) !important;
}

/* Sub-info layout */
.savvy-trending .td-editor-date {
    margin-top: auto;
    font-size: 0.8rem !important;
    color: var(--savvy-text-light) !important;
    border-top: 1px solid #F1F5F9;
    padding-top: 12px;
}

/* ==========================================================================
   MUST READ SECTION (.savvy-must-read)
   ========================================================================== */
/* Compact vertical list style for sidebars or secondary grids */
.savvy-must-read .td-module-container {
    display: flex !important;
    align-items: center !important;
    padding: 16px !important;
    background: var(--savvy-white) !important;
    border-left: 4px solid var(--savvy-blue-medium) !important;
    border-radius: 0 10px 10px 0 !important;
    margin-bottom: 16px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-must-read .td-module-container:hover {
    background: var(--savvy-blue-light) !important;
    border-left-color: var(--savvy-green-growth) !important;
    transform: translateX(4px) !important;
    box-shadow: var(--savvy-shadow-md) !important;
}

/* Image styling in must-read lists */
.savvy-must-read .td-image-container {
    width: 80px !important;
    height: 80px !important;
    min-width: 80px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    margin-right: 16px !important;
    margin-bottom: 0 !important;
}

.savvy-must-read .entry-title {
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    color: var(--savvy-blue-dark) !important;
    margin: 0 !important;
}

.savvy-must-read .entry-title a {
    color: var(--savvy-blue-dark) !important;
}

.savvy-must-read .entry-title a:hover {
    color: var(--savvy-green-growth) !important;
}

/* Custom list-number feature if tagDiv flex block handles numbers */
.savvy-must-read-numbered {
    counter-reset: must-read-counter;
}

.savvy-must-read-numbered .td-module-container {
    position: relative;
    padding-left: 54px !important;
    border-left: none !important;
    border-radius: 10px !important;
}

.savvy-must-read-numbered .td-module-container::before {
    counter-increment: must-read-counter;
    content: counter(must-read-counter, decimal-leading-zero);
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--savvy-blue-medium);
    opacity: 0.7;
}

/* ==========================================================================
   CATEGORIES SECTION (.savvy-categories)
   ========================================================================== */
/* Category badging lists (usually customized lists or standard menus) */
.savvy-categories {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    padding: 12px 0 !important;
}

/* Targets standard elements or list block anchors */
.savvy-categories a,
.savvy-categories .td-category-list a,
.savvy-category-badge {
    background: var(--savvy-white) !important;
    color: var(--savvy-blue-dark) !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
    transition: var(--savvy-transition) !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-decoration: none !important;
}

/* Dynamic category colors depending on tags or lists */
.savvy-categories a:hover,
.savvy-categories .td-category-list a:hover,
.savvy-category-badge:hover {
    background-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
    border-color: var(--savvy-blue-medium) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 16px 0 rgba(37, 99, 235, 0.2) !important;
}

/* Optional styling to make specific words stand out (e.g. green focus for Saving) */
.savvy-categories a[href*="saving"]:hover,
.savvy-categories a[href*="money"]:hover {
    background-color: var(--savvy-green-growth) !important;
    border-color: var(--savvy-green-growth) !important;
    box-shadow: 0 8px 16px 0 rgba(16, 185, 129, 0.2) !important;
}

/* ==========================================================================
   RESPONSIVE DESIGN (MOBILE OPTIMIZATIONS)
   ========================================================================== */
@media (max-width: 1018px) {
    .savvy-hero {
        padding: 60px 0 !important;
    }
    .savvy-hero h1,
    .savvy-hero .tdb-title-text {
        font-size: 2.8rem !important;
    }
}

@media (max-width: 767px) {
    /* Hero styling changes */
    .savvy-hero {
        padding: 50px 0 !important;
        text-align: center;
    }
    
    .savvy-hero h1,
    .savvy-hero .tdb-title-text {
        font-size: 2.25rem !important;
        line-height: 1.25 !important;
        letter-spacing: -0.02em !important;
    }
    
    .savvy-hero p,
    .savvy-hero .savvy-subheadline {
        font-size: 1.1rem !important;
        margin-left: auto;
        margin-right: auto;
    }
    
    /* Force CTA buttons to stack on small viewports */
    .savvy-cta-btn {
        width: 100% !important;
        margin-left: 0 !important;
        margin-bottom: 12px;
    }
    
    .savvy-cta-btn:last-child {
        margin-bottom: 0;
    }
    
    /* Trending layouts stacking cleanly */
    .savvy-trending .td-module-container {
        margin-bottom: 16px;
    }
    
    /* Category Badges wrapping */
    .savvy-categories {
        justify-content: center;
        gap: 8px !important;
    }
    .savvy-categories a {
        padding: 10px 18px !important;
    }
}

/* ==========================================================================
   SINGLE POST LAYOUT & READABILITY (.savvy-post-content)
   ========================================================================== */
.savvy-post-content {
    font-size: 18px !important;
    line-height: 1.8 !important;
    color: var(--savvy-text-primary) !important;
    font-family: 'Inter', sans-serif !important;
}

.savvy-post-content p {
    margin-bottom: 24px !important;
    font-size: 18px !important;
    line-height: 1.8 !important;
}

.savvy-post-content h2,
.savvy-post-content h3,
.savvy-post-content h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    color: var(--savvy-blue-dark) !important;
    font-weight: 800 !important;
    margin-top: 40px !important;
    margin-bottom: 18px !important;
    letter-spacing: -0.02em !important;
}

.savvy-post-content h2 {
    font-size: 28px !important;
    border-bottom: 2px solid #F1F5F9;
    padding-bottom: 8px;
}

.savvy-post-content h3 {
    font-size: 22px !important;
}

.savvy-post-content blockquote {
    border-left: 4px solid var(--savvy-green-growth) !important;
    background: var(--savvy-green-light) !important;
    padding: 20px 24px !important;
    border-radius: 0 8px 8px 0 !important;
    margin: 32px 0 !important;
    font-style: italic !important;
    color: var(--savvy-green-dark) !important;
}

.savvy-post-content ul, 
.savvy-post-content ol {
    margin-bottom: 28px !important;
    padding-left: 24px !important;
}

.savvy-post-content li {
    margin-bottom: 10px !important;
    line-height: 1.6 !important;
}

/* ==========================================================================
   FEATURED IMAGE HEADER WITH GRADIENT OVERLAY (.savvy-post-header)
   ========================================================================== */
.savvy-post-header {
    position: relative !important;
    background-size: cover !important;
    background-position: center !important;
    padding: 80px 0 60px 0 !important;
    color: var(--savvy-white) !important;
    border-radius: 0 0 16px 16px !important;
    overflow: hidden !important;
}

/* Tinted gradient overlay for readability */
.savvy-post-header::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(180deg, rgba(10, 37, 64, 0.45) 0%, rgba(10, 37, 64, 0.85) 100%) !important;
    z-index: 1 !important;
}

.savvy-post-header-content {
    position: relative !important;
    z-index: 2 !important;
}

.savvy-post-header h1,
.savvy-post-header .tdb-title-text {
    color: var(--savvy-white) !important;
    font-size: 2.75rem !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
    letter-spacing: -0.02em !important;
    margin-bottom: 20px !important;
    text-shadow: 0 2px 4px rgba(10, 37, 64, 0.15) !important;
}

.savvy-post-header-meta {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    font-size: 0.9rem !important;
    font-family: 'Inter', sans-serif !important;
    opacity: 0.95 !important;
}

/* ==========================================================================
   TABLE OF CONTENTS OVERRIDES (.savvy-toc)
   ========================================================================== */
.savvy-toc {
    background: var(--savvy-bg-base) !important;
    border: 1px solid #E2E8F0 !important;
    border-left: 4px solid var(--savvy-green-growth) !important;
    border-radius: 8px !important;
    padding: 20px !important;
    margin: 32px 0 !important;
    box-shadow: var(--savvy-shadow-sm) !important;
}

.savvy-toc .tdb-block-title-wrap h4,
.savvy-toc .td-block-title {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    color: var(--savvy-blue-dark) !important;
    margin-bottom: 14px !important;
}

.savvy-toc ul {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 0 !important;
}

.savvy-toc li {
    margin-bottom: 8px !important;
    font-size: 0.95rem !important;
    line-height: 1.4 !important;
}

.savvy-toc a {
    color: var(--savvy-blue-dark) !important;
    text-decoration: none !important;
    transition: var(--savvy-transition) !important;
}

.savvy-toc a:hover {
    color: var(--savvy-blue-medium) !important;
    padding-left: 6px !important;
}

/* ==========================================================================
   STICKY SIDEBAR WIDGETS
   ========================================================================== */
/* Affiliate Disclosure Widget */
.savvy-disclosure {
    background: var(--savvy-blue-light) !important;
    border: 1px dashed var(--savvy-blue-medium) !important;
    border-radius: 8px !important;
    padding: 16px !important;
    font-size: 0.85rem !important;
    line-height: 1.5 !important;
    color: var(--savvy-text-secondary) !important;
    margin-bottom: 24px !important;
    font-family: 'Inter', sans-serif !important;
}

.savvy-disclosure strong {
    color: var(--savvy-blue-dark) !important;
}

/* Newsletter Widget */
.savvy-sidebar-newsletter {
    background: linear-gradient(135deg, var(--savvy-blue-dark) 0%, #1E3A8A 100%) !important;
    color: var(--savvy-white) !important;
    border-radius: 12px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
    box-shadow: var(--savvy-shadow-md) !important;
    text-align: center !important;
}

.savvy-sidebar-newsletter h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.3rem !important;
    font-weight: 700 !important;
    color: var(--savvy-white) !important;
    margin-bottom: 8px !important;
}

.savvy-sidebar-newsletter p {
    font-size: 0.9rem !important;
    line-height: 1.4 !important;
    opacity: 0.85 !important;
    margin-bottom: 18px !important;
}

.savvy-sidebar-newsletter input[type="email"] {
    width: 100% !important;
    padding: 12px 14px !important;
    border-radius: 6px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--savvy-white) !important;
    margin-bottom: 12px !important;
    font-size: 0.9rem !important;
}

.savvy-sidebar-newsletter input[type="email"]::placeholder {
    color: rgba(255, 255, 255, 0.6) !important;
}

.savvy-sidebar-newsletter button,
.savvy-sidebar-newsletter input[type="submit"] {
    width: 100% !important;
    background-color: var(--savvy-green-growth) !important;
    color: var(--savvy-white) !important;
    border: none !important;
    padding: 12px 14px !important;
    font-weight: 700 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: var(--savvy-transition) !important;
}

.savvy-sidebar-newsletter button:hover,
.savvy-sidebar-newsletter input[type="submit"]:hover {
    background-color: #059669 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 10px 0 rgba(16, 185, 129, 0.3) !important;
}

/* ==========================================================================
   SOCIAL SHARING OVERRIDES (.savvy-social-share)
   ========================================================================== */
.savvy-social-share {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin: 28px 0 !important;
}

.savvy-social-share .td-social-sharing-button {
    border-radius: 30px !important;
    border: 1px solid #E2E8F0 !important;
    background: var(--savvy-white) !important;
    color: var(--savvy-text-primary) !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    padding: 8px 18px !important;
    transition: var(--savvy-transition) !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    display: inline-flex !important;
    align-items: center !important;
    text-decoration: none !important;
}

.savvy-social-share .td-social-sharing-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--savvy-shadow-md) !important;
    border-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-blue-medium) !important;
}

.savvy-social-share .td-social-icon {
    margin-right: 6px !important;
    font-size: 1rem !important;
}

/* ==========================================================================
   ENHANCED AUTHOR BOX (.savvy-author-box)
   ========================================================================== */
.savvy-author-box {
    background: var(--savvy-white) !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 12px !important;
    padding: 24px !important;
    margin: 48px 0 !important;
    box-shadow: var(--savvy-shadow-md) !important;
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
}

.savvy-author-box img,
.savvy-author-box .avatar {
    width: 90px !important;
    height: 90px !important;
    border-radius: 50% !important;
    border: 3px solid var(--savvy-blue-light) !important;
    object-fit: cover !important;
}

.savvy-author-box-content {
    flex: 1;
}

.savvy-author-box .tdb-author-name {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.3rem !important;
    font-weight: 700 !important;
    color: var(--savvy-blue-dark) !important;
    margin-bottom: 6px !important;
}

.savvy-author-box .tdb-author-descr {
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
    color: var(--savvy-text-secondary) !important;
    margin-bottom: 12px !important;
}

.savvy-author-box .tdb-author-social {
    display: flex !important;
    gap: 12px !important;
}

.savvy-author-box .tdb-author-social a {
    color: var(--savvy-text-light) !important;
    transition: var(--savvy-transition) !important;
    font-size: 0.95rem !important;
}

.savvy-author-box .tdb-author-social a:hover {
    color: var(--savvy-blue-medium) !important;
}

/* ==========================================================================
   RELATED POSTS CARD OVERRIDES (.savvy-related-posts)
   ========================================================================== */
.savvy-related-posts .td-module-container {
    background: var(--savvy-white) !important;
    border: 1px solid #F1F5F9 !important;
    border-radius: 10px !important;
    padding: 12px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-related-posts .td-module-container:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--savvy-shadow-md) !important;
    border-color: #E2E8F0 !important;
}

.savvy-related-posts .td-image-container {
    border-radius: 6px !important;
    overflow: hidden !important;
    margin-bottom: 12px !important;
}

.savvy-related-posts .entry-title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    margin: 8px 0 !important;
}

/* Media Query overrides for single post layout */
@media (max-width: 767px) {
    .savvy-post-header {
        padding: 40px 0 30px 0 !important;
    }
    
    .savvy-post-header h1,
    .savvy-post-header .tdb-title-text {
        font-size: 2rem !important;
    }
    
    .savvy-post-content {
        font-size: 17px !important;
    }
    
    .savvy-post-content p {
        font-size: 17px !important;
    }
    
    .savvy-author-box {
        flex-direction: column !important;
        text-align: center !important;
        padding: 20px !important;
    }
    
    .savvy-author-box img,
    .savvy-author-box .avatar {
        width: 80px !important;
    }
}

/* ==========================================================================
   GLOBAL BRAND OVERRIDES FOR NEWSPAPER BLOCKS
   ========================================================================== */
/* Standard text link color rules */
a {
    color: var(--savvy-blue-medium);
    transition: var(--savvy-transition);
}

a:hover {
    color: var(--savvy-blue-dark);
    text-decoration: none;
}

/* Enforce headline/header colors sitewide */
h1, h2, h3, h4, h5, h6,
.tdb-title-text,
.td-block-title,
.td-block-title a,
.entry-title a,
.td-module-title a {
    color: var(--savvy-blue-dark) !important;
}

/* Hover highlights for post title links */
.entry-title a:hover,
.td-module-title a:hover {
    color: var(--savvy-blue-medium) !important;
}

/* Newspaper Category Badges override */
.td-post-category {
    background-color: var(--savvy-blue-light) !important;
    color: var(--savvy-blue-medium) !important;
    transition: var(--savvy-transition) !important;
}

.td-post-category:hover {
    background-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
}

/* tagDiv standard button override */
.tdb-btn {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    background-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
    border-radius: 6px !important;
    transition: var(--savvy-transition) !important;
}

.tdb-btn:hover {
    background-color: var(--savvy-blue-dark) !important;
    color: var(--savvy-white) !important;
    transform: translateY(-1px) !important;
}

/* ==========================================================================
   WEALTH GOLD CTA BUTTONS (.savvy-cta-btn-gold)
   ========================================================================== */
.savvy-cta-btn-gold {
    background-color: var(--savvy-gold-accent) !important;
    color: var(--savvy-blue-dark) !important;
    box-shadow: 0 4px 14px 0 rgba(245, 158, 11, 0.35) !important;
}

.savvy-cta-btn-gold:hover {
    background-color: var(--savvy-gold-dark) !important;
    color: var(--savvy-white) !important;
    box-shadow: 0 6px 20px 0 rgba(217, 119, 6, 0.45) !important;
}

/* ==========================================================================
   STICKY HEADER GLASSMORPHISM & TRANSITIONS
   ========================================================================== */
/* Target the active sticky state row in tagDiv Composer Header templates */
.tdc-header-wrap .td-sticky-header-active,
.td-header-wrap .td-sticky-header-active,
.td-sticky-header-active {
    background-color: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    box-shadow: 0 4px 20px -5px rgba(15, 23, 42, 0.08) !important;
    transition: var(--savvy-transition) !important;
}

/* Shrink height of elements slightly on sticky state for clean UX */
.td-sticky-header-active .tdc-columns {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    transition: var(--savvy-transition) !important;
}

/* ==========================================================================
   MAIN NAVIGATION MENU & MEGA MENU OVERRIDES (.savvy-nav-menu)
   ========================================================================== */
.savvy-nav-menu {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
}

/* Main Menu Items */
.savvy-nav-menu .tdb-menu-items-wrap > li > a {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    color: var(--savvy-blue-dark) !important;
    padding: 0 16px !important;
    letter-spacing: -0.01em !important;
    transition: var(--savvy-transition) !important;
}

.savvy-nav-menu .tdb-menu-items-wrap > li > a:hover,
.savvy-nav-menu .tdb-menu-items-wrap > li.current-menu-item > a {
    color: var(--savvy-blue-medium) !important;
}

/* Mega Menu Panel Overrides */
.savvy-nav-menu .tdb-mega-menu-wrap,
.savvy-nav-menu .tdb-sub-menu {
    border-top: 4px solid var(--savvy-blue-medium) !important;
    border-radius: 0 0 12px 12px !important;
    box-shadow: var(--savvy-shadow-lg) !important;
    padding: 24px !important;
    background-color: var(--savvy-white) !important;
    border-right: 1px solid #E2E8F0 !important;
    border-bottom: 1px solid #E2E8F0 !important;
    border-left: 1px solid #E2E8F0 !important;
}

/* Mega Menu sub-categories list */
.savvy-nav-menu .tdb-mega-menu-cats a {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    color: var(--savvy-blue-dark) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-nav-menu .tdb-mega-menu-cats a:hover {
    color: var(--savvy-blue-medium) !important;
    padding-left: 4px !important;
}

/* Mega Menu post items */
.savvy-nav-menu .tdb-mega-post .td-module-title a {
    font-family: 'Inter', sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    color: var(--savvy-blue-dark) !important;
}

.savvy-nav-menu .tdb-mega-post .td-module-title a:hover {
    color: var(--savvy-blue-medium) !important;
}

/* ==========================================================================
   HEADER SEARCH MODULE OVERRIDES (.savvy-search)
   ========================================================================== */
.savvy-search .tdb-search-btn {
    color: var(--savvy-blue-dark) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-search .tdb-search-btn:hover {
    color: var(--savvy-blue-medium) !important;
}

/* Popup Search Dropdown Card styling */
.savvy-search .tdb-search-form-wrap {
    border-top: 3px solid var(--savvy-blue-medium) !important;
    border-radius: 0 0 10px 10px !important;
    box-shadow: var(--savvy-shadow-lg) !important;
    border-right: 1px solid #E2E8F0 !important;
    border-bottom: 1px solid #E2E8F0 !important;
    border-left: 1px solid #E2E8F0 !important;
    padding: 16px !important;
}

.savvy-search input[type="text"] {
    border: 1px solid #E2E8F0 !important;
    border-radius: 6px !important;
    padding: 10px 14px !important;
    font-family: 'Inter', sans-serif !important;
}

.savvy-search input[type="text"]:focus {
    border-color: var(--savvy-blue-medium) !important;
}

/* ==========================================================================
   BREADCRUMBS STYLING (.savvy-breadcrumbs)
   ========================================================================== */
.savvy-breadcrumbs {
    font-size: 13px !important;
    color: var(--savvy-text-secondary) !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid #F1F5F9 !important;
    margin-bottom: 28px !important;
}

.savvy-breadcrumbs a {
    color: var(--savvy-text-secondary) !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: var(--savvy-transition) !important;
}

.savvy-breadcrumbs a:hover {
    color: var(--savvy-blue-medium) !important;
}

.savvy-breadcrumbs .tdb-bread-sep {
    margin: 0 8px !important;
    opacity: 0.6;
    font-size: 11px !important;
}

.savvy-breadcrumbs span:last-child {
    color: var(--savvy-text-light) !important;
    font-weight: 400 !important;
}

/* ==========================================================================
   DARK TRUST FOOTER OVERRIDES (.savvy-footer)
   ========================================================================== */
.savvy-footer {
    background-color: var(--savvy-blue-dark) !important;
    color: #94A3B8 !important; /* Slate 400 */
    padding: 80px 0 40px 0 !important;
    border-top: 4px solid var(--savvy-green-growth) !important;
    font-family: 'Inter', sans-serif !important;
}

/* Grid title wrappers inside footer */
.savvy-footer h4,
.savvy-footer .td-block-title,
.savvy-footer .tdb-block-title-wrap h4 {
    color: var(--savvy-white) !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    margin-bottom: 24px !important;
    letter-spacing: -0.01em !important;
    border-bottom: 2px solid rgba(255, 255, 255, 0.05) !important;
    padding-bottom: 10px !important;
}

/* Quick links inside footer columns */
.savvy-footer ul,
.savvy-footer li {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 0 !important;
}

.savvy-footer li {
    margin-bottom: 12px !important;
}

.savvy-footer a {
    color: #94A3B8 !important;
    transition: var(--savvy-transition) !important;
    text-decoration: none !important;
}

.savvy-footer a:hover {
    color: var(--savvy-white) !important;
    padding-left: 4px !important;
}

/* Trust signal copyright text & disclosures */
.savvy-footer-disclosures {
    border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    margin-top: 48px !important;
    padding-top: 24px !important;
    font-size: 0.8rem !important;
    line-height: 1.6 !important;
}

.savvy-footer-disclosures p {
    margin-bottom: 12px !important;
}

.savvy-footer-disclosures a {
    color: #CBD5E1 !important;
    text-decoration: underline !important;
}

.savvy-footer-disclosures a:hover {
    color: var(--savvy-white) !important;
}

/* Custom social icons block inside footer */
.savvy-footer-socials {
    display: flex !important;
    gap: 12px !important;
    margin-top: 16px !important;
}

.savvy-footer-socials a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: #94A3B8 !important;
    transition: var(--savvy-transition) !important;
}

.savvy-footer-socials a:hover {
    background: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
    transform: translateY(-2px) !important;
}

/* ==========================================================================
   MID-ARTICLE INLINE NEWSLETTER CARD (.savvy-inline-newsletter)
   ========================================================================== */
.savvy-inline-newsletter {
    background: linear-gradient(135deg, var(--savvy-blue-light) 0%, #E0F2FE 100%) !important;
    border: 2px solid var(--savvy-blue-medium) !important;
    border-radius: 12px !important;
    padding: 28px !important;
    margin: 36px 0 !important;
    box-shadow: var(--savvy-shadow-md) !important;
    text-align: center !important;
    position: relative;
    overflow: hidden;
}

/* Subtle corner decoration */
.savvy-inline-newsletter::after {
    content: '$' !important;
    position: absolute !important;
    right: -10px !important;
    bottom: -20px !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 8rem !important;
    font-weight: 800 !important;
    color: rgba(16, 185, 129, 0.05) !important;
    pointer-events: none !important;
    z-index: 0;
}

.savvy-inline-newsletter h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.4rem !important;
    color: var(--savvy-blue-dark) !important;
    font-weight: 800 !important;
    margin: 0 0 8px 0 !important;
    letter-spacing: -0.01em !important;
    position: relative;
    z-index: 1;
}

.savvy-inline-newsletter p {
    font-size: 1rem !important;
    color: var(--savvy-text-secondary) !important;
    margin: 0 0 20px 0 !important;
    line-height: 1.55 !important;
    position: relative;
    z-index: 1;
}

.savvy-inline-form {
    display: flex !important;
    gap: 12px !important;
    max-width: 500px;
    margin: 0 auto !important;
    position: relative;
    z-index: 1;
}

.savvy-inline-form input[type="email"] {
    flex: 1 !important;
    padding: 12px 16px !important;
    border: 1px solid #CBD5E1 !important;
    border-radius: 8px !important;
    font-size: 0.95rem !important;
    background: var(--savvy-white) !important;
    font-family: 'Inter', sans-serif !important;
}

.savvy-inline-form input[type="email"]:focus {
    border-color: var(--savvy-blue-medium) !important;
    outline: none !important;
}

.savvy-inline-form button,
.savvy-inline-form input[type="submit"] {
    background-color: var(--savvy-green-growth) !important;
    color: var(--savvy-white) !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 700 !important;
    border-radius: 8px !important;
    border: none !important;
    padding: 12px 24px !important;
    cursor: pointer !important;
    transition: var(--savvy-transition) !important;
}

.savvy-inline-form button:hover,
.savvy-inline-form input[type="submit"]:hover {
    background-color: var(--savvy-green-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2) !important;
}

@media (max-width: 576px) {
    .savvy-inline-newsletter {
        padding: 20px !important;
    }
    .savvy-inline-form {
        flex-direction: column !important;
        gap: 8px !important;
    }
    .savvy-inline-form button {
        width: 100% !important;
    }
}

/* ==========================================================================
   AFFILIATE PRODUCT/OFFER CARDS (.savvy-offer-card)
   ========================================================================== */
.savvy-offer-card {
    background: var(--savvy-white) !important;
    border: 2px solid #E2E8F0 !important;
    border-top: 4px solid var(--savvy-gold-accent) !important;
    border-radius: 12px !important;
    padding: 24px !important;
    margin: 36px 0 !important;
    box-shadow: var(--savvy-shadow-md) !important;
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
    font-family: 'Inter', sans-serif !important;
}

.savvy-offer-logo-wrap {
    width: 120px !important;
    min-width: 120px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.savvy-offer-logo-wrap img {
    max-width: 100% !important;
    height: auto !important;
    border-radius: 6px !important;
}

.savvy-offer-details {
    flex: 1 !important;
}

.savvy-offer-title {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: var(--savvy-blue-dark) !important;
    margin: 0 0 6px 0 !important;
    line-height: 1.3 !important;
}

.savvy-offer-rating {
    color: var(--savvy-gold-accent) !important;
    font-size: 0.95rem !important;
    margin-bottom: 12px !important;
    font-weight: 700 !important;
}

.savvy-offer-bullets {
    margin: 0 !important;
    padding-left: 18px !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    color: var(--savvy-text-secondary) !important;
}

.savvy-offer-bullets li {
    margin-bottom: 6px !important;
}

.savvy-offer-bullets li::marker {
    color: var(--savvy-green-growth) !important;
}

.savvy-offer-action {
    text-align: right !important;
}

.savvy-offer-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 14px 24px !important;
    background-color: var(--savvy-gold-accent) !important;
    color: var(--savvy-blue-dark) !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 800 !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.25) !important;
    transition: var(--savvy-transition) !important;
    border: none !important;
    font-size: 0.95rem !important;
    white-space: nowrap !important;
}

.savvy-offer-btn:hover {
    background-color: var(--savvy-gold-dark) !important;
    color: var(--savvy-white) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 18px rgba(217, 119, 6, 0.35) !important;
}

@media (max-width: 768px) {
    .savvy-offer-card {
        flex-direction: column !important;
        text-align: center !important;
        gap: 16px !important;
        padding: 20px !important;
    }
    .savvy-offer-logo-wrap {
        margin: 0 auto !important;
    }
    .savvy-offer-bullets {
        padding-left: 0 !important;
        list-style-position: inside !important;
    }
    .savvy-offer-action {
        width: 100% !important;
        text-align: center !important;
    }
    .savvy-offer-btn {
        width: 100% !important;
    }
}

/* ==========================================================================
   TRUST SIGNAL BADGES (.savvy-trust-badge-container)
   ========================================================================== */
.savvy-trust-badge-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    margin: 24px 0 !important;
}

.savvy-trust-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: var(--savvy-bg-base) !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 6px !important;
    padding: 6px 12px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    color: var(--savvy-text-primary) !important;
    font-family: 'Inter', sans-serif !important;
}

/* Dot indicator */
.savvy-trust-badge span::before {
    content: '' !important;
    display: inline-block !important;
    width: 6px !important;
    height: 6px !important;
    background-color: var(--savvy-green-growth) !important;
    border-radius: 50% !important;
    margin-right: 6px !important;
    vertical-align: middle !important;
}

/* ==========================================================================
   RELATED POSTS CAROUSEL OVERRIDES (.savvy-carousel-related)
   ========================================================================== */
.savvy-carousel-related .td-module-container {
    background: var(--savvy-white) !important;
    border: 1px solid #F1F5F9 !important;
    border-radius: 10px !important;
    padding: 10px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-carousel-related .td-module-container:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--savvy-shadow-md) !important;
    border-color: #E2E8F0 !important;
}

.savvy-carousel-related .td-image-container {
    border-radius: 6px !important;
    overflow: hidden !important;
}

.savvy-carousel-related .entry-title {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    margin-top: 8px !important;
}

/* ==========================================================================
   COMMENTS SECTION OVERRIDES (.savvy-comments)
   ========================================================================== */
.savvy-comments {
    margin-top: 48px !important;
}

.savvy-comments .comment-list .comment-body {
    background: var(--savvy-bg-base) !important;
    border: 1px solid #F1F5F9 !important;
    border-radius: 10px !important;
    padding: 20px !important;
    margin-bottom: 16px !important;
    box-shadow: var(--savvy-shadow-sm) !important;
    transition: var(--savvy-transition) !important;
}

.savvy-comments .comment-list .comment-body:hover {
    border-color: #E2E8F0 !important;
    box-shadow: var(--savvy-shadow-md) !important;
}

.savvy-comments .comment-author .avatar {
    border-radius: 50% !important;
    border: 2px solid var(--savvy-blue-light) !important;
}

/* Custom Reply Button outline */
.savvy-comments .reply a {
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    color: var(--savvy-blue-medium) !important;
    text-transform: uppercase !important;
    border: 1px solid var(--savvy-blue-medium) !important;
    padding: 4px 12px !important;
    border-radius: 6px !important;
    transition: var(--savvy-transition) !important;
    text-decoration: none !important;
    display: inline-block !important;
}

.savvy-comments .reply a:hover {
    background: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
}

/* Form Styles */
.savvy-comments .comment-respond input[type="text"],
.savvy-comments .comment-respond textarea {
    border: 1px solid #E2E8F0 !important;
    border-radius: 6px !important;
    padding: 12px !important;
    font-family: 'Inter', sans-serif !important;
    width: 100% !important;
    background: var(--savvy-white) !important;
}

.savvy-comments .comment-respond input[type="text"]:focus,
.savvy-comments .comment-respond textarea:focus {
    border-color: var(--savvy-blue-medium) !important;
    outline: none !important;
}

.savvy-comments .comment-respond input[type="submit"] {
    background-color: var(--savvy-blue-medium) !important;
    color: var(--savvy-white) !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 700 !important;
    border-radius: 6px !important;
    padding: 12px 24px !important;
    border: none !important;
    cursor: pointer !important;
    transition: var(--savvy-transition) !important;
}

.savvy-comments .comment-respond input[type="submit"]:hover {
    background-color: var(--savvy-blue-dark) !important;
}
