/**
 * Naissantiel Agenda — Front single event
 *
 * Page événement premium, éditoriale, lisible et mobile-first.
 *
 * @package Naissantiel_Agenda
 * @since   0.3.5
 */

.naiss-event-single {
    background: #f5f8fc;
    color: #2f2a26;
}

.naiss-event-single * {
    box-sizing: border-box;
}

/* ==========================================================================
   HERO — plus éditorial, moins massif
   ========================================================================== */

.naiss-event-hero {
    padding: 30px 20px 24px;
    background: #f5f8fc;
}

.naiss-event-hero__inner {
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: clamp(28px, 4vw, 44px);
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(260px, 0.72fr);
    gap: clamp(26px, 4vw, 46px);
    align-items: center;
    border-radius: 34px;
    background:
        radial-gradient(circle at 5% 0%, rgba(222, 171, 151, 0.18), transparent 34%),
        linear-gradient(135deg, #fffaf7 0%, #f8eee8 100%);
    border: 1px solid rgba(151, 112, 94, 0.12);
    box-shadow: 0 18px 48px rgba(62, 43, 34, 0.055);
}

.naiss-event-kicker,
.naiss-event-section__eyebrow {
    margin: 0 0 10px;
    color: #a36f5c;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.naiss-event-title {
    margin: 0;
    max-width: 740px;
    color: #2f261f;
    font-size: clamp(2rem, 3vw, 3.05rem);
    line-height: 1.08;
    letter-spacing: -0.045em;
}

.naiss-event-lead {
    margin: 16px 0 0;
    max-width: 690px;
    color: #5b4b43;
    font-size: clamp(1rem, 1.15vw, 1.08rem);
    line-height: 1.68;
}

.naiss-event-meta-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin: 22px 0 0;
    max-width: 760px;
}

.naiss-event-meta {
    padding: 12px 13px;
    border: 1px solid rgba(151, 112, 94, 0.13);
    border-radius: 17px;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: 0 8px 20px rgba(76, 47, 34, 0.035);
}

.naiss-event-meta__label {
    display: block;
    margin-bottom: 5px;
    color: #a36f5c;
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.naiss-event-meta__value {
    color: #342a25;
    font-size: 0.9rem;
    font-weight: 750;
    line-height: 1.35;
}

.naiss-event-byline {
    margin: 18px 0 0;
    color: #6a554b;
    font-size: 0.98rem;
    font-weight: 650;
}

.naiss-event-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 22px;
}

.naiss-event-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 12px 22px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 800;
    line-height: 1.2;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.naiss-event-button:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.naiss-event-button--primary {
    background: #b97862;
    color: #ffffff;
    box-shadow: 0 12px 26px rgba(185, 120, 98, 0.22);
}

.naiss-event-button--primary:hover {
    background: #a96854;
    color: #ffffff;
}

.naiss-event-button--full {
    width: 100%;
}

/* Image hero plus chic, moins envahissante */
.naiss-event-hero__media {
    position: relative;
    max-width: 360px;
    margin-left: auto;
}

.naiss-event-hero__media::before {
    content: "";
    position: absolute;
    inset: 12px -10px -12px 10px;
    border-radius: 27px;
    background: rgba(139, 174, 125, 0.14);
    z-index: 0;
}

.naiss-event-hero__image,
.naiss-event-hero__placeholder {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    aspect-ratio: 4 / 4.15;
    object-fit: cover;
    border-radius: 27px;
    box-shadow: 0 18px 42px rgba(67, 43, 31, 0.14);
}

.naiss-event-hero__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #eadad1;
    color: #9b6f5d;
    font-weight: 800;
}

/* ==========================================================================
   BODY
   ========================================================================== */

.naiss-event-body {
    width: min(1120px, calc(100% - 40px));
    margin: 0 auto;
    padding: 34px 0 72px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 310px;
    gap: clamp(24px, 4vw, 40px);
    align-items: start;
}

