/*
Theme Name: Astra PBLE Child
Theme URI: https://plus-belle-l-enfance.fr
Description: Child theme Astra pour Plus belle l'enfance. Design chaleureux et éditorial pour le réseau PBN.
Author: Geoffrey
Version: 1.1.0
Template: astra
Text Domain: astra-pble-child
*/

/* ─────────────────────────────────────────────────────────────
   Design tokens
   ───────────────────────────────────────────────────────────── */
:root {
    --pble-primary: #E76F51;
    --pble-primary-dark: #C95A3F;
    --pble-secondary: #2A9D8F;
    --pble-accent: #F4A261;
    --pble-text: #264653;
    --pble-text-soft: #587480;
    --pble-bg: #FFFCF8;
    --pble-bg-soft: #F8F1E8;
    --pble-border: #E8DECF;
    --pble-card-shadow: 0 4px 16px rgba(38, 70, 83, 0.06);
    --pble-card-shadow-hover: 0 12px 32px rgba(38, 70, 83, 0.14);
    --pble-radius: 16px;
    --pble-radius-small: 8px;
    --pble-font-heading: 'Playfair Display', Georgia, serif;
    --pble-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ─────────────────────────────────────────────────────────────
   FIX ASTRA WRAPPER : casser TOUT ce qui pourrait contraindre
   notre layout full-width sur home + archive.
   Astra met du box-shadow + padding via ast-separate-container,
   on neutralise tout ça.
   ───────────────────────────────────────────────────────────── */
body.home,
body.archive {
    background: var(--pble-bg) !important;
}

.home #content,
.archive #content {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    max-width: 100% !important;
    width: 100% !important;
}

.home #content > .ast-container,
.archive #content > .ast-container,
.home .site-content > .ast-container,
.archive .site-content > .ast-container {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    max-width: 100% !important;
    width: 100% !important;
    display: block;
}

