@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";
@font-face{font-family:Satoshi;src:url(/fonts/satoshi-regular.otf)format("opentype");font-weight:400;font-display:swap}@font-face{font-family:Satoshi;src:url(/fonts/satoshi-medium.otf)format("opentype");font-weight:500;font-display:swap}@font-face{font-family:Satoshi;src:url(/fonts/satoshi-bold.otf)format("opentype");font-weight:700;font-display:swap}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.skip-link{background:var(--color-text-primary);color:var(--color-bg);z-index:9999;border-radius:8px;padding:8px 16px;font-size:14px;text-decoration:none;position:absolute;top:-100%;left:16px}.skip-link:focus{top:16px}:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:2px}:root{--color-bg:#fff;--color-left-bg:#fafafa;--color-text-primary:#111;--color-text-secondary:#666;--color-text-tertiary:#888;--color-text:var(--color-text-primary);--color-muted:var(--color-text-secondary);--color-light:var(--color-text-tertiary);--color-border:#f0f0f0;--color-border-subtle:#0000000d;--color-timeline:#f0f0f0;--btn-primary-bg:#111;--btn-primary-text:#fff;--btn-ghost-bg:#fffc;--btn-ghost-text:#444;--btn-ghost-border:#0000000d;--btn-secondary-bg:#fffc;--btn-secondary-text:#444;--btn-secondary-border:#0000000d;--font-main:"Satoshi", sans-serif;--font-body:"Inter", sans-serif}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-main);min-height:100vh}[data-theme=dark]{--color-bg:#101010;--color-left-bg:#181818;--color-text-primary:#fff;--color-text-secondary:#ccc;--color-text-tertiary:#aaa;--color-border:#ffffff14;--color-border-subtle:#ffffff0d;--color-timeline:#2b2b2b;--btn-primary-bg:#fff;--btn-primary-text:#101010;--btn-ghost-bg:#222c;--btn-ghost-text:#fff;--btn-ghost-border:#ffffff0d;--btn-secondary-bg:#222c;--btn-secondary-text:#fff;--btn-secondary-border:#ffffff0d}.left{background:var(--color-left-bg);border-right:1px solid var(--color-border);flex-shrink:0;justify-content:center;align-items:center;width:50%;height:100vh;display:flex;position:sticky;top:0}.left-inner{flex-direction:column;gap:32px;width:100%;max-width:512px;display:flex}.tabbar-theme .icon-sun,.tabbar-theme .icon-moon{flex-shrink:0;width:20px;height:20px}.tabbar-theme .icon-moon,[data-theme=dark] .tabbar-theme .icon-sun{display:none}[data-theme=dark] .tabbar-theme .icon-moon{display:block}.avatar-wrap{width:64px;height:64px;position:relative}.avatar{object-fit:cover;border-radius:50%;width:64px;height:64px;display:block;box-shadow:inset 0 0 0 1px #0000001a}.avatar-dot{border:2px solid var(--color-left-bg);background:#22c55e;border-radius:50%;width:12px;height:12px;position:absolute;bottom:2px;right:2px}.hero-title{font-family:var(--font-main);color:var(--color-text);font-size:40px;font-weight:400;line-height:48px}.hero-title a{color:var(--color-text);white-space:nowrap;text-decoration:none;transition:color .15s}.hero-title a:hover{color:var(--color-muted)}.hero-sub{font-family:var(--font-body), sans-serif;color:var(--color-text-secondary);margin-top:-16px;font-size:18px;font-weight:400;line-height:28px}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);font-family:var(--font-main);cursor:pointer;border:none;border-radius:100px;align-items:center;padding:10px 20px;font-size:14px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.btn-primary:hover{opacity:.8}.btn-ghost{background:var(--btn-ghost-bg);color:var(--btn-ghost-text);font-family:var(--font-main);border:1px solid var(--btn-ghost-border);border-radius:100px;align-items:center;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.btn-ghost:hover{background:var(--color-border)}.right{background:var(--color-bg);flex:1;padding:48px 48px 80px 28px;position:relative}.right:before{content:"";background:repeating-linear-gradient(to bottom, var(--color-border) 0px, var(--color-border) 1px, transparent 1px, transparent 12px);width:8px;position:absolute;top:8px;bottom:0;left:4px}.section-label-row{flex-direction:row;gap:0;margin-bottom:40px;display:flex}.section-label-spacer{flex-shrink:0;width:160px}.section-label{max-width:512px;font-family:var(--font-body), sans-serif;color:var(--color-text-tertiary);flex:1;margin:0 auto;font-size:13px;font-style:italic}[data-theme=dark] .section-label{color:#666}.case{flex-direction:row;align-items:flex-start;gap:0;margin-bottom:64px;display:flex}.case:last-child{margin-bottom:0}.case-meta{flex-shrink:0;align-self:flex-start;width:160px;padding-top:0;padding-right:24px;position:sticky;top:24px}.case-meta:before{content:"";left:-24px;top:var(--tick-top,50%);background:silver;width:16px;height:1px;position:absolute;transform:translateY(-50%)}[data-theme=dark] .case-meta:before{background:#444}.case-client{font-family:var(--font-main);color:var(--color-text);margin-bottom:3px;font-size:12px;font-weight:500}.case-year{font-family:var(--font-body), sans-serif;color:var(--color-muted);white-space:nowrap;font-size:12px}.case-content{flex-direction:column;flex:1;gap:20px;max-width:512px;margin:0 auto;display:flex}.case-image{aspect-ratio:16/9;background:var(--color-left-bg);border:1px solid var(--color-border-subtle);border-radius:24px;width:100%;overflow:hidden;box-shadow:0 1px 2px #00000008}.case-image img{object-fit:cover;width:100%;height:100%;display:block}.case-title{font-family:var(--font-main);color:var(--color-text);font-size:22px;font-weight:500;line-height:1.3}.case-desc{font-family:var(--font-body), sans-serif;color:var(--color-text-tertiary);font-size:14px;line-height:1.7}.impact-label{font-family:var(--font-main);color:var(--color-text);align-items:center;gap:8px;font-size:16px;font-weight:500;display:flex}.impact-label svg{flex-shrink:0}.impact-list{flex-direction:column;gap:10px;list-style:none;display:flex}.impact-list li{font-family:var(--font-body), sans-serif;color:var(--color-text-tertiary);padding-left:16px;font-size:14px;line-height:1.6;position:relative}.impact-list li:before{content:"·";color:var(--color-light);font-size:18px;position:absolute;left:4px}.modal-backdrop{z-index:1000;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay{-webkit-backdrop-filter:blur();backdrop-filter:blur();z-index:-1;background:#00000005;position:absolute;inset:0}.modal-backdrop.is-open{display:flex}.modal{border:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(80px);backdrop-filter:blur(80px);background:#fffc;position:relative}[data-theme=dark] .modal{background:#222c}.modal-close{z-index:10;border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);width:40px;height:40px;color:var(--btn-secondary-text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:0;line-height:0;transition:background .15s;display:flex;position:absolute;top:24px;right:24px}.modal-close:hover{background:var(--color-border);color:var(--color-text)}.modal-backdrop--right{justify-content:flex-end;padding:24px}.modal--connect{opacity:0;border-radius:24px;width:100%;max-width:360px;height:100%;max-height:100%;padding:0;overflow:hidden;box-shadow:0 4px 12px #0000000f}.modal-scroll{scrollbar-width:none}.modal-scroll::-webkit-scrollbar{display:none}.modal--connect .modal-scroll{height:100%;padding:40px 16px 16px;overflow-y:auto}.connect-header{text-align:center;flex-direction:column;align-items:center;gap:0;margin-bottom:14px;display:flex}.connect-avatar{object-fit:cover;border-radius:50%;width:96px;height:96px;margin-bottom:16px}.connect-name{font-family:var(--font-main);color:var(--color-text);margin:0 0 4px;padding:0;font-size:28px;font-weight:400;line-height:1.35}.connect-email{font-family:var(--font-body), sans-serif;color:var(--color-light);cursor:pointer;align-items:center;gap:6px;font-size:16px;transition:color .15s;display:inline-flex}.connect-email:hover{color:var(--color-text)}.connect-email svg{flex-shrink:0;width:14px;height:14px;transform:translateY(2px)}.connect-categories{flex-direction:column;gap:16px;display:flex}.connect-category{border:1px solid var(--color-border);background:#fff;border-radius:16px;overflow:hidden}[data-theme=dark] .connect-category{background:#1a1a1a}.connect-category-title{font-family:var(--font-main);color:var(--color-light);text-transform:none;letter-spacing:0;padding:14px 16px 8px;font-size:12px;font-weight:600}.connect-category-items{flex-direction:column;display:flex}.connect-item{align-items:center;gap:16px;padding:12px 16px;text-decoration:none;transition:background .15s;display:flex;position:relative}.connect-item+.connect-item:before{content:"";background:var(--color-border);height:1px;position:absolute;top:0;left:56px;right:16px}.connect-item:hover{background:var(--color-left-bg)}.connect-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;overflow:hidden}.connect-icon svg{width:24px;height:24px}.connect-icon--sm,.connect-icon--sm svg{width:20px;height:20px}.connect-label{font-family:var(--font-main);color:var(--color-text);flex:1;font-size:15px;font-weight:500}.connect-arrow{width:16px;height:16px;color:var(--color-light);flex-shrink:0}.connect-arrow svg{width:16px;height:16px}.connect-arrow--code{width:auto;height:auto;font-size:12px;font-family:var(--font-body), sans-serif;cursor:pointer;white-space:nowrap;align-items:center;gap:4px;display:inline-flex}.connect-arrow--code svg{width:14px;height:14px;transform:translateY(1px)}.about-title{font-family:var(--font-main);color:var(--color-text);margin:24px 0 20px;padding-right:32px;font-size:28px;font-weight:400;line-height:1.3}.about-content h3{font-family:var(--font-main);color:var(--color-text);margin:28px 0 12px;font-size:18px;font-weight:500}.about-content p{font-family:"Inter", var(--font-body), sans-serif;color:var(--color-light);margin-bottom:16px;font-size:14px;line-height:1.7}.photo-slider{border-radius:0;margin:24px -40px;padding:16px 0;overflow:hidden}.photo-slider-track{gap:24px;animation:20s linear infinite sliderScroll;display:flex}.photo-slider-track img{object-fit:cover;border-radius:24px;flex-shrink:0;width:240px;height:320px;transition:transform .4s;box-shadow:0 1px 2px #00000008}.photo-slider-track img:nth-child(odd){transform:rotate(2deg)}.photo-slider-track img:nth-child(2n){transform:rotate(-2deg)}.photo-slider-track img:hover{transform:rotate(0)scale(1.02)}@keyframes sliderScroll{0%{transform:translate(0)}to{transform:translate(calc(-50% - 12px))}}.tabbar{z-index:900;flex-direction:column;align-items:center;width:auto;padding:20px 0;display:flex;position:fixed;top:0;bottom:0;left:24px}.tabbar-inner{background:var(--color-bg);border:1px solid var(--color-border);border-radius:22px;flex-direction:column;justify-content:center;align-items:center;gap:4px;margin:auto;padding:4px;display:flex;box-shadow:0 2px 12px #00000014}.tabbar-item{cursor:pointer;width:44px;height:44px;color:var(--color-text-tertiary);background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;text-decoration:none!important}.tabbar-item:hover{background:var(--color-border);color:var(--color-text-primary)}.tabbar-item.is-active{color:var(--color-text-primary)}.tabbar-theme{justify-content:center;width:44px;height:44px}#main-content{margin-left:0}@media (max-width:1215px){.page-cv{flex-direction:column}.left{border-right:none;border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;width:100%;max-width:100%;height:auto;padding:64px 40px;position:relative}.left-inner{width:100%;max-width:512px;margin:0 auto}.right{padding:40px 40px 60px 28px}.case{position:relative}.case-meta{width:120px}.case-content{max-width:512px}.section-label-spacer{width:120px}.hero-title{font-size:36px;line-height:44px}.tabbar{width:100%;height:auto;padding:16px 0 calc(16px + env(safe-area-inset-bottom,0px));background:0 0;border:none;flex-direction:row;justify-content:center;inset:auto 0 0}.tabbar-inner{background:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;flex-direction:row;gap:0;margin:0;padding:4px 8px;box-shadow:0 2px 12px #00000014}.tabbar-theme{display:none}#main-content{margin-left:0}.page-home,.page-about{padding-bottom:80px}}@media (max-width:809px){.left{padding:48px 24px}.left-inner{max-width:512px;margin-left:auto;margin-right:auto}.hero-title{font-size:34px;line-height:42px}.right{padding:40px 24px 100px 36px}.right:before{left:4px}.case{flex-direction:column;gap:64px;max-width:512px;margin-bottom:80px;margin-left:auto;margin-right:auto;position:relative}.case-meta{width:auto;padding-right:0;position:relative}.case-meta:before{left:min(254px - 50vw,-32px)}.case-content{max-width:100%;margin:0}.section-label-spacer{display:none}.section-label-row{max-width:512px;margin-left:auto;margin-right:auto}.section-label{margin-left:0;margin-right:0}}@media (max-width:479px){.desktop-br{display:none}.left{padding:48px 24px}.hero-title{font-size:36px;line-height:44px}.hero-sub{font-size:18px;line-height:26px}.right{padding:32px 24px 100px 36px}.case-image{border-radius:8px}.modal-backdrop--right{justify-content:center;align-items:flex-end;padding:0}.modal--connect{border-radius:24px 24px 0 0;max-width:100%;height:auto;max-height:calc(100vh - 48px)}}.page-home{background:var(--color-left-bg);justify-content:center;align-items:center;min-height:100vh;padding:40px;display:flex}.page-home .left-inner{flex-direction:column;gap:32px;width:100%;max-width:512px;display:flex}.page-about{max-width:640px;margin:0 auto;padding:60px 40px 40px}.pl-layout{min-height:100vh;display:flex}.pl-sidebar{border-right:1px solid var(--color-border);background:var(--color-left-bg);flex-direction:column;flex-shrink:0;gap:16px;width:280px;height:100vh;padding:24px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.pl-sidebar-header{align-items:center;display:flex}.pl-spotify-link{border:1px solid var(--btn-ghost-border);background:var(--btn-ghost-bg);color:var(--btn-ghost-text);font-family:var(--font-main);cursor:pointer;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s;display:flex}.pl-spotify-link:hover{background:var(--color-border)}.pl-sidebar-list{flex-direction:column;gap:4px;display:flex}.sidebar-card{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:background .15s;display:flex}.sidebar-card:hover{background:#00000008}.sidebar-card.is-active{background:#0000000d}[data-theme=dark] .sidebar-card:hover{background:#ffffff0f}[data-theme=dark] .sidebar-card.is-active{background:#ffffff1a}.sidebar-cover{object-fit:cover;border-radius:8px;flex-shrink:0;width:48px;height:48px}.sidebar-cover-placeholder{background:var(--color-border)}.sidebar-card-text{flex-direction:column;gap:2px;min-width:0;display:flex}.sidebar-card-title{font-family:var(--font-main);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.sidebar-card-meta{font-family:var(--font-body);color:var(--color-text-tertiary);font-size:12px}.pl-main{flex:1;min-width:0;padding:32px 40px 80px}.pl-loading,.pl-error{text-align:center;font-family:var(--font-body);color:var(--color-text-tertiary);padding:80px 0;font-size:14px}.pl-error{color:#e74c3c}.pl-content{animation:.25s plFadeIn}@keyframes plFadeIn{0%{opacity:0}to{opacity:1}}.pl-header{align-items:flex-end;gap:32px;margin-bottom:40px;display:flex}.pl-cover{object-fit:cover;border-radius:12px;flex-shrink:0;width:200px;height:200px;box-shadow:0 4px 12px #00000014}.pl-header-text{flex-direction:column;gap:8px;min-width:0;display:flex}.pl-header-label{font-family:var(--font-main);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.pl-header-title{font-family:var(--font-main);color:var(--color-text-primary);font-size:32px;font-weight:700;line-height:1.2}.pl-header-desc{font-family:var(--font-body);color:var(--color-text-secondary);font-size:14px;line-height:1.5}.pl-header-meta{font-family:var(--font-body);color:var(--color-text-tertiary);font-size:13px}.pl-open-spotify{background:var(--btn-primary-bg);color:var(--btn-primary-text);font-family:var(--font-main);border-radius:100px;align-items:center;gap:6px;width:fit-content;padding:8px 20px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.pl-open-spotify:hover{opacity:.8}.track-table-header{border-bottom:1px solid var(--color-border);font-family:var(--font-body);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:16px;padding:8px 16px;font-size:12px;display:flex}.track-row{cursor:pointer;border-radius:8px;align-items:center;gap:16px;height:52px;padding:8px 16px;transition:background .1s;display:flex}.track-row:hover{background:#00000008}.track-row.is-playing{background:#0000000d}[data-theme=dark] .track-row:hover{background:#ffffff0f}[data-theme=dark] .track-row.is-playing{background:#ffffff1a}.track-number{text-align:right;width:32px;font-family:var(--font-body);color:var(--color-text-tertiary);flex-shrink:0;font-size:14px;position:relative}.track-num-text{display:block}.track-play-btn{cursor:pointer;color:var(--color-text-primary);background:0 0;border:none;justify-content:center;align-items:center;font-size:10px;display:none;position:absolute;inset:0}.track-play-disabled{opacity:.3;cursor:default}.track-row:hover .track-num-text{display:none}.track-row:hover .track-play-btn{display:flex}.track-row.is-playing .track-num-text,.track-row.is-playing .track-play-btn{display:none}.track-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.track-album-art{object-fit:cover;border-radius:4px;flex-shrink:0;width:32px;height:32px}.track-text{flex-direction:column;gap:1px;min-width:0;display:flex}.track-name{font-family:var(--font-main);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;text-decoration:none;overflow:hidden}.track-name:hover{text-decoration:underline}.track-row.is-playing .track-name{color:#1db954}.track-artist{font-family:var(--font-body);color:var(--color-text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.track-album{width:200px;font-family:var(--font-body);color:var(--color-text-tertiary);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;font-size:13px;overflow:hidden}.track-duration{text-align:right;width:48px;font-family:var(--font-body);color:var(--color-text-tertiary);flex-shrink:0;font-size:13px}.equalizer{color:#1db954}.eq-bar{transform-origin:bottom}.eq-bar-1{animation:.45s ease-in-out infinite alternate eqBounce}.eq-bar-2{animation:.55s ease-in-out infinite alternate-reverse eqBounce}.eq-bar-3{animation:.5s ease-in-out .15s infinite alternate eqBounce}@keyframes eqBounce{0%{transform:scaleY(.3)}to{transform:scaleY(1)}}@media (max-width:768px){.pl-layout{flex-direction:column;padding-top:0;padding-bottom:80px}.pl-sidebar{border-right:none;border-bottom:1px solid var(--color-border);flex-direction:column;width:100%;height:auto;padding:16px;position:relative;top:0}.pl-sidebar-list{scrollbar-width:none;flex-direction:row;gap:8px;padding-bottom:4px;overflow-x:auto}.pl-sidebar-list::-webkit-scrollbar{display:none}.sidebar-card{flex-shrink:0;width:auto;min-width:180px}.pl-main{padding:24px 16px 40px}.pl-header{flex-direction:column;align-items:flex-start;gap:20px}.pl-cover{width:160px;height:160px}.pl-header-title{font-size:24px}.track-album,.track-table-header .track-album{display:none}}.page-cv{min-height:100vh;display:flex}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
