/*
Template: about-us.css
Version: 1.0.0
Author: Perspective3 Studio
*/

/* Section: About Us (hero, valeurs, equipe, contenu) */
 :root { --p3s-about-white:#f8f9ff; --p3s-about-ink:#1d2347; --p3s-about-soft-ink:#4a4f71; --p3s-about-border:rgba(76, 88, 153, 0.24); --p3s-about-blue:#4f8dff; --p3s-about-violet:#7f4fff; --p3s-about-magenta:#d745cb; --p3s-about-dark-a:#081530; --p3s-about-dark-b:#171437; --p3s-about-radius:16px; --p3s-about-header-h:86px; }
body { background:radial-gradient(1200px 800px at 70% 10%, rgba(90, 30, 130, 0.55), transparent 55%), radial-gradient(900px 700px at 35% 30%, rgba(0, 120, 190, 0.35), transparent 60%), linear-gradient(90deg, #061828 0%, #071c2a 55%, #1a1430 100%); }
.p3s-about { color:var(--p3s-about-white); padding-bottom:90px; }
body.page-template-page-about-us .p3s-about { margin-top:calc(-1 * var(--p3s-about-header-h)); }
body.page-template-page-about-us .p3s-about__hero { padding-top:var(--p3s-about-header-h); }
body.admin-bar.page-template-page-about-us { --p3s-about-header-h:118px; }
body.page-template-page-about-us .site-header { position:relative; z-index:30; background:rgba(8, 19, 47, 0.34); backdrop-filter:blur(6px); border-bottom:1px solid rgba(255, 255, 255, 0.12); }
.p3s-about__hero { width:100vw; margin-left:calc(50% - 50vw); min-height:clamp(440px, 60vw, 620px); position:relative; background-size:cover; background-position:center; overflow:hidden; }
.p3s-about__hero::before { position:absolute; inset:0; content:''; background:radial-gradient(circle at 12% 28%, rgba(255, 255, 255, 0.25) 0.6px, transparent 1.4px), radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.22) 0.7px, transparent 1.6px), radial-gradient(circle at 62% 66%, rgba(255, 255, 255, 0.2) 0.6px, transparent 1.3px), radial-gradient(1100px 540px at 80% 10%, rgba(233, 98, 221, 0.34), transparent 64%), radial-gradient(900px 520px at 20% 100%, rgba(104, 148, 255, 0.24), transparent 65%); pointer-events:none; }
.p3s-about__hero::after { content:''; position:absolute; inset:0; background-image:radial-gradient(rgba(255, 255, 255, 0.12) 0.8px, transparent 0.8px); background-size:3px 3px; opacity:0.26; mix-blend-mode:screen; pointer-events:none; }
.p3s-about__hero-inner { position:absolute; bottom:4vh; left:50%; transform:translateX(-50%); z-index:1; width:min(1180px, calc(100% - 48px)); margin:0; padding:0 4vw; }
.p3s-about__kicker, .p3s-about__lead, .p3s-about h1, .p3s-about h2, .p3s-about h3, .p3s-about p { margin:0; }
.p3s-about__kicker { display:inline-block; position:relative; padding-left:18px; font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(248, 249, 255, 0.84); }
.p3s-about__kicker::before { content:''; position:absolute; left:0; top:7px; width:6px; height:6px; border-radius:999px; background:#00d1b2; box-shadow:0 0 0 4px rgba(0, 209, 178, 0.14); }
.p3s-about__kicker::after { content:''; position:absolute; left:-14vw; top:8px; width:14vw; height:2px; border-radius:999px; background:linear-gradient( 90deg, rgba(46, 91, 255, 0) 0%, rgba(46, 91, 255, 0.55) 35%, rgba(0, 209, 178, 0.75) 100% ); opacity:0.95; }
.p3s-about h1 { margin:2vh 0; font-size:clamp(34px, 5.3vw, 66px); line-height:1.05; letter-spacing:-0.02em; max-width:80vw; }
.p3s-about__lead { margin-top:18px; max-width:52ch; line-height:1.8; color:rgba(248, 249, 255, 0.86); font-size:clamp(15px, 1.2vw, 19px); }
.p3s-about__btn { display:inline-flex; align-items:center; justify-content:center; margin-top:26px; min-height:50px; padding:0 32px; border-radius:11px; border:1px solid rgba(255, 255, 255, 0.42); color:var(--p3s-about-white); text-decoration:none; font-weight:600; font-size:27px; background:rgba(16, 30, 70, 0.22); backdrop-filter:blur(2px); }
.p3s-about__approach, .p3s-about__values, .p3s-about__team { position:relative; width:100vw; margin-left:calc(50% - 50vw); padding:clamp(56px, 7vw, 88px) 0; }
.p3s-about__approach { color:var(--p3s-about-ink); z-index:1; }
.p3s-about__approach::before { content:''; position:absolute; inset:0; z-index:-1; background:radial-gradient(900px 380px at 95% 5%, rgba(206, 164, 255, 0.2), transparent 66%), radial-gradient(700px 350px at 5% 70%, rgba(154, 184, 255, 0.2), transparent 65%), linear-gradient(180deg, rgba(247, 245, 255, 0.62) 0%, rgba(239, 235, 255, 0.62) 100%); }
.p3s-about__values { color:var(--p3s-about-ink); z-index:1; }
.p3s-about__values::before { content:''; position:absolute; inset:0; z-index:-1; background:radial-gradient(900px 380px at 95% 5%, rgba(206, 164, 255, 0.2), transparent 66%), radial-gradient(700px 350px at 5% 70%, rgba(154, 184, 255, 0.2), transparent 65%), linear-gradient(180deg, rgba(247, 245, 255, 0.62) 0%, rgba(239, 235, 255, 0.62) 100%); }
.p3s-about__team { color:var(--p3s-about-white); background:radial-gradient(1000px 500px at 84% 18%, rgba(192, 98, 236, 0.24), transparent 65%), radial-gradient(700px 380px at 12% 85%, rgba(75, 142, 255, 0.24), transparent 64%), linear-gradient(90deg, #081530 0%, #171437 100%); }
.p3s-about__section-head { width:min(1180px, calc(100% - 48px)); margin:0 auto; }
.p3s-about__section-head--center { text-align:center; }
.p3s-about h2 { font-size:clamp(34px, 4.3vw, 55px); line-height:1.08; letter-spacing:-0.02em; }
.p3s-about__section-head p { margin-top:12px; font-size:clamp(16px, 1.25vw, 24px); line-height:1.7; }
.p3s-about__approach .p3s-about__section-head p, .p3s-about__values .p3s-about__section-head p { color:var(--p3s-about-soft-ink); }
.p3s-about__team .p3s-about__section-head p { color:rgba(248, 249, 255, 0.78); }
.p3s-about__steps-grid, .p3s-about__values-grid { width:min(1180px, calc(100% - 48px)); margin:clamp(30px, 4vw, 44px) auto 0; display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:clamp(16px, 1.8vw, 22px); }
.p3s-about__step-card, .p3s-about__value-card { border-radius:10px; border:1px solid var(--p3s-about-border); background:linear-gradient(180deg, rgba(249, 249, 255, 0.98), rgba(242, 241, 255, 0.96)); box-shadow:0 20px 42px rgba(77, 53, 151, 0.16), 0 4px 10px rgba(34, 24, 75, 0.08); padding:22px; }
.p3s-about__step-number { width:42px; height:42px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; color:#2a2f52; font-size:24px; font-weight:700; border:1px solid rgba(92, 108, 193, 0.35); background:rgba(108, 132, 230, 0.09); }
.p3s-about__step-meta { display:flex; align-items:center; justify-content:space-between; gap:14px; }
.p3s-about__step-icon, .p3s-about__value-icon { width:56px; height:56px; border-radius:14px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(123, 101, 225, 0.38); color:#3456bf; background:rgba(110, 142, 255, 0.14); font-size:24px; font-weight:700; }
.p3s-about__step-icon img, .p3s-about__value-icon img { width:28px; height:28px; object-fit:contain; display:block; }
.p3s-about__step-card h3, .p3s-about__value-card h3 { margin-top:16px; font-size:31px; color:#21274d; }
.p3s-about__step-card p, .p3s-about__value-card p { margin-top:10px; color:#434a73; line-height:1.65; font-size:17px; }
.p3s-about__team-slider { width:min(1180px, calc(100% - 48px)); margin:clamp(30px, 4vw, 44px) auto 0; }
.p3s-about__team-track { display:flex; gap:18px; }
.p3s-about__team-slider.is-carousel { overflow:hidden; }
.p3s-about__team-slider.is-carousel .p3s-about__team-track { gap:0; transition:transform 0.36s ease; }
.p3s-about__member-card { border:1px solid rgba(248, 249, 255, 0.16); border-radius:var(--p3s-about-radius); background:rgba(13, 32, 71, 0.46); padding:24px; display:grid; grid-template-columns:220px 1fr; gap:24px; align-items:center; }
.p3s-about__team-slider:not(.is-carousel) .p3s-about__member-card { width:min(980px, 100%); margin:0 auto; }
.p3s-about__team-slider.is-carousel .p3s-about__member-card { min-width:100%; }
.p3s-about__member-media img, .p3s-about__member-avatar { width:220px; height:220px; border-radius:16px; object-fit:cover; display:block; }
.p3s-about__member-avatar { display:flex; align-items:center; justify-content:center; font-size:72px; font-weight:700; background:linear-gradient(140deg, #527dff, #9f56f0); color:#fff; }
.p3s-about__member-content h3 { font-size:clamp(30px, 3vw, 42px); }
.p3s-about__member-role { margin-top:8px !important; color:rgba(174, 208, 255, 0.92); font-size:20px; font-weight:600; }
.p3s-about__member-text { margin-top:12px !important; color:rgba(248, 249, 255, 0.82); line-height:1.7; font-size:17px; }
.p3s-about__team-controls { display:flex; align-items:center; justify-content:center; gap:14px; margin-top:22px; }
.p3s-about__team-nav { width:42px; height:42px; border-radius:999px; border:1px solid rgba(248, 249, 255, 0.38); background:rgba(248, 249, 255, 0.08); color:#fff; font-size:18px; cursor:pointer; }
.p3s-about__team-nav:focus-visible { outline:2px solid rgba(0, 209, 178, 0.85); outline-offset:2px; }
.p3s-about__team-dots { display:inline-flex; align-items:center; gap:8px; }
.p3s-about__team-dot { width:9px; height:9px; border-radius:999px; border:0; background:rgba(248, 249, 255, 0.42); cursor:pointer; }
.p3s-about__team-dot.is-active { background:#00d1b2; box-shadow:0 0 0 4px rgba(0, 209, 178, 0.16); }
.p3s-about__team-empty { width:min(1180px, calc(100% - 48px)); margin:clamp(22px, 3vw, 30px) auto 0; border:1px dashed rgba(248, 249, 255, 0.3); border-radius:14px; padding:20px 22px; color:rgba(248, 249, 255, 0.86); background:rgba(248, 249, 255, 0.06); }
body.page-template-page-about-us { --p3s-about-header-h:108px; }
body.admin-bar.page-template-page-about-us { --p3s-about-header-h:140px; }
.p3s-about__hero-inner { top:calc(var(--p3s-about-header-h) + 20px); bottom:auto; }

/* Media queries : desktop (larges ecrans et interactions souris) */

/* Media queries : tablet (tablettes et ecrans intermediaires) */
@media (max-width:1100px) { :root { --p3s-about-header-h:116px; }body.admin-bar.page-template-page-about-us { --p3s-about-header-h:146px; } }
@media (max-width:1100px) { .p3s-about__steps-grid, .p3s-about__values-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }.p3s-about__step-card p, .p3s-about__value-card p, .p3s-about__member-text { font-size:16px; } }
@media (max-width:900px) { body.page-template-page-about-us { --p3s-about-header-h:74px; }body.admin-bar.page-template-page-about-us { --p3s-about-header-h:104px; }.p3s-about__hero-inner, .p3s-about__section-head, .p3s-about__steps-grid, .p3s-about__values-grid, .p3s-about__team-slider, .p3s-about__team-empty { width:min(1180px, calc(100% - 28px)); }.p3s-about__steps-grid, .p3s-about__values-grid { grid-template-columns:1fr; }.p3s-about__btn { width:100%; font-size:20px; }.p3s-about__member-card { grid-template-columns:1fr; text-align:center; }.p3s-about__member-media img, .p3s-about__member-avatar { margin:0 auto; } }
@media (max-width:1100px) { body.page-template-page-about-us { --p3s-about-header-h:94px; }body.admin-bar.page-template-page-about-us { --p3s-about-header-h:126px; } }
@media (max-width:1100px) { .p3s-about__hero { min-height:auto; }.p3s-about__hero-inner { position:relative; left:auto; top:auto; bottom:auto; transform:none; width:min(1180px, calc(100% - 28px)); margin:0 auto; padding:calc(var(--p3s-about-header-h) + 20px) 4vw 24px; } }

/* Media queries : mobile (petits ecrans) */
@media (max-width:640px) { body.page-template-page-about-us { --p3s-about-header-h:90px; }body.admin-bar.page-template-page-about-us { --p3s-about-header-h:136px; } }
