/*
Theme Name: Xavier Sellier CV
Theme URI: https://xavier-sellier.com
Author: Xavier Sellier
Description: Thème de blocs (FSE) pour le CV en ligne de Xavier Sellier — design premium exécutif, bleu nuit & cuivre. Éditable dans l'éditeur de blocs WordPress. Autonome, sans plugin. Polices Fraunces & Inter embarquées localement.
Version: 3.0
Requires at least: 6.4
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: xavier-sellier
*/

:root{
  --night:#10242E;
  --night-2:#1A3845;
  --cream:#F4F0E8;
  --cream-2:#EAE3D6;
  --copper:#C2683B;
  --copper-dk:#A2532D;
  --slate:#6A7B83;
  --ink:#16282F;
  --line:rgba(16,36,46,.16);
  --line-soft:rgba(16,36,46,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:16px}
h1,h2,h3,.disp{font-family:'Fraunces',Georgia,serif;font-weight:400;line-height:1.06}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px}
@media(max-width:640px){.wrap{padding:0 22px}}

/* selection */
::selection{background:var(--copper);color:#fff}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,border-color .3s,padding .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(244,240,232,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:500;letter-spacing:.005em;color:var(--night)}
.brand b{font-weight:500}
.brand .dot{color:var(--copper)}
.nav.on-dark .brand{color:var(--cream)}
.nav-links{display:flex;gap:34px;list-style:none;align-items:center}
.nav-links a{font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);transition:color .2s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--copper);transition:width .25s}
.nav-links a:hover{color:var(--night)}
.nav-links a:hover::after{width:100%}
.nav.on-dark .nav-links a{color:rgba(244,240,232,.65)}
.nav.on-dark .nav-links a:hover{color:#fff}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative}
.nav-toggle span{position:absolute;left:0;width:100%;height:1.5px;background:var(--night);transition:.3s}
.nav.on-dark .nav-toggle span{background:var(--cream)}
.nav-toggle span:nth-child(1){top:2px}.nav-toggle span:nth-child(2){top:10px}.nav-toggle span:nth-child(3){top:18px}
@media(max-width:860px){
  .nav-links{position:fixed;inset:74px 0 auto 0;flex-direction:column;gap:0;background:var(--night);padding:0;max-height:0;overflow:hidden;transition:max-height .35s ease}
  .nav-links.open{max-height:60vh;padding:12px 0}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:16px 40px;color:rgba(244,240,232,.8)!important;font-size:.95rem}
  .nav-toggle{display:block}
}

/* HERO */
.hero{background:var(--night);color:var(--cream);min-height:100vh;display:flex;align-items:flex-end;position:relative;overflow:hidden;padding-bottom:64px}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(130% 90% at 100% 0%,rgba(194,104,59,.16),transparent 50%);pointer-events:none}
.hero::after{content:"";position:absolute;right:-8%;top:8%;width:46vw;height:46vw;max-width:640px;max-height:640px;border:1px solid rgba(244,240,232,.10);border-radius:50%;pointer-events:none}
.hero-inner{position:relative;width:100%;padding-top:130px}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:38px;opacity:0;animation:fadeUp .9s .15s forwards}
.hero-eyebrow .ln{width:46px;height:1px;background:var(--copper)}
.hero-eyebrow span{font-size:.76rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--copper)}
.hero h1{font-size:clamp(2.9rem,8vw,6.2rem);font-weight:300;letter-spacing:-.015em;color:#fff;max-width:17ch;margin-bottom:40px}
.hero h1 em{font-style:italic;color:var(--copper);font-weight:400}
.hero h1 .l1{display:block;opacity:0;animation:fadeUp .9s .3s forwards}
.hero h1 .l2{display:block;opacity:0;animation:fadeUp .9s .45s forwards}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .6s forwards}
.hero-lede{font-size:1.16rem;color:#C4D0D5;max-width:40ch;font-weight:400;line-height:1.6}
.hero-lede .targets{display:block;margin-top:18px;font-size:.82rem;color:#8DA0A8;letter-spacing:.02em}
.hero-cta{display:flex;gap:14px;flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;font-size:.86rem;font-weight:600;letter-spacing:.02em;border-radius:1px;transition:transform .18s,background .22s,color .22s,border-color .22s;white-space:nowrap}
.btn .arr{transition:transform .22s}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--copper);color:#fff}
.btn-primary:hover{background:var(--copper-dk);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(244,240,232,.30);color:#fff}
.btn-ghost:hover{border-color:var(--copper);color:var(--copper)}
.scroll-hint{position:absolute;left:40px;bottom:28px;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,240,232,.4);display:flex;align-items:center;gap:10px;opacity:0;animation:fadeUp .9s .9s forwards}
.scroll-hint .bar{width:1px;height:30px;background:linear-gradient(var(--copper),transparent);animation:scrollPulse 2s infinite}
@media(max-width:860px){.hero{min-height:auto;padding-top:30px}.scroll-hint{display:none}.hero-foot{flex-direction:column;align-items:flex-start}.hero-cta{width:100%}.btn{flex:1;justify-content:center}}

@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}

