:root{--bg: #0a0b0d;--bg-2: #111316;--fg: #ececec;--fg-dim: #8a8f98;--fg-muted: #5a5f68;--line: rgba(255,255,255,.08);--line-strong: rgba(255,255,255,.18);--accent: #ff6b35;--accent-ink: #0a0b0d;--card: rgba(255,255,255,.02);--card-border: rgba(255,255,255,.07);--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;--sans: "Space Grotesk", system-ui, -apple-system, sans-serif;--serif: "Instrument Serif", Georgia, serif}[data-theme=light]{--bg: #f2efe9;--bg-2: #e8e4dc;--fg: #0e1012;--fg-dim: #555a63;--fg-muted: #8a8f98;--line: rgba(0,0,0,.08);--line-strong: rgba(0,0,0,.2);--accent-ink: #f2efe9;--card: rgba(0,0,0,.02);--card-border: rgba(0,0,0,.08)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--sans);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","ss02";transition:background .5s ease,color .5s ease}::selection{background:var(--accent);color:var(--accent-ink)}.app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}.bg-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}.chrome{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:color-mix(in oklab,var(--bg) 60%,transparent);flex-shrink:0;flex-wrap:wrap;gap:0}.chrome .brand{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.02em;text-transform:uppercase;color:var(--fg-dim)}.chrome .brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chrome .brand b{color:var(--fg);font-weight:600}.chrome nav{display:flex;gap:4px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.chrome nav button{background:none;border:1px solid transparent;color:var(--fg-muted);padding:8px 14px;cursor:pointer;font:inherit;text-transform:inherit;letter-spacing:inherit;border-radius:2px;transition:color .2s,border-color .2s,background .2s;position:relative}.chrome nav button:hover{color:var(--fg)}.chrome nav button.active{color:var(--fg);border-color:var(--line-strong);background:var(--card)}.chrome nav button .idx{opacity:.5;margin-right:6px}.chrome .meta{font-family:var(--mono);font-size:11px;color:var(--fg-muted);letter-spacing:.05em;display:flex;align-items:center;gap:16px}.chrome .meta .time{color:var(--fg-dim)}.chrome .meta .tweaks-btn{background:none;border:1px solid var(--line-strong);color:var(--fg-dim);padding:6px 10px;cursor:pointer;font:inherit;text-transform:uppercase;letter-spacing:.1em;transition:all .2s}.chrome .meta .tweaks-btn:hover{color:var(--fg);border-color:var(--fg)}.stage{position:relative;z-index:5;flex:1;overflow-y:auto;overflow-x:hidden;scroll-snap-type:y proximity;scroll-behavior:smooth;display:block}.stage::-webkit-scrollbar{width:8px}.stage::-webkit-scrollbar-track{background:transparent}.stage::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}.stage::-webkit-scrollbar-thumb:hover{background:var(--fg-muted)}.section{min-height:100%;width:100%;scroll-snap-align:start;padding:64px 64px 80px;position:relative;display:flex;flex-direction:column;border-bottom:1px solid var(--line)}.section-frame{flex:1;display:flex;flex-direction:column;gap:32px;max-width:1440px;width:100%;margin:0 auto}.section-tag{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim)}.section-tag .num{color:var(--accent);font-weight:600}.section-tag .line{flex:1;height:1px;background:linear-gradient(90deg,var(--line-strong),transparent);max-width:200px}.footer-bar{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 32px;border-top:1px solid var(--line);background:color-mix(in oklab,var(--bg) 60%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);flex-shrink:0}.footer-bar .progress{display:flex;gap:6px;align-items:center}.footer-bar .progress .seg{width:32px;height:2px;background:var(--line-strong);transition:background .3s}.footer-bar .progress .seg.active{background:var(--accent)}.footer-bar .progress .seg.visited{background:var(--fg-dim)}.footer-bar .arrows{display:flex;gap:8px;align-items:center}.footer-bar .arrows button{background:none;border:1px solid var(--line-strong);color:var(--fg-dim);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:2px;transition:all .2s;font-family:var(--mono)}.footer-bar .arrows button:hover{color:var(--fg);border-color:var(--fg)}.footer-bar .arrows button:disabled{opacity:.3;cursor:not-allowed}.footer-bar .hint{opacity:.6}.hero-wrap{flex:1;display:grid;grid-template-columns:1fr auto;align-items:stretch;gap:40px;padding-top:16px}.hero-title{font-family:var(--sans);font-weight:300;font-size:clamp(56px,10vw,160px);line-height:.92;letter-spacing:-.04em;margin-bottom:16px}.hero-title .i{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--accent);letter-spacing:-.02em}.hero-title .stroke{-webkit-text-stroke:1px var(--fg);color:transparent}.hero-sub{font-family:var(--mono);color:var(--fg-dim);font-size:13px;line-height:1.6;max-width:560px;margin-top:32px}.hero-sub b{color:var(--fg);font-weight:500}.hero-right{display:flex;flex-direction:column;justify-content:flex-end;gap:20px;align-items:flex-end;min-width:280px;font-family:var(--mono);font-size:11px;color:var(--fg-dim)}.hero-stat{text-align:right;border-right:1px solid var(--line-strong);padding-right:18px}.hero-stat .num{font-family:var(--sans);font-weight:300;font-size:48px;color:var(--fg);line-height:1;letter-spacing:-.03em}.hero-stat .lbl{text-transform:uppercase;letter-spacing:.15em;margin-top:6px;font-size:10px}.hero-meta{display:grid;grid-template-columns:auto auto auto;gap:48px;margin-top:24px;font-family:var(--mono);font-size:11px}.hero-meta .k{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.12em;font-size:10px;margin-bottom:6px}.hero-meta .v{color:var(--fg)}.hero-meta .v.accent{color:var(--accent)}.skills-header{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end}.skills-intro{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.65;color:var(--fg-dim);max-width:480px;padding-bottom:4px}.skills-intro b{color:var(--fg);font-weight:400}.skills-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:24px}.skills-title{font-family:var(--sans);font-weight:300;font-size:clamp(42px,5.5vw,84px);line-height:.95;letter-spacing:-.03em}.skills-title .i{font-family:var(--serif);font-style:italic;color:var(--accent)}.skill-group h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between}.skill-group h4 span{color:var(--accent)}.skill-list{display:flex;flex-direction:column;gap:2px;font-family:var(--mono);font-size:13px}.skill-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:8px 0;color:var(--fg);border-bottom:1px dashed var(--line)}.skill-row .yrs{color:var(--fg-muted);font-size:11px}.skill-row .bar{width:60px;height:3px;background:var(--line);position:relative;overflow:hidden}.skill-row .bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);transform-origin:left;transform:scaleX(var(--lvl, .5))}.exp-layout{display:grid;grid-template-columns:1fr 2fr;gap:56px;flex:1;align-items:start}.exp-title{font-family:var(--sans);font-weight:300;font-size:clamp(42px,5.5vw,84px);line-height:.95;letter-spacing:-.03em}.exp-title .i{font-family:var(--serif);font-style:italic;color:var(--accent)}.exp-intro{font-family:var(--mono);font-size:12px;color:var(--fg-dim);margin-top:24px;line-height:1.7;max-width:360px}.exp-intro-link{color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in oklab,var(--accent) 40%,transparent);transition:border-color .2s;white-space:nowrap}.exp-intro-link:hover{border-color:var(--accent)}.timeline{position:relative;padding-left:20px;border-left:1px solid var(--line-strong)}.timeline-item{padding:0 0 32px 32px;position:relative}.timeline-item:before{content:"";position:absolute;left:-26px;top:4px;width:11px;height:11px;border:1px solid var(--fg-dim);background:var(--bg);border-radius:50%;transition:all .25s}.timeline-item:hover:before,.timeline-item.active:before{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 20%,transparent)}.timeline-head{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}.timeline-head .role{font-size:20px;font-weight:500;letter-spacing:-.01em}.timeline-head .at{color:var(--fg-muted);font-family:var(--mono);font-size:13px}.timeline-head .co{color:var(--fg);font-weight:500}.timeline-head .co-link{color:var(--fg);font-weight:500;text-decoration:none;border-bottom:1px solid var(--line-strong);transition:color .2s,border-color .2s}.timeline-head .co-link:hover{color:var(--accent);border-color:var(--accent)}.timeline-meta{font-family:var(--mono);font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.1em;margin:6px 0 10px;display:flex;gap:16px}.timeline-desc{color:var(--fg-dim);font-size:14px;line-height:1.6;max-width:640px}.timeline-tags{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}.tag{font-family:var(--mono);font-size:10px;padding:3px 8px;border:1px solid var(--line-strong);color:var(--fg-dim);border-radius:2px;text-transform:uppercase;letter-spacing:.05em}.projects-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px}.projects-title{font-family:var(--sans);font-weight:300;font-size:clamp(42px,5.5vw,84px);line-height:.95;letter-spacing:-.03em;max-width:640px}.projects-title .i{font-family:var(--serif);font-style:italic;color:var(--accent)}.projects-nav{display:flex;gap:4px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em}.projects-nav button{background:none;border:1px solid var(--line-strong);color:var(--fg-dim);padding:8px 12px;font:inherit;text-transform:inherit;letter-spacing:inherit;cursor:pointer;transition:all .2s}.projects-nav button:hover{color:var(--fg);border-color:var(--fg)}.projects-nav button.active{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.projects-body{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;flex:1;min-height:0;overflow:hidden;align-items:stretch}.project-preview{background:var(--bg-2);border:1px solid var(--card-border);position:relative;overflow:hidden;aspect-ratio:16 / 9;max-height:340px;display:flex;align-items:center;justify-content:center}.project-media{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.project-media iframe{width:100%;height:100%;border:none;display:block}.project-media img{width:100%;height:100%;object-fit:cover;display:block}.project-preview .placeholder-stripe{position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,transparent,transparent 20px,var(--line) 20px,var(--line) 21px);opacity:.7}.project-preview .placeholder-label{position:relative;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--fg-muted);background:var(--bg);padding:8px 14px;border:1px solid var(--line-strong)}.project-preview .coords{position:absolute;bottom:12px;left:14px;font-family:var(--mono);font-size:10px;color:var(--fg-muted);letter-spacing:.1em}.project-preview .idx{position:absolute;top:16px;right:18px;font-family:var(--mono);font-size:10px;color:var(--fg-dim);letter-spacing:.1em}.project-detail{display:flex;flex-direction:column;gap:20px;overflow-y:auto;min-height:0}.project-detail .client{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent)}.project-detail h3{font-size:clamp(22px,2.2vw,32px);font-weight:400;line-height:1;letter-spacing:-.02em}.project-detail p{color:var(--fg-dim);line-height:1.65;font-size:15px}.project-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;border-top:1px solid var(--line);padding-top:20px;font-family:var(--mono);font-size:12px}.project-facts .k{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.12em;font-size:10px;margin-bottom:4px}.project-facts .v{color:var(--fg)}.project-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.project-selector{display:flex;gap:0;border-top:1px solid var(--line);margin-top:auto}.project-selector button{flex:1;background:none;border:none;border-right:1px solid var(--line);padding:16px 12px;text-align:left;cursor:pointer;font-family:var(--mono);font-size:11px;color:var(--fg-muted);transition:all .2s;min-width:0}.project-selector button:last-child{border-right:none}.project-selector button:hover{color:var(--fg);background:var(--card)}.project-selector button.active{color:var(--accent);background:var(--card)}.project-selector button .num{display:block;font-size:10px;opacity:.6;margin-bottom:4px}.project-selector button .nm{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.08em}.contact-wrap{flex:1;display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:stretch}.contact-main{display:flex;flex-direction:column;justify-content:space-between}.contact-headline{font-family:var(--sans);font-weight:300;font-size:clamp(48px,7vw,112px);line-height:.92;letter-spacing:-.035em}.contact-headline .i{font-family:var(--serif);font-style:italic;color:var(--accent)}.contact-headline .stroke{-webkit-text-stroke:1px var(--fg);color:transparent}.contact-links{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}.contact-link{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;padding:22px 4px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--fg);transition:padding .3s,color .3s;position:relative;overflow:hidden}.contact-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);transform:translate(-100%);transition:transform .4s cubic-bezier(.77,0,.175,1);z-index:-1}.contact-link:hover{padding-left:20px;color:var(--accent-ink)}.contact-link:hover:before{transform:translate(0)}.contact-link .platform{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--fg-muted);width:100px;transition:color .3s}.contact-link:hover .platform{color:var(--accent-ink);opacity:.7}.contact-link .handle{font-size:22px;font-weight:400;letter-spacing:-.01em}.contact-link .arr{font-family:var(--mono);font-size:18px;transition:transform .3s}.contact-link:hover .arr{transform:translate(4px)}.contact-photo{position:relative;overflow:hidden;border:1px solid var(--card-border);min-height:320px;max-height:480px;align-self:end}.contact-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(20%)}.tweaks{position:fixed;right:24px;bottom:70px;z-index:100;width:280px;background:color-mix(in oklab,var(--bg-2) 95%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:4px;padding:18px;font-family:var(--mono);font-size:11px;box-shadow:0 24px 60px #0006}.tweaks h4{font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}.tweaks h4 .close{background:none;border:none;cursor:pointer;color:var(--fg-muted);font-size:14px}.tweak-group{margin-bottom:16px}.tweak-group label{display:block;color:var(--fg-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.1em;font-size:10px}.tweak-opts{display:grid;grid-template-columns:1fr 1fr;gap:4px}.tweak-opts button{background:none;border:1px solid var(--line-strong);color:var(--fg-dim);padding:8px 10px;cursor:pointer;font:inherit;text-align:left;transition:all .2s}.tweak-opts button:hover{color:var(--fg);border-color:var(--fg-dim)}.tweak-opts button.active{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.tweak-colors{display:flex;gap:8px}.tweak-colors button{width:28px;height:28px;border:1px solid var(--line-strong);cursor:pointer;border-radius:50%;transition:transform .2s}.tweak-colors button:hover{transform:scale(1.15)}.tweak-colors button.active{border:2px solid var(--fg);box-shadow:0 0 0 2px var(--bg),0 0 0 3px var(--fg)}.tweak-theme{display:flex;gap:4px}.tweak-theme button{flex:1;background:none;border:1px solid var(--line-strong);color:var(--fg-dim);padding:8px;cursor:pointer;font:inherit;text-transform:uppercase;letter-spacing:.1em;font-size:10px;transition:all .2s}.tweak-theme button.active{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.blink-cursor:after{content:"▮";display:inline-block;margin-left:4px;color:var(--accent);animation:pulse 1s infinite;font-size:.7em;vertical-align:middle}.mono{font-family:var(--mono)}.dim{color:var(--fg-dim)}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (max-width: 960px){.section{padding:32px 24px}.hero-wrap,.skills-header,.skills-groups,.exp-layout,.projects-body,.contact-wrap{grid-template-columns:1fr}.projects-head{flex-direction:column;align-items:flex-start;gap:16px}.contact-photo{width:100%;justify-self:stretch;min-height:unset;max-height:unset}.contact-photo img{height:auto}.contact-link{gap:12px}.contact-link .platform{width:60px;font-size:10px}.contact-link .handle{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.footer-bar .hint{display:none}.chrome nav button .idx{display:none}.footer-bar .progress .seg{width:18px}.hero-right{flex-direction:row;justify-content:flex-start;align-items:flex-start;gap:32px;min-width:unset}.hero-stat{text-align:left;border-right:none;border-left:1px solid var(--line-strong);padding-right:0;padding-left:16px}.hero-stat .num{font-size:36px}}@media (max-width: 1100px){.chrome{padding:14px 20px;row-gap:0}.chrome .brand{flex:1}.chrome .meta{flex-shrink:0}.chrome nav{order:3;width:100%;border-top:1px solid var(--line);padding-top:10px;margin-top:10px;justify-content:flex-start;overflow-x:auto;scrollbar-width:none}.chrome nav::-webkit-scrollbar{display:none}.chrome nav button{padding:6px 10px;white-space:nowrap;flex-shrink:0}}
