
        /* ... (Styles CSS existants - inchangés) ... */
        :root {
            --site-bg-color: #ffffff;
            --site-primary-color: #007aff;
            --site-primary-contrast: #ffffff;
            --site-accent-color: #005ecb;
            --site-primary-rgb: 0, 122, 255;
            --site-text-color: #111111;
            --site-muted-color: #555555;
            --site-surface-color: #f9f9f9;
            --site-border-color: #eeeeee;
        }
        body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; margin: 0; line-height: 1.7; background: var(--site-bg-color, #fff); color: var(--site-text-color, #111); }
        .container { max-width: 900px; margin: 0 auto; padding: 20px; }
        a { color: var(--site-primary-color, #007aff); text-decoration: none; } 
        a:hover { text-decoration: underline; color: var(--site-accent-color, #005ecb); }
        h1 { font-size: 2.5rem; margin-bottom: 0.5rem; line-height: 1.2; } 
        h2 { font-size: 1.8rem; } h3 { font-size: 1.5rem; }
        img { max-width: 100%; height: auto; }
        figure { margin: 0; } figcaption { font-size: 0.9em; color: var(--site-muted-color, #555); text-align: center; margin-top: 5px; }
        .card-content.card-type-image figure {
            width: min(100%, var(--card-image-width, 100%));
            margin: 20px auto;
        }
        .card-content.card-type-image figure.align-left {
            margin-left: 0;
            margin-right: auto;
        }
        .card-content.card-type-image figure.align-right {
            margin-right: 0;
            margin-left: auto;
        }
        .card-content.card-type-image figure picture,
        .card-content.card-type-image figure img {
            width: 100%;
            display: block;
        }
        .btn, button.btn { background: var(--site-primary-color, #007aff); color: var(--site-primary-contrast, #fff); padding: 10px 16px; border: none; border-radius: 6px; cursor: pointer; text-decoration: none; display: inline-block; font-size: 1em; transition: background .2s ease, box-shadow .2s ease; }
        .btn:hover, button.btn:hover { background: var(--site-accent-color, #005ecb); }
        .btn-card { margin-top: 10px; display:inline-flex; align-items:center; gap:8px; }
        .btn-card .btn-icon { font-size:1.1em; display:inline-flex; align-items:center; }
        .btn-card .btn-text { display:inline-flex; align-items:center; }
        .sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
        hr.card-hr { border: 0; border-top: 1px solid var(--site-border-color, #eee); margin: 30px 0; }

        header { border-bottom: 1px solid var(--site-border-color, #eee); padding: 20px; background: var(--site-bg-color, #fff); }
        header .container { display: flex; justify-content: space-between; align-items: center; padding: 0; flex-wrap: wrap; }
        .logo { font-size: 1.5rem; font-weight: 600; text-decoration: none; color: var(--site-text-color, #111); }
        .logo img { max-height: 50px; display: block; }
        header nav { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
        header nav a { text-decoration: none; color: var(--site-text-color, #333); font-weight: 500; }
        header nav a:hover { color: var(--site-accent-color, #005ecb); }
        .admin-link { color: var(--site-muted-color, #888); font-size: 0.9em; }

        .announcement-bar {
            width: 100%;
            padding: 16px 18px 0;
            box-sizing: border-box;
            display: flex;
            justify-content: center;
            transition: opacity .2s ease, transform .2s ease;
        }
        .announcement-bar.is-hidden {
            opacity: 0;
            transform: translateY(-12px);
            pointer-events: none;
        }
        .announcement-inner {
            position: relative;
            width: min(1200px, 100%);
            margin: 0 auto;
            background: linear-gradient(120deg, var(--site-primary-color, #007aff), var(--site-accent-color, #005ecb));
            color: var(--site-primary-contrast, #fff);
            border-radius: 18px;
            padding: 18px 56px 18px 24px;
            box-shadow: 0 15px 35px rgba(0, 34, 77, 0.25);
            font-size: 1.02rem;
            font-weight: 500;
            display: flex;
            align-items: center;
            line-height: 1.5;
        }
        .announcement-text {
            flex: 1;
        }
        .announcement-dismiss {
            position: absolute;
            top: 50%;
            right: 12px;
            transform: translateY(-50%);
            width: 32px;
            height: 32px;
            border-radius: 50%;
            border: none;
            background: rgba(var(--site-primary-rgb, 0,122,255), 0.2);
            color: var(--site-primary-contrast, #fff);
            cursor: pointer;
            font-size: 20px;
            font-family: inherit;
            line-height: 0;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            transition: background .2s ease, transform .2s ease;
        }
        .announcement-dismiss:hover {
            background: rgba(var(--site-primary-rgb, 0,122,255), 0.3);
            transform: translateY(-50%) scale(1.05);
        }
        @media (max-width: 640px) {
            .announcement-inner {
                padding-right: 48px;
                font-size: .95rem;
            }
            .announcement-dismiss {
                right: 10px;
                width: 28px;
                height: 28px;
            }
        }

        .card-content { margin-bottom: 25px; }
        .card-content p, .card-content li, .card-content blockquote { font-size: 1.1rem; margin: 0; }
        .video-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; background: #000; margin-bottom: 20px; border-radius: 8px; }
        .video-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

        .contact-form, .newsletter-form { background: var(--site-surface-color, #f9f9f9); border: 1px solid var(--site-border-color, #eee); padding: 20px; border-radius: 8px; }
        .contact-form label, .newsletter-form label { font-weight: 600; display: block; margin-bottom: 5px; }
        .contact-form input, .contact-form textarea, .newsletter-form input { width: 100%; padding: 10px; box-sizing: border-box; border: 1px solid var(--site-border-color, #ccc); border-radius: 4px; margin-bottom: 12px; background: transparent; color: var(--site-text-color, #111); }

        .testimonial-item { border-left: 4px solid var(--site-primary-color, #007aff); padding-left: 15px; font-style: italic; }
        .testimonial-item footer { font-style: normal; font-weight: 600; margin-top: 5px; }
        .faq-item { border-bottom: 1px solid var(--site-border-color, #eee); }
        .faq-item summary { font-weight: 600; cursor: pointer; padding: 15px 0; }
        .faq-item .faq-answer { padding: 0 5px 15px 10px; }

        .flux-intro { color: var(--site-muted-color, #888); margin-top: -10px; font-size: 1.1em; }
        
        .grid-type-article { display: grid; gap: 40px; }
        .flux-item.type-article { border-bottom: 1px solid var(--site-border-color, #eee); padding-bottom: 20px; }
        .flux-item.type-article h2 { margin-top: 0; margin-bottom: 5px; }
        .flux-item.type-article h2 a { color: var(--site-text-color, #111); }
        
        .article-meta {
            font-size: 0.9em;
            color: var(--site-muted-color, #777);
            margin-top: -5px; 
            margin-bottom: 10px;
        }
        
        .flux-item.type-article p { margin-top: 5px; color: var(--site-text-color, #555); }
        .flux-item.type-article .read-more { font-weight: 500; }

        .grid-type-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
        .flux-item.type-gallery { position: relative; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.05); }
        .flux-item.type-gallery img { width: 100%; height: auto; aspect-ratio: 16 / 10; object-fit: cover; display: block; }
        .flux-item.type-gallery h2 { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0,0,0,0.8), transparent); color: white; margin: 0; padding: 30px 15px 15px; font-size: 1.2rem; }
        .flux-item.type-gallery:hover img { transform: scale(1.03); transition: transform 0.3s ease; }

        .article-tag-cloud {
            margin: 30px 0 20px;
            padding: 20px;
            border-radius: 18px;
            border: 1px solid var(--site-border-color, #e0e0e0);
            background: var(--site-surface-color, #f6f8fb);
            box-shadow: 0 10px 25px rgba(15, 23, 42, 0.08);
        }
        .article-tag-cloud-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: 10px;
            margin-bottom: 12px;
        }
        .article-tag-cloud-header strong {
            font-size: 1rem;
            color: var(--site-text-color, #111);
        }
        .article-tag-selection {
            font-size: 0.9rem;
            color: var(--site-muted-color, #666);
        }
        .article-tag-cloud-list {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
        }
        .tag-chip {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 16px;
            border-radius: 999px;
            border: 1px solid var(--site-border-color, #e0e0e0);
            background: #fff;
            color: var(--site-text-color, #111);
            font-weight: 500;
            text-decoration: none;
            transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
        }
        .tag-chip:hover {
            transform: translateY(-1px);
            box-shadow: 0 6px 15px rgba(15, 23, 42, 0.12);
        }
        .tag-chip-count {
            font-size: 0.85rem;
            padding: 2px 8px;
            border-radius: 999px;
            background: var(--site-surface-color, #eef2f7);
            color: var(--site-muted-color, #555);
        }
        .tag-chip.is-active {
            background: var(--site-primary-color, #007aff);
            border-color: var(--site-primary-color, #007aff);
            color: var(--site-primary-contrast, #fff);
            box-shadow: 0 8px 22px rgba(0, 110, 255, 0.28);
        }
        .tag-chip.is-active .tag-chip-count {
            background: rgba(var(--site-primary-rgb, 0,122,255), 0.25);
            color: var(--site-primary-contrast, #fff);
        }

        .grid-pagination {
            display: flex;
            justify-content: center;
            gap: 14px;
            flex-wrap: wrap;
            margin: 45px 0 25px;
            font-size: 1.15rem;
        }
        .grid-pagination .page-link {
            min-width: 48px;
            padding: 10px 14px;
            border-radius: 999px;
            text-align: center;
            background: var(--site-surface-color, #f1f3f5);
            color: var(--site-muted-color, #555);
            font-weight: 600;
            text-decoration: none;
            border: 1px solid transparent;
            transition: all 0.2s ease;
        }
        .grid-pagination .page-link:hover {
            background: rgba(var(--site-primary-rgb, 0,122,255), 0.12);
            color: var(--site-primary-color, #007aff);
        }
        .grid-pagination .page-link.active {
            background: var(--site-primary-color, #007aff);
            color: var(--site-primary-contrast, #fff);
            border-color: var(--site-primary-color, #007aff);
            box-shadow: 0 6px 18px rgba(0,0,0,0.2);
        }
        .grid-archive-link {
            text-align: center;
            margin: 10px 0 70px;
        }
        .grid-archive-link a {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-weight: 600;
            padding: 12px 22px;
            border-radius: 999px;
            background: rgba(var(--site-primary-rgb, 0,122,255), 0.12);
            color: var(--site-primary-color, #007aff);
            border: 1px solid rgba(var(--site-primary-rgb, 0,122,255), 0.35);
            text-decoration: none;
            transition: transform 0.2s ease, box-shadow 0.2s ease;
        }
        .grid-archive-link a:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 20px rgba(0,0,0,0.15);
        }