/* METRICS — editorial */
.metrics{background:var(--night-2);color:var(--cream);border-top:1px solid rgba(244,240,232,.08)}
.metrics-inner{display:grid;grid-template-columns:repeat(5,1fr)}
.metric{padding:46px 26px;border-left:1px solid rgba(244,240,232,.10);position:relative}
.metric:first-child{border-left:0}
.metric .num{font-family:'Fraunces',serif;font-size:clamp(2.2rem,3.6vw,3.1rem);font-weight:400;color:#fff;line-height:1;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.metric .num em{color:var(--copper);font-style:normal}
.metric .lab{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#8DA0A8;margin-top:14px;line-height:1.4}
@media(max-width:860px){.metrics-inner{grid-template-columns:1fr 1fr}.metric{border-left:1px solid rgba(244,240,232,.10);border-top:1px solid rgba(244,240,232,.10);padding:30px 22px}.metric:nth-child(odd){border-left:0}.metric:nth-child(-n+2){border-top:0}.metric:last-child{grid-column:1/-1}}

/* SECTION SHELL */
section{padding:120px 0;position:relative}
.sec-mark{display:flex;align-items:baseline;gap:18px;margin-bottom:54px}
.sec-num{font-family:'Fraunces',serif;font-size:.9rem;color:var(--copper);font-weight:500;letter-spacing:.05em}
.sec-eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--slate)}
.sec-title{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:300;color:var(--night);letter-spacing:-.01em;max-width:22ch;margin-bottom:6px}
.sec-title em{font-style:italic;color:var(--copper)}

/* PROFIL */
.profil-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.profil-lede{font-size:1.32rem;line-height:1.6;color:var(--night-2);font-weight:400}
.profil-lede .drop{font-family:'Fraunces',serif;font-size:1.5em;line-height:1;color:var(--copper);float:left;margin:.05em .12em 0 0;font-weight:500}
.values{display:flex;flex-direction:column}
.value{padding:22px 0;border-top:1px solid var(--line-soft);display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:baseline}
.value:first-child{border-top:0;padding-top:0}
.value .vi{font-family:'Fraunces',serif;font-size:.85rem;color:var(--copper);font-weight:500;font-variant-numeric:tabular-nums}
.value h3{font-size:1.04rem;color:var(--night);font-weight:500;font-family:'Inter',sans-serif;margin-bottom:5px}
.value p{font-size:.92rem;color:var(--slate)}
@media(max-width:860px){.profil-grid{grid-template-columns:1fr;gap:48px}}

