/* =========================================================================
   page-approche.css — OAcom "Notre approche" immersive manifesto layout
   Brand-native: warm near-black + paper + signature yellow, "texture infinie"
   mountain motif, PolicePrincipale display / New Atten body, real OAcom
   photography & service pictos. No neon. Readable everywhere.
   Scoped under .oa-approche + body.layout-approche (chrome/full-bleed).
   ========================================================================= */

/* ---- Full-bleed: hide ALL normal template chrome on this layout ---- */
body.layout-approche {
  margin: 0;
  overflow-x: hidden;
  scroll-behavior: smooth;
  background: var(--ap-bg);
  color: var(--ap-paper);
  font-family: var(--oa-font-body, 'New Atten'), system-ui, -apple-system, "Segoe UI", sans-serif;

  /* warm OAcom palette */
  --ap-bg: #18160f;
  --ap-bg-2: #211d15;
  --ap-ink: #221d14;
  --ap-paper: #f4eee1;
  --ap-paper-2: #ece3d1;
  --ap-grey: #948b85;
  --ap-slate: #4a5458;
  --ap-yellow: #ffc901;
  --ap-yellow-deep: #e3ad00;
  --ap-muted: rgba(244, 238, 225, .80);
  --ap-muted-2: rgba(244, 238, 225, .60);
  --ap-ink-muted: rgba(34, 29, 20, .66);
  --ap-border: rgba(244, 238, 225, .16);
  --ap-border-ink: rgba(34, 29, 20, .12);
  --ap-ease: cubic-bezier(.16, 1, .3, 1);
  --ap-shadow: 0 40px 110px rgba(0, 0, 0, .42);
  --ap-radius: 30px;

  /* brand textures */
  --ap-tex-mountain: url('/images/textures/texture-infinie-montagne-oa.jpg');
  --ap-tex-weave: url('/images/textures/texture-infinie-oa.png');
  --ap-tex-paysage: url('/images/textures/paysage_montagne-N-B-oa-2.png');
}

/* Orphan UI from the old gamified concept — hidden on the new e-commerce layout */
body.layout-approche .oa-approche .xp-panel,
body.layout-approche .oa-approche .toast-zone,
body.layout-approche .oa-approche .side-progress { display: none !important; }

body.layout-approche .header,
body.layout-approche .container-header,
body.layout-approche .container-footer,
body.layout-approche .footer,
body.layout-approche .container-sidebar-left,
body.layout-approche .grid-child.container-sidebar-left,
body.layout-approche .container-below-top,
body.layout-approche .container-topbar,
body.layout-approche #rightOffcanvas,
body.layout-approche #lottie-loading-overlay,
body.layout-approche .oui-favorites-top-right,
body.layout-approche .oui-share-top-right {
  display: none !important;
}
/* Kept visible on this layout (user request): hamburger toggle (.menu-container/#toggle)
   + overlay menu (#overlay) + its animation blob (.menu-pseudo), the contact dropdown FAB
   (.oacom-contact-fab), and the accessibility button/panel (.oacom-a11y-toggle / .oui4all). */

body.layout-approche #main-content,
body.layout-approche main#main-content {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 0;
}

body.layout-approche .grid { display: block; }

/* ---- Scoped reset ---- */
.oa-approche * { box-sizing: border-box; }
.oa-approche a { color: inherit; text-decoration: none; }
.oa-approche button { font: inherit; }
.oa-approche img { max-width: 100%; }
.oa-approche h1, .oa-approche h2, .oa-approche h3 {
  font-family: var(--oa-font-heading, 'PolicePrincipale'), Georgia, serif;
  font-weight: 700;
}

