/**
 * Correzioni di stile per CheQuadroBlog
 */

/* Usa il colore principale del tema dai customizer per tutti gli elementi rilevanti */
.main-navigation a:hover, 
.site-header.article-header .main-navigation a:hover,
.article-card:hover .article-title a,
.footer-links a:hover,
.read-more:hover,
.article-header .main-navigation a:hover,
.newsletter-signup .gdpr-consent a:hover,
.footer-nav a:hover, 
.gdpr-consent a:hover, 
.footer-gdpr a:hover,
a:hover:not(.btn-primary):not(.btn-secondary):not(.category a),
a:focus:not(.btn-primary):not(.btn-secondary):not(.category a),
a:active:not(.btn-primary):not(.btn-secondary):not(.category a) {
    color: var(--primary-color) !important;
}

/* Header styles uniformi */
.site-header.article-header {
    background-color: #fff !important;
    border-bottom: 1px solid #e9ecef !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05) !important;
    padding: 1.5rem 0 !important;
    position: relative !important;
    z-index: 100 !important;
}

/* Rendere coerente l'allineamento e il font del titolo del sito */
.site-header.article-header .site-branding {
    display: flex !important;
    flex-direction: column !important;
    text-align: left !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
}

.site-header.article-header .site-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.8rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    margin: 0 !important;
}

.site-header.article-header .site-title a {
    color: #283845 !important;
}

.site-header.article-header .site-tagline {
    color: #6c757d !important;
    margin: 5px 0 0 !important;
    font-size: 0.9rem !important;
    font-family: 'Poppins', sans-serif !important;
}

.site-header.article-header .main-navigation a {
    color: #283845 !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    font-family: 'Poppins', sans-serif !important;
}

/* Impedisci che .article-header definito per altre parti del sito influenzi il masthead */
header#masthead + .container .article-header,
.single-article .article-header {
    border: none !important;
    margin-bottom: 2rem !important;
    text-align: center !important;
}

/* Allineare il menu nell'header a destra e in linea con il titolo/logo */
.site-header .container {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.site-header .main-navigation {
    margin-left: auto !important;
}

/* Rimuovere il padding dai section nei widget del footer */
.footer-widget section {
    padding: 0 !important;
    margin-bottom: 1.5rem !important;
}

/* Newsletter nel footer - correzione di stile */
.footer-newsletter {
    display: flex !important;
    margin-top: 1rem !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    justify-content: space-evenly !important;
    align-items: stretch !important;
    width: 100% !important;
}

.footer-newsletter .newsletter-form-group {
    display: flex !important;
    width: 100% !important;
    margin-bottom: 0.5rem !important;
}

.footer-newsletter input {
    flex: 1 !important;
    min-width: 0 !important;
    padding: 0.5rem 1rem !important;
    border: 1px solid #ddd !important;
    border-radius: 3px !important;
}

.footer-newsletter button {
    background-color: var(--primary-color) !important;
    color: #fff !important;
    border: none !important;
    padding: 0.5rem 1rem !important;
    margin-left: 0.5rem !important;
    border-radius: 3px !important;
    cursor: pointer !important;
    transition: background-color 0.3s !important;
}

.footer-gdpr {
    margin-top: 1rem !important;
    display: block !important;
    width: 100% !important;
}

/* Card degli articoli clickabili */
.article-card {
    cursor: pointer !important;
    position: relative !important;
    z-index: 1 !important;
    background-color: #f9f9f9 !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 0 3px 8px rgba(0,0,0,0.03) !important;
    border: 1px solid #f0f0f0 !important;
}

.article-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 15px rgba(0,0,0,0.08) !important;
}

/* Rendere tutti gli elementi clickabili all'interno della card accessibili */
.article-card a,
.article-card .btn,
.article-card .category a {
    position: relative !important;
    z-index: 2 !important;
}

/* Stile corretto per categorie */
.article-meta {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 1rem 1.5rem 0.5rem !important;
    font-size: 0.85rem !important;
}

.article-meta .category {
    position: relative !important;
    z-index: 2 !important;
}

.article-meta .category a {
    position: relative !important;
    z-index: 2 !important;
    background-color: var(--primary-color) !important;
    color: white !important;
    padding: 4px 10px !important;
    border-radius: 3px !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    text-decoration: none !important;
    display: inline-block !important;
    margin-right: 5px !important;
    margin-bottom: 5px !important;
}

/* Impedisce che il testo della categoria diventi illeggibile in hover */
.article-meta .category a:hover {
    color: white !important;
    background-color: var(--primary-color) !important;
    opacity: 0.9 !important;
}

.article-meta .date {
    color: #6c757d !important;
}

.article-title {
    padding: 0.5rem 1.5rem !important;
    margin: 0 !important;
    font-family: 'Playfair Display', serif !important;
    font-size: 1.3rem !important;
    line-height: 1.4 !important;
}

.article-title a {
    position: relative !important;
    z-index: 2 !important;
    color: #283845 !important;
    text-decoration: none !important;
    background: none !important; /* Rimuove lo sfondo dal titolo */
}