.home #primary,
.archive #primary,
.home .site-main,
.archive .site-main {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* Astra ajoute parfois un wrapper supplémentaire */
.home .ast-row,
.archive .ast-row,
.home [class^="ast-grid-common"],
.archive [class^="ast-grid-common"] {
    margin: 0 !important;
    padding: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Sur les pages internes, garder la largeur Astra normale */
.single .ast-container,
.page .ast-container {
    background: var(--pble-bg);
}

/* ─────────────────────────────────────────────────────────────
   Base
   ───────────────────────────────────────────────────────────── */
body {
    background: var(--pble-bg) !important;
    color: var(--pble-text) !important;
    font-family: var(--pble-font-body) !important;
    font-size: 16px;
    line-height: 1.7;
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.widget-title {
    font-family: var(--pble-font-heading) !important;
    color: var(--pble-text) !important;
    letter-spacing: -0.01em;
    font-weight: 600;
}

a {
    color: var(--pble-primary);
    transition: color 0.2s;
}

a:hover {
    color: var(--pble-primary-dark);
}

/* ─────────────────────────────────────────────────────────────
   Header
   ───────────────────────────────────────────────────────────── */
.site-header {
    background: var(--pble-bg) !important;
    border-bottom: 1px solid var(--pble-border);
}

.main-header-bar {
    padding: 14px 0;
}

.site-title {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0;
}

.site-title a,
.site-title a:hover {
    font-family: var(--pble-font-heading) !important;
    color: var(--pble-text) !important;
    font-weight: 700;
    font-size: 26px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
}

/* Logo monogramme corail avec coeur blanc */
.site-title a::before {
    content: "";
    display: inline-block;
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 42 42' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' stop-color='%23E76F51'/%3E%3Cstop offset='100%25' stop-color='%23F4A261'/%3E%3C/linearGradient%3E%3C/defs%3E%3Ccircle cx='21' cy='21' r='21' fill='url(%23g)'/%3E%3Cpath d='M21 32 l-1.4-1.2 c-5-4.4-8.1-7.1-8.1-10.5 0-2.8 2.2-5 5-5 1.6 0 3.1 0.7 4.1 1.9 1-1.2 2.5-1.9 4.1-1.9 2.8 0 5 2.2 5 5 0 3.4-3.1 6.1-8.1 10.5L21 32z' fill='white'/%3E%3Cpath d='M14 11 l1 2 2 1-2 1-1 2-1-2-2-1 2-1 1-2z' fill='white' opacity='0.7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    box-shadow: 0 4px 12px rgba(231, 111, 81, 0.3);
    border-radius: 50%;
    transition: transform 0.3s;
}

.site-title a:hover::before {
    transform: rotate(-8deg) scale(1.05);
}

/* Sur mobile, logo + texte qui restent alignés */
@media (max-width: 480px) {
    .site-title a {
        font-size: 22px;
    }
    .site-title a::before {
        width: 36px;
        height: 36px;
    }
}

.site-description {
    font-family: var(--pble-font-body) !important;
    color: var(--pble-text-soft) !important;
    font-size: 13px;
    font-style: italic;
}

.main-navigation .main-nav-ul > li > a {
    font-family: var(--pble-font-body) !important;
    font-weight: 500;
    font-size: 15px;
    color: var(--pble-text) !important;
    padding: 10px 16px;
}

.main-navigation .main-nav-ul > li > a:hover,
.main-navigation .main-nav-ul > li.current-menu-item > a {
    color: var(--pble-primary) !important;
}

/* CTA Contact dans le menu */
.main-navigation .main-nav-ul > li.pble-menu-cta {
    margin-left: 16px;
}

.main-navigation .main-nav-ul > li.pble-menu-cta > a {
    background: var(--pble-primary) !important;
    color: #fff !important;
    padding: 10px 22px !important;
    border-radius: 100px !important;
    font-weight: 600 !important;
    transition: background 0.2s, transform 0.2s, box-shadow 0.2s !important;
    box-shadow: 0 4px 12px rgba(231, 111, 81, 0.25) !important;
}

.main-navigation .main-nav-ul > li.pble-menu-cta > a:hover {
    background: var(--pble-primary-dark) !important;
    color: #fff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 16px rgba(231, 111, 81, 0.4) !important;
}

/* ─────────────────────────────────────────────────────────────
   Hero homepage avec image de fond
   ───────────────────────────────────────────────────────────── */
.pble-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 140px 20px 160px;
    text-align: center;
    color: #fff;
    overflow: hidden;
}

.pble-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(38, 70, 83, 0.62) 0%,
        rgba(231, 111, 81, 0.50) 100%
    );
}

.pble-hero > * {
    position: relative;
    z-index: 1;
}

.pble-hero .eyebrow {
    display: inline-block;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 6px 16px;
    border-radius: 100px;
    margin-bottom: 24px;
    backdrop-filter: blur(8px);
}

.pble-hero h1 {
    color: #fff !important;
    font-size: clamp(36px, 5.2vw, 60px);
    line-height: 1.1;
    margin: 0 auto 20px;
    max-width: 900px;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.18);
}

.pble-hero h1 em {
    color: var(--pble-accent);
    font-style: italic;
}

.pble-hero p {
    font-size: clamp(16px, 1.4vw, 19px);
    color: rgba(255, 255, 255, 0.92);
    max-width: 680px;
    margin: 0 auto 36px;
    line-height: 1.6;
}

/* ─────────────────────────────────────────────────────────────
   Section commune
   ───────────────────────────────────────────────────────────── */
.pble-section {
    padding: 80px 20px;
    max-width: 1200px;
    margin: 0 auto;
}

.pble-section-alt {
    background: var(--pble-bg-soft);
    max-width: none;
}

.pble-section-alt .pble-section-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.pble-section-header {
    text-align: center;
    margin-bottom: 48px;
}

.pble-section-header h2 {
    font-size: clamp(28px, 3.5vw, 40px);
    margin: 0 0 12px;
}

.pble-section-header p {
    color: var(--pble-text-soft);
    font-size: 17px;
    margin: 0;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* ─────────────────────────────────────────────────────────────
   Cards catégories (avec image)
   ───────────────────────────────────────────────────────────── */
.pble-cats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
}

.pble-cat-card {
    position: relative;
    border-radius: var(--pble-radius);
    overflow: hidden;
    text-decoration: none !important;
    color: #fff;
    aspect-ratio: 4 / 5;
    background-size: cover;
    background-position: center;
    transition: transform 0.3s, box-shadow 0.3s;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
    box-shadow: var(--pble-card-shadow);
}

