/* ─────────────────────────────────────────────────────────────────────────
   SINGLES.CSS — Articles, formations et réalisations individuels
   Chargé sur : is_single(), is_singular('formation'), is_singular('realisation')
   ───────────────────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE ARTICLE
   ═══════════════════════════════════════════════════════════════════════════ */

.single-post__hero {
    position: relative;
    min-height: 460px;
    display: flex;
    align-items: flex-end;
    background: var(--slate-900);
    overflow: hidden;
}
.single-post__hero--no-thumb {
    background: linear-gradient(135deg, var(--slate-800) 0%, #3b0764 100%);
    min-height: 340px;
}
.single-post__hero-bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
}
.single-post__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(10,10,25,.9) 0%, rgba(10,10,25,.4) 60%, transparent 100%);
}
.single-post__hero-content {
    position: relative;
    z-index: 1;
    width: 100%;
    padding-block: 56px;
}

.single-post__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 18px;
}
.single-post__cat {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    color: var(--fushia-300, #f0abfc);
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none;
    border: 1.5px solid rgba(240,171,252,.4);
    padding: 4px 10px;
    border-radius: 99px;
    transition: all var(--transition);
}
.single-post__cat:hover { background: rgba(240,171,252,.15); }
.single-post__date,
.single-post__read-time {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: rgba(255,255,255,.65);
}
.single-post__title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.22;
    margin-bottom: 14px;
    max-width: 820px;
}
.single-post__excerpt {
    color: rgba(255,255,255,.72);
    font-size: 17px;
    max-width: 680px;
    line-height: 1.7;
    margin-bottom: 20px;
}
.single-post__author-inline {
    display: flex;
    align-items: center;
    gap: 10px;
    color: rgba(255,255,255,.65);
    font-size: 14px;
}
.single-post__author-inline strong { color: rgba(255,255,255,.9); }
.single-author__avatar--sm {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,.3);
}

/* Body layout */
.single-post__body { padding-block: 64px; }
.single-post__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 296px;
    gap: 52px;
    align-items: start;
    max-width: var(--container-max);
    margin-inline: auto;
    width: 100%;
}

