/* ===== Bases ===== */
:root { --cdb-radius: 18px; --cdb-gap: 24px; }

/* === Page shell (system font for global UI) === */
.cdb-page {
    display: grid;
    gap: 64px;
    max-width: 1600px;
    margin: 64px auto;
    padding: 0 32px;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;
    color: #1d1d1f;
    background: transparent;
}

/* === Article === */
.cdb-article {
    color: #1d1d1f;
}
.cdb-article-cover {
    margin: 0 0 56px;
    overflow: hidden;
    border-radius: 24px;
    aspect-ratio: 21/9;
    background: #f5f5f7;
}
.cdb-article-cover img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.cdb-article header {
    max-width: 760px;
    margin: 0 auto 56px;
    text-align: left;
}
.cdb-article-title {
    font-family: var(--cdb-font-title);
    color: #1d1d1f;
    font-size: clamp(40px, 5.5vw, 72px);
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 24px;
    font-weight: 600;
}
.cdb-article-meta {
    color: #86868b;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0;
}
.cdb-article-meta a { color: var(--cdb-accent); text-decoration: none; transition: opacity 0.2s; }
.cdb-article-meta a:hover { opacity: 0.7; }

/* === Body — narrow optimal reading column === */
.cdb-article-body {
    max-width: 760px;
    margin: 0 auto;
    color: #1d1d1f;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;
    font-size: 19px;
    line-height: 1.65;
}
.cdb-block { margin: 0 0 64px; }
.cdb-block .cdb-text {
    font-size: 19px;
    line-height: 1.65;
    color: #1d1d1f;
}
.cdb-block .cdb-text p { margin: 0 0 1.4em; }
.cdb-block .cdb-text a { color: var(--cdb-accent); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }

/* === Images & figures === */
.cdb-block figure { margin: 0; }
.cdb-block .cdb-img,
.cdb-block figure img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    border-radius: var(--cdb-radius);
}

/* For image-heavy variants: let them break out a bit beyond text column for impact */
.cdb-v-1-1 .cdb-banner,
.cdb-v-1-5 .cdb-overlay,
.cdb-v-2-1 .cdb-row-2,
.cdb-v-2-2 .cdb-row-2,
.cdb-v-2-3 .cdb-overlap,
.cdb-v-3-1 .cdb-row-3,
.cdb-v-3-3 .cdb-banner,
.cdb-v-3-4 .cdb-overlap-bg,
.cdb-v-4-1 .cdb-grid-2x2,
.cdb-v-4-3 .cdb-overlap-bg,
.cdb-v-4-4 .cdb-row-4,
.cdb-v-4-5 .cdb-tetris,
.cdb-v-5-2 .cdb-slider-thumbs,
.cdb-v-5-4 .cdb-cover-grid,
.cdb-v-5-5 .cdb-bento,
.cdb-carousel {
    margin-left: -120px;
    margin-right: -120px;
    width: calc(100% + 240px);
    max-width: calc(100% + 240px);
}
@media (max-width: 1100px) {
    .cdb-v-1-1 .cdb-banner, .cdb-v-1-5 .cdb-overlay, .cdb-v-2-1 .cdb-row-2,
    .cdb-v-2-2 .cdb-row-2, .cdb-v-2-3 .cdb-overlap, .cdb-v-3-1 .cdb-row-3,
    .cdb-v-3-3 .cdb-banner, .cdb-v-3-4 .cdb-overlap-bg, .cdb-v-4-1 .cdb-grid-2x2,
    .cdb-v-4-3 .cdb-overlap-bg, .cdb-v-4-4 .cdb-row-4, .cdb-v-4-5 .cdb-tetris,
    .cdb-v-5-2 .cdb-slider-thumbs, .cdb-v-5-4 .cdb-cover-grid, .cdb-v-5-5 .cdb-bento,
    .cdb-carousel {
        margin-left: 0; margin-right: 0; width: 100%; max-width: 100%;
    }
}