.naiss-event-body__main {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* ==========================================================================
   CARTES GÉNÉRALES
   ========================================================================== */

.naiss-event-content-card,
.naiss-event-section,
.naiss-event-sticky-card {
    border: 1px solid rgba(151, 112, 94, 0.11);
    border-radius: 26px;
    background: #ffffff;
    box-shadow: 0 14px 38px rgba(62, 43, 34, 0.05);
}

.naiss-event-content-card,
.naiss-event-section {
    padding: clamp(24px, 3vw, 34px);
}

.naiss-event-content-card h2,
.naiss-event-section h2,
.naiss-event-sticky-card h2 {
    margin: 0 0 16px;
    color: #2f261f;
    font-size: clamp(1.32rem, 1.65vw, 1.68rem);
    line-height: 1.22;
    letter-spacing: -0.025em;
}

/* ==========================================================================
   À PROPOS
   ========================================================================== */

.naiss-event-rich-content {
    max-width: 760px;
    color: #4f433d;
    font-size: 0.99rem;
    line-height: 1.78;
}

.naiss-event-rich-content > *:first-child {
    margin-top: 0;
}

.naiss-event-rich-content > *:last-child {
    margin-bottom: 0;
}

.naiss-event-rich-content p {
    margin: 0 0 1em;
}

.naiss-event-rich-content h1,
.naiss-event-rich-content h2,
.naiss-event-rich-content h3 {
    color: #2f261f;
    letter-spacing: -0.025em;
}

.naiss-event-rich-content strong {
    color: #312620;
    font-weight: 800;
}

.naiss-event-rich-content ul,
.naiss-event-rich-content ol {
    padding-left: 1.2em;
}

/* ==========================================================================
   SECTIONS
   ========================================================================== */

.naiss-event-section__heading {
    margin-bottom: 20px;
}

.naiss-event-section__heading h2 {
    margin-bottom: 0;
}

/* ==========================================================================
   MINI-CARTES — version plus premium
   ========================================================================== */

.naiss-event-explore-grid {
    counter-reset: explore;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.naiss-event-explore-card {
    counter-increment: explore;
    position: relative;
    min-height: auto;
    padding: 20px 20px 20px 22px;
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(139, 174, 125, 0.10), transparent 34%),
        linear-gradient(145deg, rgba(255, 249, 245, 0.98), rgba(248, 238, 232, 0.96));
    border: 1px solid rgba(185, 120, 98, 0.13);
    overflow: hidden;
}

.naiss-event-explore-card::before {
    content: "0" counter(explore);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 24px;
    margin-bottom: 14px;
    border-radius: 999px;
    background: rgba(185, 120, 98, 0.12);
    color: #a36f5c;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.04em;
}

.naiss-event-explore-card h3 {
    margin: 0 0 8px;
    color: #332720;
    font-size: 1.03rem;
    line-height: 1.35;
    letter-spacing: -0.015em;
}

.naiss-event-explore-card p {
    margin: 0;
    color: #66554b;
    font-size: 0.94rem;
    line-height: 1.62;
}

/* ==========================================================================
   ACCOMPAGNATRICES — 2 cartes premium sur desktop
   ========================================================================== */

.naiss-event-companions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.naiss-event-companion {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-height: 100%;
    padding: 20px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top right, rgba(222, 171, 151, 0.12), transparent 38%),
        #fff9f5;
    border: 1px solid rgba(151, 112, 94, 0.12);
}

.naiss-event-companion__media {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
}

.naiss-event-companion__image,
.naiss-event-companion__placeholder {
    width: 86px;
    height: 86px;
    border-radius: 999px;
    object-fit: cover;
    box-shadow: 0 12px 28px rgba(76, 47, 34, 0.10);
}

.naiss-event-companion__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #eadad1;
    color: #b97862;
    font-size: 1.8rem;
    font-weight: 800;
}

.naiss-event-companion h3 {
    margin: 0;
    color: #312620;
    font-size: 1.14rem;
    line-height: 1.25;
}

.naiss-event-companion__role {
    margin: 5px 0 10px;
    color: #9b6f5d;
    font-size: 0.88rem;
    font-weight: 850;
}

.naiss-event-companion p:not(.naiss-event-companion__role) {
    margin: 0;
    color: #5b4b43;
    font-size: 0.93rem;
    line-height: 1.64;
}

/* ==========================================================================
   SIDEBAR INFORMATIONS PRATIQUES
   ========================================================================== */

.naiss-event-sticky-card {
    position: sticky;
    top: 105px;
    padding: 22px;
    background:
        radial-gradient(circle at top right, rgba(222, 171, 151, 0.10), transparent 36%),
        #ffffff;
}

.naiss-event-sticky-card h2 {
    margin-bottom: 18px;
    font-size: 1.24rem;
}

.naiss-event-practical-list {
    display: grid;
    gap: 12px;
    margin: 0 0 20px;
}

.naiss-event-practical-list div {
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(151, 112, 94, 0.11);
}

.naiss-event-practical-list div:last-child {
    border-bottom: none;
}

.naiss-event-practical-list dt {
    margin-bottom: 4px;
    color: #9b6f5d;
    font-size: 0.68rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.naiss-event-practical-list dd {
    margin: 0;
    color: #342a25;
    font-size: 0.94rem;
    font-weight: 650;
    line-height: 1.52;
}

.naiss-event-practical-list dd span {
    color: #6a554b;
    font-weight: 500;
}

.naiss-event-reassurance {
    margin: 14px 0 0;
    color: #6a554b;
    font-size: 0.88rem;
    line-height: 1.55;
    text-align: center;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 1080px) {
    .naiss-event-meta-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .naiss-event-hero__inner,
    .naiss-event-body {
        grid-template-columns: 1fr;
    }

    .naiss-event-hero__media {
        max-width: 440px;
        margin: 0 auto;
    }

    .naiss-event-body__aside {
        order: -1;
    }

    .naiss-event-sticky-card {
        position: static;
    }
}

@media (max-width: 760px) {
    .naiss-event-explore-grid,
    .naiss-event-companions {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .naiss-event-hero {
        padding: 20px 14px 18px;
    }

    .naiss-event-hero__inner {
        padding: 22px;
        border-radius: 26px;
    }

    .naiss-event-title {
        font-size: clamp(1.85rem, 10vw, 2.3rem);
    }

    .naiss-event-body {
        width: calc(100% - 28px);
        padding: 24px 0 48px;
    }

    .naiss-event-meta-grid {
        grid-template-columns: 1fr;
    }

    .naiss-event-content-card,
    .naiss-event-section,
    .naiss-event-sticky-card {
        border-radius: 22px;
    }

    .naiss-event-button {
        width: 100%;
    }
}