.pble-cat-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(38, 70, 83, 0.1) 30%,
        rgba(38, 70, 83, 0.78) 100%
    );
    transition: background 0.3s;
}

.pble-cat-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--pble-card-shadow-hover);
}

.pble-cat-card:hover::before {
    background: linear-gradient(
        180deg,
        rgba(231, 111, 81, 0.15) 30%,
        rgba(231, 111, 81, 0.82) 100%
    );
}

.pble-cat-card > * {
    position: relative;
    z-index: 1;
}

.pble-cat-card .name {
    font-family: var(--pble-font-heading);
    font-size: 26px;
    font-weight: 600;
    color: #fff;
    margin: 0 0 4px;
    line-height: 1.1;
}

.pble-cat-card .count {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.85);
}

/* ─────────────────────────────────────────────────────────────
   Cards articles (avec image)
   ───────────────────────────────────────────────────────────── */
.pble-articles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 32px;
}

.pble-article-card {
    background: #fff;
    border: 1px solid var(--pble-border);
    border-radius: var(--pble-radius);
    overflow: hidden;
    transition: transform 0.25s, box-shadow 0.25s;
    display: flex;
    flex-direction: column;
}

.pble-article-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--pble-card-shadow-hover);
}

.pble-article-card .thumb {
    aspect-ratio: 16 / 10;
    background-size: cover;
    background-position: center;
    display: block;
    text-decoration: none;
    transition: transform 0.5s;
}

.pble-article-card:hover .thumb {
    transform: scale(1.04);
}

.pble-article-card .body {
    padding: 24px 26px 26px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
}

.pble-article-card .cat-tag {
    align-self: flex-start;
    background: rgba(231, 111, 81, 0.12);
    color: var(--pble-primary);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 5px 12px;
    border-radius: 100px;
    text-decoration: none;
}

.pble-article-card h3 {
    font-size: 20px;
    line-height: 1.3;
    margin: 0;
}

.pble-article-card h3 a {
    color: var(--pble-text) !important;
    text-decoration: none;
}

.pble-article-card h3 a:hover {
    color: var(--pble-primary) !important;
}

.pble-article-card .excerpt {
    color: var(--pble-text-soft);
    font-size: 14.5px;
    line-height: 1.6;
    margin: 0;
    flex: 1;
}

.pble-article-card .read-more {
    color: var(--pble-primary);
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    margin-top: 4px;
}

.pble-article-card .read-more:after {
    content: " →";
    transition: margin-left 0.2s;
}

.pble-article-card:hover .read-more:after {
    margin-left: 4px;
}

/* ─────────────────────────────────────────────────────────────
   Article single
   ───────────────────────────────────────────────────────────── */
.single .ast-container,
.single-post .ast-container {
    max-width: 800px;
}

.single .entry-header {
    text-align: center;
    margin-bottom: 32px;
}

.single .entry-title {
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.15;
    margin-bottom: 16px;
}

.single .entry-meta {
    color: var(--pble-text-soft);
    font-size: 14px;
}

.single .ast-post-thumbnail {
    border-radius: var(--pble-radius);
    overflow: hidden;
    margin-bottom: 40px;
}

.single .entry-content {
    font-size: 17px;
    line-height: 1.8;
    color: var(--pble-text);
}

.single .entry-content h2,
.single .entry-content h3 {
    margin-top: 1.6em;
    margin-bottom: 0.6em;
}

.single .entry-content h2 {
    font-size: 28px;
}

.single .entry-content h3 {
    font-size: 22px;
}

.single .entry-content p {
    margin-bottom: 1.3em;
}

.single .entry-content a {
    color: var(--pble-primary);
    border-bottom: 1px solid rgba(231, 111, 81, 0.3);
    text-decoration: none;
    transition: border-color 0.2s;
}

.single .entry-content a:hover {
    border-bottom-color: var(--pble-primary);
}

/* ─────────────────────────────────────────────────────────────
   Archive (catégorie)
   ───────────────────────────────────────────────────────────── */
