@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--bg: #0c0c0c;--bg2: #141414;--bg3: #1c1c1c;--text: #f0efea;--text2: #999;--border: rgba(255,255,255,.08);--accent: #ff4500;--accent-t: rgba(255,69,0,.12);--font-display: "Syne", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--nav-h: 68px;--ease: cubic-bezier(.22, 1, .36, 1)}:root.light{--bg: #f5f4ef;--bg2: #ebebea;--bg3: #dfdedd;--text: #0c0c0c;--text2: #777;--border: rgba(0,0,0,.08);--accent: #ff3000;--accent-t: rgba(255,48,0,.08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.7;letter-spacing:-.01em;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5{font-family:var(--font-display);letter-spacing:-.03em}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}img{display:block;max-width:100%}#root{min-height:100dvh}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-content{flex:1;padding-top:var(--nav-h)}.c-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}.c-nav.scrolled{background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border)}.c-nav-inner{max-width:1280px;margin:0 auto;padding:0 2rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:2rem}.c-nav-logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-weight:800}.logo-mark{font-size:1.1rem;letter-spacing:.06em;background:var(--accent);color:#fff;width:36px;height:36px;border-radius:6px;display:grid;place-items:center;flex-shrink:0}.logo-name{font-size:.85rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}.c-nav-links{display:flex;gap:2.5rem}.c-nav-link{font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);transition:color .18s;position:relative}.c-nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width .25s var(--ease)}.c-nav-link:hover,.c-nav-link.is-active{color:var(--text)}.c-nav-link:hover:after,.c-nav-link.is-active:after{width:100%}.c-nav-end{display:flex;align-items:center;gap:.75rem}.c-theme-btn{background:none;border:1px solid var(--border);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;transition:border-color .2s}.c-theme-btn:hover{border-color:var(--accent)}.theme-dot{width:12px;height:12px;border-radius:50%;background:var(--text);transition:background .2s}.c-menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:1px solid var(--border);padding:10px;border-radius:6px;transition:border-color .2s}.c-menu-btn:hover{border-color:var(--accent)}.c-menu-btn span{display:block;width:20px;height:1.5px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}.c-menu-btn.is-open span:first-child{transform:rotate(45deg) translate(4.5px,4.5px)}.c-menu-btn.is-open span:last-child{transform:rotate(-45deg) translate(4.5px,-4.5px)}.c-mobile-nav{position:fixed;top:var(--nav-h);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);padding:1.5rem 2rem 2rem;z-index:99}.c-mobile-link{display:flex;align-items:center;gap:1.25rem;padding:1rem 0;font-family:var(--font-display);font-size:1.6rem;font-weight:700;border-bottom:1px solid var(--border);color:var(--text);transition:color .18s}.c-mobile-link:hover{color:var(--accent)}.c-mobile-link:last-child{border-bottom:none}.mobile-link-idx{font-size:.72rem;font-weight:600;letter-spacing:.15em;color:var(--text2);font-family:var(--font-body)}.c-footer{border-top:1px solid var(--border);margin-top:8rem}.c-footer-inner{max-width:1280px;margin:0 auto;padding:2.5rem 2rem;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1.5rem}.footer-copy{font-size:.9rem;color:var(--text);font-weight:600}.footer-sub{font-size:.78rem;color:var(--text2);margin-top:.25rem;letter-spacing:.05em}.c-footer-links{display:flex;gap:1.75rem;font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text2)}.c-footer-links a:hover{color:var(--text)}.reveal-wrap{overflow:hidden;display:block}.c-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.85rem 2rem;border-radius:4px;font-family:var(--font-display);font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid transparent;transition:all .2s var(--ease);white-space:nowrap}.c-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.c-btn--primary:hover{background:transparent;color:var(--accent)}.c-btn--ghost{background:transparent;color:var(--text);border-color:var(--border)}.c-btn--ghost:hover{border-color:var(--text)}.section-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text2);flex-shrink:0}.section-rule{flex:1;height:1px;background:var(--border);transform-origin:left}.filter-pill{padding:.45rem 1rem;border-radius:2px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:all .18s}.filter-pill:hover{color:var(--text);border-color:var(--text)}.filter-pill.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}.home-hero{max-width:1280px;margin:0 auto;padding:4rem 2rem;min-height:calc(100dvh - var(--nav-h));display:flex;flex-direction:column;justify-content:flex-start;position:relative}.home-hero-inner{max-width:100%}.home-greeting{font-size:.95rem;font-weight:500;color:var(--text2);letter-spacing:.02em;margin-bottom:2rem;min-height:1.4em}.tw-cursor{display:inline-block;width:2px;height:.9em;background:var(--accent);margin-left:3px;vertical-align:middle;border-radius:1px;animation:blink .85s step-end infinite}.tw-cursor.done{animation:blink .85s step-end infinite,cursorFade .3s 1.6s forwards}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes cursorFade{to{opacity:0;width:0;margin:0}}.home-display{font-size:clamp(2.5rem,6.5vw,6.5rem);font-weight:800;line-height:.92;letter-spacing:-.04em;margin-bottom:2.5rem}.display-outline{-webkit-text-stroke:2px var(--text);color:transparent}.home-divider{height:1px;background:var(--border);margin-bottom:2.5rem}.home-intro{max-width:680px;display:flex;flex-direction:column;gap:1rem}.home-bio-lead{font-size:1.15rem;font-weight:500;line-height:1.65;color:var(--text)}.home-bio-body{font-size:.95rem;line-height:1.75;color:var(--text2)}.home-cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}.home-scroll-hint{position:absolute;bottom:2.5rem;right:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text2)}.home-work{max-width:1280px;margin:6rem auto 0;padding:0 2rem}.home-work-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:3.5rem}.home-work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}.home-work-grid .home-work-item:first-child{grid-column:1 / -1}.home-work-link{display:block}.home-work-thumb{position:relative;aspect-ratio:16 / 9;border-radius:4px;display:flex;align-items:flex-end;padding:1.75rem;overflow:hidden;transition:filter .3s}.home-work-grid .home-work-item:first-child .home-work-thumb{aspect-ratio:21 / 9}.home-work-link:hover .home-work-thumb{filter:brightness(.85)}.thumb-index{position:absolute;top:1.25rem;left:1.75rem;font-family:var(--font-display);font-size:.7rem;font-weight:700;letter-spacing:.15em;opacity:.6}.thumb-title{font-family:var(--font-display);font-size:clamp(1.1rem,2.5vw,1.8rem);font-weight:800;line-height:1.1;max-width:480px}.thumb-arrow{position:absolute;top:1.25rem;right:1.75rem;font-size:1.2rem;opacity:0;transform:translate(-6px,6px);transition:opacity .25s,transform .25s var(--ease)}.home-work-link:hover .thumb-arrow{opacity:1;transform:translate(0)}.home-work-meta{display:flex;gap:.5rem;margin-top:1rem;margin-bottom:.35rem}.meta-tag{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text2)}.meta-lang{font-size:.68rem;font-weight:600;color:var(--text2);opacity:.6}.meta-lang:before{content:"·";margin-right:.5rem}.home-work-title{font-size:1rem;font-weight:700;color:var(--text);transition:color .18s}.home-work-link:hover .home-work-title{color:var(--accent)}.home-work-footer{margin-top:3rem}.home-bio{max-width:1280px;margin:0 auto;padding:5rem 2rem;border-top:1px solid var(--border)}.home-bio-wrap{max-width:680px;display:flex;flex-direction:column;gap:1.25rem}.home-stats{max-width:1280px;margin:6rem auto 0;padding:3rem 2rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}.home-stat{text-align:center}.stat-n{display:block;font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text)}.stat-l{display:block;font-size:.75rem;color:var(--text2);letter-spacing:.12em;text-transform:uppercase;margin-top:.5rem}.work-page{max-width:1280px;margin:0 auto;padding:0 2rem}.work-header{padding:4rem 0 3rem}.work-display{font-size:clamp(5rem,16vw,18rem);font-weight:800;line-height:.88;letter-spacing:-.05em;margin-bottom:1.5rem}.work-subtitle{font-size:1rem;color:var(--text2);max-width:480px}.work-filters{display:flex;flex-wrap:wrap;gap:.5rem;padding:2.5rem 0;border-bottom:1px solid var(--border);margin-bottom:3rem}.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}.work-card{display:block}.work-card-thumb{aspect-ratio:4 / 3;position:relative;display:flex;align-items:flex-end;padding:1.25rem;overflow:hidden;transition:filter .3s}.work-card:hover .work-card-thumb{filter:brightness(.82)}.wc-index{position:absolute;top:1rem;left:1.25rem;font-family:var(--font-display);font-size:.65rem;font-weight:700;letter-spacing:.15em;opacity:.55}.wc-title{font-family:var(--font-display);font-size:clamp(1rem,1.8vw,1.4rem);font-weight:800;line-height:1.1}.wc-arrow{position:absolute;top:1rem;right:1.25rem;font-size:1.1rem;opacity:0;transform:translate(-5px,5px);transition:opacity .22s,transform .22s var(--ease)}.work-card:hover .wc-arrow{opacity:1;transform:translate(0)}.work-card-info{padding:1rem 0 2rem;display:flex;flex-direction:column;gap:.5rem}.wc-tags{display:flex;gap:.5rem;flex-wrap:wrap}.tag-pill{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text2);border:1px solid var(--border);padding:.2rem .55rem;border-radius:2px}.tag-pill--lang{opacity:.7}.wc-short{font-size:.88rem;color:var(--text2);line-height:1.55}.wc-links{display:flex;gap:1rem;margin-top:.25rem}.wc-link{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:color .18s}.wc-link.live{color:var(--accent)}.wc-link.code{color:var(--text2)}.wc-link:hover{color:var(--text)}.detail-page{max-width:1280px;margin:0 auto;padding:2rem 2rem 0}.detail-back{margin-bottom:2rem}.detail-back-link{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);transition:color .18s}.detail-back-link:hover{color:var(--text)}.detail-hero{width:100%;min-height:40vh;border-radius:8px;display:flex;flex-direction:column;justify-content:flex-end;padding:3rem;position:relative;overflow:hidden}.detail-hero-index{font-size:.7rem;font-weight:700;letter-spacing:.2em;opacity:.5;margin-bottom:.75rem;font-family:var(--font-display)}.detail-hero-title{font-size:clamp(2rem,5vw,5rem);font-weight:800;line-height:1.05;max-width:800px}.detail-body{display:grid;grid-template-columns:280px 1fr;gap:4rem;padding:4rem 0}.detail-meta-row{display:flex;flex-direction:column;gap:2rem;position:sticky;top:calc(var(--nav-h) + 2rem);align-self:flex-start}.detail-meta-item{display:flex;flex-direction:column;gap:.3rem}.detail-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text2)}.detail-value{font-size:.95rem;font-weight:500}.detail-content{display:flex;flex-direction:column;gap:2rem;padding-top:.25rem}.detail-description{font-size:1.1rem;line-height:1.8;color:var(--text2);max-width:600px}.detail-actions{display:flex;gap:1rem;flex-wrap:wrap}.detail-not-found{display:flex;flex-direction:column;gap:1.5rem;align-items:flex-start;padding:4rem 0}.detail-next{padding-bottom:6rem}.detail-next-rule{height:1px;background:var(--border);margin-bottom:2rem}.detail-next-label{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text2);margin-bottom:1.25rem;display:block}.detail-next-link{display:block}.detail-next-thumb{aspect-ratio:21 / 6;border-radius:6px;display:flex;align-items:center;justify-content:space-between;padding:2rem 3rem;font-family:var(--font-display);font-size:clamp(1rem,2.5vw,2rem);font-weight:800;transition:filter .3s}.detail-next-link:hover .detail-next-thumb{filter:brightness(.85)}.about-hero{max-width:1280px;margin:0 auto;padding:4rem 2rem 2rem}.about-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:1.5rem}.about-statement{font-size:clamp(3rem,8vw,8rem);font-weight:800;line-height:1;letter-spacing:-.04em;margin-bottom:0}.statement-accent{color:var(--accent)}.about-bio{max-width:1280px;margin:5rem auto 0;padding:0 2rem}.about-bio-inner{display:grid;grid-template-columns:1fr 280px;gap:5rem;padding-bottom:5rem;border-bottom:1px solid var(--border);align-items:flex-start}.about-bio-text{display:flex;flex-direction:column;gap:1.25rem}.bio-lead{font-size:1.2rem;font-weight:500;line-height:1.65}.about-bio-text p{font-size:.98rem;color:var(--text2);line-height:1.8}.about-bio-text strong{color:var(--text);font-weight:600}.about-bio-aside{display:flex;flex-direction:column;gap:1.75rem;position:sticky;top:calc(var(--nav-h) + 2rem)}.aside-block h3{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text2);margin-bottom:.4rem}.aside-block p{font-size:.92rem}.aside-link{color:var(--accent)}.aside-link:hover{text-decoration:underline}.about-skills{max-width:1280px;margin:5rem auto 0;padding:0 2rem}.about-skills-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:3rem}.skills-groups-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2.5rem;padding-bottom:5rem}.skills-group-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}.skills-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.skill-item{font-size:.9rem;color:var(--text2);padding-bottom:.6rem;border-bottom:1px solid var(--border);transition:color .18s}.skill-item:hover{color:var(--text)}.skill-item:last-child{border-bottom:none}.about-cta{max-width:1280px;margin:0 auto;padding:5rem 2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.about-cta-text{font-family:var(--font-display);font-size:clamp(1.2rem,3vw,2.2rem);font-weight:700;max-width:500px}.about-cta-btns{display:flex;gap:1rem;flex-wrap:wrap}.contact-hero{max-width:1280px;margin:0 auto;padding:4rem 2rem 3rem}.contact-display{font-size:clamp(3rem,9.5vw,9.5rem);font-weight:800;line-height:.88;letter-spacing:-.05em;margin-bottom:2rem}.contact-subtitle{font-size:1.05rem;color:var(--text2);max-width:480px}.contact-body{max-width:1280px;margin:3rem auto 0;padding:0 2rem 6rem;display:grid;grid-template-columns:1fr 320px;gap:6rem}.c-form{display:flex;flex-direction:column;gap:2rem}.c-field{display:flex;flex-direction:column;gap:.6rem}.c-label{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text2)}.c-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);padding:.75rem 0;font-family:var(--font-body);font-size:1rem;color:var(--text);transition:border-color .2s}.c-input:focus{outline:none;border-bottom-color:var(--text)}.c-textarea{resize:vertical;min-height:120px}.c-submit{margin-top:.5rem;align-self:flex-start}.form-msg{font-size:.88rem;font-weight:600;padding:.85rem 1.25rem;border-radius:4px}.form-msg.success{background:#22c55e1a;color:#16a34a}.form-msg.error{background:#ef44441a;color:#dc2626}.contact-aside{display:flex;flex-direction:column;gap:2.5rem;padding-top:.5rem}.contact-info-block{display:flex;flex-direction:column;gap:.4rem}.ci-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text2)}.ci-value{font-size:.95rem;font-weight:500}.ci-value a{transition:color .18s}.ci-value a:hover{color:var(--accent)}@media(max-width:1024px){.work-grid{grid-template-columns:repeat(2,1fr)}.skills-groups-grid{grid-template-columns:repeat(3,1fr)}.about-bio-inner{grid-template-columns:1fr;gap:3rem}.about-bio-aside{position:static;flex-direction:row;flex-wrap:wrap;gap:2rem}.aside-block{flex:1;min-width:160px}.contact-body{grid-template-columns:1fr;gap:4rem}.contact-aside{flex-direction:row;flex-wrap:wrap;gap:2rem}.contact-info-block{flex:1;min-width:160px}.detail-body{grid-template-columns:1fr;gap:2.5rem}.detail-meta-row{position:static;flex-direction:row;flex-wrap:wrap;gap:2rem}.detail-meta-item{flex:1;min-width:120px}.home-work-grid{grid-template-columns:1fr}.home-work-grid .home-work-item:first-child{grid-column:auto}}@media(max-width:768px){:root{--nav-h: 60px}.c-nav-links{display:none}.c-menu-btn{display:flex}.logo-name{display:none}.home-hero{padding:3rem 1.25rem;min-height:auto}.home-display{font-size:clamp(3.5rem,18vw,7rem)}.home-stats{grid-template-columns:repeat(2,1fr)}.home-bio{padding:3rem 1.25rem}.home-work{padding:0 1.25rem;margin-top:4rem}.home-scroll-hint{display:none}.work-page{padding:0 1.25rem}.work-header{padding:2.5rem 0 2rem}.work-grid{grid-template-columns:1fr;gap:0}.work-filters{gap:.4rem}.about-page .about-hero,.about-bio,.about-skills{padding-left:1.25rem;padding-right:1.25rem}.about-statement{font-size:clamp(2.5rem,12vw,5rem)}.skills-groups-grid{grid-template-columns:repeat(2,1fr)}.about-cta{padding-left:1.25rem;padding-right:1.25rem;flex-direction:column;align-items:flex-start}.contact-hero{padding:2rem 1.25rem}.contact-display{font-size:clamp(4rem,20vw,8rem)}.contact-body{padding:0 1.25rem}.detail-page{padding:2rem 1.25rem 0}.detail-hero{min-height:30vh;padding:2rem}.detail-hero-title{font-size:clamp(1.5rem,8vw,3rem)}.detail-next-thumb{aspect-ratio:16/6;padding:1.5rem 2rem;font-size:1rem}.c-footer-inner{padding:2rem 1.25rem}}@media(max-width:480px){.home-display{font-size:clamp(3rem,19vw,6rem)}.work-display{font-size:clamp(4rem,25vw,9rem)}.about-statement{font-size:clamp(2.2rem,15vw,4rem)}.contact-display{font-size:clamp(2.5rem,18vw,7rem)}.home-stats{grid-template-columns:repeat(2,1fr)}.skills-groups-grid{grid-template-columns:1fr 1fr}.c-footer-links{gap:1rem;font-size:.75rem}}
