/*
Template: portfolio-single.css
Version: 1.0.0
Author: Perspective3 Studio
*/

/* Section: Portfolio single (hero, details projet, navigation) */
 :root { --p3s-ps-white:#f8f9ff; --p3s-ps-ink:#1d2347; --p3s-ps-soft-ink:#4a4f71; --p3s-ps-border:rgba(76, 88, 153, 0.24); --p3s-ps-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%); }
.single-portfolio .p3s-portfolio-single { margin-top:calc(-1 * var(--p3s-ps-header-h)); color:var(--p3s-ps-white); padding-bottom:90px; }
.single-portfolio .p3s-portfolio-single__hero { padding-top:var(--p3s-ps-header-h); }
body.admin-bar.single-portfolio { --p3s-ps-header-h:118px; }
.single-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-single__hero { width:100vw; margin-left:calc(50% - 50vw); min-height:clamp(420px, 54vw, 560px); position:relative; background-size:cover; background-position:center; overflow:hidden; }
.p3s-portfolio-single__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-single__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-single__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-single__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-single__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-single h1 { margin:2vh 0 0; font-size:clamp(34px, 5.1vw, 62px); line-height:1.05; letter-spacing:-0.02em; }
.p3s-portfolio-single__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-single__meta, .p3s-portfolio-single__content { width:100vw; margin-left:calc(50% - 50vw); position:relative; }
.p3s-portfolio-single__meta { padding:clamp(46px, 6vw, 72px) 0; color:var(--p3s-ps-ink); }
.p3s-portfolio-single__meta::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-single__meta-grid, .p3s-portfolio-single__content-grid, .p3s-portfolio-single__visual, .p3s-portfolio-single__quote, .p3s-portfolio-single__actions { width:min(1180px, calc(100% - 48px)); margin-left:auto; margin-right:auto; }
.p3s-portfolio-single__meta-grid { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; }
.p3s-portfolio-single__meta-card { border-radius:12px; border:1px solid var(--p3s-ps-border); background:linear-gradient(180deg, rgba(249, 249, 255, 0.98), rgba(242, 241, 255, 0.96)); box-shadow:0 10px 24px rgba(77, 53, 151, 0.12); padding:16px; }
.p3s-portfolio-single__meta-card h3 { margin:0; color:#2a325c; font-size:15px; text-transform:uppercase; letter-spacing:0.08em; }
.p3s-portfolio-single__meta-card p, .p3s-portfolio-single__meta-card ul { margin:8px 0 0; color:#3f4a76; line-height:1.6; }
.p3s-portfolio-single__meta-card ul { padding-left:18px; }
.p3s-portfolio-single__meta-card li + li { margin-top:6px; }
.p3s-portfolio-single__details-list { list-style:none; padding-left:0 !important; }
.p3s-portfolio-single__details-list li::marker { content:''; }
.p3s-portfolio-single__content { padding:clamp(46px, 6vw, 72px) 0; }
.p3s-portfolio-single__content-grid { display:grid; grid-template-columns:1.2fr 0.8fr; gap:20px; }
.p3s-portfolio-single__panel { border:1px solid rgba(248, 249, 255, 0.15); border-radius:16px; padding:24px; background:rgba(13, 32, 71, 0.42); display:flex; flex-direction:column; }
.p3s-portfolio-single__panel h2, .p3s-portfolio-single__panel h3 { margin:0; }
.p3s-portfolio-single__panel h2 { font-size:clamp(30px, 3.2vw, 42px); }
.p3s-portfolio-single__panel h3 { font-size:22px; }
.p3s-portfolio-single__wysiwyg { margin-top:12px; color:rgba(248, 249, 255, 0.85); line-height:1.8; }
.p3s-portfolio-single__story-media { margin-top:14px; border-radius:12px; overflow:hidden; border:1px solid rgba(248, 249, 255, 0.16); background:rgba(248, 249, 255, 0.04); display:flex; align-items:center; justify-content:center; }
.p3s-portfolio-single__story-media video, .p3s-portfolio-single__story-media img { display:block; width:100%; height:auto; max-height:460px; object-fit:cover; }
.p3s-portfolio-single__story-media.is-fill { flex:1; min-height:280px; }
.p3s-portfolio-single__story-media.is-fill video, .p3s-portfolio-single__story-media.is-fill img { width:auto; max-width:100%; max-height:100%; object-fit:contain; }
.p3s-portfolio-single__story-cta { margin-top:14px; display:flex; justify-content:flex-start; }
.p3s-portfolio-single__story-cta .btn-official { margin-top:0; }
.p3s-portfolio-single__wysiwyg:empty { display:none; }
.p3s-portfolio-single__block + .p3s-portfolio-single__block { margin-top:14px; }
.p3s-portfolio-single__block p { margin:8px 0 0; color:rgba(248, 249, 255, 0.82); line-height:1.7; }
.p3s-portfolio-single__visual { margin-top:20px; }
.p3s-portfolio-single__visual img { display:block; width:100%; height:auto; border-radius:16px; border:1px solid rgba(248, 249, 255, 0.16); }
.p3s-portfolio-single__quote { margin-top:20px; border-left:3px solid rgba(120, 168, 255, 0.72); border-radius:10px; padding:14px 16px; background:rgba(77, 126, 242, 0.13); }
.p3s-portfolio-single__quote p { margin:0; font-style:italic; color:rgba(248, 249, 255, 0.9); }
.p3s-portfolio-single__quote cite { display:block; margin-top:8px; color:rgba(179, 209, 255, 0.94); font-style:normal; }
.p3s-portfolio-single__actions { margin-top:18px; display:flex; flex-wrap:wrap; gap:10px; }
.p3s-portfolio-single__actions .btn-official { margin-top:0; }
body.single-portfolio { --p3s-ps-header-h:108px; }
body.admin-bar.single-portfolio { --p3s-ps-header-h:140px; }
.p3s-portfolio-single__hero-inner { top:calc(var(--p3s-ps-header-h) + 20px); bottom:auto; }

/* Media queries : desktop (larges ecrans et interactions souris) */

/* Media queries : tablet (tablettes et ecrans intermediaires) */
@media (max-width:1000px) { .p3s-portfolio-single__meta-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }.p3s-portfolio-single__content-grid { grid-template-columns:1fr; } }
@media (max-width:900px) { body.single-portfolio { --p3s-ps-header-h:74px; }body.admin-bar.single-portfolio { --p3s-ps-header-h:104px; }.p3s-portfolio-single__hero-inner, .p3s-portfolio-single__meta-grid, .p3s-portfolio-single__content-grid, .p3s-portfolio-single__visual, .p3s-portfolio-single__quote, .p3s-portfolio-single__actions { width:min(1180px, calc(100% - 28px)); }.p3s-portfolio-single__meta-grid { grid-template-columns:1fr; } }
@media (max-width:1100px) { body.single-portfolio { --p3s-ps-header-h:94px; }body.admin-bar.single-portfolio { --p3s-ps-header-h:126px; } }
@media (max-width:1100px) { .p3s-portfolio-single__hero { min-height:auto; }.p3s-portfolio-single__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-ps-header-h) + 20px) 4vw 24px; } }

/* Media queries : mobile (petits ecrans) */
@media (max-width:640px) { body.single-portfolio { --p3s-ps-header-h:90px; }body.admin-bar.single-portfolio { --p3s-ps-header-h:136px; } }
