*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #fafaf9;--color-surface: #ffffff;--color-border: #e8e5e0;--color-text: #1a1a1a;--color-text-secondary: #4a4a4a;--color-text-muted: #7a7a7a;--color-accent: #1a6b6a;--color-accent-hover: #124e4d;--color-accent-subtle: rgba(26, 107, 106, .07);--gradient-brand: linear-gradient(45deg, #1a6b6a, #7b4a6e, #c47a3a);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--max-width: 720px;--max-width-wide: 1100px;--radius: 6px;--transition: .15s ease}html{font-size:16px;scroll-behavior:smooth;scrollbar-gutter:stable}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-text);text-decoration:underline;text-decoration-color:var(--color-border);text-underline-offset:3px;transition:text-decoration-color var(--transition)}a:hover{text-decoration-color:var(--color-text)}.accent{background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.layout{display:flex;flex-direction:column;min-height:100vh;position:relative}.layout:before,.layout:after{content:"";position:fixed;top:0;bottom:0;width:calc((100vw - var(--max-width)) / 2);z-index:-1;background:radial-gradient(circle,rgba(26,107,106,.75) 1.5px,transparent 0) 0 0 / 28px 28px}.layout:before{left:0;mask-image:linear-gradient(to left,transparent 0%,black 100%);-webkit-mask-image:linear-gradient(to left,transparent 0%,black 100%)}.layout:after{right:0;mask-image:linear-gradient(to right,transparent 0%,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 100%)}.main{flex:1;width:100%;max-width:var(--max-width);margin:0 auto;padding:0rem 1.5rem 1rem}.navbar{position:sticky;top:0;z-index:100;background:#fafaf9eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:none;border-image:var(--gradient-brand) 1;border-bottom-width:2px;border-bottom-style:solid}.navbar-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.5rem}.navbar-brand{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.navbar-brand:hover{color:var(--color-text);text-decoration:none}.navbar-links{display:flex;gap:1.75rem}.navbar-links a{color:var(--color-text-muted);font-size:.875rem;font-weight:500;text-decoration:none;transition:color var(--transition)}.navbar-links a:hover,.navbar-links a.active{color:var(--color-text)}.navbar-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.navbar-toggle span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:all var(--transition)}.navbar-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-toggle.open span:nth-child(2){opacity:0}.navbar-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:640px){.navbar-toggle{display:flex}.navbar-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fafaf9fa;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease}.navbar-links.open{max-height:300px}.navbar-links a{padding:.85rem 1.5rem;border-top:1px solid var(--color-border)}}.footer{border-top:1px solid var(--color-border);padding:2rem 1.5rem;margin-top:auto;background:#fafaf9d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer p{color:var(--color-text-muted);font-size:.8rem}.footer-links{display:flex;gap:1.25rem}.footer-links a{color:var(--color-text-muted);font-size:.8rem;text-decoration:none}.footer-links a:hover{color:var(--color-text)}.page{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.section{margin-top:2rem}.section h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem}.section h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.section-subtitle{color:var(--color-text-muted);font-size:1rem;margin-bottom:2rem}.hero-with-photo{position:relative;overflow:hidden;margin-bottom:2.5rem;aspect-ratio:27 / 9}.hero-with-photo .hero-photo{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem 1.5rem;background:linear-gradient(45deg,#0a2d41,#4623378c,#aa5a2800)}.hero-overlay h1{font-size:2.5rem;font-weight:900;letter-spacing:-.03em;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,1)}.hero-overlay .hero-subtitle{margin-top:.2rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,1)}.home-bio p{font-size:1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:1.25rem}.home-bio p:last-child{margin-bottom:0}@media(max-width:720px){.hero-overlay{padding:3.5vw}.hero-overlay h1{font-size:5.5vw}.hero-overlay .hero-subtitle{font-size:2.5vw}.hero-with-photo{margin-bottom:3.5vw}}.hero h1{font-weight:900;letter-spacing:-.04em;line-height:1.1;margin-bottom:1rem}.hero-subtitle{font-size:1.1rem;color:var(--color-text-secondary);max-width:520px;line-height:1.7}.hero-overlay .hero-subtitle{margin-bottom:0}.hero-links{display:flex;flex-wrap:wrap;gap:.75rem}.hero-links a{font-size:.9rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;padding:.45rem 0;border-bottom:1px solid var(--color-border);transition:color var(--transition),border-color var(--transition)}.hero-links a:hover{color:var(--color-text);border-color:var(--color-text)}.btn{display:inline-flex;align-items:center;padding:.6rem 1.25rem;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);border:none;text-decoration:none}.btn-primary{background:var(--color-text);color:var(--color-bg)}.btn-primary:hover{background:var(--color-text-secondary);color:var(--color-bg)}.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-outline:hover{border-color:var(--color-text)}.card-grid{display:grid;grid-template-columns:1fr;gap:1rem}.card{padding:1.25rem 0;border-bottom:1px solid var(--color-border);transition:none}.card:last-child{border-bottom:none}.card h3{font-size:1rem;font-weight:700;margin-bottom:.3rem;letter-spacing:-.01em}.card p{color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.project-card{position:relative}.project-tag{display:inline-block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-accent);margin-bottom:.4rem;display:none}.project-tech{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.project-tech span{font-size:.75rem;font-family:var(--font-mono);color:var(--color-text-muted)}.project-tech span:not(:last-child):after{content:" ·";color:var(--color-border)}.placeholder-card{opacity:.5}.about-content{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-top:1.5rem}@media(min-width:640px){.about-content{grid-template-columns:2fr 1fr}}.about-text p{color:var(--color-text-secondary);margin-bottom:1.25rem;font-size:1rem;line-height:1.8}.about-links{margin-top:2rem}.about-links h2{font-size:1rem;font-weight:700;margin-bottom:.75rem}.about-links ul{list-style:none}.about-links li{margin-bottom:.5rem}.about-links a{font-size:.9rem;color:var(--color-text-secondary)}.about-links a:hover{color:var(--color-text)}.not-found{padding:4rem 0}.not-found h1{font-size:4rem;font-weight:900;color:var(--color-text);margin-bottom:.5rem;letter-spacing:-.04em}.not-found p{color:var(--color-text-muted);font-size:1rem;margin-bottom:1.5rem}.resume-header{margin-bottom:2.5rem;margin-top:2rem}.resume-name{font-size:clamp(2rem,4vw,2.75rem);font-weight:900;letter-spacing:-.04em;line-height:1.1}.resume-role{font-size:.85rem;font-weight:600;color:var(--color-accent);margin-top:.4rem;letter-spacing:.02em}.resume-summary{margin-top:1rem;font-size:.95rem;line-height:1.75;color:var(--color-text-secondary);max-width:600px}.resume-clearance{display:inline-flex;align-items:center;gap:.35rem;margin-top:.75rem;font-size:.78rem;font-weight:600;color:#15803d}.resume-contacts{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}.resume-contacts a{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--color-text-muted);text-decoration:none}.resume-contacts a:hover{color:var(--color-text)}.resume-contacts svg{width:14px;height:14px;flex-shrink:0}.resume-section{margin-bottom:2rem}.resume-section-title{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.resume-skills{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.resume-skill-group h3{font-size:.82rem;font-weight:700;color:var(--color-text);margin-bottom:.35rem}.resume-skill-group p{font-size:.82rem;color:var(--color-text-muted);line-height:1.6}.resume-job{padding-bottom:1.75rem;margin-bottom:1.75rem;border-bottom:1px solid var(--color-border)}.resume-job:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.resume-job-role{font-size:1rem;font-weight:700;color:var(--color-text);line-height:1.3}.resume-job-meta{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;margin-top:.15rem;margin-bottom:.6rem}.resume-job-company{font-size:.88rem;color:var(--color-text-secondary)}.resume-job-period{font-size:.8rem;color:var(--color-text-muted)}.resume-job-period:before{content:"· "}.resume-job-bullets{list-style:none;padding:0}.resume-job-bullets li{position:relative;padding-left:.9rem;margin-bottom:.4rem;font-size:.87rem;line-height:1.65;color:var(--color-text-secondary)}.resume-job-bullets li:before{content:"–";position:absolute;left:0;color:var(--color-text-muted)}.resume-projects{display:grid;gap:1rem}.resume-project{padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.resume-project:last-child{border-bottom:none;padding-bottom:0}.resume-project h3{font-size:.9rem;font-weight:700}.resume-project p{font-size:.85rem;color:var(--color-text-muted);line-height:1.6;margin-top:.2rem}.resume-education{font-size:.9rem;color:var(--color-text-secondary)}.resume-education strong{color:var(--color-text)}@media(max-width:640px){.resume-skills{grid-template-columns:1fr}}.games-page{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;background:#000;z-index:50}.games-track{display:flex;height:100%;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none}.games-track::-webkit-scrollbar{display:none}.game-slide{--clip: 0px;position:relative;flex-shrink:0;height:100%;overflow:hidden;cursor:default;isolation:isolate;clip-path:polygon(var(--clip) 0,100% 0,100% 100%,0 100%);margin-left:calc(-1 * var(--clip));transition:width .5s cubic-bezier(.25,.46,.45,.94)}.game-slide-first{clip-path:none;margin-left:0}@keyframes slowPan{0%{transform:scale(1.15) translate(-8%)}to{transform:scale(1.15) translate(8%)}}.game-slide-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:var(--parallax, 50%) center;animation:slowPan 8s ease-in-out infinite alternate}.game-slide-img-top{z-index:1;transition:opacity 1s ease}.game-slide-img-top.fading{opacity:0}.game-slide-bottom{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:1.5rem;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,transparent 100%);transition:background .4s ease}.game-slide-bottom.expanded{background:linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.7) 70%,transparent 100%)}.game-slide-title{font-size:clamp(1.15rem,1.8vw,1.75rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.15;text-shadow:0 2px 16px rgba(0,0,0,.6);margin-bottom:.15rem}.game-slide-genre{display:inline-block;font-size:.8rem;font-weight:600;color:#6c63ff;text-shadow:0 1px 8px rgba(0,0,0,.7)}.game-slide-details{max-height:0;overflow:hidden;opacity:0;transition:max-height .45s cubic-bezier(.25,.46,.45,.94),opacity .35s ease}.game-slide-bottom.expanded .game-slide-details{max-height:300px;opacity:1}.game-slide-desc{font-size:.9rem;color:#ffffffd9;line-height:1.55;margin-top:.75rem;margin-bottom:.75rem}.game-slide-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.78rem;color:#ffffff8c;margin-bottom:.75rem}.game-slide-divider{opacity:.3}.game-slide-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}.game-slide-tags span{font-size:.7rem;color:#ffffffa6;border:1px solid rgba(255,255,255,.15);padding:.15rem .5rem;border-radius:3px}.game-slide-link{display:inline-block;font-size:.85rem;font-weight:600;color:#fff;background:#6c63ff;padding:.5rem 1rem;border-radius:6px;text-decoration:none!important;transition:background .15s ease}.game-slide-link:hover{background:#7f78ff;color:#fff}.games-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:#fff;cursor:pointer;transition:all .15s ease}.games-nav:hover{background:#6c63ff99;border-color:#6c63ff}.games-nav svg{width:20px;height:20px}.games-nav-prev{left:1rem}.games-nav-next{right:1rem}@media(max-width:700px){.hero{padding:2.5rem 1.5rem;margin-left:-1.5rem;margin-right:-1.5rem}.game-slide-title{font-size:1.5rem}.games-nav{width:36px;height:36px}.games-nav svg{width:18px;height:18px}.games-nav-prev{left:.75rem}.games-nav-next{right:.75rem}}