/* ---- Atmosphere ---- */
.oa-approche .ap-noise { position: fixed; inset: 0; z-index: 900; pointer-events: none; opacity: .05; mix-blend-mode: overlay; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.oa-approche .ap-ambient { position: fixed; inset: 0; z-index: -8; background:
    radial-gradient(circle at 84% 6%, rgba(255, 201, 1, .18), transparent 34vw),
    radial-gradient(circle at 6% 82%, rgba(148, 139, 133, .22), transparent 40vw),
    var(--ap-bg); }
.oa-approche .cursor-light { position: fixed; z-index: 890; width: 30px; height: 30px; border-radius: 50%; border: 1px solid rgba(255, 201, 1, .55); pointer-events: none; transform: translate(-50%, -50%); mix-blend-mode: difference; transition: width .25s var(--ap-ease), height .25s var(--ap-ease), opacity .25s var(--ap-ease); opacity: 0; }
.oa-approche .cursor-light.is-big { width: 76px; height: 76px; }

/* ---- Floating nav (frameless vertical tab stack, top-right) ---- */
.oa-approche .oa-nav { position: fixed; z-index: 850; right: 18px; left: auto; top: 16px; transform: none; width: auto; max-width: calc(100vw - 32px); border: 0; background: transparent; backdrop-filter: none; border-radius: 0; padding: 0; box-shadow: none; }
.oa-approche .oa-nav > div { flex-direction: column; align-items: flex-end; gap: 2px; }
.oa-approche .brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 900; letter-spacing: -.06em; }
.oa-approche .brand-badge { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: var(--ap-yellow); color: #18160f; box-shadow: 0 0 0 6px rgba(255, 201, 1, .12); font-weight: 900; }
.oa-approche .nav-mini { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.oa-approche .nav-mini a { position: relative; padding: 6px 0 6px 18px; font-family: var(--oa-font-accent, 'Meutas'), sans-serif; font-size: .76rem; font-weight: 700; letter-spacing: .02em; color: rgba(244, 238, 225, .6); transition: .25s var(--ap-ease); white-space: nowrap; text-align: right; text-shadow: 0 1px 10px rgba(0, 0, 0, .65); }
.oa-approche .nav-mini a:hover { color: rgba(244, 238, 225, .95); }
.oa-approche .nav-mini a.active { color: var(--ap-paper); }
.oa-approche .nav-mini a::before { content: ''; position: absolute; left: 2px; top: 50%; transform: translateY(-50%) scale(0); width: 8px; height: 8px; border-radius: 50%; background: var(--ap-yellow); box-shadow: 0 0 12px rgba(255, 201, 1, .9); transition: transform .25s var(--ap-ease); }
.oa-approche .nav-mini a.active::before { transform: translateY(-50%) scale(1); }
.oa-approche .btn-oa { display: inline-flex; align-items: center; justify-content: center; gap: 9px; border: 0; border-radius: 999px; background: var(--ap-yellow); color: #18160f; font-weight: 800; font-size: .86rem; padding: 13px 22px; box-shadow: 0 16px 40px rgba(255, 201, 1, .22); transition: .25s var(--ap-ease); cursor: pointer; }
.oa-approche .btn-oa:hover { transform: translateY(-2px); box-shadow: 0 22px 56px rgba(255, 201, 1, .34); }
/* Inline button icon — counter the global `svg { position:absolute; top:0 }` rule */
.oa-approche .btn-oa .btn-icon { position: static !important; top: auto !important; width: 1.15em; height: 1.15em; flex: 0 0 auto; transition: transform .3s var(--ap-ease); }
/* Micro-interaction on the "Vendre en ligne" CTA: icon pops on hover, button presses on click */
.oa-approche .btn-oa:hover .btn-icon { transform: translateY(-1px) scale(1.16) rotate(-7deg); }
.oa-approche .btn-oa:active { transform: scale(.96); }

/* ---- Fulfilment flow: alternating cards on a central path ---- */
.oa-approche .fulfil-head { position: sticky; top: 0; z-index: 6; text-align: center; padding: 24px 12px 30px; margin: 0 0 clamp(20px, 4vw, 44px); background: linear-gradient(180deg, var(--ap-bg) 60%, rgba(24, 22, 15, .82) 82%, transparent); }
.oa-approche .fulfil-head__title { font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-weight: 700; line-height: 1; margin: 8px 0 0; font-size: clamp(2.1rem, 5vw, 3.8rem); color: var(--ap-paper); }
.oa-approche .fulfil-head__sub { display: block; margin-top: 4px; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: clamp(1.25rem, 3vw, 2.1rem); color: var(--ap-yellow); }
.oa-approche .fulfil { list-style: none; position: relative; max-width: 1040px; margin: 0 auto; padding: 0; }
.oa-approche .fulfil::before { content: ''; position: absolute; left: 50%; top: 6px; bottom: 6px; width: 2px; transform: translateX(-50%); background: linear-gradient(180deg, transparent, var(--ap-border) 6%, var(--ap-border) 94%, transparent); }
.oa-approche .fulfil-step { position: relative; width: 50%; padding: 0 38px; margin-bottom: clamp(18px, 3.4vw, 38px); box-sizing: border-box; }
.oa-approche .fulfil-step:nth-child(odd) { left: 0; text-align: right; }
.oa-approche .fulfil-step:nth-child(even) { left: 50%; text-align: left; }
.oa-approche .fulfil-node { position: absolute; top: 26px; width: 16px; height: 16px; border-radius: 50%; background: var(--ap-yellow); box-shadow: 0 0 0 6px rgba(255, 201, 1, .14), 0 0 18px rgba(255, 201, 1, .55); z-index: 2; }
.oa-approche .fulfil-step:nth-child(odd) .fulfil-node { right: -8px; }
.oa-approche .fulfil-step:nth-child(even) .fulfil-node { left: -8px; }
.oa-approche .fulfil-card { position: relative; display: inline-flex; gap: 16px; align-items: flex-start; text-align: left; max-width: 440px; border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .74); backdrop-filter: blur(20px); border-radius: 22px; padding: 18px 46px 18px 20px; box-shadow: var(--ap-shadow); color: inherit; font: inherit; cursor: pointer; transition: transform .3s var(--ap-ease), border-color .3s var(--ap-ease); }
.oa-approche .fulfil-card:hover { transform: translateY(-4px); border-color: rgba(255, 201, 1, .42); }
.oa-approche .fulfil-card:active { transform: translateY(-1px) scale(.985); }
.oa-approche .fulfil-card:focus-visible { outline: 2px solid var(--ap-yellow); outline-offset: 3px; }
.oa-approche .fulfil-icon { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: var(--ap-yellow); color: #18160f; transition: transform .3s var(--ap-ease); }
.oa-approche .fulfil-card:hover .fulfil-icon, .oa-approche .fulfil-card:focus-visible .fulfil-icon { transform: scale(1.08) rotate(-6deg); }
.oa-approche .fulfil-icon svg { position: static !important; top: auto !important; width: 24px; height: 24px; }
.oa-approche .fulfil-body { display: block; }
.oa-approche .fulfil-num { display: block; font-family: var(--oa-font-accent, 'Meutas'), sans-serif; font-size: .7rem; font-weight: 700; letter-spacing: .14em; color: var(--ap-yellow); margin-bottom: 4px; }
.oa-approche .fulfil-title { display: block; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: 1.12rem; line-height: 1.1; margin: 0 0 6px; color: var(--ap-paper); }
.oa-approche .fulfil-text { display: block; margin: 0; font-size: .9rem; line-height: 1.5; color: var(--ap-muted); }
.oa-approche .fulfil-more { position: absolute; top: 14px; right: 14px; width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 1.05rem; line-height: 1; font-weight: 700; color: #18160f; background: var(--ap-yellow); opacity: 0; transform: scale(.5) rotate(-90deg); transition: opacity .25s var(--ap-ease), transform .25s var(--ap-ease); }
.oa-approche .fulfil-card:hover .fulfil-more, .oa-approche .fulfil-card:focus-visible .fulfil-more { opacity: 1; transform: scale(1) rotate(0); }

@media (max-width: 820px) {
  .oa-approche .fulfil::before { left: 19px; }
  .oa-approche .fulfil-step,
  .oa-approche .fulfil-step:nth-child(odd),
  .oa-approche .fulfil-step:nth-child(even) { width: 100%; left: 0; text-align: left; padding: 0 0 0 50px; }
  .oa-approche .fulfil-step:nth-child(odd) .fulfil-node,
  .oa-approche .fulfil-step:nth-child(even) .fulfil-node { left: 11px; right: auto; }
  .oa-approche .fulfil-card { max-width: none; }
}

/* ---- Left-corner step popup ---- */
.oa-approche .fulfil-pop { position: fixed; left: 22px; bottom: 22px; z-index: 870; width: min(360px, calc(100vw - 44px)); border: 1px solid var(--ap-border); background: rgba(20, 18, 12, .94); backdrop-filter: blur(22px); border-radius: 22px; padding: 22px 22px 20px; box-shadow: var(--ap-shadow); transform: translateY(18px) scale(.96); opacity: 0; transition: transform .32s var(--ap-ease), opacity .32s var(--ap-ease); pointer-events: none; }
.oa-approche .fulfil-pop.is-open { transform: none; opacity: 1; pointer-events: auto; }
.oa-approche .fulfil-pop[hidden] { display: none; }
.oa-approche .fulfil-pop__close { position: absolute; top: 10px; right: 12px; border: 0; background: transparent; color: var(--ap-muted); font-size: 1.5rem; line-height: 1; cursor: pointer; padding: 4px 6px; }
.oa-approche .fulfil-pop__close:hover { color: var(--ap-paper); }
.oa-approche .fulfil-pop__num { font-family: var(--oa-font-accent, 'Meutas'), sans-serif; font-size: .7rem; font-weight: 700; letter-spacing: .14em; color: var(--ap-yellow); }
.oa-approche .fulfil-pop__title { font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: 1.3rem; line-height: 1.1; margin: 6px 0 8px; color: var(--ap-paper); }
.oa-approche .fulfil-pop__text { margin: 0 0 16px; font-size: .92rem; line-height: 1.55; color: var(--ap-muted); }
.oa-approche .fulfil-pop__link { display: inline-flex; align-items: center; gap: 8px; border-radius: 999px; background: var(--ap-yellow); color: #18160f; font-weight: 800; font-size: .82rem; padding: 10px 16px; transition: transform .25s var(--ap-ease), box-shadow .25s var(--ap-ease); }
.oa-approche .fulfil-pop__link:hover { transform: translateX(3px); box-shadow: 0 14px 36px rgba(255, 201, 1, .28); }
.oa-approche .fulfil-pop__link svg { position: static !important; top: auto !important; width: 16px; height: 16px; flex: 0 0 auto; }

/* ============================================================
   Single-screen hero: "tout est lié" → (click) → "tout s'enchaîne" + arc
   ============================================================ */
.oa-approche .hero { padding: 56px 0 40px !important; }
.oa-approche .hero-stage { position: relative; width: min(1000px, 92vw); height: clamp(440px, 66svh, 660px); margin: 0 auto; }

/* Centred core (eyebrow + morphing title + lead + CTA) */
.oa-approche .hero-core { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: min(640px, 90%); text-align: center; z-index: 3; }
.oa-approche .hero-eyebrow, .oa-approche .hero-lead, .oa-approche .hero-cta { transition: opacity .4s var(--ap-ease), transform .4s var(--ap-ease); }

/* Morphing title — both states stacked in one grid cell, crossfaded */
.oa-approche .hero-title { display: grid; place-items: center; }
.oa-approche .hero-title__lie, .oa-approche .hero-title__chain { grid-area: 1 / 1; transition: opacity .55s var(--ap-ease), transform .55s var(--ap-ease); }
.oa-approche .hero-title__chain { opacity: 0; transform: translateY(16px) scale(.94); color: var(--ap-paper); font-size: clamp(1.8rem, 4.6vw, 3.2rem); line-height: 1.05; }
.oa-approche .hero-title__sub { display: block; margin-top: 2px; font-size: clamp(1.1rem, 2.6vw, 1.7rem); color: var(--ap-yellow); }

/* Arc of steps around the title */
.oa-approche .arc { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.oa-approche .arc::before { content: ''; position: absolute; left: 50%; top: 50%; width: 78%; height: 78%; transform: translate(-50%, -50%); border: 1px dashed var(--ap-border); border-radius: 50%; opacity: 0; transition: opacity .6s var(--ap-ease); }
.oa-approche .arc-step { position: absolute; left: var(--x); top: var(--y); transform: translate(-50%, -50%) scale(.5); width: 132px; display: flex; flex-direction: column; align-items: center; gap: 8px; background: transparent; border: 0; padding: 0; cursor: pointer; color: inherit; font: inherit; opacity: 0; pointer-events: none; transition: opacity .5s var(--ap-ease), transform .5s var(--ap-ease); }
.oa-approche .arc-node { width: 66px; height: 66px; border-radius: 50%; display: grid; place-items: center; background: rgba(24, 22, 15, .82); border: 1px solid var(--ap-border); color: var(--ap-yellow); box-shadow: var(--ap-shadow); backdrop-filter: blur(14px); transition: transform .25s var(--ap-ease), border-color .25s var(--ap-ease), background .25s var(--ap-ease); }
.oa-approche .arc-node svg { position: static !important; top: auto !important; width: 28px; height: 28px; }
.oa-approche .arc-label { font-family: var(--oa-font-accent, 'Meutas'), sans-serif; font-size: .74rem; line-height: 1.2; color: var(--ap-paper); max-width: 132px; text-shadow: 0 1px 8px rgba(0, 0, 0, .6); }
.oa-approche .arc-label b { display: block; font-size: .62rem; letter-spacing: .12em; color: var(--ap-yellow); margin-bottom: 2px; }
/* Micro-interactions */
.oa-approche .arc-step:hover .arc-node, .oa-approche .arc-step:focus-visible .arc-node { transform: scale(1.14) translateY(-3px); border-color: rgba(255, 201, 1, .55); background: rgba(36, 33, 22, .92); }
.oa-approche .arc-step:active .arc-node { transform: scale(1.02); }
.oa-approche .arc-step:focus-visible { outline: none; }
.oa-approche .arc-step:focus-visible .arc-node { box-shadow: 0 0 0 3px var(--ap-yellow), var(--ap-shadow); }

/* ---- State: chain (after clicking "Vendre en ligne") ---- */
.oa-approche .hero-stage[data-state="chain"] .hero-eyebrow,
.oa-approche .hero-stage[data-state="chain"] .hero-lead,
.oa-approche .hero-stage[data-state="chain"] .hero-cta { opacity: 0 !important; transform: translateY(10px) !important; pointer-events: none; }
.oa-approche .hero-stage[data-state="chain"] .hero-title__lie { opacity: 0; transform: translateY(-16px) scale(.94); }
.oa-approche .hero-stage[data-state="chain"] .hero-title__chain { opacity: 1; transform: none; }
.oa-approche .hero-stage[data-state="chain"] .arc::before { opacity: 1; }
.oa-approche .hero-stage[data-state="chain"] .arc-step { opacity: 1; transform: translate(-50%, -50%) scale(1); pointer-events: auto; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(1) { transition-delay: .06s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(2) { transition-delay: .13s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(3) { transition-delay: .20s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(4) { transition-delay: .27s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(5) { transition-delay: .34s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(6) { transition-delay: .41s; }
.oa-approche .hero-stage[data-state="chain"] .arc-step:nth-child(7) { transition-delay: .48s; }

/* Mobile: ring doesn't fit — stack the steps below the title (scroll allowed here) */
@media (max-width: 760px) {
  .oa-approche .hero-stage { height: auto; }
  .oa-approche .hero-core { position: relative; left: auto; top: auto; transform: none; width: 100%; }
  .oa-approche .arc { position: relative; inset: auto; display: grid; gap: 12px; margin-top: 28px; }
  .oa-approche .arc::before { display: none; }
  .oa-approche .arc-step { position: relative; left: auto; top: auto; transform: none; width: 100%; flex-direction: row; gap: 14px; text-align: left; }
  .oa-approche .hero-stage[data-state="chain"] .arc-step { transform: none; }
}
.oa-approche .btn-ghost { display: inline-flex; align-items: center; justify-content: center; gap: 9px; border-radius: 999px; background: rgba(244, 238, 225, .08); color: var(--ap-paper); border: 1px solid var(--ap-border); font-weight: 700; font-size: .86rem; padding: 13px 22px; transition: .25s var(--ap-ease); cursor: pointer; }
.oa-approche .btn-ghost:hover { background: rgba(244, 238, 225, .16); transform: translateY(-2px); }

/* ---- Side progress + toasts + xp HUD ---- */
.oa-approche .side-progress { position: fixed; right: 18px; top: 50%; transform: translateY(-50%); z-index: 840; display: grid; gap: 9px; }
.oa-approche .side-progress span { width: 7px; height: 7px; border-radius: 999px; background: rgba(244, 238, 225, .26); transition: .35s var(--ap-ease); }
.oa-approche .side-progress span.active { height: 40px; background: linear-gradient(180deg, var(--ap-yellow), var(--ap-yellow-deep)); }

.oa-approche .toast-zone { position: fixed; z-index: 860; right: 18px; top: 78px; width: min(360px, calc(100vw - 36px)); display: grid; gap: 10px; pointer-events: none; }
.oa-approche .oa-toast { display: flex; gap: 12px; align-items: flex-start; border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .9); backdrop-filter: blur(24px); border-radius: 20px; padding: 13px 14px; box-shadow: var(--ap-shadow); transform: translateX(120%); opacity: 0; }
.oa-approche .oa-toast-icon { width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; background: var(--ap-yellow); color: #18160f; font-weight: 900; flex: 0 0 auto; }
.oa-approche .oa-toast strong { display: block; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; letter-spacing: -.01em; line-height: 1.1; font-size: 1.02rem; }
.oa-approche .oa-toast p { margin: 5px 0 0; color: var(--ap-muted); font-size: .82rem; line-height: 1.4; }

.oa-approche .xp-panel { position: fixed; z-index: 830; left: 18px; bottom: 18px; width: min(300px, calc(100vw - 36px)); border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .82); backdrop-filter: blur(24px); border-radius: 22px; padding: 14px; box-shadow: var(--ap-shadow); }
.oa-approche .xp-label { font-family: var(--oa-font-accent, 'Meutas'), sans-serif; text-transform: uppercase; letter-spacing: .16em; color: var(--ap-yellow); font-size: .64rem; font-weight: 700; }
.oa-approche .xp-score { font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: 1.4rem; font-weight: 700; letter-spacing: -.02em; }
.oa-approche .xp-bar { height: 8px; border-radius: 999px; background: rgba(244, 238, 225, .12); overflow: hidden; margin-top: 10px; }
.oa-approche .xp-bar span { display: block; height: 100%; width: 0; border-radius: inherit; background: linear-gradient(90deg, var(--ap-yellow-deep), var(--ap-yellow)); transition: .55s var(--ap-ease); }
.oa-approche .xp-list { display: grid; gap: 7px; margin-top: 12px; }
.oa-approche .xp-item { display: flex; gap: 9px; align-items: center; color: var(--ap-muted-2); font-size: .78rem; font-weight: 600; }
.oa-approche .xp-item i { font-style: normal; width: 16px; height: 16px; border-radius: 50%; display: grid; place-items: center; border: 1px solid var(--ap-border); font-size: .6rem; }
.oa-approche .xp-item.done { color: var(--ap-paper); }
.oa-approche .xp-item.done i { background: var(--ap-yellow); border-color: var(--ap-yellow); color: #18160f; }

/* ---- Shared section primitives ---- */
.oa-approche .section { position: relative; isolation: isolate; overflow: hidden; }
.oa-approche .eyebrow { display: inline-flex; align-items: center; gap: 9px; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); border-radius: 999px; padding: 8px 14px; color: var(--ap-muted); font-family: var(--oa-font-accent, 'Meutas'), sans-serif; text-transform: uppercase; letter-spacing: .16em; font-size: .68rem; font-weight: 700; }
.oa-approche .eyebrow:before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--ap-yellow); box-shadow: 0 0 0 6px rgba(255, 201, 1, .16); }
.oa-approche .eyebrow.dark { border-color: var(--ap-border-ink); background: rgba(34, 29, 20, .04); color: var(--ap-slate); }
.oa-approche .display-xl { font-size: clamp(3.2rem, 8vw, 7rem); line-height: 1.0; letter-spacing: -.015em; font-weight: 700; }
.oa-approche .display-lg { font-size: clamp(2.4rem, 5vw, 4.6rem); line-height: 1.02; letter-spacing: -.01em; font-weight: 700; }
.oa-approche .lead-copy { font-size: clamp(1.04rem, 1.4vw, 1.2rem); line-height: 1.7; color: var(--ap-muted); font-family: var(--oa-font-body, 'New Atten'), sans-serif; }
.oa-approche .text-panel { border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .74); backdrop-filter: blur(20px); border-radius: var(--ap-radius); padding: clamp(24px, 4vw, 44px); box-shadow: var(--ap-shadow); }
.oa-approche .text-panel.light { background: rgba(244, 238, 225, .92); color: var(--ap-ink); border-color: var(--ap-border-ink); box-shadow: 0 34px 90px rgba(34, 29, 20, .16); }
.oa-approche .text-panel.light .lead-copy, .oa-approche .light-copy { color: var(--ap-ink-muted); }
.oa-approche .hairline { height: 1px; background: linear-gradient(90deg, transparent, var(--ap-border), transparent); }
.oa-approche .chip { display: inline-flex; align-items: center; gap: 8px; border-radius: 999px; padding: 8px 12px; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); color: var(--ap-muted); font-weight: 600; font-size: .76rem; }

/* ---- Hero ---- */
.oa-approche .hero { min-height: 100svh; display: grid; place-items: center; padding: 150px 0 90px; }
.oa-approche .hero-bg { position: absolute; inset: 0; z-index: -6; background:
    linear-gradient(180deg, rgba(24, 22, 15, .82), rgba(24, 22, 15, .72) 45%, rgba(24, 22, 15, .94)),
    var(--ap-tex-mountain) center/cover no-repeat; filter: saturate(.2); }
.oa-approche .hero-grid { position: absolute; inset: -20%; z-index: -4; opacity: .12; background-image: linear-gradient(rgba(244, 238, 225, .14) 1px, transparent 1px), linear-gradient(90deg, rgba(244, 238, 225, .14) 1px, transparent 1px); background-size: 84px 84px; -webkit-mask-image: radial-gradient(circle at 50% 45%, #000, transparent 66%); mask-image: radial-gradient(circle at 50% 45%, #000, transparent 66%); transform: perspective(900px) rotateX(64deg) translateY(16%); transform-origin: 50% 100%; }
.oa-approche .hero h1 span { display: block; }
.oa-approche .hero .outline { color: var(--ap-paper); }
.oa-approche .hero .shine { color: var(--ap-yellow); }
/* Hero headline forced into the brand "big fat" headline font (PolicePrincipale = Meutas Black) */
.oa-approche .hero h1.display-xl,
.oa-approche .hero h1.display-xl .hw { font-family: 'PolicePrincipale', var(--oa-font-heading, 'PolicePrincipale'), sans-serif !important; font-weight: 700; }
/* Per-word reveal: each word starts yellow (JS fades non-stay words to white);
   relié keeps the yellow. inline-block so the y-axis entrance tween works. */
.oa-approche .hero h1.display-xl .hw { display: inline-block; color: var(--ap-yellow); }
.oa-approche .hero-pills { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-top: 32px; }
.oa-approche .hero-objects { position: absolute; inset: 0; z-index: 3; pointer-events: none; }
.oa-approche .hero-card { position: absolute; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); box-shadow: var(--ap-shadow); border-radius: 24px; overflow: hidden; }
.oa-approche .hero-card img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.92) contrast(1.02); }
.oa-approche .hc1 { width: 210px; height: 280px; left: 5vw; top: 20vh; transform: rotate(-6deg); }
.oa-approche .hc2 { width: 300px; height: 195px; right: 5vw; top: 19vh; transform: rotate(5deg); }
.oa-approche .hc3 { width: 245px; height: 168px; left: 11vw; bottom: 12vh; transform: rotate(4deg); }
.oa-approche .hc4 { width: 195px; height: 248px; right: 12vw; bottom: 10vh; transform: rotate(-6deg); }
.oa-approche .floating-chip { position: absolute; z-index: 5; border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .66); backdrop-filter: blur(14px); border-radius: 999px; padding: 10px 15px; font-family: var(--oa-font-accent, 'Meutas'), sans-serif; font-size: .76rem; font-weight: 700; color: var(--ap-paper); box-shadow: 0 14px 40px rgba(0, 0, 0, .3); }
.oa-approche .floating-chip:before { content: ""; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--ap-yellow); margin-right: 8px; vertical-align: middle; }
.oa-approche .fc1 { left: 26vw; top: 20vh; } .oa-approche .fc2 { right: 24vw; bottom: 20vh; } .oa-approche .fc3 { left: 46vw; bottom: 9vh; }

/* ---- Dark section texture helper ---- */
.oa-approche .chain, .oa-approche .silos, .oa-approche .method, .oa-approche .delivery { background: var(--ap-bg); }
.oa-approche .chain-bg, .oa-approche .silos-bg, .oa-approche .method-bg { position: absolute; inset: 0; z-index: -4; background:
    linear-gradient(180deg, rgba(24, 22, 15, .86), rgba(24, 22, 15, .96)),
    var(--ap-tex-weave) center/cover no-repeat; opacity: .9; }

/* ---- Chain / Notre regard ---- */
.oa-approche .chain { min-height: 115svh; padding: 120px 0; }
.oa-approche .journey-stage { position: relative; min-height: 740px; margin-top: 52px; }
.oa-approche .journey-phone { position: absolute; left: 50%; top: 30px; transform: translateX(-50%); width: 330px; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); backdrop-filter: blur(18px); border-radius: 44px; padding: 14px; box-shadow: var(--ap-shadow); }
.oa-approche .phone-screen { border-radius: 32px; background: #14120c; overflow: hidden; min-height: 630px; }
.oa-approche .phone-image { height: 200px; background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .55)), url('/images/divers/telephone-oacom.jpg') center/cover; }
.oa-approche .phone-content { padding: 20px; }
.oa-approche .phone-content h3 { font-size: 1.95rem; line-height: 1.02; letter-spacing: -.01em; }
.oa-approche .phone-content p { font-size: .86rem; line-height: 1.5; color: var(--ap-muted-2); }
.oa-approche .action-stack { display: grid; gap: 10px; margin-top: 18px; }
.oa-approche .action-btn { display: block; width: 100%; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); color: var(--ap-paper); text-align: left; border-radius: 16px; padding: 14px 15px; font-weight: 700; font-size: .84rem; cursor: pointer; position: relative; overflow: hidden; transition: .22s var(--ap-ease); }
.oa-approche .action-btn:hover { background: var(--ap-yellow); color: #18160f; transform: translateX(5px); }
.oa-approche .action-btn.done { background: rgba(255, 201, 1, .16); border-color: rgba(255, 201, 1, .5); color: var(--ap-paper); }
.oa-approche .ops-board, .oa-approche .client-board { position: absolute; width: min(460px, 36vw); border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .06); backdrop-filter: blur(22px); border-radius: 34px; padding: 15px; box-shadow: var(--ap-shadow); }
.oa-approche .client-board { left: 3vw; top: 130px; } .oa-approche .ops-board { right: 3vw; top: 100px; }
.oa-approche .board-screen { border-radius: 26px; background: var(--ap-paper); color: var(--ap-ink); padding: 22px; min-height: 430px; }
.oa-approche .board-title { font-size: 1.85rem; line-height: 1.04; letter-spacing: -.01em; margin: 0; }
.oa-approche .signal-list { display: grid; gap: 10px; margin-top: 18px; }
.oa-approche .signal { display: flex; gap: 10px; align-items: center; border-radius: 15px; background: #fff; border: 1px solid var(--ap-border-ink); padding: 12px; font-size: .82rem; font-weight: 600; color: var(--ap-ink); box-shadow: 0 8px 22px rgba(34, 29, 20, .05); }
.oa-approche .signal i { width: 9px; height: 9px; border-radius: 50%; background: var(--ap-yellow); box-shadow: 0 0 0 5px rgba(255, 201, 1, .16); flex: 0 0 auto; }
.oa-approche .metric-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 18px; }
.oa-approche .metric { border-radius: 17px; background: var(--ap-paper-2); border: 1px solid var(--ap-border-ink); padding: 14px; color: var(--ap-ink); }
.oa-approche .metric small { display: block; font-weight: 700; color: var(--ap-slate); font-size: .7rem; }
.oa-approche .metric strong { display: block; margin-top: 4px; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: 1.5rem; letter-spacing: -.01em; }
.oa-approche .connect-line { position: absolute; height: 2px; background: linear-gradient(90deg, transparent, var(--ap-yellow), transparent); opacity: .5; transform-origin: left center; }
.oa-approche .cl1 { width: 32vw; left: 28vw; top: 330px; transform: rotate(-8deg); }
.oa-approche .cl2 { width: 31vw; right: 27vw; top: 365px; transform: rotate(10deg); }
.oa-approche .cl3 { width: 27vw; left: 37vw; top: 575px; transform: rotate(6deg); }
.oa-approche .pulse-dot { position: absolute; width: 11px; height: 11px; border-radius: 50%; background: var(--ap-yellow); box-shadow: 0 0 0 7px rgba(255, 201, 1, .12), 0 0 28px rgba(255, 201, 1, .6); }
.oa-approche .pd1 { left: 31vw; top: 323px; } .oa-approche .pd2 { right: 34vw; top: 358px; } .oa-approche .pd3 { left: 55vw; top: 570px; }

/* ---- Delivery 3D world — copy ALWAYS on top & solid ---- */
.oa-approche .delivery { min-height: 560vh; overflow: clip; }
.oa-approche .delivery-sticky { position: sticky; top: 0; height: 100svh; perspective: 1400px; overflow: hidden; }
.oa-approche .delivery-world { position: absolute; inset: 0; transform-style: preserve-3d; will-change: transform; }
.oa-approche .delivery-bg { position: absolute; inset: -15%; background: linear-gradient(180deg, rgba(24, 22, 15, .6), rgba(24, 22, 15, .9)), var(--ap-tex-paysage) center/cover; transform: translateZ(-650px) scale(1.72); filter: saturate(.2); }
.oa-approche .delivery-road { position: absolute; left: 50%; top: 50%; width: 150vw; height: 135vh; opacity: .18; transform: translate(-50%, -50%) translateZ(-120px) rotate(-7deg); background-image: url("data:image/svg+xml,%3Csvg width='1400' height='900' viewBox='0 0 1400 900' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M70 630 C 250 170, 500 820, 735 360 S 1100 190, 1330 570' stroke='%23ffc901' stroke-width='2' stroke-dasharray='9 18'/%3E%3C/svg%3E"); background-size: 100% 100%; background-repeat: no-repeat; }
.oa-approche .delivery-copy { position: absolute; width: min(600px, 88vw); z-index: 30; will-change: transform, opacity; }
.oa-approche .delivery-copy .text-panel { background: rgba(20, 18, 12, .94); border-color: rgba(255, 201, 1, .18); }
.oa-approche .dc1 { left: 7vw; top: 22vh; } .oa-approche .dc2 { right: 7vw; top: 20vh; text-align: right; } .oa-approche .dc3 { left: 8vw; bottom: 15vh; } .oa-approche .dc4 { right: 8vw; bottom: 13vh; text-align: right; } .oa-approche .dc5 { left: 50%; top: 50%; transform: translate(-50%, -50%); text-align: center; width: min(820px, 92vw); }
.oa-approche .delivery-object { position: absolute; z-index: 8; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .05); border-radius: 30px; box-shadow: var(--ap-shadow); overflow: hidden; opacity: .5; will-change: transform, opacity; transform-style: preserve-3d; }
.oa-approche .delivery-object img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.35) saturate(.7); }
.oa-approche .do1 { width: 38vw; height: 54vh; left: 56vw; top: 22vh; transform: translateZ(120px) rotate(4deg); }
.oa-approche .do2 { width: 26vw; height: 35vh; left: 11vw; top: 53vh; transform: translateZ(360px) rotate(-7deg); }
.oa-approche .do3 { width: 32vw; height: 45vh; left: 33vw; top: 16vh; transform: translateZ(560px) rotate(7deg); }
.oa-approche .do4 { width: 24vw; height: 54vh; left: 72vw; top: 34vh; transform: translateZ(760px) rotate(-6deg); }
.oa-approche .do5 { width: 35vw; height: 39vh; left: 4vw; top: 12vh; transform: translateZ(960px) rotate(6deg); }
.oa-approche .floating-ui { position: absolute; z-index: 25; display: block; width: min(330px, 30vw); border: 1px solid var(--ap-border); background: rgba(20, 18, 12, .92); backdrop-filter: blur(20px); border-radius: 24px; padding: 16px; box-shadow: var(--ap-shadow); will-change: transform, opacity; cursor: pointer; transition: border-color .25s var(--ap-ease); }
.oa-approche .floating-ui:hover { border-color: var(--ap-yellow); }
.oa-approche .floating-ui.light { background: rgba(244, 238, 225, .94); color: var(--ap-ink); border-color: var(--ap-border-ink); }
.oa-approche .floating-ui h3 { font-size: 1.4rem; line-height: 1.05; letter-spacing: -.01em; margin: 12px 0 0; }
.oa-approche .floating-ui p { font-size: .82rem; line-height: 1.5; color: var(--ap-muted); margin: 8px 0 0; }
.oa-approche .floating-ui.light p { color: var(--ap-ink-muted); }
.oa-approche .fu-pic { width: 46px; height: 46px; border-radius: 13px; background: var(--ap-yellow); padding: 9px; object-fit: contain; display: block; }
.oa-approche .fu1 { left: 47vw; top: 62vh; transform: translateZ(480px); }
.oa-approche .fu2 { left: 15vw; top: 18vh; transform: translateZ(680px); }
.oa-approche .fu3 { left: 57vw; top: 18vh; transform: translateZ(880px); }
.oa-approche .fu4 { left: 26vw; top: 66vh; transform: translateZ(1080px); }
.oa-approche .fu5 { left: 63vw; top: 57vh; transform: translateZ(1280px); }
.oa-approche .video-card { position: absolute; z-index: 28; left: 50%; top: 50%; width: min(840px, 82vw); height: min(520px, 62vh); border-radius: 40px; overflow: hidden; border: 1px solid var(--ap-border); background: #111; box-shadow: var(--ap-shadow); transform: translate(-50%, -50%) translateZ(1450px); cursor: pointer; will-change: transform, opacity; }
.oa-approche .video-card img { width: 100%; height: 100%; object-fit: cover; }
.oa-approche .video-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0, 0, 0, .1), rgba(0, 0, 0, .72)); }
.oa-approche .play-btn { position: absolute; z-index: 3; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 96px; height: 96px; border-radius: 50%; display: grid; place-items: center; background: var(--ap-yellow); box-shadow: 0 16px 50px rgba(255, 201, 1, .3); }
.oa-approche .play-btn:before { content: ""; width: 0; height: 0; border-top: 15px solid transparent; border-bottom: 15px solid transparent; border-left: 23px solid #18160f; margin-left: 5px; }
.oa-approche .video-caption { position: absolute; z-index: 4; left: 34px; right: 34px; bottom: 30px; }
.oa-approche .video-caption h2 { font-size: clamp(2.2rem, 5vw, 4.6rem); line-height: 1.0; letter-spacing: -.01em; margin: 0; }
.oa-approche .video-caption p { max-width: 560px; color: var(--ap-muted); line-height: 1.6; margin: 16px 0 0; }
.oa-approche .delivery-fade { position: absolute; inset: auto 0 0 0; height: 26vh; background: linear-gradient(180deg, transparent, var(--ap-bg)); z-index: 40; pointer-events: none; }

/* ---- Split real / Les 4 piliers (light) ---- */
.oa-approche .split-real { padding: 130px 0; background: var(--ap-paper); color: var(--ap-ink); }
.oa-approche .real-bg { position: absolute; inset: 0; z-index: 0; opacity: .14; background: var(--ap-tex-mountain) top center/cover no-repeat; -webkit-mask-image: linear-gradient(180deg, #000, transparent 55%); mask-image: linear-gradient(180deg, #000, transparent 55%); }
.oa-approche .split-real .container { z-index: 2; }
.oa-approche .real-card { position: relative; z-index: 2; display: block; border-radius: 28px; background: #fff; border: 1px solid var(--ap-border-ink); padding: clamp(22px, 3vw, 32px); box-shadow: 0 22px 60px rgba(34, 29, 20, .08); min-height: 100%; color: var(--ap-ink); transition: .25s var(--ap-ease); }
.oa-approche .real-card:hover { transform: translateY(-6px); box-shadow: 0 30px 80px rgba(34, 29, 20, .16); }
.oa-approche .real-icon { width: 64px; height: 64px; border-radius: 18px; display: grid; place-items: center; background: var(--ap-yellow); }
.oa-approche .real-icon img { width: 60%; height: 60%; object-fit: contain; }
.oa-approche .real-card h3 { font-size: 1.9rem; line-height: 1.0; letter-spacing: -.01em; margin: 20px 0 0; }
.oa-approche .real-card p { line-height: 1.6; color: var(--ap-ink-muted); margin: 12px 0 0; }
.oa-approche .real-card ul { list-style: none; padding: 0; margin: 16px 0 0; display: grid; gap: 9px; }
.oa-approche .real-card li { display: flex; gap: 9px; align-items: flex-start; color: var(--ap-slate); font-size: .92rem; font-weight: 600; }
.oa-approche .real-card li:before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--ap-yellow); margin-top: .45rem; box-shadow: 0 0 0 5px rgba(255, 201, 1, .14); flex: 0 0 auto; }
.oa-approche .real-card .real-more { display: inline-flex; margin-top: 18px; font-weight: 800; font-size: .82rem; color: var(--ap-ink); border-bottom: 2px solid var(--ap-yellow); padding-bottom: 2px; }

/* ---- Silos / Nos expertises (dark) ---- */
.oa-approche .silos { min-height: 120svh; padding: 130px 0; }
.oa-approche .silo-map { position: relative; height: 640px; margin-top: 46px; border-radius: 40px; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .04); backdrop-filter: blur(14px); overflow: hidden; box-shadow: var(--ap-shadow); }
.oa-approche .silo-node { position: absolute; width: 185px; min-height: 130px; border: 1px solid var(--ap-border); background: rgba(24, 22, 15, .82); backdrop-filter: blur(14px); border-radius: 24px; padding: 16px; cursor: pointer; transition: .25s var(--ap-ease); box-shadow: 0 22px 60px rgba(0, 0, 0, .35); color: var(--ap-paper); text-align: left; }
.oa-approche .silo-node:hover { transform: translateY(-8px) scale(1.03); border-color: var(--ap-yellow); }
.oa-approche .silo-pic { width: 38px; height: 38px; border-radius: 11px; background: #fff; padding: 7px; object-fit: contain; display: block; margin-bottom: 12px; }
.oa-approche .silo-node strong { display: block; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-size: 1.1rem; line-height: 1.0; letter-spacing: -.01em; font-weight: 700; }
.oa-approche .silo-node span { display: block; margin-top: 7px; color: var(--ap-muted-2); font-size: .76rem; line-height: 1.35; }
.oa-approche .n-crm { left: 8%; top: 12%; } .oa-approche .n-erp { right: 10%; top: 11%; } .oa-approche .n-stock { left: 14%; bottom: 13%; } .oa-approche .n-team { right: 18%; bottom: 14%; }
.oa-approche .n-web { left: 50%; top: 50%; transform: translate(-50%, -50%); background: var(--ap-yellow); color: #18160f; border-color: var(--ap-yellow); }
.oa-approche .n-web .silo-pic { background: #18160f; }
.oa-approche .n-web span { color: rgba(24, 22, 15, .7); }
.oa-approche .n-web:hover { transform: translate(-50%, -56%) scale(1.04); }
.oa-approche .svg-lines { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.oa-approche .silo-panel { position: absolute; left: 50%; bottom: 24px; transform: translateX(-50%); width: min(760px, calc(100% - 48px)); border-radius: 24px; background: rgba(20, 18, 12, .9); border: 1px solid var(--ap-border); backdrop-filter: blur(18px); padding: 18px 22px; }
.oa-approche .silo-panel strong { font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; letter-spacing: -.01em; font-size: 1.15rem; }
.oa-approche .silo-panel p { margin: 6px 0 0; color: var(--ap-muted); line-height: 1.5; }
.oa-approche .silo-panel a { display: inline-flex; margin-top: 10px; font-weight: 800; font-size: .82rem; color: var(--ap-yellow); }

/* ---- Checkout / Travailler avec OAcom (light) ---- */
.oa-approche .checkout { padding: 130px 0; background: var(--ap-paper); color: var(--ap-ink); }
.oa-approche .checkout-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 26px; margin-top: 46px; align-items: stretch; }
.oa-approche .shop-card, .oa-approche .backoffice-card { border-radius: 34px; border: 1px solid var(--ap-border-ink); background: #fff; box-shadow: 0 22px 60px rgba(34, 29, 20, .08); padding: clamp(20px, 3vw, 32px); overflow: hidden; color: var(--ap-ink); }
.oa-approche .shop-hero { height: 210px; border-radius: 24px; background: linear-gradient(180deg, rgba(0, 0, 0, .04), rgba(0, 0, 0, .42)), url('/images/divers/image-marque-oacom.jpg') center/cover; margin-bottom: 20px; }
.oa-approche .option-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; border: 1px solid var(--ap-border-ink); background: var(--ap-paper-2); border-radius: 18px; padding: 15px; margin-top: 10px; cursor: pointer; transition: .22s var(--ap-ease); color: var(--ap-ink); text-align: left; width: 100%; }
.oa-approche .option-row strong { font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-weight: 700; }
.oa-approche .option-row:hover { transform: translateX(6px); background: #fff; }
.oa-approche .option-row.active { background: var(--ap-ink); color: var(--ap-paper); transform: scale(1.02); }
.oa-approche .option-row small { display: block; color: var(--ap-slate); font-weight: 600; } .oa-approche .option-row.active small { color: rgba(244, 238, 225, .66); }
.oa-approche .pay-line { height: 10px; border-radius: 999px; background: rgba(34, 29, 20, .1); overflow: hidden; margin-top: 14px; }
.oa-approche .pay-line span { height: 100%; width: 0; display: block; border-radius: inherit; background: linear-gradient(90deg, var(--ap-yellow-deep), var(--ap-yellow)); transition: .6s var(--ap-ease); }
.oa-approche .backoffice-card { background: var(--ap-bg-2); color: var(--ap-paper); border-color: var(--ap-border); }
.oa-approche .event-log { display: grid; gap: 10px; margin-top: 18px; }
.oa-approche .event { display: flex; gap: 11px; align-items: flex-start; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .05); border-radius: 18px; padding: 13px; opacity: .55; transition: .25s var(--ap-ease); }
.oa-approche .event.active { opacity: 1; background: rgba(255, 201, 1, .12); border-color: rgba(255, 201, 1, .4); transform: translateX(5px); }
.oa-approche .event i { width: 28px; height: 28px; border-radius: 10px; background: var(--ap-yellow); color: #18160f; display: grid; place-items: center; font-style: normal; font-weight: 900; flex: 0 0 auto; }
.oa-approche .event strong { display: block; line-height: 1.1; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; } .oa-approche .event span { display: block; margin-top: 4px; color: var(--ap-muted); font-size: .8rem; line-height: 1.4; }

/* ---- Method / Notre méthode (dark) ---- */
.oa-approche .method { padding: 130px 0; min-height: 100svh; }
.oa-approche .method-card { display: block; border: 1px solid var(--ap-border); background: rgba(244, 238, 225, .05); backdrop-filter: blur(16px); border-radius: 28px; padding: 26px; min-height: 260px; box-shadow: var(--ap-shadow); transition: .25s var(--ap-ease); cursor: pointer; color: var(--ap-paper); }
.oa-approche .method-card:hover { transform: translateY(-8px); background: rgba(244, 238, 225, .1); border-color: var(--ap-yellow); }
.oa-approche .method-card .num { width: 52px; height: 52px; border-radius: 15px; background: var(--ap-yellow); color: #18160f; display: grid; place-items: center; font-family: var(--oa-font-heading, 'PolicePrincipale'), serif; font-weight: 700; font-size: 1.2rem; }
.oa-approche .method-card h3 { font-size: 1.6rem; line-height: 1.05; letter-spacing: -.01em; margin: 24px 0 0; }
.oa-approche .method-card p { color: var(--ap-muted); line-height: 1.6; margin: 14px 0 0; }

/* ---- Final ---- */
.oa-approche .final { min-height: 100svh; display: grid; place-items: center; padding: 120px 0; }
.oa-approche .final-bg { position: absolute; inset: 0; z-index: -5; background:
    linear-gradient(180deg, rgba(24, 22, 15, .78), rgba(24, 22, 15, .92)),
    var(--ap-tex-mountain) center/cover no-repeat; filter: saturate(.2); }
.oa-approche .final-card { width: min(1040px, 92vw); border-radius: 44px; border: 1px solid var(--ap-border); background: rgba(20, 18, 12, .82); backdrop-filter: blur(22px); box-shadow: var(--ap-shadow); text-align: center; padding: clamp(34px, 7vw, 80px); }

/* ---- Modal ---- */
.oa-approche .mini-modal { position: fixed; inset: 0; z-index: 880; background: rgba(0, 0, 0, .66); backdrop-filter: blur(10px); display: none; align-items: center; justify-content: center; padding: 24px; }
.oa-approche .mini-modal.open { display: flex; }
.oa-approche .modal-card { width: min(900px, 100%); border-radius: 30px; border: 1px solid var(--ap-border); background: rgba(20, 18, 12, .94); box-shadow: var(--ap-shadow); padding: 18px; color: var(--ap-paper); }
.oa-approche .modal-video { aspect-ratio: 16/9; border-radius: 22px; overflow: hidden; background: linear-gradient(135deg, rgba(255, 201, 1, .5), rgba(74, 84, 88, .55)), url('/images/divers/video-oacom.jpg') center/cover; position: relative; }
.oa-approche .modal-video:after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at center, transparent 0 18%, rgba(0, 0, 0, .46) 58%); }
.oa-approche .modal-video h3 { position: absolute; z-index: 2; left: 28px; right: 28px; bottom: 24px; font-size: clamp(1.8rem, 4vw, 3.6rem); letter-spacing: -.01em; line-height: 1.0; margin: 0; }
.oa-approche .modal-close { position: absolute; right: 18px; top: 16px; z-index: 3; border: 0; background: rgba(244, 238, 225, .14); color: var(--ap-paper); border-radius: 999px; width: 42px; height: 42px; font-weight: 900; cursor: pointer; }

.oa-approche .ripple { position: absolute; border-radius: 999px; transform: scale(0); background: rgba(255, 201, 1, .5); pointer-events: none; animation: ap-ripple .65s ease-out forwards; }
@keyframes ap-ripple { to { transform: scale(4); opacity: 0; } }

/* ---- Responsive ---- */
@media (max-width: 1050px) {
  .oa-approche .nav-mini, .oa-approche .side-progress, .oa-approche .xp-panel, .oa-approche .cursor-light { display: none; }
  .oa-approche .oa-nav { display: none; }
  .oa-approche .brand span:last-child { display: none; }
  .oa-approche .hero-card, .oa-approche .floating-chip { display: none; }
  .oa-approche .journey-stage { display: grid; gap: 18px; min-height: auto; }
  .oa-approche .journey-phone, .oa-approche .client-board, .oa-approche .ops-board { position: relative; inset: auto; transform: none; width: min(540px, 92vw); margin: 0 auto; }
  .oa-approche .connect-line, .oa-approche .pulse-dot { display: none; }
  .oa-approche .delivery { height: auto; min-height: auto; }
  .oa-approche .delivery-sticky { position: relative; height: auto; perspective: none; }
  .oa-approche .delivery-world { position: relative; display: grid; gap: 22px; padding: 100px 24px; }
  .oa-approche .delivery-bg, .oa-approche .delivery-road, .oa-approche .delivery-fade { display: none; }
  .oa-approche .delivery-copy, .oa-approche .dc1, .oa-approche .dc2, .oa-approche .dc3, .oa-approche .dc4, .oa-approche .dc5 { position: relative; inset: auto; transform: none; text-align: left; width: min(720px, 92vw); margin: 0 auto; }
  .oa-approche .delivery-object, .oa-approche .do1, .oa-approche .do2, .oa-approche .do3, .oa-approche .do4, .oa-approche .do5, .oa-approche .floating-ui, .oa-approche .fu1, .oa-approche .fu2, .oa-approche .fu3, .oa-approche .fu4, .oa-approche .fu5, .oa-approche .video-card { position: relative; inset: auto; transform: none; width: min(540px, 92vw); height: auto; min-height: 240px; margin: 0 auto; opacity: 1; }
  .oa-approche .delivery-object img { filter: none; }
  .oa-approche .video-card { height: 460px; } .oa-approche .floating-ui { min-height: auto; }
  .oa-approche .checkout-grid { grid-template-columns: 1fr; }
  .oa-approche .silo-map { height: auto; display: grid; gap: 14px; padding: 18px; }
  .oa-approche .silo-node, .oa-approche .n-crm, .oa-approche .n-erp, .oa-approche .n-stock, .oa-approche .n-team, .oa-approche .n-web { position: relative; inset: auto; transform: none; width: 100%; }
  .oa-approche .n-web:hover { transform: translateY(-8px) scale(1.03); }
  .oa-approche .svg-lines { display: none; } .oa-approche .silo-panel { position: relative; left: auto; bottom: auto; transform: none; width: 100%; margin-top: 12px; }
}
@media (max-width: 560px) {
  .oa-approche .hero, .oa-approche .chain, .oa-approche .split-real, .oa-approche .silos, .oa-approche .checkout, .oa-approche .method, .oa-approche .final { padding-top: 90px; padding-bottom: 84px; }
  .oa-approche .display-xl { font-size: clamp(3rem, 15vw, 5rem); }
  .oa-approche .display-lg { font-size: clamp(2.2rem, 11vw, 3.6rem); }
  .oa-approche .text-panel, .oa-approche .final-card { border-radius: 26px; }
  .oa-approche .toast-zone { right: 12px; top: 16px; width: calc(100vw - 24px); }
  .oa-approche .metric-grid { grid-template-columns: 1fr; }
  .oa-approche .video-caption { left: 22px; right: 22px; } .oa-approche .play-btn { width: 76px; height: 76px; }
}

@media (prefers-reduced-motion: reduce) {
  .oa-approche *, body.layout-approche { scroll-behavior: auto !important; animation: none !important; transition: none !important; }
}
