@import"https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600&display=swap";:root{--bg: #0f0f0f;--bg2: #161616;--bg3: #1e1e1e;--border: rgba(255,255,255,.08);--text: #f0f0f0;--muted: #888;--accent: #9b6dff;--accent2: #c084fc;--fixe: #e07050;--aroud: #a855f7;--video: #3b82f6;--interactif: #ec4899;--floatland: #22d3ee;--memoir: #a1a1aa;--header-h: 64px;--r: 10px;--font-d: "Bebas Neue", sans-serif;--font-b: "Outfit", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-b);background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;overflow-x:clip}img,video,iframe{display:block;max-width:100%}a{color:inherit;text-decoration:none}#header{position:fixed;inset:0 0 auto 0;height:var(--header-h);background:#0f0f0fd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,56px);z-index:500}.logo{font-family:var(--font-d);font-size:1.6rem;letter-spacing:.04em;color:#fff;transition:color .2s}.logo:hover{color:var(--accent2)}.nav-links{display:flex;gap:36px}.nav-links a{font-size:.82rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .2s}.nav-links a:hover{color:#fff}.nav-cv{font-size:.75rem;font-weight:600;letter-spacing:.1em;color:var(--accent2);border:1px solid rgba(155,109,255,.35);padding:6px 14px;border-radius:5px;transition:background .2s,border-color .2s,color .2s;white-space:nowrap}.nav-cv:hover{background:#9b6dff1f;border-color:var(--accent);color:#fff}.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin:0}.burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .25s}.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.drawer{position:fixed;inset:var(--header-h) 0 0 0;background:#0a0a0af7;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;transform:translateY(-100%);opacity:0;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;z-index:490;pointer-events:none}.drawer.open{transform:translateY(0);opacity:1;pointer-events:auto}.drawer a{font-family:var(--font-d);font-size:2.4rem;letter-spacing:.06em;color:var(--text);transition:color .2s}.drawer a:hover{color:var(--accent2)}.drawer-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:480}#hero{position:sticky;top:0;min-height:50svh;display:flex;align-items:center;padding:calc(var(--header-h) + 48px) clamp(20px,6vw,96px) 80px;overflow:hidden;background:var(--bg);will-change:filter;z-index:1}#hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(ellipse 60% 50% at 70% 50%,rgba(80,30,160,.18) 0%,transparent 70%),url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:100%,200px;pointer-events:none;z-index:0}.hero-content{position:relative;z-index:1;max-width:780px}.hero-sub{font-size:.88rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}.hero-title{font-family:var(--font-d);font-size:clamp(3.2rem,8vw,7.5rem);line-height:1;letter-spacing:.01em;color:#fff;margin-bottom:24px}.hero-accent{color:var(--accent2);font-size:clamp(2.5rem,5vw,6rem)}.hero-desc{font-size:clamp(.95rem,1.4vw,1.1rem);color:var(--muted);max-width:520px;line-height:1.7;margin-bottom:40px}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;font-family:var(--font-b);font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:14px 28px;border-radius:4px;cursor:pointer;transition:background .2s,border-color .2s,color .2s;text-decoration:none}.btn-primary:hover{background:#ffffff0f;border-color:#fff}.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border);color:var(--muted);font-family:var(--font-b);font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:14px 28px;border-radius:4px;cursor:pointer;transition:color .2s,border-color .2s;text-decoration:none}.btn-ghost:hover{color:#fff;border-color:#ffffff4d}.btn-card{display:inline-flex;align-items:center;background:transparent;border:1px solid var(--border);color:var(--accent2);font-family:var(--font-b);font-size:.8rem;font-weight:500;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:12px;transition:background .2s,border-color .2s}.btn-card:hover{background:#9b6dff1a;border-color:var(--accent)}.section{position:relative;z-index:2;background:var(--bg);padding:80px clamp(20px,5vw,80px);scroll-margin-top:var(--header-h);border-top:1px solid var(--border)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:12px}.section-label{display:flex;align-items:center;gap:10px;font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:40px}.section-header .section-label{margin-bottom:0}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.dot-fixe{background:var(--fixe)}.dot-aroud{background:var(--aroud)}.dot-video{background:var(--video)}.dot-interactif{background:var(--interactif)}.dot-floatland{background:var(--floatland)}.dot-memoir{background:var(--memoir)}.see-all{font-size:.8rem;font-weight:500;color:var(--muted);transition:color .2s}.see-all:hover{color:#fff}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2px}.cards-grid.featured{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.card-project{background:var(--bg2);display:flex;flex-direction:column;overflow:hidden;transition:background .22s;cursor:pointer;text-decoration:none;color:inherit}.card-project:hover{background:var(--bg3)}.card-img-wrap{width:100%;aspect-ratio:4/3;overflow:hidden;background:#111}.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}.card-project:hover .card-img-wrap img{transform:scale(1.04)}.card-img-dark{background:#0a0a0a}.card-video-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;background:#000}.card-video-wrap iframe,.card-video-wrap video{width:100%;height:100%;border-radius:0;border:none;object-fit:cover}.card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:1.6rem;letter-spacing:.06em;color:#ffffff2e}.card-placeholder-code{font-family:var(--font-b);font-size:.9rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#9b6dff66}.card-info{padding:20px 22px 24px;display:flex;flex-direction:column;gap:6px;flex:1;position:relative}.card-info-top{padding-bottom:0}.card-cat{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent2)}.card-info h3{font-family:var(--font-b);font-size:1rem;font-weight:600;color:#fff;line-height:1.3}.card-info p{font-size:.84rem;color:var(--muted);line-height:1.55}.card-desc-clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-arrow{position:absolute;bottom:20px;right:20px;font-size:1rem;color:var(--muted);transition:color .2s,transform .2s}.card-project:hover .card-arrow{color:#fff;transform:translate(2px,-2px)}.card-wide{grid-column:span 2}.skills-section{background:var(--bg2)}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}.skill-item{background:var(--bg2);padding:40px 32px;display:flex;flex-direction:column;gap:12px}.skill-icon{font-size:1.1rem;color:var(--accent);line-height:1}.skill-item h4{font-family:var(--font-b);font-size:1rem;font-weight:600;color:#fff}.skill-item p{font-size:.83rem;color:var(--muted);line-height:1.6}.about-body{max-width:600px}.about-text h2{font-family:var(--font-d);font-size:clamp(2.4rem,4vw,3.8rem);line-height:1.05;letter-spacing:.02em;color:#fff;margin-bottom:20px}.accent{color:var(--accent2)}.about-text p{font-size:.96rem;color:var(--muted);line-height:1.75;margin-bottom:32px}.about-actions{display:flex;flex-wrap:wrap;gap:12px}.team-card{aspect-ratio:unset;min-height:160px;padding:24px}.team-grid{display:flex;flex-direction:column;gap:14px;width:100%}.team-member{display:flex;flex-direction:column;gap:2px}.team-member strong{font-size:.9rem;font-weight:600;color:#fff}.team-member span{font-size:.78rem;color:var(--muted)}.team-me strong{color:var(--accent2)}.revolte-game{display:flex;flex-wrap:wrap;gap:24px;padding:0 22px 24px;align-items:flex-start}.revolte-controls{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0}.deck-img{width:96px;height:150px;object-fit:cover;border-radius:8px 0;cursor:pointer;border:1px solid rgba(155,109,255,.3);transition:transform .2s,box-shadow .2s}.deck-img:hover{transform:translateY(-4px);box-shadow:0 8px 24px #9b6dff40}.revolte-btns{display:flex;flex-direction:column;gap:6px}.revolte-btns button{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:var(--font-b);font-size:.72rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:7px 14px;border-radius:4px;cursor:pointer;margin:0;transition:color .2s,border-color .2s}.revolte-btns button:hover{color:#fff;border-color:#ffffff4d}.game-container{display:flex;gap:20px;flex:1;min-width:0;flex-wrap:wrap}.suit-col{flex:1;min-width:140px;display:flex;flex-direction:column;gap:8px}.suit-label{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.suit-container{display:flex;flex-wrap:wrap;gap:6px}.card{width:72px;height:112px;background:var(--bg3);border:1px solid var(--border);border-radius:6px 0;overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s}.card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000080}.card img{width:100%;height:100%;object-fit:cover}.contact-section{background:var(--bg);text-align:center;padding-top:100px;padding-bottom:100px}.contact-pre{font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent2);margin-bottom:16px}.contact-title{font-family:var(--font-d);font-size:clamp(2.8rem,6vw,5.5rem);line-height:1.05;letter-spacing:.02em;color:#fff;margin-bottom:40px}.contact-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}footer{text-align:center;padding:28px;border-top:1px solid var(--border);font-size:.76rem;color:var(--muted);letter-spacing:.08em}.popup-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:900}.popup{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:32px;text-align:center;z-index:1000;max-width:min(420px,90vw);box-shadow:0 24px 80px #000c}.popup-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--muted);font-size:1rem;cursor:pointer;padding:6px;margin:0;transition:color .2s}.popup-close:hover{color:#fff}.popup h2{font-family:var(--font-d);font-size:1.6rem;letter-spacing:.04em;color:#fff;margin-bottom:12px}.popup img{width:min(260px,80vw);height:auto;aspect-ratio:2/3;object-fit:cover;border-radius:10px 0;margin:0 auto 16px;border:1px solid var(--border)}.popup p{font-size:.88rem;color:var(--muted);line-height:1.6}.detail-panel{position:fixed;top:var(--header-h);right:0;width:min(520px,92vw);height:calc(100vh - var(--header-h));background:var(--bg2);border-left:1px solid var(--border);padding:34px;z-index:600;overflow-y:auto;transform:translate(100%);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.22,.61,.36,1),opacity .25s;box-shadow:-30px 0 80px #00000073}.detail-panel.open{transform:translate(0);opacity:1;pointer-events:auto}.detail-panel .detail-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border:1px solid var(--border);background:#ffffff08;color:var(--text);border-radius:999px;cursor:pointer;font-size:.9rem;transition:background .2s,border-color .2s}.detail-panel .detail-close:hover{background:#9b6dff26;border-color:var(--accent)}.detail-overlay{position:fixed;inset:var(--header-h) 0 0 0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:590;opacity:0;pointer-events:none;transition:opacity .25s}.detail-overlay.open{opacity:1;pointer-events:auto}.detail-title{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:600;line-height:1.1;margin-bottom:8px;color:#fff}.detail-meta{color:var(--accent2);font-size:.84rem;margin-bottom:22px}.detail-cover{width:100%;aspect-ratio:16/9;object-fit:cover;background:#000;margin-bottom:20px;border:1px solid var(--border);border-radius:4px}.detail-desc{color:var(--muted);line-height:1.75;font-size:.92rem;margin-bottom:28px}.detail-infos{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);margin-bottom:28px}.detail-info{background:var(--bg2);padding:16px 18px}.detail-info strong{display:block;color:var(--accent2);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:5px}.detail-info span{color:var(--text);font-size:.86rem}.dp-media{width:100%;aspect-ratio:16/9;background:#000;border:1px solid var(--border);border-radius:4px;overflow:hidden;margin-bottom:8px}.dp-media img,.dp-media iframe{width:100%;height:100%;object-fit:contain;border:none;display:block}.dp-thumbs{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-bottom:20px}.dp-thumbs::-webkit-scrollbar{display:none}.dp-thumb{flex-shrink:0;width:72px;height:48px;border-radius:3px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:#111;transition:border-color .15s}.dp-thumb.active{border-color:var(--accent)}.dp-thumb img{width:100%;height:100%;object-fit:cover;display:block}.dp-thumb-video{display:flex;align-items:center;justify-content:center;position:relative}.dp-thumb-video span{font-size:.9rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8);position:relative;z-index:1}.dp-thumb-video:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0006}.doc-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;background:var(--bg2);border-radius:4px;padding:32px;text-align:center}.doc-card-icon{font-size:3.5rem;line-height:1}.doc-card-name{font-family:var(--font-d);font-size:1.4rem;letter-spacing:.04em;color:#fff}.doc-card-ext{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.doc-card-btn{margin-top:8px;display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;font-size:.82rem;font-weight:600;letter-spacing:.06em;padding:11px 22px;border-radius:6px;text-decoration:none;transition:background .2s,transform .15s}.doc-card-btn:hover{background:var(--accent2);transform:translateY(-2px)}.doc-card-dl{font-size:.76rem;color:var(--muted);text-decoration:none;transition:color .2s}.doc-card-dl:hover{color:#fff}.dp-thumb-doc{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:#ffffff0a;border-color:#ffffff1f;font-size:1.2rem;line-height:1}.dp-thumb-doc span{font-size:.55rem;font-weight:700;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}.doc-thumb{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:4px;cursor:pointer;transition:background .15s;padding:8px 4px}.doc-thumb:hover{background:#ffffff14}.doc-thumb.active{border-color:var(--accent)}.doc-thumb-icon{font-size:1.5rem;line-height:1}.doc-thumb-label{font-size:.65rem;font-weight:600;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}.dp-caption{font-size:.78rem;color:#ffffff61;font-style:italic;line-height:1.5;min-height:1em;margin-bottom:6px}.dp-contrib-title{color:var(--accent2);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}.dp-contrib-list{padding-left:18px;color:var(--muted);line-height:1.9;font-size:.88rem;margin-bottom:28px}.dp-voir-plus{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);color:var(--accent2);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:12px 20px;border-radius:4px;transition:background .2s,border-color .2s,color .2s}.dp-voir-plus:hover{background:#9b6dff1a;border-color:var(--accent);color:#fff}@media (max-width: 1024px){.skills-grid{grid-template-columns:repeat(2,1fr)}.card-wide{grid-column:span 1}}@media (max-width: 768px){.nav-links{display:none}.burger{display:flex}.hero-title{font-size:clamp(2.8rem,11vw,5rem)}.section{padding:56px clamp(16px,4vw,32px)}.skills-grid{grid-template-columns:repeat(2,1fr)}.cards-grid,.cards-grid.featured{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.card-wide{grid-column:span 1}.contact-title{font-size:clamp(2.4rem,8vw,4rem)}}@media (max-width: 480px){.skills-grid,.cards-grid,.cards-grid.featured{grid-template-columns:1fr}.hero-title{font-size:2.6rem}.about-actions{flex-direction:column}.contact-actions{flex-direction:column;align-items:center}.revolte-game{flex-direction:column}}@media (min-width: 1400px){.cards-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.cards-grid.featured{grid-template-columns:repeat(6,1fr)}.skills-grid{grid-template-columns:repeat(4,1fr)}}
