body{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='17' viewBox='0 0 12 17'%3E%3Cpath d='M1 1 L1 13 L3.8 9.8 L6.5 15 L8 14.2 L5.3 9 L9.5 9 Z' fill='none' stroke='%232A2A2A' stroke-width='1' stroke-linejoin='round'/%3E%3C/svg%3E") 1 1,auto}[data-theme=dark] body{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='17' viewBox='0 0 12 17'%3E%3Cpath d='M1 1 L1 13 L3.8 9.8 L6.5 15 L8 14.2 L5.3 9 L9.5 9 Z' fill='none' stroke='%23DDDDE0' stroke-width='1' stroke-linejoin='round'/%3E%3C/svg%3E") 1 1,auto}a,button,.toolkit-tag,.project-card{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='17' viewBox='0 0 12 17'%3E%3Cpath d='M1 1 L1 13 L3.8 9.8 L6.5 15 L8 14.2 L5.3 9 L9.5 9 Z' fill='none' stroke='%232A2A2A' stroke-width='1' stroke-linejoin='round'/%3E%3C/svg%3E") 1 1,pointer}[data-theme=dark] a,[data-theme=dark] button,[data-theme=dark] .toolkit-tag,[data-theme=dark] .project-card{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='17' viewBox='0 0 12 17'%3E%3Cpath d='M1 1 L1 13 L3.8 9.8 L6.5 15 L8 14.2 L5.3 9 L9.5 9 Z' fill='none' stroke='%23DDDDE0' stroke-width='1' stroke-linejoin='round'/%3E%3C/svg%3E") 1 1,pointer}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #F5F4F1;--bg-alt: #EEEDEA;--text-primary: #2A2A2A;--text-secondary: #6B6B6B;--text-muted: #9A9A9A;--accent: #3B6BDE;--accent-hover: #2D55B8;--accent-muted: #C3CFEA;--accent-ghost: #DAE0ED;--accent-faint: #E8ECF4;--border: #C5D0DC;--card-bg: #FAFAF8;--font-body: "Inter", -apple-system, sans-serif;--font-display: "Manrope", -apple-system, sans-serif;--max-w: 720px;--section-gap: 140px;--nav-bg: rgba(245, 244, 241, .85)}[data-theme=dark]{--bg: #1E2028;--bg-alt: #252830;--text-primary: #DDDDE0;--text-secondary: #9496A1;--text-muted: #6C6E7A;--accent: #7BA4F7;--accent-hover: #93B6F9;--accent-muted: #2F3D5E;--accent-ghost: #272E42;--accent-faint: #232840;--border: #353845;--card-bg: #252830;--nav-bg: rgba(30, 32, 40, .85)}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.7;overflow-x:hidden;transition:background .4s ease,color .4s ease}::selection{background:var(--accent);color:#fff}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:center;padding:24px 20px;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .4s ease,transform .4s ease}.nav.visible{opacity:1;transform:translateY(0);pointer-events:all}.nav-inner{display:flex;gap:32px;padding:10px 28px;background:var(--nav-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:40px}.nav-link{font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--text-secondary);text-decoration:none;position:relative;padding:2px 0;transition:color .3s ease}.nav-link:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.nav-link:hover{color:var(--accent)}.nav-link:hover:after{width:100%}.theme-toggle{background:none;border:none;cursor:inherit;color:var(--text-muted);padding:4px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.theme-toggle:hover{color:var(--accent)}.theme-icon.moon,[data-theme=dark] .theme-icon.sun{display:none}[data-theme=dark] .theme-icon.moon{display:block}section{display:flex;justify-content:center;padding:0 24px}.section-inner{width:100%;max-width:var(--max-w)}.section-label{font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.2em;color:var(--accent);margin-bottom:32px}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:80px 24px}.hero-content{max-width:var(--max-w);width:100%;position:relative;text-align:center}.hero-bg-name{font-family:var(--font-display);font-weight:800;font-size:clamp(72px,12vw,160px);color:transparent;-webkit-text-stroke:1.5px var(--accent-ghost);line-height:.9;letter-spacing:-.03em;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:0;animation:fadeInBgName 1.2s ease .2s forwards}@keyframes fadeInBgName{to{opacity:1}}.hero-foreground{position:relative;z-index:2;opacity:0;animation:fadeUp .8s ease .6s forwards}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-subtitle{font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.14em;color:var(--text-muted);margin-bottom:16px}.hero-name{font-family:var(--font-display);font-size:clamp(32px,5vw,52px);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.15;margin-bottom:28px}.hero-name span{color:var(--accent)}.hero-nee{font-size:.38em;font-weight:400;color:var(--text-muted);letter-spacing:0;vertical-align:baseline}.hero-photo{width:72px;height:72px;border-radius:50%;background:var(--accent-muted);margin:0 auto 24px;overflow:hidden;border:2px solid var(--bg);box-shadow:0 0 0 1px var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent);font-family:var(--font-display);font-weight:700;font-size:24px}.hero-tagline{font-size:15px;color:var(--text-secondary);max-width:440px;margin:0 auto;line-height:1.7}.scroll-hint{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeUp .8s ease 1.2s forwards}.scroll-line{width:1px;height:32px;background:var(--accent-muted);position:relative;overflow:hidden}.scroll-line:after{content:"";position:absolute;top:-100%;left:0;width:1px;height:100%;background:var(--accent);animation:scrollPulse 2s ease infinite}@keyframes scrollPulse{0%{top:-100%}50%{top:100%}to{top:100%}}.about-section{padding-top:var(--section-gap);padding-bottom:var(--section-gap)}.about-text{font-size:16px;color:var(--text-secondary);line-height:1.8;margin-bottom:24px;text-align:justify}.about-pullquote{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--text-primary);line-height:1.5;margin:40px 0;padding-left:20px;border-left:2px solid var(--accent)}.toolkit{display:flex;flex-wrap:wrap;gap:8px;margin-top:40px}.toolkit-tag{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);padding:6px 14px;background:var(--accent-faint);border-radius:20px;transition:background .3s ease,color .3s ease;letter-spacing:.01em}.toolkit-tag:hover{background:var(--accent);color:#fff}.experience-section{padding-bottom:var(--section-gap)}.exp-list{display:flex;flex-direction:column;gap:0}.exp-item{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--border);align-items:start;transition:background .3s ease}.exp-item:first-child{border-top:1px solid var(--border)}.exp-date{font-size:12px;font-weight:500;color:var(--text-muted);letter-spacing:.02em;padding-top:2px}.exp-role{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px;position:relative;display:inline}.exp-role:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.exp-item:hover .exp-role:after{width:100%}.exp-company{font-size:14px;color:var(--text-secondary);margin-bottom:6px}.exp-desc{font-size:13px;color:var(--text-muted);line-height:1.6;text-align:justify}.projects-section{padding-bottom:var(--section-gap)}.projects-grid{display:flex;flex-direction:column;gap:24px}.project-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .3s ease,box-shadow .3s ease}.project-card:hover{border-color:var(--accent-muted);box-shadow:0 4px 24px #3b6bde0f}.project-preview{width:100%;height:200px;background:linear-gradient(135deg,var(--accent-faint) 0%,var(--accent-ghost) 100%);position:relative;overflow:hidden}.project-preview-placeholder{position:absolute;top:20px;right:20px;bottom:20px;left:20px;border-radius:6px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px}.project-info{padding:24px}.project-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px;display:inline;position:relative}.project-title:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.project-card:hover .project-title:after{width:100%}.project-image{width:100%;object-fit:cover;border-radius:16px;display:block}.project-desc{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-top:8px;margin-bottom:16px;text-align:justify}.project-tags{display:flex;flex-wrap:wrap;gap:6px}.project-tag{font-size:11px;font-weight:500;padding:4px 10px;background:var(--accent-faint);color:var(--accent);border-radius:14px;letter-spacing:.01em}.project-links{display:flex;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.project-link{font-size:12px;font-weight:500;color:var(--text-secondary);text-decoration:none;position:relative;padding:2px 0;transition:color .3s ease}.project-link:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.project-link:hover{color:var(--accent)}.project-link:hover:after{width:100%}.resume-link{display:inline-block;margin-top:24px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;position:relative;padding:2px 0;transition:color .3s ease}.resume-link:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.resume-link:hover{color:var(--accent)}.resume-link:hover:after{width:100%}.contact-section{padding-bottom:var(--section-gap)}.contact-heading{font-family:var(--font-display);font-size:clamp(28px,4vw,40px);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:16px}.contact-text{font-size:15px;color:var(--text-secondary);line-height:1.7;margin-bottom:32px;max-width:480px;text-align:justify}.contact-links{display:flex;flex-direction:column;gap:12px}.contact-link{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-primary);text-decoration:none;position:relative;display:inline-flex;align-items:center;gap:10px;padding:2px 0;width:fit-content;transition:color .3s ease}.contact-link:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.25,.46,.45,.94)}.contact-link:hover{color:var(--accent)}.contact-link:hover:after{width:100%}.contact-link-label{font-size:11px;font-weight:500;color:var(--text-muted);letter-spacing:.06em;min-width:60px}.footer{display:flex;justify-content:center;padding:40px 24px;border-top:1px solid var(--border)}.footer-inner{max-width:var(--max-w);width:100%;display:flex;justify-content:space-between;align-items:center}.footer-text{font-size:12px;color:var(--text-muted)}.footer-built{font-size:11px;color:var(--text-muted);letter-spacing:.02em}.fade-section{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.fade-section.visible{opacity:1;transform:translateY(0)}@media (max-width: 640px){:root{--section-gap: 100px}.nav-inner{gap:20px;padding:10px 20px}.nav-link{font-size:12px}.exp-item{grid-template-columns:1fr;gap:4px}.exp-date{padding-top:0}.project-preview{height:160px}.contact-link{flex-direction:column;align-items:flex-start;gap:2px}}
