/* ========== com2dev-core ========== */
:root {
    --c2d-accent: var(--wp--preset--color--cyan, #0ea5b7);
    --c2d-ink: var(--wp--preset--color--contrast, #111827);
    --c2d-muted: #6b7280;
    --c2d-border: rgba(0, 0, 0, .12);
    --c2d-bg-soft: #f7fafb;
}

/* A) ARCHIVE & SINGLE (CPT 'project') ------------------------ */
.post-type-archive-project .kicker,
.single-project .kicker {
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .85rem;
    color: #6b7280;
    margin-bottom: .75rem;
}

.post-type-archive-project .projects-grid {
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.post-type-archive-project .project-card {
    background: #fff;
    border: 1px solid #E6E8EC;
    border-radius: 16px;
    box-shadow: 0 1px 0 rgba(0, 0, 0, .03);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.post-type-archive-project .project-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(0, 0, 0, .06);
    border-color: #d9dfe6;
}

.post-type-archive-project .card-link {
    display: block;
    padding: 1.1rem;
    color: inherit;
    text-decoration: none;
}

.post-type-archive-project .thumb img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 12px;
}

.post-type-archive-project .card-title {
    margin: .2rem 0 .35rem;
    font-size: 1.25rem;
    word-break: keep-all;
    hyphens: auto;
}

.post-type-archive-project .card-excerpt {
    color: #4b5563;
}

.post-type-archive-project .card-cta {
    display: inline-block;
    margin-top: .65rem;
    font-weight: 500;
    color: #2c5c5e;
    border-bottom: 1px solid transparent;
}

.post-type-archive-project .project-card:hover .card-cta {
    border-color: currentColor;
}

.single-project .project-header {
    max-width: 80ch;
    color: #374151;
}

.single-project .project-content {
    color: #374151;
}

/* Badge "générique" utilisé au-dessus des titres (archive/single) */
.post-type-archive-project .badge,
.single-project .badge {
    display: inline-block;
    margin-top: .75rem;
    margin-bottom: .4rem;
    padding: .35rem .6rem;
    border-radius: 999px;
    font-size: .8rem;
    line-height: 1;
    background: rgba(74, 144, 147, .12);
    color: #2c5c5e;
}

/* B) KADENCE POST GRID (si utilisé) -------------------------- */
.c2d-postcards article,
.c2d-postcards .kb-posts-item-inner {
    background: #fff;
    border: 1px solid #E6E8EC;
    border-radius: 16px;
    padding: 16px;
    box-shadow: 0 1px 0 rgba(0, 0, 0, .03);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.c2d-postcards article:hover,
.c2d-postcards .kb-posts-item-inner:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(0, 0, 0, .06);
    border-color: #d9dfe6;
}

.c2d-postcards figure img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 12px;
    display: block;
}

.c2d-postcards .entry-title {
    margin: .15rem 0 .35rem;
    font-size: 1.25rem;
}

.c2d-postcards .kb-posts-excerpt {
    color: #4b5563;
}

.c2d-postcards .kb-posts-readmore {
    color: #2c5c5e;
    font-weight: 500;
    position: relative;
    padding-right: .6rem;
}

.c2d-postcards .kb-posts-readmore::after {
    content: "→";
    position: absolute;
    right: -.05rem;
    transform: translateX(2px);
    transition: transform .18s ease;
}

.c2d-postcards article:hover .kb-posts-readmore::after {
    transform: translateX(6px);
}

.c2d-postcards .kb-posts-wrap {
    gap: 28px;
}

/* C) SHORTCODES — Badges / Liens / Meta ---------------------- */
/* Badges [c2d_project_badges] */
/* Base */
/* ===== Badges : base ===== */
.c2d-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem .75rem;
    margin: .75rem 0;
}

.c2d-badge {
    display: inline-block;
    line-height: 1;
    font-size: 1.1rem;
    padding: .35rem .6rem;
    border-radius: 999px;
    background: #eef2f6;
    color: #1f2937;
    text-decoration: none;
    border: 1px solid rgba(0, 0, 0, .06);
}

.c2d-badge:hover {
    box-shadow: 0 1px 0 rgba(0, 0, 0, .05);
}

/* Modifs par famille */
.c2d-badge--type {
    background: #eaf3f8;
    color: #0f3e4f;
}

.c2d-badge--stack {
    background: #eef7ea;
    color: #1f3d1f;
}

.c2d-badge--status {
    background: #f3f4f6;
    color: #374151;
}

/* ===== Statuts – couleurs par slug ===== */
.c2d-badge--status-en-production {
    background: #DCFCE7;
    color: #166534;
}

/* vert */
.c2d-badge--status-en-cours {
    background: #FEF9C3;
    color: #92400E;
}

/* jaune */
.c2d-badge--status-termine {
    background: #E0E7FF;
    color: #3730A3;
}

/* indigo */
.c2d-badge--status-poc,
.c2d-badge--status-brouillon {
    background: #F5F3FF;
    color: #6D28D9;
}

/* violet */

/* ===== Stacks – exemples par slug ===== */
.c2d-badge--stack-react {
    background: #E6F0FF;
    color: #1F3A8A;
}

.c2d-badge--stack-node-js {
    background: #E9FCE6;
    color: #166534;
}

.c2d-badge--stack-wordpress {
    background: #E7F3F8;
    color: #0F3E4F;
}

.c2d-badge--stack-make {
    background: #EAF7FB;
    color: #0E7490;
}