/* ===== 1.x ===== */
.cdb-v-1-1 .cdb-banner { margin-bottom: var(--cdb-gap); aspect-ratio: 16/9; }
.cdb-v-1-2 { display: grid; grid-template-columns: 40% 1fr; gap: var(--cdb-gap); align-items: start; }
.cdb-v-1-3 { display: grid; grid-template-columns: 1fr 40%; gap: var(--cdb-gap); align-items: start; }
.cdb-v-1-4 .cdb-square-center { width: 60%; margin: var(--cdb-gap) auto; aspect-ratio: 1/1; text-align: center; }
.cdb-v-1-4 .cdb-square-center figcaption { font-style: italic; color: var(--cdb-accent); font-family: var(--cdb-font-title); margin-top: 8px; font-size: 13px; }
.cdb-v-1-5 .cdb-overlay { position: relative; aspect-ratio: 16/9; margin-bottom: var(--cdb-gap); }
.cdb-v-1-5 .cdb-overlay-quote { position: absolute; left: 16px; right: 16px; bottom: 16px; background: rgba(255,255,255,0.94); padding: 10px 16px; border-left: 3px solid var(--cdb-accent); font-family: var(--cdb-font-title); font-style: italic; color: var(--cdb-primary); margin: 0; font-size: 16px; }

/* ===== 2.x ===== */
.cdb-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cdb-v-2-1 .cdb-row-2 { margin-bottom: var(--cdb-gap); }
.cdb-v-2-2 .cdb-row-2 { margin-top: var(--cdb-gap); }
.cdb-v-2-3 .cdb-overlap { position: relative; aspect-ratio: 16/9; margin-bottom: 48px; }
.cdb-v-2-3 .cdb-overlap .cdb-main { width: 100%; height: 100%; }
.cdb-polaroid { background: #fff; padding: 10px 10px 24px; border-radius: 14px; box-shadow: 0 8px 24px rgba(0,0,0,0.18); display: block; }
.cdb-polaroid .cdb-img { aspect-ratio: 1/1; }
.cdb-polaroid-br { position: absolute; right: 16px; bottom: -20px; width: 32%; transform: rotate(3deg); }
.cdb-polaroid-bl { position: absolute; left: 16px; bottom: -20px; width: 32%; transform: rotate(-4deg); }
.cdb-polaroid-bc { position: absolute; left: 50%; bottom: -20px; width: 28%; transform: translateX(-50%) rotate(2deg); z-index: 2; }
.cdb-v-2-4 .cdb-banner, .cdb-v-2-5 .cdb-banner { aspect-ratio: 21/9; margin-bottom: var(--cdb-gap); }
.cdb-row-text-img { display: grid; grid-template-columns: 1fr 35%; gap: var(--cdb-gap); align-items: start; }
.cdb-row-img-text { display: grid; grid-template-columns: 35% 1fr; gap: var(--cdb-gap); align-items: start; }

/* ===== 3.x ===== */
.cdb-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin-bottom: var(--cdb-gap); }
.cdb-row-3 figure { aspect-ratio: 4/3; }
.cdb-hero-stack { display: grid; grid-template-columns: 60% 1fr; gap: 8px; margin-bottom: var(--cdb-gap); }
.cdb-stack-right { display: grid; grid-template-rows: 1fr 1fr; gap: 8px; }
.cdb-v-3-3 .cdb-banner { aspect-ratio: 21/9; margin-bottom: var(--cdb-gap); }
.cdb-v-3-3 .cdb-row-2 { margin-top: var(--cdb-gap); }
.cdb-overlap-bg { position: relative; aspect-ratio: 16/8; margin-bottom: 48px; }
.cdb-overlap-bg .cdb-bg { width: 100%; height: 100%; }