.article-thumbnail {
    position: relative !important;
    z-index: 1 !important;
}

.article-thumbnail a {
    position: relative !important;
    z-index: 3 !important; /* Aumentato per essere sopra full-link */
    display: block !important;
    overflow: hidden !important;
    cursor: pointer !important; /* Aggiunto per indicare che è cliccabile */
}

.article-thumbnail img {
    width: 100% !important;
    height: auto !important;
    transition: transform 0.5s ease !important;
    display: block !important;
}

.article-card:hover .article-thumbnail img {
    transform: scale(1.05) !important;
}

.article-excerpt {
    padding: 0 1.5rem !important;
    margin-bottom: 1rem !important;
    color: #6c757d !important;
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    flex-grow: 1 !important;
}

/* Pulsante shop negli articoli */
.shop-cta {
    margin: 3rem 0 !important;
    text-align: center !important;
    clear: both !important;
}

.shop-button {
    display: inline-block !important;
    padding: 1rem 2.5rem !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    transition: all 0.3s ease !important;
}

/* Bottone Leggi tutto negli articoli recenti */
.article-read-more {
    margin-top: auto !important; /* Spinge il bottone al fondo della card */
    margin-bottom: 1.5rem !important;
    padding: 0 1.5rem !important;
    text-align: right !important;
}

.btn-sm {
    padding: 0.4rem 1rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    border-radius: 0.2rem !important;
}

.article-read-more .btn {
    position: relative !important;
    z-index: 2 !important;
}

/* Correzione colore link footer */
.footer-nav a, 
.gdpr-consent a, 
.footer-gdpr a {
    color: #ffffff !important;
    text-decoration: underline !important;
}

.footer-nav a:hover, 
.gdpr-consent a:hover, 
.footer-gdpr a:hover {
    color: var(--primary-color) !important;
}

/* Stile per le pagine di archivio e categorie */
.archive-page {
    padding: 3rem 0 !important;
}

.archive-page .section-header {
    margin-bottom: 2rem !important;
    text-align: center !important;
}

.archive-page .page-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 2.5rem !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
    color: #283845 !important;
    background: none !important; /* Rimuove lo sfondo dal titolo */
}

.archive-page .archive-description {
    font-family: 'Poppins', sans-serif !important;
    font-size: 1.1rem !important;
    color: #6c757d !important;
    max-width: 800px !important;
    margin: 0 auto !important;
}

.archive-page .articles-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
    gap: 2rem !important;
    margin-bottom: 3rem !important;
}

.archive-page .pagination-container {
    text-align: center !important;
    margin: 2rem 0 !important;
}

.archive-page .pagination {
    display: inline-flex !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0.25rem !important;
}

.archive-page .pagination .page-numbers {
    display: inline-block !important;
    padding: 0.5rem 1rem !important;
    margin: 0 0.25rem !important;
    border: 1px solid #dee2e6 !important;
    color: var(--primary-color) !important;
    text-decoration: none !important;
    border-radius: 0.25rem !important;
    transition: all 0.3s ease !important;
}

.archive-page .pagination .page-numbers:hover {
    background-color: #f5f5f5 !important;
}

.archive-page .pagination .current {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #fff !important;
}

.archive-page .no-results {
    text-align: center !important;
    padding: 3rem 0 !important;
}

/* Colore principale del tema per tutti gli elementi rilevanti */
.article-category span {
    display: inline-block !important;
    padding: 4px 10px !important;
    background-color: var(--primary-color) !important;
    color: white !important;
    font-size: 0.8rem !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    border-radius: 4px !important;
}

/* Titolo articolo singolo più grande */
.single-article .article-title {
    font-size: 2.8rem !important;
    line-height: 1.2 !important;
    margin-bottom: 1rem !important;
    font-weight: 700 !important;
    font-family: 'Playfair Display', serif !important;
}

/* Aggiunge scorrimento fluido per le ancore */
html {
    scroll-behavior: smooth !important;
}

/* Offset verticale per le ancore per compensare l'header fisso */
:target {
    scroll-margin-top: 80px !important;
}

/* Aggiunta di stili per sottolineare i link nei paragrafi degli articoli */
.article-content p a {
    text-decoration: underline !important;
}

/* Centrare le immagini wp-block-image aligncenter size-large is-resized */
.article-content .wp-block-image.aligncenter.size-large.is-resized {
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

.article-content .wp-block-image.aligncenter.size-large.is-resized img {
    margin: 0 auto !important;
    display: block !important;
}

/* Aggiunta di overlay scuro alla featured image */
.article-featured-image {
    position: relative !important;
}

.article-featured-image::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, 0.3) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* Assicurarsi che il testo della categoria appaia sopra l'overlay */
.article-featured-image .article-category {
    position: relative !important;
    z-index: 2 !important;
}

/* Centrare la didascalia (figcaption) delle immagini */
.wp-block-image figcaption.wp-element-caption {
    text-align: center !important;
    margin-top: 10px !important;
    width: 100% !important;
    display: block !important;
} 