.c2d-badge--stack-airtable {
    background: #FFF7ED;
    color: #9A3412;
}

.c2d-badge--stack-flutter {
    background: #E6F0FF;
    color: #1E3A8A;
}

.c2d-badge--stack-ios {
    background: #F3F4F6;
    color: #111827;
}

.c2d-badge--stack-android {
    background: #ECFDF5;
    color: #065F46;
}

.c2d-badge--stack-prisma {
    background: #ECFEFF;
    color: #155E75;
}

.c2d-badge--stack-vite {
    background: #F5F3FF;
    color: #6D28D9;
}

.c2d-badge--stack-docker {
    background: #E0F2FE;
    color: #1D4ED8;
}

.c2d-badge--stack-sqlite {
    background: #EEF2FF;
    color: #4338CA;
}

/* ===== Types – exemples par slug ===== */
.c2d-badge--type-b2b {
    background: #E0F2F1;
    color: #0F766E;
}

.c2d-badge--type-outil-metier {
    background: #E8F5E9;
    color: #1B5E20;
}

.c2d-badge--type-mobile {
    background: #EFF6FF;
    color: #1E40AF;
}

.c2d-badge--type-ecommerce {
    background: #FEF3C7;
    color: #92400E;
}

/* Liens & boutons [c2d_project_links] */
.c2d-links {
    display: flex;
    gap: .5rem;
    margin: 1rem 0 0;
}

.c2d-links--buttons {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}

.c2d-btn {
    display: inline-block;
    padding: .5rem .75rem;
    border: 1px solid rgba(0, 0, 0, .1);
    border-radius: .6rem;
    text-decoration: none;
    transition: .12s ease;
}

.c2d-btn:hover {
    box-shadow: 0 1px 0 rgba(0, 0, 0, .05);
}

.c2d-btn--demo_url {
    background: var(--c2d-accent);
    color: #fff;
    border-color: transparent;
}

.c2d-btn--github_url {
    background: #0f172a;
    color: #fff;
}

.c2d-btn--video_url {
    background: #fff;
    color: #0b5963;
    border-color: var(--c2d-accent);
}

.c2d-links--inline {
    margin: .35rem 0 0;
}

.c2d-links--inline .c2d-link {
    text-decoration: none;
    color: #0b5963;
    font-weight: 600;
}

.c2d-links--inline .c2d-link:hover {
    color: var(--c2d-accent);
}

/* Meta [c2d_project_meta] — version <dl> (recommandée) */
.c2d-meta {
    margin: 1.25rem 0;
}

.c2d-meta dl {
    margin: 0;
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: .5rem 1rem;
}

@media (max-width:680px) {
    .c2d-meta dl {
        grid-template-columns: 1fr;
    }
}

.c2d-meta dt {
    font-weight: 600;
    color: rgba(0, 0, 0, .65);
}

.c2d-meta dd {
    margin: 0;
    color: rgba(0, 0, 0, .85);
}

/* (Ancienne variante en lignes .c2d-meta__row conservée si déjà utilisée) */
.c2d-meta__row {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: .5rem 1rem;
    padding: .4rem 0;
    border-top: 1px dashed rgba(0, 0, 0, .06);
}

.c2d-meta__row:first-child {
    border-top: 0;
}

.c2d-meta__dt {
    font-weight: 600;
    color: rgba(0, 0, 0, .65);
}

.c2d-meta__dd {
    color: rgba(0, 0, 0, .85);
}

.c2d-meta__ul {
    margin: .25rem 0 0;
    padding-left: 1rem;
}

/* D) UTILITAIRES & CARDS GÉNÉRIQUES --------------------------- */
.c2d-grid {
    display: grid;
    gap: 1rem;
}

.c2d-grid--cols-1 {
    grid-template-columns: 1fr;
}

.c2d-grid--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.c2d-grid--cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

/* Card générique (si tu en utilises en dehors de Kadence) */
.c2d-card {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, .08);
    border-radius: 14px;
    padding: 1rem;
    box-shadow: 0 8px 20px rgba(0, 0, 0, .03);
}

.c2d-card__title {
    margin: 0 0 .5rem;
}

.c2d-card__excerpt {
    color: rgba(0, 0, 0, .7);
}

.c2d-card__link {
    display: inline-block;
    margin-top: .5rem;
    font-weight: 600;
}

/* Autres projets  */
.c2d-other-projects .project-card,
.c2d-other-projects .kb-posts-item-inner {
    background: #fff;
    border: 1px solid #E6E8EC;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 1px 0 rgba(0, 0, 0, .03);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.c2d-other-projects .project-card:hover,
.c2d-other-projects .kb-posts-item-inner:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(0, 0, 0, .06);
    border-color: #d9dfe6;
}

/* Vignette plus petite */
.c2d-other-projects figure img {
    width: 100%;
    height: 160px;
    /* compact */
    object-fit: cover;
    border-radius: 12px;
    display: block;
}

/* Titres + extrait raccourcis */
.c2d-other-projects .entry-title {
    font-size: 1.05rem;
    margin: .25rem 0 .35rem;
}

.c2d-other-projects .kb-posts-excerpt {
    font-size: .9rem;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Grille */
.c2d-other-projects .c2d-grid {
    gap: 22px;
}

@media (max-width: 640px) {
    .c2d-other-projects .c2d-grid {
        grid-template-columns: 1fr;
    }
}