:root{--bg: #FAFAFA;--fg: #09090B;--card: #FFFFFF;--muted: #F4F4F5;--muted-fg: #71717A;--border: #E4E4E7;--accent: #18181B;--accent-hover: #27272A;--accent-on: #FAFAFA;--accent-soft: rgba(24, 24, 27, .06);--highlight: #2563EB;--highlight-bg: rgba(37, 99, 235, .08);--radius-sm: 6px;--radius: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--z-header: 30;color-scheme:light}.dark{--bg: #09090B;--fg: #FAFAFA;--card: #18181B;--muted: #27272A;--muted-fg: #A1A1AA;--border: #3F3F46;--accent: #F4F4F5;--accent-hover: #E4E4E7;--accent-on: #09090B;--accent-soft: rgba(244, 244, 245, .07);--highlight: #60A5FA;--highlight-bg: rgba(96, 165, 250, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .65);color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html,body{overflow-x:clip}html{background:var(--bg);color:var(--fg);font-family:Space Grotesk,ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;background:var(--bg)}body,button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}button{border:0;cursor:pointer;background:transparent;padding:0}img,picture,video,canvas,svg{display:block;max-width:100%}ul,ol{list-style:none;padding:0;margin:0}p,h1,h2,h3,h4,h5,h6{margin:0}h1,h2,h3,h4{font-family:Archivo,ui-sans-serif,system-ui,sans-serif;font-weight:800;letter-spacing:-.025em;text-wrap:balance;line-height:1.08}p{line-height:1.7}::selection{background:var(--accent-soft)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .58s cubic-bezier(.16,1,.3,1),transform .58s cubic-bezier(.16,1,.3,1);transition-delay:var(--reveal-delay, 0ms);will-change:opacity,transform}[data-reveal].is-visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}.site-shell{min-height:100svh}.container{width:min(1100px,calc(100% - 3rem));margin-inline:auto}.topbar{position:sticky;top:0;z-index:var(--z-header);display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem clamp(1rem,4vw,2rem);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:saturate(160%) blur(18px)}.brand{display:flex;align-items:center;font-family:Archivo,sans-serif;font-weight:800;font-size:.95rem;letter-spacing:-.01em;color:var(--fg);transition:opacity .15s ease}.brand:hover{opacity:.65}.brand-name-short{display:none}.topbar-nav{display:flex;align-items:center;gap:.1rem}.topbar-nav a{display:inline-flex;align-items:center;height:2.1rem;padding:0 .8rem;border-radius:var(--radius-full);color:var(--muted-fg);font-size:.875rem;font-weight:500;transition:color .15s ease,background .15s ease;cursor:pointer}.topbar-nav a:hover{color:var(--fg);background:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:.5rem}.lang-switcher{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-full);padding:.18rem;gap:.05rem;background:var(--card);cursor:pointer}.lang-link{display:inline-flex;align-items:center;justify-content:center;height:1.75rem;padding:0 .65rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;letter-spacing:.04em;color:var(--muted-fg);transition:color .14s ease,background .14s ease;cursor:pointer}.lang-link.active{background:var(--fg);color:var(--bg)}.lang-link:not(.active):hover{color:var(--fg);background:var(--muted)}.theme-toggle{display:inline-grid;place-items:center;width:2.2rem;height:2.2rem;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--card);color:var(--muted-fg);transition:color .15s ease,border-color .15s ease;cursor:pointer;flex:none}.theme-toggle:hover{color:var(--fg);border-color:color-mix(in srgb,var(--fg) 35%,var(--border))}.theme-toggle svg{width:1rem;height:1rem}.icon-sun{display:none}.dark .icon-sun{display:block}.dark .icon-moon{display:none}.button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:2.65rem;border:1.5px solid transparent;border-radius:var(--radius-full);padding:0 1.4rem;font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease,box-shadow .14s ease;white-space:nowrap;text-decoration:none}.button:hover{transform:translateY(-1px)}.button-primary{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}.button-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.button-secondary{background:var(--card);color:var(--fg);border-color:var(--border)}.button-secondary:hover{border-color:color-mix(in srgb,var(--fg) 35%,var(--border));background:var(--muted)}.button-lg{min-height:3rem;padding:0 1.8rem;font-size:.95rem}.section{padding:clamp(4rem,8vw,6.5rem) 0}.section-alt{background:var(--muted)}.section-head{margin-bottom:clamp(2rem,4vw,3.5rem)}.section-head.center{text-align:center}.section-eyebrow{display:inline-block;margin-bottom:.6rem;color:var(--muted-fg);font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.section-head h2{font-size:clamp(1.9rem,4vw,3rem);color:var(--fg)}.section-lead{margin-top:.75rem;color:var(--muted-fg);font-size:1.05rem;max-width:50ch;line-height:1.65}.section-head.center .section-lead{margin-inline:auto}.hero{padding:clamp(4.5rem,11vw,9rem) 0 clamp(3rem,7vw,6rem)}.hero-inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:clamp(2.5rem,6vw,5.5rem)}.hero-text{width:min(760px,100%);max-width:100%}.hero-text h1{font-size:clamp(2.35rem,4.6vw,4.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.02;color:var(--fg);margin-bottom:.3rem;white-space:nowrap}.hero-role{font-family:Space Grotesk,sans-serif;font-size:clamp(1rem,2vw,1.2rem);font-weight:500;color:var(--muted-fg);margin-bottom:1.35rem}.hero-lead{font-size:clamp(1rem,1.8vw,1.125rem);color:var(--fg);line-height:1.68;max-width:52ch;margin-bottom:2rem}.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem}.hero-photo{margin:0;flex:none}.hero-photo img{width:clamp(160px,24vw,300px);aspect-ratio:1;object-fit:cover;object-position:center 15%;border-radius:var(--radius-xl);border:1.5px solid var(--border);box-shadow:var(--shadow-md)}.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.project-card{display:flex;flex-direction:column;border:1.5px solid var(--border);border-radius:var(--radius-xl);background:var(--card);overflow:hidden;transition:box-shadow .22s ease,transform .22s ease,border-color .22s ease;cursor:pointer}.project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:color-mix(in srgb,var(--fg) 18%,var(--border))}.project-featured{grid-column:1 / -1;display:grid;grid-template-columns:1.15fr 1fr}.project-shot{margin:0;overflow:hidden;background:var(--muted);flex:none}.project-shot img{width:100%;height:100%;object-fit:cover;transition:transform .38s ease}.project-card:hover .project-shot img{transform:scale(1.035)}.project-card:not(.project-featured) .project-shot{aspect-ratio:16 / 10}.project-info{padding:clamp(1.25rem,2.5vw,1.85rem);display:flex;flex-direction:column;gap:.7rem;flex:1}.project-meta{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.project-role-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted-fg);background:var(--muted);border:1px solid var(--border);padding:.15rem .55rem;border-radius:var(--radius-full)}.project-period{font-size:.78rem;color:var(--muted-fg)}.project-title{font-family:Archivo,sans-serif;font-size:clamp(1.2rem,1.8vw,1.45rem);font-weight:800;letter-spacing:-.02em;line-height:1.15}.project-desc{font-size:clamp(1rem,1.08vw,1.05rem);color:color-mix(in srgb,var(--fg) 72%,transparent);line-height:1.62}.project-stats{display:flex;flex-wrap:wrap;gap:.45rem}.project-stats li{font-size:.75rem;font-weight:700;color:var(--highlight);background:var(--highlight-bg);border:1px solid color-mix(in srgb,var(--highlight) 22%,transparent);border-radius:var(--radius-full);padding:.18rem .65rem}.tech-pills{display:flex;flex-wrap:wrap;gap:.35rem}.tech-pills li{font-size:.72rem;font-weight:500;color:var(--muted-fg);background:var(--muted);border:1px solid var(--border);border-radius:var(--radius-full);padding:.14rem .58rem}.project-link{display:inline-flex;align-items:center;align-self:flex-end;gap:.35rem;font-size:.82rem;font-weight:600;color:var(--muted-fg);transition:color .15s ease;margin-top:auto;padding-top:.25rem}.project-link:hover{color:var(--highlight)}.project-link svg{width:.82rem;height:.82rem;flex:none}.exp-list{display:flex;flex-direction:column;max-width:860px;margin-inline:auto}.exp-item{padding:2.1rem 0 2.1rem 2rem;border-left:2px solid var(--border);position:relative;transition:border-color .2s ease}.exp-item:before{content:"";position:absolute;left:-5px;top:2.35rem;width:8px;height:8px;border-radius:50%;background:var(--border);border:2px solid var(--bg);transition:background .2s ease,border-color .2s ease}.exp-item:hover{border-color:var(--accent)}.exp-item:hover:before{background:var(--accent);border-color:var(--bg)}.exp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.85rem;flex-wrap:wrap}.exp-title-group{display:flex;flex-direction:column;gap:.1rem}.exp-identity{display:flex;align-items:center;gap:.85rem;min-width:0}.exp-logo{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:contain;background:var(--card);border:1px solid var(--border);flex:none}.exp-company{font-family:Archivo,sans-serif;font-size:clamp(1.2rem,1.5vw,1.45rem);font-weight:800;color:var(--fg);letter-spacing:-.01em}.exp-role{font-size:1rem;font-weight:500;color:var(--muted-fg)}.exp-meta-group{display:flex;flex-direction:column;align-items:flex-end;gap:.08rem;flex-shrink:0}.exp-period{font-size:.92rem;font-weight:600;color:var(--fg);white-space:nowrap}.exp-location{font-size:.86rem;color:var(--muted-fg);white-space:nowrap}.exp-bullets{display:flex;flex-direction:column;gap:.4rem}.exp-bullets li{font-size:clamp(1rem,1.12vw,1.08rem);color:color-mix(in srgb,var(--fg) 72%,transparent);line-height:1.58;padding-left:1.15rem;position:relative}.exp-bullets li:before{content:"–";position:absolute;left:0;color:var(--muted-fg);font-weight:400}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.75rem}.service-card{border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--card);padding:clamp(1.35rem,2.5vw,1.85rem);transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease;cursor:default}.service-card:hover{box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--fg) 18%,var(--border));transform:translateY(-2px)}.service-num{display:inline-block;font-family:Archivo,sans-serif;font-size:.68rem;font-weight:800;letter-spacing:.06em;color:var(--muted-fg);margin-bottom:1rem}.service-card h3{font-family:Archivo,sans-serif;font-size:1.05rem;font-weight:800;letter-spacing:-.015em;margin-bottom:.55rem}.service-card p{font-size:.875rem;color:var(--muted-fg);line-height:1.62}.services-cta{text-align:center}.contact-section{text-align:center;min-height:100svh;display:flex;align-items:center}.contact-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}.contact-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;object-position:center 15%;border:2px solid var(--border);margin-bottom:.1rem}.contact-inner h2{font-size:clamp(1.75rem,3.5vw,2.6rem)}.contact-lead{color:var(--muted-fg);max-width:46ch;font-size:1.05rem;line-height:1.65}.contact-email{display:inline-flex;align-items:center;gap:.5rem;font-size:clamp(.9rem,1.8vw,1.05rem);color:var(--muted-fg);margin-top:.25rem;transition:color .15s ease}.contact-email strong{font-weight:700;color:var(--fg);border-bottom:1.5px solid var(--border);padding-bottom:.1rem;transition:border-color .15s ease}.contact-email:hover strong{border-color:var(--fg)}.contact-email:hover{color:var(--fg)}.contact-or{font-size:.82rem;color:var(--muted-fg);margin-top:.1rem}.contact-links{display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center}.contact-link{display:inline-flex;align-items:center;gap:.5rem;height:2.75rem;padding:0 1.2rem;border:1.5px solid var(--border);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;color:var(--fg);transition:border-color .15s ease,color .15s ease,background .15s ease;cursor:pointer}.contact-link:hover{border-color:color-mix(in srgb,var(--fg) 40%,var(--border));background:var(--muted)}.contact-link svg{width:1rem;height:1rem;flex:none}.footer{border-top:1px solid var(--border);background:var(--card);padding:1.5rem 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.78rem;color:var(--muted-fg)}@media(max-width:960px){.topbar-nav{display:none}.hero-inner{grid-template-columns:1fr;text-align:center}.hero-photo{order:-1;margin-inline:auto}.hero-photo img{width:120px;height:120px;border-radius:50%;object-position:center 12%}.hero-ctas{justify-content:center}.hero-lead{margin-inline:auto}.hero-text{width:100%}.hero-text h1{font-size:clamp(2.1rem,7.2vw,3.25rem)}.project-featured{grid-template-columns:1fr}}@media(max-width:900px){.project-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.topbar{padding:.7rem 1rem}.brand{font-size:.9rem;flex:none}.brand-name-full{display:none}.brand-name-short{display:inline}.lang-switcher{padding:.22rem}.lang-link{height:2.1rem;min-width:2.45rem;padding:0 .7rem;font-size:.78rem}.theme-toggle{width:2.65rem;height:2.65rem}.theme-toggle svg{width:1.1rem;height:1.1rem}.container{width:calc(100% - 2rem)}.project-grid{grid-template-columns:1fr}.hero-text h1{font-size:clamp(1.75rem,7.6vw,2.35rem)}.hero-ctas{flex-direction:column}.hero-ctas .button{width:100%}.exp-header{flex-direction:column;gap:.3rem}.exp-identity{align-items:flex-start}.exp-logo{width:40px;height:40px}.exp-meta-group{align-items:flex-start}.services-grid{grid-template-columns:1fr}.footer-inner{flex-direction:column;gap:.35rem;text-align:center}}