/* ===== Carrousel commun (3.5 / 4.2 / 5.3) ===== */
.cdb-carousel { position: relative; }
.cdb-carousel .cdb-slides { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.cdb-carousel .cdb-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s; }
.cdb-carousel .cdb-slide.is-active { opacity: 1; }
.cdb-arrow { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.85); border: none; border-radius: 50%; width: 36px; height: 36px; font-size: 20px; color: var(--cdb-primary); cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,0.15); }
.cdb-arrow-prev { left: 12px; } .cdb-arrow-next { right: 12px; }
.cdb-dots { display: flex; justify-content: center; gap: 6px; margin-top: 10px; }
.cdb-dot { width: 8px; height: 8px; border-radius: 50%; background: #ccc; border: none; padding: 0; cursor: pointer; }
.cdb-dot.is-active { background: var(--cdb-primary); }
.cdb-counter { position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,0.6); color: #fff; padding: 2px 10px; border-radius: 12px; font-size: 12px; }

/* ===== 4.x ===== */
.cdb-grid-2x2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: var(--cdb-gap); }
.cdb-grid-2x2 figure { aspect-ratio: 4/3; }
.cdb-row-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-bottom: var(--cdb-gap); }
.cdb-row-4 figure { aspect-ratio: 1/1; }
.cdb-tetris { display: grid; grid-template-columns: 60% 1fr; gap: 8px; margin-bottom: var(--cdb-gap); }
.cdb-tetris .cdb-main { aspect-ratio: 1/1; }
.cdb-tetris-right { display: grid; grid-template-rows: 1.4fr 1fr; gap: 8px; }
.cdb-tetris-right .cdb-portrait { aspect-ratio: 3/4; }

/* ===== 5.x ===== */
.cdb-zigzag { display: grid; gap: var(--cdb-gap); align-items: center; margin-bottom: var(--cdb-gap); }
.cdb-zigzag-right { grid-template-columns: 1fr 38%; }
.cdb-zigzag-left  { grid-template-columns: 38% 1fr; }
.cdb-zigzag figure { aspect-ratio: 4/3; }

.cdb-slider-thumbs .cdb-slides { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.cdb-slider-thumbs .cdb-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s; }
.cdb-slider-thumbs .cdb-slide.is-active { opacity: 1; }
.cdb-thumbs-strip { display: grid; grid-template-columns: repeat(auto-fill, minmax(60px, 1fr)); gap: 5px; margin-top: 8px; }
.cdb-thumb { background: none; border: 2px solid transparent; padding: 0; cursor: pointer; aspect-ratio: 1/1; overflow: hidden; }
.cdb-thumb.is-active { border-color: var(--cdb-primary); }
.cdb-thumb img { width: 100%; height: 100%; object-fit: cover; }

.cdb-cover-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 6px; margin-bottom: var(--cdb-gap); aspect-ratio: 5/3; }
.cdb-cover-grid .cdb-cover-main { grid-row: span 2; }
.cdb-cover-last { position: relative; }
.cdb-more-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 600; font-size: 18px; cursor: pointer; }

.cdb-bento { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 6px; aspect-ratio: 5/3; margin-bottom: 6px; }
.cdb-bento .cdb-bento-hero { grid-row: span 2; }
.cdb-bento-extra { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-bottom: var(--cdb-gap); }
.cdb-bento-extra figure { aspect-ratio: 1/1; }

