/* ==========================================================================
 * Snazzy Enova Page — Frontend
 * Snazzy Digital Agency · editorial / porcelaine premium
 * ========================================================================== */

.eno {
    /* palette ---------------------------------------------------------- */
    --eno-header-h: 120px; /* hauteur réservée au header flottant (héros remontés dessous) */
    --eno-forest:   #5C2E3D;
    --eno-forest-2: #3E1E2A;
    --eno-forest-3: #2A141C;
    --eno-ink:      #2C2126;
    --eno-body:     #5A4E52;
    --eno-gold:     #b8975a;
    --eno-gold-2:   #cca96a;
    --eno-gold-3:   #e8d6ac;
    --eno-cream:    #f5efe3;
    --eno-cream-2:  #efe6d4;
    --eno-paper:    #fffdf8;
    --eno-line:     rgba(92, 46, 61, .12);
    --eno-line-2:   rgba(92, 46, 61, .07);
    --eno-shadow:   0 28px 70px -38px rgba(62, 30, 42, .45);
    --eno-shadow-sm:0 16px 40px -28px rgba(62, 30, 42, .42);

    /* type ------------------------------------------------------------- */
    --eno-serif: "Fraunces", "Times New Roman", serif;
    --eno-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --eno-radius: 26px;
    --eno-radius-sm: 16px;

    font-family: var(--eno-sans);
    color: var(--eno-ink);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 17px;
}

.eno *,
.eno *::before,
.eno *::after { box-sizing: border-box; }

.eno img { max-width: 100%; height: auto; display: block; }

/* layout ------------------------------------------------------------- */
.eno-wrap {
    width: 100%;
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: clamp(20px, 5vw, 40px);
}