/* Entry content ────────────────────────────────────────────────── */
.entry-content {
    min-width: 0;
    overflow-wrap: anywhere;
}
.entry-content h2 {
    font-size: clamp(1.3rem, 2.5vw, 1.6rem);
    font-weight: 700;
    color: var(--slate-900);
    margin-top: 40px;
    margin-bottom: 14px;
}
.entry-content h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--slate-800);
    margin-top: 28px;
    margin-bottom: 10px;
}
.entry-content p {
    font-size: 17px;
    line-height: 1.85;
    color: var(--slate-700);
    margin-bottom: 18px;
}
.entry-content ul,
.entry-content ol {
    margin-bottom: 18px;
    padding-left: 22px;
}
.entry-content li {
    font-size: 17px;
    line-height: 1.75;
    color: var(--slate-700);
    margin-bottom: 6px;
}
.entry-content ul li { list-style: disc; }
.entry-content ol li { list-style: decimal; }
.entry-content strong { font-weight: 700; color: var(--slate-900); }
.entry-content a {
    color: var(--fushia-600);
    text-decoration: underline;
    text-underline-offset: 3px;
}
.entry-content a:hover { color: var(--fushia-700); }
.entry-content blockquote {
    border-left: 4px solid var(--fushia-600);
    margin-block: 24px;
    padding: 16px 20px;
    background: var(--fushia-50, #fdf4ff);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.entry-content blockquote p { color: var(--slate-800); margin-bottom: 0; font-style: italic; }
.entry-content img {
    width: 100%;
    border-radius: var(--radius-md);
    margin-block: 24px;
}
.entry-content :first-child { margin-top: 0; }

/* Entry tags */
.entry-tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding-top: 32px;
    margin-top: 32px;
    border-top: 1px solid var(--color-border);
}
.entry-tags__label {
    font-size: 13px;
    font-weight: 700;
    color: var(--slate-500);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Entry prev/next nav */
.entry-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 40px;
    padding-top: 32px;
    border-top: 1px solid var(--color-border);
}
.entry-nav__link {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 16px;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: all var(--transition);
    background: var(--color-white);
    text-decoration: none;
}
.entry-nav__link:hover {
    border-color: var(--fushia-600);
    background: var(--fushia-50, #fdf4ff);
}
.entry-nav__link--next { text-align: right; grid-column: 2; }
.entry-nav__dir {
    font-size: 12px;
    font-weight: 700;
    color: var(--fushia-600);
    display: flex;
    align-items: center;
    gap: 4px;
}
.entry-nav__link--next .entry-nav__dir { justify-content: flex-end; }
.entry-nav__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--slate-800);
    line-height: 1.4;
    overflow: hidden;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

/* Single Aside Cards */
.single-post__sidebar,
.single-formation__sidebar,
.single-realisation__sidebar {
    position: sticky;
    top: calc(72px + 24px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-left: 4px;
}
.admin-bar .single-post__sidebar,
.admin-bar .single-formation__sidebar,
.admin-bar .single-realisation__sidebar {
    top: calc(72px + 32px + 24px);
}
.single-aside {
    background: var(--color-white);
    border-radius: var(--radius-md);
    padding: 20px;
    box-shadow: var(--shadow-card);
    border: 1px solid var(--color-border);
}
.single-aside__title {
    font-family: var(--font-heading);
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 7px;
}
.single-aside__title i { color: var(--fushia-600); }
.single-author {
    display: flex;
    align-items: center;
    gap: 12px;
}
.single-author__avatar {
    width: 52px !important; height: 52px !important;
    border-radius: 50%;
    border: 2px solid var(--color-border);
    flex-shrink: 0;
}
.single-author__name {
    font-size: 15px;
    font-weight: 700;
    color: var(--slate-900);
    margin: 0;
}

/* Share buttons */
.share-list { display: flex; gap: 8px; flex-wrap: wrap; }
.share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    text-decoration: none;
    transition: opacity var(--transition);
}
.share-btn:hover { opacity: .82; color: #fff; }
.share-btn--linkedin { background: #0077b5; }
.share-btn--twitter  { background: #1da1f2; }

/* Related section */
.related-section {
    background: var(--slate-50, #f8fafc);
    border-top: 1px solid var(--color-border);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE FORMATION
   ═══════════════════════════════════════════════════════════════════════════ */

.single-formation__hero {
    background: linear-gradient(135deg, var(--slate-900) 0%, #1e1448 100%);
    padding-block: 72px 60px;
    position: relative;
    overflow: hidden;
}
.single-formation__hero.has-thumb {
    min-height: 480px;
    display: flex;
    align-items: flex-end;
}
.single-formation__hero-img {
    position: absolute;
    inset: 0;
}
.single-formation__hero-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: .25;
}
.single-formation__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(5,5,20,.95) 0%, rgba(5,5,20,.5) 60%, rgba(5,5,20,.25) 100%);
}
.single-formation__hero-content {
    position: relative;
    z-index: 1;
    width: 100%;
    padding-block: 20px;
}

.single-breadcrumb {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: rgba(255,255,255,.5);
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.single-breadcrumb a  { color: rgba(255,255,255,.55); transition: color var(--transition); }
.single-breadcrumb a:hover { color: rgba(255,255,255,.9); }
.single-breadcrumb i  { font-size: 14px; opacity: .4; }

.single-formation__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 16px;
}
.single-formation__title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 16px;
    max-width: 860px;
}
.single-formation__subtitle {
    font-size: 18px;
    color: rgba(255,255,255,.72);
    max-width: 700px;
    line-height: 1.7;
    margin-bottom: 24px;
}
.single-formation__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.formation-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: rgba(255,255,255,.1);
    border: 1.5px solid rgba(255,255,255,.2);
    border-radius: 99px;
    font-size: 13px;
    font-weight: 600;
    color: rgba(255,255,255,.85);
    backdrop-filter: blur(4px);
}
.formation-chip--emerald {
    background: rgba(5,150,105,.3);
    border-color: rgba(52,211,153,.4);
    color: #6ee7b7;
}

/* Formation body layout */
.single-formation__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 324px;
    gap: 52px;
    align-items: start;
    max-width: var(--container-max);
    margin-inline: auto;
    width: 100%;
}

/* Formation content blocks */
.formation-block {
    margin-bottom: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--color-border);
}
.formation-block:last-child { border-bottom: none; margin-bottom: 0; }

.formation-block__title {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--fushia-600);
}
.formation-block__title i {
    color: var(--fushia-600);
    font-size: 1.2rem;
}
.formation-block__content p,
.formation-block__content li {
    font-size: 17px;
    line-height: 1.8;
    color: var(--slate-700);
}

/* Objectifs avec puces stylées */
.formation-objectifs p { margin-bottom: 8px; }
.formation-objectifs li::before { content: '✓ '; color: var(--emerald-600); font-weight: 700; }

