@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@300;400&display=swap";.hero-section{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:10rem 2.5rem 5rem;max-width:var(--max-w);margin:0 auto;position:relative}.hero-layout{display:flex;align-items:center;gap:3.5rem}.hero-photo-wrap{flex-shrink:0}.hero-photo{object-fit:cover;border-radius:12px;display:block;border:1px solid var(--border)}.hero-photo--portrait{width:240px;height:300px;object-position:center top}.hero-photo--action{width:240px;height:380px;object-position:center 30%}.hero-text{display:flex;flex-direction:column;min-width:0}.hero-eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1.5rem}.hero-name{font-family:var(--font-serif);font-size:clamp(3rem,6vw,6rem);font-weight:300;line-height:.95;letter-spacing:-.02em;color:var(--ink);margin-bottom:2rem}.hero-name em{font-style:italic;color:var(--accent)}.hero-tagline{font-family:var(--font-serif);font-size:clamp(1rem,2vw,1.3rem);font-weight:300;font-style:italic;color:var(--ink-2);line-height:1.5;max-width:380px;margin-bottom:2.5rem}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.hero-scroll-hint{position:absolute;bottom:2.5rem;left:2.5rem;display:flex;flex-direction:column;align-items:center;gap:8px}.scroll-line{display:block;width:1px;height:50px;background:var(--ink-4);animation:lineGrow 2s ease-in-out infinite;transform-origin:top}@keyframes lineGrow{0%,to{transform:scaleY(1);opacity:.5}50%{transform:scaleY(.4);opacity:1}}.scroll-text{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-4);writing-mode:vertical-rl}@media (max-width: 1000px){.hero-photo--action{width:180px;height:280px}.hero-photo--portrait{width:180px;height:225px}.hero-layout{gap:2.5rem}}@media (max-width: 768px){.hero-layout{flex-direction:column;align-items:flex-start;gap:2rem}}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}.about-body{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2.5rem;font-size:15px;color:var(--ink-2);line-height:1.8}.about-links{display:flex;gap:1rem}.skills-header{margin-bottom:1.5rem}.skills-list{list-style:none}.skill-row{display:flex;justify-content:space-between;align-items:baseline;padding:.85rem 0;border-bottom:1px solid var(--border);gap:1rem}.skill-row:first-child{border-top:1px solid var(--border)}.skill-name{font-size:14px;font-weight:400;color:var(--ink);font-family:var(--font-sans)}.skill-note{font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--accent);letter-spacing:.06em;white-space:nowrap}@media (max-width: 800px){.about-grid{grid-template-columns:1fr;gap:3rem}}.cv-tabs{display:flex;gap:0;margin-bottom:3rem;border-bottom:1px solid var(--border)}.cv-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:var(--font-sans);font-size:13px;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);padding:.75rem 1.5rem;cursor:pointer;transition:color .2s,border-color .2s}.cv-tab:hover{color:var(--ink)}.cv-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.cv-timeline{display:flex;flex-direction:column;gap:2rem}.cv-entry{display:grid;grid-template-columns:140px 1fr;gap:2rem;align-items:start}.cv-entry-aside{display:flex;flex-direction:column;align-items:flex-end;padding-top:1.75rem;gap:.75rem}.cv-period{font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--ink-4);letter-spacing:.06em;white-space:nowrap}.cv-line{width:1px;height:40px;background:var(--border-md)}.cv-card{width:100%}.cv-role{font-family:var(--font-serif);font-size:1.2rem;font-weight:400;color:var(--ink);margin-bottom:.25rem}.cv-company{font-family:var(--font-mono);font-size:12px;font-weight:300;color:var(--accent);letter-spacing:.06em;margin-bottom:.75rem}.cv-desc{font-size:14px;color:var(--ink-2);line-height:1.75;margin-bottom:1rem}.cv-key-points{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:1rem}.cv-key-points li{font-size:13px;color:var(--ink-2);line-height:1.6;padding-left:1rem;position:relative}.cv-key-points li:before{content:"—";position:absolute;left:0;color:var(--accent)}.cv-tags{display:flex;flex-wrap:wrap;gap:6px}.skills-bars-wrap{max-width:600px;display:flex;flex-direction:column;gap:1.5rem}.skill-bar{display:flex;flex-direction:column;gap:8px}.skill-bar-meta{display:flex;justify-content:space-between}.skill-bar-label{font-size:14px;color:var(--ink);font-weight:400}.skill-bar-pct{font-family:var(--font-mono);font-size:12px;font-weight:300;color:var(--ink-3)}.skill-bar-track{height:3px;background:var(--border-md);border-radius:2px;overflow:hidden}.skill-bar-fill{height:100%;width:0;background:var(--accent);border-radius:2px;animation:fillBar 1.1s ease forwards}@keyframes fillBar{0%{width:0}to{width:var(--w)}}@media (max-width: 700px){.cv-entry{grid-template-columns:1fr;gap:.5rem}.cv-entry-aside{flex-direction:row;align-items:center;padding-top:0}.cv-line{width:20px;height:1px}}.projects-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.project-row{display:grid;grid-template-columns:48px 1fr auto;gap:1.5rem;align-items:start;padding:2rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background .2s;border-radius:var(--radius)}.project-row:hover{background:#1a1a1805}.project-row:hover .project-arrow{transform:translate(3px,-3px);color:var(--accent)}.project-row:hover .project-title{color:var(--accent)}.project-num{font-family:var(--font-mono);font-size:12px;font-weight:300;color:var(--ink-4);padding-top:.2rem;letter-spacing:.04em}.project-info{display:flex;flex-direction:column;gap:.4rem}.project-category{font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}.project-title{font-family:var(--font-serif);font-size:1.35rem;font-weight:400;color:var(--ink);transition:color .2s;line-height:1.2}.project-desc{font-size:14px;color:var(--ink-3);line-height:1.7;max-width:560px;margin:.25rem 0 .75rem}.project-tags{display:flex;flex-wrap:wrap;gap:6px}.project-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;padding-top:.2rem;min-width:100px}.project-status{font-family:var(--font-mono);font-size:11px;font-weight:300;letter-spacing:.08em;padding:3px 10px;border-radius:2px;white-space:nowrap}.status-live{color:var(--accent);background:var(--accent-light);border:1px solid rgba(45,90,61,.2)}.status-dev{color:var(--ink-3);background:var(--cream);border:1px solid var(--border-md)}.project-arrow{font-size:1.1rem;color:var(--ink-4);transition:transform .2s,color .2s}@media (max-width: 640px){.project-row{grid-template-columns:32px 1fr}.project-meta{display:none}}.hobbies-grid{display:grid;grid-template-columns:340px 1fr;gap:4rem;align-items:start}.hobbies-feature{position:sticky;top:6rem;display:flex;flex-direction:column;gap:1rem}.hobbies-feature-img{width:100%;height:480px;object-fit:cover;object-position:center 20%;border-radius:12px;border:1px solid var(--border);display:block}.hobbies-feature-caption{display:flex;flex-direction:column;gap:4px}.hobbies-feature-caption p{font-family:var(--font-serif);font-size:1.1rem;font-weight:400;font-style:italic;color:var(--ink)}.hobbies-list{display:flex;flex-direction:column}.hobby-row{padding:2rem 0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}.hobby-row:first-child{border-top:1px solid var(--border)}.hobby-title{font-family:var(--font-serif);font-size:1.3rem;font-weight:400;color:var(--ink)}.hobby-body{font-size:14px;color:var(--ink-2);line-height:1.8}.hobby-tags{display:flex;flex-wrap:wrap;gap:6px}@media (max-width: 900px){.hobbies-grid{grid-template-columns:1fr}.hobbies-feature{position:static}.hobbies-feature-img{height:300px}}.games-switcher{display:flex;gap:1rem;margin-bottom:2.5rem;flex-wrap:wrap}.game-switch-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:none;border:1px solid var(--border-md);border-radius:var(--radius);padding:.75rem 1.25rem;cursor:pointer;transition:all .2s;text-align:left}.game-switch-btn:hover{border-color:var(--ink-3)}.game-switch-btn.active{border-color:var(--accent);background:var(--accent-light)}.gsb-engine{font-family:var(--font-mono);font-size:10px;font-weight:300;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4)}.game-switch-btn.active .gsb-engine{color:var(--accent)}.gsb-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:400;color:var(--ink)}.game-panel{display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}.game-viewport{background:var(--ink);border-radius:var(--radius);overflow:hidden;aspect-ratio:16 / 9;position:relative}.game-cover{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;cursor:pointer;background:linear-gradient(135deg,#1a2e1a,#0d1a0d);transition:opacity .2s}.game-cover:hover{opacity:.92}.game-cover-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;padding:2rem}.game-engine-label{font-family:var(--font-mono);font-size:11px;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2)}.game-cover-title{font-family:var(--font-serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:300;font-style:italic;color:#e8f5e8}.game-cover-desc{font-size:14px;color:#c8f0c899;max-width:320px;line-height:1.6}.game-launch-btn{margin-top:.5rem}.game-iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.game-placeholder-launched{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,#1a2e1a,#0d1a0d)}.game-ph-msg{font-size:14px;color:#c8f0c899;text-align:center;line-height:1.6;max-width:340px}.game-ph-msg code{font-family:var(--font-mono);font-size:12px;color:var(--accent-2);background:#4a8c6126;padding:1px 6px;border-radius:2px}.game-meta{display:flex;flex-direction:column;gap:2rem;padding-top:.5rem}.game-meta-engine{font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:.25rem}.game-meta-title{font-family:var(--font-serif);font-size:1.4rem;font-weight:400;color:var(--ink);margin-bottom:.5rem}.game-meta-desc{font-size:14px;color:var(--ink-2);line-height:1.7}.game-controls-label{font-family:var(--font-mono);font-size:11px;font-weight:300;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);margin-bottom:.75rem}.game-controls{list-style:none;display:flex;flex-direction:column;gap:.5rem}.game-controls li{font-size:13px;color:var(--ink-2);font-family:var(--font-mono);font-weight:300;padding:.4rem 0;border-bottom:1px solid var(--border)}@media (max-width: 860px){.game-panel{grid-template-columns:1fr}}:root{--cream: #faf9f6;--white: #ffffff;--ink: #1a1a18;--ink-2: #3d3d3a;--ink-3: #7a7a74;--ink-4: #b8b8b0;--accent: #2d5a3d;--accent-2: #4a8c61;--accent-light: rgba(45, 90, 61, .08);--border: rgba(26, 26, 24, .1);--border-md: rgba(26, 26, 24, .18);--surface: rgba(250, 249, 246, .94);--surface-solid: #faf9f6;--font-serif: "Cormorant Garamond", Georgia, serif;--font-sans: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--section-pad: 7rem 2rem;--max-w: 1060px;--radius: 3px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--cream);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.7;font-weight:300;overflow-x:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--ink-4);border-radius:2px}.bg-scene{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;opacity:0;transition:opacity 1.4s ease}.bg-scene.active{opacity:1}.bg-scene img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.05);transition:transform 10s ease-out}.bg-scene.active img{transform:scale(1)}.bg-scene:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#faf9f61a,#faf9f680 35%,#faf9f6e0 65%,#faf9f6fc)}.app{position:relative;z-index:1}.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2.5rem;transition:background .5s,box-shadow .5s,padding .4s}.nav.scrolled{background:var(--surface);box-shadow:0 1px 0 var(--border);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:1rem 2.5rem}.nav-logo{font-family:var(--font-serif);font-size:1.2rem;font-weight:400;color:var(--ink);text-decoration:none;letter-spacing:.02em}.nav-logo span{font-style:italic;color:var(--accent)}.nav-links{display:flex;gap:2.25rem;list-style:none}.nav-links a{font-size:12px;font-weight:400;color:var(--ink-2);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--accent)}.section-wrap{position:relative;z-index:2}section{padding:var(--section-pad);max-width:var(--max-w);margin:0 auto}.eyebrow{font-family:var(--font-mono);font-size:11px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.eyebrow:after{content:"";display:block;height:1px;width:40px;background:var(--accent);opacity:.4}.section-heading{font-family:var(--font-serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--ink);line-height:1.15;margin-bottom:3rem;letter-spacing:-.01em}.section-heading em{font-style:italic;color:var(--accent-2)}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 2rem;transition:border-color .25s,box-shadow .25s}.card:hover{border-color:var(--border-md);box-shadow:0 4px 28px #1a1a1812}.tag{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--ink-3);border:1px solid var(--border-md);border-radius:2px;padding:3px 10px;background:var(--cream);letter-spacing:.04em}.tag.accent{color:var(--accent);border-color:#2d5a3d40;background:var(--accent-light)}.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-sans);font-size:12px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border:1px solid var(--border-md);padding:11px 26px;border-radius:var(--radius);text-decoration:none;background:transparent;cursor:pointer;transition:all .22s}.btn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{background:#1e3d2a;border-color:#1e3d2a}hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.scene-break{position:relative;z-index:1;height:55vh;min-height:360px;display:flex;align-items:center;justify-content:center}.scene-break-inner{text-align:center;padding:0 2rem}.scene-break-label{font-family:var(--font-serif);font-size:clamp(1.8rem,5vw,4rem);font-weight:300;font-style:italic;color:#000;text-shadow:0 2px 30px rgba(0,0,0,.35);letter-spacing:.03em}.scene-break-sub{margin-top:1rem;font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#000000b3;text-shadow:0 1px 8px rgba(0,0,0,.4)}.footer{border-top:1px solid var(--border);padding:2rem 2.5rem;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--ink-4);font-family:var(--font-mono);font-weight:300;background:var(--surface-solid);position:relative;z-index:2}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .8s ease both}.fade-up-2{animation:fadeUp .8s .15s ease both}.fade-up-3{animation:fadeUp .8s .3s ease both}.fade-up-4{animation:fadeUp .8s .45s ease both}@media (max-width: 768px){:root{--section-pad: 4rem 1.25rem}.nav{padding:1rem 1.25rem}.nav.scrolled{padding:.75rem 1.25rem}.nav-links{display:none}.footer{flex-direction:column;gap:.5rem;text-align:center}}
