/*
Template: portfolio.css
Version: 1.0.0
Author: Perspective3 Studio
*/

/* Section: Portfolio listing (hero, grille projets, cartes) */
 :root { --p3s-portfolio-white:#f8f9ff; --p3s-portfolio-ink:#1d2347; --p3s-portfolio-soft-ink:#4a4f71; --p3s-portfolio-border:rgba(76, 88, 153, 0.24); --p3s-portfolio-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-portfolio { color:var(--p3s-portfolio-white); padding-bottom:90px; }
body.page-template-page-portfolio .p3s-portfolio { margin-top:calc(-1 * var(--p3s-portfolio-header-h)); }
body.page-template-page-portfolio .p3s-portfolio__hero { padding-top:var(--p3s-portfolio-header-h); }
body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:118px; }
body.page-template-page-portfolio .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-portfolio__hero { width:100vw; margin-left:calc(50% - 50vw); min-height:clamp(410px, 52vw, 540px); position:relative; background-size:cover; background-position:center; overflow:hidden; }
.p3s-portfolio__hero::before { content:''; position:absolute; inset:0; background: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%); }
.p3s-portfolio__hero-inner { position:absolute; bottom:4vh; left:50%; transform:translateX(-50%); z-index:1; width:min(1180px, calc(100% - 48px)); padding:0 4vw; }
.p3s-portfolio__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-portfolio__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-portfolio__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-portfolio h1 { margin:2vh 0 0; font-size:clamp(34px, 5.1vw, 62px); line-height:1.05; letter-spacing:-0.02em; max-width:80vw; }
.p3s-portfolio__lead { margin-top:18px; max-width:58ch; line-height:1.8; color:rgba(248, 249, 255, 0.86); font-size:clamp(15px, 1.2vw, 19px); }
.p3s-portfolio__projects { position:relative; width:100vw; margin-left:calc(50% - 50vw); padding:clamp(56px, 7vw, 88px) 0; color:var(--p3s-portfolio-ink); z-index:1; }
.p3s-portfolio__projects::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-portfolio__section-head { width:min(1180px, calc(100% - 48px)); margin:0 auto; }
.p3s-portfolio__section-head--center { text-align:center; }
.p3s-portfolio h2 { margin:0; font-size:clamp(34px, 4.3vw, 55px); line-height:1.08; letter-spacing:-0.02em; }
.p3s-portfolio__section-head p { margin:12px 0 0; color:var(--p3s-portfolio-soft-ink); font-size:clamp(16px, 1.25vw, 24px); line-height:1.7; }
.p3s-portfolio__grid { width:min(1180px, calc(100% - 48px)); margin:clamp(30px, 4vw, 44px) auto 0; display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:clamp(18px, 2.2vw, 28px); }
.p3s-portfolio__card { position:relative; border-radius:14px; border:1px solid var(--p3s-portfolio-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); overflow:hidden; }
.p3s-portfolio__card-link { position:absolute; inset:0; z-index:2; }
.p3s-portfolio__media { display:block; aspect-ratio:16 / 9; background:linear-gradient(120deg, #cad9ff, #e6d8ff); border-bottom:3px solid rgba(93, 121, 223, 0.38); box-shadow:inset 0 -1px 0 rgba(255, 255, 255, 0.6); }
.p3s-portfolio__media img { width:100%; height:100%; object-fit:cover; display:block; }
.p3s-portfolio__media video { width:100%; height:100%; object-fit:cover; display:block; background:#d6def8; }
.p3s-portfolio__media-fallback { height:100%; display:flex; align-items:center; justify-content:center; color:#32407a; font-size:24px; font-weight:700; }
.p3s-portfolio__content { position:relative; z-index:3; padding:22px; }
.p3s-portfolio__content h3 { margin:0; font-size:clamp(26px, 2.2vw, 34px); color:#21274d; }
.p3s-portfolio__excerpt { margin:10px 0 0; color:#434a73; line-height:1.65; font-size:17px; }
.p3s-portfolio__quote { margin:14px 0 0; padding:12px 14px; border-left:3px solid rgba(92, 126, 246, 0.72); border-radius:8px; background:rgba(92, 126, 246, 0.08); color:#354574; font-style:italic; }
.p3s-portfolio__actions { margin-top:18px; display:flex; flex-wrap:wrap; gap:10px; }
.p3s-portfolio__btn { margin-top:0 !important; position:relative; z-index:4; }
.p3s-portfolio__btn--ghost { min-height:42px; padding:9px 18px; }
.p3s-portfolio__empty { width:min(1180px, calc(100% - 48px)); margin:clamp(22px, 3vw, 30px) auto 0; border:1px dashed rgba(76, 88, 153, 0.36); border-radius:14px; padding:20px 22px; color:#404b76; background:rgba(248, 249, 255, 0.55); }
body.page-template-page-portfolio { --p3s-portfolio-header-h:108px; }
body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:140px; }
.p3s-portfolio__hero-inner { top:calc(var(--p3s-portfolio-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-portfolio-header-h:116px; }body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:146px; } }
@media (max-width:900px) { body.page-template-page-portfolio { --p3s-portfolio-header-h:74px; }body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:104px; }.p3s-portfolio__hero-inner, .p3s-portfolio__section-head, .p3s-portfolio__grid, .p3s-portfolio__empty { width:min(1180px, calc(100% - 28px)); }.p3s-portfolio__grid { grid-template-columns:1fr; } }
@media (max-width:1100px) { body.page-template-page-portfolio { --p3s-portfolio-header-h:94px; }body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:126px; } }
@media (max-width:1100px) { .p3s-portfolio__hero { min-height:auto; }.p3s-portfolio__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-portfolio-header-h) + 20px) 4vw 24px; } }

/* Media queries : mobile (petits ecrans) */
@media (max-width:640px) { body.page-template-page-portfolio { --p3s-portfolio-header-h:90px; }body.admin-bar.page-template-page-portfolio { --p3s-portfolio-header-h:136px; } }