/* ===== Lightbox ===== */
.cdb-lightbox-modal { position: fixed; inset: 0; background: rgba(0,0,0,0.92); display: flex; align-items: center; justify-content: center; z-index: 9999; }
.cdb-lightbox-modal img { max-width: 90vw; max-height: 90vh; object-fit: contain; }
.cdb-lightbox-modal .cdb-lb-close { position: absolute; top: 20px; right: 20px; color: #fff; background: none; border: none; font-size: 32px; cursor: pointer; }

/* ===== Mobile ===== */
@media (max-width: 768px) {
    .cdb-v-1-2, .cdb-v-1-3, .cdb-row-text-img, .cdb-row-img-text, .cdb-zigzag-right, .cdb-zigzag-left, .cdb-hero-stack, .cdb-tetris { grid-template-columns: 1fr; }
    .cdb-row-3, .cdb-row-4, .cdb-grid-2x2, .cdb-cover-grid, .cdb-bento { grid-template-columns: 1fr 1fr; }
    .cdb-cover-grid .cdb-cover-main, .cdb-bento .cdb-bento-hero { grid-row: auto; grid-column: span 2; }
    .cdb-polaroid { transform: none !important; position: static; width: 50%; margin: 8px auto; }
    .cdb-overlap-bg { aspect-ratio: 4/3; margin-bottom: var(--cdb-gap); }
    .cdb-v-2-3 .cdb-overlap { margin-bottom: var(--cdb-gap); }
}

/* ===== Page layout ===== */
.cdb-page.cdb-sidebar-right { grid-template-columns: 1fr 280px; }
.cdb-page.cdb-sidebar-left  { grid-template-columns: 280px 1fr; }
.cdb-page.cdb-sidebar-left .cdb-main { order: 2; }
.cdb-page.cdb-sidebar-none  { grid-template-columns: 1fr; }
@media (max-width: 992px) { .cdb-page { grid-template-columns: 1fr !important; } .cdb-sidebar { display: none; } }

/* ===== Archive header ===== */
.cdb-archive-header { margin: 24px 0 16px; }
.cdb-archive-header h1 {
    font-family: var(--cdb-font-title);
    color: #1d1d1f;
    font-size: clamp(40px, 5vw, 64px);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.05;
    margin: 0 0 32px;
}
.cdb-archive-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 48px; }
.cdb-chip {
    display: inline-block; padding: 8px 18px;
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 999px;
    color: #1d1d1f; text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all 0.2s;
}
.cdb-chip:hover { border-color: var(--cdb-accent); color: var(--cdb-accent); }
.cdb-chip.is-active { background: #1d1d1f; color: #fff; border-color: #1d1d1f; }
.cdb-no-results { color: #86868b; font-size: 17px; padding: 48px 0; text-align: center; }

/* ===== Listing ===== */
.cdb-list { display: flex; flex-direction: column; gap: 0; margin: 64px 0; }
.cdb-list-item {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 56px;
    text-decoration: none;
    color: inherit;
    padding: 56px 0;
    border-bottom: 1px solid rgba(0,0,0,0.08);
    align-items: center;
    transition: opacity 0.3s ease;
}
.cdb-list-item:first-child { padding-top: 0; }
.cdb-list-item:hover .cdb-list-cover img { transform: scale(1.04); }
.cdb-list-item:hover .cdb-list-title { color: var(--cdb-primary); }
.cdb-list-cover {
    overflow: hidden;
    border-radius: 18px;
    aspect-ratio: 16/10;
    background: #f5f5f7;
}
.cdb-list-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s cubic-bezier(.2,.8,.2,1);
}
.cdb-list-cover-empty { background: linear-gradient(135deg, #f5f5f7, #e8e8ed); }
.cdb-list-body { display: flex; flex-direction: column; }
.cdb-list-top-meta {
    display: flex; gap: 12px; align-items: center;
    font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cdb-accent); margin-bottom: 16px;
}
.cdb-list-top-meta a { color: inherit; text-decoration: none; }
.cdb-list-cat::after { content: '·'; margin-left: 12px; color: rgba(0,0,0,0.2); font-weight: 400; }
.cdb-list-date { color: #86868b; font-weight: 500; letter-spacing: 0.04em; }
.cdb-list-title {
    font-family: var(--cdb-font-title);
    color: #1d1d1f;
    font-size: clamp(28px, 3.2vw, 40px);
    line-height: 1.1;
    letter-spacing: -0.015em;
    margin: 0 0 18px;
    font-weight: 600;
    transition: color 0.3s ease;
}
.cdb-list-excerpt {
    font-size: 17px;
    line-height: 1.55;
    color: #515154;
    margin: 0 0 24px;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;
}
.cdb-list-bottom-meta {
    display: flex; gap: 20px; flex-wrap: wrap; align-items: center;
    font-size: 13px; color: #86868b;
    padding-top: 0; border: none;
}
.cdb-list-bottom-meta a { color: var(--cdb-accent); text-decoration: none; transition: opacity 0.2s; }
.cdb-list-bottom-meta a:hover { opacity: 0.7; }
.cdb-list-author { font-weight: 500; }
.cdb-list-tags { font-style: normal; opacity: 0.85; }
@media (max-width: 768px) {
    .cdb-list-item { grid-template-columns: 1fr; gap: 24px; padding: 32px 0; }
    .cdb-list-title { font-size: 24px; }
    .cdb-list-excerpt { font-size: 15px; }
}

/* ===== Sidebar ===== */
.cdb-sidebar h3 {
    font-family: var(--cdb-font-title);
    color: #1d1d1f;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 28px 0 12px;
}
.cdb-sidebar ul { list-style: none; padding: 0; margin: 0; }
.cdb-sidebar li { padding: 10px 0; border-bottom: 1px solid rgba(0,0,0,0.06); font-size: 14px; }
.cdb-sidebar li:last-child { border: none; }
.cdb-sidebar a { color: #1d1d1f; text-decoration: none; transition: color 0.2s; }
.cdb-sidebar a:hover { color: var(--cdb-accent); }
.cdb-sb-search input[type=search] {
    width: 100%; padding: 12px 16px; border: 1px solid rgba(0,0,0,0.1);
    border-radius: 12px; font-size: 14px; background: #f5f5f7;
    transition: border-color 0.2s, background 0.2s;
}
.cdb-sb-search input[type=search]:focus { outline: none; border-color: var(--cdb-accent); background: #fff; }

/* ===== Pagination ===== */
.cdb-pagination { display: flex; justify-content: center; gap: 6px; margin-top: 56px; }
.cdb-pagination .page-numbers {
    padding: 10px 16px; border: 1px solid rgba(0,0,0,0.08);
    border-radius: 999px; color: #1d1d1f; text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all 0.2s;
}
.cdb-pagination .page-numbers:hover { border-color: var(--cdb-accent); color: var(--cdb-accent); }
.cdb-pagination .page-numbers.current { background: #1d1d1f; color: #fff; border-color: #1d1d1f; }

/* ===== Share buttons ===== */
.cdb-share {
    display: flex; gap: 16px; margin: 64px auto 0;
    max-width: 760px;
    padding: 24px 0; border-top: 1px solid rgba(0,0,0,0.08);
    align-items: center; font-size: 13px; color: #86868b;
}
.cdb-share a, .cdb-share button {
    color: var(--cdb-accent); text-decoration: none;
    background: none; border: 1px solid rgba(0,0,0,0.1); cursor: pointer;
    padding: 8px 16px; font-size: 13px; border-radius: 999px;
    transition: all 0.2s; font-family: inherit;
}
.cdb-share a:hover, .cdb-share button:hover { border-color: var(--cdb-accent); background: rgba(201,169,110,0.08); }

/* ===== Suggested articles ===== */
.cdb-suggested { margin-top: 96px; max-width: 1600px; }
.cdb-suggested h2 {
    font-family: var(--cdb-font-title);
    color: #1d1d1f;
    font-size: 32px;
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 0 0 32px;
    padding-top: 64px;
    border-top: 1px solid rgba(0,0,0,0.08);
}
.cdb-suggested-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.cdb-suggested-card { display: block; text-decoration: none; color: #1d1d1f; transition: opacity 0.3s; }
.cdb-suggested-card:hover { opacity: 0.7; }
.cdb-suggested-card figure { aspect-ratio: 16/10; margin: 0 0 16px; overflow: hidden; border-radius: 14px; background: #f5f5f7; }
.cdb-suggested-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(.2,.8,.2,1); }
.cdb-suggested-card:hover img { transform: scale(1.04); }
.cdb-suggested-card h3 {
    font-family: var(--cdb-font-title);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.3;
    margin: 0;
    color: #1d1d1f;
    letter-spacing: -0.01em;
}
@media (max-width: 768px) {
    .cdb-suggested-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* === Elementor widget cdactualites === */
.cdb-actu-widget { font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif; color: #1d1d1f; }
.cdb-actu-title {
    font-family: var(--cdb-font-title);
    font-size: clamp(28px, 3.5vw, 44px);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.05;
    margin: 0 0 32px;
    color: #1d1d1f;
}
.cdb-actu-list { display: grid; gap: 24px; }
.cdb-actu-card {
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
    transition: opacity 0.3s, transform 0.3s;
    overflow: hidden;
}
.cdb-actu-card:hover { transform: translateY(-2px); }
.cdb-actu-card:hover .cdb-actu-cover img { transform: scale(1.04); }
.cdb-actu-cover {
    overflow: hidden;
    border-radius: 18px;
    aspect-ratio: 16/10;
    background: #f5f5f7;
    margin: 0;
}
.cdb-actu-cover img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform 0.6s cubic-bezier(.2,.8,.2,1);
}
.cdb-actu-cover-empty { background: linear-gradient(135deg, #f5f5f7, #e8e8ed); }
.cdb-actu-body { padding: 18px 0 0; display: flex; flex-direction: column; gap: 8px; }
.cdb-actu-cat {
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cdb-accent);
}
.cdb-actu-cat a { color: inherit; text-decoration: none; }
.cdb-actu-card-title {
    font-family: var(--cdb-font-title);
    font-size: 22px; line-height: 1.2;
    letter-spacing: -0.01em;
    margin: 0; color: #1d1d1f;
    font-weight: 600;
}
.cdb-actu-excerpt {
    font-size: 15px; line-height: 1.55; color: #515154; margin: 0;
}
.cdb-actu-date {
    font-size: 12px; color: #86868b; font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.cdb-actu-more {
    margin-top: 36px; text-align: center;
}
.cdb-actu-more a {
    display: inline-block;
    padding: 14px 28px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 999px;
    color: #1d1d1f;
    text-decoration: none;
    font-size: 14px; font-weight: 500;
    transition: all 0.25s;
}
.cdb-actu-more a:hover { border-color: var(--cdb-accent); color: var(--cdb-accent); }
.cdb-actu-empty { padding: 48px 0; text-align: center; color: #86868b; font-style: italic; }

/* Layout per count */
.cdb-actu-one .cdb-actu-list { grid-template-columns: 1fr; }
.cdb-actu-one .cdb-actu-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 28px;
    align-items: center;
}
.cdb-actu-one .cdb-actu-cover { aspect-ratio: 16/10; border-radius: 14px; margin: 0; }
.cdb-actu-one .cdb-actu-body { padding: 0; gap: 6px; }
.cdb-actu-one .cdb-actu-card-title { font-size: 20px; }
.cdb-actu-one .cdb-actu-excerpt { font-size: 14px; line-height: 1.5; }
@media (max-width: 600px) {
    .cdb-actu-one .cdb-actu-card { grid-template-columns: 1fr; gap: 16px; }
}

.cdb-actu-two .cdb-actu-list { grid-template-columns: 1fr 1fr; gap: 32px; }

.cdb-actu-three .cdb-actu-list { grid-template-columns: 2fr 1fr; gap: 32px; grid-auto-rows: min-content; }
.cdb-actu-three .cdb-actu-card:first-child { grid-row: span 2; }
.cdb-actu-three .cdb-actu-card:first-child .cdb-actu-cover { aspect-ratio: 4/5; }
.cdb-actu-three .cdb-actu-card:first-child .cdb-actu-card-title { font-size: 28px; }
.cdb-actu-three .cdb-actu-card:not(:first-child) { display: grid; grid-template-columns: 140px 1fr; gap: 16px; align-items: center; }
.cdb-actu-three .cdb-actu-card:not(:first-child) .cdb-actu-cover { aspect-ratio: 1/1; border-radius: 12px; }
.cdb-actu-three .cdb-actu-card:not(:first-child) .cdb-actu-body { padding: 0; }
.cdb-actu-three .cdb-actu-card:not(:first-child) .cdb-actu-card-title { font-size: 17px; }
.cdb-actu-three .cdb-actu-card:not(:first-child) .cdb-actu-excerpt { display: none; }

.cdb-actu-many .cdb-actu-list { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 32px; }
.cdb-actu-many .cdb-actu-card-title { font-size: 18px; }
.cdb-actu-many .cdb-actu-excerpt { font-size: 14px; -webkit-line-clamp: 2; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; }

@media (max-width: 768px) {
    .cdb-actu-two .cdb-actu-list,
    .cdb-actu-three .cdb-actu-list,
    .cdb-actu-many .cdb-actu-list { grid-template-columns: 1fr; }
    .cdb-actu-three .cdb-actu-card:first-child { grid-row: auto; }
    .cdb-actu-three .cdb-actu-card:first-child .cdb-actu-cover { aspect-ratio: 16/10; }
    .cdb-actu-three .cdb-actu-card:not(:first-child) { grid-template-columns: 100px 1fr; }
}
