*{box-sizing:border-box;margin:0;padding:0}html{font-size:100%}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:400;line-height:var(--leading-body);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;background-color:var(--bg-color);color:var(--text-color);isolation:isolate;min-height:100vh;min-height:100dvh;overflow-x:hidden;position:relative;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}[role=button],a,button,summary{-webkit-tap-highlight-color:color-mix(in srgb,var(--color-accent-orange) 18%,transparent)}.font-display{font-family:var(--font-display);font-weight:400}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background-color:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:#26251e47;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#26251e66}.dark-theme ::-webkit-scrollbar-thumb{background:#f54e0073}.dark-theme ::-webkit-scrollbar-thumb:hover{background:#f54e009e}a{color:var(--color-accent-orange);text-decoration:none;transition:color var(--transition-speed) ease}a:hover{color:var(--accent-bright)}:focus-visible{box-shadow:0 4px 12px #0000001a;outline:none}:focus:not(:focus-visible){outline:none}::-moz-selection{background-color:color-mix(in srgb,var(--color-accent-orange) 22%,transparent);color:var(--text-color)}::selection{background-color:color-mix(in srgb,var(--color-accent-orange) 22%,transparent);color:var(--text-color)}.fade-enter-active,.fade-leave-active{transition:opacity var(--duration-moderate) var(--ease-out-quint)}.fade-enter-from,.fade-leave-to{opacity:0}*,:after,:before{transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease}@media(prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.scroll-down-indicator .chevron,.scroll-down-indicator .chevron:after,.scroll-down-indicator .chevron:before{animation-duration:1.4s!important;animation-iteration-count:infinite!important}.scroll-reveal{opacity:1!important;transform:none!important}}@media(prefers-contrast:more){.contact-link,.skill-tag{border:2px solid}}.transform-gpu{transform:translateZ(0);will-change:transform}@keyframes shimmer{0%{background-position:-468px 0}to{background-position:468px 0}}.loading-shimmer{animation:shimmer 1.5s linear infinite;background:linear-gradient(to right,var(--card-bg) 8%,var(--color-surface-300) 18%,var(--card-bg) 33%);background-size:800px 104px}html[data-design=cursor]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-cursor-dark:#26251e;--color-cursor-cream:#f2f1ed;--color-surface-100:#f7f7f4;--color-surface-200:#f2f1ed;--color-surface-300:#ebeae5;--color-surface-400:#e6e5e0;--color-surface-500:#e1e0db;--color-accent-orange:#f54e00;--color-error:#cf2d56;--color-success:#1f8a65;--border-oklab:oklab(.263084 -.00230259 .0124794/.1);--border-oklab-medium:oklab(.263084 -.00230259 .0124794/.2);--bg-color:var(--color-surface-200);--card-bg:var(--color-surface-100);--card-bg-rgb:247,247,244;--text-color:var(--color-cursor-dark);--secondary-text:rgba(38,37,30,.55);--accent:var(--color-accent-orange);--accent-bright:#ff6a26;--accent-deep:#d94400;--accent-muted:color-mix(in srgb,var(--color-accent-orange) 14%,transparent);--accent-rgb:245,78,0;--highlight:#dfa88f;--highlight-soft:color-mix(in srgb,var(--highlight) 28%,transparent);--gradient-primary:linear-gradient(135deg in srgb,var(--accent-deep) 0%,var(--color-accent-orange) 52%,var(--accent-bright) 100%);--gradient-primary-soft:linear-gradient(135deg in srgb,color-mix(in srgb,var(--accent-deep) 88%,transparent),color-mix(in srgb,var(--accent-bright) 82%,transparent));--header-bg:linear-gradient(168deg,#f7f7f4 0%,var(--color-cursor-cream) 42%,var(--color-surface-300) 100%);--footer-bg:linear-gradient(168deg,var(--color-surface-300) 0%,var(--color-surface-400) 52%,var(--color-surface-500) 100%);--shadow-color:rgba(0,0,0,.12);--shadow-hover:rgba(0,0,0,.18);--shadow-section:rgba(0,0,0,.14) 0px 28px 70px,rgba(0,0,0,.1) 0px 14px 32px,oklab(.263084 -.00230259 .0124794/.1) 0px 0px 0px 1px;--shadow-elevated-sm:rgba(0,0,0,.02) 0px 0px 16px,rgba(0,0,0,.008) 0px 0px 8px;--shadow-elevated-md:rgba(0,0,0,.12) 0px 18px 44px,rgba(0,0,0,.08) 0px 8px 20px;--shadow-elevated-lg:rgba(0,0,0,.14) 0px 28px 70px,rgba(0,0,0,.1) 0px 14px 32px;--border-color:var(--border-oklab);--nav-scrolled-surface:color-mix(in srgb,var(--color-surface-100) 94%,#fff);--nav-scrolled-shadow:0 4px 24px rgba(0,0,0,.06);--nav-scrolled-divider:var(--border-oklab);--surface-drawer:var(--color-surface-100);--surface-drawer-shadow:-5px 0 18px rgba(0,0,0,.08);--chrome-on-hero-bg:rgba(38,37,30,.06);--chrome-on-hero-border:rgba(38,37,30,.1);--chrome-on-hero-bg-hover:rgba(38,37,30,.09);--chrome-on-hero-border-hover:rgba(38,37,30,.14);--text-on-accent:#fff;--text-on-dark-pure:#f7f7f4;--surface-article-nav:color-mix(in srgb,var(--card-bg) 90%,transparent);--theme-switch-track:var(--color-surface-300);--theme-switch-track-active:color-mix(in srgb,var(--color-cursor-dark) 88%,#000);--theme-switch-knob:#fff;--theme-switch-knob-on:var(--color-surface-500);--theme-switch-knob-shadow:0 2px 8px rgba(0,0,0,.12);--theme-sun-core:#f0a070;--theme-moon-ring:rgba(38,37,30,.38);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:1200px;--layout-article-max:min(72rem,1100px);--border-radius:10px;--radius-card:8px;--radius-sm:4px;--transition-speed:.15s;--scrollbar-track:var(--color-surface-300);--scrollbar-thumb:rgba(38,37,30,.22);--scrollbar-thumb-hover:rgba(38,37,30,.36);--scroll-indicator-color:rgba(38,37,30,.42);--scroll-indicator-shadow:hsla(48,16%,94%,.55);--font-display:system-ui,-apple-system,"Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:"Noto Serif SC","Source Han Serif CN","Iowan Old Style","Palatino Linotype","PingFang SC","Microsoft YaHei",ui-serif,Georgia,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--text-xs:.6875rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.08rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.65rem,4vw,2.25rem);--text-hero:clamp(2.65rem,10vw,4.5rem);--leading-none:1.1;--leading-tight:1.2;--leading-snug:1.38;--leading-body:1.65;--leading-relaxed:1.75;--tracking-display-hero:-.03em;--tracking-section:-.02em;--tracking-tighter:-.03em;--tracking-tight:-.015em;--tracking-normal:0;--tracking-wide:.07em;--tracking-wider:.08em;--text-shadow-hero-title:0 2px 24px rgba(38,37,30,.12);--text-shadow-hero-title-strong:0 4px 28px rgba(0,0,0,.35);--text-shadow-hero-sub:0 2px 16px rgba(38,37,30,.1);--text-shadow-hero-sub-strong:0 2px 18px rgba(0,0,0,.28);--text-shadow-hero-body:0 1px 10px rgba(38,37,30,.08);--text-shadow-hero-body-strong:0 2px 12px rgba(0,0,0,.22);--text-shadow-ui-soft:0 1px 3px rgba(38,37,30,.08);--text-shadow-hero-name-on-hero:0 1px 2px hsla(0,0%,100%,.55),0 2px 14px rgba(38,37,30,.08);--text-shadow-hero-tagline-on-hero:0 1px 8px hsla(0,0%,100%,.45);--text-shadow-hero-body-on-hero:0 1px 6px hsla(0,0%,100%,.4);--text-shadow-hero-on-light-title:0 1px 0 hsla(0,0%,100%,.35),0 2px 20px rgba(38,37,30,.06);--text-shadow-hero-on-light-sub:0 1px 0 hsla(0,0%,100%,.28);--text-shadow-hero-on-light-body:0 1px 0 hsla(0,0%,100%,.22);--hero-body-text-on-light:var(--secondary-text);--hero-body-text:rgba(247,247,244,.78);--hero-body-text-strong:rgba(247,247,244,.9);--explore-button-bg:var(--color-surface-300);--text-emphasis-ink:var(--color-cursor-dark);--code-block-bg:#1a1916;--code-block-fg:#ebeae5;--border-subtle:rgba(38,37,30,.08);--cta-glass-bg:hsla(0,0%,100%,.35);--cta-glass-border:var(--border-oklab);--cta-glass-hover-bg:hsla(0,0%,100%,.5);--cta-glass-bg-on-dark:hsla(0,0%,100%,.12);--cta-glass-border-on-dark:hsla(0,0%,100%,.2);--cta-glass-hover-on-dark:hsla(0,0%,100%,.18);--shadow-footer-block:rgba(0,0,0,.12) 0px 20px 50px;--shadow-header-underline:rgba(0,0,0,.08) 0px 8px 24px;--contact-chip-bg:rgba(38,37,30,.06);--contact-chip-border:var(--border-oklab);--contact-chip-hover-bg:rgba(38,37,30,.04);--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:hsla(0,0%,100%,.35);--contact-chip-bg-dark:hsla(0,0%,100%,.08);--contact-chip-hover-bg-dark:hsla(0,0%,100%,.12);--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:color-mix(in srgb,var(--color-accent-orange) 38%,var(--border-oklab));--button-hover-text:var(--color-error)}html[data-design=cursor] body:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cfilter id='a'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='4' stitchTiles='stitch' type='fractalNoise'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.55'/%3E%3C/svg%3E");content:"";inset:0;mix-blend-mode:multiply;opacity:.028;pointer-events:none;position:fixed;z-index:0}html[data-design=cursor] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:500;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=cursor] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=cursor] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=cursor] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=cursor] .design-theme-select{accent-color:var(--color-accent-orange);align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--color-surface-300);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2326251e' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--border-oklab-medium);border-radius:8px;box-sizing:border-box;color:var(--text-color);color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:.8125rem;font-weight:500;justify-content:flex-start;margin:0;padding:6px 28px 6px 10px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=cursor] .design-theme-select-panel{background-color:var(--color-surface-100);border:1px solid var(--border-oklab-medium);border-radius:8px;box-shadow:var(--shadow-elevated-md);box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=cursor] .design-theme-select-option{border-radius:6px;color:var(--text-color);cursor:pointer;font-size:.8125rem;font-weight:500;line-height:1.35;margin:0;padding:.5rem .65rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=cursor] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=cursor] .design-theme-select-option:not(.is-disabled):hover{background-color:var(--color-surface-400)}html[data-design=cursor] .design-theme-select-option.is-selected{background-color:color-mix(in srgb,var(--color-accent-orange) 20%,var(--color-surface-100));color:var(--text-color)}html[data-design=cursor] .design-theme-select-option.is-disabled{color:var(--secondary-text);cursor:not-allowed;opacity:1}html[data-design=cursor] .design-theme-select:hover{background-color:var(--color-surface-400);border-color:color-mix(in srgb,var(--text-color) 22%,var(--border-oklab-medium))}html[data-design=cursor] .design-theme-select:focus-visible{box-shadow:none;outline:2px solid var(--color-accent-orange);outline-offset:2px}html[data-design=cursor].dark-theme{color-scheme:dark;--bg-color:#1a1916;--card-bg:#23221e;--card-bg-rgb:35,34,30;--text-color:#ebeae5;--secondary-text:hsla(50,13%,91%,.62);--accent:#ff6a33;--accent-bright:#ff8a5c;--accent-deep:#f54e00;--accent-muted:color-mix(in srgb,var(--accent) 20%,transparent);--accent-rgb:255,106,51;--highlight:#c08532;--highlight-soft:color-mix(in srgb,var(--highlight) 25%,transparent);--gradient-primary:linear-gradient(135deg in srgb,var(--accent-deep) 0%,var(--accent) 50%,var(--accent-bright) 100%);--gradient-primary-soft:linear-gradient(135deg in srgb,color-mix(in srgb,var(--accent-deep) 85%,transparent),color-mix(in srgb,var(--accent-bright) 82%,transparent));--header-bg:linear-gradient(168deg,#121110,#1a1916 45%,#141311);--footer-bg:linear-gradient(168deg,#1f1e1b,#181714);--shadow-color:rgba(0,0,0,.45);--shadow-hover:rgba(0,0,0,.55);--shadow-section:rgba(0,0,0,.35) 0px 24px 60px,oklab(.263084 -.00230259 .0124794/.12) 0px 0px 0px 1px;--shadow-elevated-sm:0 4px 18px rgba(0,0,0,.35);--shadow-elevated-md:0 10px 28px rgba(0,0,0,.45);--shadow-elevated-lg:0 16px 40px rgba(0,0,0,.5);--border-color:oklab(.263084 -.00230259 .0124794/.18);--nav-scrolled-surface:color-mix(in srgb,var(--card-bg) 94%,#000);--nav-scrolled-shadow:0 4px 28px rgba(0,0,0,.4);--nav-scrolled-divider:oklab(.263084 -.00230259 .0124794/.14);--surface-drawer:#1e1d19;--surface-drawer-shadow:-5px 0 22px rgba(0,0,0,.4);--chrome-on-hero-bg:hsla(0,0%,100%,.08);--chrome-on-hero-border:hsla(0,0%,100%,.14);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.12);--chrome-on-hero-border-hover:hsla(0,0%,100%,.2);--text-on-accent:#141311;--surface-article-nav:color-mix(in srgb,var(--card-bg) 88%,transparent);--theme-switch-track:#2e2c27;--theme-switch-track-active:#f54e00;--theme-switch-knob:#f7f7f4;--theme-switch-knob-on:#23221e;--theme-switch-knob-shadow:0 2px 10px rgba(0,0,0,.45);--theme-sun-core:#f0a070;--theme-moon-ring:hsla(50,13%,91%,.85);--scrollbar-track:#1e1d19;--scrollbar-thumb:rgba(245,78,0,.45);--scrollbar-thumb-hover:rgba(245,78,0,.62);--scroll-indicator-color:hsla(50,13%,91%,.55);--scroll-indicator-shadow:rgba(0,0,0,.35);--tech-tag-muted:hsla(50,13%,91%,.72);--leading-body:1.72;--border-subtle:hsla(50,13%,91%,.1);--border-section-on-dark:hsla(50,13%,91%,.06);--code-block-bg:#121110;--code-block-fg:#e6e5e0;--article-item-border-hover:color-mix(in srgb,var(--accent) 45%,var(--border-color))}html[data-design=cursor].dark-theme body:before{mix-blend-mode:soft-light;opacity:.06}html[data-design=cursor].dark-theme .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,#2e2c27 18%,var(--card-bg) 33%)}html[data-design=cursor].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=cursor].dark-theme .design-theme-select{background-color:#ffffff1f;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f5f5f4' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:#ffffff38;color:var(--text-color);color-scheme:dark}html[data-design=cursor].dark-theme .design-theme-select:hover{background-color:#ffffff29;border-color:#ffffff47}html[data-design=cursor].dark-theme .design-theme-select-panel{background-color:var(--card-bg);border-color:var(--border-color);box-shadow:var(--shadow-elevated-lg)}html[data-design=cursor].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=cursor].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#ffffff1a}html[data-design=cursor].dark-theme .design-theme-select-option.is-selected{background-color:color-mix(in srgb,var(--accent) 32%,var(--card-bg));color:var(--text-color)}html[data-design=cursor].dark-theme .design-theme-select-option.is-disabled{color:#ebeae58c}html[data-design=cursor].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--text-on-dark-pure)}html[data-design=cursor].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f7f7f4' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:var(--chrome-on-hero-border);color:var(--text-on-dark-pure);color-scheme:dark}html[data-design=cursor].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--chrome-on-hero-border-hover)}@media(prefers-contrast:more){html[data-design=cursor]{--shadow-color:rgba(0,0,0,.22);--shadow-hover:rgba(0,0,0,.32);--border-color:rgba(38,37,30,.22)}html[data-design=cursor].dark-theme{--shadow-color:hsla(0,0%,100%,.12);--shadow-hover:hsla(0,0%,100%,.18);--border-color:hsla(50,13%,91%,.22)}}@media(max-width:768px){html[data-design=cursor] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=cursor] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;color:ButtonText;padding:.2rem .45rem}html[data-design=cursor] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=cursor] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=cursor] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=cursor] .design-theme-select-option{color:ButtonText}html[data-design=cursor] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=apple]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-cursor-dark:#1d1d1f;--color-accent-orange:#0071e3;--color-apple-blue:#0071e3;--color-link:#06c;--color-link-on-dark:#2997ff;--color-error:#0071e3;--color-success:#0071e3;--color-surface-100:#fff;--color-surface-200:#f5f5f7;--color-surface-300:#fafafc;--color-surface-400:#ededf2;--color-surface-500:#e8e8ed;--bg-color:#f5f5f7;--card-bg:#fff;--card-bg-rgb:255,255,255;--text-color:#1d1d1f;--secondary-text:rgba(0,0,0,.48);--accent:#0071e3;--accent-bright:#2997ff;--accent-deep:#06c;--accent-muted:rgba(0,113,227,.14);--accent-rgb:0,113,227;--highlight:rgba(0,113,227,.12);--highlight-soft:rgba(0,113,227,.08);--gradient-primary:linear-gradient(180deg,#0071e3,#0071e3);--gradient-primary-soft:linear-gradient(180deg,rgba(0,113,227,.85),rgba(0,113,227,.85));--header-bg:#000;--footer-bg:#f5f5f7;--shadow-color:rgba(0,0,0,.12);--shadow-hover:rgba(0,0,0,.18);--shadow-section:rgba(0,0,0,.22) 3px 5px 30px 0px;--shadow-elevated-sm:rgba(0,0,0,.22) 3px 5px 30px 0px;--shadow-elevated-md:rgba(0,0,0,.22) 3px 8px 36px 0px;--shadow-elevated-lg:rgba(0,0,0,.25) 3px 10px 40px 0px;--border-color:rgba(0,0,0,.06);--border-oklab:rgba(0,0,0,.08);--border-oklab-medium:rgba(0,0,0,.12);--nav-scrolled-surface:rgba(0,0,0,.72);--nav-scrolled-shadow:none;--nav-scrolled-divider:hsla(0,0%,100%,.08);--surface-drawer:#f5f5f7;--surface-drawer-shadow:-4px 0 24px rgba(0,0,0,.12);--chrome-on-hero-bg:hsla(0,0%,100%,.12);--chrome-on-hero-border:hsla(0,0%,100%,.22);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.18);--chrome-on-hero-border-hover:hsla(0,0%,100%,.28);--text-on-accent:#fff;--text-on-dark-pure:#fff;--surface-article-nav:rgba(0,0,0,.72);--theme-switch-track:#d2d2d7;--theme-switch-track-active:#0071e3;--theme-switch-knob:#fff;--theme-switch-knob-on:#1d1d1f;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.2);--theme-sun-core:#ffd60a;--theme-moon-ring:hsla(0,0%,100%,.85);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:980px;--layout-article-max:min(61rem,980px);--border-radius:8px;--radius-card:8px;--radius-sm:5px;--transition-speed:.2s;--scrollbar-track:#e8e8ed;--scrollbar-thumb:rgba(0,0,0,.25);--scrollbar-thumb-hover:rgba(0,0,0,.4);--scroll-indicator-color:hsla(0,0%,100%,.55);--scroll-indicator-shadow:rgba(0,0,0,.35);--font-display:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:var(--font-display);--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1.0625rem;--text-md:1.0625rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.75rem,4vw,2.5rem);--text-hero:clamp(2.5rem,9vw,3.5rem);--leading-none:1.07;--leading-tight:1.1;--leading-snug:1.29;--leading-body:1.47;--leading-relaxed:1.5;--tracking-display-hero:-.28px;--tracking-section:0;--tracking-tighter:-.02em;--tracking-tight:-.015em;--tracking-normal:-.022em;--tracking-wide:0;--tracking-wider:0;--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:hsla(0,0%,100%,.85);--hero-body-text:hsla(0,0%,100%,.88);--hero-body-text-strong:#fff;--explore-button-bg:#0071e3;--text-emphasis-ink:#1d1d1f;--code-block-bg:#1d1d1f;--code-block-fg:#f5f5f7;--border-subtle:rgba(0,0,0,.06);--cta-glass-bg:hsla(0,0%,100%,.12);--cta-glass-border:hsla(0,0%,100%,.35);--cta-glass-hover-bg:hsla(0,0%,100%,.2);--cta-glass-bg-on-dark:hsla(0,0%,100%,.12);--cta-glass-border-on-dark:hsla(0,0%,100%,.25);--cta-glass-hover-on-dark:hsla(0,0%,100%,.18);--shadow-footer-block:rgba(0,0,0,.22) 3px 5px 30px 0px;--shadow-header-underline:none;--contact-chip-bg:#fafafc;--contact-chip-border:rgba(0,0,0,.06);--contact-chip-hover-bg:#ededf2;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:hsla(0,0%,100%,.35);--contact-chip-bg-dark:hsla(0,0%,100%,.08);--contact-chip-hover-bg-dark:hsla(0,0%,100%,.14);--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(0,113,227,.35);--button-hover-text:#06c}html[data-design=apple] .header{--text-color:#fff;--secondary-text:hsla(0,0%,100%,.72);--hero-body-text-on-light:hsla(0,0%,100%,.8)}html[data-design=apple] .main-nav:before{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#000000b8;border-bottom:1px solid var(--nav-scrolled-divider);box-shadow:none;opacity:var(--nav-bg-opacity,0)}html[data-design=apple] .main-nav .nav-links a,html[data-design=apple] .main-nav .nav-logo,html[data-design=apple] .main-nav.scrolled .nav-links a,html[data-design=apple] .main-nav.scrolled .nav-logo{color:#ffffffeb!important}html[data-design=apple] .main-nav .nav-links a:hover{color:#fff!important}html[data-design=apple] .main-nav .hamburger span{background-color:#ffffffeb!important}html[data-design=apple] .main-nav .nav-links a:after{background:#2997ff!important}html[data-design=apple] .main-nav .nav-links a.active:after{background:#2997ff!important}html[data-design=apple] .header:before{display:none}html[data-design=apple] .name-card h1{font-weight:600;letter-spacing:var(--tracking-display-hero)}html[data-design=apple] .section-title{font-weight:600}html[data-design=apple] .section:hover{box-shadow:var(--shadow-section);transform:none}html[data-design=apple] .explore-button{background:#0071e3!important;border:1px solid transparent!important;border-radius:8px!important;box-shadow:none!important;color:#fff!important;font-weight:400!important;padding:8px 15px!important}html[data-design=apple] .explore-button:hover{background:#0077ed!important;box-shadow:none!important;color:#fff!important;transform:translate3d(0,-1px,0)}html[data-design=apple] .back-to-top-btn{background:#0071e3;border:none;box-shadow:var(--shadow-elevated-sm);color:#fff}html[data-design=apple] .back-to-top-btn:hover{background:#0077ed;box-shadow:var(--shadow-elevated-md);color:#fff}html[data-design=apple] .skill-tag{background:#fafafc!important;border:3px solid rgba(0,0,0,.04)!important;border-radius:11px!important;color:#000c!important;font-weight:400!important}html[data-design=apple] .skill-tag:hover{box-shadow:none!important;color:#06c!important}html[data-design=apple] .skill-tag.is-active{background:#ededf2!important;border-color:#0071e359!important;color:#1d1d1f!important}html[data-design=apple] .article-tag{background:transparent!important;border:1px solid #06c!important;border-radius:980px!important;color:#06c!important;font-size:.875rem!important}html[data-design=apple] .article-tag:hover{color:#0071e3!important;text-decoration:underline}html[data-design=apple] :focus-visible{box-shadow:none;outline:2px solid #0071e3;outline-offset:2px}html[data-design=apple] .article-nav{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#000000b8!important;border-bottom:1px solid hsla(0,0%,100%,.08);box-shadow:none}html[data-design=apple] .article-page .nav-logo{filter:none}html[data-design=apple] .article-page .back-home{background:#0071e3;border:1px solid transparent;color:#fff}html[data-design=apple] .article-page .back-home:hover{background:#0077ed;color:#fff}html[data-design=apple] .article-page .back-to-top{background:#0071e3;border:none;color:#fff}html[data-design=apple] .article-page .back-to-top:hover{background:#0077ed;color:#fff}html[data-design=apple] ::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}html[data-design=apple] ::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}html[data-design=apple] ::-moz-selection{background-color:#0071e338;color:var(--text-color)}html[data-design=apple] ::selection{background-color:#0071e338;color:var(--text-color)}html[data-design=apple] .main-nav .nav-links a{font-size:12px;font-weight:400;letter-spacing:-.08px}html[data-design=apple] .main-nav.scrolled .nav-links a,html[data-design=apple] .main-nav.scrolled .nav-logo{font-weight:400}html[data-design=apple] .content-container .section{border:none}html[data-design=apple] .footer .section-title:after{background:#0071e3}html[data-design=apple] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:500;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=apple] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=apple] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=apple] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=apple] .design-theme-select{accent-color:#0071e3;align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fafafc;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231d1d1f' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid rgba(0,0,0,.18);border-radius:11px;box-shadow:none;box-sizing:border-box;color:#1d1d1f;color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:12px;font-weight:400;justify-content:flex-start;letter-spacing:-.08px;margin:0;min-height:36px;padding:0 28px 0 14px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=apple] .design-theme-select-panel{background-color:#fff;border:1px solid rgba(0,0,0,.14);border-radius:11px;box-shadow:3px 8px 28px #00000038;box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=apple] .design-theme-select-option{border-radius:8px;color:#1d1d1f;cursor:pointer;font-size:12px;font-weight:400;letter-spacing:-.08px;line-height:1.35;margin:0;padding:.5rem .75rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=apple] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=apple] .design-theme-select-option:not(.is-disabled):hover{background-color:#f5f5f7}html[data-design=apple] .design-theme-select-option.is-selected{background-color:#0071e31f;color:#06c}html[data-design=apple] .design-theme-select-option.is-disabled{color:#6e6e73;cursor:not-allowed;opacity:1}html[data-design=apple] .design-theme-select:hover{background-color:#ededf2;border-color:#00000042}html[data-design=apple] .design-theme-select:focus-visible{box-shadow:none;outline:2px solid #0071e3;outline-offset:2px}html[data-design=apple] #articles.section-container,html[data-design=apple] #skills.section-container{position:relative;z-index:1}html[data-design=apple].dark-theme{color-scheme:dark;--bg-color:#000;--card-bg:#272729;--card-bg-rgb:39,39,41;--text-color:#fff;--secondary-text:hsla(0,0%,100%,.72);--accent:#2997ff;--accent-bright:#64b5ff;--accent-deep:#0071e3;--accent-muted:rgba(41,151,255,.2);--accent-rgb:41,151,255;--highlight:rgba(41,151,255,.15);--highlight-soft:rgba(41,151,255,.1);--gradient-primary:linear-gradient(180deg,#0071e3,#0071e3);--gradient-primary-soft:linear-gradient(180deg,rgba(0,113,227,.9),rgba(0,113,227,.9));--header-bg:#000;--footer-bg:#1d1d1f;--shadow-color:rgba(0,0,0,.5);--shadow-hover:rgba(0,0,0,.55);--shadow-section:rgba(0,0,0,.45) 3px 8px 40px 0px;--shadow-elevated-sm:rgba(0,0,0,.35) 3px 5px 28px 0px;--shadow-elevated-md:rgba(0,0,0,.4) 3px 8px 36px 0px;--shadow-elevated-lg:rgba(0,0,0,.45) 3px 10px 44px 0px;--border-color:hsla(0,0%,100%,.12);--border-oklab:hsla(0,0%,100%,.12);--border-oklab-medium:hsla(0,0%,100%,.18);--nav-scrolled-surface:rgba(0,0,0,.72);--nav-scrolled-divider:hsla(0,0%,100%,.1);--surface-drawer:#1d1d1f;--surface-drawer-shadow:-4px 0 28px rgba(0,0,0,.5);--chrome-on-hero-bg:hsla(0,0%,100%,.1);--chrome-on-hero-border:hsla(0,0%,100%,.2);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.16);--chrome-on-hero-border-hover:hsla(0,0%,100%,.28);--text-on-accent:#fff;--surface-article-nav:rgba(0,0,0,.72);--theme-switch-track:#424245;--theme-switch-track-active:#0071e3;--theme-switch-knob:#f5f5f7;--theme-switch-knob-on:#1d1d1f;--scrollbar-track:#1d1d1f;--scrollbar-thumb:hsla(0,0%,100%,.28);--scrollbar-thumb-hover:hsla(0,0%,100%,.45);--scroll-indicator-color:hsla(0,0%,100%,.5);--tech-tag-muted:hsla(0,0%,100%,.65);--leading-body:1.47;--border-subtle:hsla(0,0%,100%,.1);--border-section-on-dark:hsla(0,0%,100%,.06);--code-block-bg:#0a0a0b;--code-block-fg:#f5f5f7;--article-item-border-hover:rgba(41,151,255,.45);--contact-chip-bg:hsla(0,0%,100%,.08);--contact-chip-border:hsla(0,0%,100%,.12);--contact-chip-hover-bg:hsla(0,0%,100%,.12);--text-emphasis-ink:#fff;--button-hover-text:#2997ff}html[data-design=apple].dark-theme .header{--text-color:#fff;--secondary-text:hsla(0,0%,100%,.72);--hero-body-text-on-light:hsla(0,0%,100%,.8)}html[data-design=apple].dark-theme .explore-button{background:#0071e3!important;border:1px solid transparent!important;color:#fff!important}html[data-design=apple].dark-theme .explore-button:hover{background:#0077ed!important;color:#fff!important}html[data-design=apple].dark-theme .skill-tag{background:#ffffff14!important;border:1px solid hsla(0,0%,100%,.12)!important;color:#ffffffd9!important}html[data-design=apple].dark-theme .skill-tag:hover{color:#2997ff!important}html[data-design=apple].dark-theme .skill-tag.is-active{background:#ffffff24!important;color:#fff!important}html[data-design=apple].dark-theme .article-tag{border-color:#2997ff!important;color:#2997ff!important}html[data-design=apple].dark-theme .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,#3a3a3c 18%,var(--card-bg) 33%)}html[data-design=apple].dark-theme ::-webkit-scrollbar-thumb{background:#ffffff47}html[data-design=apple].dark-theme ::-webkit-scrollbar-thumb:hover{background:#ffffff6b}html[data-design=apple].dark-theme ::-moz-selection{background-color:#2997ff47;color:var(--text-color)}html[data-design=apple].dark-theme ::selection{background-color:#2997ff47;color:var(--text-color)}html[data-design=apple].dark-theme .design-theme-select-label,html[data-design=apple].dark-theme .design-theme-select-wrap{color:var(--text-color)}html[data-design=apple].dark-theme .design-theme-select-value{color:inherit}html[data-design=apple].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=apple].dark-theme .design-theme-select{background-color:#ffffff1f;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f5f5f7' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid hsla(0,0%,100%,.28);color:#f5f5f7;color-scheme:dark}html[data-design=apple].dark-theme .design-theme-select:hover{background-color:#ffffff2e;border-color:#ffffff61}html[data-design=apple].dark-theme .design-theme-select-panel{background-color:#2c2c2e;border:1px solid hsla(0,0%,100%,.22);box-shadow:3px 10px 36px #00000073}html[data-design=apple].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=apple].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#ffffff1a}html[data-design=apple].dark-theme .design-theme-select-option.is-selected{background-color:#0071e359;color:#f5f5f7}html[data-design=apple].dark-theme .design-theme-select-option.is-disabled{color:#a1a1a6}html[data-design=apple].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--text-on-dark-pure)}html[data-design=apple].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:#ffffff59;color:#fff;color-scheme:dark}html[data-design=apple].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:#ffffff73}html[data-design=apple].dark-theme #projects.section-container{background:#000;box-sizing:border-box;color:#fff;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(3.5rem,8vw,5.5rem) max(2rem,env(safe-area-inset-right,0px)) clamp(5rem,11vw,10rem) max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:#fff;--secondary-text:hsla(0,0%,100%,.72);--card-bg:#272729;--card-bg-rgb:39,39,41;--border-color:hsla(0,0%,100%,.1);--border-subtle:hsla(0,0%,100%,.08);--border-oklab:hsla(0,0%,100%,.12);--button-hover-text:#2997ff;--color-accent-orange:#0071e3;--article-item-border-hover:rgba(41,151,255,.45)}html[data-design=apple].dark-theme #projects .section-title{color:#fff}html[data-design=apple].dark-theme #projects .section-title:after{background:#0071e3}html[data-design=apple].dark-theme #projects .section{background:#272729;box-shadow:3px 5px 30px #00000038}html[data-design=apple].dark-theme #projects .project-card-wrapper{border:none;box-shadow:3px 5px 30px #00000038}html[data-design=apple].dark-theme #contact.section-container{background:#000;box-sizing:border-box;color:#fff;margin-bottom:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(2.5rem,6vw,4rem) max(2rem,env(safe-area-inset-right,0px)) 0 max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:#fff;--secondary-text:hsla(0,0%,100%,.65)}html[data-design=apple].dark-theme #contact .footer{background:transparent;border:none;box-shadow:none;color:#fff;margin-top:0;padding-bottom:clamp(4rem,10vw,7rem);padding-top:clamp(2.5rem,6vw,4rem)}html[data-design=apple].dark-theme #contact .footer .section-title{color:#fff}html[data-design=apple].dark-theme #contact .footer .section-title:after{background:#0071e3}html[data-design=apple].dark-theme #contact .footer .beian-link{color:#2997ff}html[data-design=apple].dark-theme #contact .footer .beian-link:focus-visible,html[data-design=apple].dark-theme #contact .footer .beian-link:hover{color:#64b5ff}html[data-design=apple].dark-theme #contact .contact-link{border:none}@media(prefers-contrast:more){html[data-design=apple]{--border-color:rgba(0,0,0,.22);--border-oklab:rgba(0,0,0,.22)}html[data-design=apple].dark-theme{--border-color:hsla(0,0%,100%,.22);--border-oklab:hsla(0,0%,100%,.22)}}@media(max-width:768px){html[data-design=apple] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=apple] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;color:ButtonText;min-height:unset;padding:.2rem .45rem}html[data-design=apple] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=apple] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=apple] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=apple] .design-theme-select-option{color:ButtonText}html[data-design=apple] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=claude]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-cursor-dark:#141413;--color-accent-orange:#c96442;--color-link:#3d3d3a;--color-link-on-dark:#d97757;--color-error:#b53333;--color-success:#5e5d59;--color-surface-100:#fff;--color-surface-200:#faf9f5;--color-surface-300:#f5f4ed;--color-surface-400:#f0eee6;--color-surface-500:#e8e6dc;--bg-color:#f5f4ed;--card-bg:#faf9f5;--card-bg-rgb:250,249,245;--text-color:#141413;--secondary-text:#5e5d59;--accent:#c96442;--accent-bright:#d97757;--accent-deep:#a85538;--accent-muted:rgba(201,100,66,.14);--accent-rgb:201,100,66;--highlight:rgba(201,100,66,.12);--highlight-soft:rgba(201,100,66,.08);--gradient-primary:linear-gradient(180deg,#c96442,#c96442);--gradient-primary-soft:linear-gradient(180deg,rgba(201,100,66,.92),rgba(201,100,66,.92));--header-bg:#141413;--footer-bg:#f5f4ed;--shadow-color:rgba(0,0,0,.06);--shadow-hover:rgba(0,0,0,.1);--shadow-section:rgba(0,0,0,.05) 0px 4px 24px;--shadow-elevated-sm:rgba(0,0,0,.05) 0px 4px 24px;--shadow-elevated-md:rgba(0,0,0,.06) 0px 6px 28px;--shadow-elevated-lg:rgba(0,0,0,.07) 0px 8px 32px;--border-color:#f0eee6;--border-oklab:#f0eee6;--border-oklab-medium:#e8e6dc;--nav-scrolled-surface:rgba(20,20,19,.78);--nav-scrolled-shadow:none;--nav-scrolled-divider:#30302e;--surface-drawer:#faf9f5;--surface-drawer-shadow:-4px 0 24px rgba(0,0,0,.08);--chrome-on-hero-bg:hsla(48,33%,97%,.12);--chrome-on-hero-border:hsla(48,33%,97%,.22);--chrome-on-hero-bg-hover:hsla(48,33%,97%,.18);--chrome-on-hero-border-hover:hsla(48,33%,97%,.3);--text-on-accent:#faf9f5;--text-on-dark-pure:#faf9f5;--surface-article-nav:rgba(20,20,19,.78);--theme-switch-track:#e8e6dc;--theme-switch-track-active:#c96442;--theme-switch-knob:#fff;--theme-switch-knob-on:#4d4c48;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.12);--theme-sun-core:#d97757;--theme-moon-ring:hsla(48,33%,97%,.85);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:1200px;--layout-article-max:min(72rem,1100px);--border-radius:8px;--radius-card:8px;--radius-sm:6px;--transition-speed:.2s;--scrollbar-track:#e8e6dc;--scrollbar-thumb:rgba(77,76,72,.28);--scrollbar-thumb-hover:rgba(77,76,72,.45);--scroll-indicator-color:hsla(48,33%,97%,.55);--scroll-indicator-shadow:rgba(0,0,0,.35);--font-display:Georgia,"Noto Serif SC","Source Han Serif CN","Iowan Old Style","Palatino Linotype","Times New Roman",serif;--font-sans:system-ui,-apple-system,"Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-body:var(--font-sans);--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1.0625rem;--text-md:1.0625rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.85rem,4.2vw,3.25rem);--text-hero:clamp(2.5rem,9vw,4rem);--leading-none:1.1;--leading-tight:1.15;--leading-snug:1.3;--leading-body:1.6;--leading-relaxed:1.65;--tracking-display-hero:-.02em;--tracking-section:0;--tracking-tighter:-.02em;--tracking-tight:-.015em;--tracking-normal:-.01em;--tracking-wide:0;--tracking-wider:0;--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:hsla(48,33%,97%,.88);--hero-body-text:hsla(48,33%,97%,.9);--hero-body-text-strong:#faf9f5;--explore-button-bg:#c96442;--text-emphasis-ink:#141413;--code-block-bg:#30302e;--code-block-fg:#faf9f5;--border-subtle:#f0eee6;--cta-glass-bg:hsla(48,33%,97%,.12);--cta-glass-border:hsla(48,33%,97%,.35);--cta-glass-hover-bg:hsla(48,33%,97%,.2);--cta-glass-bg-on-dark:hsla(48,33%,97%,.1);--cta-glass-border-on-dark:hsla(48,33%,97%,.22);--cta-glass-hover-on-dark:hsla(48,33%,97%,.16);--shadow-footer-block:rgba(0,0,0,.05) 0px 4px 24px;--shadow-header-underline:none;--contact-chip-bg:#faf9f5;--contact-chip-border:#f0eee6;--contact-chip-hover-bg:#f5f4ed;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:hsla(0,0%,100%,.35);--contact-chip-bg-dark:hsla(48,33%,97%,.08);--contact-chip-hover-bg-dark:hsla(48,33%,97%,.12);--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(201,100,66,.45);--button-hover-text:#a85538}html[data-design=claude] .header{--text-color:#faf9f5;--secondary-text:hsla(48,33%,97%,.72);--hero-body-text-on-light:hsla(48,33%,97%,.85)}html[data-design=claude] .main-nav:before{backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);background-color:#141413c7;border-bottom:1px solid var(--nav-scrolled-divider);box-shadow:none;opacity:var(--nav-bg-opacity,0)}html[data-design=claude] .main-nav .nav-links a,html[data-design=claude] .main-nav .nav-logo,html[data-design=claude] .main-nav.scrolled .nav-links a,html[data-design=claude] .main-nav.scrolled .nav-logo{color:#faf9f5eb!important}html[data-design=claude] .main-nav .nav-links a:hover{color:#faf9f5!important}html[data-design=claude] .main-nav .hamburger span{background-color:#faf9f5eb!important}html[data-design=claude] .main-nav .nav-links a:after{background:#c96442!important}html[data-design=claude] .main-nav .nav-links a.active:after{background:#c96442!important}html[data-design=claude] .header:before{display:none}html[data-design=claude] .name-card h1{font-family:var(--font-display);font-weight:500;letter-spacing:var(--tracking-display-hero)}html[data-design=claude] .section-title{font-family:var(--font-display);font-weight:500}html[data-design=claude] .section:hover{box-shadow:var(--shadow-section);transform:none}html[data-design=claude] .explore-button{background:#c96442!important;border:1px solid transparent!important;border-radius:12px!important;box-shadow:0 0 #c96442,0 0 0 1px #c96442!important;color:#faf9f5!important;font-family:var(--font-sans);font-weight:500!important;padding:8px 16px 8px 12px!important}html[data-design=claude] .explore-button:hover{background:#d97757!important;box-shadow:0 0 #d97757,0 0 0 1px #d97757!important;color:#faf9f5!important;transform:translate3d(0,-1px,0)}html[data-design=claude] .back-to-top-btn{background:#c96442;border:none;box-shadow:0 0 #c96442,0 0 0 1px #c96442;color:#faf9f5}html[data-design=claude] .back-to-top-btn:hover{background:#d97757;box-shadow:0 0 #d97757,0 0 0 1px #d97757;color:#faf9f5}html[data-design=claude] .skill-tag{background:#faf9f5!important;border:1px solid #f0eee6!important;border-radius:8px!important;box-shadow:none!important;color:#4d4c48!important;font-family:var(--font-sans);font-weight:500!important}html[data-design=claude] .skill-tag:hover{box-shadow:0 0 #faf9f5,0 0 0 1px #d1cfc5!important;color:#c96442!important}html[data-design=claude] .skill-tag.is-active{background:#f5f4ed!important;border-color:#c9644273!important;color:#141413!important}html[data-design=claude] .article-tag{background:transparent!important;border:1px solid #e8e6dc!important;border-radius:980px!important;color:#3d3d3a!important;font-family:var(--font-sans);font-size:.875rem!important}html[data-design=claude] .article-tag:hover{border-color:#c96442!important;color:#c96442!important}html[data-design=claude] :focus-visible{box-shadow:none;outline:2px solid #3898ec;outline-offset:2px}html[data-design=claude] .article-nav{backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);background-color:#141413c7!important;border-bottom:1px solid #30302e;box-shadow:none}html[data-design=claude] .article-page .nav-logo{filter:none}html[data-design=claude] .article-page .back-home{background:#c96442;border:1px solid transparent;border-radius:12px;box-shadow:0 0 #c96442,0 0 0 1px #c96442;color:#faf9f5;font-family:var(--font-sans)}html[data-design=claude] .article-page .back-home:hover{background:#d97757;color:#faf9f5}html[data-design=claude] .article-page .back-to-top{background:#c96442;border:none;border-radius:12px;box-shadow:0 0 #c96442,0 0 0 1px #c96442;color:#faf9f5}html[data-design=claude] .article-page .back-to-top:hover{background:#d97757;color:#faf9f5}html[data-design=claude] ::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}html[data-design=claude] ::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}html[data-design=claude] ::-moz-selection{background-color:#c9644238;color:var(--text-color)}html[data-design=claude] ::selection{background-color:#c9644238;color:var(--text-color)}html[data-design=claude] .main-nav .nav-links a{font-family:var(--font-sans);font-size:17px;font-weight:400;letter-spacing:normal}html[data-design=claude] .main-nav.scrolled .nav-links a,html[data-design=claude] .main-nav.scrolled .nav-logo{font-weight:400}html[data-design=claude] .content-container .section{border:1px solid #f0eee6}html[data-design=claude] .footer .section-title:after{background:#c96442}html[data-design=claude] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:.8125rem;font-weight:500;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=claude] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=claude] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=claude] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=claude] .design-theme-select{accent-color:#c96442;align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#e8e6dc;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234d4c48' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid #e8e6dc;border-radius:8px;box-shadow:0 0 #e8e6dc,0 0 0 1px #d1cfc5;box-sizing:border-box;color:#4d4c48;color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:15px;font-weight:400;justify-content:flex-start;letter-spacing:normal;margin:0;min-height:36px;padding:0 28px 0 12px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=claude] .design-theme-select-panel{background-color:#fff;border:1px solid #f0eee6;border-radius:12px;box-shadow:0 4px 24px #0000000d;box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=claude] .design-theme-select-option{border-radius:8px;color:#141413;cursor:pointer;font-size:15px;font-weight:400;letter-spacing:normal;line-height:1.45;margin:0;padding:.5rem .75rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=claude] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=claude] .design-theme-select-option:not(.is-disabled):hover{background-color:#f5f4ed}html[data-design=claude] .design-theme-select-option.is-selected{background-color:#c964421f;color:#a85538}html[data-design=claude] .design-theme-select-option.is-disabled{color:#87867f;cursor:not-allowed;opacity:1}html[data-design=claude] .design-theme-select:hover{background-color:#e0ded4;border-color:#d1cfc5;box-shadow:0 0 #e0ded4,0 0 0 1px #c2c0b6}html[data-design=claude] .design-theme-select:focus-visible{box-shadow:0 0 #e8e6dc,0 0 0 1px #3898ec;outline:2px solid #3898ec;outline-offset:2px}html[data-design=claude] #articles.section-container,html[data-design=claude] #skills.section-container{position:relative;z-index:1}html[data-design=claude].dark-theme{color-scheme:dark;--bg-color:#141413;--card-bg:#30302e;--card-bg-rgb:48,48,46;--text-color:#faf9f5;--secondary-text:#b0aea5;--accent:#c96442;--accent-bright:#d97757;--accent-deep:#a85538;--accent-muted:rgba(201,100,66,.22);--accent-rgb:201,100,66;--highlight:rgba(201,100,66,.18);--highlight-soft:rgba(201,100,66,.12);--gradient-primary:linear-gradient(180deg,#c96442,#c96442);--gradient-primary-soft:linear-gradient(180deg,rgba(201,100,66,.95),rgba(201,100,66,.95));--header-bg:#141413;--footer-bg:#1a1a18;--shadow-color:rgba(0,0,0,.4);--shadow-hover:rgba(0,0,0,.45);--shadow-section:rgba(0,0,0,.25) 0px 6px 32px;--shadow-elevated-sm:rgba(0,0,0,.2) 0px 4px 24px;--shadow-elevated-md:rgba(0,0,0,.28) 0px 8px 32px;--shadow-elevated-lg:rgba(0,0,0,.32) 0px 10px 40px;--border-color:#30302e;--border-oklab:#30302e;--border-oklab-medium:#3d3d3a;--nav-scrolled-surface:rgba(20,20,19,.82);--nav-scrolled-divider:#30302e;--surface-drawer:#252523;--surface-drawer-shadow:-4px 0 28px rgba(0,0,0,.45);--chrome-on-hero-bg:hsla(48,33%,97%,.1);--chrome-on-hero-border:hsla(48,33%,97%,.2);--chrome-on-hero-bg-hover:hsla(48,33%,97%,.16);--chrome-on-hero-border-hover:hsla(48,33%,97%,.28);--text-on-accent:#faf9f5;--surface-article-nav:rgba(20,20,19,.82);--theme-switch-track:#3d3d3a;--theme-switch-track-active:#c96442;--theme-switch-knob:#faf9f5;--theme-switch-knob-on:#30302e;--scrollbar-track:#1a1a18;--scrollbar-thumb:rgba(176,174,165,.35);--scrollbar-thumb-hover:rgba(176,174,165,.52);--scroll-indicator-color:hsla(48,33%,97%,.5);--tech-tag-muted:hsla(48,33%,97%,.65);--leading-body:1.6;--border-subtle:hsla(48,33%,97%,.1);--border-section-on-dark:hsla(48,33%,97%,.06);--code-block-bg:#1a1a18;--code-block-fg:#faf9f5;--article-item-border-hover:rgba(217,119,87,.5);--contact-chip-bg:hsla(48,33%,97%,.08);--contact-chip-border:#30302e;--contact-chip-hover-bg:hsla(48,33%,97%,.12);--text-emphasis-ink:#faf9f5;--button-hover-text:#d97757}html[data-design=claude].dark-theme .header{--text-color:#faf9f5;--secondary-text:hsla(48,33%,97%,.72);--hero-body-text-on-light:hsla(48,33%,97%,.85)}html[data-design=claude].dark-theme .explore-button{background:#c96442!important;border:1px solid transparent!important;color:#faf9f5!important}html[data-design=claude].dark-theme .explore-button:hover{background:#d97757!important;color:#faf9f5!important}html[data-design=claude].dark-theme .skill-tag{background:#faf9f514!important;border:1px solid #30302e!important;color:#b0aea5!important}html[data-design=claude].dark-theme .skill-tag:hover{color:#d97757!important}html[data-design=claude].dark-theme .skill-tag.is-active{background:#faf9f51f!important;color:#faf9f5!important}html[data-design=claude].dark-theme .article-tag{border-color:#d97757!important;color:#d97757!important}html[data-design=claude].dark-theme .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,#3d3d3a 18%,var(--card-bg) 33%)}html[data-design=claude].dark-theme ::-webkit-scrollbar-thumb{background:#b0aea559}html[data-design=claude].dark-theme ::-webkit-scrollbar-thumb:hover{background:#b0aea585}html[data-design=claude].dark-theme ::-moz-selection{background-color:#d9775747;color:var(--text-color)}html[data-design=claude].dark-theme ::selection{background-color:#d9775747;color:var(--text-color)}html[data-design=claude].dark-theme .content-container .section{border:1px solid #30302e}html[data-design=claude].dark-theme .design-theme-select-label,html[data-design=claude].dark-theme .design-theme-select-wrap{color:var(--text-color)}html[data-design=claude].dark-theme .design-theme-select-value{color:inherit}html[data-design=claude].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=claude].dark-theme .design-theme-select{background-color:#30302e;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23faf9f5' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid #30302e;box-shadow:0 0 #30302e,0 0 0 1px #3d3d3a;color:var(--text-color);color-scheme:dark}html[data-design=claude].dark-theme .design-theme-select:hover{background-color:#3d3d3a;border-color:#3d3d3a}html[data-design=claude].dark-theme .design-theme-select-panel{background-color:#30302e;border:1px solid #3d3d3a;box-shadow:0 8px 32px #00000059}html[data-design=claude].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=claude].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#faf9f514}html[data-design=claude].dark-theme .design-theme-select-option.is-selected{background-color:#c9644247;color:#faf9f5}html[data-design=claude].dark-theme .design-theme-select-option.is-disabled{color:#87867f}html[data-design=claude].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--text-on-dark-pure)}html[data-design=claude].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23faf9f5' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:#faf9f547;box-shadow:none;color:#faf9f5;color-scheme:dark}html[data-design=claude].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:#faf9f561}html[data-design=claude].dark-theme #projects.section-container{background:#141413;box-sizing:border-box;color:#faf9f5;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(3.5rem,8vw,5.5rem) max(2rem,env(safe-area-inset-right,0px)) clamp(5rem,11vw,10rem) max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:#faf9f5;--secondary-text:#b0aea5;--card-bg:#30302e;--card-bg-rgb:48,48,46;--border-color:#30302e;--border-subtle:hsla(48,33%,97%,.08);--border-oklab:#30302e;--button-hover-text:#d97757;--color-accent-orange:#c96442;--article-item-border-hover:rgba(217,119,87,.5)}html[data-design=claude].dark-theme #projects .section-title{color:#faf9f5}html[data-design=claude].dark-theme #projects .section-title:after{background:#c96442}html[data-design=claude].dark-theme #projects .section{background:#30302e;border:1px solid #3d3d3a;box-shadow:0 4px 24px #0003}html[data-design=claude].dark-theme #projects .project-card-wrapper{border:none;box-shadow:0 4px 24px #0003}html[data-design=claude].dark-theme #contact.section-container{background:#141413;box-sizing:border-box;color:#faf9f5;margin-bottom:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(2.5rem,6vw,4rem) max(2rem,env(safe-area-inset-right,0px)) 0 max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:#faf9f5;--secondary-text:#b0aea5}html[data-design=claude].dark-theme #contact .footer{background:transparent;border:none;box-shadow:none;color:#faf9f5;margin-top:0;padding-bottom:clamp(4rem,10vw,7rem);padding-top:clamp(2.5rem,6vw,4rem)}html[data-design=claude].dark-theme #contact .footer .section-title{color:#faf9f5}html[data-design=claude].dark-theme #contact .footer .section-title:after{background:#c96442}html[data-design=claude].dark-theme #contact .footer .beian-link{color:#d97757}html[data-design=claude].dark-theme #contact .footer .beian-link:focus-visible,html[data-design=claude].dark-theme #contact .footer .beian-link:hover{color:#e8a090}html[data-design=claude].dark-theme #contact .contact-link{border:none}@media(prefers-contrast:more){html[data-design=claude]{--border-color:#e8e6dc;--border-oklab:#e8e6dc}html[data-design=claude].dark-theme{--border-color:hsla(48,33%,97%,.22);--border-oklab:hsla(48,33%,97%,.22)}}@media(max-width:768px){html[data-design=claude] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=claude] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;box-shadow:none;color:ButtonText;min-height:unset;padding:.2rem .45rem}html[data-design=claude] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=claude] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=claude] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=claude] .design-theme-select-option{color:ButtonText}html[data-design=claude] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=clickhouse]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--bg-color:#e4e6eb;--card-bg:#fff;--card-bg-rgb:255,255,255;--text-color:#0f0f0f;--secondary-text:#52525b;--color-surface-100:#fff;--color-surface-200:#f4f4f6;--color-surface-300:#ebebef;--color-surface-400:#e4e4e9;--color-surface-500:#dcdce2;--border-color:rgba(65,65,65,.2);--border-oklab:rgba(65,65,65,.22);--border-oklab-medium:rgba(65,65,65,.32);--border-subtle:rgba(65,65,65,.12);--border-section-on-dark:rgba(22,101,52,.12);--nav-scrolled-surface:hsla(0,0%,100%,.94);--nav-scrolled-shadow:0 4px 24px rgba(0,0,0,.08);--nav-scrolled-divider:rgba(65,65,65,.14);--font-display:"Inter",system-ui,-apple-system,"Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:var(--font-display);--font-mono:"Inconsolata",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.75rem,4vw,2.25rem);--text-hero:clamp(2.75rem,11vw,6rem);--leading-none:1;--leading-tight:1.1;--leading-snug:1.3;--leading-body:1.56;--leading-relaxed:1.65;--tracking-display-hero:-.02em;--tracking-section:.0875rem;--tracking-tighter:-.02em;--tracking-tight:-.015em;--tracking-normal:0;--tracking-wide:.06em;--tracking-wider:.08em;--layout-max-width:min(1200px,92vw);--layout-article-max:min(72rem,1100px);--border-radius:8px;--radius-card:8px;--radius-sm:4px;--transition-speed:.15s;--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--ch-nav-fg:hsla(0,0%,6%,.92);--ch-nav-hover:#166534;--ch-nav-bar-bg:hsla(0,0%,100%,.94);--ch-hamburger:hsla(0,0%,6%,.88);--ch-hero-h1:#0a0a0a;--ch-hero-h2:#64748b;--ch-hero-p:#52525b;--ch-section-title:#111827;--ch-focus-ring:#166534;--ch-explore-hover-bg:#14532d;--ch-explore-hover-fg:#fff;--ch-explore-shadow:var(--shadow-elevated-sm);--ch-btt-bg:#fff;--ch-btt-fg:#166534;--ch-btt-bd:rgba(65,65,65,.22);--ch-btt-shadow:var(--shadow-elevated-sm);--ch-btt-hover-bg:#f4f4f6;--ch-btt-hover-fg:#faff69;--ch-btt-hover-bd:#faff69;--ch-skill-bg:#fff;--ch-skill-fg:#111827;--ch-skill-bd:rgba(65,65,65,.22);--ch-skill-hover-fg:#166534;--ch-skill-active-bg:#f4f4f6;--ch-skill-active-fg:#14532d;--ch-skill-active-bd:#166534;--ch-skill-active-shadow:inset rgba(0,0,0,.06) 0px 2px 8px;--ch-art-bg:#fff;--ch-art-fg:#0f0f0f;--ch-art-hover-fg:#166534;--ch-art-hover-bd:#166534;--ch-article-nav-bg:hsla(0,0%,100%,.96);--ch-article-nav-bd:rgba(65,65,65,.12);--ch-article-nav-sh:0 1px 0 rgba(65,65,65,.1);--ch-section-fill:#fff;--ch-section-bd:rgba(65,65,65,.16);--ch-section-sh:rgba(0,0,0,.06) 0px 1px 3px;--ch-projects-band:#dcdfe5;--ch-projects-fg:#0f0f0f;--ch-projects-muted:#52525b;--ch-projects-card:#fff;--ch-projects-card-rgb:255,255,255;--ch-projects-border:rgba(65,65,65,.2);--ch-projects-border-subtle:rgba(65,65,65,.12);--ch-projects-button-hover:#14532d;--ch-projects-article-hover-bd:rgba(22,101,52,.4);--ch-projects-accent:#166534;--ch-projects-title:#111827;--ch-projects-section-bg:#fff;--ch-projects-section-sh:rgba(0,0,0,.08) 0px 8px 24px;--ch-projects-section-bd:rgba(65,65,65,.14);--ch-projects-card-sh:rgba(0,0,0,.06) 0px 6px 20px;--ch-contact-band:#dcdfe5;--ch-footer-fg:#0f0f0f;--ch-footer-title:#111827;--ch-beian:#166534;--ch-beian-hover:#faff69;--ch-contact-chip-bg:#fff;--ch-contact-chip-bd:rgba(65,65,65,.2);--ch-contact-chip-hover-bd:#faff69;--ch-contact-chip-hover-fg:#166534;--ch-dts-accent:#166534;--ch-dts-fg:#0f0f0f;--ch-dts-bg:#fff;--ch-dts-bd:rgba(65,65,65,.22);--ch-dts-inset:none;--ch-dts-hover-bg:#f4f4f6;--ch-dts-hover-bd:rgba(22,101,52,.45);--ch-dts-focus:#166534;--ch-dts-fv-sh:none;--ch-dts-panel-bg:#fff;--ch-dts-panel-bd:rgba(65,65,65,.18);--ch-dts-panel-sh:rgba(0,0,0,.12) 0px 12px 32px;--ch-dts-opt-hov-bg:#f4f4f6;--ch-dts-opt-hov-fg:#166534;--ch-dts-opt-sel-bg:rgba(22,101,52,.1);--ch-dts-opt-sel-fg:#14532d;--ch-dts-opt-sel-sh:none;--ch-dts-opt-dis-fg:#a1a1aa;--ch-dts-opt-dis-op:.75;--ch-dts-nav-wrap-fg:#0f0f0f;--ch-dts-nav-fg:#0f0f0f;--ch-dts-nav-bd:hsla(0,0%,6%,.14);--ch-dts-nav-hov-bd:rgba(22,101,52,.4);--ch-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23166534' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--ch-selection-bg:rgba(22,101,52,.18);--ch-back-home-hov-bg:#14532d;--ch-back-home-hov-fg:#fff;--ch-article-btt-bg:#fff;--ch-article-btt-fg:#166534;--ch-article-btt-bd:rgba(65,65,65,.22);--ch-article-btt-sh:var(--shadow-elevated-sm);--ch-article-btt-inset:none;--ch-article-btt-hov-bg:#f4f4f6;--ch-article-btt-hov-fg:#faff69;--ch-article-btt-hov-bd:#faff69;--ch-shimmer-mid:#e8e8ec;--color-cursor-dark:#0f0f0f;--color-accent-orange:#faff69;--color-link:#166534;--color-link-on-dark:#166534;--color-error:#ef4444;--color-success:#166534;--accent:#faff69;--accent-bright:#d4e82a;--accent-deep:#c8db20;--accent-muted:rgba(22,101,52,.12);--accent-rgb:22,101,52;--highlight:rgba(22,101,52,.08);--highlight-soft:rgba(22,101,52,.05);--gradient-primary:linear-gradient(180deg,#faff69,#faff69);--gradient-primary-soft:linear-gradient(180deg,rgba(250,255,105,.85),rgba(250,255,105,.85));--header-bg:#d7d9df;--footer-bg:#e4e6eb;--shadow-color:rgba(0,0,0,.12);--shadow-hover:rgba(0,0,0,.16);--shadow-section:rgba(0,0,0,.08) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.06) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.1) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.12) 0px 12px 36px;--surface-drawer:#f4f4f6;--surface-drawer-shadow:-4px 0 24px rgba(0,0,0,.12);--chrome-on-hero-bg:hsla(0,0%,100%,.5);--chrome-on-hero-border:hsla(0,0%,6%,.12);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.72);--chrome-on-hero-border-hover:rgba(22,101,52,.45);--text-on-accent:#fff;--text-on-dark-pure:#0f0f0f;--surface-article-nav:hsla(0,0%,100%,.94);--theme-switch-track:#d4d4d8;--theme-switch-track-active:#166534;--theme-switch-knob:#fff;--theme-switch-knob-on:#0f0f0f;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.15);--theme-sun-core:#f59e0b;--theme-moon-ring:hsla(0,0%,6%,.35);--scrollbar-track:#e8e8ec;--scrollbar-thumb:rgba(22,101,52,.35);--scrollbar-thumb-hover:rgba(22,101,52,.5);--scroll-indicator-color:rgba(22,101,52,.45);--scroll-indicator-shadow:rgba(0,0,0,.15);--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:#52525b;--hero-body-text:#52525b;--hero-body-text-strong:#0f0f0f;--explore-button-bg:#166534;--text-emphasis-ink:#0f0f0f;--code-block-bg:#1a1a1a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.65);--cta-glass-border:rgba(65,65,65,.2);--cta-glass-hover-bg:hsla(0,0%,100%,.85);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:rgba(65,65,65,.8);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.1) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#fff;--contact-chip-border:rgba(65,65,65,.18);--contact-chip-hover-bg:#f4f4f6;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(22,101,52,.12);--contact-chip-bg-dark:#fff;--contact-chip-hover-bg-dark:#f4f4f6;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(22,101,52,.45);--button-hover-text:#14532d;--tech-tag-muted:#71717a}html[data-design=clickhouse] .header{--text-color:#0f0f0f;--secondary-text:#52525b;--hero-body-text-on-light:#52525b}html[data-design=clickhouse] .main-nav:before{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--ch-nav-bar-bg);border-bottom:1px solid var(--nav-scrolled-divider);box-shadow:var(--nav-scrolled-shadow);opacity:var(--nav-bg-opacity,0)}html[data-design=clickhouse] .main-nav .nav-links a,html[data-design=clickhouse] .main-nav .nav-logo,html[data-design=clickhouse] .main-nav.scrolled .nav-links a,html[data-design=clickhouse] .main-nav.scrolled .nav-logo{color:var(--ch-nav-fg)!important}html[data-design=clickhouse] .main-nav .nav-links a:hover{color:var(--ch-nav-hover)!important}html[data-design=clickhouse] .main-nav .hamburger span{background-color:var(--ch-hamburger)!important}html[data-design=clickhouse] .main-nav .nav-links a.active:after,html[data-design=clickhouse] .main-nav .nav-links a:after{background:#faff69!important}html[data-design=clickhouse] .header:before{display:none}html[data-design=clickhouse] .name-card h1{color:var(--ch-hero-h1)!important;font-family:var(--font-display);font-weight:900;letter-spacing:var(--tracking-display-hero);text-shadow:none!important}html[data-design=clickhouse] .name-card h2{color:var(--ch-hero-h2)!important;font-size:clamp(.75rem,1.8vw,.875rem);font-weight:600;letter-spacing:.06em;text-shadow:none!important;text-transform:uppercase}html[data-design=clickhouse] .name-card p{color:var(--ch-hero-p)!important;text-shadow:none!important}html[data-design=clickhouse] .section .section-title{color:var(--ch-section-title);font-family:var(--font-display);font-size:clamp(1.35rem,3.2vw,2rem);font-weight:700;letter-spacing:.0875rem;line-height:var(--leading-tight);text-transform:uppercase}html[data-design=clickhouse] .footer .section-title{color:var(--ch-section-title);font-family:var(--font-display);font-size:clamp(1.35rem,3.2vw,2rem);font-weight:700;letter-spacing:.06em;text-transform:none}html[data-design=clickhouse] .section:hover{box-shadow:var(--shadow-section);transform:none}html[data-design=clickhouse] .explore-button{background:#166534!important;border:1px solid #0f3d22!important;border-radius:4px!important;box-shadow:var(--ch-explore-shadow)!important;color:#fff!important;font-family:var(--font-display);font-weight:600!important;padding:12px 16px!important}html[data-design=clickhouse] .explore-button:hover{background:var(--ch-explore-hover-bg)!important;color:var(--ch-explore-hover-fg)!important;transform:translate3d(0,-1px,0)}html[data-design=clickhouse] .explore-button:active{color:#f4f692!important}html[data-design=clickhouse] .back-to-top-btn{background:var(--ch-btt-bg);border:1px solid var(--ch-btt-bd);box-shadow:var(--ch-btt-shadow);color:var(--ch-btt-fg)}html[data-design=clickhouse] .back-to-top-btn:hover{background:var(--ch-btt-hover-bg);border-color:var(--ch-btt-hover-bd);color:var(--ch-btt-hover-fg)}html[data-design=clickhouse] .skill-tag{background:var(--ch-skill-bg)!important;border:1px solid var(--ch-skill-bd)!important;border-radius:4px!important;box-shadow:none!important;color:var(--ch-skill-fg)!important;font-family:var(--font-display);font-weight:600!important}html[data-design=clickhouse] .skill-tag:hover{border-color:#faff69!important;color:var(--ch-skill-hover-fg)!important}html[data-design=clickhouse] .skill-tag.is-active{background:var(--ch-skill-active-bg)!important;border-color:var(--ch-skill-active-bd)!important;box-shadow:var(--ch-skill-active-shadow)!important;color:var(--ch-skill-active-fg)!important}html[data-design=clickhouse] .article-tag{background:var(--ch-art-bg)!important;border:1px solid #4f5100!important;border-radius:4px!important;color:var(--ch-art-fg)!important;font-family:var(--font-display);font-size:.875rem!important;font-weight:500!important}html[data-design=clickhouse] .article-tag:hover{border-color:var(--ch-art-hover-bd)!important;color:var(--ch-art-hover-fg)!important}html[data-design=clickhouse] :focus-visible{box-shadow:none;outline:2px solid var(--ch-focus-ring);outline-offset:2px}html[data-design=clickhouse] .article-nav{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--ch-article-nav-bg)!important;border-bottom:1px solid var(--ch-article-nav-bd);box-shadow:var(--ch-article-nav-sh)}html[data-design=clickhouse] .article-page .nav-logo{filter:none}html[data-design=clickhouse] .article-page .back-home{background:#166534;border:1px solid #0f3d22;border-radius:4px;box-shadow:var(--shadow-elevated-sm);color:#fff;font-family:var(--font-display);font-weight:600}html[data-design=clickhouse] .article-page .back-home:hover{background:var(--ch-back-home-hov-bg);color:var(--ch-back-home-hov-fg)}html[data-design=clickhouse] .article-page .back-to-top{background:var(--ch-article-btt-bg);border:1px solid var(--ch-article-btt-bd);border-radius:4px;box-shadow:var(--ch-article-btt-sh),var(--ch-article-btt-inset);color:var(--ch-article-btt-fg)}html[data-design=clickhouse] .article-page .back-to-top:hover{background:var(--ch-article-btt-hov-bg);border-color:var(--ch-article-btt-hov-bd);color:var(--ch-article-btt-hov-fg)}html[data-design=clickhouse] ::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}html[data-design=clickhouse] ::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}html[data-design=clickhouse] ::-moz-selection{background-color:var(--ch-selection-bg);color:var(--text-color)}html[data-design=clickhouse] ::selection{background-color:var(--ch-selection-bg);color:var(--text-color)}html[data-design=clickhouse] .main-nav .nav-links a{font-family:var(--font-display);font-size:.875rem;font-weight:600;letter-spacing:.0875rem;text-transform:uppercase}html[data-design=clickhouse] .main-nav.scrolled .nav-links a,html[data-design=clickhouse] .main-nav.scrolled .nav-logo{font-weight:600}html[data-design=clickhouse] .content-container .section{background:var(--ch-section-fill);border:1px solid var(--ch-section-bd);border-radius:var(--radius-card);box-shadow:var(--ch-section-sh)}html[data-design=clickhouse] .footer .section-title:after{background:#faff69}html[data-design=clickhouse] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:600;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=clickhouse] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=clickhouse] .design-theme-select-value{flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=clickhouse] .design-theme-select-label{color:var(--text-color);font-size:.75rem;letter-spacing:.06em;opacity:1;text-transform:uppercase;white-space:nowrap}html[data-design=clickhouse] .design-theme-select{accent-color:var(--ch-dts-accent);align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--ch-dts-bg);background-image:var(--ch-chevron);background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--ch-dts-bd);border-radius:4px;box-shadow:var(--ch-dts-inset);box-sizing:border-box;color:var(--ch-dts-fg);cursor:pointer;display:inline-flex;font:inherit;font-size:.9375rem;font-weight:500;justify-content:flex-start;letter-spacing:normal;margin:0;min-height:36px;padding:0 28px 0 12px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=clickhouse] .design-theme-select-panel{background-color:var(--ch-dts-panel-bg);border:1px solid var(--ch-dts-panel-bd);border-radius:8px;box-shadow:var(--ch-dts-panel-sh);box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=clickhouse] .design-theme-select-option{border-radius:4px;color:var(--ch-dts-fg);cursor:pointer;font-size:.9375rem;font-weight:500;letter-spacing:normal;line-height:1.45;margin:0;padding:.5rem .75rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=clickhouse] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=clickhouse] .design-theme-select-option:not(.is-disabled):hover{background-color:var(--ch-dts-opt-hov-bg);color:var(--ch-dts-opt-hov-fg)}html[data-design=clickhouse] .design-theme-select-option.is-selected{background-color:var(--ch-dts-opt-sel-bg);box-shadow:var(--ch-dts-opt-sel-sh);color:var(--ch-dts-opt-sel-fg)}html[data-design=clickhouse] .design-theme-select-option.is-disabled{color:var(--ch-dts-opt-dis-fg);cursor:not-allowed;opacity:var(--ch-dts-opt-dis-op)}html[data-design=clickhouse] .design-theme-select:hover{background-color:var(--ch-dts-hover-bg);border-color:var(--ch-dts-hover-bd)}html[data-design=clickhouse] .design-theme-select:focus-visible{box-shadow:var(--ch-dts-fv-sh);outline:2px solid var(--ch-dts-focus);outline-offset:2px}html[data-design=clickhouse] .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--ch-dts-nav-wrap-fg)}html[data-design=clickhouse] .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:var(--ch-chevron);border-color:var(--ch-dts-nav-bd);box-shadow:none;color:var(--ch-dts-nav-fg)}html[data-design=clickhouse] .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--ch-dts-nav-hov-bd)}html[data-design=clickhouse] #articles.section-container,html[data-design=clickhouse] #skills.section-container{position:relative;z-index:1}html[data-design=clickhouse] #projects.section-container{background:var(--ch-projects-band);box-sizing:border-box;color:var(--ch-projects-fg);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(3.5rem,8vw,5.5rem) max(2rem,env(safe-area-inset-right,0px)) clamp(5rem,11vw,10rem) max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--ch-projects-fg);--secondary-text:var(--ch-projects-muted);--card-bg:var(--ch-projects-card);--card-bg-rgb:var(--ch-projects-card-rgb);--border-color:var(--ch-projects-border);--border-subtle:var(--ch-projects-border-subtle);--border-oklab:var(--ch-projects-border);--button-hover-text:var(--ch-projects-button-hover);--color-accent-orange:var(--ch-projects-accent);--article-item-border-hover:var(--ch-projects-article-hover-bd)}html[data-design=clickhouse] #projects .section-title{color:var(--ch-projects-title)}html[data-design=clickhouse] #projects .section-title:after{background:#faff69}html[data-design=clickhouse] #projects .section{background:var(--ch-projects-section-bg);border:1px solid var(--ch-projects-section-bd);box-shadow:var(--ch-projects-section-sh)}html[data-design=clickhouse] #projects .project-card-wrapper{border:none;box-shadow:var(--ch-projects-card-sh)}html[data-design=clickhouse] #contact.section-container{background:var(--ch-contact-band);box-sizing:border-box;color:var(--ch-footer-fg);margin-bottom:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(2.5rem,6vw,4rem) max(2rem,env(safe-area-inset-right,0px)) 0 max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--ch-footer-fg);--secondary-text:var(--ch-projects-muted)}html[data-design=clickhouse] #contact .footer{background:transparent;border:none;box-shadow:none;color:var(--ch-footer-fg);margin-top:0;padding-bottom:clamp(4rem,10vw,7rem);padding-top:clamp(2.5rem,6vw,4rem)}html[data-design=clickhouse] #contact .footer .section-title{color:var(--ch-footer-title)}html[data-design=clickhouse] #contact .footer .section-title:after{background:#faff69}html[data-design=clickhouse] #contact .footer .beian-link{color:var(--ch-beian)}html[data-design=clickhouse] #contact .footer .beian-link:focus-visible,html[data-design=clickhouse] #contact .footer .beian-link:hover{color:var(--ch-beian-hover)}html[data-design=clickhouse] #contact .contact-link{background:var(--ch-contact-chip-bg);border:1px solid var(--ch-contact-chip-bd);border-radius:4px;box-shadow:var(--shadow-elevated-sm)}html[data-design=clickhouse] #contact .contact-link:hover{border-color:var(--ch-contact-chip-hover-bd);color:var(--ch-contact-chip-hover-fg)}html[data-design=clickhouse] .design-theme-select-label,html[data-design=clickhouse] .design-theme-select-wrap{color:var(--text-color)}html[data-design=clickhouse] .design-theme-select-value{color:inherit}html[data-design=clickhouse] .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,var(--ch-shimmer-mid) 18%,var(--card-bg) 33%)}html[data-design=clickhouse].dark-theme{color-scheme:dark;--bg-color:#000;--card-bg:#141414;--card-bg-rgb:20,20,20;--text-color:#fff;--secondary-text:#a0a0a0;--color-surface-100:#141414;--color-surface-200:#0a0a0a;--color-surface-300:#101010;--color-surface-400:#3a3a3a;--color-surface-500:#242424;--border-color:rgba(65,65,65,.8);--border-oklab:rgba(65,65,65,.8);--border-oklab-medium:#343434;--border-section-on-dark:rgba(250,255,105,.06);--nav-scrolled-surface:rgba(0,0,0,.88);--nav-scrolled-shadow:none;--nav-scrolled-divider:rgba(65,65,65,.8);--ch-nav-fg:hsla(0,0%,100%,.94);--ch-nav-hover:#faff69;--ch-nav-bar-bg:rgba(0,0,0,.88);--ch-hamburger:hsla(0,0%,100%,.92);--ch-hero-h1:#fff;--ch-hero-h2:#a0a0a0;--ch-hero-p:#a0a0a0;--ch-section-title:#fff;--ch-focus-ring:#faff69;--ch-explore-hover-bg:#3a3a3a;--ch-explore-hover-fg:hsla(0,0%,100%,.8);--ch-explore-shadow:none;--ch-btt-bg:#141414;--ch-btt-fg:#faff69;--ch-btt-bd:rgba(65,65,65,.8);--ch-btt-shadow:inset rgba(0,0,0,.14) 0px 4px 25px;--ch-btt-hover-bg:#3a3a3a;--ch-btt-hover-fg:#faff69;--ch-btt-hover-bd:#faff69;--ch-skill-bg:#141414;--ch-skill-fg:#fff;--ch-skill-bd:rgba(65,65,65,.8);--ch-skill-hover-fg:#faff69;--ch-skill-active-bg:#0a0a0a;--ch-skill-active-fg:#f4f692;--ch-skill-active-bd:#faff69;--ch-skill-active-shadow:inset rgba(0,0,0,.2) 0px 4px 12px;--ch-art-bg:transparent;--ch-art-fg:#fff;--ch-art-hover-fg:#faff69;--ch-art-hover-bd:#faff69;--ch-article-nav-bg:rgba(0,0,0,.88);--ch-article-nav-bd:rgba(65,65,65,.8);--ch-article-nav-sh:none;--ch-section-fill:hsla(0,0%,8%,.35);--ch-section-bd:rgba(65,65,65,.8);--ch-section-sh:rgba(0,0,0,.1) 0px 1px 3px,rgba(0,0,0,.1) 0px 1px 2px -1px;--ch-projects-band:#000;--ch-projects-fg:#fff;--ch-projects-muted:#a0a0a0;--ch-projects-card:#141414;--ch-projects-card-rgb:20,20,20;--ch-projects-border:rgba(65,65,65,.8);--ch-projects-border-subtle:rgba(65,65,65,.8);--ch-projects-button-hover:#f4f692;--ch-projects-article-hover-bd:rgba(250,255,105,.5);--ch-projects-accent:#faff69;--ch-projects-title:#fff;--ch-projects-section-bg:#141414;--ch-projects-section-sh:rgba(0,0,0,.35) 0px 8px 24px;--ch-projects-section-bd:rgba(65,65,65,.8);--ch-projects-card-sh:rgba(0,0,0,.35) 0px 6px 20px;--ch-contact-band:#000;--ch-footer-fg:#fff;--ch-footer-title:#fff;--ch-beian:#faff69;--ch-beian-hover:#f4f692;--ch-contact-chip-bg:#141414;--ch-contact-chip-bd:rgba(65,65,65,.8);--ch-contact-chip-hover-bd:#faff69;--ch-contact-chip-hover-fg:#faff69;--ch-dts-accent:#faff69;--ch-dts-fg:#fff;--ch-dts-bg:#141414;--ch-dts-bd:rgba(65,65,65,.8);--ch-dts-inset:inset rgba(0,0,0,.12) 0px 2px 6px;--ch-dts-hover-bg:#3a3a3a;--ch-dts-hover-bd:#faff69;--ch-dts-focus:#faff69;--ch-dts-fv-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--ch-dts-panel-bg:#000;--ch-dts-panel-bd:rgba(65,65,65,.8);--ch-dts-panel-sh:rgba(0,0,0,.45) 0px 12px 32px;--ch-dts-opt-hov-bg:#141414;--ch-dts-opt-hov-fg:#faff69;--ch-dts-opt-sel-bg:rgba(250,255,105,.12);--ch-dts-opt-sel-fg:#faff69;--ch-dts-opt-sel-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--ch-dts-opt-dis-fg:#a0a0a0;--ch-dts-opt-dis-op:.55;--ch-dts-nav-wrap-fg:#fff;--ch-dts-nav-fg:#fff;--ch-dts-nav-bd:rgba(250,255,105,.35);--ch-dts-nav-hov-bd:#faff69;--ch-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23faff69' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--ch-selection-bg:rgba(250,255,105,.28);--ch-back-home-hov-bg:#3a3a3a;--ch-back-home-hov-fg:hsla(0,0%,100%,.85);--ch-article-btt-bg:#141414;--ch-article-btt-fg:#faff69;--ch-article-btt-bd:rgba(65,65,65,.8);--ch-article-btt-sh:none;--ch-article-btt-inset:inset rgba(0,0,0,.14) 0px 4px 20px;--ch-article-btt-hov-bg:#3a3a3a;--ch-article-btt-hov-fg:#faff69;--ch-article-btt-hov-bd:#faff69;--ch-shimmer-mid:#1f1f1f;--color-cursor-dark:#fff;--color-accent-orange:#faff69;--color-link:#faff69;--color-link-on-dark:#faff69;--color-error:#ef4444;--color-success:#166534;--accent:#faff69;--accent-bright:#faff69;--accent-deep:#e8f04a;--accent-muted:rgba(250,255,105,.12);--accent-rgb:250,255,105;--highlight:rgba(250,255,105,.14);--highlight-soft:rgba(250,255,105,.08);--gradient-primary:linear-gradient(180deg,#faff69,#faff69);--gradient-primary-soft:linear-gradient(180deg,rgba(250,255,105,.85),rgba(250,255,105,.85));--header-bg:#000;--footer-bg:#000;--shadow-color:rgba(0,0,0,.4);--shadow-hover:rgba(0,0,0,.45);--shadow-section:rgba(0,0,0,.35) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.35) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.4) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.45) 0px 12px 36px;--surface-drawer:#0a0a0a;--surface-drawer-shadow:-4px 0 28px rgba(0,0,0,.6);--chrome-on-hero-bg:hsla(0,0%,100%,.08);--chrome-on-hero-border:rgba(250,255,105,.35);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.12);--chrome-on-hero-border-hover:#faff69;--text-on-accent:#151515;--text-on-dark-pure:#fff;--surface-article-nav:rgba(0,0,0,.88);--theme-switch-track:#2a2a2a;--theme-switch-track-active:#faff69;--theme-switch-knob:#fff;--theme-switch-knob-on:#151515;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.4);--theme-sun-core:#faff69;--theme-moon-ring:rgba(250,255,105,.45);--scrollbar-track:#141414;--scrollbar-thumb:rgba(250,255,105,.28);--scrollbar-thumb-hover:rgba(250,255,105,.45);--scroll-indicator-color:rgba(250,255,105,.55);--scroll-indicator-shadow:rgba(0,0,0,.5);--hero-body-text-on-light:#a0a0a0;--hero-body-text:#a0a0a0;--hero-body-text-strong:#fff;--explore-button-bg:#166534;--text-emphasis-ink:#fff;--code-block-bg:#0a0a0a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.06);--cta-glass-border:rgba(65,65,65,.8);--cta-glass-hover-bg:hsla(0,0%,100%,.1);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:rgba(65,65,65,.8);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.45) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#141414;--contact-chip-border:rgba(65,65,65,.8);--contact-chip-hover-bg:#3a3a3a;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(250,255,105,.2);--contact-chip-bg-dark:#141414;--contact-chip-hover-bg-dark:#3a3a3a;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(250,255,105,.55);--button-hover-text:#f4f692;--tech-tag-muted:#a0a0a0;--border-subtle:rgba(65,65,65,.8)}html[data-design=clickhouse].dark-theme .header{--text-color:#fff;--secondary-text:#a0a0a0;--hero-body-text-on-light:#a0a0a0}@media(prefers-contrast:more){html[data-design=clickhouse]{--border-color:#0f0f0f;--border-oklab:#0f0f0f}html[data-design=clickhouse].dark-theme{--border-color:rgba(250,255,105,.55);--border-oklab:rgba(250,255,105,.55)}}@media(max-width:768px){html[data-design=clickhouse] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=clickhouse] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;box-shadow:none;color:ButtonText;min-height:unset;padding:.2rem .45rem}html[data-design=clickhouse] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=clickhouse] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=clickhouse] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=clickhouse] .design-theme-select-option{color:ButtonText}html[data-design=clickhouse] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=coinbase]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--bg-color:hsla(0,0%,97%,.92);--card-bg:#fff;--card-bg-rgb:255,255,255;--text-color:#0a0b0d;--secondary-text:#5b616e;--color-surface-100:#fff;--color-surface-200:#eef0f3;--color-surface-300:#e8eaed;--color-surface-400:#dfe2e6;--color-surface-500:#d4d8dd;--border-color:rgba(91,97,110,.2);--border-oklab:rgba(91,97,110,.2);--border-oklab-medium:rgba(91,97,110,.32);--border-subtle:rgba(10,11,13,.08);--border-section-on-dark:rgba(0,82,255,.12);--nav-scrolled-surface:hsla(0,0%,100%,.96);--nav-scrolled-shadow:0 4px 24px rgba(10,11,13,.06);--nav-scrolled-divider:rgba(91,97,110,.2);--font-display:"Inter",system-ui,-apple-system,"Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:var(--font-display);--font-mono:"Inconsolata",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--text-xs:.8125rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.65rem,3.5vw,2.25rem);--text-hero:clamp(2.5rem,9vw,5rem);--leading-none:1;--leading-tight:1.11;--leading-snug:1.33;--leading-body:1.56;--leading-relaxed:1.65;--tracking-display-hero:-.03em;--tracking-section:-.02em;--tracking-tighter:-.03em;--tracking-tight:-.015em;--tracking-normal:0;--tracking-wide:.06em;--tracking-wider:.08em;--layout-max-width:min(1200px,92vw);--layout-article-max:min(72rem,1100px);--border-radius:12px;--radius-card:12px;--radius-sm:8px;--transition-speed:.15s;--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--cb-nav-fg:rgba(10,11,13,.92);--cb-nav-hover:#0052ff;--cb-nav-bar-bg:hsla(0,0%,100%,.94);--cb-hamburger:rgba(10,11,13,.88);--cb-hero-h1:#0a0b0d;--cb-hero-h2:#5b616e;--cb-hero-p:#3d424c;--cb-section-title:#0a0b0d;--cb-focus-ring:#0a0b0d;--cb-explore-hover-bg:#578bfa;--cb-explore-hover-fg:#fff;--cb-explore-shadow:var(--shadow-elevated-sm);--cb-btt-bg:#eef0f3;--cb-btt-fg:#0a0b0d;--cb-btt-bd:rgba(91,97,110,.2);--cb-btt-shadow:var(--shadow-elevated-sm);--cb-btt-hover-bg:#578bfa;--cb-btt-hover-fg:#fff;--cb-btt-hover-bd:#578bfa;--cb-skill-bg:#fff;--cb-skill-fg:#0a0b0d;--cb-skill-bd:rgba(91,97,110,.2);--cb-skill-hover-fg:#0052ff;--cb-skill-active-bg:#eef0f3;--cb-skill-active-fg:#0052ff;--cb-skill-active-bd:#0052ff;--cb-skill-active-shadow:inset rgba(0,0,0,.06) 0px 2px 8px;--cb-art-bg:#fff;--cb-art-fg:#0a0b0d;--cb-art-hover-fg:#0052ff;--cb-art-hover-bd:#0052ff;--cb-article-nav-bg:hsla(0,0%,100%,.96);--cb-article-nav-bd:rgba(91,97,110,.2);--cb-article-nav-sh:0 1px 0 rgba(91,97,110,.12);--cb-section-fill:#fff;--cb-section-bd:rgba(91,97,110,.2);--cb-section-sh:rgba(0,0,0,.04) 0px 1px 3px;--cb-projects-band:#eef0f3;--cb-projects-fg:#0a0b0d;--cb-projects-muted:#5b616e;--cb-projects-card:#fff;--cb-projects-card-rgb:255,255,255;--cb-projects-border:rgba(91,97,110,.2);--cb-projects-border-subtle:rgba(91,97,110,.12);--cb-projects-button-hover:#0052ff;--cb-projects-article-hover-bd:rgba(0,82,255,.45);--cb-projects-accent:#0052ff;--cb-projects-title:#0a0b0d;--cb-projects-section-bg:#fff;--cb-projects-section-sh:rgba(0,0,0,.06) 0px 8px 24px;--cb-projects-section-bd:rgba(91,97,110,.2);--cb-projects-card-sh:rgba(0,0,0,.05) 0px 6px 20px;--cb-contact-band:#eef0f3;--cb-footer-fg:#0a0b0d;--cb-footer-title:#0a0b0d;--cb-beian:#0667d0;--cb-beian-hover:#0052ff;--cb-contact-chip-bg:#fff;--cb-contact-chip-bd:rgba(91,97,110,.2);--cb-contact-chip-hover-bd:#0052ff;--cb-contact-chip-hover-fg:#0052ff;--cb-dts-accent:#0052ff;--cb-dts-fg:#0a0b0d;--cb-dts-bg:#fff;--cb-dts-bd:rgba(91,97,110,.2);--cb-dts-inset:none;--cb-dts-hover-bg:#eef0f3;--cb-dts-hover-bd:rgba(0,82,255,.35);--cb-dts-focus:#0052ff;--cb-dts-fv-sh:none;--cb-dts-panel-bg:#fff;--cb-dts-panel-bd:rgba(91,97,110,.2);--cb-dts-panel-sh:rgba(0,0,0,.1) 0px 12px 32px;--cb-dts-opt-hov-bg:#eef0f3;--cb-dts-opt-hov-fg:#0052ff;--cb-dts-opt-sel-bg:rgba(0,82,255,.1);--cb-dts-opt-sel-fg:#0052ff;--cb-dts-opt-sel-sh:none;--cb-dts-opt-dis-fg:#a1a1aa;--cb-dts-opt-dis-op:.75;--cb-dts-nav-wrap-fg:#0a0b0d;--cb-dts-nav-fg:#0a0b0d;--cb-dts-nav-bd:rgba(10,11,13,.14);--cb-dts-nav-hov-bd:rgba(0,82,255,.4);--cb-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230052ff' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--cb-selection-bg:rgba(0,82,255,.18);--cb-back-home-hov-bg:#0052ff;--cb-back-home-hov-fg:#fff;--cb-article-btt-bg:#fff;--cb-article-btt-fg:#0052ff;--cb-article-btt-bd:rgba(91,97,110,.2);--cb-article-btt-sh:var(--shadow-elevated-sm);--cb-article-btt-inset:none;--cb-article-btt-hov-bg:#eef0f3;--cb-article-btt-hov-fg:#0052ff;--cb-article-btt-hov-bd:#0052ff;--cb-shimmer-mid:#e4e6eb;--color-cursor-dark:#0a0b0d;--color-accent-orange:#0052ff;--color-link:#0667d0;--color-link-on-dark:#578bfa;--color-error:#ef4444;--color-success:#0d7a5c;--accent:#0052ff;--accent-bright:#578bfa;--accent-deep:#0047e0;--accent-muted:rgba(0,82,255,.12);--accent-rgb:0,82,255;--highlight:rgba(0,82,255,.08);--highlight-soft:rgba(0,82,255,.05);--gradient-primary:linear-gradient(180deg,#0052ff,#578bfa);--gradient-primary-soft:linear-gradient(180deg,rgba(0,82,255,.85),rgba(87,139,250,.85));--header-bg:#fff;--footer-bg:#eef0f3;--shadow-color:rgba(0,0,0,.12);--shadow-hover:rgba(0,0,0,.16);--shadow-section:rgba(0,0,0,.08) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.06) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.1) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.12) 0px 12px 36px;--surface-drawer:#f4f4f6;--surface-drawer-shadow:-4px 0 24px rgba(0,0,0,.12);--chrome-on-hero-bg:hsla(0,0%,100%,.55);--chrome-on-hero-border:rgba(91,97,110,.2);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.78);--chrome-on-hero-border-hover:rgba(0,82,255,.4);--text-on-accent:#fff;--text-on-dark-pure:#0a0b0d;--surface-article-nav:hsla(0,0%,100%,.94);--theme-switch-track:#d4d4d8;--theme-switch-track-active:#0052ff;--theme-switch-knob:#fff;--theme-switch-knob-on:#0a0b0d;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.15);--theme-sun-core:#f59e0b;--theme-moon-ring:rgba(10,11,13,.35);--scrollbar-track:#e8eaed;--scrollbar-thumb:rgba(0,82,255,.35);--scrollbar-thumb-hover:rgba(0,82,255,.5);--scroll-indicator-color:rgba(0,82,255,.45);--scroll-indicator-shadow:rgba(0,0,0,.15);--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:#3d424c;--hero-body-text:#3d424c;--hero-body-text-strong:#0a0b0d;--explore-button-bg:#eef0f3;--text-emphasis-ink:#0a0b0d;--code-block-bg:#1a1a1a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.65);--cta-glass-border:rgba(91,97,110,.2);--cta-glass-hover-bg:hsla(0,0%,100%,.85);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:rgba(91,97,110,.2);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.1) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#fff;--contact-chip-border:rgba(65,65,65,.18);--contact-chip-hover-bg:#f4f4f6;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(0,82,255,.1);--contact-chip-bg-dark:#fff;--contact-chip-hover-bg-dark:#f4f4f6;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(0,82,255,.45);--button-hover-text:#0052ff;--tech-tag-muted:#71717a}html[data-design=coinbase] .header{--text-color:#0a0b0d;--secondary-text:#5b616e;--hero-body-text-on-light:#3d424c}html[data-design=coinbase] .main-nav:before{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--cb-nav-bar-bg);border-bottom:1px solid var(--nav-scrolled-divider);box-shadow:var(--nav-scrolled-shadow);opacity:var(--nav-bg-opacity,0)}html[data-design=coinbase] .main-nav .nav-links a,html[data-design=coinbase] .main-nav .nav-logo,html[data-design=coinbase] .main-nav.scrolled .nav-links a,html[data-design=coinbase] .main-nav.scrolled .nav-logo{color:var(--cb-nav-fg)!important}html[data-design=coinbase] .main-nav .nav-links a:hover{color:var(--cb-nav-hover)!important}html[data-design=coinbase] .main-nav .hamburger span{background-color:var(--cb-hamburger)!important}html[data-design=coinbase] .main-nav .nav-links a.active:after,html[data-design=coinbase] .main-nav .nav-links a:after{background:#0052ff!important}html[data-design=coinbase] .header:before{display:none}html[data-design=coinbase] .name-card h1{color:var(--cb-hero-h1)!important;font-family:var(--font-display);font-weight:400;letter-spacing:var(--tracking-display-hero);line-height:var(--leading-none);text-shadow:none!important}html[data-design=coinbase] .name-card h2{color:var(--cb-hero-h2)!important;font-size:clamp(.875rem,2vw,1rem);font-weight:600;letter-spacing:.02em;text-shadow:none!important;text-transform:none}html[data-design=coinbase] .name-card p{color:var(--cb-hero-p)!important;text-shadow:none!important}html[data-design=coinbase] .section .section-title{color:var(--cb-section-title);font-family:var(--font-display);font-size:clamp(1.35rem,3.2vw,2.25rem);font-weight:400;letter-spacing:var(--tracking-section);line-height:var(--leading-tight);text-transform:none}html[data-design=coinbase] .footer .section-title{color:var(--cb-section-title);font-family:var(--font-display);font-size:clamp(1.35rem,3.2vw,2.25rem);font-weight:400;letter-spacing:var(--tracking-section);text-transform:none}html[data-design=coinbase] .section:hover{box-shadow:var(--shadow-section);transform:none}html[data-design=coinbase] .explore-button{background:#eef0f3!important;border:1px solid #eef0f3!important;border-radius:56px!important;box-shadow:var(--cb-explore-shadow)!important;color:#0a0b0d!important;font-family:var(--font-display);font-weight:600!important;letter-spacing:.01em;padding:14px 28px!important;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease,border-color var(--transition-speed) ease,transform .2s ease}html[data-design=coinbase] .explore-button:hover{background:var(--cb-explore-hover-bg)!important;border-color:var(--cb-explore-hover-bg)!important;color:var(--cb-explore-hover-fg)!important;transform:translate3d(0,-1px,0)}html[data-design=coinbase] .explore-button:active{color:#fff!important}html[data-design=coinbase] .back-to-top-btn{background:var(--cb-btt-bg);border:1px solid var(--cb-btt-bd);box-shadow:var(--cb-btt-shadow);color:var(--cb-btt-fg)}html[data-design=coinbase] .back-to-top-btn:hover{background:var(--cb-btt-hover-bg);border-color:var(--cb-btt-hover-bd);color:var(--cb-btt-hover-fg)}html[data-design=coinbase] .skill-tag{background:var(--cb-skill-bg)!important;border:1px solid var(--cb-skill-bd)!important;border-radius:12px!important;box-shadow:none!important;color:var(--cb-skill-fg)!important;font-family:var(--font-display);font-weight:600!important}html[data-design=coinbase] .skill-tag:hover{border-color:#0052ff!important;color:var(--cb-skill-hover-fg)!important}html[data-design=coinbase] .skill-tag.is-active{background:var(--cb-skill-active-bg)!important;border-color:var(--cb-skill-active-bd)!important;box-shadow:var(--cb-skill-active-shadow)!important;color:var(--cb-skill-active-fg)!important}html[data-design=coinbase] .article-tag{background:var(--cb-art-bg)!important;border:1px solid rgba(91,97,110,.2)!important;border-radius:8px!important;color:var(--cb-art-fg)!important;font-family:var(--font-display);font-size:.875rem!important;font-weight:500!important}html[data-design=coinbase] .article-tag:hover{border-color:var(--cb-art-hover-bd)!important;color:var(--cb-art-hover-fg)!important}html[data-design=coinbase] :focus-visible{box-shadow:none;outline:2px solid var(--cb-focus-ring);outline-offset:2px}html[data-design=coinbase] .article-nav{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--cb-article-nav-bg)!important;border-bottom:1px solid var(--cb-article-nav-bd);box-shadow:var(--cb-article-nav-sh)}html[data-design=coinbase] .article-page .nav-logo{filter:none}html[data-design=coinbase] .article-page .back-home{background:#0052ff;border:1px solid #0047e0;border-radius:56px;box-shadow:var(--shadow-elevated-sm);color:#fff;font-family:var(--font-display);font-weight:600}html[data-design=coinbase] .article-page .back-home:hover{background:var(--cb-back-home-hov-bg);color:var(--cb-back-home-hov-fg)}html[data-design=coinbase] .article-page .back-to-top{background:var(--cb-article-btt-bg);border:1px solid var(--cb-article-btt-bd);border-radius:4px;box-shadow:var(--cb-article-btt-sh),var(--cb-article-btt-inset);color:var(--cb-article-btt-fg)}html[data-design=coinbase] .article-page .back-to-top:hover{background:var(--cb-article-btt-hov-bg);border-color:var(--cb-article-btt-hov-bd);color:var(--cb-article-btt-hov-fg)}html[data-design=coinbase] ::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}html[data-design=coinbase] ::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}html[data-design=coinbase] ::-moz-selection{background-color:var(--cb-selection-bg);color:var(--text-color)}html[data-design=coinbase] ::selection{background-color:var(--cb-selection-bg);color:var(--text-color)}html[data-design=coinbase] .main-nav .nav-links a{font-family:var(--font-display);font-size:.875rem;font-weight:600;letter-spacing:.0875rem;text-transform:uppercase}html[data-design=coinbase] .main-nav.scrolled .nav-links a,html[data-design=coinbase] .main-nav.scrolled .nav-logo{font-weight:600}html[data-design=coinbase] .content-container .section{background:var(--cb-section-fill);border:1px solid var(--cb-section-bd);border-radius:var(--radius-card);box-shadow:var(--cb-section-sh)}html[data-design=coinbase] .footer .section-title:after{background:#0052ff}html[data-design=coinbase] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:600;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=coinbase] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=coinbase] .design-theme-select-value{flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=coinbase] .design-theme-select-label{color:var(--text-color);font-size:.75rem;letter-spacing:.06em;opacity:1;text-transform:uppercase;white-space:nowrap}html[data-design=coinbase] .design-theme-select{accent-color:var(--cb-dts-accent);align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--cb-dts-bg);background-image:var(--cb-chevron);background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--cb-dts-bd);border-radius:4px;box-shadow:var(--cb-dts-inset);box-sizing:border-box;color:var(--cb-dts-fg);cursor:pointer;display:inline-flex;font:inherit;font-size:.9375rem;font-weight:500;justify-content:flex-start;letter-spacing:normal;margin:0;min-height:36px;padding:0 28px 0 12px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=coinbase] .design-theme-select-panel{background-color:var(--cb-dts-panel-bg);border:1px solid var(--cb-dts-panel-bd);border-radius:8px;box-shadow:var(--cb-dts-panel-sh);box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=coinbase] .design-theme-select-option{border-radius:4px;color:var(--cb-dts-fg);cursor:pointer;font-size:.9375rem;font-weight:500;letter-spacing:normal;line-height:1.45;margin:0;padding:.5rem .75rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=coinbase] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=coinbase] .design-theme-select-option:not(.is-disabled):hover{background-color:var(--cb-dts-opt-hov-bg);color:var(--cb-dts-opt-hov-fg)}html[data-design=coinbase] .design-theme-select-option.is-selected{background-color:var(--cb-dts-opt-sel-bg);box-shadow:var(--cb-dts-opt-sel-sh);color:var(--cb-dts-opt-sel-fg)}html[data-design=coinbase] .design-theme-select-option.is-disabled{color:var(--cb-dts-opt-dis-fg);cursor:not-allowed;opacity:var(--cb-dts-opt-dis-op)}html[data-design=coinbase] .design-theme-select:hover{background-color:var(--cb-dts-hover-bg);border-color:var(--cb-dts-hover-bd)}html[data-design=coinbase] .design-theme-select:focus-visible{box-shadow:var(--cb-dts-fv-sh);outline:2px solid var(--cb-dts-focus);outline-offset:2px}html[data-design=coinbase] .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--cb-dts-nav-wrap-fg)}html[data-design=coinbase] .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:var(--cb-chevron);border-color:var(--cb-dts-nav-bd);box-shadow:none;color:var(--cb-dts-nav-fg)}html[data-design=coinbase] .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--cb-dts-nav-hov-bd)}html[data-design=coinbase] #articles.section-container,html[data-design=coinbase] #skills.section-container{position:relative;z-index:1}html[data-design=coinbase] #projects.section-container{background:var(--cb-projects-band);box-sizing:border-box;color:var(--cb-projects-fg);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(3.5rem,8vw,5.5rem) max(2rem,env(safe-area-inset-right,0px)) clamp(5rem,11vw,10rem) max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--cb-projects-fg);--secondary-text:var(--cb-projects-muted);--card-bg:var(--cb-projects-card);--card-bg-rgb:var(--cb-projects-card-rgb);--border-color:var(--cb-projects-border);--border-subtle:var(--cb-projects-border-subtle);--border-oklab:var(--cb-projects-border);--button-hover-text:var(--cb-projects-button-hover);--color-accent-orange:var(--cb-projects-accent);--article-item-border-hover:var(--cb-projects-article-hover-bd)}html[data-design=coinbase] #projects .section-title{color:var(--cb-projects-title)}html[data-design=coinbase] #projects .section-title:after{background:#0052ff}html[data-design=coinbase] #projects .section{background:var(--cb-projects-section-bg);border:1px solid var(--cb-projects-section-bd);box-shadow:var(--cb-projects-section-sh)}html[data-design=coinbase] #projects .project-card-wrapper{border:none;box-shadow:var(--cb-projects-card-sh)}html[data-design=coinbase] #contact.section-container{background:var(--cb-contact-band);box-sizing:border-box;color:var(--cb-footer-fg);margin-bottom:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(2.5rem,6vw,4rem) max(2rem,env(safe-area-inset-right,0px)) 0 max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--cb-footer-fg);--secondary-text:var(--cb-projects-muted)}html[data-design=coinbase] #contact .footer{background:transparent;border:none;box-shadow:none;color:var(--cb-footer-fg);margin-top:0;padding-bottom:clamp(4rem,10vw,7rem);padding-top:clamp(2.5rem,6vw,4rem)}html[data-design=coinbase] #contact .footer .section-title{color:var(--cb-footer-title)}html[data-design=coinbase] #contact .footer .section-title:after{background:#0052ff}html[data-design=coinbase] #contact .footer .beian-link{color:var(--cb-beian)}html[data-design=coinbase] #contact .footer .beian-link:focus-visible,html[data-design=coinbase] #contact .footer .beian-link:hover{color:var(--cb-beian-hover)}html[data-design=coinbase] #contact .contact-link{background:var(--cb-contact-chip-bg);border:1px solid var(--cb-contact-chip-bd);border-radius:4px;box-shadow:var(--shadow-elevated-sm)}html[data-design=coinbase] #contact .contact-link:hover{border-color:var(--cb-contact-chip-hover-bd);color:var(--cb-contact-chip-hover-fg)}html[data-design=coinbase] .design-theme-select-label,html[data-design=coinbase] .design-theme-select-wrap{color:var(--text-color)}html[data-design=coinbase] .design-theme-select-value{color:inherit}html[data-design=coinbase] .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,var(--cb-shimmer-mid) 18%,var(--card-bg) 33%)}html[data-design=coinbase].dark-theme{color-scheme:dark;--bg-color:#0a0b0d;--card-bg:#282b31;--card-bg-rgb:40,43,49;--text-color:#fff;--secondary-text:#c8cdd6;--color-surface-100:#282b31;--color-surface-200:#1a1c21;--color-surface-300:#22252b;--color-surface-400:#32363d;--color-surface-500:#3a3f48;--border-color:hsla(0,0%,100%,.14);--border-oklab:hsla(0,0%,100%,.14);--border-oklab-medium:hsla(0,0%,100%,.22);--border-subtle:hsla(0,0%,100%,.1);--border-section-on-dark:rgba(0,82,255,.2);--nav-scrolled-surface:rgba(10,11,13,.92);--nav-scrolled-shadow:none;--nav-scrolled-divider:hsla(0,0%,100%,.12);--cb-nav-fg:hsla(0,0%,100%,.94);--cb-nav-hover:#578bfa;--cb-nav-bar-bg:rgba(10,11,13,.9);--cb-hamburger:hsla(0,0%,100%,.92);--cb-hero-h1:#fff;--cb-hero-h2:#aeb4c0;--cb-hero-p:#c8cdd6;--cb-section-title:#fff;--cb-focus-ring:#578bfa;--cb-explore-hover-bg:#578bfa;--cb-explore-hover-fg:#fff;--cb-explore-shadow:none;--cb-btt-bg:#282b31;--cb-btt-fg:#fff;--cb-btt-bd:hsla(0,0%,100%,.14);--cb-btt-shadow:inset rgba(0,0,0,.14) 0px 4px 25px;--cb-btt-hover-bg:#32363d;--cb-btt-hover-fg:#fff;--cb-btt-hover-bd:#578bfa;--cb-skill-bg:#282b31;--cb-skill-fg:#fff;--cb-skill-bd:hsla(0,0%,100%,.14);--cb-skill-hover-fg:#578bfa;--cb-skill-active-bg:#1a1c21;--cb-skill-active-fg:#fff;--cb-skill-active-bd:#0052ff;--cb-skill-active-shadow:inset rgba(0,0,0,.2) 0px 4px 12px;--cb-art-bg:transparent;--cb-art-fg:#fff;--cb-art-hover-fg:#578bfa;--cb-art-hover-bd:#578bfa;--cb-article-nav-bg:rgba(10,11,13,.9);--cb-article-nav-bd:hsla(0,0%,100%,.14);--cb-article-nav-sh:none;--cb-section-fill:rgba(40,43,49,.65);--cb-section-bd:hsla(0,0%,100%,.14);--cb-section-sh:rgba(0,0,0,.2) 0px 1px 3px;--cb-projects-band:#0a0b0d;--cb-projects-fg:#fff;--cb-projects-muted:#aeb4c0;--cb-projects-card:#282b31;--cb-projects-card-rgb:40,43,49;--cb-projects-border:hsla(0,0%,100%,.14);--cb-projects-border-subtle:hsla(0,0%,100%,.08);--cb-projects-button-hover:#578bfa;--cb-projects-article-hover-bd:rgba(0,82,255,.5);--cb-projects-accent:#0052ff;--cb-projects-title:#fff;--cb-projects-section-bg:#282b31;--cb-projects-section-sh:rgba(0,0,0,.35) 0px 8px 24px;--cb-projects-section-bd:hsla(0,0%,100%,.14);--cb-projects-card-sh:rgba(0,0,0,.35) 0px 6px 20px;--cb-contact-band:#0a0b0d;--cb-footer-fg:#fff;--cb-footer-title:#fff;--cb-beian:#578bfa;--cb-beian-hover:#fff;--cb-contact-chip-bg:#282b31;--cb-contact-chip-bd:hsla(0,0%,100%,.14);--cb-contact-chip-hover-bd:#578bfa;--cb-contact-chip-hover-fg:#578bfa;--cb-dts-accent:#0052ff;--cb-dts-fg:#fff;--cb-dts-bg:#282b31;--cb-dts-bd:hsla(0,0%,100%,.14);--cb-dts-inset:inset rgba(0,0,0,.12) 0px 2px 6px;--cb-dts-hover-bg:#32363d;--cb-dts-hover-bd:#578bfa;--cb-dts-focus:#578bfa;--cb-dts-fv-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--cb-dts-panel-bg:#0f1012;--cb-dts-panel-bd:hsla(0,0%,100%,.14);--cb-dts-panel-sh:rgba(0,0,0,.45) 0px 12px 32px;--cb-dts-opt-hov-bg:#282b31;--cb-dts-opt-hov-fg:#578bfa;--cb-dts-opt-sel-bg:rgba(0,82,255,.2);--cb-dts-opt-sel-fg:#fff;--cb-dts-opt-sel-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--cb-dts-opt-dis-fg:#8b9099;--cb-dts-opt-dis-op:.55;--cb-dts-nav-wrap-fg:#fff;--cb-dts-nav-fg:#fff;--cb-dts-nav-bd:hsla(0,0%,100%,.2);--cb-dts-nav-hov-bd:#578bfa;--cb-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23578bfa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--cb-selection-bg:rgba(0,82,255,.28);--cb-back-home-hov-bg:#32363d;--cb-back-home-hov-fg:hsla(0,0%,100%,.92);--cb-article-btt-bg:#282b31;--cb-article-btt-fg:#fff;--cb-article-btt-bd:hsla(0,0%,100%,.14);--cb-article-btt-sh:none;--cb-article-btt-inset:inset rgba(0,0,0,.14) 0px 4px 20px;--cb-article-btt-hov-bg:#32363d;--cb-article-btt-hov-fg:#fff;--cb-article-btt-hov-bd:#578bfa;--cb-shimmer-mid:#2a2d33;--color-cursor-dark:#fff;--color-accent-orange:#0052ff;--color-link:#578bfa;--color-link-on-dark:#578bfa;--color-error:#ef4444;--color-success:#3dd68c;--accent:#0052ff;--accent-bright:#578bfa;--accent-deep:#0047e0;--accent-muted:rgba(0,82,255,.2);--accent-rgb:0,82,255;--highlight:rgba(0,82,255,.18);--highlight-soft:rgba(0,82,255,.1);--gradient-primary:linear-gradient(180deg,#0052ff,#578bfa);--gradient-primary-soft:linear-gradient(180deg,rgba(0,82,255,.9),rgba(87,139,250,.9));--header-bg:#0a0b0d;--footer-bg:#0a0b0d;--shadow-color:rgba(0,0,0,.4);--shadow-hover:rgba(0,0,0,.45);--shadow-section:rgba(0,0,0,.35) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.35) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.4) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.45) 0px 12px 36px;--surface-drawer:#0a0a0a;--surface-drawer-shadow:-4px 0 28px rgba(0,0,0,.6);--chrome-on-hero-bg:hsla(0,0%,100%,.08);--chrome-on-hero-border:hsla(0,0%,100%,.18);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.12);--chrome-on-hero-border-hover:#578bfa;--text-on-accent:#fff;--text-on-dark-pure:#fff;--surface-article-nav:rgba(0,0,0,.88);--theme-switch-track:#2a2a2a;--theme-switch-track-active:#0052ff;--theme-switch-knob:#fff;--theme-switch-knob-on:#0a0b0d;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.4);--theme-sun-core:#578bfa;--theme-moon-ring:rgba(87,139,250,.45);--scrollbar-track:#1a1c21;--scrollbar-thumb:rgba(0,82,255,.35);--scrollbar-thumb-hover:rgba(87,139,250,.55);--scroll-indicator-color:rgba(87,139,250,.55);--scroll-indicator-shadow:rgba(0,0,0,.5);--hero-body-text-on-light:#c8cdd6;--hero-body-text:#c8cdd6;--hero-body-text-strong:#fff;--explore-button-bg:#282b31;--text-emphasis-ink:#fff;--code-block-bg:#0a0a0a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.06);--cta-glass-border:hsla(0,0%,100%,.14);--cta-glass-hover-bg:hsla(0,0%,100%,.1);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:hsla(0,0%,100%,.14);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.45) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#282b31;--contact-chip-border:hsla(0,0%,100%,.14);--contact-chip-hover-bg:#32363d;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(0,82,255,.2);--contact-chip-bg-dark:#282b31;--contact-chip-hover-bg-dark:#32363d;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(87,139,250,.55);--button-hover-text:#578bfa;--tech-tag-muted:#8b9099;--border-subtle:hsla(0,0%,100%,.14)}html[data-design=coinbase].dark-theme .header{--text-color:#fff;--secondary-text:#c8cdd6;--hero-body-text-on-light:#c8cdd6}@media(prefers-contrast:more){html[data-design=coinbase]{--border-color:#0a0b0d;--border-oklab:#0a0b0d}html[data-design=coinbase].dark-theme{--border-color:hsla(0,0%,100%,.55);--border-oklab:hsla(0,0%,100%,.55)}}@media(max-width:768px){html[data-design=coinbase] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=coinbase] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;box-shadow:none;color:ButtonText;min-height:unset;padding:.2rem .45rem}html[data-design=coinbase] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=coinbase] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=coinbase] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=coinbase] .design-theme-select-option{color:ButtonText}html[data-design=coinbase] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=composio]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--bg-color:rgba(228,230,235,.96);--card-bg:#f0f2f6;--card-bg-rgb:240,242,246;--text-color:#0f0f0f;--secondary-text:#444;--color-surface-100:#f5f6f8;--color-surface-200:#e4e6eb;--color-surface-300:#dcdfe5;--color-surface-400:#cfd3db;--color-surface-500:#c2c6cf;--border-color:hsla(0,0%,6%,.12);--border-oklab:hsla(0,0%,6%,.12);--border-oklab-medium:hsla(0,0%,6%,.22);--border-subtle:hsla(0,0%,6%,.08);--border-section-on-dark:rgba(0,7,205,.12);--nav-scrolled-surface:rgba(245,246,248,.96);--nav-scrolled-shadow:0 4px 24px hsla(0,0%,6%,.08);--nav-scrolled-divider:hsla(0,0%,6%,.12);--font-display:"Space Grotesk","DM Sans",ui-sans-serif,system-ui,-apple-system,"Segoe UI","Helvetica Neue",Helvetica,Arial,"PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:var(--font-display);--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;--text-xs:.8125rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.65rem,3.5vw,2.25rem);--text-hero:clamp(2.5rem,9vw,4rem);--leading-none:1;--leading-tight:1;--leading-snug:1.2;--leading-body:1.5;--leading-relaxed:1.63;--tracking-display-hero:-.02em;--tracking-section:-.015em;--tracking-tighter:-.03em;--tracking-tight:-.01em;--tracking-normal:0;--tracking-wide:.06em;--tracking-wider:.08em;--layout-max-width:min(1200px,92vw);--layout-article-max:min(72rem,1100px);--border-radius:4px;--radius-card:4px;--radius-sm:2px;--transition-speed:.15s;--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--cp-nav-fg:rgba(10,11,13,.92);--cp-nav-hover:#0007cd;--cp-nav-bar-bg:rgba(245,246,248,.94);--cp-hamburger:rgba(10,11,13,.88);--cp-hero-h1:#0f0f0f;--cp-hero-h2:#444;--cp-hero-p:#3a3d45;--cp-section-title:#0f0f0f;--cp-focus-ring:#0089ff;--cp-explore-hover-bg:#e4e4e8;--cp-explore-hover-fg:#0c0e12;--cp-explore-shadow:rgba(0,0,0,.15) 4px 4px 0 0;--cp-btt-bg:#e4e6eb;--cp-btt-fg:#0f0f0f;--cp-btt-bd:hsla(0,0%,6%,.12);--cp-btt-shadow:var(--shadow-elevated-sm);--cp-btt-hover-bg:#0089ff;--cp-btt-hover-fg:#fff;--cp-btt-hover-bd:#0089ff;--cp-skill-bg:#fff;--cp-skill-fg:#0f0f0f;--cp-skill-bd:hsla(0,0%,6%,.12);--cp-skill-hover-fg:#0007cd;--cp-skill-active-bg:#e4e6eb;--cp-skill-active-fg:#0007cd;--cp-skill-active-bd:#0007cd;--cp-skill-active-shadow:inset rgba(0,0,0,.06) 0px 2px 8px;--cp-art-bg:#fff;--cp-art-fg:#0f0f0f;--cp-art-hover-fg:#0007cd;--cp-art-hover-bd:#0007cd;--cp-article-nav-bg:hsla(0,0%,100%,.96);--cp-article-nav-bd:hsla(0,0%,6%,.12);--cp-article-nav-sh:0 1px 0 hsla(0,0%,6%,.1);--cp-section-fill:#fff;--cp-section-bd:hsla(0,0%,6%,.12);--cp-section-sh:rgba(0,0,0,.04) 0px 1px 3px;--cp-projects-band:#e4e6eb;--cp-projects-fg:#0f0f0f;--cp-projects-muted:#444;--cp-projects-card:#fff;--cp-projects-card-rgb:255,255,255;--cp-projects-border:hsla(0,0%,6%,.12);--cp-projects-border-subtle:hsla(0,0%,6%,.1);--cp-projects-button-hover:#0007cd;--cp-projects-article-hover-bd:rgba(0,7,205,.45);--cp-projects-accent:#0007cd;--cp-projects-title:#0f0f0f;--cp-projects-section-bg:#fff;--cp-projects-section-sh:rgba(0,0,0,.06) 0px 8px 24px;--cp-projects-section-bd:hsla(0,0%,6%,.12);--cp-projects-card-sh:rgba(0,0,0,.05) 0px 6px 20px;--cp-contact-band:#e4e6eb;--cp-footer-fg:#0f0f0f;--cp-footer-title:#0f0f0f;--cp-beian:#0007cd;--cp-beian-hover:#0007cd;--cp-contact-chip-bg:#fff;--cp-contact-chip-bd:hsla(0,0%,6%,.12);--cp-contact-chip-hover-bd:#0007cd;--cp-contact-chip-hover-fg:#0007cd;--cp-dts-accent:#0007cd;--cp-dts-fg:#0f0f0f;--cp-dts-bg:#fff;--cp-dts-bd:hsla(0,0%,6%,.12);--cp-dts-inset:none;--cp-dts-hover-bg:#e4e6eb;--cp-dts-hover-bd:rgba(0,7,205,.35);--cp-dts-focus:#0007cd;--cp-dts-fv-sh:none;--cp-dts-panel-bg:#fff;--cp-dts-panel-bd:hsla(0,0%,6%,.12);--cp-dts-panel-sh:rgba(0,0,0,.1) 0px 12px 32px;--cp-dts-opt-hov-bg:#e4e6eb;--cp-dts-opt-hov-fg:#0007cd;--cp-dts-opt-sel-bg:rgba(0,7,205,.1);--cp-dts-opt-sel-fg:#0007cd;--cp-dts-opt-sel-sh:none;--cp-dts-opt-dis-fg:#a1a1aa;--cp-dts-opt-dis-op:.75;--cp-dts-nav-wrap-fg:#0f0f0f;--cp-dts-nav-fg:#0f0f0f;--cp-dts-nav-bd:rgba(10,11,13,.14);--cp-dts-nav-hov-bd:rgba(0,7,205,.4);--cp-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230007cd' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--cp-selection-bg:rgba(0,7,205,.18);--cp-back-home-hov-bg:#0007cd;--cp-back-home-hov-fg:#fff;--cp-article-btt-bg:#fff;--cp-article-btt-fg:#0007cd;--cp-article-btt-bd:hsla(0,0%,6%,.12);--cp-article-btt-sh:var(--shadow-elevated-sm);--cp-article-btt-inset:none;--cp-article-btt-hov-bg:#e4e6eb;--cp-article-btt-hov-fg:#0007cd;--cp-article-btt-hov-bd:#0007cd;--cp-shimmer-mid:#e4e6eb;--color-cursor-dark:#0f0f0f;--color-accent-orange:#0007cd;--color-link:#0007cd;--color-link-on-dark:#0089ff;--color-error:#ef4444;--color-success:#0d7a5c;--accent:#0007cd;--accent-bright:#0089ff;--accent-deep:#0005a0;--accent-muted:rgba(0,7,205,.12);--accent-rgb:0,7,205;--highlight:rgba(0,7,205,.08);--highlight-soft:rgba(0,7,205,.05);--gradient-primary:linear-gradient(180deg,#0007cd,#0089ff);--gradient-primary-soft:linear-gradient(180deg,rgba(0,7,205,.85),rgba(0,137,255,.85));--header-bg:#fff;--footer-bg:#e4e6eb;--shadow-color:rgba(0,0,0,.12);--shadow-hover:rgba(0,0,0,.16);--shadow-section:rgba(0,0,0,.08) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.06) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.1) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.12) 0px 12px 36px;--surface-drawer:#f4f4f6;--surface-drawer-shadow:-4px 0 24px rgba(0,0,0,.12);--chrome-on-hero-bg:hsla(0,0%,100%,.55);--chrome-on-hero-border:hsla(0,0%,6%,.16);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.78);--chrome-on-hero-border-hover:rgba(0,7,205,.4);--text-on-accent:#fff;--text-on-dark-pure:#0f0f0f;--surface-article-nav:hsla(0,0%,100%,.94);--theme-switch-track:#d4d4d8;--theme-switch-track-active:#0007cd;--theme-switch-knob:#fff;--theme-switch-knob-on:#0f0f0f;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.15);--theme-sun-core:#f59e0b;--theme-moon-ring:rgba(10,11,13,.35);--scrollbar-track:#e8eaed;--scrollbar-thumb:rgba(0,7,205,.35);--scrollbar-thumb-hover:rgba(0,7,205,.5);--scroll-indicator-color:rgba(0,7,205,.45);--scroll-indicator-shadow:rgba(0,0,0,.15);--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:#3d424c;--hero-body-text:#3d424c;--hero-body-text-strong:#0f0f0f;--explore-button-bg:#e4e6eb;--text-emphasis-ink:#0f0f0f;--code-block-bg:#1a1a1a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.65);--cta-glass-border:hsla(0,0%,6%,.12);--cta-glass-hover-bg:hsla(0,0%,100%,.85);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:hsla(0,0%,6%,.12);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.1) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#fff;--contact-chip-border:rgba(65,65,65,.18);--contact-chip-hover-bg:#f4f4f6;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(0,7,205,.1);--contact-chip-bg-dark:#fff;--contact-chip-hover-bg-dark:#f4f4f6;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(0,7,205,.45);--button-hover-text:#0007cd;--tech-tag-muted:#71717a}html[data-design=composio] .header{--text-color:#0f0f0f;--secondary-text:#444;--hero-body-text-on-light:#3d424c}html[data-design=composio] .main-nav:before{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--cp-nav-bar-bg);border-bottom:1px solid var(--nav-scrolled-divider);box-shadow:var(--nav-scrolled-shadow);opacity:var(--nav-bg-opacity,0)}html[data-design=composio] .main-nav .nav-links a,html[data-design=composio] .main-nav .nav-logo,html[data-design=composio] .main-nav.scrolled .nav-links a,html[data-design=composio] .main-nav.scrolled .nav-logo{color:var(--cp-nav-fg)!important}html[data-design=composio] .main-nav .nav-links a:hover{color:var(--cp-nav-hover)!important}html[data-design=composio] .main-nav .hamburger span{background-color:var(--cp-hamburger)!important}html[data-design=composio] .main-nav .nav-links a.active:after,html[data-design=composio] .main-nav .nav-links a:after{background:#0007cd!important}html[data-design=composio] .header:before{display:none}html[data-design=composio] .name-card h1{color:var(--cp-hero-h1)!important;font-family:var(--font-display);font-weight:400;letter-spacing:var(--tracking-display-hero);line-height:.87;text-shadow:none!important}html[data-design=composio] .name-card h2{color:var(--cp-hero-h2)!important;font-size:clamp(.875rem,2vw,1rem);font-weight:400;letter-spacing:.01em;text-shadow:none!important;text-transform:none}html[data-design=composio] .name-card p{color:var(--cp-hero-p)!important;text-shadow:none!important}html[data-design=composio] .section .section-title,html[data-design=composio] .footer .section-title{color:var(--cp-section-title);font-family:var(--font-display);font-size:clamp(1.35rem,3.2vw,2.25rem);font-weight:400;letter-spacing:var(--tracking-section);line-height:1;text-transform:none}html[data-design=composio] .section:hover{box-shadow:var(--shadow-section);transform:none}html[data-design=composio] .explore-button{background:#fff!important;border:1px solid hsla(0,0%,6%,.08)!important;border-radius:4px!important;box-shadow:var(--cp-explore-shadow)!important;color:#0c0e12!important;font-family:var(--font-display);font-weight:400!important;letter-spacing:0;padding:10px 24px!important;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease,border-color var(--transition-speed) ease,transform .2s ease,box-shadow var(--transition-speed) ease}html[data-design=composio] .explore-button:hover{background:var(--cp-explore-hover-bg)!important;border-color:transparent!important;box-shadow:4px 5px #0000001f!important;color:var(--cp-explore-hover-fg)!important;transform:translate3d(0,-1px,0)}html[data-design=composio] .explore-button:active{color:#0c0e12!important}html[data-design=composio] .back-to-top-btn{background:var(--cp-btt-bg);border:1px solid var(--cp-btt-bd);box-shadow:var(--cp-btt-shadow);color:var(--cp-btt-fg)}html[data-design=composio] .back-to-top-btn:hover{background:var(--cp-btt-hover-bg);border-color:var(--cp-btt-hover-bd);color:var(--cp-btt-hover-fg)}html[data-design=composio] .skill-tag{background:var(--cp-skill-bg)!important;border:1px solid var(--cp-skill-bd)!important;border-radius:4px!important;box-shadow:none!important;color:var(--cp-skill-fg)!important;font-family:var(--font-display);font-weight:500!important}html[data-design=composio] .skill-tag:hover{border-color:#0007cd!important;color:var(--cp-skill-hover-fg)!important}html[data-design=composio] .skill-tag.is-active{background:var(--cp-skill-active-bg)!important;border-color:var(--cp-skill-active-bd)!important;box-shadow:var(--cp-skill-active-shadow)!important;color:var(--cp-skill-active-fg)!important}html[data-design=composio] .article-tag{background:var(--cp-art-bg)!important;border:1px solid hsla(0,0%,6%,.12)!important;border-radius:4px!important;color:var(--cp-art-fg)!important;font-family:var(--font-mono);font-size:.8125rem!important;font-weight:400!important;letter-spacing:-.02em}html[data-design=composio] .article-tag:hover{border-color:var(--cp-art-hover-bd)!important;color:var(--cp-art-hover-fg)!important}html[data-design=composio] :focus-visible{box-shadow:none;outline:2px solid var(--cp-focus-ring);outline-offset:2px}html[data-design=composio] .article-nav{backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background-color:var(--cp-article-nav-bg)!important;border-bottom:1px solid var(--cp-article-nav-bd);box-shadow:var(--cp-article-nav-sh)}html[data-design=composio] .article-page .nav-logo{filter:none}html[data-design=composio] .article-page .back-home{background:#0007cd;border:1px solid #0005a0;border-radius:4px;box-shadow:4px 4px #00000026;color:#fff;font-family:var(--font-display);font-weight:400}html[data-design=composio] .article-page .back-home:hover{background:var(--cp-back-home-hov-bg);color:var(--cp-back-home-hov-fg)}html[data-design=composio] .article-page .back-to-top{background:var(--cp-article-btt-bg);border:1px solid var(--cp-article-btt-bd);border-radius:4px;box-shadow:var(--cp-article-btt-sh),var(--cp-article-btt-inset);color:var(--cp-article-btt-fg)}html[data-design=composio] .article-page .back-to-top:hover{background:var(--cp-article-btt-hov-bg);border-color:var(--cp-article-btt-hov-bd);color:var(--cp-article-btt-hov-fg)}html[data-design=composio] ::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}html[data-design=composio] ::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}html[data-design=composio] ::-moz-selection{background-color:var(--cp-selection-bg);color:var(--text-color)}html[data-design=composio] ::selection{background-color:var(--cp-selection-bg);color:var(--text-color)}html[data-design=composio] .main-nav .nav-links a{font-family:var(--font-display);font-size:1rem;font-weight:400;letter-spacing:0;text-transform:none}html[data-design=composio] .main-nav.scrolled .nav-links a,html[data-design=composio] .main-nav.scrolled .nav-logo{font-weight:400}html[data-design=composio] .content-container .section{background:var(--cp-section-fill);border:1px solid var(--cp-section-bd);border-radius:var(--radius-card);box-shadow:var(--cp-section-sh)}html[data-design=composio] .footer .section-title:after{background:#0007cd}html[data-design=composio] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:600;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=composio] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=composio] .design-theme-select-value{flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=composio] .design-theme-select-label{color:var(--text-color);font-size:.75rem;letter-spacing:.06em;opacity:1;text-transform:uppercase;white-space:nowrap}html[data-design=composio] .design-theme-select{accent-color:var(--cp-dts-accent);align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--cp-dts-bg);background-image:var(--cp-chevron);background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--cp-dts-bd);border-radius:4px;box-shadow:var(--cp-dts-inset);box-sizing:border-box;color:var(--cp-dts-fg);cursor:pointer;display:inline-flex;font:inherit;font-size:.9375rem;font-weight:500;justify-content:flex-start;letter-spacing:normal;margin:0;min-height:36px;padding:0 28px 0 12px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=composio] .design-theme-select-panel{background-color:var(--cp-dts-panel-bg);border:1px solid var(--cp-dts-panel-bd);border-radius:8px;box-shadow:var(--cp-dts-panel-sh);box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=composio] .design-theme-select-option{border-radius:4px;color:var(--cp-dts-fg);cursor:pointer;font-size:.9375rem;font-weight:500;letter-spacing:normal;line-height:1.45;margin:0;padding:.5rem .75rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=composio] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=composio] .design-theme-select-option:not(.is-disabled):hover{background-color:var(--cp-dts-opt-hov-bg);color:var(--cp-dts-opt-hov-fg)}html[data-design=composio] .design-theme-select-option.is-selected{background-color:var(--cp-dts-opt-sel-bg);box-shadow:var(--cp-dts-opt-sel-sh);color:var(--cp-dts-opt-sel-fg)}html[data-design=composio] .design-theme-select-option.is-disabled{color:var(--cp-dts-opt-dis-fg);cursor:not-allowed;opacity:var(--cp-dts-opt-dis-op)}html[data-design=composio] .design-theme-select:hover{background-color:var(--cp-dts-hover-bg);border-color:var(--cp-dts-hover-bd)}html[data-design=composio] .design-theme-select:focus-visible{box-shadow:var(--cp-dts-fv-sh);outline:2px solid var(--cp-dts-focus);outline-offset:2px}html[data-design=composio] .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--cp-dts-nav-wrap-fg)}html[data-design=composio] .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:var(--cp-chevron);border-color:var(--cp-dts-nav-bd);box-shadow:none;color:var(--cp-dts-nav-fg)}html[data-design=composio] .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--cp-dts-nav-hov-bd)}html[data-design=composio] #articles.section-container,html[data-design=composio] #skills.section-container{position:relative;z-index:1}html[data-design=composio] #projects.section-container{background:var(--cp-projects-band);box-sizing:border-box;color:var(--cp-projects-fg);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(3.5rem,8vw,5.5rem) max(2rem,env(safe-area-inset-right,0px)) clamp(5rem,11vw,10rem) max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--cp-projects-fg);--secondary-text:var(--cp-projects-muted);--card-bg:var(--cp-projects-card);--card-bg-rgb:var(--cp-projects-card-rgb);--border-color:var(--cp-projects-border);--border-subtle:var(--cp-projects-border-subtle);--border-oklab:var(--cp-projects-border);--button-hover-text:var(--cp-projects-button-hover);--color-accent-orange:var(--cp-projects-accent);--article-item-border-hover:var(--cp-projects-article-hover-bd)}html[data-design=composio] #projects .section-title{color:var(--cp-projects-title)}html[data-design=composio] #projects .section-title:after{background:#0007cd}html[data-design=composio] #projects .section{background:var(--cp-projects-section-bg);border:1px solid var(--cp-projects-section-bd);box-shadow:var(--cp-projects-section-sh)}html[data-design=composio] #projects .project-card-wrapper{border:none;box-shadow:var(--cp-projects-card-sh)}html[data-design=composio] #contact.section-container{background:var(--cp-contact-band);box-sizing:border-box;color:var(--cp-footer-fg);margin-bottom:0!important;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;padding:clamp(2.5rem,6vw,4rem) max(2rem,env(safe-area-inset-right,0px)) 0 max(2rem,env(safe-area-inset-left,0px));width:100vw;--text-color:var(--cp-footer-fg);--secondary-text:var(--cp-projects-muted)}html[data-design=composio] #contact .footer{background:transparent;border:none;box-shadow:none;color:var(--cp-footer-fg);margin-top:0;padding-bottom:clamp(4rem,10vw,7rem);padding-top:clamp(2.5rem,6vw,4rem)}html[data-design=composio] #contact .footer .section-title{color:var(--cp-footer-title)}html[data-design=composio] #contact .footer .section-title:after{background:#0007cd}html[data-design=composio] #contact .footer .beian-link{color:var(--cp-beian)}html[data-design=composio] #contact .footer .beian-link:focus-visible,html[data-design=composio] #contact .footer .beian-link:hover{color:var(--cp-beian-hover)}html[data-design=composio] #contact .contact-link{background:var(--cp-contact-chip-bg);border:1px solid var(--cp-contact-chip-bd);border-radius:4px;box-shadow:var(--shadow-elevated-sm)}html[data-design=composio] #contact .contact-link:hover{border-color:var(--cp-contact-chip-hover-bd);color:var(--cp-contact-chip-hover-fg)}html[data-design=composio] .design-theme-select-label,html[data-design=composio] .design-theme-select-wrap{color:var(--text-color)}html[data-design=composio] .design-theme-select-value{color:inherit}html[data-design=composio] .loading-shimmer{background:linear-gradient(to right,var(--card-bg) 8%,var(--cp-shimmer-mid) 18%,var(--card-bg) 33%)}html[data-design=composio].dark-theme{color-scheme:dark;--bg-color:#0f0f0f;--card-bg:#000;--card-bg-rgb:0,0,0;--text-color:#fff;--secondary-text:hsla(0,0%,100%,.62);--color-surface-100:#000;--color-surface-200:#0a0a0a;--color-surface-300:#121212;--color-surface-400:#161616;--color-surface-500:#2c2c2c;--border-color:hsla(0,0%,100%,.1);--border-oklab:hsla(0,0%,100%,.1);--border-oklab-medium:hsla(0,0%,100%,.16);--border-subtle:hsla(0,0%,100%,.08);--border-section-on-dark:rgba(0,7,205,.22);--nav-scrolled-surface:hsla(0,0%,6%,.94);--nav-scrolled-shadow:none;--nav-scrolled-divider:hsla(0,0%,100%,.08);--cp-nav-fg:hsla(0,0%,100%,.94);--cp-nav-hover:#0089ff;--cp-nav-bar-bg:hsla(0,0%,6%,.92);--cp-hamburger:hsla(0,0%,100%,.92);--cp-hero-h1:#fff;--cp-hero-h2:hsla(0,0%,100%,.55);--cp-hero-p:hsla(0,0%,100%,.62);--cp-section-title:#fff;--cp-focus-ring:#0089ff;--cp-explore-hover-bg:#ececee;--cp-explore-hover-fg:#0c0e12;--cp-explore-shadow:rgba(0,0,0,.15) 4px 4px 0 0;--cp-btt-bg:#000;--cp-btt-fg:#fff;--cp-btt-bd:hsla(0,0%,100%,.1);--cp-btt-shadow:inset rgba(0,0,0,.14) 0px 4px 25px;--cp-btt-hover-bg:#161616;--cp-btt-hover-fg:#fff;--cp-btt-hover-bd:#0089ff;--cp-skill-bg:#000;--cp-skill-fg:#fff;--cp-skill-bd:hsla(0,0%,100%,.1);--cp-skill-hover-fg:#0089ff;--cp-skill-active-bg:#0a0a0a;--cp-skill-active-fg:#fff;--cp-skill-active-bd:#0096ff;--cp-skill-active-shadow:inset rgba(0,0,0,.2) 0px 4px 12px;--cp-art-bg:transparent;--cp-art-fg:#fff;--cp-art-hover-fg:#0089ff;--cp-art-hover-bd:#0089ff;--cp-article-nav-bg:rgba(10,11,13,.9);--cp-article-nav-bd:hsla(0,0%,100%,.1);--cp-article-nav-sh:none;--cp-section-fill:#000;--cp-section-bd:hsla(0,0%,100%,.1);--cp-section-sh:rgba(0,0,0,.35) 0px 8px 28px;--cp-projects-band:#0f0f0f;--cp-projects-fg:#fff;--cp-projects-muted:hsla(0,0%,100%,.58);--cp-projects-card:#000;--cp-projects-card-rgb:0,0,0;--cp-projects-border:hsla(0,0%,100%,.1);--cp-projects-border-subtle:hsla(0,0%,100%,.08);--cp-projects-button-hover:#0089ff;--cp-projects-article-hover-bd:rgba(0,7,205,.5);--cp-projects-accent:#0007cd;--cp-projects-title:#fff;--cp-projects-section-bg:#000;--cp-projects-section-sh:rgba(0,0,0,.35) 0px 8px 24px;--cp-projects-section-bd:hsla(0,0%,100%,.1);--cp-projects-card-sh:rgba(0,0,0,.35) 0px 6px 20px;--cp-contact-band:#0f0f0f;--cp-footer-fg:#fff;--cp-footer-title:#fff;--cp-beian:#0089ff;--cp-beian-hover:#fff;--cp-contact-chip-bg:#000;--cp-contact-chip-bd:hsla(0,0%,100%,.1);--cp-contact-chip-hover-bd:#0089ff;--cp-contact-chip-hover-fg:#0089ff;--cp-dts-accent:#0007cd;--cp-dts-fg:#fff;--cp-dts-bg:#000;--cp-dts-bd:hsla(0,0%,100%,.1);--cp-dts-inset:inset rgba(0,0,0,.12) 0px 2px 6px;--cp-dts-hover-bg:#161616;--cp-dts-hover-bd:#0089ff;--cp-dts-focus:#0089ff;--cp-dts-fv-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--cp-dts-panel-bg:#0f1012;--cp-dts-panel-bd:hsla(0,0%,100%,.1);--cp-dts-panel-sh:rgba(0,0,0,.45) 0px 12px 32px;--cp-dts-opt-hov-bg:#000;--cp-dts-opt-hov-fg:#0089ff;--cp-dts-opt-sel-bg:rgba(0,7,205,.2);--cp-dts-opt-sel-fg:#fff;--cp-dts-opt-sel-sh:inset rgba(0,0,0,.2) 0px 2px 8px;--cp-dts-opt-dis-fg:#8b9099;--cp-dts-opt-dis-op:.55;--cp-dts-nav-wrap-fg:#fff;--cp-dts-nav-fg:#fff;--cp-dts-nav-bd:hsla(0,0%,100%,.2);--cp-dts-nav-hov-bd:#0089ff;--cp-chevron:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230089ff' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");--cp-selection-bg:rgba(0,7,205,.28);--cp-back-home-hov-bg:#161616;--cp-back-home-hov-fg:hsla(0,0%,100%,.92);--cp-article-btt-bg:#000;--cp-article-btt-fg:#fff;--cp-article-btt-bd:hsla(0,0%,100%,.1);--cp-article-btt-sh:none;--cp-article-btt-inset:inset rgba(0,0,0,.14) 0px 4px 20px;--cp-article-btt-hov-bg:#161616;--cp-article-btt-hov-fg:#fff;--cp-article-btt-hov-bd:#0089ff;--cp-shimmer-mid:#2a2d33;--color-cursor-dark:#fff;--color-accent-orange:#0007cd;--color-link:#0089ff;--color-link-on-dark:#0089ff;--color-error:#ef4444;--color-success:#3dd68c;--accent:#0007cd;--accent-bright:#0089ff;--accent-deep:#0005a0;--accent-muted:rgba(0,7,205,.2);--accent-rgb:0,7,205;--highlight:rgba(0,7,205,.18);--highlight-soft:rgba(0,7,205,.1);--gradient-primary:linear-gradient(180deg,#0007cd,#0089ff);--gradient-primary-soft:linear-gradient(180deg,rgba(0,7,205,.9),rgba(0,137,255,.9));--header-bg:#0f0f0f;--footer-bg:#0f0f0f;--shadow-color:rgba(0,0,0,.4);--shadow-hover:rgba(0,0,0,.45);--shadow-section:rgba(0,0,0,.35) 0px 8px 28px;--shadow-elevated-sm:rgba(0,0,0,.35) 0px 2px 8px;--shadow-elevated-md:rgba(0,0,0,.4) 0px 8px 24px;--shadow-elevated-lg:rgba(0,0,0,.45) 0px 12px 36px;--surface-drawer:#0a0a0a;--surface-drawer-shadow:-4px 0 28px rgba(0,0,0,.6);--chrome-on-hero-bg:hsla(0,0%,100%,.08);--chrome-on-hero-border:hsla(0,0%,100%,.18);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.12);--chrome-on-hero-border-hover:#0089ff;--text-on-accent:#fff;--text-on-dark-pure:#fff;--surface-article-nav:rgba(0,0,0,.88);--theme-switch-track:#2a2a2a;--theme-switch-track-active:#0007cd;--theme-switch-knob:#fff;--theme-switch-knob-on:#0f0f0f;--theme-switch-knob-shadow:0 1px 4px rgba(0,0,0,.4);--theme-sun-core:#0089ff;--theme-moon-ring:rgba(0,137,255,.45);--scrollbar-track:#1a1c21;--scrollbar-thumb:rgba(0,7,205,.35);--scrollbar-thumb-hover:rgba(0,137,255,.55);--scroll-indicator-color:rgba(0,137,255,.55);--scroll-indicator-shadow:rgba(0,0,0,.5);--hero-body-text-on-light:#c8cdd6;--hero-body-text:#c8cdd6;--hero-body-text-strong:#fff;--explore-button-bg:#000;--text-emphasis-ink:#fff;--code-block-bg:#0a0a0a;--code-block-fg:#f5f5f5;--cta-glass-bg:hsla(0,0%,100%,.06);--cta-glass-border:hsla(0,0%,100%,.1);--cta-glass-hover-bg:hsla(0,0%,100%,.1);--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:hsla(0,0%,100%,.1);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:rgba(0,0,0,.45) 0px 12px 40px;--shadow-header-underline:none;--contact-chip-bg:#000;--contact-chip-border:hsla(0,0%,100%,.1);--contact-chip-hover-bg:#161616;--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:rgba(0,7,205,.2);--contact-chip-bg-dark:#000;--contact-chip-hover-bg-dark:#161616;--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:rgba(0,137,255,.55);--button-hover-text:#0089ff;--tech-tag-muted:#8b9099;--border-subtle:hsla(0,0%,100%,.1)}html[data-design=composio].dark-theme .header{--text-color:#fff;--secondary-text:#c8cdd6;--hero-body-text-on-light:#c8cdd6}@media(prefers-contrast:more){html[data-design=composio]{--border-color:#0f0f0f;--border-oklab:#0f0f0f}html[data-design=composio].dark-theme{--border-color:hsla(0,0%,100%,.55);--border-oklab:hsla(0,0%,100%,.55)}}@media(max-width:768px){html[data-design=composio] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=composio] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;box-shadow:none;color:ButtonText;min-height:unset;padding:.2rem .45rem}html[data-design=composio] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=composio] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=composio] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=composio] .design-theme-select-option{color:ButtonText}html[data-design=composio] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=mistral]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-mistral-black:#1f1f1f;--color-mistral-ivory:#fffaeb;--color-mistral-cream:#fff0c2;--color-accent-orange:#fa520f;--color-surface-100:#fff;--color-surface-200:#fffaeb;--color-surface-300:#fff0c2;--color-surface-400:#ffe295;--color-surface-500:color-mix(in srgb,#ffa110 35%,#fff0c2);--bg-color:#fffaeb;--card-bg:#fff;--card-bg-rgb:255,255,255;--text-color:#1f1f1f;--secondary-text:#3d3d3d;--accent:#fa520f;--accent-bright:#fb6424;--accent-deep:color-mix(in srgb,#fa520f 72%,#000);--accent-muted:color-mix(in srgb,#fa520f 18%,transparent);--accent-rgb:250,82,15;--highlight:#ffa110;--highlight-soft:color-mix(in srgb,#ffa110 28%,transparent);--gradient-primary:linear-gradient(90deg in srgb,#ffd900,#ffe295 22%,#ffa110 48%,#ff8105 72%,#fb6424 88%,#fa520f);--gradient-primary-soft:linear-gradient(135deg in srgb,color-mix(in srgb,#fa520f 55%,transparent),color-mix(in srgb,#ffd900 40%,transparent));--header-bg:linear-gradient(168deg in srgb,#fffaeb,color-mix(in srgb,#fff0c2 55%,#fffaeb) 45%,color-mix(in srgb,#ffe295 22%,#fffaeb));--footer-bg:linear-gradient(168deg in srgb,#ffa110,#fa520f 38%,#1f1f1f 92%);--shadow-color:rgba(127,99,21,.14);--shadow-hover:rgba(127,99,21,.22);--shadow-section:rgba(127,99,21,.12) -8px 16px 39px,rgba(127,99,21,.09) -28px 52px 58px,rgba(127,99,21,.05) -56px 100px 72px;--shadow-elevated-sm:rgba(127,99,21,.12) -8px 16px 39px;--shadow-elevated-md:rgba(127,99,21,.12) -8px 16px 39px,rgba(127,99,21,.09) -28px 52px 58px;--shadow-elevated-lg:rgba(127,99,21,.12) -8px 16px 39px,rgba(127,99,21,.09) -28px 52px 58px,rgba(127,99,21,.05) -56px 100px 72px;--border-oklab:rgba(127,99,21,.14);--border-oklab-medium:rgba(127,99,21,.22);--border-color:var(--border-oklab);--nav-scrolled-surface:color-mix(in srgb,#fff 92%,#fff0c2);--nav-scrolled-shadow:rgba(127,99,21,.12) -8px 16px 39px;--nav-scrolled-divider:rgba(127,99,21,.12);--surface-drawer:#fff;--surface-drawer-shadow:-6px 0 28px rgba(127,99,21,.12);--chrome-on-hero-bg:rgba(31,31,31,.06);--chrome-on-hero-border:rgba(31,31,31,.12);--chrome-on-hero-bg-hover:rgba(31,31,31,.1);--chrome-on-hero-border-hover:rgba(31,31,31,.18);--text-on-accent:#fff;--text-on-dark-pure:#fff;--surface-article-nav:color-mix(in srgb,var(--card-bg) 90%,transparent);--theme-switch-track:#fff0c2;--theme-switch-track-active:#1f1f1f;--theme-switch-knob:#fff;--theme-switch-knob-on:#fff0c2;--theme-switch-knob-shadow:rgba(127,99,21,.12) -8px 16px 39px;--theme-sun-core:#ffa110;--theme-moon-ring:rgba(31,31,31,.35);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:1280px;--layout-article-max:min(72rem,1100px);--border-radius:2px;--radius-card:2px;--radius-sm:0px;--transition-speed:.15s;--scrollbar-track:#fff0c2;--scrollbar-thumb:rgba(127,99,21,.28);--scrollbar-thumb-hover:rgba(127,99,21,.42);--scroll-indicator-color:rgba(31,31,31,.4);--scroll-indicator-shadow:rgba(255,250,235,.65);--font-display:"Helvetica Neue",Helvetica,Arial,ui-sans-serif,system-ui,-apple-system,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;--font-sans:var(--font-display);--font-body:var(--font-display);--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--text-xs:.875rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.08rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.75rem,3.6vw,3.5rem);--text-hero:clamp(2rem,9.2vw,5.125rem);--leading-none:1;--leading-tight:.95;--leading-snug:1.15;--leading-body:1.5;--leading-relaxed:1.63;--tracking-display-hero:-.025em;--tracking-section:-.01em;--tracking-tighter:-.03em;--tracking-tight:-.015em;--tracking-normal:0;--tracking-wide:.06em;--tracking-wider:.08em;--text-shadow-hero-title:0 2px 28px rgba(127,99,21,.12);--text-shadow-hero-title-strong:0 4px 32px rgba(0,0,0,.35);--text-shadow-hero-sub:0 2px 18px rgba(127,99,21,.08);--text-shadow-hero-sub-strong:0 2px 20px rgba(0,0,0,.28);--text-shadow-hero-body:0 1px 12px rgba(127,99,21,.06);--text-shadow-hero-body-strong:0 2px 14px rgba(0,0,0,.22);--text-shadow-ui-soft:0 1px 3px rgba(127,99,21,.08);--text-shadow-hero-name-on-hero:0 1px 2px hsla(0,0%,100%,.45),0 2px 16px rgba(127,99,21,.08);--text-shadow-hero-tagline-on-hero:0 1px 8px rgba(255,250,235,.5);--text-shadow-hero-body-on-hero:0 1px 6px rgba(255,250,235,.42);--text-shadow-hero-on-light-title:0 1px 0 hsla(0,0%,100%,.35),0 2px 22px rgba(127,99,21,.06);--text-shadow-hero-on-light-sub:0 1px 0 hsla(0,0%,100%,.28);--text-shadow-hero-on-light-body:0 1px 0 hsla(0,0%,100%,.22);--hero-body-text-on-light:color-mix(in srgb,#1f1f1f 62%,#ffa110);--hero-body-text:hsla(0,0%,100%,.82);--hero-body-text-strong:hsla(0,0%,100%,.92);--explore-button-bg:#1f1f1f;--text-emphasis-ink:#1f1f1f;--code-block-bg:#1f1f1f;--code-block-fg:#fff0c2;--border-subtle:rgba(127,99,21,.1);--cta-glass-bg:hsla(0,0%,100%,.4);--cta-glass-border:var(--border-oklab);--cta-glass-hover-bg:hsla(0,0%,100%,.55);--cta-glass-bg-on-dark:hsla(0,0%,100%,.1);--cta-glass-border-on-dark:hsla(0,0%,100%,.2);--cta-glass-hover-on-dark:hsla(0,0%,100%,.16);--shadow-footer-block:rgba(127,99,21,.09) -28px 52px 58px;--shadow-header-underline:rgba(127,99,21,.08) 0px 10px 28px;--contact-chip-bg:rgba(31,31,31,.06);--contact-chip-border:var(--border-oklab);--contact-chip-hover-bg:rgba(31,31,31,.04);--contact-chip-shadow-hover:var(--shadow-elevated-sm);--contact-chip-shimmer-mid:hsla(0,0%,100%,.4);--contact-chip-bg-dark:hsla(0,0%,100%,.08);--contact-chip-hover-bg-dark:hsla(0,0%,100%,.12);--contact-chip-shadow-hover-dark:var(--shadow-elevated-md);--article-item-border-hover:color-mix(in srgb,#fa520f 42%,var(--border-oklab));--button-hover-text:#fb6424}@media(min-width:1024px){html[data-design=mistral]{--tracking-display-hero:-2.05px}}html[data-design=mistral] body:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cfilter id='a'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='4' stitchTiles='stitch' type='fractalNoise'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.55'/%3E%3C/svg%3E");content:"";inset:0;mix-blend-mode:multiply;opacity:.04;pointer-events:none;position:fixed;z-index:0}html[data-design=mistral] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:400;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=mistral] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=mistral] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=mistral] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=mistral] .design-theme-select{accent-color:var(--color-accent-orange);align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--color-surface-300);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231f1f1f' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--border-oklab-medium);border-radius:2px;box-sizing:border-box;color:var(--text-color);color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:.8125rem;font-weight:400;justify-content:flex-start;margin:0;padding:6px 28px 6px 10px;text-align:left;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease,box-shadow var(--transition-speed) ease;width:100%}html[data-design=mistral] .design-theme-select-panel{background-color:var(--color-surface-100);border:1px solid var(--border-oklab-medium);border-radius:2px;box-shadow:var(--shadow-elevated-md);box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=mistral] .design-theme-select-option{border-radius:2px;color:var(--text-color);cursor:pointer;font-size:.8125rem;font-weight:400;line-height:1.35;margin:0;padding:.5rem .65rem;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html[data-design=mistral] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=mistral] .design-theme-select-option:not(.is-disabled):hover{background-color:var(--color-surface-300)}html[data-design=mistral] .design-theme-select-option.is-selected{background-color:color-mix(in srgb,var(--color-accent-orange) 22%,var(--color-surface-100));color:var(--text-color)}html[data-design=mistral] .design-theme-select-option.is-disabled{color:var(--secondary-text);cursor:not-allowed;opacity:1}html[data-design=mistral] .design-theme-select:hover{background-color:color-mix(in srgb,#fff0c2 70%,#fff);border-color:color-mix(in srgb,var(--text-color) 18%,var(--border-oklab-medium))}html[data-design=mistral] .design-theme-select:focus-visible{box-shadow:none;outline:2px solid var(--color-accent-orange);outline-offset:2px}html[data-design=mistral] .header:before{background:radial-gradient(ellipse 72% 58% at 55% 42%,rgba(250,82,15,.09) 0,rgba(255,167,16,.06) 45%,transparent 70%)}html[data-design=mistral] .name-card h1{font-weight:400;line-height:1}html[data-design=mistral] .explore-button{background:#1f1f1f;border:none;border-radius:2px;box-shadow:var(--shadow-elevated-sm);color:#fff;font-weight:400;letter-spacing:var(--tracking-wide);padding:12px 18px;text-transform:uppercase}html[data-design=mistral] .explore-button:hover{background:color-mix(in srgb,#1f1f1f 88%,#fa520f);color:#fff}html[data-design=mistral] .section-title:after{border-radius:0;height:6px}html[data-design=mistral] .skill-tag{background:var(--color-surface-300);border-radius:2px;color:color-mix(in srgb,#1f1f1f 58%,#ffa110);font-size:.8125rem;font-weight:400;letter-spacing:var(--tracking-wide);text-transform:uppercase}html[data-design=mistral] .skill-tag.is-active{color:#1f1f1f}html[data-design=mistral] .article-tag{background:var(--color-surface-300);border-radius:2px;color:color-mix(in srgb,#1f1f1f 58%,#ffa110);font-size:.8125rem;font-weight:400;letter-spacing:.05em;text-transform:uppercase}html[data-design=mistral] .article-item-title,html[data-design=mistral] .nav-links a,html[data-design=mistral] .nav-links a.active{font-weight:400}html[data-design=mistral] .contact-link{border-radius:2px;font-size:.8125rem;font-weight:400;letter-spacing:.05em;text-transform:uppercase}html[data-design=mistral] .back-to-top-btn{border-radius:2px}html[data-design=mistral] .footer{border-color:#fff3;box-shadow:var(--shadow-footer-block);color:#fff}html[data-design=mistral] .footer .section-title{color:#fff;font-size:clamp(1.25rem,2.4vw,1.75rem);letter-spacing:var(--tracking-wider);text-transform:uppercase}html[data-design=mistral] .footer .section-title:after{background:linear-gradient(90deg,#ffd900,#ffe295 22%,#ffa110 48%,#ff8105 72%,#fb6424 88%,#fa520f)}html[data-design=mistral] .footer-copyright{color:#ffffffd1}html[data-design=mistral] .footer .contact-link{background-color:#fff8eb1f;border-color:#fff8eb3d;color:#fff8ebf5}html[data-design=mistral] .footer .contact-link.is-hovering,html[data-design=mistral] .footer .contact-link:hover{background-color:#fff8eb2e;box-shadow:var(--shadow-elevated-sm);color:#fff}html[data-design=mistral] .footer .beian-link{color:#ffffffeb}html[data-design=mistral] .footer .beian-link:focus-visible,html[data-design=mistral] .footer .beian-link:hover{color:#fff}html[data-design=mistral].dark-theme{color-scheme:dark;--bg-color:#1a1712;--card-bg:#242019;--card-bg-rgb:36,32,25;--text-color:#fff8eb;--secondary-text:rgba(255,248,235,.74);--color-surface-100:#242019;--color-surface-200:#1e1b16;--color-surface-300:#2e281f;--color-surface-400:#3a3228;--color-surface-500:#453c30;--accent:#fb6424;--accent-bright:color-mix(in srgb,#fb6424 85%,#fff);--accent-deep:#fa520f;--accent-muted:color-mix(in srgb,#fb6424 22%,transparent);--accent-rgb:251,100,36;--highlight:#ffa110;--highlight-soft:color-mix(in srgb,#ffa110 28%,transparent);--gradient-primary:linear-gradient(90deg in srgb,#ffd900,#ffe295 22%,#ffa110 48%,#ff8105 72%,#fb6424 88%,#fa520f);--gradient-primary-soft:linear-gradient(135deg in srgb,color-mix(in srgb,#fa520f 65%,transparent),color-mix(in srgb,#ffd900 35%,transparent));--header-bg:linear-gradient(168deg in srgb,#12100c,#1a1712 48%,#16130f);--footer-bg:linear-gradient(168deg in srgb,#2a2318,#1f1c17 45%,#14110d);--shadow-color:rgba(0,0,0,.5);--shadow-hover:rgba(127,99,21,.35);--shadow-section:rgba(0,0,0,.4) 0px 22px 56px,rgba(127,99,21,.12) 0px 0px 0px 1px;--shadow-elevated-sm:0 4px 20px rgba(0,0,0,.38);--shadow-elevated-md:0 12px 32px rgba(0,0,0,.48);--shadow-elevated-lg:0 18px 48px rgba(0,0,0,.52);--border-color:rgba(255,248,235,.14);--border-oklab:rgba(255,248,235,.14);--border-oklab-medium:rgba(255,248,235,.22);--nav-scrolled-surface:color-mix(in srgb,var(--card-bg) 94%,#000);--nav-scrolled-shadow:0 4px 28px rgba(0,0,0,.42);--nav-scrolled-divider:rgba(255,248,235,.12);--surface-drawer:#1e1b16;--surface-drawer-shadow:-6px 0 26px rgba(0,0,0,.45);--chrome-on-hero-bg:rgba(255,248,235,.1);--chrome-on-hero-border:rgba(255,248,235,.16);--chrome-on-hero-bg-hover:rgba(255,248,235,.14);--chrome-on-hero-border-hover:rgba(255,248,235,.24);--text-on-accent:#fff8eb;--text-on-dark-pure:#fff;--surface-article-nav:color-mix(in srgb,var(--card-bg) 88%,transparent);--theme-switch-track:#2e281f;--theme-switch-track-active:#fa520f;--theme-switch-knob:#fff8eb;--theme-switch-knob-on:#242019;--theme-switch-knob-shadow:0 2px 12px rgba(0,0,0,.45);--theme-sun-core:#ffa110;--theme-moon-ring:rgba(255,248,235,.85);--scrollbar-track:#1a1712;--scrollbar-thumb:rgba(250,82,15,.45);--scrollbar-thumb-hover:rgba(250,82,15,.62);--scroll-indicator-color:rgba(255,248,235,.55);--scroll-indicator-shadow:rgba(0,0,0,.35);--hero-body-text-on-light:rgba(255,248,235,.78);--hero-body-text:hsla(0,0%,100%,.84);--hero-body-text-strong:hsla(0,0%,100%,.94);--explore-button-bg:#1f1f1f;--border-subtle:rgba(255,248,235,.1);--border-section-on-dark:rgba(255,248,235,.06);--code-block-bg:#14110d;--code-block-fg:#fff0c2;--article-item-border-hover:color-mix(in srgb,#fb6424 48%,var(--border-color));--contact-chip-bg-dark:rgba(255,248,235,.08);--contact-chip-hover-bg-dark:rgba(255,248,235,.12)}html[data-design=mistral].dark-theme body:before{mix-blend-mode:soft-light;opacity:.07}html[data-design=mistral].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=mistral].dark-theme .design-theme-select{background-color:#fff8eb1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff8eb' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:#fff8eb33;color:var(--text-color);color-scheme:dark}html[data-design=mistral].dark-theme .design-theme-select:hover{background-color:#fff8eb24;border-color:#fff8eb47}html[data-design=mistral].dark-theme .design-theme-select-panel{background-color:var(--card-bg);border-color:var(--border-color);box-shadow:var(--shadow-elevated-lg)}html[data-design=mistral].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=mistral].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#fff8eb14}html[data-design=mistral].dark-theme .design-theme-select-option.is-selected{background-color:color-mix(in srgb,#fa520f 30%,var(--card-bg));color:var(--text-color)}html[data-design=mistral].dark-theme .design-theme-select-option.is-disabled{color:#fff8eb85}html[data-design=mistral].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--text-on-dark-pure)}html[data-design=mistral].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:var(--chrome-on-hero-border);color:var(--text-on-dark-pure);color-scheme:dark}html[data-design=mistral].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--chrome-on-hero-border-hover)}html[data-design=mistral].dark-theme .skill-tag{background:#fff8eb14;color:#fff8ebb8}html[data-design=mistral].dark-theme .skill-tag:hover{color:var(--accent-bright)}html[data-design=mistral].dark-theme .skill-tag.is-active{background:#fff8eb1f;color:var(--text-on-dark-pure)}html[data-design=mistral].dark-theme .article-tag{background:#fff8eb1a;color:#fff8ebc7}html[data-design=mistral].dark-theme .article-tag:hover{color:var(--accent-bright)}html[data-design=mistral].dark-theme .footer{border-color:#fff8eb1f;box-shadow:var(--shadow-elevated-sm);color:var(--text-color)}html[data-design=mistral].dark-theme .footer .section-title{color:var(--text-color);text-transform:uppercase}html[data-design=mistral].dark-theme .footer .section-title:after{background:linear-gradient(90deg,#ffd900,#ffe295 22%,#ffa110 48%,#ff8105 72%,#fb6424 88%,#fa520f)}html[data-design=mistral].dark-theme .footer-copyright{color:#fff8ebc2}html[data-design=mistral].dark-theme .footer .beian-link{color:#fff8ebe0}html[data-design=mistral].dark-theme .footer .beian-link:focus-visible,html[data-design=mistral].dark-theme .footer .beian-link:hover{color:var(--text-on-dark-pure)}html[data-design=mistral].dark-theme .explore-button{background:#fff;border:none;color:#1f1f1f}html[data-design=mistral].dark-theme .explore-button:hover{background:#fff0c2;color:#1f1f1f}@media(prefers-contrast:more){html[data-design=mistral]{--shadow-color:rgba(127,99,21,.22);--shadow-hover:rgba(127,99,21,.32);--border-color:rgba(31,31,31,.28);--secondary-text:color-mix(in srgb,#1f1f1f 88%,#ffa110)}html[data-design=mistral].dark-theme{--shadow-color:rgba(255,248,235,.14);--shadow-hover:rgba(255,248,235,.2);--border-color:rgba(255,248,235,.26);--secondary-text:rgba(255,248,235,.88)}}@media(max-width:768px){html[data-design=mistral] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=mistral] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;color:ButtonText;padding:.2rem .45rem}html[data-design=mistral] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=mistral] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=mistral] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=mistral] .design-theme-select-option{color:ButtonText}html[data-design=mistral] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=ollama]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-accent-orange:#000;--color-error:#525252;--color-success:#737373;--color-surface-100:#fff;--color-surface-200:#fafafa;--color-surface-300:#e5e5e5;--color-surface-400:#d4d4d4;--color-surface-500:color-mix(in srgb,#737373 18%,#e5e5e5);--bg-color:#fff;--card-bg:#fafafa;--card-bg-rgb:250,250,250;--text-color:#000;--secondary-text:#737373;--accent:#000;--accent-bright:#262626;--accent-deep:#000;--accent-muted:rgba(0,0,0,.06);--accent-rgb:0,0,0;--highlight:#525252;--highlight-soft:rgba(82,82,82,.18);--gradient-primary:#000;--gradient-primary-soft:#262626;--header-bg:#fff;--footer-bg:#090909;--shadow-color:transparent;--shadow-hover:transparent;--shadow-section:none;--shadow-elevated-sm:none;--shadow-elevated-md:none;--shadow-elevated-lg:none;--border-oklab:#e5e5e5;--border-oklab-medium:#d4d4d4;--border-color:#e5e5e5;--nav-scrolled-surface:#fafafa;--nav-scrolled-shadow:none;--nav-scrolled-divider:#e5e5e5;--surface-drawer:#fff;--surface-drawer-shadow:none;--chrome-on-hero-bg:rgba(0,0,0,.06);--chrome-on-hero-border:rgba(0,0,0,.1);--chrome-on-hero-bg-hover:rgba(0,0,0,.09);--chrome-on-hero-border-hover:rgba(0,0,0,.14);--text-on-accent:#fff;--text-on-dark-pure:#fff;--surface-article-nav:color-mix(in srgb,#fafafa 92%,transparent);--theme-switch-track:#e5e5e5;--theme-switch-track-active:#000;--theme-switch-knob:#fff;--theme-switch-knob-on:#fafafa;--theme-switch-knob-shadow:none;--theme-sun-core:#525252;--theme-moon-ring:rgba(0,0,0,.32);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:1280px;--layout-article-max:min(72rem,1100px);--border-radius:12px;--radius-card:12px;--radius-sm:12px;--transition-speed:.12s;--scrollbar-track:#fafafa;--scrollbar-thumb:rgba(0,0,0,.22);--scrollbar-thumb-hover:rgba(0,0,0,.38);--scroll-indicator-color:rgba(0,0,0,.38);--scroll-indicator-shadow:transparent;--font-display:"SF Pro Rounded",system-ui,-apple-system,"BlinkMacSystemFont","Segoe UI","Helvetica Neue","PingFang SC","Microsoft YaHei",sans-serif;--font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;--font-body:var(--font-sans);--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--text-xs:.875rem;--text-sm:1rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.5rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:clamp(1.75rem,3.6vw,2.25rem);--text-hero:clamp(2.5rem,9vw,3rem);--leading-none:1;--leading-tight:1.11;--leading-snug:1.2;--leading-body:1.5;--leading-relaxed:1.56;--tracking-display-hero:0;--tracking-section:0;--tracking-tighter:-.02em;--tracking-tight:-.01em;--tracking-normal:0;--tracking-wide:0;--tracking-wider:0;--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:#737373;--hero-body-text:hsla(0,0%,100%,.9);--hero-body-text-strong:hsla(0,0%,100%,.96);--explore-button-bg:#000;--text-emphasis-ink:#000;--code-block-bg:#262626;--code-block-fg:#fafafa;--border-subtle:#e5e5e5;--border-section-on-dark:hsla(0,0%,100%,.1);--cta-glass-bg:#fff;--cta-glass-border:#e5e5e5;--cta-glass-hover-bg:#fafafa;--cta-glass-bg-on-dark:hsla(0,0%,100%,.08);--cta-glass-border-on-dark:hsla(0,0%,100%,.14);--cta-glass-hover-on-dark:hsla(0,0%,100%,.12);--shadow-footer-block:none;--shadow-header-underline:none;--contact-chip-bg:rgba(0,0,0,.04);--contact-chip-border:#e5e5e5;--contact-chip-hover-bg:#e5e5e5;--contact-chip-shadow-hover:none;--contact-chip-shimmer-mid:transparent;--contact-chip-bg-dark:hsla(0,0%,100%,.08);--contact-chip-hover-bg-dark:hsla(0,0%,100%,.12);--contact-chip-shadow-hover-dark:none;--article-item-border-hover:#525252;--button-hover-text:#262626;--tech-tag-muted:#737373}html[data-design=ollama] body:before{display:none}html[data-design=ollama] .header:before{background:none;opacity:0}html[data-design=ollama] .name-card h1{font-weight:500}html[data-design=ollama] .name-card h2,html[data-design=ollama] .nav-links a{font-weight:400}html[data-design=ollama] .nav-links a.active,html[data-design=ollama] .nav-logo,html[data-design=ollama] .section-title,html[data-design=ollama] .article-item-title{font-weight:500}html[data-design=ollama] .explore-button{background:#000;border:1px solid #000;border-radius:9999px;box-shadow:none;color:#fff;font-weight:400;padding:10px 24px}html[data-design=ollama] .explore-button:hover{background:#262626;border-color:#262626;box-shadow:none;color:#fff}html[data-design=ollama] .section{box-shadow:none}html[data-design=ollama] .section:hover{border-color:#d4d4d4;box-shadow:none}html[data-design=ollama] .section-title:after{border-radius:12px;height:6px}html[data-design=ollama] .skill-tag{background:#e5e5e5;border:1px solid transparent;border-radius:9999px;color:#262626;font-weight:400}html[data-design=ollama] .skill-tag.is-active{background:#000;color:#fff}html[data-design=ollama] .article-tag{background:#e5e5e5;border-radius:9999px;color:#404040;font-weight:400}html[data-design=ollama] .article-tag:hover{color:#000}html[data-design=ollama] .project-card{border-radius:12px;box-shadow:none}html[data-design=ollama] .back-to-top-btn{border-radius:9999px;box-shadow:none}html[data-design=ollama] .back-to-top-btn:hover{box-shadow:none}html[data-design=ollama] .contact-link{border-radius:9999px;box-shadow:none;font-weight:400}html[data-design=ollama] .footer{border-color:#ffffff24;box-shadow:none;color:#fff}html[data-design=ollama] .footer .section-title{color:#fff}html[data-design=ollama] .footer .section-title:after{background:#fff}html[data-design=ollama] .footer-copyright{color:#a3a3a3}html[data-design=ollama] .footer .contact-link{background-color:#ffffff14;border:1px solid hsla(0,0%,100%,.18);color:#fff}html[data-design=ollama] .footer .contact-link.is-hovering,html[data-design=ollama] .footer .contact-link:hover{background-color:#ffffff1f;border-color:#ffffff42}html[data-design=ollama] .footer .beian-link{color:#ffffffe0}html[data-design=ollama] .footer .beian-link:focus-visible,html[data-design=ollama] .footer .beian-link:hover{color:#fff}html[data-design=ollama] .article-item:hover,html[data-design=ollama] .explore-button:hover,html[data-design=ollama] .section:hover{box-shadow:none!important;transform:none!important}html[data-design=ollama] .back-to-top-btn{box-shadow:none!important}html[data-design=ollama] .back-to-top-btn:hover{box-shadow:none!important;transform:none!important}html[data-design=ollama] .scroll-down-indicator .chevron:after,html[data-design=ollama] .scroll-down-indicator .chevron:before{box-shadow:none}html[data-design=ollama] .theme-toggle:focus-visible{box-shadow:0 0 0 2px #3b82f680}html[data-design=ollama] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.8125rem;font-weight:400;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=ollama] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=ollama] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=ollama] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=ollama] .design-theme-select{accent-color:#000;align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#e5e5e5;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23262626' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;border:1px solid #e5e5e5;border-radius:9999px;box-shadow:none;box-sizing:border-box;color:#262626;color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:.8125rem;font-weight:400;justify-content:flex-start;margin:0;padding:6px 28px 6px 12px;text-align:left;transition:none;width:100%}html[data-design=ollama] .design-theme-select-panel{background-color:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:none;box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=ollama] .design-theme-select-option{border-radius:9999px;color:var(--text-color);cursor:pointer;font-size:.8125rem;font-weight:400;line-height:1.35;margin:0;padding:.5rem .65rem;transition:none}html[data-design=ollama] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=ollama] .design-theme-select-option:not(.is-disabled):hover{background-color:#e5e5e5}html[data-design=ollama] .design-theme-select-option.is-selected{background-color:#e5e5e5;color:#000}html[data-design=ollama] .design-theme-select-option.is-disabled{color:#a3a3a3;cursor:not-allowed;opacity:1}html[data-design=ollama] .design-theme-select:hover{background-color:color-mix(in srgb,#e5e5e5 85%,#000);border-color:#d4d4d4}html[data-design=ollama] .design-theme-select:focus-visible{box-shadow:none;outline:2px solid rgba(59,130,246,.5);outline-offset:2px}html[data-design=ollama].dark-theme{color-scheme:dark;--color-accent-orange:#fafafa;--color-surface-100:#141414;--color-surface-200:#101010;--color-surface-300:#1f1f1f;--color-surface-400:#2a2a2a;--color-surface-500:#333;--bg-color:#090909;--card-bg:#141414;--card-bg-rgb:20,20,20;--text-color:#fafafa;--secondary-text:#b0b0b0;--accent:#fafafa;--accent-bright:#fff;--accent-deep:#e5e5e5;--accent-muted:hsla(0,0%,100%,.08);--accent-rgb:250,250,250;--highlight:#a3a3a3;--highlight-soft:hsla(0,0%,64%,.22);--gradient-primary:#fafafa;--gradient-primary-soft:#e5e5e5;--header-bg:#090909;--footer-bg:#050505;--border-oklab:hsla(0,0%,100%,.12);--border-oklab-medium:hsla(0,0%,100%,.18);--border-color:hsla(0,0%,100%,.12);--nav-scrolled-surface:color-mix(in srgb,var(--card-bg) 92%,#000);--nav-scrolled-shadow:none;--nav-scrolled-divider:hsla(0,0%,100%,.12);--surface-drawer:#101010;--surface-drawer-shadow:none;--surface-article-nav:color-mix(in srgb,var(--card-bg) 88%,transparent);--chrome-on-hero-bg:hsla(0,0%,100%,.08);--chrome-on-hero-border:hsla(0,0%,100%,.14);--chrome-on-hero-bg-hover:hsla(0,0%,100%,.12);--chrome-on-hero-border-hover:hsla(0,0%,100%,.2);--text-on-accent:#fafafa;--text-on-dark-pure:#fff;--theme-switch-track:#2a2a2a;--theme-switch-track-active:#fafafa;--theme-switch-knob:#fff;--theme-switch-knob-on:#141414;--theme-switch-knob-shadow:none;--theme-sun-core:#a3a3a3;--theme-moon-ring:hsla(0,0%,98%,.85);--scrollbar-track:#101010;--scrollbar-thumb:hsla(0,0%,100%,.22);--scrollbar-thumb-hover:hsla(0,0%,100%,.38);--scroll-indicator-color:hsla(0,0%,98%,.45);--scroll-indicator-shadow:transparent;--hero-body-text-on-light:#c8c8c8;--hero-body-text:hsla(0,0%,100%,.9);--hero-body-text-strong:hsla(0,0%,100%,.97);--explore-button-bg:#fafafa;--code-block-bg:#0a0a0a;--code-block-fg:#e5e5e5;--border-subtle:hsla(0,0%,100%,.1);--border-section-on-dark:hsla(0,0%,100%,.08);--article-item-border-hover:hsla(0,0%,100%,.28);--button-hover-text:#fff;--contact-chip-bg-dark:hsla(0,0%,100%,.08);--contact-chip-hover-bg-dark:hsla(0,0%,100%,.12)}html[data-design=ollama].dark-theme .header:before{opacity:0}html[data-design=ollama].dark-theme .explore-button{background:#fafafa;border:1px solid #fafafa;color:#000}html[data-design=ollama].dark-theme .explore-button:hover{background:#e5e5e5;border-color:#e5e5e5;color:#000}html[data-design=ollama].dark-theme .skill-tag{background:#ffffff1a;color:#d0d0d0}html[data-design=ollama].dark-theme .skill-tag.is-active{background:#fafafa;color:#000}html[data-design=ollama].dark-theme .article-tag{background:#ffffff1a;color:#d0d0d0}html[data-design=ollama].dark-theme .article-tag:hover{color:#fff}html[data-design=ollama].dark-theme .section:hover{border-color:#ffffff29}html[data-design=ollama].dark-theme .footer{border-color:#ffffff1f;color:#fafafa}html[data-design=ollama].dark-theme .footer .section-title{color:#fafafa}html[data-design=ollama].dark-theme .footer .section-title:after{background:#fafafa}html[data-design=ollama].dark-theme .footer-copyright{color:#b0b0b0}html[data-design=ollama].dark-theme .footer .beian-link{color:#d0d0d0}html[data-design=ollama].dark-theme .footer .beian-link:focus-visible,html[data-design=ollama].dark-theme .footer .beian-link:hover{color:#fff}html[data-design=ollama].dark-theme .footer .contact-link{background-color:#ffffff14;border:1px solid hsla(0,0%,100%,.16);color:#fafafa}html[data-design=ollama].dark-theme .footer .contact-link.is-hovering,html[data-design=ollama].dark-theme .footer .contact-link:hover{background-color:#ffffff1f;border-color:#ffffff3d}html[data-design=ollama].dark-theme .article-item:hover,html[data-design=ollama].dark-theme .explore-button:hover,html[data-design=ollama].dark-theme .section:hover{box-shadow:none!important;transform:none!important}html[data-design=ollama].dark-theme .back-to-top-btn{box-shadow:none!important}html[data-design=ollama].dark-theme .back-to-top-btn:hover{box-shadow:none!important;transform:none!important}html[data-design=ollama].dark-theme .scroll-down-indicator .chevron:after,html[data-design=ollama].dark-theme .scroll-down-indicator .chevron:before{box-shadow:none}html[data-design=ollama].dark-theme .theme-toggle:focus-visible{box-shadow:0 0 0 2px #3b82f680}html[data-design=ollama].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=ollama].dark-theme .design-theme-select{background-color:#ffffff1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fafafa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid hsla(0,0%,100%,.16);color:#fafafa;color-scheme:dark}html[data-design=ollama].dark-theme .design-theme-select:hover{background-color:#ffffff24;border-color:#ffffff3d}html[data-design=ollama].dark-theme .design-theme-select-panel{background-color:var(--card-bg);border-color:var(--border-color);box-shadow:none}html[data-design=ollama].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=ollama].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#ffffff14}html[data-design=ollama].dark-theme .design-theme-select-option.is-selected{background-color:#ffffff24;color:var(--text-color)}html[data-design=ollama].dark-theme .design-theme-select-option.is-disabled{color:#a3a3a3}html[data-design=ollama].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:var(--text-on-dark-pure)}html[data-design=ollama].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:var(--chrome-on-hero-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border-color:var(--chrome-on-hero-border);color:var(--text-on-dark-pure);color-scheme:dark}html[data-design=ollama].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:var(--chrome-on-hero-bg-hover);border-color:var(--chrome-on-hero-border-hover)}@media(prefers-contrast:more){html[data-design=ollama]{--secondary-text:#525252;--border-color:#d4d4d4;--border-oklab-medium:#525252}html[data-design=ollama].dark-theme{--secondary-text:#d8d8d8;--border-color:hsla(0,0%,100%,.22);--border-oklab-medium:hsla(0,0%,100%,.28)}}@media(max-width:768px){html[data-design=ollama] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=ollama] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;color:ButtonText;padding:.2rem .45rem}html[data-design=ollama] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=ollama] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=ollama] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=ollama] .design-theme-select-option{color:ButtonText}html[data-design=ollama] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}html[data-design=spacex]{color-scheme:light;--breakpoint-xs:380px;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:900px;--breakpoint-xl:1024px;--touch-target-min:44px;--measure-prose:65ch;--measure-tight:40ch;--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-out-quint:cubic-bezier(.22,1,.36,1);--ease-out-expo:cubic-bezier(.16,1,.3,1);--duration-instant:.1s;--duration-fast:165ms;--duration-normal:.26s;--duration-moderate:.4s;--duration-entrance:.72s;--color-accent-orange:#0a0a12;--color-error:#3d3d4c;--color-success:#3d3d4c;--color-surface-100:#e4e4ee;--color-surface-200:#d8d8e4;--color-surface-300:color-mix(in srgb,#e4e4ee 70%,#0a0a12);--color-surface-400:color-mix(in srgb,#f0f0fa 22%,#0a0a12);--color-surface-500:color-mix(in srgb,#0a0a12 12%,#e4e4ee);--bg-color:#d0d0dc;--card-bg:#e4e4ee;--card-bg-rgb:228,228,238;--text-color:#0a0a12;--secondary-text:#3d3d4c;--accent:#0a0a12;--accent-bright:#f0f0fa;--accent-deep:#000;--accent-muted:rgba(10,10,18,.08);--accent-rgb:10,10,18;--highlight:#3d3d4c;--highlight-soft:rgba(61,61,76,.2);--gradient-primary:#f0f0fa;--gradient-primary-soft:#f0f0fa;--header-bg:#000;--footer-bg:#000;--shadow-color:transparent;--shadow-hover:transparent;--shadow-section:none;--shadow-elevated-sm:none;--shadow-elevated-md:none;--shadow-elevated-lg:none;--border-oklab:rgba(10,10,18,.14);--border-oklab-medium:rgba(10,10,18,.22);--border-color:rgba(10,10,18,.12);--nav-scrolled-surface:#050508;--nav-scrolled-shadow:none;--nav-scrolled-divider:rgba(240,240,250,.12);--surface-drawer:#0a0a0f;--surface-drawer-shadow:none;--chrome-on-hero-bg:rgba(240,240,250,.1);--chrome-on-hero-border:rgba(240,240,250,.35);--chrome-on-hero-bg-hover:rgba(240,240,250,.16);--chrome-on-hero-border-hover:rgba(240,240,250,.5);--text-on-accent:#000;--text-on-dark-pure:#f0f0fa;--surface-article-nav:color-mix(in srgb,var(--card-bg) 90%,#000);--theme-switch-track:rgba(10,10,18,.2);--theme-switch-track-active:#0a0a12;--theme-switch-knob:#f0f0fa;--theme-switch-knob-on:#e4e4ee;--theme-switch-knob-shadow:none;--theme-sun-core:#3d3d4c;--theme-moon-ring:rgba(10,10,18,.35);--text-nav-logo:clamp(1.55rem,2.65vw,1.85rem);--layout-max-width:1280px;--layout-article-max:min(72rem,1100px);--border-radius:4px;--radius-card:4px;--radius-sm:4px;--transition-speed:.12s;--scrollbar-track:#d8d8e4;--scrollbar-thumb:rgba(10,10,18,.25);--scrollbar-thumb-hover:rgba(10,10,18,.4);--scroll-indicator-color:rgba(240,240,250,.45);--scroll-indicator-shadow:transparent;--font-display:Barlow Condensed,Arial Narrow,Arial,Verdana,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif;--font-sans:Barlow Condensed,Arial Narrow,Arial,Verdana,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif;--font-body:Barlow Condensed,Arial Narrow,Arial,Verdana,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--text-xs:.625rem;--text-sm:.75rem;--text-base:1rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:clamp(1.5rem,3.2vw,2rem);--text-hero:clamp(2.25rem,8vw,3rem);--leading-none:1;--leading-tight:.94;--leading-snug:1;--leading-body:1.62;--leading-relaxed:1.68;--tracking-display-hero:.96px;--tracking-section:1.17px;--tracking-tighter:.04em;--tracking-tight:.06em;--tracking-normal:.04em;--tracking-wide:.08em;--tracking-wider:.1em;--text-shadow-hero-title:none;--text-shadow-hero-title-strong:none;--text-shadow-hero-sub:none;--text-shadow-hero-sub-strong:none;--text-shadow-hero-body:none;--text-shadow-hero-body-strong:none;--text-shadow-ui-soft:none;--text-shadow-hero-name-on-hero:none;--text-shadow-hero-tagline-on-hero:none;--text-shadow-hero-body-on-hero:none;--text-shadow-hero-on-light-title:none;--text-shadow-hero-on-light-sub:none;--text-shadow-hero-on-light-body:none;--hero-body-text-on-light:rgba(240,240,250,.82);--hero-body-text:rgba(240,240,250,.88);--hero-body-text-strong:#f0f0fa;--explore-button-bg:rgba(240,240,250,.1);--text-emphasis-ink:#0a0a12;--code-block-bg:#12121a;--code-block-fg:#f0f0fa;--border-subtle:rgba(10,10,18,.1);--border-section-on-dark:rgba(240,240,250,.1);--cta-glass-bg:rgba(240,240,250,.1);--cta-glass-border:rgba(240,240,250,.35);--cta-glass-hover-bg:rgba(240,240,250,.16);--cta-glass-bg-on-dark:rgba(240,240,250,.1);--cta-glass-border-on-dark:rgba(240,240,250,.35);--cta-glass-hover-on-dark:rgba(240,240,250,.16);--shadow-footer-block:none;--shadow-header-underline:none;--contact-chip-bg:rgba(10,10,18,.06);--contact-chip-border:rgba(10,10,18,.16);--contact-chip-hover-bg:rgba(10,10,18,.1);--contact-chip-shadow-hover:none;--contact-chip-shimmer-mid:transparent;--contact-chip-bg-dark:rgba(240,240,250,.1);--contact-chip-hover-bg-dark:rgba(240,240,250,.16);--contact-chip-shadow-hover-dark:none;--article-item-border-hover:rgba(10,10,18,.35);--button-hover-text:#f0f0fa;--tech-tag-muted:#3d3d4c}html[data-design=spacex] body:before{display:none}html[data-design=spacex] .header:before{background:linear-gradient(180deg,rgba(0,0,0,.5),transparent 55%,rgba(0,0,0,.5));opacity:.55}html[data-design=spacex] .header,html[data-design=spacex] .name-card h1,html[data-design=spacex] .name-card h2,html[data-design=spacex] .name-card p{text-shadow:none}html[data-design=spacex] .header{color:#f0f0fa}html[data-design=spacex] .name-card h1{color:#f0f0fa;font-weight:700;letter-spacing:var(--tracking-display-hero);text-transform:uppercase}html[data-design=spacex] .name-card h2{color:#f0f0fae0;font-size:.8125rem;font-weight:400;letter-spacing:1.17px;line-height:2;text-transform:uppercase}html[data-design=spacex] .name-card p{color:#f0f0fac7;font-size:.75rem;font-weight:400;letter-spacing:.04em;line-height:1.65;text-transform:uppercase}html[data-design=spacex] .nav-links a{font-family:var(--font-display);font-size:.8125rem;font-weight:700;letter-spacing:1.17px;line-height:.94;text-transform:uppercase}html[data-design=spacex] .nav-links a:not(.active){font-size:.75rem;font-weight:400;letter-spacing:normal;line-height:2}html[data-design=spacex] .nav-links a.active{font-weight:700}html[data-design=spacex] .nav-logo,html[data-design=spacex] .section-title{font-weight:700;letter-spacing:1.17px;text-transform:uppercase}html[data-design=spacex] .article-item-title{font-weight:700;letter-spacing:.06em;text-transform:uppercase}html[data-design=spacex] .header a.explore-button{background:#f0f0fa1a;border:1px solid rgba(240,240,250,.35);border-radius:32px;box-shadow:none;color:#f0f0fa;font-size:.8125rem;font-weight:700;letter-spacing:1.17px;padding:18px 24px;text-transform:uppercase;transform:none}html[data-design=spacex] .header a.explore-button:hover{background:#f0f0fa29;border-color:#f0f0fa80;box-shadow:none;color:#fff;transform:none}html[data-design=spacex] .header a.explore-button:active{transform:none}html[data-design=spacex] .section{background-color:var(--card-bg);border-color:var(--border-color);box-shadow:none}html[data-design=spacex] .section:hover{border-color:#0a0a122e;box-shadow:none}html[data-design=spacex] .section-title:after{background:#f0f0fa;border-radius:4px;height:4px;opacity:.35}html[data-design=spacex] .section:hover .section-title:after{opacity:.55}html[data-design=spacex] .skill-tag{background:#0a0a120f;border:1px solid rgba(10,10,18,.14);border-radius:4px;box-shadow:none;color:#0a0a12;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}html[data-design=spacex] .skill-tag.is-active{background:#0a0a12;border-color:#0a0a12;color:#f0f0fa}html[data-design=spacex] .article-tag{background:#0a0a120f;border:1px solid transparent;border-radius:4px;box-shadow:none;color:#3d3d4c;font-size:.75rem;font-weight:400;letter-spacing:.04em;text-transform:uppercase}html[data-design=spacex] .article-tag:hover{border-color:#0a0a1224;color:#0a0a12}html[data-design=spacex] .project-card{border:1px solid var(--border-color);border-radius:4px;box-shadow:none}html[data-design=spacex] .project-card h3{font-weight:700;letter-spacing:.06em;text-transform:uppercase}html[data-design=spacex] .back-to-top-btn{border:1px solid var(--border-oklab);border-radius:4px;box-shadow:none}html[data-design=spacex] .back-to-top-btn:hover{box-shadow:none}html[data-design=spacex] .contact-link{background:#f0f0fa1a;border:1px solid rgba(10,10,18,.22);border-radius:32px;box-shadow:none;color:#0a0a12;font-weight:700;letter-spacing:.06em;text-transform:uppercase}html[data-design=spacex] .contact-link.is-hovering,html[data-design=spacex] .contact-link:hover{background:#0a0a1214;color:#0a0a12}html[data-design=spacex] .footer{border-color:#f0f0fa24;box-shadow:none;color:#f0f0fa}html[data-design=spacex] .footer .section-title{color:#f0f0fa}html[data-design=spacex] .footer .section-title:after{background:#f0f0fa;opacity:.45}html[data-design=spacex] .footer-copyright{color:#f0f0faa6;font-size:.625rem;letter-spacing:1px;text-transform:uppercase}html[data-design=spacex] .footer .contact-link{background-color:#f0f0fa1a;border:1px solid rgba(240,240,250,.35);color:#f0f0fa}html[data-design=spacex] .footer .contact-link.is-hovering,html[data-design=spacex] .footer .contact-link:hover{background-color:#f0f0fa29;border-color:#f0f0fa80}html[data-design=spacex] .footer .beian-link{color:#f0f0fad1}html[data-design=spacex] .footer .beian-link:focus-visible,html[data-design=spacex] .footer .beian-link:hover{color:#f0f0fa}html[data-design=spacex] .article-item:hover,html[data-design=spacex] .section:hover{box-shadow:none!important;transform:none!important}html[data-design=spacex] .back-to-top-btn{box-shadow:none!important}html[data-design=spacex] .back-to-top-btn:hover{box-shadow:none!important;transform:none!important}html[data-design=spacex] .scroll-down-indicator .chevron:after,html[data-design=spacex] .scroll-down-indicator .chevron:before{box-shadow:none}html[data-design=spacex] .theme-toggle:focus-visible{box-shadow:0 0 0 2px #788cff73}html[data-design=spacex] .main-nav:not(.scrolled) .nav-links a,html[data-design=spacex] .main-nav:not(.scrolled) .nav-logo{color:#f0f0fa}html[data-design=spacex] .main-nav:not(.scrolled) .hamburger span{background-color:#f0f0fa}html[data-design=spacex] .main-nav.scrolled .nav-links a,html[data-design=spacex] .main-nav.scrolled .nav-logo{color:#f0f0fa}html[data-design=spacex] .main-nav.scrolled .hamburger span{background-color:#f0f0fa}html[data-design=spacex] .design-theme-select-wrap{align-items:center;color:var(--text-color);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.75rem;font-weight:700;gap:6px;letter-spacing:1px;text-transform:uppercase;-webkit-user-select:none;-moz-user-select:none;user-select:none}html[data-design=spacex] .design-theme-select-root{display:inline-block;max-width:min(42vw,11rem);min-width:7rem;position:relative;vertical-align:middle}html[data-design=spacex] .design-theme-select-value{color:inherit;flex:1 1 auto;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}html[data-design=spacex] .design-theme-select-label{color:var(--text-color);opacity:1;white-space:nowrap}html[data-design=spacex] .design-theme-select{accent-color:#0a0a12;align-items:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#0a0a1214;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230a0a12' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;border:1px solid rgba(10,10,18,.18);border-radius:32px;box-shadow:none;box-sizing:border-box;color:#0a0a12;color-scheme:light;cursor:pointer;display:inline-flex;font:inherit;font-size:.75rem;font-weight:700;justify-content:flex-start;letter-spacing:1px;margin:0;padding:8px 28px 8px 14px;text-align:left;text-transform:uppercase;transition:background-color var(--transition-speed) ease,border-color var(--transition-speed) ease;width:100%}html[data-design=spacex] .design-theme-select-panel{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;box-shadow:none;box-sizing:border-box;left:0;list-style:none;margin:0;max-height:min(60vh,280px);overflow-x:hidden;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 6px);z-index:12050}html[data-design=spacex] .design-theme-select-option{border-radius:4px;color:var(--text-color);cursor:pointer;font-size:.75rem;font-weight:700;letter-spacing:.06em;line-height:1.35;margin:0;padding:.5rem .65rem;text-transform:uppercase;transition:background-color var(--transition-speed) ease}html[data-design=spacex] .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=spacex] .design-theme-select-option:not(.is-disabled):hover{background-color:#0a0a1214}html[data-design=spacex] .design-theme-select-option.is-selected{background-color:#0a0a121f;color:#0a0a12}html[data-design=spacex] .design-theme-select-option.is-disabled{color:#3d3d4c;cursor:not-allowed;opacity:.65}html[data-design=spacex] .design-theme-select:hover{background-color:#0a0a121f;border-color:#0a0a1242}html[data-design=spacex] .design-theme-select:focus-visible{box-shadow:none;outline:2px solid rgba(120,140,255,.45);outline-offset:2px}html[data-design=spacex] .main-nav:not(.scrolled) .design-theme-select-wrap{color:#f0f0fa}html[data-design=spacex] .main-nav:not(.scrolled) .design-theme-select{background-color:#f0f0fa1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f0f0fa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid rgba(240,240,250,.35);color:#f0f0fa;color-scheme:dark}html[data-design=spacex] .main-nav:not(.scrolled) .design-theme-select:hover{background-color:#f0f0fa29;border-color:#f0f0fa80}html[data-design=spacex] .main-nav.scrolled .design-theme-select-wrap,html[data-design=spacex] .main-nav.scrolled .design-theme-select-label{color:#f0f0fa}html[data-design=spacex] .main-nav.scrolled .design-theme-select{background-color:#f0f0fa1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f0f0fa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid rgba(240,240,250,.35);color:#f0f0fa;color-scheme:dark}html[data-design=spacex] .main-nav.scrolled .design-theme-select:hover{background-color:#f0f0fa29;border-color:#f0f0fa80}html[data-design=spacex] .main-nav.scrolled .theme-toggle{--theme-switch-track:rgba(240,240,250,.26);--theme-switch-track-active:rgba(240,240,250,.4);--theme-switch-knob:#f8f8fc;--theme-switch-knob-on:#12121a;--theme-switch-knob-shadow:none;--theme-sun-core:#3d3d4c;--theme-moon-ring:rgba(240,240,250,.92)}html[data-design=spacex] .main-nav.scrolled .theme-toggle:focus-visible{box-shadow:0 0 0 2px #f0f0fa73}html[data-design=spacex].dark-theme{color-scheme:dark;--color-accent-orange:#f0f0fa;--color-surface-100:#0c0c10;--color-surface-200:#08080c;--color-surface-300:#12121a;--color-surface-400:#1a1a24;--color-surface-500:#22222e;--bg-color:#000;--card-bg:#0a0a0f;--card-bg-rgb:10,10,15;--text-color:#f0f0fa;--secondary-text:rgba(240,240,250,.72);--accent:#f0f0fa;--accent-bright:#fff;--accent-deep:#c8c8d8;--accent-muted:rgba(240,240,250,.08);--accent-rgb:240,240,250;--highlight:rgba(240,240,250,.55);--highlight-soft:rgba(240,240,250,.14);--gradient-primary:#f0f0fa;--gradient-primary-soft:rgba(240,240,250,.65);--header-bg:#000;--footer-bg:#000;--border-oklab:rgba(240,240,250,.14);--border-oklab-medium:rgba(240,240,250,.22);--border-color:rgba(240,240,250,.12);--nav-scrolled-surface:#050508;--nav-scrolled-shadow:none;--nav-scrolled-divider:rgba(240,240,250,.12);--surface-drawer:#0a0a0f;--surface-drawer-shadow:none;--surface-article-nav:color-mix(in srgb,var(--card-bg) 88%,transparent);--chrome-on-hero-bg:rgba(240,240,250,.1);--chrome-on-hero-border:rgba(240,240,250,.35);--chrome-on-hero-bg-hover:rgba(240,240,250,.16);--chrome-on-hero-border-hover:rgba(240,240,250,.5);--text-on-accent:#000;--text-on-dark-pure:#f0f0fa;--theme-switch-track:#2a2a32;--theme-switch-track-active:#f0f0fa;--theme-switch-knob:#f0f0fa;--theme-switch-knob-on:#12121a;--theme-switch-knob-shadow:none;--theme-sun-core:rgba(240,240,250,.55);--theme-moon-ring:rgba(240,240,250,.85);--scrollbar-track:#0a0a0f;--scrollbar-thumb:rgba(240,240,250,.22);--scrollbar-thumb-hover:rgba(240,240,250,.38);--scroll-indicator-color:rgba(240,240,250,.45);--hero-body-text-on-light:rgba(240,240,250,.78);--hero-body-text:rgba(240,240,250,.88);--hero-body-text-strong:#f0f0fa;--explore-button-bg:rgba(240,240,250,.1);--code-block-bg:#050508;--code-block-fg:rgba(240,240,250,.88);--border-subtle:rgba(240,240,250,.1);--border-section-on-dark:rgba(240,240,250,.08);--article-item-border-hover:rgba(240,240,250,.28);--button-hover-text:#fff;--contact-chip-bg-dark:rgba(240,240,250,.1);--contact-chip-hover-bg-dark:rgba(240,240,250,.16);--text-emphasis-ink:#f0f0fa}html[data-design=spacex].dark-theme .header:before{opacity:.5}html[data-design=spacex].dark-theme .skill-tag{background:#f0f0fa1a;border:1px solid rgba(240,240,250,.18);color:#f0f0faeb}html[data-design=spacex].dark-theme .skill-tag.is-active{background:#f0f0fa;border-color:#f0f0fa;color:#000}html[data-design=spacex].dark-theme .article-tag{background:#f0f0fa1a;border:1px solid transparent;color:#f0f0fabf}html[data-design=spacex].dark-theme .article-tag:hover{border-color:#f0f0fa38;color:#f0f0fa}html[data-design=spacex].dark-theme .section:hover{border-color:#f0f0fa29}html[data-design=spacex].dark-theme .contact-link{background:#f0f0fa1a;border:1px solid rgba(240,240,250,.35);color:#f0f0fa}html[data-design=spacex].dark-theme .contact-link.is-hovering,html[data-design=spacex].dark-theme .contact-link:hover{background:#f0f0fa29;border-color:#f0f0fa73;color:#fff}html[data-design=spacex].dark-theme .footer{border-color:#f0f0fa1f;color:#f0f0fa}html[data-design=spacex].dark-theme .footer .section-title{color:#f0f0fa}html[data-design=spacex].dark-theme .footer .section-title:after{background:#f0f0fa}html[data-design=spacex].dark-theme .footer-copyright{color:#f0f0fa9e}html[data-design=spacex].dark-theme .footer .beian-link{color:#f0f0fac7}html[data-design=spacex].dark-theme .footer .beian-link:focus-visible,html[data-design=spacex].dark-theme .footer .beian-link:hover{color:#f0f0fa}html[data-design=spacex].dark-theme .footer .contact-link{background-color:#f0f0fa1a;border:1px solid rgba(240,240,250,.35);color:#f0f0fa}html[data-design=spacex].dark-theme .footer .contact-link.is-hovering,html[data-design=spacex].dark-theme .footer .contact-link:hover{background-color:#f0f0fa29;border-color:#f0f0fa73}html[data-design=spacex].dark-theme .article-item:hover,html[data-design=spacex].dark-theme .section:hover{box-shadow:none!important;transform:none!important}html[data-design=spacex].dark-theme .back-to-top-btn{box-shadow:none!important}html[data-design=spacex].dark-theme .back-to-top-btn:hover{box-shadow:none!important;transform:none!important}html[data-design=spacex].dark-theme .scroll-down-indicator .chevron:after,html[data-design=spacex].dark-theme .scroll-down-indicator .chevron:before{box-shadow:none}html[data-design=spacex].dark-theme .theme-toggle:focus-visible{box-shadow:0 0 0 2px #788cff73}html[data-design=spacex].dark-theme .design-theme-select-option{color:var(--text-color)}html[data-design=spacex].dark-theme .design-theme-select{background-color:#f0f0fa1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f0f0fa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid rgba(240,240,250,.35);color:#f0f0fa;color-scheme:dark}html[data-design=spacex].dark-theme .design-theme-select:hover{background-color:#f0f0fa24;border-color:#f0f0fa66}html[data-design=spacex].dark-theme .design-theme-select-panel{background-color:var(--card-bg);border-color:var(--border-color);box-shadow:none}html[data-design=spacex].dark-theme .design-theme-select-option.is-highlighted:not(.is-disabled),html[data-design=spacex].dark-theme .design-theme-select-option:not(.is-disabled):hover{background-color:#f0f0fa14}html[data-design=spacex].dark-theme .design-theme-select-option.is-selected{background-color:#f0f0fa24;color:var(--text-color)}html[data-design=spacex].dark-theme .design-theme-select-option.is-disabled{color:#f0f0fa73}html[data-design=spacex].dark-theme .design-theme-select-label{color:var(--text-color)}html[data-design=spacex].dark-theme .main-nav:not(.scrolled) .design-theme-select-wrap{color:#f0f0fa}html[data-design=spacex].dark-theme .main-nav:not(.scrolled) .design-theme-select{background-color:#f0f0fa1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23f0f0fa' d='M3 4.5 6 8l3-3.5'/%3E%3C/svg%3E");border:1px solid rgba(240,240,250,.35);color:#f0f0fa;color-scheme:dark}html[data-design=spacex].dark-theme .main-nav:not(.scrolled) .design-theme-select:hover{background-color:#f0f0fa29;border-color:#f0f0fa80}html[data-design=spacex].dark-theme .main-nav.scrolled .nav-links a,html[data-design=spacex].dark-theme .main-nav.scrolled .nav-logo{color:#f0f0fa}html[data-design=spacex].dark-theme .main-nav.scrolled .hamburger span{background-color:#f0f0fa}html[data-design=spacex].dark-theme .header a.explore-button{background:#f0f0fa1a;border:1px solid rgba(240,240,250,.35);box-shadow:none;color:#f0f0fa}html[data-design=spacex].dark-theme .header a.explore-button:hover{background:#f0f0fa29;border-color:#f0f0fa80;box-shadow:none;color:#fff;transform:none}@media(prefers-contrast:more){html[data-design=spacex]{--secondary-text:#1a1a24;--border-color:rgba(10,10,18,.28);--border-oklab-medium:rgba(10,10,18,.35);--hero-body-text-on-light:rgba(240,240,250,.92)}html[data-design=spacex].dark-theme{--secondary-text:rgba(240,240,250,.88);--border-color:rgba(240,240,250,.22);--border-oklab-medium:rgba(240,240,250,.3)}}@media(max-width:768px){html[data-design=spacex] .design-theme-select-label{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}}@media(forced-colors:active){html[data-design=spacex] .design-theme-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background-color:Field;background-image:none;border:1px solid ButtonBorder;color:ButtonText;padding:.2rem .45rem}html[data-design=spacex] .design-theme-select-root{max-width:unset;min-width:unset}html[data-design=spacex] .design-theme-select:focus-visible{outline:2px solid Highlight;outline-offset:2px}html[data-design=spacex] .design-theme-select-panel{background:Field;border:1px solid ButtonBorder}html[data-design=spacex] .design-theme-select-option{color:ButtonText}html[data-design=spacex] .design-theme-select-option.is-highlighted:not(.is-disabled){background:Highlight;color:HighlightText}}@font-face{font-family:iconfont;src:url(iconfont.woff2?t=1746759224452) format("woff2"),url(iconfont.woff?t=1746759224452) format("woff"),url(iconfont.ttf?t=1746759224452) format("truetype")}.iconfont{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.icon-xiangshang:before{content:""}.icon-phone:before{content:""}.icon-email:before{content:""}.icon-github:before{content:""}.icon-chaiquan:before{content:""}.entry-content{background-color:var(--card-bg);box-sizing:border-box;color:var(--text-color);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-relaxed);margin:0 auto;max-width:100%;padding:1.25rem max(1.25rem,env(safe-area-inset-right,0px)) 1.25rem max(1.25rem,env(safe-area-inset-left,0px));width:100%;word-wrap:break-word}.tech-summary-box{background-color:color-mix(in oklch,var(--card-bg) 92%,var(--accent-muted));border-left:4px solid var(--accent-deep);border-radius:var(--border-radius);margin-bottom:2rem;padding:1rem 1.25rem}.tech-summary-box strong{color:var(--text-color);display:block;font-size:var(--text-md);font-weight:700;line-height:var(--leading-snug);margin-bottom:.5rem}.tech-summary-box p{color:var(--secondary-text);font-size:var(--text-sm);line-height:var(--leading-body);margin:0}.entry-content h2{border-bottom:1px solid var(--border-color);font-size:var(--text-2xl);letter-spacing:var(--tracking-section);line-height:var(--leading-tight);margin-bottom:.75em;margin-top:2.25em;padding-bottom:.5rem}.entry-content h2,.entry-content h3{color:var(--text-color);font-family:var(--font-display);font-weight:400}.entry-content h3{font-size:var(--text-xl);letter-spacing:-.11px;line-height:var(--leading-snug);margin-bottom:.65em;margin-top:1.75em}.entry-content p{margin-bottom:1.5em;text-align:justify;text-justify:inter-ideograph}.entry-content strong{color:var(--text-color);font-weight:700}.entry-content a{border-bottom:1px dashed color-mix(in oklch,var(--accent-deep) 55%,transparent);color:var(--accent-deep);text-decoration:none;transition:color .2s ease,border-color .2s ease}.entry-content a:hover{border-bottom-color:var(--accent-bright);border-bottom-style:solid;color:var(--accent-bright)}.entry-content ol,.entry-content ul{margin-bottom:1.5em;padding-left:1.35rem}.entry-content li{line-height:var(--leading-relaxed);margin-bottom:.5em}.entry-content pre{background:var(--code-block-bg);border-radius:var(--border-radius);box-shadow:0 4px 12px var(--shadow-color);color:var(--code-block-fg);font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--leading-snug);margin:1.5em 0;overflow-x:auto;padding:1.25rem;scrollbar-color:hsla(50,13%,91%,.35) hsla(0,0%,100%,.06);scrollbar-width:thin}.entry-content pre::-webkit-scrollbar{height:5px;width:5px}.entry-content pre::-webkit-scrollbar-track{background:#ffffff0f;border-radius:3px}.entry-content pre::-webkit-scrollbar-thumb{background:#ebeae547;border-radius:3px}.entry-content pre::-webkit-scrollbar-thumb:hover{background:#ebeae56b}.dark-theme .entry-content pre{scrollbar-color:rgba(245,78,0,.45) hsla(0,0%,100%,.05)}.dark-theme .entry-content pre::-webkit-scrollbar-thumb{background:#f54e006b}.dark-theme .entry-content pre::-webkit-scrollbar-thumb:hover{background:#f54e0094}.entry-content code{font-family:var(--font-mono);font-size:var(--text-sm)}.entry-content li code,.entry-content p code{background-color:color-mix(in oklch,var(--accent-muted) 40%,var(--card-bg));border-radius:4px;color:var(--accent-deep);margin:0 2px;padding:.15em .4em}.entry-content blockquote{background-color:color-mix(in oklch,var(--card-bg) 88%,var(--secondary-text));border-left:4px solid color-mix(in oklch,var(--accent) 35%,var(--border-color));color:var(--secondary-text);font-style:italic;line-height:var(--leading-body);margin:1.5em 0;padding:.75rem 1.25rem}.dark-theme .entry-content{background-color:transparent}.dark-theme .tech-summary-box{background-color:color-mix(in oklch,var(--card-bg) 96%,var(--accent-muted));border-left-color:var(--accent-bright)}.dark-theme .entry-content li code,.dark-theme .entry-content p code{background-color:color-mix(in oklch,var(--card-bg) 75%,var(--accent));color:var(--accent-bright)}
