/* The Bright Company V5 — styles partagés pages internes (pôles, légal) */

/* ---- Hero de page (interne) ---- */
.phero { position: relative; padding-top: clamp(9rem, 6rem + 9vw, 13rem); padding-bottom: clamp(2.5rem, 2rem + 3vw, 4rem); overflow: hidden; }
.phero__grid { position: absolute; inset: 0; z-index: 0; opacity: .18; background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px); background-size: 64px 64px; mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, #000, transparent 75%); }
.phero::before { content: ""; position: absolute; top: -38%; left: 50%; transform: translateX(-50%); width: 90%; height: 118%; background: radial-gradient(ellipse at center, rgba(212,175,55,.10) 0%, transparent 60%); pointer-events: none; z-index: 0; }
.phero__inner { position: relative; z-index: 2; max-width: 58rem; }
.phero h1 { margin-top: 1.3rem; }
.phero .lead { margin-top: 1.5rem; max-width: 42rem; }
.phero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.phero__tags { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.6rem; }

/* ---- Deux colonnes générique ---- */
.cols2 { display: grid; gap: 2.5rem; } @media (min-width: 820px) { .cols2 { grid-template-columns: 1fr 1fr; gap: 4rem; } }

/* ---- Liste à puces dorées ---- */
.dlist { margin-top: 1.4rem; } .dlist li { display: flex; gap: .8rem; padding: .55rem 0; color: var(--ink-soft); line-height: 1.55; }
.dlist li svg { width: 20px; height: 20px; flex: 0 0 20px; margin-top: 4px; stroke: var(--gold); fill: none; stroke-width: 1.8; }

/* ---- Processus numéroté ---- */
.steps { display: grid; gap: 1rem; margin-top: 2.5rem; counter-reset: st; }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(4, 1fr); } }
.step { position: relative; padding: 1.8rem 1.5rem; }
.step__n { font-family: var(--font-display); font-size: 2.6rem; line-height: 1; color: transparent; -webkit-text-stroke: 1px var(--line-gold); display: block; margin-bottom: .8rem; }
.step h3 { font-size: 1.2rem; } .step p { margin-top: .5rem; font-size: .95rem; color: var(--ink-faint); }

/* ---- Bénéfices ---- */
.benefits { display: grid; gap: 1.2rem; margin-top: 2.5rem; grid-template-columns: 1fr; }
@media (min-width: 720px) { .benefits { grid-template-columns: repeat(3, 1fr); } }
.benefit { padding: 2rem; } .benefit__ico { width: 44px; height: 44px; border-radius: 11px; display: grid; place-items: center; background: rgba(212,175,55,.1); border: 1px solid var(--line-gold); margin-bottom: 1.1rem; }
.benefit h3 { font-size: 1.25rem; } .benefit p { margin-top: .6rem; font-size: .96rem; }

/* ---- Cross-links autres pôles ---- */
.xlinks { display: grid; gap: .8rem; margin-top: 2.5rem; grid-template-columns: 1fr 1fr; } @media (min-width: 760px) { .xlinks { grid-template-columns: repeat(5, 1fr); } }
.xlink { padding: 1rem; text-align: center; font-size: .95rem; transition: color .3s, border-color .3s; } .xlink:hover { color: var(--gold-light); }
.xlink--active { border-color: var(--line-gold); color: var(--gold-light); background: rgba(212,175,55,.05); }

/* ---- CTA final partagé ---- */
.cta-band { position: relative; overflow: hidden; padding: clamp(2.5rem,2rem + 4vw,5rem) 2rem; text-align: center; }

/* ---- Pages légales (prose) ---- */
.legal { max-width: 50rem; margin-inline: auto; }
.legal__updated { font-size: .85rem; color: var(--ink-faint); margin-top: .8rem; }
.legal section { margin-top: 2.6rem; scroll-margin-top: 100px; }
.legal h2 { font-size: 1.5rem; margin-bottom: .9rem; }
.legal h3 { font-size: 1.15rem; margin: 1.4rem 0 .6rem; color: var(--gold-light); font-family: var(--font-body); font-weight: 600; }
.legal p { color: var(--ink-soft); margin-bottom: .8rem; line-height: 1.75; }
.legal ul { margin: .6rem 0 1rem; padding-left: 0; }
.legal li { display: flex; gap: .7rem; padding: .35rem 0; color: var(--ink-soft); }
.legal li::before { content: ""; flex: 0 0 6px; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); margin-top: .65em; }
.legal a { color: var(--gold-light); text-decoration: underline; text-underline-offset: 3px; }
.legal .note { padding: 1.2rem 1.4rem; border-left: 3px solid var(--gold); background: rgba(212,175,55,.05); border-radius: 0 var(--r-sm) var(--r-sm) 0; margin: 1.5rem 0; }
.legal__toc { display: flex; flex-wrap: wrap; gap: .5rem; margin: 2rem 0; }
.legal__toc a { font-size: .85rem; padding: .4rem .8rem; border: 1px solid var(--line); border-radius: var(--r-pill); color: var(--ink-soft); text-decoration: none; transition: border-color .3s, color .3s; }
.legal__toc a:hover { border-color: var(--line-gold); color: var(--gold-light); }

/* ---- Footer partagé ---- */
.footer { border-top: 1px solid var(--line); padding-block: 3.5rem; margin-top: 2rem; }
.footer__grid { display: grid; gap: 2rem; grid-template-columns: 1fr; } @media (min-width: 720px) { .footer__grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }
.footer h4 { font-family: var(--font-body); font-size: .78rem; text-transform: uppercase; letter-spacing: .16em; color: var(--gold-light); margin-bottom: 1rem; }
.footer a { display: block; color: var(--ink-faint); font-size: .92rem; padding: .25rem 0; transition: color .3s; } .footer a:hover { color: var(--ink); }
.footer__brand img { height: 40px; margin-bottom: 1rem; }
.footer__legal { margin-top: 2.5rem; padding-top: 1.5rem; border-top: 1px solid var(--line); display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; font-size: .85rem; color: var(--ink-faint); }
.footer__dna { display: inline-flex; align-items: center; gap: .5rem; }
.footer__dna-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 10px var(--gold); }
.footer__legal a { display: inline; }