.eno-section {
    position: relative;
    padding-block: clamp(64px, 9vw, 120px);
    background: var(--eno-paper);
    overflow: hidden;
}
.eno-section--cream { background: var(--eno-cream); }
.eno-section--dark {
    background:
        radial-gradient(120% 120% at 12% 0%, #7E4150 0%, transparent 55%),
        radial-gradient(120% 130% at 100% 100%, #3E1E2A 0%, transparent 60%),
        linear-gradient(160deg, var(--eno-forest) 0%, var(--eno-forest-2) 100%);
    color: #eef3ef;
}
.eno-section--dark .eno-h2,
.eno-section--dark .eno-h3 { color: #fff; }
.eno-section--dark .eno-p,
.eno-section--dark .eno-lead { color: rgba(238, 243, 239, .82); }

/* atmosphere (halos + dot grid) -------------------------------------- */
.eno-atmos {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}
.eno-atmos + * ,
.eno-section--dark > .eno-wrap { position: relative; z-index: 1; }
.eno-halo {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    opacity: .5;
}
.eno-halo--1 {
    width: 460px; height: 460px;
    top: -160px; right: -120px;
    background: radial-gradient(circle, rgba(202,164,104,.55), transparent 70%);
}
.eno-halo--2 {
    width: 520px; height: 520px;
    bottom: -220px; left: -160px;
    background: radial-gradient(circle, rgba(92, 46, 61,.45), transparent 70%);
}
.eno-section--dark .eno-halo--1 { background: radial-gradient(circle, rgba(202,164,104,.4), transparent 70%); }
.eno-section--dark .eno-halo--2 { background: radial-gradient(circle, rgba(120,190,150,.22), transparent 70%); }
.eno-dots {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(currentColor 1px, transparent 1.4px);
    background-size: 26px 26px;
    color: rgba(92, 46, 61,.06);
    -webkit-mask-image: radial-gradient(70% 60% at 50% 40%, #000 0%, transparent 75%);
            mask-image: radial-gradient(70% 60% at 50% 40%, #000 0%, transparent 75%);
}
.eno-section--dark .eno-dots { color: rgba(255,255,255,.06); }

/* typography --------------------------------------------------------- */
.eno-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-size: 12.5px;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--eno-gold);
    margin-bottom: 18px;
}
.eno-section--dark .eno-eyebrow { color: var(--eno-gold-3); }
.eno-eyebrow-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 0 4px rgba(180,138,78,.18);
}

.eno-h2 {
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: clamp(28px, 4.2vw, 46px);
    line-height: 1.08;
    letter-spacing: -.01em;
    color: var(--eno-forest);
    margin: 0 0 18px;
}
.eno-h3 {
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: clamp(19px, 2vw, 23px);
    line-height: 1.2;
    color: var(--eno-forest);
    margin: 0 0 10px;
}
.eno-p {
    font-size: 16px;
    color: var(--eno-body);
    margin: 0 0 14px;
}
.eno-p:last-child { margin-bottom: 0; }
.eno-lead {
    font-size: clamp(17px, 1.6vw, 19.5px);
    line-height: 1.62;
    color: var(--eno-body);
    margin: 0 0 22px;
}
.eno-lead--wide { max-width: 720px; }
.eno-head .eno-lead--wide,
.eno-head--center .eno-lead--wide { margin-inline: 0; }
.eno-head--center .eno-lead--wide { margin-inline: auto; }

.eno-hl {
    color: var(--eno-gold);
    font-style: italic;
    position: relative;
    white-space: nowrap;
}
.eno-section--dark .eno-hl { color: var(--eno-gold-3); }

/* heads -------------------------------------------------------------- */
.eno-head { max-width: 760px; margin-bottom: clamp(36px, 5vw, 56px); }
.eno-head--center { margin-inline: auto; text-align: center; }
.eno-head--center .eno-eyebrow { justify-content: center; }
.eno-head-cta { margin-top: clamp(34px, 5vw, 52px); text-align: center; }

/* buttons ------------------------------------------------------------ */
.eno-btn {
    --b: var(--eno-forest);
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 14px 24px;
    border-radius: 100px;
    font-family: var(--eno-sans);
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    line-height: 1;
    cursor: pointer;
    transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.eno-btn svg { width: 17px; height: 17px; transition: transform .25s ease; }
.eno-btn:hover svg { transform: translateX(4px); }

/* ====================================================================
   BOUTONS — style + VERROUILLAGE COULEUR. Le texte des CTA est forcé dans
   TOUS les états (normal/hover/focus/visited) et sur le <span>/<svg>, pour
   battre la couleur de lien (bleue) du thème/Elementor, même très spécifique.
   ==================================================================== */
/* -- Styles de fond / bordure / ombre (le thème ne touche pas au background) -- */
.eno-btn--primary { background: var(--eno-forest); box-shadow: 0 16px 34px -18px rgba(62, 30, 42,.7); }
.eno-btn--primary:hover { background: var(--eno-forest-2); transform: translateY(-2px); }

.eno-btn--ghost { background: transparent; border: 1.5px solid rgba(92, 46, 61,.28); }
.eno-btn--ghost:hover { border-color: var(--eno-forest); background: rgba(92, 46, 61,.05); transform: translateY(-2px); }

.eno-btn--light { background: var(--eno-gold); box-shadow: 0 16px 34px -18px rgba(180,138,78,.7); }
.eno-btn--light:hover { background: var(--eno-gold-2); transform: translateY(-2px); }

/* Fond vert foncé : primary -> or · ghost -> contour blanc */
.eno-hero .eno-btn--primary, .eno-section--dark .eno-btn--primary, .eno-band--dark .eno-btn--primary {
    background: var(--eno-gold); box-shadow: 0 16px 34px -18px rgba(184,151,90,.7);
}
.eno-hero .eno-btn--primary:hover, .eno-section--dark .eno-btn--primary:hover, .eno-band--dark .eno-btn--primary:hover { background: var(--eno-gold-2); }
.eno-hero .eno-btn--ghost, .eno-section--dark .eno-btn--ghost, .eno-band--dark .eno-btn--ghost { border-color: rgba(255,255,255,.45); }
.eno-hero .eno-btn--ghost:hover, .eno-section--dark .eno-btn--ghost:hover, .eno-band--dark .eno-btn--ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; }

/* -- Couleur du texte FORCÉE : <a> + tous les descendants (span, svg), tous états -- */
.eno a.eno-btn { text-decoration: none !important; }

/* Fond clair (défaut) */
.eno a.eno-btn--primary, .eno a.eno-btn--primary * { color: #ffffff !important; }
.eno a.eno-btn--ghost,   .eno a.eno-btn--ghost *   { color: var(--eno-forest) !important; }
.eno a.eno-btn--light,   .eno a.eno-btn--light *   { color: #1a160c !important; }

/* Fond vert foncé (héro, sections & bandeaux sombres) */
.eno .eno-hero a.eno-btn--primary,        .eno .eno-hero a.eno-btn--primary *,
.eno .eno-section--dark a.eno-btn--primary,.eno .eno-section--dark a.eno-btn--primary *,
.eno .eno-band--dark a.eno-btn--primary,   .eno .eno-band--dark a.eno-btn--primary *   { color: #1a160c !important; }

.eno .eno-hero a.eno-btn--ghost,          .eno .eno-hero a.eno-btn--ghost *,
.eno .eno-section--dark a.eno-btn--ghost,  .eno .eno-section--dark a.eno-btn--ghost *,
.eno .eno-band--dark a.eno-btn--ghost,     .eno .eno-band--dark a.eno-btn--ghost *     { color: #ffffff !important; }

/* La flèche SVG suit toujours la couleur verrouillée du libellé */
.eno a.eno-btn svg path { stroke: currentColor !important; }

/* ===================== HERO ========================================== */
.eno-hero {
    position: relative;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    /* Remonte le héro sous le header flottant : le vert part du tout en haut,
       le contenu reste à sa place grâce au padding-top compensé. */
    margin-top: calc(-1 * var(--eno-header-h, 120px));
    padding-top: calc(var(--eno-header-h, 120px) + clamp(40px, 7vw, 80px));
    padding-bottom: clamp(72px, 11vw, 130px);
    background:
        radial-gradient(110% 120% at 8% -10%, #7E4150 0%, transparent 55%),
        radial-gradient(120% 130% at 105% 110%, #2A141C 0%, transparent 58%),
        linear-gradient(155deg, var(--eno-forest) 0%, var(--eno-forest-2) 60%, var(--eno-forest-3) 100%);
    color: #f2f6f2;
    overflow: hidden;
}
.eno-hero--compact { padding-top: calc(var(--eno-header-h, 120px) + clamp(30px, 5vw, 56px)); padding-bottom: clamp(58px, 8vw, 92px); }
.eno-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: clamp(36px, 5vw, 70px);
    align-items: center;
}
.eno-hero--compact .eno-hero-grid { grid-template-columns: 1fr; max-width: 880px; text-align: center; }
.eno-hero--compact .eno-hero-cta { justify-content: center; }
.eno-hero--compact .eno-eyebrow { justify-content: center; }

.eno-hero-copy .eno-eyebrow { color: var(--eno-gold-3); }
.eno-hero-title {
    font-family: var(--eno-serif);
    font-weight: 400;
    font-size: clamp(36px, 6vw, 68px);
    line-height: 1.04;
    letter-spacing: -.015em;
    color: #fff;
    margin: 0 0 22px;
}
.eno-hero-title .eno-hl { color: var(--eno-gold-3); }
.eno-hero-sub {
    font-size: clamp(16px, 1.8vw, 19px);
    line-height: 1.6;
    color: rgba(238,243,239,.82);
    max-width: 540px;
    margin: 0 0 30px;
}
.eno-hero--compact .eno-hero-sub { margin-inline: auto; }
.eno-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; }
.eno-hero--compact .eno-hero-cta .eno-btn--primary { background: var(--eno-gold); color: #1a160c; }
.eno-hero--compact .eno-hero-cta .eno-btn--primary:hover { background: var(--eno-gold-2); }

.eno-hero-media { position: relative; }
.eno-hero-frame {
    position: relative;
    border-radius: var(--eno-radius);
    overflow: hidden;
    aspect-ratio: 4 / 4.4;
    box-shadow: 0 50px 90px -40px rgba(0,0,0,.7);
    border: 1px solid rgba(255,255,255,.1);
}
.eno-hero-frame::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(10,31,23,.35) 100%);
}
.eno-hero-frame img { width: 100%; height: 100%; object-fit: cover; }
.eno-hero-badge {
    position: absolute;
    left: 18px; bottom: 18px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 100px;
    background: rgba(255,255,255,.14);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255,255,255,.22);
    font-size: 13px;
    font-weight: 600;
    color: #fff;
}
.eno-hero-badge i {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--eno-gold-2);
    box-shadow: 0 0 0 4px rgba(202,164,104,.3);
}

/* ===================== SPLIT (image + copy) ========================= */
.eno-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(34px, 5vw, 72px);
    align-items: center;
}
.eno-split-copy .eno-btn { margin-top: 8px; }
.eno-split-media { position: relative; }

/* thumb / placeholder ----------------------------------------------- */
.eno-thumb {
    position: relative;
    border-radius: var(--eno-radius);
    overflow: hidden;
    background: linear-gradient(150deg, var(--eno-cream-2), #e3d8bf);
    box-shadow: var(--eno-shadow);
}
.eno-thumb img { width: 100%; height: 100%; object-fit: cover; }
.eno-r-43 { aspect-ratio: 4 / 3; }
.eno-r-45 { aspect-ratio: 4 / 5; }
.eno-r-11 { aspect-ratio: 1 / 1; }
.eno-thumb-ph {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    background:
        radial-gradient(60% 60% at 50% 40%, rgba(255,255,255,.55), transparent 70%),
        linear-gradient(150deg, var(--eno-cream-2), #ddd0b3);
}
.eno-thumb-ph svg { width: 38%; max-width: 110px; height: auto; color: var(--eno-gold); opacity: .8; }

/* stat chip ---------------------------------------------------------- */
.eno-stat-chip {
    position: absolute;
    right: -14px; bottom: -18px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 16px 22px;
    border-radius: var(--eno-radius-sm);
    background: var(--eno-forest);
    color: #fff;
    box-shadow: var(--eno-shadow);
}
.eno-stat-chip strong {
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: 26px;
    line-height: 1;
    color: var(--eno-gold-3);
}
.eno-stat-chip span { font-size: 12.5px; color: rgba(255,255,255,.8); max-width: 160px; }

/* ===================== GRIDS ======================================== */
.eno-grid { display: grid; gap: clamp(18px, 2.4vw, 28px); }
.eno-grid-2 { grid-template-columns: repeat(2, 1fr); }
.eno-grid-3 { grid-template-columns: repeat(3, 1fr); }
.eno-grid-4 { grid-template-columns: repeat(4, 1fr); }
.eno-grid-5 { grid-template-columns: repeat(5, 1fr); }

/* cards -------------------------------------------------------------- */
.eno-card {
    position: relative;
    padding: clamp(26px, 3vw, 36px);
    border-radius: var(--eno-radius);
    background: var(--eno-paper);
    border: 1px solid var(--eno-line);
    box-shadow: var(--eno-shadow-sm);
    transition: transform .3s ease, box-shadow .3s ease;
}
.eno-section--cream .eno-card { background: #fff; }
.eno-card:hover { transform: translateY(-5px); box-shadow: var(--eno-shadow); }
.eno-card-ico {
    display: grid;
    place-items: center;
    width: 56px; height: 56px;
    border-radius: 16px;
    margin-bottom: 18px;
    background: linear-gradient(150deg, rgba(180,138,78,.18), rgba(180,138,78,.06));
    color: var(--eno-gold);
}
.eno-card-ico svg { width: 28px; height: 28px; }
.eno-card--feature { padding-block: clamp(30px, 3.4vw, 42px); }

.eno-card--doc { display: flex; flex-direction: column; }
.eno-doc-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    font-size: 14.5px;
    font-weight: 600;
    color: var(--eno-forest);
    text-decoration: none;
    transition: gap .2s ease, color .2s ease;
}
.eno-doc-link svg { width: 17px; height: 17px; color: var(--eno-gold); }
.eno-doc-link:hover { gap: 12px; color: var(--eno-gold); }

/* ===================== GAMMES (home icon grid) ===================== */
.eno-gammes-grid { gap: 16px; }
.eno-gamme {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 20px 22px;
    border-radius: var(--eno-radius-sm);
    background: #fff;
    border: 1px solid var(--eno-line);
    text-decoration: none;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.eno-gamme:hover { transform: translateY(-3px); box-shadow: var(--eno-shadow-sm); border-color: rgba(180,138,78,.4); }
.eno-gamme-ico {
    display: grid; place-items: center;
    width: 44px; height: 44px; flex: 0 0 auto;
    border-radius: 12px;
    background: linear-gradient(150deg, rgba(180,138,78,.18), rgba(180,138,78,.05));
    color: var(--eno-gold);
}
.eno-gamme-ico svg { width: 23px; height: 23px; }
.eno-gamme-name {
    flex: 1;
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: 17px;
    color: var(--eno-forest);
    margin: 0;
}
.eno-gamme-arrow { color: var(--eno-gold); display: grid; place-items: center; transition: transform .25s ease; }
.eno-gamme-arrow svg { width: 18px; height: 18px; }
.eno-gamme:hover .eno-gamme-arrow { transform: translateX(4px); }

/* ===================== COLLECTIONS strip (home) ==================== */
.eno-coll-strip {
    display: flex;
    gap: 22px;
    overflow-x: auto;
    padding: 8px clamp(20px, 5vw, 40px) 28px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.eno-coll-strip::-webkit-scrollbar { height: 6px; }
.eno-coll-strip::-webkit-scrollbar-thumb { background: rgba(92, 46, 61,.2); border-radius: 100px; }
.eno-coll-card {
    flex: 0 0 clamp(220px, 26vw, 280px);
    scroll-snap-align: start;
    text-decoration: none;
    transition: transform .3s ease;
}
.eno-coll-card:hover { transform: translateY(-6px); }
.eno-coll-card .eno-thumb { margin-bottom: 14px; }
.eno-coll-kicker {
    display: block;
    font-size: 11.5px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--eno-gold);
    margin-bottom: 4px;
}
.eno-coll-name {
    display: block;
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: 21px;
    color: var(--eno-forest);
}

/* ===================== MARCHÉS (home dark grid) ==================== */
.eno-marche-grid { gap: 16px; }
.eno-marche {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 28px 16px;
    text-align: center;
    border-radius: var(--eno-radius-sm);
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.eno-marche:hover { transform: translateY(-4px); background: rgba(255,255,255,.09); border-color: rgba(202,164,104,.4); }
.eno-marche-ico {
    display: grid; place-items: center;
    width: 52px; height: 52px;
    border-radius: 14px;
    background: rgba(202,164,104,.16);
    color: var(--eno-gold-3);
}
.eno-marche-ico svg { width: 26px; height: 26px; }
.eno-marche-name {
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: 16px;
    color: #fff;
    margin: 0;
}

/* ===================== BAND (CTA) ================================== */
.eno-band {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: clamp(24px, 4vw, 48px);
    flex-wrap: wrap;
    padding: clamp(32px, 4.5vw, 56px);
    border-radius: var(--eno-radius);
    background: linear-gradient(150deg, #fff, var(--eno-cream));
    border: 1px solid var(--eno-line);
    box-shadow: var(--eno-shadow-sm);
}
.eno-band--dark {
    background:
        radial-gradient(100% 140% at 0% 0%, #7E4150 0%, transparent 60%),
        linear-gradient(150deg, var(--eno-forest) 0%, var(--eno-forest-2) 100%);
    border-color: rgba(255,255,255,.1);
    color: #fff;
    box-shadow: var(--eno-shadow);
}
.eno-band--dark .eno-h2 { color: #fff; }
.eno-band--dark .eno-p { color: rgba(255,255,255,.82); }
.eno-band-copy { flex: 1 1 360px; }
.eno-band-copy .eno-h2 { margin-bottom: 10px; }
.eno-band-copy .eno-p { margin-bottom: 0; }
.eno-band-actions { display: flex; flex-wrap: wrap; gap: 14px; }

/* ===================== PILLARS (engagement) ======================= */
.eno-pillar {
    padding: clamp(24px, 3vw, 34px);
    border-radius: var(--eno-radius);
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform .3s ease, background .3s ease;
}
.eno-pillar:hover { transform: translateY(-5px); background: rgba(255,255,255,.09); }
.eno-pillar-ico {
    display: grid; place-items: center;
    width: 54px; height: 54px;
    border-radius: 15px;
    margin-bottom: 18px;
    background: rgba(202,164,104,.16);
    color: var(--eno-gold-3);
}
.eno-pillar-ico svg { width: 27px; height: 27px; }

/* ===================== PROSE (inner intro blocks) ================= */
.eno-prose { max-width: 760px; }
.eno-prose--center { margin-inline: auto; text-align: center; }
.eno-prose--center .eno-eyebrow { justify-content: center; }

/* ===================== PRODUITS / GAMMES page grid =============== */
.eno-prod {
    display: flex;
    flex-direction: column;
    border-radius: var(--eno-radius);
    overflow: hidden;
    background: var(--eno-paper);
    border: 1px solid var(--eno-line);
    box-shadow: var(--eno-shadow-sm);
    text-decoration: none;
    transition: transform .3s ease, box-shadow .3s ease;
}
.eno-section--cream .eno-prod { background: #fff; }
.eno-prod:hover { transform: translateY(-6px); box-shadow: var(--eno-shadow); }
.eno-prod .eno-thumb { border-radius: 0; box-shadow: none; }
.eno-prod-body { padding: clamp(22px, 2.6vw, 30px); position: relative; }
.eno-prod-ico {
    position: absolute;
    top: -26px; left: clamp(22px, 2.6vw, 30px);
    display: grid; place-items: center;
    width: 52px; height: 52px;
    border-radius: 14px;
    background: var(--eno-forest);
    color: var(--eno-gold-3);
    box-shadow: var(--eno-shadow-sm);
}
.eno-prod-ico svg { width: 26px; height: 26px; }
.eno-prod-body .eno-h3 { margin-top: 14px; }
.eno-prod-more {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-top: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--eno-gold);
}
.eno-prod-more svg { width: 16px; height: 16px; transition: transform .25s ease; }
.eno-prod:hover .eno-prod-more svg { transform: translateX(4px); }

/* ===================== COLLECTIONS page grid ===================== */
.eno-collec {
    display: flex;
    flex-direction: column;
    border-radius: var(--eno-radius);
    overflow: hidden;
    background: var(--eno-paper);
    border: 1px solid var(--eno-line);
    box-shadow: var(--eno-shadow-sm);
    text-decoration: none;
    transition: transform .3s ease, box-shadow .3s ease;
}
.eno-section--cream .eno-collec { background: #fff; }
.eno-collec:hover { transform: translateY(-6px); box-shadow: var(--eno-shadow); }
.eno-collec .eno-thumb { border-radius: 0; box-shadow: none; }
.eno-collec-body { padding: clamp(22px, 2.6vw, 30px); }
.eno-collec-kicker {
    display: block;
    font-size: 11.5px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--eno-gold);
    margin-bottom: 6px;
}
.eno-collec-name {
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: clamp(20px, 2.2vw, 25px);
    color: var(--eno-forest);
    margin: 0 0 4px;
}
.eno-collec-tag {
    font-size: 13.5px;
    font-style: italic;
    color: var(--eno-gold);
    margin: 0 0 12px;
}

/* ===================== MARCHÉS page list ========================= */
.eno-marche-list {
    display: flex;
    flex-direction: column;
    border-radius: var(--eno-radius);
    overflow: hidden;
    border: 1px solid var(--eno-line);
    background: var(--eno-paper);
    box-shadow: var(--eno-shadow-sm);
}
.eno-marche-row {
    display: flex;
    align-items: center;
    gap: clamp(16px, 2.4vw, 28px);
    padding: clamp(22px, 2.8vw, 32px);
    text-decoration: none;
    border-top: 1px solid var(--eno-line-2);
    transition: background .25s ease;
}
.eno-marche-row:first-child { border-top: 0; }
.eno-marche-row:hover { background: var(--eno-cream); }
.eno-marche-row-no {
    font-family: var(--eno-serif);
    font-size: clamp(22px, 3vw, 32px);
    font-weight: 500;
    color: var(--eno-gold);
    flex: 0 0 auto;
    width: 48px;
}
.eno-marche-row-ico {
    display: grid; place-items: center;
    width: 56px; height: 56px; flex: 0 0 auto;
    border-radius: 15px;
    background: linear-gradient(150deg, rgba(180,138,78,.18), rgba(180,138,78,.05));
    color: var(--eno-gold);
}
.eno-marche-row-ico svg { width: 28px; height: 28px; }
.eno-marche-row-copy { flex: 1; min-width: 0; }
.eno-marche-row-name {
    display: block;
    font-family: var(--eno-serif);
    font-weight: 500;
    font-size: clamp(19px, 2vw, 23px);
    color: var(--eno-forest);
    margin-bottom: 4px;
}
.eno-marche-row-desc { display: block; font-size: 15px; color: var(--eno-body); }
.eno-marche-row-arrow {
    display: grid; place-items: center;
    flex: 0 0 auto;
    color: var(--eno-gold);
    transition: transform .25s ease;
}
.eno-marche-row-arrow svg { width: 22px; height: 22px; }
.eno-marche-row:hover .eno-marche-row-arrow { transform: translateX(6px); }

/* ===================== REVEAL ON SCROLL ========================== */
[data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1);
    transition-delay: calc(var(--d, 0) * 90ms);
    will-change: opacity, transform;
}
[data-reveal].is-in { opacity: 1; transform: none; }

/* ===================== RESPONSIVE =============================== */
@media (max-width: 1100px) {
    .eno-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .eno-grid-5 { grid-template-columns: repeat(3, 1fr); }
    .eno-hero-grid { grid-template-columns: 1fr; }
    .eno-hero-media { max-width: 460px; }
    .eno-hero-frame { aspect-ratio: 16 / 11; }
}
@media (max-width: 900px) {
    .eno-split { grid-template-columns: 1fr; }
    .eno-split-media { order: -1; }
    .eno-grid-3 { grid-template-columns: repeat(2, 1fr); }
    .eno-stat-chip { right: 12px; bottom: 12px; }
    .eno-band { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
    .eno { font-size: 16px; }
    .eno-grid-2,
    .eno-grid-3,
    .eno-grid-4,
    .eno-grid-5 { grid-template-columns: 1fr; }
    .eno-hero-cta,
    .eno-band-actions { width: 100%; }
    .eno-hero-cta .eno-btn,
    .eno-band-actions .eno-btn { flex: 1; justify-content: center; }
    .eno-marche-row { flex-wrap: wrap; }
    .eno-marche-row-no { width: auto; }
    .eno-marche-row-arrow { display: none; }
    .eno-stat-chip { position: static; margin-top: 14px; display: inline-flex; }
}

/* ===================== MOTION SAFETY ============================ */
@media (prefers-reduced-motion: reduce) {
    [data-reveal] { opacity: 1; transform: none; transition: none; }
    .eno-btn, .eno-card, .eno-prod, .eno-collec, .eno-gamme,
    .eno-marche, .eno-pillar, .eno-coll-card { transition: none; }
    * { scroll-behavior: auto !important; }
}

/* ============================================================================
 * PAGE CONTACT (ajout) — coordonnées société, carte, emplacement formulaire
 * ========================================================================== */
.eno-contact-grid{
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 28px;
    align-items: stretch;
    margin-top: 42px;
}
.eno-contact-grid--solo{
    grid-template-columns: 1fr;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}

/* Carte coordonnées (panneau forêt) */
.eno-contact-card{
    position: relative;
    overflow: hidden;
    background: linear-gradient(150deg, var(--eno-forest) 0%, var(--eno-forest-2) 100%);
    color: #fff;
    border-radius: var(--eno-radius);
    padding: 40px 36px;
    box-shadow: var(--eno-shadow-sm);
}
.eno-contact-card::before{
    content: "";
    position: absolute; inset: 0;
    background-image: radial-gradient(circle at 1.5px 1.5px, rgba(255,255,255,.05) 1.5px, transparent 0);
    background-size: 22px 22px;
    pointer-events: none;
}
.eno-contact-brand{
    position: relative;
    display: flex; flex-direction: column; gap: 3px;
    padding-bottom: 22px; margin-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,.14);
}
.eno-contact-brand-name{ font-family: var(--eno-serif); font-size: 26px; font-weight: 600; color: #fff; }
.eno-contact-brand-base{ font-size: 12.5px; letter-spacing: .4px; color: var(--eno-gold-2); }

.eno-contact-list{ position: relative; list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 20px; }
.eno-contact-list li{ display: flex; gap: 15px; align-items: flex-start; }
.eno-contact-ico{
    flex-shrink: 0; width: 44px; height: 44px; border-radius: 13px;
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
    display: flex; align-items: center; justify-content: center; color: var(--eno-gold-2);
}
.eno-contact-ico svg{ width: 21px; height: 21px; }
.eno-contact-txt{ display: flex; flex-direction: column; gap: 3px; font-size: 14px; line-height: 1.55; color: rgba(255,255,255,.82); }
.eno-contact-txt strong{ color: #fff; font-weight: 700; font-size: 13px; letter-spacing: .3px; text-transform: uppercase; }
.eno-contact-txt a{ color: rgba(255,255,255,.92); text-decoration: none; border-bottom: 1px solid rgba(184,151,90,.5); width: fit-content; transition: color .2s, border-color .2s; }
.eno-contact-txt a:hover{ color: var(--eno-gold-2); border-color: var(--eno-gold-2); }

.eno-contact-map{ position: relative; margin-top: 26px; border-radius: var(--eno-radius-sm); overflow: hidden; border: 1px solid rgba(255,255,255,.14); line-height: 0; }
.eno-contact-map iframe{ width: 100%; height: 210px; border: 0; filter: grayscale(.2) contrast(.95); }

/* Bloc formulaire (rempli par un autre plugin de formulaire) */
.eno-contact-form{
    background: var(--eno-paper);
    border: 1px solid var(--eno-line);
    border-radius: var(--eno-radius);
    padding: 40px 36px;
    box-shadow: var(--eno-shadow-sm);
    display: flex; flex-direction: column; justify-content: center;
}
.eno-contact-form-title{ font-family: var(--eno-serif); font-size: 24px; font-weight: 600; color: var(--eno-forest); margin: 0 0 22px; }

/* Habillage Enova de n'importe quel formulaire injecté (CF7, Forminator, Gravity…) */
.eno-contact-form-slot input[type=text],
.eno-contact-form-slot input[type=email],
.eno-contact-form-slot input[type=tel],
.eno-contact-form-slot input[type=url],
.eno-contact-form-slot input[type=number],
.eno-contact-form-slot textarea,
.eno-contact-form-slot select{
    width: 100%; padding: 13px 15px; margin: 4px 0; box-sizing: border-box;
    border: 1px solid var(--eno-line); border-radius: var(--eno-radius-sm);
    background: #fff; color: var(--eno-ink);
    font-family: var(--eno-sans); font-size: 15px;
    transition: border-color .2s, box-shadow .2s;
}
.eno-contact-form-slot textarea{ resize: vertical; min-height: 130px; }
.eno-contact-form-slot input:focus,
.eno-contact-form-slot textarea:focus,
.eno-contact-form-slot select:focus{
    outline: none; border-color: var(--eno-forest); box-shadow: 0 0 0 3px rgba(92, 46, 61,.08);
}
.eno-contact-form-slot label{ font-size: 14px; font-weight: 600; color: var(--eno-forest); }
.eno-contact-form-slot input[type=submit],
.eno-contact-form-slot button[type=submit]{
    display: inline-flex; align-items: center; gap: 9px; margin-top: 10px; width: auto;
    padding: 15px 32px; border: none; border-radius: 999px; cursor: pointer;
    background: var(--eno-forest); color: #fff;
    font-family: var(--eno-sans); font-size: 15px; font-weight: 700; letter-spacing: .3px;
    box-shadow: 0 14px 30px -16px rgba(62, 30, 42,.7); transition: background .2s, transform .12s;
}
.eno-contact-form-slot input[type=submit]:hover,
.eno-contact-form-slot button[type=submit]:hover{ background: var(--eno-gold); transform: translateY(-2px); }

@media (max-width: 880px){
    .eno-contact-grid{ grid-template-columns: 1fr; }
    .eno-contact-card, .eno-contact-form{ padding: 30px 24px; }
}
