/* --- UTILITAIRES --- */
html,body{overflow-x:hidden;width:100%}
*,*::before,*::after{box-sizing:border-box}
.container{width:100%;max-width:1150px;margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}
.glass-ios{background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.07)}
.glass-panel{background-color:rgba(255,255,255,.6);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow-ios)}
[data-theme="dark"] .glass-panel{background-color:rgba(15,23,42,.4);border-color:rgba(255,255,255,.05)}
.bg-alt{background-color:var(--hover-bg)}
.text-primary{color:var(--cpw-primary)!important}

/* --- HERO --- */
.legal-hero{position:relative;padding-top:10rem;padding-bottom:6rem;overflow:hidden;text-align:center}
.legal-hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:150vw;height:150vw;max-width:700px;max-height:700px;background:radial-gradient(circle,rgba(0,123,255,.1) 0%,rgba(0,123,255,0) 70%);filter:blur(90px);z-index:0;pointer-events:none}
.legal-hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--glass-border) 1px,transparent 1px),linear-gradient(90deg,var(--glass-border) 1px,transparent 1px);background-size:60px 60px;opacity:.4;z-index:0;mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 40%,transparent 100%);pointer-events:none}
.legal-hero .container{position:relative;z-index:1}

/* Badge hero avec reflet */
.hero-badge{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem 1.25rem;border-radius:9999px;background-color:var(--glass-bg);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border:1px solid var(--glass-border);margin-bottom:2rem;box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.07)}
.badge-dot-wrapper{position:relative;display:flex;width:.5rem;height:.5rem}
.badge-dot{width:100%;height:100%;border-radius:50%;background-color:var(--cpw-primary);box-shadow:0 0 10px var(--cpw-primary),0 0 20px rgba(0,123,255,.4)}
.badge-text{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--cpw-text)}
.hero-title{font-size:2.25rem;font-weight:800;line-height:1.12;letter-spacing:-.03em;margin-bottom:1.5rem;color:var(--cpw-text)}
.text-gradient{background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);-webkit-background-clip:text;color:transparent;display:inline-block}
.hero-subtitle{font-size:1.0625rem;color:var(--cpw-text);opacity:.75;line-height:1.8;max-width:48rem;margin:0 auto 3rem;font-weight:400}
.date-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:9999px;color:var(--cpw-primary);font-size:.875rem;font-weight:700}

/* --- TRUST SECTION --- */
.trust-section{padding:5rem 0;position:relative}
.trust-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}

/* Trust cards avec reflet supérieur */
.trust-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.25rem;padding:2.5rem 1.5rem;border-radius:2rem;position:relative;overflow:hidden}
.trust-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}
.trust-card:hover{background-color:var(--glass-highlight);box-shadow:0 16px 40px -8px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.08)}

/* Icônes trust avec reflet */
.trust-icon{width:3.5rem;height:3.5rem;border-radius:1.125rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;background-color:rgba(0,123,255,.1);color:var(--cpw-primary);border:1px solid rgba(0,123,255,.15);box-shadow:inset 0 1px 0 rgba(255,255,255,.12);position:relative;overflow:hidden}
.trust-icon::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 60%);pointer-events:none}
.trust-card:hover .trust-icon{background:linear-gradient(145deg,var(--cpw-primary),#2563eb);color:#fff;border-color:transparent;box-shadow:0 6px 16px -4px rgba(0,123,255,.4),inset 0 1px 0 rgba(255,255,255,.2)}
.trust-title{font-weight:800;font-size:1.0625rem;color:var(--cpw-text);margin-bottom:.375rem;letter-spacing:-.01em}
.trust-desc{font-size:.875rem;color:var(--cpw-text);opacity:.65;line-height:1.7;margin:0}

/* --- CONTENU LEGAL --- */
.legal-content-section{padding:6rem 0}
.legal-layout{display:grid;grid-template-columns:1fr;gap:3rem}
.legal-sidebar{display:none;height:100%}
.sidebar-sticky{position:sticky;top:8rem}
.sidebar-title{font-weight:800;color:var(--cpw-text);margin-bottom:1.5rem;padding-left:1rem;text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;opacity:.5}

/* Sidebar nav avec reflet */
.sidebar-nav{padding:1.5rem 1rem;border-radius:2rem;display:flex;flex-direction:column;gap:.375rem;position:relative;overflow:hidden}
.sidebar-nav::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}
.legal-nav-link{display:block;padding:.75rem 1.25rem;border-radius:1rem;font-size:.9375rem;font-weight:700;color:var(--cpw-text);opacity:.65;text-decoration:none}
.legal-nav-link:hover{background-color:var(--hover-bg);opacity:1;color:var(--cpw-primary)}
.legal-nav-link.active{color:var(--cpw-primary);background-color:rgba(0,123,255,.08);opacity:1;border-left:3px solid var(--cpw-primary);padding-left:1rem}
.legal-nav-link:focus-visible{outline:2px solid var(--cpw-primary);outline-offset:2px}

/* Articles container avec reflet supérieur */
.legal-articles{padding:2rem 1.5rem;border-radius:2rem;display:flex;flex-direction:column;gap:4rem;position:relative;overflow:hidden}
.legal-articles::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}
.legal-block{scroll-margin-top:100px}
.article-title{font-size:1.4375rem;font-weight:800;color:var(--cpw-text);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:.75rem;letter-spacing:-.02em;line-height:1.3}
.article-text{font-size:1rem;color:var(--cpw-text);opacity:.78;line-height:1.8;font-weight:400}
.article-text-group{display:flex;flex-direction:column;gap:1.25rem;font-size:1rem;color:var(--cpw-text);opacity:.78;line-height:1.8;font-weight:400}
.article-text-group strong{color:var(--cpw-text);font-weight:800;opacity:1}
.mb-medium{margin-bottom:2rem}