.pble-cat-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    padding: 100px 20px 110px;
    text-align: center;
    color: #fff;
    margin-bottom: 0;
}

.pble-cat-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(38, 70, 83, 0.72) 0%,
        rgba(231, 111, 81, 0.55) 100%
    );
}

.pble-cat-hero > * {
    position: relative;
    z-index: 1;
}

.pble-cat-hero h1 {
    color: #fff !important;
    font-size: clamp(32px, 4.5vw, 52px);
    margin: 0 0 12px;
    text-shadow: 0 2px 18px rgba(0,0,0,0.18);
}

.pble-cat-hero .desc {
    color: rgba(255, 255, 255, 0.92);
    font-size: 17px;
    max-width: 680px;
    margin: 0 auto;
    line-height: 1.6;
}

.pble-cat-hero .count-chip {
    display: inline-block;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    padding: 5px 14px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 18px;
    backdrop-filter: blur(8px);
}

/* ─────────────────────────────────────────────────────────────
   Page institutionnelle (mon-parcours, contact, etc.)
   ───────────────────────────────────────────────────────────── */
.page .ast-container,
.page-template-default .ast-container {
    max-width: 760px;
}

.page .entry-header {
    text-align: center;
    margin: 40px 0 32px;
}

.page .entry-title {
    font-size: clamp(28px, 4vw, 44px);
    margin: 0;
}

.page .entry-content {
    font-size: 17px;
    line-height: 1.8;
    color: var(--pble-text);
}

.page .entry-content h2 {
    font-size: 26px;
    margin-top: 1.6em;
    margin-bottom: 0.6em;
}

.page .entry-content a {
    color: var(--pble-primary);
}

/* Contact email mis en avant */
.pble-contact-block {
    text-align: center;
    background: var(--pble-bg-soft);
    border-radius: var(--pble-radius);
    padding: 40px 28px;
    margin: 32px 0;
}

.pble-contact-block .label {
    color: var(--pble-text-soft);
    font-size: 14px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 10px;
}

.pble-contact-block a {
    display: inline-block;
    color: var(--pble-primary);
    font-family: var(--pble-font-heading);
    font-size: 28px;
    font-weight: 600;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: border-color 0.2s;
}

.pble-contact-block a:hover {
    border-bottom-color: var(--pble-primary);
}

/* ─────────────────────────────────────────────────────────────
   Section Réassurance ("Pourquoi nous suivre")
   ───────────────────────────────────────────────────────────── */
.pble-trust {
    background: var(--pble-bg);
    padding: 80px 20px;
    border-top: 1px solid var(--pble-border);
    border-bottom: 1px solid var(--pble-border);
}

.pble-trust-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.pble-trust-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 32px;
}

.pble-trust-card {
    text-align: center;
    padding: 8px;
}

.pble-trust-card .icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(231, 111, 81, 0.12);
    color: var(--pble-primary);
    font-size: 28px;
    margin-bottom: 16px;
}

.pble-trust-card h3 {
    font-size: 19px;
    margin: 0 0 8px;
}

.pble-trust-card p {
    color: var(--pble-text-soft);
    font-size: 14.5px;
    line-height: 1.6;
    margin: 0;
}

/* Stats bar */
.pble-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 24px;
    padding: 32px 0 0;
    margin-top: 48px;
    border-top: 1px solid var(--pble-border);
}

.pble-stat {
    text-align: center;
}

.pble-stat .num {
    font-family: var(--pble-font-heading);
    font-size: 36px;
    font-weight: 600;
    color: var(--pble-primary);
    line-height: 1;
    margin-bottom: 6px;
}

