*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d0f;--bg-alt: #111114;--fg: #e8e6e1;--fg-muted: #8a8680;--fg-subtle: #3a3835;--accent: #dd9d2e;--accent-dim: oklch(72% .1 65);--rule: rgba(232, 230, 225, .08);--mono: "DM Mono", monospace;--serif: "DM Serif Display", Georgia, serif;--sans: "DM Sans", system-ui, sans-serif}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:256px 256px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--fg-subtle);border-radius:2px}.shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh;max-width:1200px;margin:0 auto}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:80px 48px 64px 56px;border-right:1px solid var(--rule)}.sidebar-name{font-family:var(--serif);font-size:1.35rem;font-weight:400;line-height:1.2;letter-spacing:-.01em;color:var(--fg);margin-bottom:6px}.sidebar-role{font-family:var(--mono);font-size:.7rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:40px}.sidebar-nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:16px;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted);text-decoration:none;padding:6px 0;transition:color .2s;position:relative}.nav-item:before{content:"";display:block;width:24px;height:1px;background:var(--fg-muted);transition:width .25s ease,background .2s;flex-shrink:0}.nav-item:hover,.nav-item.active{color:var(--fg)}.nav-item:hover:before,.nav-item.active:before{width:40px;background:var(--accent)}.sidebar-bottom{display:flex;flex-direction:column;gap:18px}.social-links{display:flex;flex-direction:column;gap:10px}.social-link{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--fg-muted);text-decoration:none;transition:color .2s}.social-link:hover{color:var(--accent)}.social-link svg{opacity:.6;transition:opacity .2s;flex-shrink:0}.social-link:hover svg{opacity:1}.main{padding:0 72px}section{padding:120px 0;border-bottom:1px solid var(--rule)}section:last-child{border-bottom:none}.section-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:40px;display:flex;align-items:center;gap:12px}.section-label:after{content:"";display:block;flex:1;height:1px;background:var(--rule);max-width:80px}#hero{padding-top:140px;padding-bottom:120px}.hero-index{font-family:var(--mono);font-size:.68rem;color:var(--fg-muted);letter-spacing:.1em;margin-bottom:32px}.hero-headline{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.6rem);font-weight:400;line-height:1.12;letter-spacing:-.02em;color:var(--fg);margin-bottom:28px;max-width:680px}.hero-headline em{font-style:italic;color:var(--accent)}.hero-sub{font-size:1rem;color:var(--fg-muted);font-weight:300;max-width:460px;line-height:1.75;margin-bottom:52px}.hero-actions{display:flex;align-items:center;gap:32px;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bg);background:var(--accent);border:none;padding:14px 28px;cursor:pointer;text-decoration:none;transition:opacity .2s,transform .2s}.btn-primary:hover{opacity:.88;transform:translateY(-1px)}.btn-primary svg{flex-shrink:0}.hero-links{display:flex;gap:24px}.hero-link{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;color:var(--fg-muted);text-decoration:none;transition:color .2s;padding-bottom:2px;border-bottom:1px solid transparent}.hero-link:hover{color:var(--fg);border-bottom-color:var(--fg-muted)}.about-text{font-size:1.05rem;line-height:1.85;color:var(--fg-muted);max-width:580px;font-weight:300}.about-text strong{color:var(--fg);font-weight:400}.experience-list{display:flex;flex-direction:column;position:relative}.experience-list:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--accent),rgba(232,230,225,.08) 90%)}.exp-item{display:grid;grid-template-columns:140px 1fr;gap:0 40px;padding:36px 0 36px 36px;position:relative;transition:background .2s}.exp-item:hover{background:#e8e6e105}.exp-item:before{content:"";position:absolute;left:3px;top:44px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:1.5px solid var(--accent);box-shadow:0 0 0 3px #dd9d2e1a;transition:background .2s,box-shadow .2s}.exp-item:hover:before{background:var(--accent);box-shadow:0 0 0 5px #dd9d2e26}.exp-date{font-family:var(--mono);font-size:.65rem;color:var(--fg-muted);letter-spacing:.06em;line-height:1.6;padding-top:1px}.exp-title{font-size:1rem;font-weight:500;color:var(--fg);margin-bottom:2px;letter-spacing:-.01em}.exp-org{font-family:var(--mono);font-size:.72rem;color:var(--accent);letter-spacing:.04em;margin-bottom:16px}.exp-org a{color:inherit;text-decoration:none;transition:opacity .2s}.exp-org a:hover{opacity:.75}.exp-bullets{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:20px}.exp-bullets li{font-size:.9rem;color:var(--fg-muted);line-height:1.65;padding-left:16px;position:relative}.exp-bullets li:before{content:"—";position:absolute;left:0;color:var(--fg-subtle);font-size:.75rem}.exp-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);border:1px solid var(--fg-subtle);padding:3px 8px;border-radius:2px;white-space:nowrap}.projects-grid{display:flex;flex-direction:column;gap:20px}.proj-card{background:var(--bg-alt);border:1px solid var(--rule);padding:40px 44px;position:relative;transition:border-color .25s,transform .25s;overflow:hidden}.proj-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .3s ease}.proj-card:hover{border-color:#e8e6e124;transform:translate(4px)}.proj-card:hover:before{transform:scaleY(1)}.proj-card.placeholder{opacity:.45}.proj-card.placeholder:hover{opacity:.65}.proj-num{font-family:var(--mono);font-size:.6rem;color:var(--fg-subtle);letter-spacing:.14em;margin-bottom:18px}.proj-name{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--fg);letter-spacing:-.01em;margin-bottom:4px;line-height:1.2}.proj-subtitle{font-family:var(--mono);font-size:.7rem;color:var(--accent);letter-spacing:.06em;margin-bottom:18px}.proj-desc{font-size:.9rem;color:var(--fg-muted);line-height:1.7;max-width:540px;margin-bottom:24px;font-weight:300}.proj-meta{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:22px}.proj-meta-item{display:flex;flex-direction:column;gap:2px}.proj-meta-label{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-subtle)}.proj-meta-value{font-family:var(--mono);font-size:.72rem;color:var(--fg-muted)}.proj-tech{display:flex;flex-wrap:wrap;gap:6px}#contact{border-bottom:none}.contact-inner{max-width:480px}.contact-heading{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:400;line-height:1.2;letter-spacing:-.02em;color:var(--fg);margin-bottom:20px}.contact-sub{font-size:.95rem;color:var(--fg-muted);line-height:1.75;font-weight:300;margin-bottom:44px}.contact-links{display:flex;flex-direction:column;gap:16px}.contact-link{display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--fg-muted);transition:color .2s;padding:12px 0;border-bottom:1px solid var(--rule)}.contact-link:hover{color:var(--fg)}.contact-link:hover .contact-link-arrow{transform:translate(4px);color:var(--accent)}.contact-link-text{display:flex;flex:1;align-items:center;gap:16px;min-width:0}.contact-link-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;flex:1}.contact-link-value{font-size:.9rem;flex:2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-link-arrow{font-size:1rem;color:var(--fg-subtle);transition:transform .2s,color .2s;margin-left:auto}.contact-link-icon{flex-shrink:0;opacity:.55;color:var(--fg-muted);transition:opacity .2s,color .2s}.contact-link:hover .contact-link-icon{opacity:1;color:var(--accent)}.footer{padding:48px 72px;display:flex;justify-content:space-between;align-items:center}.footer-copy{font-family:var(--mono);font-size:.65rem;color:var(--fg-subtle);letter-spacing:.06em}.fade-up{opacity:0;transform:translateY(22px);filter:blur(6px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1),filter .85s cubic-bezier(.22,1,.36,1)}.fade-up.visible{opacity:1;transform:translateY(0);filter:blur(0)}@media(max-width:900px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:32px 32px 24px;border-right:none;border-bottom:1px solid var(--rule);flex-direction:column;gap:0}.sidebar-nav,.sidebar-bottom{display:none}.sidebar-top{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:20px}.sidebar-name{margin-bottom:0;font-size:1.2rem}.sidebar-role{margin-bottom:0;text-align:right}.sidebar-nav{flex-direction:row;flex-wrap:wrap;gap:4px 20px}.nav-item{padding:8px 0}.sidebar-bottom,.social-links{flex-direction:row;flex-wrap:wrap;gap:14px 20px}.main{padding:0 32px}section{padding:80px 0}#hero{padding-top:48px;padding-bottom:80px}.exp-item{grid-template-columns:1fr;gap:4px;padding:28px 0 28px 32px}.exp-item:before{top:36px}.exp-date{order:-1;margin-bottom:6px}.footer{padding:24px 32px;flex-direction:column;gap:10px;text-align:center}#contact{padding-bottom:40px}}@media(max-width:600px){.main{padding:0 22px}.sidebar{padding:32px 22px 24px;gap:24px}section{padding:72px 0;scroll-margin-top:24px}#hero{padding-top:40px;padding-bottom:64px}#contact{padding-bottom:32px}.hero-headline{font-size:clamp(1.85rem,7vw,2.4rem)}.hero-sub{margin-bottom:36px}.hero-actions{flex-direction:column;align-items:flex-start;gap:24px}.hero-links{flex-wrap:wrap;gap:16px 20px}.btn-primary{width:100%;justify-content:center;padding:16px 24px}.section-label{margin-bottom:28px}.about-text{font-size:1rem;line-height:1.8}.exp-item{padding:24px 0 24px 28px}.exp-bullets li{font-size:.88rem}.proj-card{padding:28px 22px}.proj-card:hover{transform:none}.proj-name{font-size:1.3rem}.contact-link{gap:14px;padding:14px 0}.contact-link-text{flex-direction:column;align-items:flex-start;gap:2px}.contact-link-label{font-size:.62rem;flex:none}.contact-link-value{flex:none;font-size:.9rem;max-width:100%}.contact-link-arrow{margin-left:8px}}@media(hover:none){.proj-card:hover{transform:none}}.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:10000;pointer-events:none;box-shadow:0 0 12px #dd9d2e99;transition:width .1s linear}.cursor-glow{position:fixed;top:0;left:0;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(221,157,46,.1) 0%,rgba(221,157,46,.04) 25%,transparent 60%);transform:translate(-50%,-50%);pointer-events:none;z-index:9998;opacity:0;transition:opacity .4s ease;will-change:transform;mix-blend-mode:screen}body:hover .cursor-glow{opacity:1}.hero-headline em{position:relative;background:linear-gradient(90deg,var(--accent) 0%,oklch(82% .14 70) 50%,var(--accent) 100%);background-size:200% auto;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:text-shimmer 5s ease-in-out infinite;text-shadow:0 0 30px rgba(221,157,46,.15)}@keyframes text-shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.section-label:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:dot-pulse 2.4s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.nav-item.active:before{box-shadow:0 0 8px #dd9d2e99}.hero-link{position:relative;overflow:hidden}.hero-link:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--accent);transform:translate(-101%);transition:transform .4s cubic-bezier(.65,0,.35,1)}.hero-link:hover{color:var(--fg);border-bottom-color:transparent}.hero-link:hover:after{transform:translate(0)}.btn-primary{position:relative;overflow:hidden;box-shadow:0 0 #dd9d2e00,0 4px 14px #dd9d2e2e;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s ease,opacity .2s}.btn-primary:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);transform:translate(-100%);transition:transform .7s cubic-bezier(.22,1,.36,1)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 24px #dd9d2e59,0 8px 24px #dd9d2e40}.btn-primary:hover:after{transform:translate(100%)}.btn-primary svg{transition:transform .3s cubic-bezier(.22,1,.36,1);position:relative;z-index:1}.btn-primary:hover svg{transform:translate(4px)}.proj-card{--mx: 50%;--my: 50%;transform-style:preserve-3d;transition:border-color .4s ease,transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease}.proj-card:after{content:"";position:absolute;inset:0;background:radial-gradient(400px circle at var(--mx) var(--my),rgba(221,157,46,.08),transparent 40%);opacity:0;transition:opacity .4s ease;pointer-events:none}.proj-card:hover{border-color:#dd9d2e4d;box-shadow:0 0 0 1px #dd9d2e1a,0 20px 40px -20px #dd9d2e26,0 0 60px -20px #dd9d2e1a}.proj-card:hover:after{opacity:1}.proj-card>*{position:relative;z-index:1}.exp-item.current:before{background:var(--accent);animation:beacon-ping 2.4s ease-out infinite}@keyframes beacon-ping{0%{box-shadow:0 0 0 3px #dd9d2e26,0 0 #dd9d2e8c}to{box-shadow:0 0 0 3px #dd9d2e26,0 0 0 16px #dd9d2e00}}.tag{transition:color .25s ease,border-color .25s ease,background .25s ease,transform .25s ease}.tag:hover{color:var(--bg);background:var(--accent);border-color:var(--accent);transform:translateY(-1px)}.sidebar-name{background:linear-gradient(90deg,var(--fg) 0%,var(--fg) 50%,var(--accent) 100%);background-size:200% auto;background-position:0% 50%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;transition:background-position .6s ease}.sidebar:hover .sidebar-name{background-position:100% 50%}.contact-link{position:relative}.contact-link:after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--accent);transition:width .5s cubic-bezier(.22,1,.36,1)}.contact-link:hover:after{width:100%}.social-link,.section-label{position:relative}.nav-item{overflow:hidden}body:after{content:"";position:fixed;top:20%;left:50%;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(221,157,46,.04) 0%,transparent 60%);transform:translate(-50%,-50%);pointer-events:none;z-index:0;animation:orb-drift 18s ease-in-out infinite}@keyframes orb-drift{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-30%,-45%) scale(1.15)}}.shell,.footer{position:relative;z-index:2}.footer-copy{transition:color .3s ease}.footer-copy:hover{color:var(--fg-muted)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.fade-up{opacity:1;transform:none;filter:none}.cursor-glow,body:after{display:none}}@media(hover:none){.cursor-glow{display:none}.proj-card:after{display:none}.btn-primary:hover{transform:none}}
