@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Inter:wght@300;400;500&family=JetBrains+Mono:wght@300;400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #f3ede0;--paper: #ebe4ce;--f1: #162a12;--f2: #224618;--f3: #356828;--f4: #4e8a3c;--f5: #72ac58;--f6: #a0cc84;--f7: #cce4b4;--fog: #c0d8a4;--mist: #dceacc;--ink: #182814;--ink-mid: #445c38;--ink-dim: #708060;--ink-faint: #9eae90;--serif: "Cormorant Garamond", Georgia, serif;--sans: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", monospace}html,body{height:100%;font-family:var(--sans);background:var(--cream);color:var(--ink);overflow:hidden}#root{height:100%}.screens{width:100%;height:100%;position:relative;overflow:hidden}.landing{position:absolute;inset:0;display:flex;flex-direction:column;z-index:2;transition:transform .95s cubic-bezier(.77,0,.18,1),opacity .6s}.landing.out{transform:translateY(-100%);opacity:0;pointer-events:none}.hero{flex:1;position:relative;overflow:hidden;background:#1a3214}.hero img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;z-index:1}.hero-overlay{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse at 18% 25%,rgba(160,204,132,.12) 0%,transparent 55%),linear-gradient(to top,rgba(22,42,18,.9) 0%,rgba(22,42,18,.25) 50%,transparent 80%)}.hero-trees{position:absolute;bottom:0;left:0;right:0;height:44%;z-index:3;pointer-events:none}.hero-name{position:absolute;bottom:0;left:0;right:0;z-index:5;padding:0 48px 48px}.hero-name h1{font-family:var(--serif);font-size:clamp(40px,6vw,68px);font-weight:300;line-height:1;color:#f3ede0;text-shadow:0 2px 28px rgba(0,0,0,.4)}.hero-name h1 em{font-style:italic;color:#c0dea0}.hero-name .tag{font-family:var(--mono);font-size:clamp(9px,1.2vw,10px);letter-spacing:.38em;color:#9ec87e;text-transform:uppercase;margin-top:9px}.enter-zone{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;pointer-events:none}.enter-btn{pointer-events:auto;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:12px;animation:breathe 3.2s ease-in-out infinite}.ring{width:72px;height:72px;border-radius:50%;border:1.5px solid rgba(192,222,160,.5);background:#162a1259;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;position:relative;transition:border-color .3s,background .3s}.ring:before{content:"";position:absolute;inset:-10px;border-radius:50%;border:1px solid rgba(192,222,160,.2);animation:ripple 3s ease-out infinite}.ring:after{content:"";position:absolute;inset:-22px;border-radius:50%;border:1px solid rgba(192,222,160,.1);animation:ripple 3s ease-out .6s infinite}.enter-btn:hover .ring{border-color:#c0dea0f2;background:#162a128c}.enter-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.34em;color:#c0dea0bf;text-transform:uppercase;transition:color .3s}.enter-btn:hover .enter-label{color:#c0dea0}.land-foot{background:var(--cream);border-top:1px solid var(--fog);padding:13px 48px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.foot-meta{font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase}.main{position:absolute;inset:0;display:flex;transform:translateY(100%);transition:transform .95s cubic-bezier(.77,0,.18,1);z-index:1;background:var(--cream)}.main.in{transform:translateY(0);z-index:3}.map-col{width:320px;flex-shrink:0;background:var(--paper);border-right:1.5px solid var(--fog);display:flex;flex-direction:column;overflow:hidden}.map-head{padding:18px 20px 13px;border-bottom:1px solid var(--fog);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.back-btn{background:none;border:none;cursor:pointer;font-family:var(--mono);font-size:8px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase;display:flex;align-items:center;gap:5px;transition:color .2s;padding:0}.back-btn:hover{color:var(--f2)}.map-title-wrap{text-align:right}.map-title{font-family:var(--serif);font-size:15px;font-weight:400;color:var(--ink)}.map-sub{font-family:var(--mono);font-size:7.5px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;margin-top:2px}.topo-wrap{flex:1;position:relative;overflow:hidden}#topoSvg{width:100%;height:100%}.map-foot{border-top:1px solid var(--fog);padding:12px 20px;display:flex;flex-direction:column;gap:5px;flex-shrink:0}.clink{display:flex;gap:10px;align-items:baseline;text-decoration:none;color:inherit;transition:color .2s}.clink:hover{color:var(--f2)}.ck{font-family:var(--mono);font-size:7.5px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;width:26px;flex-shrink:0}.cv{font-size:11px;color:var(--ink-mid)}.content-col{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.slide-win{flex:1;position:relative;overflow:hidden}.slide{position:absolute;inset:0;overflow-y:auto;padding:40px 52px 32px;opacity:0;pointer-events:none;transform:translateY(28px);transition:opacity .48s cubic-bezier(.4,0,.2,1),transform .48s cubic-bezier(.4,0,.2,1)}.slide.active{opacity:1;pointer-events:auto;transform:translateY(0)}.slide.leaving{opacity:0;transform:translateY(-28px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1)}.wm{position:absolute;right:32px;top:24px;font-family:var(--serif);font-size:130px;font-weight:600;font-style:italic;color:#3568280b;line-height:1;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sl-badge{display:flex;align-items:baseline;gap:14px;margin-bottom:6px}.sl-num{font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;color:var(--f3);text-transform:uppercase}.sl-elev{font-family:var(--mono);font-size:8.5px;letter-spacing:.2em;color:var(--ink-faint);margin-left:auto}.sl-title{font-family:var(--serif);font-size:clamp(32px,4vw,46px);font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:4px}.sl-title em{font-style:italic;color:var(--f2)}.sl-sub{font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--ink-dim);text-transform:uppercase}.fig-box{width:100%;height:210px;border:1px solid var(--fog);background:linear-gradient(135deg,var(--mist) 0%,var(--paper) 100%);display:flex;align-items:center;justify-content:center;margin:20px 0;overflow:hidden;position:relative}.fig-box svg{max-width:100%;max-height:100%}.photo-gallery{display:flex;flex-direction:column;gap:5px;margin:20px 0}.photo-row{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.photo-cell{position:relative;overflow:hidden;height:180px}.photo-cell img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .4s ease}.photo-cell:hover img{transform:scale(1.04)}.sl-lede{font-family:var(--serif);font-size:clamp(16px,1.9vw,19px);font-weight:300;font-style:italic;color:var(--ink-mid);line-height:1.85;margin-bottom:24px;border-left:2px solid var(--f5);padding-left:18px}.sl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--fog);margin-bottom:24px}.sl-hl{background:var(--cream);padding:14px 14px 12px}.hl-k{font-family:var(--mono);font-size:7.5px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:5px}.hl-v{font-family:var(--serif);font-size:19px;color:var(--ink)}.hl-v em{font-style:italic;color:var(--f2)}.sh{display:flex;align-items:center;gap:9px;margin-bottom:10px}.sh-line{flex:1;height:1px;background:var(--fog)}.sh-text{font-family:var(--mono);font-size:8px;letter-spacing:.28em;color:var(--ink-dim);text-transform:uppercase;white-space:nowrap}.sh-icon{flex-shrink:0;opacity:.5}.sl-moments{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.sl-moments li{font-size:clamp(12px,1.4vw,13px);color:var(--ink-mid);line-height:1.72;padding-left:18px;position:relative}.sl-moments li:before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-top:1.5px solid var(--f4);border-right:1.5px solid var(--f4);transform:rotate(45deg) scale(.6)}.sl-projects{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.sl-proj{background:var(--paper);border:1px solid var(--fog);padding:13px 15px}.proj-hd{display:flex;align-items:baseline;gap:9px;margin-bottom:5px}.proj-t{font-family:var(--serif);font-size:16px;font-weight:400;color:var(--ink)}.proj-st{font-family:var(--mono);font-size:8px;letter-spacing:.14em;color:var(--ink-dim);text-transform:uppercase}.proj-d{font-size:12px;color:var(--ink-mid);line-height:1.65;margin-bottom:8px}.proj-stack{display:flex;flex-wrap:wrap;gap:3px}.ptag{font-family:var(--mono);font-size:7.5px;letter-spacing:.12em;padding:2px 6px;border:1px solid var(--fog);color:var(--ink-dim);text-transform:uppercase}.sl-skills{display:flex;flex-direction:column;gap:11px;margin-bottom:20px}.sg-h{font-family:var(--mono);font-size:7.5px;letter-spacing:.2em;color:var(--f3);text-transform:uppercase;margin-bottom:5px}.sg-tags{display:flex;flex-wrap:wrap;gap:4px}.sg-tag{font-size:11px;color:var(--ink-mid);padding:3px 9px;background:var(--paper);border:1px solid var(--fog)}.sl-tags{display:flex;flex-wrap:wrap;gap:4px}.sl-tag{font-family:var(--mono);font-size:8px;letter-spacing:.12em;padding:2px 8px;border:1px solid var(--f7);color:var(--ink-dim);text-transform:uppercase;background:#4e8a3c0f}.hobby-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.hc{background:var(--paper);border:1px solid var(--fog);padding:12px 14px;display:flex;flex-direction:column;gap:5px}.hc-icon{font-size:22px;margin-bottom:2px}.hc-t{font-family:var(--serif);font-size:15px;color:var(--ink)}.hc-d{font-size:11px;color:var(--ink-mid);line-height:1.6}.content-nav{border-top:1.5px solid var(--fog);padding:12px 48px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.nav-arr{background:none;border:none;cursor:pointer;font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase;display:flex;align-items:center;gap:7px;transition:color .2s;padding:0}.nav-arr:hover{color:var(--f2)}.nav-arr:disabled{opacity:.18;cursor:default}.nav-center{display:flex;flex-direction:column;align-items:center;gap:7px}.nav-dots{display:flex;gap:6px}.ndot{width:5px;height:5px;border-radius:50%;background:var(--fog);cursor:pointer;border:none;padding:0;transition:background .25s,transform .25s}.ndot.on{background:var(--f2);transform:scale(1.55)}.nav-sname{font-family:var(--mono);font-size:8px;letter-spacing:.16em;color:var(--ink-dim);text-transform:uppercase}.mobile-map-btn{display:none}@media (max-width: 768px){.map-col{display:none;position:fixed;inset:0;z-index:10;width:100%;border-right:none}.map-col.mob-open{display:flex}.mobile-map-btn{display:block;position:fixed;bottom:74px;right:16px;z-index:8;background:var(--f2);color:var(--cream);border:none;cursor:pointer;width:44px;height:44px;border-radius:50%;font-size:18px;box-shadow:0 3px 12px #162a124d;transition:background .2s}.mobile-map-btn:hover{background:var(--f3)}.hero-name{padding:0 24px 32px}.hero-name h1{font-size:40px}.land-foot{padding:12px 24px}.slide{padding:24px 24px 16px}.wm{font-size:90px;right:16px;top:16px}.content-nav{padding:11px 24px}.sl-grid{grid-template-columns:repeat(2,1fr)}.photo-cell{height:110px}.hobby-cards{grid-template-columns:1fr}.fig-box{height:160px}}@keyframes breathe{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes ripple{0%{transform:scale(1);opacity:.6}to{transform:scale(1.35);opacity:0}}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes blink{50%{opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes dash{to{stroke-dashoffset:-20}}@keyframes glow{0%,to{opacity:.4}50%{opacity:.9}}@keyframes wave{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}
