/*
Theme Name: Spheric
Theme URI: https://spheric.fr
Author: Spheric
Description: Portfolio immersif — sound design pour le cinéma, la télévision et la VR. Hero nuage d'affiches en orbite + waveform.
Version: 1.0
*/
:root{
  --bg:#0a0c10; --fg:#eaeef4; --muted:#8593a8; --accent:#7cb3e0;
  --line:#1c2230; --surface:#11161f;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg)}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;-webkit-font-smoothing:antialiased;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.sph-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 34px;position:relative;z-index:50}
.sph-brand{display:flex;flex-direction:column;gap:7px}
.sph-logo{font-size:16px;letter-spacing:.34em;font-weight:500}
.sph-name{font-size:18px;font-weight:500;color:var(--fg);transition:color .15s}
.sph-name .sep{color:var(--muted);margin:0 3px;font-weight:400}
.sph-name .role{color:var(--accent);font-weight:400}
.sph-name:hover{color:var(--accent)}
.sph-lang ul{display:flex;gap:9px;list-style:none;margin:0;padding:0}
.sph-lang a{text-transform:uppercase;font-size:12px;color:var(--muted);letter-spacing:.05em}
.sph-lang a:hover{color:var(--fg)}
.sph-lang .current-lang a{color:var(--accent)}
.sph-menu{display:flex;gap:24px;font-size:13px;color:var(--muted)}
.sph-menu a:hover{color:var(--fg)}
.sph-menu a.sph-ext{color:var(--accent)}

.sph-hero-title{text-align:center;padding:30px 24px 8px;position:relative;z-index:40}
.sph-hero-title h1{font-size:32px;font-weight:500;line-height:1.3;max-width:640px;margin:0 auto}
.sph-hero-title h1 span{color:var(--accent);white-space:nowrap}
.sph-hero-title .fr{margin-top:12px;font-size:13px;color:var(--muted)}

.sph-hero{position:relative;height:66vh;min-height:460px;overflow:hidden}
#sph-wf{position:absolute;left:50%;top:0;transform:translateX(-50%);width:240px;height:100%;z-index:0;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 24%,#000 76%,transparent);
  mask-image:linear-gradient(to bottom,transparent,#000 24%,#000 76%,transparent)}
.sph-wfrow{height:2px;margin:3px auto;background:var(--accent);border-radius:2px;opacity:.28}
@keyframes sph-wfup{from{transform:translateY(0)}to{transform:translateY(-50%)}}

#sph-orb{position:absolute;inset:0;z-index:1;perspective:900px;perspective-origin:50% 42%}
#sph-cloud{position:absolute;left:50%;top:50%;transform-style:preserve-3d;will-change:transform}
.orbp{position:absolute;left:0;top:0;width:122px;border-radius:6px;border:0.5px solid #2a374b;overflow:hidden;opacity:0;line-height:0;backface-visibility:hidden}
.orbp img{display:block;width:100%;height:auto;max-width:none}
.orbp:hover{border-color:var(--accent)}
.sph-tilevid{position:absolute;inset:0;z-index:1;background:#000}
.sph-tilevid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.sph-playing .sph-play{display:none}

.sph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;padding:20px 34px 40px}
.sph-grid .orbp{position:relative;width:auto;opacity:1;transform:none}
.sph-grid .orbp img{width:100%}

.sph-foot{padding:26px 34px;color:var(--muted);font-size:13px;border-top:0.5px solid var(--line);text-align:center}
.sph-foot a{color:var(--accent)}
.sph-mail{cursor:pointer;font-size:13px;color:var(--muted)}
.sph-mail:hover{color:var(--accent)}

.sph-main{max-width:1100px;margin:0 auto;padding:30px 24px 60px}
.sph-main h1{font-size:26px;font-weight:500;margin-bottom:20px}

/* page Work */
.sph-work{max-width:1180px;margin:0 auto;padding:26px 28px 70px}
.sph-work h1{font-size:28px;font-weight:500;margin-bottom:18px}
.sph-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.sph-chip{background:transparent;color:var(--muted);border:0.5px solid var(--line);border-radius:30px;padding:8px 16px;font:inherit;font-size:13px;cursor:pointer;transition:.15s}
.sph-chip:hover{color:var(--fg);border-color:var(--muted)}
.sph-chip.is-on{background:var(--accent);color:#0a0c10;border-color:var(--accent)}
.sph-workgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}
.sph-workcard{display:block}
.sph-workcard .art{position:relative;display:block;aspect-ratio:2/3;border-radius:10px;overflow:hidden;background:var(--surface);border:0.5px solid var(--line)}
.sph-workcard .art img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.sph-workcard:hover .art img{transform:scale(1.05)}
.sph-workcard:hover .art{border-color:var(--accent)}
.sph-workcard .meta{display:block;margin-top:9px}
.sph-workcard .meta .t{display:block;font-size:14px;color:var(--fg)}
.sph-workcard .meta .c{display:block;font-size:10px;letter-spacing:.14em;color:var(--accent);margin-top:3px}

/* Journal */
.sph-journal{display:grid;gap:14px;max-width:760px}
.sph-jcard{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:0.5px solid var(--line);border-radius:12px;padding:14px;transition:.15s}
.sph-jcard:hover{border-color:var(--accent)}
.sph-jcard .art{flex:0 0 120px;width:120px;aspect-ratio:16/10;border-radius:8px;overflow:hidden;background:#0d1016}
.sph-jcard .art img{width:100%;height:100%;object-fit:cover;display:block}
.sph-jcard .art:empty{display:none}
.sph-jcard .b{display:block}
.sph-jcard .d{display:block;font-size:11px;letter-spacing:.08em;color:var(--accent)}
.sph-jcard .t{display:block;font-size:16px;font-weight:500;color:var(--fg);margin:5px 0 6px}
.sph-jcard .e{display:block;font-size:13px;color:var(--muted);line-height:1.55}
@media(max-width:560px){.sph-jcard .art{flex-basis:88px;width:88px}}

/* repère vidéo + aperçu au survol */
.sph-play{position:absolute;right:6px;bottom:6px;width:20px;height:20px;border-radius:50%;background:rgba(124,179,224,.9);color:#0a0c10;font-size:9px;display:flex;align-items:center;justify-content:center;z-index:2;padding-left:1px}
#sph-preview{position:absolute;right:24px;bottom:22px;width:300px;max-width:42%;z-index:30;opacity:0;pointer-events:none;transition:opacity .22s;background:#0d1016;border:0.5px solid var(--line);border-radius:10px;overflow:hidden}
#sph-preview.on{opacity:1}
#sph-preview .frame{position:relative;aspect-ratio:16/9;background:#000}
#sph-preview .frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
#sph-preview .ttl{padding:8px 12px;font-size:12px;color:var(--fg)}

/* fiche projet */
.sph-project{max-width:880px;margin:0 auto;padding:20px 24px 70px}
.sph-back{display:inline-block;color:var(--muted);font-size:13px;margin-bottom:18px}
.sph-back:hover{color:var(--accent)}
.sph-project h1{font-size:30px;font-weight:500;line-height:1.2}
.sph-proj-cat{color:var(--accent);font-size:11px;letter-spacing:.16em;margin:8px 0 22px}
.sph-video{position:relative;aspect-ratio:16/9;background:#000;border-radius:10px;overflow:hidden}
.sph-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.sph-proj-cover img{width:100%;height:auto;border-radius:10px}
.sph-proj-body{margin-top:24px;color:#c4ccd8;font-size:15px;line-height:1.8}
.sph-proj-body a{color:var(--accent)}
.sph-proj-link{display:inline-block;margin-top:26px;color:var(--fg);border:0.5px solid var(--line);padding:11px 20px;border-radius:30px;font-size:14px}
.sph-proj-link:hover{border-color:var(--accent);color:var(--accent)}

@media(max-width:640px){.sph-menu{gap:14px}.sph-nav{padding:16px 18px}.sph-hero-title h1{font-size:25px}}
