@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500&family=Space+Mono&display=swap";.topnav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#0f0f0fd9;position:fixed;top:0;left:0;right:0}.topnav-inner{justify-content:space-between;align-items:center;max-width:1000px;height:64px;margin:0 auto;padding:0 60px;display:flex}.topnav-brand{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.3px;flex-shrink:0;font-size:18px;font-weight:700}.topnav-brand:hover,.brand-slash{color:var(--accent)}.topnav-links{align-items:center;gap:0;margin:0 auto;display:flex}.topnav-link{font-family:var(--font-display);color:var(--text-secondary);white-space:nowrap;letter-spacing:.01em;padding:8px 16px;font-size:15px;font-weight:500;transition:color .2s}.topnav-link:hover{color:var(--accent)}.link-slash{color:var(--accent);margin-right:1px;font-weight:300}.topnav-right{flex-shrink:0;align-items:center;gap:4px;display:flex}.topnav-icon{color:var(--text-secondary);border-radius:4px;justify-content:center;align-items:center;width:36px;height:36px;transition:color .2s;display:flex}.topnav-icon:hover{color:var(--accent)}.lang-toggle{border:1px solid var(--border);border-radius:5px;align-items:center;margin-right:8px;display:flex;overflow:hidden}.lang-btn{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 11px;font-size:11px;transition:color .2s,background .2s}.lang-btn.active{color:var(--accent);background:var(--accent-dim2)}.lang-btn:hover:not(.active){color:var(--text-secondary)}.lang-divider{background:var(--border);width:1px;height:18px}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:none}.hamburger span{background:var(--text-secondary);transform-origin:50%;border-radius:2px;height:1.5px;transition:transform .25s,opacity .25s;display:block}.hamburger.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.mobile-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);background:#0f0f0ff7;flex-direction:column;padding:16px 32px 32px;display:flex}.mobile-link{font-family:var(--font-display);color:var(--text-secondary);border-bottom:1px solid var(--border);padding:16px 0;font-size:22px;font-weight:500;transition:color .2s;animation:.3s both slideIn}.mobile-link:hover{color:var(--accent)}.mobile-lang{border:1px solid var(--border);border-radius:6px;align-items:center;width:fit-content;margin-top:28px;display:flex;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}@media (width<=768px){.topnav-inner{padding:0 24px}.topnav-links,.topnav-icon,.lang-toggle{display:none}.hamburger{display:flex}}#intro{align-items:center;min-height:calc(100vh - 64px);padding-top:64px;display:flex}.intro-layout{grid-template-columns:1fr 1fr;align-items:center;gap:48px;width:100%;display:grid}.intro-left{justify-content:center;align-items:center;display:flex}.intro-avatar{aspect-ratio:3/4;border-radius:4px;width:100%;max-width:360px;position:relative;overflow:hidden}.intro-avatar img{object-fit:cover;z-index:2;filter:grayscale(15%);border:1px solid #c8b89a26;border-radius:4px;width:100%;height:100%;transition:filter .3s;display:block;position:relative}.intro-avatar:hover img{filter:none}.intro-avatar-placeholder{z-index:1;justify-content:center;align-items:center;padding:16px;display:flex;position:absolute;inset:0}.intro-right{flex-direction:column;align-items:flex-start;display:flex}.intro-greeting{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.04em;margin-bottom:16px;font-size:16px}.intro-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-1.5px;min-height:1.1em;margin-bottom:28px;font-size:clamp(40px,5.5vw,64px);font-weight:700;line-height:1.05}.intro-cursor{color:var(--accent);opacity:1;margin-left:2px;font-weight:300;display:inline-block}.intro-cursor--blink{animation:1s step-end infinite cursorBlink}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.intro-desc{color:var(--text-secondary);max-width:460px;margin-bottom:44px;font-size:17px;line-height:1.75}.intro-btn{border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);letter-spacing:.04em;border-radius:4px;align-items:center;padding:14px 32px;font-size:14px;transition:background .25s cubic-bezier(.645,.045,.355,1),transform .25s;display:inline-flex}.intro-btn:hover{background:var(--accent-dim);transform:translateY(-3px)}@media (width<=768px){.intro-layout{grid-template-columns:1fr;gap:40px}.intro-left{order:2}.intro-right{text-align:center;order:1;align-items:center}.intro-avatar{aspect-ratio:1;max-width:220px}.intro-avatar-placeholder svg{opacity:.6}.intro-name{font-size:clamp(36px,10vw,52px)}.intro-desc{text-align:center}}.about-layout{grid-template-columns:1fr 260px;align-items:start;gap:56px;display:grid}.about-left p{color:var(--text-secondary);margin-bottom:18px;font-size:17px;line-height:1.8}.about-left p b{color:var(--text-primary);font-weight:500}.about-left>p:last-of-type{margin-bottom:24px}.skills-grid{grid-template-columns:repeat(2,1fr);gap:8px 16px;list-style:none;display:grid}.skill-tag{font-family:var(--font-mono);color:var(--text-secondary);font-size:13px;line-height:1.5}.about-photo-wrap{flex-shrink:0;width:260px}.about-photo{border:2px solid var(--accent);width:260px;height:320px;box-shadow:6px 6px 0 var(--accent-dim);border-radius:4px;overflow:hidden}.about-photo img{object-fit:cover;object-position:top;filter:grayscale(10%);width:100%;height:100%;transition:filter .3s;display:block}.about-photo:hover img{filter:none}.photo-placeholder{background:var(--bg-2);flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex}.photo-placeholder code{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim2);border:1px solid #c8b89a33;border-radius:3px;padding:3px 8px;font-size:11px}@media (width<=768px){.about-layout{grid-template-columns:1fr}.about-photo-wrap{width:200px;margin:0 auto}.about-photo{width:200px;height:240px}}.svc-list{border:1px solid var(--border);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.svc-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}.svc-row:last-child{border-bottom:none}.svc-row:hover{background:var(--bg-2)}.svc-row--open{background:var(--bg-2);cursor:default}.svc-row-head{grid-template-columns:44px 1fr 2fr 32px;align-items:center;gap:20px;padding:28px 32px;display:grid}.svc-row--open .svc-row-head{padding-bottom:20px}.svc-num{font-family:var(--font-mono);color:var(--accent);letter-spacing:.1em;font-size:12px}.svc-name{font-family:var(--font-display);color:var(--text-primary);white-space:nowrap;font-size:20px;font-weight:600}.svc-desc-short{color:var(--text-muted);font-size:14px;line-height:1.5}.svc-row--open .svc-desc-short{color:var(--text-secondary)}.svc-chevron{font-family:var(--font-mono);color:var(--accent);text-align:right;-webkit-user-select:none;user-select:none;font-size:20px;line-height:1;transition:transform .2s}.svc-detail{cursor:default;padding:0 32px 32px}.svc-detail-cols{border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:40px;margin-bottom:28px;padding-top:24px;display:grid}.svc-detail-label{font-family:var(--font-mono);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;font-size:11px}.svc-features{flex-direction:column;gap:8px;list-style:none;display:flex}.svc-features li{color:var(--text-secondary);padding-left:18px;font-size:14px;line-height:1.6;position:relative}.svc-features li:before{content:"▹";color:var(--accent);font-size:11px;position:absolute;top:2px;left:0}.svc-pricing{flex-direction:column;gap:10px;display:flex}.svc-price-row{background:var(--bg-3);border:1px solid var(--border);border-radius:4px;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 14px;display:flex}.price-tier{color:var(--text-primary);font-size:13px;font-weight:500}.price-sub{color:var(--text-muted);font-size:13px}.price-val{font-family:var(--font-mono);color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:13px}.svc-tags{flex-wrap:wrap;gap:8px;display:flex}.tag{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim2);letter-spacing:.03em;border:1px solid #c8b89a33;border-radius:3px;padding:4px 10px;font-size:11px}@media (width<=768px){.svc-row-head{grid-template-columns:36px 1fr 28px;gap:12px;padding:22px 20px}.svc-desc-short{display:none}.svc-detail{padding:0 20px 24px}.svc-detail-cols{grid-template-columns:1fr;gap:24px}}.explore-link{font-family:var(--font-mono);color:var(--accent);font-size:13px;transition:letter-spacing .2s}.explore-link:hover{letter-spacing:.05em}.filter-tabs{gap:8px;margin-bottom:28px;display:flex}.filter-btn{font-family:var(--font-mono);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;letter-spacing:.04em;background:0 0;border-radius:4px;padding:6px 18px;font-size:12px;transition:color .2s,border-color .2s,background .2s}.filter-btn:hover{color:var(--text-secondary);border-color:var(--border-hover)}.filter-btn.active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim2)}.spotlight-wrap{align-items:center;display:flex;position:relative}.spotlight-card{background-color:var(--bg-2);border:1px solid var(--border);background-position:50%;background-size:cover;border-radius:10px;flex:1;min-height:460px;position:relative;overflow:hidden}.spotlight-bg-placeholder{background:linear-gradient(135deg, var(--bg-2) 0%, var(--bg-3) 100%);position:absolute;inset:0}.spotlight-overlay{background:linear-gradient(#0000 0%,#0f0f0f8c 40%,#0f0f0ff7 100%);position:absolute;inset:0}.spotlight-content{z-index:2;padding:40px 48px;position:absolute;bottom:0;left:0;right:0}.spotlight-badge{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border-radius:3px;margin-bottom:16px;padding:3px 10px;font-size:11px;display:inline-block}.badge-web{color:var(--accent);background:#c8b89a1a;border:1px solid #c8b89a4d}.badge-app{color:#7ec8a4;background:#7ec8a41a;border:1px solid #7ec8a44d}.spotlight-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.5px;margin-bottom:12px;font-size:clamp(22px,3vw,32px);font-weight:700}.spotlight-desc{color:var(--text-secondary);max-width:580px;margin-bottom:14px;font-size:15px;line-height:1.7}.spotlight-tech{font-family:var(--font-mono);color:var(--accent);letter-spacing:.04em;margin-bottom:20px;font-size:12px}.spotlight-links{gap:16px;display:flex}.spot-link{color:var(--text-secondary);align-items:center;transition:color .2s,transform .2s;display:flex}.spot-link:hover{color:var(--accent);transform:translateY(-2px)}.carousel-arrow{z-index:10;border:1px solid var(--border);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;background:#0f0f0fd9;border-radius:50%;justify-content:center;align-items:center;font-size:28px;line-height:1;transition:color .2s,border-color .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-arrow:hover{color:var(--accent);border-color:var(--accent)}.carousel-arrow--prev{left:-22px}.carousel-arrow--next{right:-22px}.carousel-dots{justify-content:center;gap:8px;margin-top:22px;display:flex}.dot{background:var(--border);cursor:pointer;border:none;border-radius:2px;width:32px;height:3px;padding:0;transition:background .2s}.dot--active{background:var(--accent)}@media (width<=768px){.spotlight-card{min-height:360px}.spotlight-content{padding:24px}.carousel-arrow--prev{left:8px}.carousel-arrow--next{right:8px}}.exp-layout{gap:0;min-height:320px;display:flex}.exp-tabs{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;min-width:140px;display:flex}.exp-tab{font-family:var(--font-mono);color:var(--text-muted);text-align:left;cursor:pointer;letter-spacing:.02em;white-space:nowrap;background:0 0;border:none;border-left:2px solid #0000;padding:12px 20px;font-size:13px;transition:color .2s,background .2s,border-color .2s}.exp-tab:hover{color:var(--accent);background:var(--accent-dim2)}.exp-tab.active{color:var(--accent);background:var(--accent-dim2);border-left-color:var(--accent)}.exp-panel{flex:1;padding:4px 0 4px 36px}.exp-role{font-family:var(--font-display);color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:600;line-height:1.3}.exp-company{color:var(--accent);font-weight:500}.exp-period{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;margin-bottom:24px;font-size:12px}.exp-desc{flex-direction:column;gap:12px;list-style:none;display:flex}.exp-desc li{color:var(--text-secondary);padding-left:22px;font-size:16px;line-height:1.7;position:relative}.exp-desc li:before{content:"▹";color:var(--accent);font-size:13px;position:absolute;top:2px;left:0}@media (width<=700px){.exp-layout{flex-direction:column}.exp-tabs{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;overflow-x:auto}.exp-tab{white-space:nowrap;border-bottom:2px solid #0000;border-left:none;padding:10px 16px}.exp-tab.active{border-bottom-color:var(--accent);border-left-color:#0000}.exp-panel{padding:28px 0 0}}.contact-body{max-width:600px}.contact-intro{color:var(--text-secondary);margin-bottom:40px;font-size:17px;line-height:1.8}.contact-intro b{color:var(--text-primary);font-weight:500}.cta-btn{border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);letter-spacing:.04em;border-radius:4px;align-items:center;padding:14px 32px;font-size:14px;transition:background .25s cubic-bezier(.645,.045,.355,1),transform .25s;display:inline-flex}.cta-btn:hover{background:var(--accent-dim);transform:translateY(-3px)}.contact-links{flex-direction:column;gap:16px;margin-top:44px;display:flex}.contact-row{align-items:center;gap:20px;display:flex}.contact-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;flex-shrink:0;width:76px;font-size:11px}.contact-value{color:var(--text-secondary);font-size:15px;transition:color .2s}.contact-value:hover{color:var(--accent)}.app{min-height:100vh}.app-content{max-width:1000px;margin:0 auto;padding:0 60px 160px}@media (width<=768px){.app-content{padding:0 32px 120px}}@media (width<=480px){.app-content{padding:0 24px 80px}}:root{--bg:#0f0f0f;--bg-2:#161616;--bg-3:#1e1e1e;--border:#ffffff12;--border-hover:#ffffff26;--text-primary:#f0ede8;--text-secondary:#9a9a8e;--text-muted:#555550;--accent:#c8b89a;--accent-dim:#c8b89a1f;--accent-dim2:#c8b89a0f;--green:#7ec8a4;--font-display:"Space Grotesk", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"Space Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;font-size:17px;line-height:1.75}::selection{background:var(--accent-dim);color:var(--accent)}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:2px}.fade-in-section{opacity:0;transition:opacity .55s,transform .55s;transform:translateY(20px)}.fade-in-section.is-visible{opacity:1;transform:none}.section-header{justify-content:space-between;align-items:center;margin-bottom:48px;display:flex}.section-title{font-family:var(--font-display);color:var(--text-primary);align-items:center;font-size:clamp(26px,3.5vw,38px);font-weight:700;display:flex}.section-title .slash{color:var(--accent);margin-right:10px;font-weight:400}.section-title:after{content:"";background:var(--border);width:200px;height:1px;margin-left:20px;display:block}section{padding-top:100px;scroll-margin-top:72px}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}body{margin:0}