.pble-stat .label {
    font-size: 13px;
    color: var(--pble-text-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

/* ─────────────────────────────────────────────────────────────
   Newsletter CTA (avant footer)
   ───────────────────────────────────────────────────────────── */
.pble-newsletter {
    background: linear-gradient(135deg, var(--pble-primary) 0%, var(--pble-accent) 100%);
    padding: 64px 20px;
    text-align: center;
    color: #fff;
}

.pble-newsletter h2 {
    color: #fff !important;
    font-size: clamp(26px, 3vw, 36px);
    margin: 0 0 12px;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.pble-newsletter p {
    color: rgba(255,255,255,0.92);
    font-size: 16px;
    max-width: 560px;
    margin: 0 auto 32px;
}

.pble-newsletter-form {
    max-width: 460px;
    margin: 0 auto;
    display: flex;
    gap: 8px;
}

.pble-newsletter-form input[type="email"] {
    flex: 1;
    padding: 14px 20px;
    border-radius: 100px;
    border: none;
    font-size: 15px;
    font-family: var(--pble-font-body);
    color: var(--pble-text);
}

.pble-newsletter-form button {
    background: var(--pble-text);
    color: #fff;
    border: none;
    padding: 14px 28px;
    border-radius: 100px;
    font-family: var(--pble-font-body);
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    transition: background 0.2s;
}

.pble-newsletter-form button:hover {
    background: #1a313c;
}

/* ─────────────────────────────────────────────────────────────
   Footer custom
   ───────────────────────────────────────────────────────────── */
.pble-footer {
    background: var(--pble-text);
    color: rgba(255,255,255,0.85);
    padding: 64px 20px 24px;
    font-family: var(--pble-font-body);
}

.pble-footer-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.pble-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.4fr;
    gap: 48px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

@media (max-width: 920px) {
    .pble-footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 36px;
    }
}

@media (max-width: 540px) {
    .pble-footer-grid {
        grid-template-columns: 1fr;
    }
}

.pble-footer-col h4 {
    color: #fff !important;
    font-family: var(--pble-font-heading) !important;
    font-size: 18px;
    margin: 0 0 18px;
}

.pble-footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pble-footer-col ul li {
    padding: 5px 0;
}

.pble-footer-col a {
    color: rgba(255,255,255,0.82);
    text-decoration: none;
    font-size: 14.5px;
    transition: color 0.2s;
}

.pble-footer-col a:hover {
    color: var(--pble-accent);
}

.pble-footer-brand .pble-footer-logo {
    display: inline-block;
    font-family: var(--pble-font-heading);
    font-size: 26px;
    font-weight: 700;
    color: #fff;
    text-decoration: none;
    margin-bottom: 14px;
}

.pble-footer-tagline {
    color: rgba(255,255,255,0.75);
    font-size: 14px;
    line-height: 1.6;
    margin: 0 0 24px;
    max-width: 340px;
}

.pble-social {
    display: flex;
    gap: 12px;
    align-items: center;
}

.pble-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    color: #fff !important;
    transition: background 0.2s, transform 0.2s;
}

.pble-social a:hover {
    background: var(--pble-primary);
    transform: translateY(-2px);
}

.pble-footer-bottom {
    padding-top: 24px;
    text-align: center;
    color: rgba(255,255,255,0.6);
    font-size: 13px;
}

.pble-footer-bottom p {
    margin: 4px 0;
}

.pble-footer-credits {
    font-style: italic;
    opacity: 0.7;
}

/* ─────────────────────────────────────────────────────────────
   Boutons
   ───────────────────────────────────────────────────────────── */
.pble-btn {
    display: inline-block;
    background: var(--pble-primary);
    color: #fff !important;
    padding: 15px 32px;
    border-radius: 100px;
    font-family: var(--pble-font-body);
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
    transition: background 0.2s, transform 0.2s;
    box-shadow: 0 4px 14px rgba(231, 111, 81, 0.3);
}

.pble-btn:hover {
    background: var(--pble-primary-dark);
    color: #fff !important;
    transform: translateY(-2px);
}

.pble-btn-light {
    background: #fff;
    color: var(--pble-primary) !important;
}

.pble-btn-light:hover {
    background: rgba(255, 255, 255, 0.92);
    color: var(--pble-primary) !important;
}

.pble-btn-secondary {
    background: transparent;
    color: var(--pble-primary) !important;
    border: 2px solid var(--pble-primary);
    box-shadow: none;
}

.pble-btn-secondary:hover {
    background: var(--pble-primary);
    color: #fff !important;
}

/* ─────────────────────────────────────────────────────────────
   Responsive
   ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .pble-hero {
        padding: 80px 20px 100px;
    }
    .pble-cat-hero {
        padding: 64px 20px 72px;
    }
    .pble-section {
        padding: 56px 16px;
    }
}
