main.portfolio{display:block}main.portfolio section{max-width:1200px;margin:0 auto;padding:8rem 5%}.section-header{text-align:center;clip-path:inset(0 100% 0 0);margin-bottom:4rem;font-size:clamp(2rem,5vw,3.5rem)}.section-header--instant{clip-path:inset(0)}.hero{min-height:100svh;padding-top:5rem;position:relative}.hero-inner{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:calc(100svh - 5rem);display:flex;position:relative}.hero-logo{opacity:1;width:clamp(150px,20vw,300px);max-width:100%;height:auto;margin-bottom:1.5rem}[data-theme=light] .hero-logo{filter:invert()}.hero-title{font-family:var(--font-label);color:var(--text-muted);opacity:1;letter-spacing:.18em;text-transform:uppercase;margin-bottom:2rem;font-size:clamp(.85rem,2vw,1.1rem);font-weight:700}.hero-tagline{letter-spacing:-.03em;opacity:1;max-width:900px;font-size:clamp(2rem,5vw,4rem);font-weight:600;line-height:1.1}.hero-tagline__rotator{vertical-align:bottom;height:1.1em;color:var(--accent);white-space:nowrap;will-change:width;line-height:1.1;display:inline-block;position:relative;overflow:hidden}.hero-tagline__rotator-track{will-change:transform;flex-direction:column;display:flex}.hero-tagline__rotator-word{white-space:nowrap;height:1.1em;line-height:1.1;display:block}.work-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (min-width:800px){.work-grid{grid-template-columns:repeat(2,1fr)}.work-card:first-child{grid-column:1/-1;grid-template-columns:1.2fr 1fr;display:grid}.work-card:first-child .card-visual{border-bottom:none;border-right:1px solid var(--border);height:100%}}.work-card{background-color:var(--surface);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);clip-path:inset(0 round 24px);isolation:isolate;color:var(--text);opacity:0;--card-entry-scale:.95;--card-entry-y:14;transform-style:preserve-3d;transform:translateY(calc((var(--card-lift,0) + var(--card-entry-y,0)) * 1px)) perspective(1000px) rotateX(calc(var(--card-ty,0) * 1deg)) rotateY(calc(var(--card-tx,0) * 1deg)) scale(var(--card-entry-scale,1));transition:border-color .32s var(--ease-out), box-shadow .42s var(--ease-out);border-radius:24px;flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.work-card:before{content:"";background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 70%, transparent), transparent);opacity:0;width:60%;height:1px;transition:opacity .38s var(--ease-out);z-index:4;pointer-events:none;position:absolute;top:0;left:50%;transform:translate(-50%)}.work-card:after{content:"";background:radial-gradient(240px circle at var(--mx,-100%) var(--my,-100%), color-mix(in srgb, var(--accent) 13%, transparent), transparent 65%);opacity:0;transition:opacity .32s var(--ease-out);pointer-events:none;z-index:3;border-radius:inherit;mix-blend-mode:plus-lighter;position:absolute;inset:0}[data-theme=light] .work-card:after{mix-blend-mode:multiply;background:radial-gradient(240px circle at var(--mx,-100%) var(--my,-100%), color-mix(in srgb, var(--accent) 9%, transparent), transparent 65%)}.work-card:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--border));box-shadow:0 28px 60px -20px color-mix(in srgb, var(--accent) 32%, transparent), 0 12px 24px #00000038}.work-card:hover:before,.work-card:hover:after{opacity:1}[data-theme=light] .work-card:hover{box-shadow:0 28px 60px -20px color-mix(in srgb, var(--accent) 22%, transparent), 0 10px 22px #0000000f}@supports (animation-timeline:view()){.native-scroll-animations .section-header:not(.section-header--instant){animation-name:section-header-reveal;animation-duration:1ms;animation-fill-mode:both;animation-timeline:view();animation-range:entry cover 34%}.native-scroll-animations .work-card{animation-name:work-card-reveal;animation-duration:1ms;animation-fill-mode:both;animation-timeline:view();animation-range:entry 8% cover 35%}@keyframes section-header-reveal{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0)}}@keyframes work-card-reveal{0%{opacity:0;transform:translateY(calc((var(--card-lift,0) + 14) * 1px)) perspective(1000px) rotateX(calc(var(--card-ty,0) * 1deg)) rotateY(calc(var(--card-tx,0) * 1deg)) scale(.95)}to{opacity:1;transform:translateY(calc((var(--card-lift,0) + 0) * 1px)) perspective(1000px) rotateX(calc(var(--card-ty,0) * 1deg)) rotateY(calc(var(--card-tx,0) * 1deg)) scale(1)}}}.card-visual{border-bottom:.5px solid var(--border);background-color:#111;width:100%;height:300px;position:relative;overflow:hidden}.card-visual:after{content:"";pointer-events:none;z-index:3;background:linear-gradient(#0000 55%,#00000052 100%);position:absolute;inset:0}[data-theme=light] .card-visual:after{background:linear-gradient(#0000 60%,#00000014 100%)}.card-visual img{object-fit:cover;opacity:.92;width:100%;height:100%;transition:opacity .42s var(--ease-out), transform .6s var(--ease-out)}.work-card:hover .card-visual img{opacity:1;transform:scale(1.04)}.work-card--carousel{position:relative}.work-card--carousel .card-visual,.work-card--carousel .card-content{z-index:2;position:relative}.card-visual .carousel-image{opacity:0;pointer-events:none;z-index:1;transition:opacity .5s,transform .5s;position:absolute;inset:0;transform:scale(1.02)}.card-visual .carousel-image.is-active{opacity:.95;z-index:2;transform:scale(1)}.work-card:hover .card-visual .carousel-image{opacity:0}.work-card:hover .card-visual .carousel-image.is-active{opacity:1;transform:scale(1.04)}.carousel-control{-webkit-backdrop-filter:blur(10px);color:#fff;cursor:pointer;width:2.5rem;height:2.5rem;transition:background-color .22s var(--ease-out), border-color .22s var(--ease-out), transform .22s var(--ease-spring);z-index:4;background:#00000059;border:1px solid #fff3;border-radius:999px;place-items:center;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.carousel-control svg{stroke-width:2.5px;width:18px;height:18px}.carousel-control:hover{background:#0000008c;border-color:#fff6;transform:translateY(-50%)scale(1.1)}.carousel-control:active{transform:translateY(-50%)scale(.95)}.carousel-control:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.carousel-control.prev{left:.85rem}.carousel-control.next{right:.85rem}.carousel-dots{z-index:4;gap:.5rem;display:flex;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.carousel-dot{cursor:pointer;width:8px;height:8px;transition:width .26s var(--ease-spring), background-color .2s var(--ease-out);background:#ffffff59;border:none;border-radius:999px}.carousel-dot.is-active{background:#fff;width:24px}.carousel-dot:hover{background:#ffffffb3}.carousel-dot:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-content{z-index:2;flex-direction:column;justify-content:center;padding:2rem 2.25rem 2.25rem;display:flex;position:relative}@media (min-width:800px){.work-card:first-child .card-content{padding:2.75rem 3rem}}.card-tag{text-transform:uppercase;letter-spacing:.12em;width:fit-content;color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border:.5px solid color-mix(in srgb, var(--accent) 28%, transparent);border-radius:999px;align-items:center;margin-bottom:1rem;padding:.35rem .75rem;font-size:.7rem;font-weight:600;display:inline-flex}.card-title{letter-spacing:-.025em;margin-bottom:.65rem;font-size:clamp(1.5rem,2.2vw,2.1rem);line-height:1.15}.card-desc{letter-spacing:-.005em;color:var(--text-muted);font-size:1.0625rem;line-height:1.5}.card-links{flex-wrap:wrap;align-items:center;gap:.625rem;margin-top:1.5rem;display:flex}.card-link{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);border:.5px solid color-mix(in srgb, var(--accent) 30%, transparent);transition:background-color .22s var(--ease-out), border-color .22s var(--ease-out), color .22s var(--ease-out), transform .22s var(--ease-out);border-radius:999px;align-items:center;gap:.4rem;padding:.5rem .95rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.card-link:hover{background:color-mix(in srgb, var(--accent) 18%, transparent);border-color:color-mix(in srgb, var(--accent) 55%, transparent);transform:translateY(-1px)}.card-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.github-link{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);border:.5px solid color-mix(in srgb, var(--accent) 30%, transparent);transition:color .22s var(--ease-out), border-color .22s var(--ease-out), background-color .22s var(--ease-out), transform .22s var(--ease-out);border-radius:999px;align-items:center;gap:.5rem;padding:.5rem .95rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.card-links .github-link{margin-top:0}.github-link:hover{background:color-mix(in srgb, var(--accent) 18%, transparent);border-color:color-mix(in srgb, var(--accent) 55%, transparent);transform:translateY(-1px)}.github-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.github-link svg{fill:currentColor;width:.95rem;height:.95rem}.skills-section{max-width:1200px!important;padding:6rem 5%!important}.skills-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (min-width:640px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.skills-grid{grid-template-columns:repeat(3,1fr)}}.skill-card{background:var(--surface);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);opacity:0;--card-entry-y:40;transform-style:preserve-3d;transform:translateY(calc((var(--card-lift,0) + var(--card-entry-y,40)) * 1px)) perspective(900px) rotateX(calc(var(--card-ty,0) * 1deg)) rotateY(calc(var(--card-tx,0) * 1deg));transition:border-color .32s var(--ease-out), box-shadow .42s var(--ease-out);border-radius:20px;padding:1.75rem 1.75rem 1.5rem;position:relative;overflow:hidden}.skill-card:after{content:"";background:radial-gradient(210px circle at var(--mx,-100%) var(--my,-100%), color-mix(in srgb, var(--accent) 11%, transparent), transparent 65%);opacity:0;transition:opacity .32s var(--ease-out);pointer-events:none;z-index:0;border-radius:inherit;mix-blend-mode:plus-lighter;position:absolute;inset:0}[data-theme=light] .skill-card:after{mix-blend-mode:multiply;background:radial-gradient(210px circle at var(--mx,-100%) var(--my,-100%), color-mix(in srgb, var(--accent) 8%, transparent), transparent 65%)}.skill-card>*{z-index:1;position:relative}.skill-card:hover:after{opacity:1}.skill-card__accent{background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 70%, transparent), transparent);opacity:0;width:60%;height:2px;transition:opacity .38s var(--ease-out);pointer-events:none;position:absolute;top:0;left:50%;transform:translate(-50%)}.skill-card:hover{border-color:color-mix(in srgb, var(--accent) 25%, var(--border));box-shadow:0 20px 48px -16px color-mix(in srgb, var(--accent) 20%, transparent), 0 8px 16px #00000026}.skill-card:hover .skill-card__accent{opacity:1}.skill-card__header{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.skill-card__icon{width:22px;height:22px;color:var(--accent);flex-shrink:0}.skill-card__title{letter-spacing:-.02em;color:var(--text);font-size:1.05rem;font-weight:600}.skill-card__pills{flex-wrap:wrap;gap:.5rem;display:flex}.skill-pill{color:var(--text-muted);background:color-mix(in srgb, var(--accent) 8%, transparent);border:.5px solid color-mix(in srgb, var(--accent) 18%, transparent);transition:color .2s var(--ease-out), background-color .2s var(--ease-out), border-color .2s var(--ease-out), transform .2s var(--ease-spring);border-radius:999px;padding:.4rem .85rem;font-size:.82rem;font-weight:500}.skill-card:hover .skill-pill{color:var(--text);background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent)}.skill-pill:hover{transform:translateY(-1px);background:color-mix(in srgb, var(--accent) 18%, transparent)!important;border-color:color-mix(in srgb, var(--accent) 45%, transparent)!important}#companies.companies-section{max-width:1200px!important;padding:6rem 5%!important}.timeline{padding:2rem 0;position:relative}.timeline__line{width:2px;height:100%;color:var(--accent);opacity:.55;filter:drop-shadow(0 0 6px color-mix(in srgb, var(--accent) 45%, transparent));position:absolute;top:0;left:24px;overflow:visible}.timeline__track{stroke-dashoffset:2000px}@media (min-width:768px){.timeline__line{left:50%;transform:translate(-50%)}}.timeline__entries{flex-direction:column;gap:3rem;display:flex}.timeline__entry{grid-template-columns:1fr;gap:1rem;padding-left:64px;display:grid;position:relative}@media (min-width:768px){.timeline__entry{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;padding-left:0}.timeline__entry .timeline__card{grid-column:2;justify-self:start}.timeline__entry--left .timeline__card{grid-column:1;justify-self:end}}.timeline__node{background:var(--accent);border:3px solid var(--bg);width:18px;height:18px;box-shadow:0 0 0 2px var(--accent);z-index:2;transition:transform .4s var(--ease-spring), box-shadow .3s ease;border-radius:50%;position:absolute;top:1.5rem;left:16px;transform:scale(0)}.timeline__node.is-active{box-shadow:0 0 0 3px var(--accent), 0 0 20px 4px color-mix(in srgb, var(--accent) 35%, transparent);transform:scale(1)}@media (min-width:768px){.timeline__node{left:50%;transform:translate(-50%)scale(0)}.timeline__node.is-active{transform:translate(-50%)scale(1)}}.timeline__card{background:var(--surface);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);max-width:420px;transition:transform .38s var(--ease-spring), border-color .32s var(--ease-out), box-shadow .42s var(--ease-out);border-radius:20px;padding:1.5rem 1.75rem;position:relative}.timeline__card:hover{border-color:color-mix(in srgb, var(--accent) 25%, var(--border));box-shadow:0 20px 48px -16px color-mix(in srgb, var(--accent) 20%, transparent), 0 8px 16px #00000026;transform:translateY(-4px)}.timeline__logos{flex-wrap:wrap;align-items:center;gap:1.25rem;margin-bottom:.75rem;display:flex}.timeline__logo-link{align-items:center;display:flex}.timeline__logo-link img{object-fit:contain;filter:brightness(0)invert();width:auto;max-width:220px;height:clamp(44px,5vw,66px);transition:filter .3s;display:block}[data-theme=light] .timeline__logo-link img{filter:brightness(0)invert(0)}.timeline__card:hover .timeline__logo-link img{filter:none}.timeline__meta{flex-direction:column;align-items:flex-start;gap:.25rem;display:flex}.timeline__role{color:var(--text-muted);font-size:.85rem;font-weight:500}.timeline__years{color:var(--accent);font-size:.8rem;font-weight:500;font-family:var(--font-mono);letter-spacing:.02em}.timeline__sub-logo{align-items:center;display:flex}.timeline__sub-logo img{object-fit:contain;filter:brightness(0)invert();width:auto;max-width:220px;height:clamp(44px,5vw,66px);transition:filter .3s;display:block}[data-theme=light] .timeline__sub-logo img{filter:brightness(0)invert(0)}.timeline__card:hover .timeline__sub-logo img,.timeline__sub-logo:hover img{filter:saturate()brightness()}#companies-worked-with.companies-section{margin-top:-3rem;overflow:hidden;max-width:none!important;padding:3rem 5% 8rem!important}@media (min-width:768px){#companies-worked-with.companies-section{padding:3rem 8% 8rem!important}}.companies-track-wrapper{width:100%;overflow:hidden}.companies-carousel{white-space:nowrap;align-items:center;gap:5rem;width:max-content;display:flex}.companies-carousel:hover{animation-play-state:paused}.company-logo{opacity:.5;filter:grayscale()brightness(10);flex-shrink:0;align-items:center;transition:opacity .3s;display:flex}[data-theme=light] .company-logo{filter:grayscale()brightness(0)}.company-logo.logo-color{filter:none;opacity:.72}[data-theme=light] .company-logo.logo-color{filter:none}.company-logo.logo-wide img{max-width:180px}.company-logo.logo-youtube,.company-logo.logo-deezer{color:var(--text)}.company-logo.logo-youtube svg{width:auto;max-width:180px;height:clamp(22px,2.5vw,32px);display:block}.company-logo.logo-deezer svg{width:auto;max-width:180px;height:clamp(28px,3.2vw,44px);display:block}.company-logo.logo-invert{filter:grayscale()invert();opacity:.6}[data-theme=light] .company-logo.logo-invert{filter:grayscale()invert(0)}.company-logo img{object-fit:contain;width:auto;max-width:180px;height:clamp(28px,3.2vw,44px);display:block}.company-logo:hover{opacity:.9}@media (prefers-reduced-motion:reduce){#companies-worked-with .companies-track-wrapper{justify-content:center;display:flex;overflow:visible}#companies-worked-with .companies-carousel{white-space:normal;flex-wrap:wrap;justify-content:center;align-items:center;width:100%;max-width:72rem;margin-inline:auto}}.about-layout{grid-template-columns:1fr;gap:4rem;max-width:1000px;margin:0 auto;display:grid}@media (min-width:768px){.about-layout{grid-template-columns:1fr 1fr;align-items:center}}.about-bio{color:var(--text-muted);letter-spacing:-.01em;font-size:clamp(1.25rem,2vw,1.5rem);line-height:1.5}.about-bio strong{color:var(--text);font-weight:500}.about-image{aspect-ratio:1;pointer-events:none;border-radius:50%;width:100%;position:relative;overflow:hidden}.about-image img{object-fit:cover;filter:grayscale(20%);width:100%;height:100%}.contact{text-align:center;padding-bottom:12rem!important}.contact-links{flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem;display:flex}.contact-link{isolation:isolate;letter-spacing:-.03em;color:var(--text);background:var(--surface);-webkit-backdrop-filter:blur(20px);border:.5px solid var(--border);transition:color .26s var(--ease-out), border-color .22s var(--ease-out), transform .24s var(--ease-out);border-radius:100px;align-items:center;gap:.5em;padding:1rem 2rem;font-size:clamp(1.5rem,3vw,2.5rem);font-weight:600;display:inline-flex;position:relative;overflow:hidden;transform:translateY(0)scale(1)}.contact-link:before{content:"";background:var(--text);clip-path:circle(0% at var(--mx,50%) var(--my,50%));transition:clip-path .46s var(--ease-out);z-index:0;pointer-events:none;border-radius:inherit;position:absolute;inset:0}.contact-link>svg,.contact-link>span{z-index:1;position:relative}.contact-link svg{flex-shrink:0;width:.85em;height:.85em}.contact-link:hover{color:var(--bg);border-color:color-mix(in srgb, var(--text) 40%, var(--border));transform:translateY(-2px)scale(1)}.contact-link:hover:before{clip-path:circle(140% at var(--mx,50%) var(--my,50%))}.contact-link:active{transition-duration:.26s,.22s,.18s;transform:translateY(-2px)scale(.96)}@media (prefers-reduced-motion:reduce){.contact-link:before{transition:none}}
