@import"https://api.fontshare.com/v2/css?f[]=satoshi@400,500&display=swap";:root{--bg: #fff;--text: #000;--text-muted: #666;--card-bg: rgba(255, 255, 255, .92);--card-text: #444;--button-bg: #f5f5f5;--button-hover: #eee;--logo-filter: grayscale(100%) brightness(0) opacity(.5);--cv-border: #f0f0f0;--cv-border-light: #ddd;--cv-text-secondary: #555;--cv-bullet: #ccc}:root[data-theme=dark]{--bg: #0a0a0a;--text: #fff;--text-muted: #888;--card-bg: rgba(25, 25, 25, .95);--card-text: #aaa;--button-bg: #1a1a1a;--button-hover: #2a2a2a;--logo-filter: grayscale(100%) invert(1) opacity(.6);--cv-border: #222;--cv-border-light: #444;--cv-text-secondary: #aaa;--cv-bullet: #555}html,body,#root{height:100%}body{font-family:Satoshi,sans-serif;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}:root[data-theme=light] body{background:#fff;color:#000}:root:not([data-theme]) body{background:#fff;color:#000}@media (prefers-color-scheme: dark){:root:not([data-theme]) body{background:#0a0a0a;color:#fff}}:root[data-theme=dark] body{background:#0a0a0a;color:#fff}.layout{display:flex;height:100%}.left{width:50%;display:flex;align-items:center;justify-content:center;padding:4rem}.content{max-width:380px}.content p{font-size:1.125rem;font-weight:400;line-height:1.6;letter-spacing:-.01em;margin:0 0 1rem}.content .muted{color:var(--text-muted)}.bio-buttons{display:flex;gap:.5rem;margin-top:1.5rem}.cv-link{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1rem;font-size:.8125rem;font-weight:500;color:var(--text-muted);text-decoration:none;background:var(--button-bg);border:none;border-radius:8px;cursor:pointer;transition:all .15s ease}.cv-link:hover{background:var(--button-hover);color:var(--text)}.theme-toggle{position:fixed;bottom:1.5rem;left:1.5rem;z-index:100;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:transparent;border:1px solid var(--button-bg);border-radius:4px;cursor:pointer;transition:all .15s ease}.theme-toggle:hover{border-color:var(--text-muted);color:var(--text)}.theme-toggle svg{display:block}.right{width:50%;position:relative;height:100vh}.gradient-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:transparent;mask-image:linear-gradient(to right,transparent 0%,transparent 15%,rgba(0,0,0,.01) 22%,rgba(0,0,0,.04) 30%,rgba(0,0,0,.1) 38%,rgba(0,0,0,.2) 46%,rgba(0,0,0,.35) 54%,rgba(0,0,0,.52) 62%,rgba(0,0,0,.7) 70%,rgba(0,0,0,.84) 78%,rgba(0,0,0,.94) 86%,black 94%);-webkit-mask-image:linear-gradient(to right,transparent 0%,transparent 15%,rgba(0,0,0,.01) 22%,rgba(0,0,0,.04) 30%,rgba(0,0,0,.1) 38%,rgba(0,0,0,.2) 46%,rgba(0,0,0,.35) 54%,rgba(0,0,0,.52) 62%,rgba(0,0,0,.7) 70%,rgba(0,0,0,.84) 78%,rgba(0,0,0,.94) 86%,black 94%)}.scroll-indicator{position:absolute;bottom:2rem;right:2rem;z-index:3;font-size:.6875rem;font-weight:500;color:#fff6;font-variant-numeric:tabular-nums;letter-spacing:.05em}.timeline{position:absolute;right:2rem;top:50%;transform:translateY(-50%);z-index:3;display:flex;flex-direction:row-reverse;gap:.75rem;height:280px}.timeline-track{width:1px;background:#ffffff26;border-radius:0;position:relative}.timeline-progress{position:absolute;top:0;left:0;width:100%;background:#ffffffe6;border-radius:1px}.timeline-years{display:flex;flex-direction:column;justify-content:space-between;font-size:.75rem;font-weight:500;padding:.1rem 0}.timeline-years span{color:#ffffff59;transition:color .2s;line-height:1}.timeline-years span.active{color:#fffffff2}.cards-container{position:relative;z-index:1;height:100%;overflow-y:auto;padding:calc(50vh - 120px) 2rem calc(50vh - 120px)}.cards{display:flex;flex-direction:column;gap:2.5rem;max-width:420px;margin:0 auto}.card{will-change:transform,filter,opacity}.card-inner{display:block;background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;text-decoration:none;color:var(--text);transition:background .3s}.card-logo{height:20px;margin-bottom:1rem;display:flex;align-items:center;justify-content:flex-start;overflow:visible}.card-logo img{height:100%;width:auto;max-width:100px;filter:var(--logo-filter);transition:filter .3s}.card-logo img[src*=Oulu]{height:140%}.card-company{font-weight:500;font-size:1rem;display:block;margin-bottom:.25rem}.card-role{font-size:.9375rem;color:var(--text-muted);margin-bottom:.75rem;display:block}.card-description{font-size:.875rem;line-height:1.55;color:var(--card-text)}@media (max-width: 768px){html,body,#root{height:auto}.layout{flex-direction:column;height:auto;min-height:100vh}.left{width:100%;min-height:auto;padding:2.5rem 1.5rem 2rem;align-items:flex-start;justify-content:flex-start}.content{max-width:100%}.content p{font-size:1rem;line-height:1.5}.right{width:100%;height:auto;min-height:400px;padding:.75rem;position:relative}.gradient-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:0;mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.01) 6%,rgba(0,0,0,.04) 12%,rgba(0,0,0,.09) 18%,rgba(0,0,0,.16) 24%,rgba(0,0,0,.23) 30%,rgba(0,0,0,.32) 36%,rgba(0,0,0,.41) 42%,rgba(0,0,0,.5) 48%,rgba(0,0,0,.59) 54%,rgba(0,0,0,.68) 60%,rgba(0,0,0,.77) 66%,rgba(0,0,0,.84) 72%,rgba(0,0,0,.91) 78%,rgba(0,0,0,.96) 84%,rgba(0,0,0,.99) 90%,black 96%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.01) 6%,rgba(0,0,0,.04) 12%,rgba(0,0,0,.09) 18%,rgba(0,0,0,.16) 24%,rgba(0,0,0,.23) 30%,rgba(0,0,0,.32) 36%,rgba(0,0,0,.41) 42%,rgba(0,0,0,.5) 48%,rgba(0,0,0,.59) 54%,rgba(0,0,0,.68) 60%,rgba(0,0,0,.77) 66%,rgba(0,0,0,.84) 72%,rgba(0,0,0,.91) 78%,rgba(0,0,0,.96) 84%,rgba(0,0,0,.99) 90%,black 96%)}.timeline,.scroll-indicator,.theme-toggle{display:none}.cards-container{position:relative;z-index:1;height:auto;overflow:visible;padding:2rem 1.25rem}.cards{flex-direction:column;gap:1.25rem;max-width:100%}.card{filter:none!important;opacity:1!important;transform:none!important}.card-inner{padding:1.25rem}.card-description{font-size:.8125rem}}.cv{max-width:680px;margin:0 auto;padding:4rem 2rem;font-family:Satoshi,sans-serif;color:var(--text);background:var(--bg);min-height:100vh}.cv-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--cv-border)}.cv-header h1{font-size:2rem;font-weight:500;letter-spacing:-.02em;margin-bottom:.25rem}.cv-subtitle{color:var(--text-muted);font-size:1.0625rem;margin-bottom:1rem}.cv-contact{font-size:.875rem;color:var(--text-muted)}.cv-contact a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--cv-border-light);transition:border-color .2s}.cv-contact a:hover{border-color:var(--text)}.cv-sep{margin:0 .625rem;color:var(--cv-border-light)}.cv-section{margin-bottom:2.5rem}.cv-section h2{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1.25rem}.cv-item{margin-bottom:2rem;padding-left:1rem;border-left:2px solid var(--cv-border);transition:border-color .2s}.cv-item:hover{border-left-color:var(--cv-border-light)}.cv-item-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5rem;margin-bottom:.125rem}.cv-item-header strong{font-weight:500;font-size:1rem;letter-spacing:-.01em}.cv-location-inline{font-size:.8125rem;color:var(--text-muted)}.cv-item-sub{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5rem;font-size:.9375rem;color:var(--cv-text-secondary);margin-bottom:.5rem}.cv-date{font-size:.8125rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.cv-tags{display:inline-flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem;font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}.cv-detail{font-size:.875rem;color:var(--cv-text-secondary);line-height:1.5;margin-bottom:.25rem}.cv-role{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--cv-border)}.cv-role:first-of-type{margin-top:.5rem;padding-top:0;border-top:none}.cv-item ul{margin:.5rem 0 0;padding-left:0;list-style:none}.cv-item li{font-size:.875rem;color:var(--cv-text-secondary);line-height:1.6;margin-bottom:.375rem;padding-left:1rem;position:relative}.cv-item li:before{content:"";position:absolute;left:0;top:.625rem;width:4px;height:4px;background:var(--cv-bullet);border-radius:50%}.cv-achievements{padding-left:0;list-style:none}.cv-achievements li{font-size:.875rem;color:var(--cv-text-secondary);line-height:1.6;margin-bottom:.375rem;padding-left:1rem;position:relative}.cv-achievements li:before{content:"";position:absolute;left:0;top:.625rem;width:4px;height:4px;background:var(--cv-bullet);border-radius:50%}.cv-skills{display:grid;gap:.625rem}.cv-skills p{font-size:.875rem;color:var(--cv-text-secondary);line-height:1.5;margin:0}.cv-skills strong{font-weight:500;color:var(--text);margin-right:.25rem}.cv-back{display:inline-flex;align-items:center;gap:.375rem;margin-top:2rem;padding:.625rem 1rem;font-size:.8125rem;font-weight:500;color:var(--text-muted);text-decoration:none;background:var(--button-bg);border-radius:8px;transition:all .15s ease}.cv-back:hover{background:var(--button-hover);color:var(--text)}@media print{.cv{padding:0;max-width:100%}.cv-back{display:none}.cv-item{border-left:none;padding-left:0}}@media (max-width: 640px){.cv{padding:2.5rem 1.5rem}.cv-header h1{font-size:1.5rem}.cv-item-header,.cv-item-sub{flex-direction:column;gap:.125rem}.cv-item{padding-left:.75rem}}*{margin:0;padding:0;box-sizing:border-box}body{background:#fff;color:#000;font-family:Satoshi,-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased}