/* Info box avec séparateurs */
.info-box{background-color:var(--hover-bg);padding:2rem 1.5rem;border-radius:1.5rem;border:1px solid var(--glass-border);display:flex;flex-direction:column;gap:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.info-row{display:flex;flex-direction:column;gap:.5rem;font-size:.9375rem;padding:1rem 0}
.info-row:not(:last-child){border-bottom:1px solid var(--glass-border)}
.info-row:first-child{padding-top:0}
.info-row:last-child{padding-bottom:0}
.info-label{display:flex;align-items:center;gap:.75rem;font-weight:800;color:var(--cpw-text);flex-shrink:0}
.info-icon{width:1.5rem;display:flex;justify-content:center;color:var(--cpw-primary);opacity:.8}
.info-value{color:var(--cpw-text);opacity:.72;word-break:break-word;font-weight:500;line-height:1.6}
.link-primary{color:var(--cpw-primary);font-weight:700;text-decoration:none}
.link-primary:hover{text-decoration:underline;text-underline-offset:2px}

/* Warning box */
.warning-box{display:flex;gap:1.25rem;padding:1.5rem;border-radius:1.5rem;border-left:3px solid #ef4444;color:#991b1b;align-items:flex-start;box-shadow:0 4px 15px rgba(239,68,68,.08)}
[data-theme="dark"] .warning-box{color:#fca5a5;border-left-color:#f87171}
.warning-icon{font-size:1.375rem;color:#ef4444;flex-shrink:0;margin-top:.1rem}
.warning-text{font-size:.9375rem;font-weight:500;line-height:1.7;margin:0}

/* Highlight section au clic */
.legal-block:target{animation:highlightSection 1.5s ease-out}
@keyframes highlightSection{0%{background-color:rgba(0,123,255,.05)}100%{background-color:transparent}}

/* --- BOUTON REINITIALISATION COOKIES --- */
.btn-reset-consent{display:inline-flex;align-items:center;gap:.625rem;padding:.875rem 1.75rem;border-radius:9999px;background-color:rgba(0,123,255,.08);color:var(--cpw-primary);border:1px solid rgba(0,123,255,.2);font-size:.9375rem;font-weight:700;cursor:pointer;position:relative;overflow:hidden}
.btn-reset-consent::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 60%);border-radius:9999px;pointer-events:none}
.btn-reset-consent:hover{background-color:rgba(0,123,255,.14);border-color:var(--cpw-primary);box-shadow:0 8px 20px -4px rgba(0,123,255,.2)}

/* --- RESPONSIVE MEDIA QUERIES --- */
@media(min-width:640px){
    .info-row{flex-direction:row;align-items:flex-start;gap:1rem}
    .info-label{width:160px;flex-shrink:0}
}
@media(min-width:768px){
    .hero-title{font-size:3rem}
    .trust-grid{grid-template-columns:repeat(3,1fr)}
    .trust-card{flex-direction:row;text-align:left}
    .legal-articles{padding:4rem 3rem;border-radius:2.5rem;gap:5rem}
    .info-box{padding:2.5rem 2rem}
}
@media(min-width:1024px){
    .legal-hero{padding-top:13rem;padding-bottom:8rem}
    .hero-title{font-size:4rem}
    .legal-layout{grid-template-columns:280px 1fr;gap:5rem}
    .legal-sidebar{display:block}
}