@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Syne:wght@600;700;800&display=swap";.Header{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:300;width:min(1180px,92vw);min-height:72px;padding:.7rem 1rem;border-radius:18px;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.Header__logoAndTitle{display:flex;align-items:center;gap:.65rem;min-width:fit-content}.Header__logoAndTitle .logo{width:2.4rem;height:2.4rem}.Header__logoAndTitle .HeaderTitle{font-family:Syne,sans-serif;font-size:1.15rem;font-weight:700;color:var(--text-primary)}.Header__menu{display:flex;align-items:center;gap:1rem}.Header__menu .Header__menu__item{color:var(--text-secondary);font-weight:600;font-size:.95rem;position:relative;transition:color .25s ease}.Header__menu .Header__menu__item:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.Header__menu .Header__menu__item:hover{color:var(--text-primary)}.Header__menu .Header__menu__item:hover:after{transform:scaleX(1)}.Header__actions{display:flex;align-items:center;gap:.8rem}.changeMode{width:2.4rem;height:2.4rem;border-radius:50%;border:1px solid var(--surface-border);background:var(--surface-strong);display:grid;place-items:center;cursor:pointer;transition:transform .2s ease}.changeMode .moon{width:1.2rem;height:1.2rem}.changeMode:hover{transform:translateY(-2px)}.hamburger-menu{display:none;width:2.35rem;height:2.35rem;border-radius:10px;border:1px solid var(--surface-border);background:var(--surface-strong);padding:.52rem;cursor:pointer;flex-direction:column;justify-content:space-between}.hamburger-menu span{height:2px;width:100%;background:var(--text-primary);border-radius:999px;transition:transform .2s ease,opacity .2s ease}.hamburger-menu.active span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger-menu.active span:nth-child(2){opacity:0}.hamburger-menu.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}@media (max-width: 930px){.Header{width:94vw}.hamburger-menu{display:flex}.Header__menu{position:absolute;top:calc(100% + .7rem);left:0;right:0;border:1px solid var(--surface-border);background:var(--surface-strong);border-radius:16px;box-shadow:var(--shadow);flex-direction:column;align-items:stretch;gap:0;overflow:hidden;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .2s ease,transform .2s ease}.Header__menu .Header__menu__item{padding:.85rem 1rem;border-bottom:1px solid var(--surface-border)}.Header__menu .Header__menu__item:last-child{border-bottom:0}.Header__menu .Header__menu__item:after{display:none}.Header__menu.show{opacity:1;pointer-events:auto;transform:translateY(0)}}@media (max-width: 600px){.Header__logoAndTitle .HeaderTitle{font-size:1rem}}.AboutMeBox{border-radius:26px;background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow);padding:clamp(1.2rem,2.6vw,2.2rem);display:grid;gap:1rem}.AboutMeHeading{display:grid;gap:.4rem}.AboutMeKicker{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:700;color:var(--accent-alt)}.AboutMeTitle{font-size:clamp(1.65rem,3vw,2.35rem);color:var(--text-primary)}.AboutMeText{color:var(--text-secondary);max-width:70ch;font-size:clamp(.98rem,1.4vw,1.1rem)}.AboutMeHighlights{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:.5rem}.HighlightCard{padding:.9rem;border-radius:14px;background:var(--surface-strong);border:1px solid var(--surface-border)}.HighlightCard h3{font-size:1rem;margin-bottom:.25rem;color:var(--text-primary)}.HighlightCard p{font-size:.92rem;color:var(--text-secondary)}@media (max-width: 860px){.AboutMeHighlights{grid-template-columns:1fr}}.Hero{position:relative;overflow:hidden;min-height:clamp(420px,70vh,640px);border-radius:30px;border:1px solid var(--surface-border);background:var(--surface);box-shadow:var(--shadow);padding:clamp(1.5rem,3vw,3rem);display:flex;align-items:center}.Hero__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,rgba(255,137,110,.35),transparent 38%),radial-gradient(circle at 85% 75%,rgba(134,166,255,.28),transparent 34%),linear-gradient(120deg,rgba(255,255,255,.05),transparent);pointer-events:none}.Hero__content{position:relative;z-index:1;width:min(760px,100%);display:grid;gap:1.1rem}.Hero__eyebrow{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent-alt);font-weight:700}.HelloAnimation{font-size:clamp(2rem,5vw,3.6rem);line-height:1.12;color:var(--text-primary)}.Hero__subtitle{color:var(--text-secondary);font-size:clamp(1rem,1.7vw,1.14rem);max-width:62ch}.Hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.6rem}.Hero__button{padding:.75rem 1.05rem;border-radius:999px;font-weight:700;border:1px solid transparent;transition:transform .2s ease,background-color .2s ease}.Hero__button:hover{transform:translateY(-2px)}.Hero__button--primary{background:linear-gradient(120deg,#9f2632,#7c2045);color:#fff}.Hero__button--ghost{background:transparent;border-color:var(--surface-border);color:var(--text-primary)}@media (max-width: 768px){.Hero{min-height:420px;border-radius:24px}}.SkillsBox{border-radius:26px;background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow);padding:clamp(1.2rem,2.6vw,2.2rem);display:grid;gap:1.2rem}.SkillsHeading{display:grid;gap:.35rem}.SkillsHeading h2{color:var(--text-primary);font-size:clamp(1.55rem,2.7vw,2.2rem)}.SkillsKicker{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:700;color:var(--accent-alt)}.SkillsList{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;list-style:none}.skill{padding:.85rem;border-radius:14px;border:1px solid var(--surface-border);background:var(--surface-strong);display:grid;gap:.45rem;animation:cardIn .55s ease both}.skill__meta{display:flex;justify-content:space-between;gap:.5rem;align-items:center}.skill__meta p{color:var(--text-primary);font-weight:600}.skill__meta span{color:var(--text-secondary);font-size:.9rem}.progress-bar{-moz-appearance:none;appearance:none;-webkit-appearance:none;height:.65rem;width:100%;border-radius:999px;overflow:hidden;border:0;background:#d8e1f3}.progress-bar::-webkit-progress-bar{background:#d8e1f3;border-radius:999px}.progress-bar::-webkit-progress-value{border-radius:999px;background:linear-gradient(120deg,var(--accent),var(--accent-alt))}.progress-bar::-moz-progress-bar{border-radius:999px;height:100%;background:linear-gradient(120deg,var(--accent),var(--accent-alt))}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 860px){.SkillsList{grid-template-columns:1fr}}.ProjectsBox{border-radius:26px;background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow);padding:clamp(1.2rem,2.6vw,2.2rem);display:grid;gap:1.2rem}.ProjectsHeading{display:grid;gap:.4rem}.ProjectsHeading h2{color:var(--text-primary);font-size:clamp(1.55rem,2.7vw,2.2rem)}.ProjectsKicker{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:700;color:var(--accent-alt)}.ProjectsIntro{color:var(--text-secondary);max-width:68ch}.ListProject{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}@media (max-width: 980px){.ListProject{grid-template-columns:1fr}}.project-card{border:1px solid var(--surface-border);border-radius:18px;overflow:hidden;background:var(--surface-strong);display:grid;grid-template-rows:180px 1fr;min-height:420px;box-shadow:0 16px 34px #111a2e24;transition:transform .25s ease,box-shadow .25s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 22px 38px #111a2e33}.project-card__media{position:relative;overflow:hidden}.project-card__image{width:100%;height:100%;object-fit:cover;display:block}.project-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:.95rem;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,#0003,#000000b3)}.project-card__overlay h3{color:#fff;font-size:1.2rem}.project-status{width:fit-content;border-radius:999px;padding:.28rem .62rem;font-weight:700;font-size:.74rem}.project-status.in-progress{background:#ffeb99;color:#704c00}.project-status.done{background:#b8f5cb;color:#0d5a2b}.project-card__body{display:grid;gap:.82rem;padding:1rem}.project-card__body p{color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;min-height:5.4rem}.LanguageBox{display:flex;flex-wrap:wrap;gap:.45rem}.LanguageUsed{border-radius:999px;padding:.25rem .56rem;font-size:.74rem;font-weight:700}.LinkBox{display:flex;flex-wrap:wrap;gap:.55rem}.card-link{font-weight:700;font-size:.85rem;padding:.48rem .78rem;border-radius:10px;border:1px solid transparent;transition:transform .2s ease}.card-link:hover{transform:translateY(-1px)}.card-link--primary{background:linear-gradient(120deg,#9f2632,#7c2045);color:#fff}.card-link--ghost{border-color:var(--surface-border);color:var(--text-primary)}.Footer{width:min(1180px,92vw);margin:0 auto 2.5rem}.Footer__content{border-radius:26px;border:1px solid var(--surface-border);background:var(--surface);box-shadow:var(--shadow);padding:clamp(1.2rem,2.6vw,2.2rem);text-align:center}.Footer__kicker{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:700;color:var(--accent-alt)}.Footer h2{margin-top:.45rem;color:var(--text-primary);font-size:clamp(1.5rem,2.6vw,2.2rem)}.Footer__lead{color:var(--text-secondary);margin-top:.45rem}.Footer__actions{margin-top:1.1rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.65rem}.Btn{border:1px solid var(--surface-border);background:var(--surface-strong);border-radius:999px;padding:.45rem .72rem;display:inline-flex;align-items:center;gap:.45rem;cursor:pointer;transition:transform .2s ease,border-color .2s ease}.Btn:hover{transform:translateY(-2px);border-color:var(--accent-alt)}.svgIcon{width:1.1rem;height:1.1rem;filter:var(--icon-filter)}.texte{color:var(--text-primary);font-weight:700;font-size:.86rem}.Footer__copyright{margin-top:1.1rem;color:var(--text-secondary);font-size:.83rem}@media (max-width: 768px){.Footer{width:94vw}}@font-face{font-family:Spartan;src:url(/assets/league-spartan.bold-BupUha9D.ttf) format("truetype")}.Portfolio{width:100%;min-height:100vh;display:flex;flex-direction:column;transition:background-color .35s ease,color .35s ease;background:radial-gradient(circle at 10% 20%,rgba(242,95,76,.18),transparent 40%),radial-gradient(circle at 90% 10%,rgba(82,121,255,.16),transparent 35%),linear-gradient(160deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);color:var(--text-primary);--bg-primary: #f8f1e8;--bg-secondary: #f1f7ff;--surface: rgba(255, 255, 255, .78);--surface-strong: #ffffff;--surface-border: rgba(19, 25, 38, .08);--text-primary: #151b2d;--text-secondary: #4b556c;--accent: #f25f4c;--accent-alt: #3655d6;--chip: #ebf0ff;--shadow: 0 20px 45px rgba(21, 27, 45, .12);--icon-filter: invert(1)}.Portfolio.theme-dark{--bg-primary: #0f1424;--bg-secondary: #131e35;--surface: rgba(16, 24, 38, .82);--surface-strong: #111a2e;--surface-border: rgba(255, 255, 255, .08);--text-primary: #eef2ff;--text-secondary: #b5bfd9;--accent: #ff896e;--accent-alt: #86a6ff;--chip: #1d2943;--shadow: 0 24px 48px rgba(0, 0, 0, .45);--icon-filter: none}@media (max-width: 768px){.Portfolio{overflow-x:hidden}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.focus-animation:focus{animation:pulse .5s ease-in-out}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:Space Grotesk,sans-serif;line-height:1.6;overflow-x:hidden;background:#f6f1e9}h1,h2,h3{font-family:Syne,sans-serif;letter-spacing:.02em}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto}:focus-visible{outline:2px solid #f25f4c;outline-offset:2px}section{scroll-margin-top:94px}.portfolio-main{width:min(1180px,92vw);margin:0 auto;display:flex;flex-direction:column;gap:2.5rem;padding:7.5rem 0 4rem}.scroll-to-top{position:fixed;right:1.2rem;bottom:1.2rem;width:3rem;height:3rem;border:0;border-radius:999px;display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(8px);transition:opacity .25s ease,transform .25s ease,background-color .25s ease;z-index:200;color:#fff;background:linear-gradient(135deg,#9f2632,#641f57);box-shadow:0 12px 30px #641f5773}.scroll-to-top.visible{opacity:1;transform:translateY(0)}.scroll-to-top:hover{background:linear-gradient(135deg,#861f2b,#4f1847)}@media (max-width: 768px){.portfolio-main{width:94vw;padding-top:6.8rem;gap:1.8rem}}
