:root{--bg:#f6f4fb;--bg-soft:#fbfaff;--surface:#ffffff;--surface-alt:#f3ecfb;--surface-strong:#eedcf8;--text:#181321;--muted:#6d647d;--line:#ece4f4;--purple:#9a4dff;--purple-strong:#b84be8;--purple-soft:#f2e5ff;--shadow:0 20px 50px rgba(143,110,177,0.12);--shadow-soft:0 12px 30px rgba(143,110,177,0.08);--radius-xl:34px;--radius-lg:24px;--radius-md:18px;--container:1220px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:radial-gradient(circle at top right,rgba(208,153,255,.2),transparent 24%),linear-gradient(180deg,#f8f6fb,#f5f3f9);color:var(--text);font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.site-shell,main{position:relative}.site-shell{overflow-x:clip}.site-backdrop{position:fixed;inset:0;background:radial-gradient(circle at 15% 10%,rgba(212,171,255,.14),transparent 22%),radial-gradient(circle at 88% 18%,rgba(245,183,236,.15),transparent 18%);pointer-events:none}.container{width:min(calc(100% - 48px),var(--container));margin:0 auto}.page-stack{padding-bottom:88px}.page-narrow .container{width:min(calc(100% - 48px),980px)}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:20;background:rgba(248,246,251,.9);border-bottom:1px solid rgba(24,19,33,.05);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.nav-frame{display:grid;grid-template-columns:auto 1fr;align-items:center;grid-gap:20px;gap:20px;min-height:74px}.brand-name{font-size:19px;font-weight:700;letter-spacing:-.03em}.brand-name-inline{white-space:nowrap}.article-tags,.contact-panel-actions,.footer-links,.hero-actions,.hero-contact-row,.hero-cta-row,.nav-links{display:flex;align-items:center;flex-wrap:wrap;gap:12px}.nav-links{justify-content:center;gap:18px}.nav-links a{padding:8px 10px;color:#312a3f;font-size:15px;font-weight:600}.footer-links a:hover,.hero-contact-row a:hover,.nav-links a:hover{color:var(--purple)}.nav-icon-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.75);color:#3d344b}.hero-portfolio{position:relative;padding:28px 0 20px}.hero-portfolio:after{content:"";position:absolute;left:0;right:0;bottom:0;height:180px;background:linear-gradient(0deg,rgba(167,150,189,.08) 1px,transparent 0) 0 0 /100% 42px,linear-gradient(90deg,rgba(167,150,189,.08) 1px,transparent 0) bottom /70px 100%;transform:perspective(900px) rotateX(76deg);transform-origin:bottom center;pointer-events:none}.hero-portfolio-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.86fr);align-items:center;grid-gap:42px;gap:42px;width:min(calc(100% - 156px),1080px);margin:0 auto}.hero-content{max-width:620px}.hero-pill,.section-kicker{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.85);color:var(--muted);font-size:14px;box-shadow:var(--shadow-soft)}.article-section-card h2,.contact-panel h2,.hero-heading,.section-heading h2,.section-heading h3,.subpage-title{margin:24px 0 0;font-weight:800;letter-spacing:-.05em;line-height:1.05}.hero-heading{font-size:clamp(2.4rem,4.8vw,4.8rem);line-height:1.04}.hero-heading-intro{display:block;max-width:11ch;font-size:clamp(2.6rem,5vw,5rem);line-height:.96;color:#6f6680;font-weight:700}.hero-heading-name{display:block;margin-top:2px;color:var(--purple);font-size:clamp(2.8rem,5.3vw,5.2rem);line-height:.98;font-weight:800}.hero-description{max-width:30rem;margin:16px 0 0;color:#191422;font-size:18px;line-height:1.75;white-space:normal;overflow-wrap:anywhere;word-break:break-word;text-wrap:pretty}.article-feature-card p,.article-hero p,.article-section-card p,.capability-card p,.contact-panel p,.footer-text,.hero-lead,.hero-summary,.project-copy,.section-heading p,.story-card{color:var(--muted);line-height:1.8}.hero-lead{margin:22px 0 0;font-size:25px;color:#473f55}.hero-summary{max-width:560px;margin:18px 0 0;font-size:20px;line-height:1.65;color:#8c84a0}.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:0 28px;border-radius:999px;font-size:16px;font-weight:700;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.article-feature-link:hover,.back-link:hover,.button:hover,.project-link:hover{transform:translateY(-1px)}.button-outline-strong,.button-primary{border:1.5px solid rgba(154,77,255,.35);background:rgba(255,255,255,.92);color:var(--purple);box-shadow:var(--shadow-soft)}.button-outline-soft,.button-secondary{border:1.5px solid rgba(154,77,255,.22);background:rgba(244,233,255,.7);color:#7c42d9}.hero-cta-row{margin-top:18px}.hero-actions{margin-top:26px}.hero-contact-row{margin-top:14px}.footer-links a,.hero-contact-row a{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px}.hero-photo-card,.hero-portrait-stage{position:relative}.hero-photo-card{width:min(100%,378px);margin-left:auto;padding:14px;border-radius:28px;background:rgba(255,255,255,.88);box-shadow:0 24px 80px rgba(210,145,221,.28),0 0 0 1px rgba(255,255,255,.8)}.hero-photo{width:100%;height:auto;border-radius:20px;background:#ffffff}.status-dot{position:absolute;top:28px;right:28px;width:12px;height:12px;border-radius:50%;background:#32c16c;border:2px solid #ffffff}.sticker{position:absolute;display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;color:#ffffff;font-size:11px;font-weight:700;box-shadow:0 12px 24px rgba(154,77,255,.22)}.sticker-top{top:-10px;left:10px;background:linear-gradient(135deg,#9d47ff,#d84cb8);transform:rotate(-8deg)}.sticker-bottom-left{left:12px;bottom:12px;background:rgba(36,35,50,.9)}.sticker-bottom-right{right:-4px;bottom:-8px;background:linear-gradient(135deg,#4d8dff,#2ac8ff);transform:rotate(6deg)}.homepage-section,.section-shell{padding:78px 0 0}.section-light{position:relative}.section-heading{max-width:900px;margin:0 0 30px}.section-heading-center{margin-inline:auto;text-align:center}.section-heading-tight{margin-bottom:20px}.contact-panel h2,.section-heading h2,.subpage-title{font-size:clamp(2.3rem,5vw,4rem)}.section-heading h3{font-size:2.1rem}.section-heading p{margin:18px auto 0;max-width:840px;font-size:18px}.story-block{margin-top:22px}.article-feature-card,.capability-card,.contact-panel,.footer-frame,.glass-card,.project-showcase-card,.story-card{border:1px solid rgba(154,77,255,.08);border-radius:var(--radius-lg);background:rgba(255,255,255,.9);box-shadow:var(--shadow-soft)}.story-card{max-width:1120px;margin:0 auto;padding:34px 38px;font-size:18px}.capability-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:22px;gap:22px;margin-top:28px}.capability-card{padding:28px}.article-feature-icon,.capability-icon,.icon-badge,.project-showcase-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#a04bf8,#e05cc2);color:#ffffff;box-shadow:0 12px 28px rgba(154,77,255,.22)}.article-feature-card h3,.capability-card h4,.project-showcase-body h3,.resume-card h2,.resume-card h3{margin:18px 0 10px;font-size:28px;line-height:1.22;letter-spacing:-.03em}.capability-card p{margin:0;font-size:17px}.project-showcase-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:22px;gap:22px}.project-showcase-card{overflow:hidden}.project-showcase-top{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;min-height:230px;padding:28px;background:linear-gradient(135deg,rgba(227,198,255,.92),rgba(245,202,230,.86));text-align:center}.project-showcase-top span{color:#5c506f;font-size:18px;font-weight:600}.project-showcase-body{padding:30px 28px}.project-highlight{margin:0;color:var(--purple);font-size:18px;font-weight:700;line-height:1.7}.project-copy{margin:18px 0 0;font-size:17px}.project-result-block{margin-top:24px}.project-result-block strong{display:block;margin-bottom:10px;font-size:18px}.detail-list,.project-bullet-list{display:grid;grid-gap:12px;gap:12px;margin:0;padding:0;list-style:none}.detail-list li,.project-bullet-list li{position:relative;padding-left:18px;color:#433b51;line-height:1.7}.detail-list li:before,.project-bullet-list li:before{content:"";position:absolute;top:11px;left:0;width:7px;height:7px;border-radius:50%;background:var(--purple)}.article-feature-tags,.chip-list,.tag-row{display:flex;flex-wrap:wrap;gap:10px}.tag-row{margin-top:22px}.article-feature-tags span,.article-tags span,.chip-list li,.tag-row span{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--purple-soft);color:#8b52db;font-size:13px;font-weight:600;list-style:none}.article-feature-link,.back-link,.project-link,.text-link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;color:var(--purple);font-weight:700}.article-feature-grid,.resume-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:22px;gap:22px}.article-feature-card,.glass-card{padding:28px}.article-feature-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.article-feature-card p{margin:14px 0 0;font-size:17px}.article-feature-card blockquote{margin:18px 0 0;padding-left:16px;border-left:3px solid #dcb6ff;color:#473f55;line-height:1.8}.contact-banner,.contact-panel{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:32px}.contact-panel p{margin:18px 0 0;font-size:18px}.resume-document-card{padding:24px;border:1px solid rgba(154,77,255,.08);border-radius:var(--radius-lg);background:rgba(255,255,255,.92);box-shadow:var(--shadow-soft)}.resume-document-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}.resume-document-chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--purple-soft);color:var(--purple);font-size:13px;font-weight:700}.resume-document-actions{display:flex;align-items:center;flex-wrap:wrap;gap:14px}.resume-document-actions a{color:var(--muted);font-size:14px}.resume-document-header{display:flex;align-items:center;gap:16px;margin:22px 0 18px}.resume-document-header h2{margin:0;font-size:28px;letter-spacing:-.03em}.resume-document-header p{margin:8px 0 0;color:var(--muted)}.resume-document{margin:0;padding:24px;border-radius:18px;background:#faf7ff;border:1px solid var(--line);color:#3f3650;font-family:SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:14px;line-height:1.75;white-space:pre-wrap;word-break:break-word}.resume-document-rich{padding:10px 0 0}.resume-rich-h2,.resume-rich-h3,.resume-rich-h4{margin:0;letter-spacing:-.03em}.resume-rich-h2{margin-top:28px;padding-top:20px;border-top:1px solid var(--line);font-size:28px}.resume-rich-h3{margin-top:22px;font-size:21px;color:#2a2036}.resume-rich-h4{margin-top:18px;font-size:18px}.resume-embed-line,.resume-rich-paragraph{margin:14px 0 0;color:#4b425a;line-height:1.9}.resume-embed-line{padding:12px 14px;border-radius:14px;background:#faf7ff;border:1px dashed #d9cdee;color:#7b6f8f;font-family:SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:13px}.resume-rich-list,.resume-rich-ordered{display:grid;grid-gap:10px;gap:10px;margin:14px 0 0;padding-left:0}.resume-rich-list{list-style:none}.resume-rich-list li,.resume-rich-ordered li{position:relative;padding-left:18px;color:#4b425a;line-height:1.8}.resume-rich-list li:before{content:"";position:absolute;top:11px;left:0;width:7px;height:7px;border-radius:50%;background:var(--purple)}.resume-rich-ordered{padding-left:20px}.resume-divider{margin:28px 0 0;border:0;border-top:1px solid var(--line)}.site-footer{padding:56px 0 36px}.footer-frame{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 28px}.footer-title{margin:0;font-size:18px;font-weight:700}.footer-text{margin:8px 0 0;font-size:15px}.subpage-hero{padding:62px 0 24px}.article-reading-card{padding:30px;border:1px solid rgba(154,77,255,.08);border-radius:var(--radius-lg);background:rgba(255,255,255,.92);box-shadow:var(--shadow-soft)}.article-page-title{margin:0 0 24px;color:var(--text);font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.14;letter-spacing:-.04em}.article-markdown{color:#433b51}.article-markdown-blockquote,.article-markdown-list li,.article-markdown-ordered li,.article-markdown-paragraph,.article-markdown-table td,.article-markdown-table th{font-size:16px;line-height:1.9}.article-markdown-paragraph{margin:0}.article-markdown-blockquote+.article-markdown-paragraph,.article-markdown-h2+.article-markdown-paragraph,.article-markdown-h3+.article-markdown-paragraph,.article-markdown-h4+.article-markdown-paragraph,.article-markdown-list+.article-markdown-paragraph,.article-markdown-ordered+.article-markdown-paragraph,.article-markdown-paragraph+.article-markdown-list,.article-markdown-paragraph+.article-markdown-ordered,.article-markdown-paragraph+.article-markdown-paragraph,.article-markdown-pre+.article-markdown-paragraph,.article-markdown-table-wrap+.article-markdown-paragraph{margin-top:16px}.article-markdown-h2,.article-markdown-h3,.article-markdown-h4{margin:28px 0 14px;color:var(--text);letter-spacing:-.03em}.article-markdown-h2{font-size:30px}.article-markdown-h3{font-size:24px}.article-markdown-h4{font-size:19px}.article-markdown-list,.article-markdown-ordered{display:grid;grid-gap:10px;gap:10px;margin:16px 0 0}.article-markdown-list{padding-left:0;list-style:none}.article-markdown-list li,.article-markdown-ordered li{color:#433b51}.article-markdown-list li{position:relative;padding-left:18px}.article-markdown-list li:before{content:"";position:absolute;top:11px;left:0;width:7px;height:7px;border-radius:50%;background:var(--purple)}.article-markdown-ordered{padding-left:22px}.article-markdown-divider{margin:24px 0 0;border:0;border-top:1px solid var(--line)}.article-markdown-blockquote{margin:18px 0 0;padding:16px 18px;border-left:4px solid #d7b0ff;border-radius:14px;background:#faf7ff;color:#5b516c}.article-markdown-pre{margin:18px 0 0;padding:18px 20px;overflow-x:auto;border-radius:18px;background:#191422;color:#f6f1ff;font-size:14px;line-height:1.75}.article-markdown pre code,.article-markdown-blockquote code,.article-markdown-list code,.article-markdown-ordered code,.article-markdown-paragraph code,.article-markdown-table code{font-family:SFMono-Regular,Menlo,Monaco,Courier New,monospace}.article-markdown-blockquote code,.article-markdown-list code,.article-markdown-ordered code,.article-markdown-paragraph code,.article-markdown-table code{padding:.18em .45em;border-radius:8px;background:#f4effd;color:#6b3cd1;font-size:.92em}.article-inline-link{color:var(--purple);text-decoration:underline;text-underline-offset:3px}.article-markdown-table-wrap{margin-top:18px;overflow-x:auto}.article-markdown-table{width:100%;min-width:580px;border-collapse:collapse;border:1px solid var(--line)}.article-markdown-table td,.article-markdown-table th{padding:14px 16px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}.article-markdown-table th{background:#faf7ff;color:var(--text);font-weight:700}.article-markdown-table tr:last-child td{border-bottom:0}@media (max-width:1180px){.article-feature-grid,.capability-grid,.hero-portfolio-grid,.project-showcase-grid,.resume-grid{grid-template-columns:1fr}.hero-portfolio-grid{width:100%;gap:32px}.hero-photo-card{width:min(100%,280px);margin:0 auto}}@media (max-width:880px){.contact-banner,.contact-panel,.footer-frame,.nav-frame{grid-template-columns:1fr;flex-direction:column;align-items:flex-start}.nav-links{justify-content:flex-start}.hero-portfolio{padding-top:28px}.hero-heading{font-size:2.8rem}.hero-lead{font-size:21px}}@media (max-width:640px){.container{width:min(calc(100% - 24px),var(--container))}.hero-portfolio-grid{width:100%}.nav-frame{min-height:auto;padding:14px 0}.contact-panel h2,.hero-heading,.section-heading h2,.subpage-title{font-size:2.2rem}.article-markdown-blockquote,.article-markdown-list li,.article-markdown-ordered li,.article-markdown-paragraph,.article-markdown-table td,.article-markdown-table th,.contact-panel p,.hero-summary,.section-heading p,.story-card{font-size:16px}.resume-document-actions,.resume-document-toolbar{flex-direction:column;align-items:flex-start}.hero-heading-intro{max-width:none}.article-feature-card,.contact-banner,.contact-panel,.glass-card,.project-showcase-body,.story-card{padding:22px}.hero-photo-card{width:min(100%,320px);padding:12px}.status-dot{top:24px;right:24px}.sticker-bottom-right{right:8px}}