/* COMPETENCES */
.skills{background:var(--night);color:var(--cream)}
.skills .sec-eyebrow{color:#8DA0A8}
.skills .sec-title{color:#fff}
.skill-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(244,240,232,.14)}
.skill{padding:42px 34px 42px 0;border-right:1px solid rgba(244,240,232,.10);position:relative}
.skill:last-child{border-right:0;padding-right:0}
.skill:not(:first-child){padding-left:34px}
.skill .si{font-family:'Fraunces',serif;color:var(--copper);font-size:.85rem;font-weight:500;display:block;margin-bottom:18px}
.skill h3{font-size:1.32rem;color:#fff;font-weight:400;margin-bottom:14px;font-family:'Fraunces',serif}
.skill p{font-size:.93rem;color:#B6C2C7;line-height:1.6}
@media(max-width:860px){.skill-grid{grid-template-columns:1fr}.skill{border-right:0;border-bottom:1px solid rgba(244,240,232,.10);padding:32px 0!important}.skill:last-child{border-bottom:0}}

/* PARCOURS */
.tl{border-top:1px solid var(--line)}
.tl-item{display:grid;grid-template-columns:200px 1fr;gap:50px;padding:46px 0;border-bottom:1px solid var(--line-soft);position:relative;transition:background .3s}
.tl-item:hover{background:rgba(194,104,59,.03)}
.tl-when{position:relative}
.tl-when .yr{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:300;color:var(--copper);line-height:1;display:block;margin-bottom:8px;font-variant-numeric:tabular-nums}
.tl-when .span{font-size:.78rem;color:var(--slate);letter-spacing:.04em}
.tl-body h3{font-size:1.42rem;color:var(--night);font-weight:400;margin-bottom:7px;letter-spacing:-.005em}
.tl-body .org{font-size:.96rem;color:var(--copper-dk);font-weight:600;margin-bottom:8px}
.tl-body .meta{display:inline-block;font-size:.76rem;color:var(--slate);letter-spacing:.03em;text-transform:uppercase;border:1px solid var(--line);padding:5px 12px;border-radius:1px;margin-bottom:20px}
.tl-body ul{list-style:none;display:grid;gap:10px}
.tl-body li{position:relative;padding-left:22px;font-size:.95rem;color:var(--night-2);line-height:1.55}
.tl-body li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:1px;background:var(--copper)}
@media(max-width:860px){.tl-item{grid-template-columns:1fr;gap:14px;padding:34px 0}.tl-when{display:flex;align-items:baseline;gap:14px}.tl-when .yr{font-size:1.8rem;margin-bottom:0}}

/* earlier */
.earlier{margin-top:14px}
.earlier-row{display:grid;grid-template-columns:1.5fr 1fr auto;gap:24px;padding:20px 0;border-bottom:1px solid var(--line-soft);align-items:baseline}
.earlier-row b{color:var(--night);font-weight:500;font-size:1rem}
.earlier-row .o{color:var(--slate);font-size:.92rem}
.earlier-row .y{color:var(--copper-dk);font-weight:600;font-size:.86rem;font-variant-numeric:tabular-nums;text-align:right}
@media(max-width:860px){.earlier-row{grid-template-columns:1fr;gap:4px}.earlier-row .y{text-align:left}}

/* CREDENTIALS */
.creds{background:var(--cream-2)}
.cred-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:56px}
.cred-col h3{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--copper);font-weight:600;margin-bottom:26px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.cred-col ul{list-style:none;display:grid;gap:18px}
.cred-col li{font-size:.94rem;color:var(--night-2)}
.cred-col li b{display:block;color:var(--night);font-weight:600;margin-bottom:3px;font-size:.97rem}
.cred-col li span{color:var(--slate);font-size:.86rem}
.lang li{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line-soft);padding-bottom:12px}
.lang li .lv{font-size:.78rem;color:var(--copper);letter-spacing:.03em}
@media(max-width:860px){.cred-grid{grid-template-columns:1fr;gap:40px}}

/* CONTACT */
.contact{background:var(--night);color:var(--cream);text-align:center;padding:130px 0}
.contact .sec-eyebrow{color:#8DA0A8;justify-content:center}
.contact h2{font-size:clamp(2.4rem,5.5vw,4rem);font-weight:300;color:#fff;margin:18px 0 24px;letter-spacing:-.01em}
.contact h2 em{font-style:italic;color:var(--copper)}
.contact .lede{font-size:1.12rem;color:#B6C2C7;max-width:48ch;margin:0 auto 44px;line-height:1.6}
.contact-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-cream{background:var(--cream);color:var(--night)}
.btn-cream:hover{background:#fff;transform:translateY(-2px)}
.contact-meta{margin-top:48px;font-size:.82rem;color:#6A7B83;letter-spacing:.04em}

/* FOOTER */
footer{background:var(--night);color:#6A7B83;padding:34px 0;border-top:1px solid rgba(244,240,232,.08)}
.foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.82rem}
.foot-inner a:hover{color:var(--copper)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.2,.6,.2,1),transform .8s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
:focus-visible{outline:2px solid var(--copper);outline-offset:3px}
