/* ==================================================================
   QRClip — Home (refonte 2026, orientation "Chaleureux & direct")
   Style aligné sur l'admin (Barlow, accent jaune QRClip, noir)
   ================================================================== */

:root {
  --noir: #0d0d0d;
  --jaune: #FED100;
  --jaune-pale: #fff6c8;
  --bleu: #1e4892;
  --gris: #555;
  --gris-clair: #efece6;
  --vert: #2d6a4f;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body.home-body { background:#fff; color:var(--noir); font-family:'Barlow',sans-serif; font-weight:400; line-height:1.55; overflow-x:hidden; }
body.home-body img { max-width:100%; display:block; }

/* ── NAV ── */
.topnav { padding:18px 60px; display:flex; justify-content:space-between; align-items:center; background:#fff; position:sticky; top:0; z-index:100; border-bottom:1px solid var(--gris-clair); }
.topnav .logo { font-family:'Barlow',sans-serif; font-size:24px; font-weight:900; color:var(--noir); letter-spacing:-0.5px; text-decoration:none; }
.topnav .logo span { color:var(--jaune); background:var(--noir); padding:0 6px; border-radius:3px; }
.topnav ul { display:flex; list-style:none; gap:36px; align-items:center; }
.topnav ul a { color:var(--noir); text-decoration:none; font-size:14px; font-weight:600; transition:color .2s; }
.topnav ul a:hover { color:var(--bleu); }
.topnav ul a.active { color:var(--bleu); position:relative; }
.topnav ul a.active::after { content:''; position:absolute; bottom:-22px; left:0; right:0; height:3px; background:var(--jaune); }
.topnav ul a.btn { background:var(--noir); color:var(--jaune); padding:10px 22px; font-size:12px; border-radius:6px; letter-spacing:1.5px; text-transform:uppercase; font-weight:800; }
.topnav ul a.btn:hover { background:var(--jaune); color:var(--noir); }
.topnav ul a.btn::after { display:none; }

/* ── HERO ── */
.hero { background:var(--jaune); padding:80px 60px 100px; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-200px; right:-200px; width:600px; height:600px; border-radius:50%; background:rgba(255,255,255,0.25); }
.hero::after { content:''; position:absolute; bottom:-100px; right:30%; width:300px; height:300px; border-radius:50%; background:rgba(255,255,255,0.15); }
.hero-inner { display:grid; grid-template-columns:1.1fr 1fr; gap:60px; align-items:center; max-width:1300px; margin:0 auto; position:relative; }
.hero-pill { display:inline-flex; align-items:center; gap:8px; background:var(--noir); color:var(--jaune); padding:8px 16px; border-radius:100px; font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:30px; }
.hero h1 { font-size:clamp(48px,7vw,92px); font-weight:900; line-height:0.95; letter-spacing:-2px; text-transform:uppercase; color:var(--noir); margin-bottom:28px; }
.hero h1 .underline { background:linear-gradient(180deg,transparent 60%,#fff 60%); padding:0 4px; }
.hero-lead { font-size:21px; color:var(--noir); max-width:520px; margin-bottom:36px; line-height:1.45; font-weight:500; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }
.hero-img { border-radius:20px; box-shadow:0 30px 60px -16px rgba(0,0,0,0.3); transform:rotate(-2deg); border:6px solid #fff; }
.hero-img-wrap { position:relative; }
.hero-badge { position:absolute; top:-20px; right:-20px; background:var(--noir); color:var(--jaune); padding:18px 22px; border-radius:14px; transform:rotate(8deg); }
.hero-badge strong { display:block; font-size:32px; font-weight:900; line-height:1; }
.hero-badge span { font-size:11px; letter-spacing:1.5px; }

/* ── BOUTONS ── */
.btn { display:inline-flex; align-items:center; gap:10px; padding:18px 32px; text-decoration:none; font-size:13px; letter-spacing:1.5px; text-transform:uppercase; font-weight:800; transition:all .25s; cursor:pointer; border:0; border-radius:8px; font-family:'Barlow',sans-serif; }
.btn-dark { background:var(--noir); color:var(--jaune); }
.btn-dark:hover { background:#222; transform:translateY(-2px); box-shadow:0 8px 24px -8px rgba(0,0,0,0.4); }
.btn-outline { background:transparent; color:var(--noir); border:2px solid var(--noir); }
.btn-outline:hover { background:var(--noir); color:var(--jaune); }
.btn-yellow { background:var(--jaune); color:var(--noir); }
.btn-yellow:hover { background:#fff; }
.btn-block { width:100%; justify-content:center; }

/* ── LIEN TROUVEUR DANS LE HERO ── */
.hero-finder-link { display:inline-flex; align-items:center; gap:10px; margin-top:24px; padding:14px 20px; background:rgba(255,255,255,0.45); border:2px solid var(--noir); border-radius:100px; text-decoration:none; color:var(--noir); font-size:14px; font-weight:600; transition:all .2s; }
.hero-finder-link:hover { background:var(--noir); color:var(--jaune); transform:translateY(-2px); }
.hero-finder-link i.bi-bell-fill { font-size:18px; }
.hero-finder-link strong { font-weight:800; text-decoration:underline; text-underline-offset:3px; }
.hero-finder-link span i.bi-arrow-right { margin-left:4px; }

/* ── BANDE TROUVEUR (dédiée) ── */
.finder-band { background:linear-gradient(135deg,#1e4892 0%,#2d6a4f 100%); color:#fff; padding:48px 60px; position:relative; overflow:hidden; }
.finder-band::before { content:''; position:absolute; top:-100px; right:-100px; width:400px; height:400px; border-radius:50%; background:rgba(255,255,255,0.06); pointer-events:none; }
.finder-band::after { content:''; position:absolute; bottom:-80px; left:-80px; width:280px; height:280px; border-radius:50%; background:rgba(254,209,0,0.08); pointer-events:none; }
.finder-inner { max-width:1300px; margin:0 auto; display:grid; grid-template-columns:1.5fr auto; gap:48px; align-items:center; position:relative; }
.finder-content { display:flex; gap:24px; align-items:center; }
.finder-icon { width:72px; height:72px; background:var(--jaune); color:var(--noir); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:32px; flex-shrink:0; box-shadow:0 6px 20px -6px rgba(0,0,0,0.4); }
.finder-text { color:#fff; }
.finder-title { font-size:clamp(22px,3vw,32px); font-weight:900; line-height:1.1; text-transform:uppercase; letter-spacing:-0.5px; margin-bottom:8px; color:#fff; }
.finder-desc { font-size:15px; color:rgba(255,255,255,0.88); line-height:1.55; margin:0; max-width:640px; }
.finder-cta { display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.finder-btn { background:var(--jaune); color:var(--noir); padding:20px 36px; font-size:14px; font-weight:900; letter-spacing:2px; text-transform:uppercase; border-radius:8px; text-decoration:none; transition:all .2s; display:inline-flex; align-items:center; gap:10px; box-shadow:0 8px 24px -8px rgba(0,0,0,0.35); }
.finder-btn:hover { background:#fff; transform:translateY(-2px); box-shadow:0 12px 32px -8px rgba(0,0,0,0.5); }
.finder-note { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.7); font-weight:600; }

/* ── STATS BAND ── */
.stats-band { background:var(--noir); color:#fff; padding:60px; }
.stats-band-inner { max-width:1300px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
.stat strong { display:block; font-size:56px; font-weight:900; color:var(--jaune); line-height:1; margin-bottom:8px; letter-spacing:-2px; }
.stat span { font-size:13px; letter-spacing:1px; text-transform:uppercase; color:#aaa; font-weight:600; }

/* ── SECTIONS COMMUNES ── */
section { padding:100px 60px; }
.section-inner { max-width:1300px; margin:0 auto; }
.section-label { display:inline-block; background:var(--jaune); color:var(--noir); font-size:12px; letter-spacing:2px; text-transform:uppercase; font-weight:800; padding:6px 14px; border-radius:6px; margin-bottom:24px; }
h2 { font-size:clamp(34px,5vw,56px); font-weight:900; line-height:1.05; margin-bottom:24px; text-transform:uppercase; letter-spacing:-1.5px; max-width:780px; }
h2 mark { background:var(--jaune); padding:0 8px; color:var(--noir); }
.lead { font-size:18px; color:var(--gris); max-width:720px; line-height:1.55; margin-bottom:0; }

/* ── PRODUIT ── */
.product-section { background:#fafaf7; }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px; }
.step-card { background:#fff; border:0; border-radius:16px; padding:0; overflow:hidden; transition:all .3s; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12), 0 2px 4px -1px rgba(0,0,0,0.04); }
.step-card:hover { transform:translateY(-4px); box-shadow:0 20px 40px -16px rgba(0,0,0,0.18), 0 0 0 4px rgba(254,209,0,0.25); }
.step-img { aspect-ratio:4/3; overflow:hidden; border-bottom:1px dashed rgba(13,13,13,0.25); }
.step-img img { width:100%; height:100%; object-fit:cover; }
.step-body { padding:28px 28px 32px; }
.step-num { display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; background:var(--jaune); color:var(--noir); border-radius:50%; font-weight:900; font-size:20px; margin-bottom:18px; border:2px solid var(--noir); }
.step-card h3 { font-size:24px; font-weight:900; margin-bottom:12px; text-transform:uppercase; letter-spacing:-0.5px; line-height:1.1; }
.step-card p { font-size:15px; color:#333; line-height:1.55; }

/* ── B2B / PAGE SPLIT ── */
.b2b-section { background:var(--noir); color:#fff; padding:120px 60px; position:relative; overflow:hidden; }
.b2b-section::before { content:''; position:absolute; top:-100px; right:-50px; width:400px; height:400px; border-radius:50%; background:rgba(254,209,0,0.12); }
.b2b-section .section-label { background:var(--jaune); }
.b2b-section h2 { color:#fff; }
.b2b-section .lead { color:#bbb; }
.b2b-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:60px; margin-top:60px; align-items:center; position:relative; }
.b2b-visual { background:#fff; padding:24px; border-radius:20px; transform:rotate(-2deg); aspect-ratio:9/12; max-width:340px; margin:0 auto; box-shadow:0 30px 60px -16px rgba(0,0,0,0.5); }
.b2b-visual-inner { background:#fff; height:100%; border-radius:12px; padding:32px 24px; display:flex; flex-direction:column; }
.b2b-form-block { flex:1; }
.b2b-form-block .icon { width:48px; height:48px; background:var(--noir); color:var(--jaune); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; margin:0 auto 10px; }
.b2b-form-block .title { font-weight:900; font-size:14px; text-align:center; text-transform:uppercase; margin-bottom:14px; letter-spacing:0.5px; }
.b2b-form-block .input { background:#f5f3ed; padding:8px 12px; font-size:10px; color:#777; margin-bottom:7px; border-radius:4px; }
.b2b-form-block .input-btn { background:var(--noir); color:var(--jaune); text-align:center; padding:9px; font-weight:900; font-size:10px; text-transform:uppercase; letter-spacing:1px; border-radius:4px; margin-top:8px; }
.b2b-brand-block { text-align:center; padding-top:14px; background:var(--jaune); margin:14px -24px -32px; padding:18px 24px 24px; border-radius:0 0 12px 12px; }
.b2b-brand-logo { width:44px; height:44px; background:var(--noir); color:var(--jaune); border-radius:50%; margin:0 auto 8px; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:18px; }
.b2b-brand-name { font-weight:900; font-size:14px; margin-bottom:4px; color:var(--noir); }
.b2b-brand-tag { font-size:10px; color:#333; }
.b2b-bullets { list-style:none; margin-top:30px; }
.b2b-bullets li { display:flex; gap:16px; margin-bottom:24px; align-items:flex-start; }
.b2b-bullets li .icon { background:var(--jaune); color:var(--noir); width:36px; height:36px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.b2b-bullets li strong { display:block; color:#fff; font-size:18px; margin-bottom:4px; font-weight:800; }
.b2b-bullets li p { color:#bbb; font-size:14px; margin:0; line-height:1.5; max-width:none; }

/* ── PACKS ── */
.packs-section { background:#fff; padding:120px 60px; }
.packs-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px; }
.pack-card { background:#fff; border:0; border-radius:18px; padding:36px 32px; transition:all .3s; display:flex; flex-direction:column; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12), 0 2px 4px -1px rgba(0,0,0,0.04); }
.pack-card.featured { border-color:var(--jaune); background:linear-gradient(180deg,#fffce4 0%,#fff 60%); position:relative; }
.pack-card.featured::before { content:attr(data-badge); position:absolute; top:-12px; left:32px; background:var(--noir); color:var(--jaune); padding:5px 12px; font-size:10px; font-weight:900; letter-spacing:1.5px; text-transform:uppercase; border-radius:6px; }
.pack-card:hover { transform:translateY(-4px); border-color:var(--noir); }
.pack-name { font-size:18px; font-weight:900; text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; color:var(--bleu); }
.pack-price { font-size:48px; font-weight:900; line-height:1; margin-bottom:6px; letter-spacing:-1.5px; }
.pack-price span { font-size:16px; color:#666; font-weight:600; }
.pack-unit { font-size:13px; color:#666; margin-bottom:24px; padding-bottom:24px; border-bottom:1px dashed var(--gris-clair); }
.pack-features { list-style:none; margin-bottom:24px; flex:1; padding:0; }
.pack-features li { padding:8px 0 8px 28px; position:relative; font-size:14px; line-height:1.4; }
.pack-features li::before { content:'✓'; position:absolute; left:0; color:var(--vert); font-weight:900; font-size:18px; }

/* ── LOGOS CLIENTS ── */
.clients-section { background:#fafaf7; padding:80px 60px; }
.clients-inner { max-width:1300px; margin:0 auto; }
.clients-title { text-align:center; font-size:14px; letter-spacing:2px; text-transform:uppercase; font-weight:700; color:var(--gris); margin-bottom:36px; }
.clients-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(120px,1fr)); gap:36px; align-items:center; justify-items:center; }
.clients-grid img { max-height:54px; object-fit:contain; width:auto; opacity:.85; transition:all .2s; }
.clients-grid img:hover { opacity:1; transform:scale(1.05); }

/* ── RSE / MIF ── */
.rse-section { background:linear-gradient(180deg, #f4f1e6 0%, #fff 100%); padding:140px 60px; position:relative; }
.rse-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:80px; margin-top:60px; align-items:center; }
.rse-label { background:var(--vert) !important; color:#fff !important; }
.rse-mark { background:#cfe8d4 !important; }
.rse-bullets { list-style:none; margin-top:36px; display:grid; grid-template-columns:1fr 1fr; gap:24px; padding:0; }
.rse-bullets li { padding:24px 22px; background:#fff; border-radius:12px; border:1px solid var(--gris-clair); display:flex; gap:14px; align-items:flex-start; }
.rse-bullets li .icon { font-size:28px; color:var(--vert); flex-shrink:0; line-height:1; }
.rse-bullets li strong { display:block; font-weight:800; font-size:15px; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:4px; }
.rse-bullets li p { font-size:13px; color:#555; margin:0; line-height:1.5; max-width:none; }
.rse-fab-img { border-radius:20px; transform:rotate(2deg); box-shadow:0 30px 60px -16px rgba(0,0,0,0.2); border:6px solid #fff; width:100%; }
.rse-claim { margin-top:80px; padding:40px 48px; background:var(--noir); color:#fff; border-radius:16px; text-align:center; position:relative; overflow:hidden; }
.rse-claim::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 80% 50%, rgba(254,209,0,0.12), transparent 50%); }
.rse-claim p { font-size:24px; font-weight:700; line-height:1.4; max-width:880px; margin:0 auto; position:relative; max-width:880px; }
.rse-claim mark { background:var(--jaune); color:var(--noir); padding:0 6px; }

/* ── CTA FINAL ── */
.cta-section { background:var(--jaune); padding:120px 60px; text-align:center; }
.cta-section .cta-label { background:var(--noir) !important; color:var(--jaune) !important; }
.cta-section h2 { color:var(--noir); margin:0 auto 20px; max-width:800px; }
.cta-section .lead { color:var(--noir); margin:0 auto 40px; max-width:600px; font-weight:500; }
.cta-section .btn { margin:0 8px 12px; }

/* ── FOOTER ── */
.footer-social { display:flex; gap:10px; margin-top:18px; flex-wrap:wrap; }
.footer-social a { width:38px; height:38px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:#aaa; background:rgba(255,255,255,0.06); font-size:16px; text-decoration:none; transition:all .2s; }
.footer-social a:hover { background:var(--jaune); color:var(--noir); transform:translateY(-2px); }

footer { background:var(--noir); color:#aaa; padding:60px 60px 36px; }
.footer-inner { max-width:1300px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,0.1); }
.footer-brand .logo { font-size:28px; font-weight:900; color:#fff; margin-bottom:14px; }
.footer-brand .logo span { color:var(--jaune); background:#fff; padding:0 6px; border-radius:3px; }
.footer-brand p { font-size:13px; max-width:280px; line-height:1.55; }
footer h5 { color:#fff; font-size:12px; letter-spacing:1px; text-transform:uppercase; margin-bottom:18px; font-weight:800; }
footer ul { list-style:none; padding:0; }
footer ul li { margin-bottom:8px; }
footer ul a { color:#aaa; text-decoration:none; font-size:14px; }
footer ul a:hover { color:var(--jaune); }
.footer-bottom { max-width:1300px; margin:36px auto 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; font-size:12px; }

/* ── RESPONSIVE ── */
@media (max-width:1000px) {
  .topnav, .hero, .stats-band, section, .b2b-section, .packs-section, .clients-section, .rse-section, .cta-section, footer { padding-left:32px; padding-right:32px; }
  .hero-inner { grid-template-columns:1fr; }
  .hero-img-wrap { max-width:400px; margin:0 auto; }
  .stats-band-inner { grid-template-columns:repeat(2,1fr); }
  .steps-grid, .packs-grid { grid-template-columns:1fr; }
  .b2b-grid, .rse-grid { grid-template-columns:1fr; gap:48px; }
  .rse-bullets { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .topnav ul { display:none; }
  .finder-band { padding:36px 32px; }
  .finder-inner { grid-template-columns:1fr; gap:24px; }
  .finder-cta { align-items:flex-start; }
}
@media (max-width:640px) {
  .topnav, .hero, .stats-band, section, .b2b-section, .packs-section, .clients-section, .rse-section, .cta-section, footer { padding-left:18px; padding-right:18px; }
  .stats-band-inner { grid-template-columns:1fr 1fr; gap:18px; }
  .stat strong { font-size:40px; }
  .footer-inner { grid-template-columns:1fr; }
  .hero { padding-top:60px; padding-bottom:60px; }
  .hero h1 { font-size:42px; }
  .hero-lead { font-size:17px; }
  .finder-band { padding:32px 18px; }
  .finder-content { flex-direction:column; align-items:flex-start; gap:16px; }
  .finder-icon { width:56px; height:56px; font-size:24px; }
  .finder-btn { padding:16px 24px; font-size:13px; width:100%; justify-content:center; }
}

/* ==================================================================
   PAGES INTERNES (infos, offres, projets, blog, a-propos, mentions, rgpd, contact)
   ================================================================== */

/* Mini-hero pour pages contenu */
.page-hero { background:var(--jaune); padding:80px 60px 60px; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; top:-200px; right:-200px; width:500px; height:500px; border-radius:50%; background:rgba(255,255,255,0.25); }
.page-hero-inner { max-width:1100px; margin:0 auto; position:relative; }
.page-hero-pill { display:inline-flex; align-items:center; gap:8px; background:var(--noir); color:var(--jaune); padding:6px 16px; border-radius:100px; font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:24px; }
.page-hero h1 { font-size:clamp(36px,5.5vw,68px); font-weight:900; line-height:1; letter-spacing:-1.5px; text-transform:uppercase; color:var(--noir); margin-bottom:22px; max-width:900px; }
.page-hero h1 .underline { background:linear-gradient(180deg,transparent 60%,#fff 60%); padding:0 4px; }
.page-hero-lead { font-size:18px; color:var(--noir); max-width:640px; line-height:1.5; font-weight:500; }

/* Sections de contenu standard */
.content-section { padding:80px 60px; background:#fff; }
.content-section.alt { background:#fafaf7; }
.content-section.dark { background:var(--noir); color:#fff; }
.content-inner { max-width:1100px; margin:0 auto; }
.content-inner h2 { font-size:clamp(28px,4vw,44px); font-weight:900; line-height:1.1; text-transform:uppercase; letter-spacing:-1px; margin-bottom:24px; max-width:760px; }
.content-inner h2 mark { background:var(--jaune); padding:0 8px; color:var(--noir); }
.content-section.dark h2 { color:#fff; }
.content-section.dark h2 mark { background:var(--jaune); color:var(--noir); }
.content-inner h3 { font-size:24px; font-weight:800; margin-top:32px; margin-bottom:14px; line-height:1.2; }
.content-section.dark h3 { color:#fff; }
.content-inner p { font-size:16px; line-height:1.65; color:#333; margin-bottom:14px; max-width:760px; }
.content-section.dark .content-inner p { color:#ccc; }
.content-inner ul { padding-left:22px; margin-bottom:18px; max-width:760px; }
.content-inner ul li { font-size:16px; line-height:1.6; color:#333; margin-bottom:8px; }
.content-section.dark .content-inner li { color:#ccc; }
.content-inner ul li::marker { color:var(--jaune); font-weight:900; }
.content-inner a:not(.btn) { color:var(--bleu); }
.content-section.dark .content-inner a:not(.btn) { color:var(--jaune); }
/* btn-outline doit rester visible sur fond sombre */
.content-section.dark .btn-outline,
.b2b-section .btn-outline,
.rse-section .btn-outline,
section.dark .btn-outline { color:#fff; border-color:#fff; }
.content-section.dark .btn-outline:hover,
.b2b-section .btn-outline:hover,
.rse-section .btn-outline:hover,
section.dark .btn-outline:hover { background:#fff; color:var(--noir); }

/* Mini cartes pour engagement, prix, etc. */
.tile-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:18px; margin-top:36px; }
.tile { background:#fff; border:0; border-radius:16px; padding:28px 24px; transition:all .3s; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12), 0 2px 4px -1px rgba(0,0,0,0.04); }
.tile:hover { transform:translateY(-4px); box-shadow:0 20px 40px -16px rgba(0,0,0,0.18), 0 0 0 4px rgba(254,209,0,0.25); }
.tile-num { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; background:var(--jaune); color:var(--noir); border-radius:50%; font-weight:900; font-size:18px; margin-bottom:14px; border:2px solid var(--noir); }
.tile-icon { display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; background:var(--jaune); color:var(--noir); border-radius:10px; font-size:22px; margin-bottom:14px; }
.tile h4 { font-size:17px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:10px; line-height:1.2; }
.tile p { font-size:14px; color:#444; line-height:1.55; margin:0; max-width:none; }
.content-section.dark .tile { background:#1a1a1a; border-color:var(--jaune); }
.content-section.dark .tile h4 { color:#fff; }
.content-section.dark .tile p { color:#bbb; }

/* Galerie clients projets */
.case-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:24px; margin-top:36px; }
.case-card { background:#fff; border:0; border-radius:16px; overflow:hidden; transition:all .3s; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12), 0 2px 4px -1px rgba(0,0,0,0.04); }
.case-card:hover { transform:translateY(-4px); box-shadow:0 20px 40px -16px rgba(0,0,0,0.18), 0 0 0 4px rgba(254,209,0,0.25); }
.case-card-logo { aspect-ratio:16/9; background:#fafaf7; display:flex; align-items:center; justify-content:center; padding:24px; border-bottom:1px dashed rgba(13,13,13,0.25); }
.case-card-logo img { max-height:80px; max-width:70%; object-fit:contain; }
.case-card-body { padding:22px 24px; }
.case-card-name { font-size:18px; font-weight:900; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:8px; }
.case-card-info { font-size:13px; color:#666; margin-bottom:10px; }
.case-card-text { font-size:14px; color:#333; line-height:1.55; margin:0; }

/* Blog cards */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(320px, 1fr)); gap:28px; margin-top:36px; }
.blog-card { background:#fff; border:0; border-radius:16px; overflow:hidden; transition:all .3s; display:flex; flex-direction:column; text-decoration:none; color:inherit; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12), 0 2px 4px -1px rgba(0,0,0,0.04); }
.blog-card:hover { transform:translateY(-6px); box-shadow:0 24px 48px -16px rgba(0,0,0,0.22), 0 0 0 4px rgba(254,209,0,0.25); }
.blog-card-img { aspect-ratio:16/9; overflow:hidden; border-bottom:1px dashed rgba(13,13,13,0.25); }
.blog-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.blog-card:hover .blog-card-img img { transform:scale(1.05); }
.blog-card-body { padding:24px 24px 28px; flex:1; display:flex; flex-direction:column; }
.blog-card-cat { display:inline-block; background:var(--jaune); color:var(--noir); padding:4px 10px; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; font-weight:800; border-radius:4px; margin-bottom:12px; align-self:flex-start; }
.blog-card-title { font-size:20px; font-weight:900; line-height:1.2; margin-bottom:10px; text-transform:uppercase; letter-spacing:-0.5px; color:var(--noir); }
.blog-card-excerpt { font-size:14px; color:#444; line-height:1.55; margin-bottom:18px; flex:1; }
.blog-card-meta { font-size:12px; color:#666; padding-top:14px; border-top:1px dashed var(--gris-clair); display:flex; justify-content:space-between; align-items:center; }
.blog-card-arrow { color:var(--noir); font-size:18px; }

/* Article blog */
.article-section { padding:80px 60px; background:#fff; }
.article-inner { max-width:760px; margin:0 auto; }
.article-meta { display:flex; gap:14px; align-items:center; margin-bottom:24px; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:#666; }
.article-meta .cat { background:var(--jaune); color:var(--noir); padding:4px 10px; font-weight:800; border-radius:4px; }
.article-inner h1 { font-size:clamp(32px,5vw,52px); font-weight:900; line-height:1.05; text-transform:uppercase; letter-spacing:-1px; margin-bottom:28px; }
.article-lead { font-size:21px; line-height:1.5; color:#333; font-weight:500; margin-bottom:36px; padding-bottom:28px; border-bottom:2px solid var(--noir); }
.article-inner h2 { font-size:30px; font-weight:900; margin-top:48px; margin-bottom:18px; text-transform:uppercase; letter-spacing:-0.5px; }
.article-inner h3 { font-size:22px; font-weight:800; margin-top:32px; margin-bottom:12px; }
.article-inner p { font-size:17px; line-height:1.7; color:#222; margin-bottom:18px; }
.article-inner ul { padding-left:24px; margin-bottom:18px; }
.article-inner li { font-size:17px; line-height:1.65; margin-bottom:8px; }
.article-inner blockquote { font-style:italic; font-size:21px; line-height:1.5; padding:20px 28px; margin:32px 0; border-left:4px solid var(--jaune); background:#fafaf7; color:#333; }
.article-inner img { max-width:100%; border-radius:8px; margin:24px 0; }

/* Formulaire contact */
.contact-form { background:#fff; border:0; border-radius:16px; padding:36px 32px; max-width:680px; margin:36px auto 0; box-shadow:0 12px 40px -16px rgba(0,0,0,0.18), 0 2px 6px -2px rgba(0,0,0,0.06); }
.contact-form .field textarea { width:100%; padding:22px 16px 8px; border:2px solid var(--gris-clair); border-radius:8px; font-size:15px; font-family:'Barlow',sans-serif; color:var(--noir); background:#fff; outline:none; resize:vertical; min-height:140px; transition:border-color .15s; }
.contact-form .field textarea:focus { border-color:var(--jaune); }
.contact-form .field textarea:not(:placeholder-shown) + label,
.contact-form .field textarea:focus + label { top:6px; font-size:11px; color:#666; letter-spacing:1px; text-transform:uppercase; }

/* Responsive content pages */
@media (max-width:900px) {
  .page-hero, .content-section, .article-section { padding-left:32px; padding-right:32px; }
}
@media (max-width:640px) {
  .page-hero, .content-section, .article-section { padding-left:18px; padding-right:18px; }
  .page-hero { padding-top:60px; padding-bottom:48px; }
  .content-section { padding-top:48px; padding-bottom:48px; }
  .case-grid, .blog-grid { grid-template-columns:1fr; }
}

/* ==================================================================
   COMPOSANTS PAGES ac.php / al.php (activation, alerte)
   ================================================================== */

/* Wrapper page intermédiaire */
.page-wrap { padding:48px 60px 80px; background:#fafaf7; min-height:60vh; }
.page-inner { max-width:1080px; margin:0 auto; }

/* Lien retour */
.return-link { display:inline-flex; align-items:center; gap:8px; color:var(--noir); text-decoration:none; font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:24px; padding:10px 16px; background:#fff; border:2px solid var(--noir); border-radius:8px; transition:all .2s; }
.return-link:hover { background:var(--noir); color:var(--jaune); }

/* Grille intro + formulaire */
.page-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:36px; align-items:start; }
.page-grid.single { grid-template-columns:1fr; max-width:640px; margin:0 auto; }

/* Carte intro avec image */
.intro-card { background:#fff; border:0; border-radius:16px; overflow:hidden; box-shadow:0 12px 40px -16px rgba(0,0,0,0.18), 0 2px 6px -2px rgba(0,0,0,0.06); }
.intro-card-img { aspect-ratio:4/3; overflow:hidden; border-bottom:1px dashed rgba(13,13,13,0.25); }
.intro-card-img img { width:100%; height:100%; object-fit:cover; }
.intro-card-body { padding:32px 28px; }
.intro-card-eyebrow { display:inline-block; background:var(--jaune); color:var(--noir); padding:5px 12px; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:800; border-radius:6px; margin-bottom:14px; }
.intro-card-title { font-size:26px; font-weight:900; line-height:1.1; text-transform:uppercase; letter-spacing:-0.5px; margin-bottom:14px; }
.intro-card-text { font-size:15px; color:#444; line-height:1.55; }

/* Carte formulaire */
.form-card { background:#fff; border:0; border-radius:16px; padding:36px 32px; box-shadow:0 12px 40px -16px rgba(0,0,0,0.18), 0 2px 6px -2px rgba(0,0,0,0.06); }
.form-card-title { font-size:22px; font-weight:900; line-height:1.1; text-transform:uppercase; letter-spacing:-0.5px; margin-bottom:10px; }
.form-card-text { font-size:14px; color:#444; line-height:1.55; margin-bottom:24px; }

/* Champs flottants (sans Bootstrap) */
.field { position:relative; margin-bottom:14px; }
.field input, .field select { width:100%; padding:22px 16px 8px; border:2px solid var(--gris-clair); border-radius:8px; font-size:15px; font-family:'Barlow',sans-serif; color:var(--noir); background:#fff; outline:none; transition:border-color .15s; }
.field input:focus, .field select:focus { border-color:var(--jaune); }
.field input:not(:placeholder-shown) + label,
.field input:focus + label,
.field select:focus + label,
.field.has-value select + label { top:6px; font-size:11px; color:#666; letter-spacing:1px; text-transform:uppercase; }
.field label { position:absolute; top:18px; left:16px; pointer-events:none; font-size:14px; color:#999; transition:all .15s; }
.field select { appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23999'%3e%3cpath d='M8 11l-5-5h10l-5 5z'/%3e%3c/svg%3e"); background-repeat:no-repeat; background-position:right 14px center; background-size:14px; padding-right:36px; }
.field select + label { top:6px; font-size:11px; color:#666; letter-spacing:1px; text-transform:uppercase; }

/* Grille des 3 codes */
.code-fields { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:6px; }
.code-fields .field input { text-align:center; font-weight:900; font-size:20px; letter-spacing:2px; }
.code-helper { font-size:12px; color:#666; text-align:center; margin-bottom:18px; font-style:italic; }

/* Ligne pays + mobile */
.row-2cols { display:grid; grid-template-columns:0.6fr 1fr; gap:10px; }

/* Boutons forms */
.form-submit { width:100%; padding:18px; background:var(--noir); color:var(--jaune); border:0; border-radius:8px; font-size:14px; font-weight:900; letter-spacing:2px; text-transform:uppercase; cursor:pointer; font-family:'Barlow',sans-serif; transition:all .2s; margin-top:8px; }
.form-submit:hover { background:#222; transform:translateY(-2px); box-shadow:0 8px 24px -8px rgba(0,0,0,0.4); }

/* Messages d'alerte */
.alert-msg { padding:16px 22px; border-radius:8px; margin-bottom:24px; font-size:15px; font-weight:600; display:flex; gap:12px; align-items:center; }
.alert-msg i { font-size:22px; flex-shrink:0; }
.alert-msg.success { background:#e8f5ed; color:var(--vert); border-left:4px solid var(--vert); }
.alert-msg.warning { background:#fff4d6; color:#8a6a00; border-left:4px solid var(--jaune); }
.alert-msg.error { background:#fce8e8; color:#a52823; border-left:4px solid #a52823; }
.alert-msg.info { background:#e6efff; color:var(--bleu); border-left:4px solid var(--bleu); }

/* Carte de félicitation / succès */
.success-card { background:linear-gradient(135deg,var(--jaune) 0%,#fff6c8 100%); border:0; border-radius:20px; padding:48px 36px; text-align:center; position:relative; overflow:hidden; box-shadow:0 16px 48px -16px rgba(0,0,0,0.2), 0 4px 8px -2px rgba(0,0,0,0.08); }
.success-card::before { content:''; position:absolute; top:-100px; right:-100px; width:300px; height:300px; border-radius:50%; background:rgba(255,255,255,0.4); }
.success-card-icon { width:80px; height:80px; background:var(--noir); color:var(--jaune); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:40px; margin:0 auto 20px; position:relative; }
.success-card-eyebrow { display:inline-block; background:var(--noir); color:var(--jaune); padding:6px 16px; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:800; border-radius:6px; margin-bottom:16px; position:relative; }
.success-card-title { font-size:32px; font-weight:900; line-height:1.1; text-transform:uppercase; letter-spacing:-1px; margin-bottom:18px; position:relative; }
.success-card-text { font-size:16px; color:var(--noir); line-height:1.6; max-width:600px; margin:0 auto 28px; position:relative; }
.success-card .btn { position:relative; }

/* Bandeau marque (compte client B2B) */
/* Badge partenaire horizontal compact (Direction A) */
.brand-header { background:var(--jaune); border:0; border-radius:14px; padding:14px 18px; margin-bottom:12px; display:flex; align-items:center; gap:14px; position:relative; overflow:hidden; box-shadow:0 8px 24px -12px rgba(0,0,0,0.15); }
.brand-header::before { content:''; position:absolute; top:-40px; right:-30px; width:120px; height:120px; border-radius:50%; background:rgba(255,255,255,0.22); pointer-events:none; }
.brand-header-img-wrap { position:relative; z-index:2; width:64px; height:64px; flex-shrink:0; background:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; padding:8px; box-shadow:0 4px 12px -4px rgba(0,0,0,0.18); }
.brand-header-img { max-width:100%; max-height:100%; width:auto; height:auto; display:block; object-fit:contain; }
.brand-header-text { position:relative; z-index:2; flex:1; min-width:0; }
.brand-header-name { font-size:15px; font-weight:900; text-transform:uppercase; letter-spacing:0.2px; color:var(--noir); margin-bottom:3px; line-height:1.15; }
.brand-header-name a { color:var(--noir); text-decoration:none; border-bottom:2px solid rgba(0,0,0,0.35); padding-bottom:1px; transition:border-color .2s; display:inline-flex; align-items:center; gap:5px; }
.brand-header-name a:hover { border-bottom-color:var(--noir); }
.brand-header-name a i { font-size:12px; }
.brand-header-context { font-size:13px; color:#222; line-height:1.4; margin:0; }
.brand-header-context strong { color:var(--noir); font-weight:700; }

/* Garde brand-social masqué : on retire les RS de la card partenaire (cf. direction A) */
.brand-social { display:none; }

/* Anonymat banner */
.anonymity-banner { background:#fff; border:2px dashed var(--vert); border-radius:8px; padding:14px 18px; margin-top:14px; display:flex; gap:12px; align-items:center; font-size:13px; color:#444; line-height:1.45; }
.anonymity-banner i { font-size:24px; color:var(--vert); flex-shrink:0; }
.anonymity-banner strong { color:var(--noir); }

/* Responsive intermediate pages */
@media (max-width:900px) {
  .page-wrap { padding-left:32px; padding-right:32px; }
  .page-grid { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .page-wrap { padding-left:18px; padding-right:18px; padding-top:32px; }
  .form-card { padding:24px 20px; }
  .intro-card-body { padding:24px 20px; }
  .success-card { padding:36px 20px; }
  .success-card-title { font-size:24px; }
  .row-2cols { grid-template-columns:1fr; }
}