/* Sidebar formation */
.formation-sidebar-card {
    background: var(--color-white);
    border-radius: var(--radius-md);
    box-shadow: 0 4px 32px rgba(26,30,60,.08);
    border: 1px solid var(--color-border);
    overflow: hidden;
    margin-bottom: 16px;
}
.formation-sidebar-card__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--slate-900);
    padding: 18px 20px 0;
    margin-bottom: 16px;
}
.formation-info-list {
    list-style: none;
    padding: 0 20px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.formation-info-list__item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding-block: 12px;
    border-bottom: 1px solid var(--color-border);
}
.formation-info-list__item:last-child { border-bottom: none; }
.formation-info-list__icon {
    width: 32px; height: 32px;
    border-radius: var(--radius-sm);
    background: var(--fushia-50, #fdf4ff);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.formation-info-list__icon i { color: var(--fushia-600); font-size: 16px; line-height: 1; }
.formation-info-list__label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--slate-400);
    margin-bottom: 2px;
}
.formation-info-list__value {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--slate-800);
    line-height: 1.4;
}
.formation-sidebar-card__cta {
    padding: 0 20px 20px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE RÉALISATION
   ═══════════════════════════════════════════════════════════════════════════ */

.single-realisation__hero {
    background: linear-gradient(135deg, var(--slate-900) 0%, #1e1448 100%);
    padding-block: 72px 60px;
    position: relative;
    overflow: hidden;
}
.single-realisation__hero.has-thumb {
    min-height: 480px;
    display: flex;
    align-items: flex-end;
}
.single-realisation__hero-img {
    position: absolute;
    inset: 0;
}
.single-realisation__hero-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: .25;
}
.single-realisation__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(5,5,20,.95) 0%, rgba(5,5,20,.5) 60%, rgba(5,5,20,.25) 100%);
}
.single-realisation__hero-content {
    position: relative;
    z-index: 1;
    width: 100%;
    padding-block: 20px;
}
.single-realisation__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 16px;
}
.single-realisation__title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 16px;
    max-width: 860px;
}
.single-realisation__subtitle {
    font-size: 18px;
    color: rgba(255,255,255,.72);
    max-width: 700px;
    line-height: 1.7;
    margin-bottom: 24px;
}
.single-realisation__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.formation-chip--link {
    background: rgba(162,28,175,.25);
    border-color: rgba(217,70,239,.35);
    color: #e879f9;
    text-decoration: none;
    transition: background var(--transition);
}
.formation-chip--link:hover {
    background: rgba(162,28,175,.4);
    color: #fff;
}

/* Layout body */
.single-realisation__body { padding-block: 64px; }
.single-realisation__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 324px;
    gap: 52px;
    align-items: start;
    max-width: var(--container-max);
    margin-inline: auto;
    width: 100%;
}

/* Galerie photos */
.realisation-galerie {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.realisation-galerie__item {
    display: block;
    border-radius: var(--radius-md);
    overflow: hidden;
    aspect-ratio: 3/2;
    transition: box-shadow var(--transition), transform var(--transition);
}
.realisation-galerie__item:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 32px rgba(26,30,60,.15);
}
.realisation-galerie__item img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.realisation-galerie__item:hover img { transform: scale(1.04); }

/* Tags technologies dans la sidebar */
.realisation-techs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

/* Info-cards dans la sidebar (client, catégorie, techs) */
.formation-info-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: var(--color-white);
    border-radius: var(--radius-md);
    padding: 16px;
    box-shadow: var(--shadow-card);
    border: 1px solid var(--color-border);
}
.formation-info-card__icon {
    width: 36px; height: 36px;
    border-radius: var(--radius-sm);
    background: var(--fushia-50, #fdf4ff);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.formation-info-card__icon i { color: var(--fushia-600); font-size: 17px; line-height: 1; }
.formation-info-card__label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--slate-400);
    margin-bottom: 3px;
}
.formation-info-card__value {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--slate-800);
    line-height: 1.45;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTION ARTICLES LIÉS
   ═══════════════════════════════════════════════════════════════════════════ */
.single-related { padding-block: 60px 80px; }
.single-related .section-label { display: block; margin-bottom: 8px; }
.single-related h2 { margin-bottom: 32px; font-size: clamp(1.4rem, 3vw, 1.9rem); }

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Singles
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .single-post__layout,
    .single-formation__layout,
    .single-realisation__layout {
        grid-template-columns: 1fr;
    }
    .single-post__sidebar,
    .single-formation__sidebar,
    .single-realisation__sidebar {
        position: static;
        border-left: none;
        border-top: 3px solid var(--fushia-100, #fae8ff);
        padding-left: 0;
        padding-top: 16px;
        display: grid;
        grid-template-columns: 1fr 1fr;
        flex-direction: unset;
    }
    .formation-sidebar-card { grid-column: 1 / -1; }
    .btn--full-width         { grid-column: 1 / -1; }
    .formations-cta__inner   { grid-template-columns: 1fr; }
    .formations-cta__actions { justify-content: flex-start; }
}
@media (max-width: 768px) {
    .single-post__hero  { min-height: 300px; }
    .single-post__title { font-size: 1.75rem; }
    .single-formation__title { font-size: 1.75rem; }
    .single-post__sidebar,
    .single-formation__sidebar {
        grid-template-columns: 1fr;
        border-top-color: var(--color-border);
    }
    .entry-nav { grid-template-columns: 1fr; }
    .entry-nav__link--next { grid-column: 1; }
    .related-section .posts-grid { grid-template-columns: 1fr; }
    .single-realisation__title { font-size: 1.75rem; }
    .single-realisation__sidebar {
        grid-template-columns: 1fr;
        border-top-color: var(--color-border);
    }
    .realisation-galerie { grid-template-columns: 1fr; }
    .single-related { padding-block: 40px 60px; }
}
