/**
 * NosJardinsEco Child V6 — Bandeau cookies
 * LIMITE CONFORMITÉ : suffisant sans outil tiers (GA4, Meta Pixel, etc.).
 * Avec traceurs tiers → CMP certifiée CNIL requise (Axeptio, Cookiebot…).
 */

#nje-cookie-banner {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 99990;
    background: var(--color-white, #fff);
    border-top: 3px solid var(--color-green, #34A42E);
    box-shadow: 0 -4px 24px rgba(0,0,0,0.12);
    padding: 20px var(--container-padding, 24px);
    animation: nje-slide-up 0.35s ease;
}
#nje-cookie-banner[hidden] { display: none; }
@keyframes nje-slide-up { from{transform:translateY(100%);opacity:0} to{transform:translateY(0);opacity:1} }

.nje-cookie-banner__inner { max-width: var(--container-max,1200px); margin: 0 auto; display: flex; align-items: center; gap: 32px; flex-wrap: wrap; }
.nje-cookie-banner__text { flex: 1 1 360px; }
.nje-cookie-banner__title { font-size: 0.95rem; font-weight: 600; color: var(--color-text,#2c2c2c); margin: 0 0 6px; }
.nje-cookie-banner__desc { font-size: 0.82rem; line-height: 1.55; color: var(--color-text,#2c2c2c); opacity: 0.7; margin: 0; }
.nje-cookie-banner__desc a { color: var(--color-green,#34A42E); text-decoration: underline; }
.nje-cookie-banner__actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }

.nje-cookie-btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 10px 22px; border-radius: 50px;
    font-size: 0.875rem; font-weight: 600; line-height: 1;
    border: 2px solid transparent; cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
    white-space: nowrap; font-family: var(--font-body, sans-serif);
}
.nje-cookie-btn--accept { background: var(--color-green,#34A42E); border-color: var(--color-green,#34A42E); color: #fff; }
.nje-cookie-btn--accept:hover { background: var(--color-green-deep,#1b7a17); border-color: var(--color-green-deep,#1b7a17); }
.nje-cookie-btn--refuse { background: transparent; border-color: var(--color-border,#dde5dd); color: var(--color-text,#2c2c2c); }
.nje-cookie-btn--refuse:hover { border-color: var(--color-text,#2c2c2c); background: var(--color-bg,#f5f7f5); }
.nje-cookie-btn--customize { background: transparent; border-color: transparent; color: var(--color-text,#2c2c2c); font-size: 0.8rem; opacity: 0.6; padding: 10px 12px; text-decoration: underline; text-underline-offset: 2px; }
.nje-cookie-btn--customize:hover { opacity: 1; }

#nje-cookie-prefs { position: fixed; inset: 0; z-index: 99995; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(0,0,0,0.5); animation: nje-fade-in 0.2s ease; }
#nje-cookie-prefs[hidden] { display: none; }
@keyframes nje-fade-in { from{opacity:0} to{opacity:1} }

.nje-cookie-prefs__panel { background: #fff; border-radius: 16px; box-shadow: 0 8px 40px rgba(0,0,0,0.2); max-width: 520px; width: 100%; max-height: 90vh; overflow-y: auto; padding: 32px; }
.nje-cookie-prefs__title { font-size: 1.1rem; font-weight: 700; color: var(--color-text,#2c2c2c); margin: 0 0 24px; }
.nje-cookie-prefs__category { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--color-border,#dde5dd); }
.nje-cookie-prefs__category:last-of-type { border-bottom: none; }
.nje-cookie-prefs__cat-info { flex: 1; }
.nje-cookie-prefs__cat-name { font-size: 0.9rem; font-weight: 600; color: var(--color-text,#2c2c2c); margin: 0 0 4px; }
.nje-cookie-prefs__cat-desc { font-size: 0.8rem; line-height: 1.5; color: var(--color-text,#2c2c2c); opacity: 0.65; margin: 0; }
.nje-cookie-prefs__actions { display: flex; gap: 10px; margin-top: 24px; flex-wrap: wrap; }

.nje-cookie-toggle { position: relative; flex-shrink: 0; margin-top: 2px; }
.nje-cookie-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.nje-cookie-toggle__track { display: block; width: 44px; height: 24px; background: var(--color-border,#dde5dd); border-radius: 12px; cursor: pointer; transition: background .15s ease; position: relative; }
.nje-cookie-toggle__track::after { content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; background:#fff; border-radius:50%; box-shadow:0 1px 3px rgba(0,0,0,.2); transition:transform .15s ease; }
.nje-cookie-toggle input:checked + .nje-cookie-toggle__track { background: var(--color-green,#34A42E); }
.nje-cookie-toggle input:checked + .nje-cookie-toggle__track::after { transform: translateX(20px); }
.nje-cookie-toggle input:disabled + .nje-cookie-toggle__track { opacity: .5; cursor: not-allowed; }
.nje-cookie-toggle input:focus-visible + .nje-cookie-toggle__track { outline: 3px solid rgba(52,164,46,.4); outline-offset: 2px; }

.nje-cookie-reopen { display: inline-flex; align-items: center; gap: 6px; font-size: 0.8rem; color: var(--color-text,#2c2c2c); opacity: 0.6; cursor: pointer; background: none; border: none; padding: 0; font-family: inherit; transition: opacity .15s ease; text-decoration: none; }
.nje-cookie-reopen:hover { opacity: 1; text-decoration: underline; text-underline-offset: 2px; }

@media (max-width: 640px) {
    .nje-cookie-banner__inner { flex-direction: column; align-items: stretch; }
    .nje-cookie-banner__actions { flex-direction: column; }
    .nje-cookie-btn { width: 100%; justify-content: center; }
    .nje-cookie-prefs__panel { padding: 24px; }
}
