@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.hidden{display:none}.inline{display:inline}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#fafaf7;--bg-subtle:#f4f4ef;--bg-muted:#edede6;--fg:#0a0a0a;--fg-muted:#525252;--fg-subtle:#737373;--fg-faint:#a3a3a3;--border:#e5e5e0;--border-strong:#d4d4ce;--accent:#1f4dba;--accent-hover:#173b91;--accent-bg:#eef2fb;--success:#15803d;--success-bg:#edf7ee;--warning:#b45309;--warning-bg:#fbf1e5;--danger:#b91c1c;--danger-bg:#fbecec;--code-bg:#f4f4ef;--code-fg:#0a0a0a;--font-sans:"IBM Plex Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--radius-full:9999px;--ease:cubic-bezier(.4, 0, .2, 1);--dur-fast:.1s;--dur-base:.15s;--dur-slow:.4s;--focus-ring:0 0 0 2px var(--bg), 0 0 0 4px var(--accent)}[data-theme=dark]{--bg:#0a0a0a;--bg-subtle:#141414;--bg-muted:#1f1f1f;--fg:#fafaf7;--fg-muted:#a3a3a3;--fg-subtle:#8a8a8a;--fg-faint:#525252;--border:#262626;--border-strong:#3a3a3a;--accent:#6b8fe0;--accent-hover:#8aaaeb;--accent-bg:#14213d;--code-bg:#141414;--code-fg:#fafaf7}*{box-sizing:border-box}html,body{font-family:var(--font-sans);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;transition:background .25s var(--ease),color .25s var(--ease);line-height:1.65}body{margin:0;font-size:15px}h1,h2,h3,h4{letter-spacing:-.02em;margin:0;line-height:1.15}p{margin:0}a{color:var(--fg);text-decoration:underline;-webkit-text-decoration-color:var(--border-strong);text-decoration-color:var(--border-strong);text-underline-offset:4px;transition:text-decoration-color var(--dur-base) var(--ease)}a:hover{-webkit-text-decoration-color:var(--fg);text-decoration-color:var(--fg)}code{font-family:var(--font-mono);background:var(--code-bg);border-radius:var(--radius-sm);color:var(--code-fg);padding:.15em .4em;font-size:.92em}pre{font-family:var(--font-mono);background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-size:13px;line-height:1.5;overflow-x:auto}pre code{font-size:inherit;background:0 0;padding:0}::selection{background:var(--accent);color:var(--bg)}:focus-visible{box-shadow:var(--focus-ring);border-radius:var(--radius-sm);outline:none}.container{max-width:1100px;margin:0 auto;padding:0 32px}.container.narrow{max-width:720px}.meta-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-subtle);font-size:11px;font-weight:500}.wordmark{letter-spacing:-.02em;color:var(--fg);white-space:nowrap;align-items:center;gap:4px;font-weight:600;text-decoration:none;display:inline-flex}.wordmark-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;margin-bottom:2px;display:inline-block}.btn{font-family:var(--font-sans);white-space:nowrap;cursor:pointer;transition:all .15s var(--ease);border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:9px 16px;font-size:13px;font-weight:500;line-height:1.2;text-decoration:none;display:inline-flex}.btn-primary{color:#fafaf7;background:#0a0a0a}.btn-primary:hover{background:#262626}[data-theme=dark] .btn-primary{color:#0a0a0a;background:#fafaf7}[data-theme=dark] .btn-primary:hover{background:#e5e5e0}.btn-accent{background:var(--accent);color:#fafaf7}.btn-accent:hover{background:var(--accent-hover)}.btn-secondary{color:var(--fg);border-color:var(--border-strong);background:0 0}.btn-secondary:hover{border-color:var(--fg)}.btn-ghost{color:var(--fg);background:0 0}.btn-ghost:hover{background:var(--bg-muted)}.btn-danger{background:var(--danger);color:#fafaf7}.btn-danger:hover{background:#8b1414}.badge{font-family:var(--font-mono);letter-spacing:.05em;border-radius:9999px;align-items:center;gap:5px;padding:3px 9px;font-size:10.5px;font-weight:500;line-height:1.5;display:inline-flex}.badge-outline{border:1px solid var(--border-strong);color:var(--fg-muted);background:0 0}.badge-solid{color:#fafaf7;background:#0a0a0a}.badge-accent{background:var(--accent-bg);color:var(--accent)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.header{z-index:50;background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.header{background:color-mix(in srgb,var(--bg) 88%,transparent)}}.header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.header-inner{align-items:center;gap:32px;max-width:1100px;margin:0 auto;padding:14px 32px;display:flex}.header-brand{font-size:15px;text-decoration:none}.header-nav{gap:22px;margin-left:24px;display:flex}.header-nav a{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--fg-muted);transition:color .15s var(--ease);font-size:12px;text-decoration:none}.header-nav a:hover,.header-nav a.is-active{color:var(--fg)}.header-actions{align-items:center;gap:14px;margin-left:auto;display:flex}.header-icon-btn{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--fg-muted);transition:all .15s var(--ease);background:0 0;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.header-icon-btn:hover{color:var(--fg);border-color:var(--border-strong)}.header-lang{font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.05em;align-items:center;gap:6px;font-size:11px;display:flex}.header-lang button{font:inherit;color:inherit;cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;padding:0}.header-lang button.active{color:var(--fg);font-weight:600}.hero{border-bottom:1px solid var(--border);padding:96px 32px 80px;position:relative;overflow:hidden}.network-bg{pointer-events:none;z-index:0;width:100%;height:100%;color:var(--fg);position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 100% 0,#000 0%,#0000 70%);mask-image:radial-gradient(at 100% 0,#000,#0000 70%)}.hero-inner{z-index:1;max-width:1100px;margin:0 auto;position:relative}.hero-status{font-family:var(--font-mono);letter-spacing:.08em;color:var(--fg-muted);align-items:center;gap:8px;margin-bottom:32px;font-size:11px;display:inline-flex}.status-dot{background:var(--success);border-radius:50%;width:7px;height:7px;position:relative}.status-dot:after{content:"";background:var(--success);animation:pulse 2s var(--ease) infinite;border-radius:50%;position:absolute;inset:0}@keyframes pulse{50%{opacity:.5}}.hero-title{letter-spacing:-.025em;text-wrap:balance;max-width:900px;margin:0 0 24px;font-size:clamp(36px,5vw,64px);font-weight:600;line-height:1.05}.hero-lead{color:var(--fg-muted);max-width:640px;margin:0 0 32px;font-size:18px;line-height:1.6}.hero-lead strong{color:var(--fg);font-weight:600}.hero-cta{flex-wrap:wrap;gap:12px;margin-bottom:56px;display:flex}.hero-stack{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding-top:24px;display:flex}.hero-stack .meta-label{margin-right:8px}.section{border-bottom:1px solid var(--border);padding:80px 32px}.section-head{flex-direction:column;gap:8px;max-width:1100px;margin:0 auto 40px;display:flex}.section-label{font-family:var(--font-mono);letter-spacing:.08em;color:var(--fg-subtle);font-size:11px}.section-title{letter-spacing:-.02em;text-wrap:balance;margin:0;font-size:32px;font-weight:600}.section-kicker{color:var(--fg-muted);max-width:560px;margin:0;font-size:16px}.section-body{max-width:1100px;margin:0 auto}.about-stack{flex-direction:column;gap:56px;display:flex}.about-block-label{font-family:var(--font-mono);letter-spacing:.08em;color:var(--fg-subtle);text-transform:uppercase;margin:0 0 20px;font-size:11px}.edu-card{border:1px solid var(--border);background:var(--bg-subtle);border-radius:14px;flex-direction:column;gap:16px;margin-bottom:16px;padding:24px;display:flex}.edu-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.edu-school{color:var(--fg);margin:0 0 4px;font-size:18px;font-weight:600}.edu-degree{color:var(--fg-muted);margin:0;font-size:14px}.edu-period{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.edu-desc{color:var(--fg-muted);max-width:720px;margin:0;font-size:14px;line-height:1.6}.edu-courses{flex-direction:column;gap:8px;display:flex}.edu-courses-list{flex-wrap:wrap;gap:6px;display:flex}.exp-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.exp-item{grid-template-columns:24px 1fr;gap:20px;padding-bottom:32px;display:grid}.exp-item:last-child{padding-bottom:0}.exp-rail{flex-direction:column;align-items:center;display:flex;position:relative}.exp-dot{background:var(--fg);border-radius:50%;width:9px;height:9px;margin-top:8px}.exp-line{background:var(--border);flex:1;width:1px;margin-top:8px}.exp-body{flex-direction:column;gap:14px;padding-bottom:8px;display:flex}.exp-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.exp-position{color:var(--fg);margin:0 0 4px;font-size:16px;font-weight:600}.exp-company{color:var(--fg-muted);font-size:14px;font-family:var(--font-mono);margin:0}.exp-meta{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.exp-loc{font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.05em;align-items:center;gap:4px;font-size:11px;display:inline-flex}.exp-bullets{max-width:760px;margin:0;padding-left:18px}.exp-bullets li{color:var(--fg);margin-bottom:6px;font-size:14.5px;line-height:1.65}.projects-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.project-card{border:1px solid var(--border);cursor:pointer;background:var(--bg);transition:all .2s var(--ease);color:inherit;border-radius:14px;flex-direction:column;gap:10px;padding:20px;text-decoration:none;display:flex;position:relative}.project-card:hover{border-color:var(--fg);transform:translateY(-2px)}.project-card:hover .project-open{color:var(--fg)}.project-meta{font-family:var(--font-mono);letter-spacing:.05em;color:var(--fg-subtle);text-transform:uppercase;align-items:center;gap:10px;font-size:11px;display:flex}.status{font-family:var(--font-mono);letter-spacing:.05em;border-radius:9999px;align-items:center;gap:6px;padding:3px 9px;font-size:10.5px;font-weight:500;display:inline-flex}.status-success{background:var(--success-bg);color:var(--success)}.status-outline{border:1px solid var(--border-strong);color:var(--fg-muted);background:0 0}.project-name{font-family:var(--font-mono);color:var(--fg);margin:0;font-size:17px;font-weight:500}.project-desc{color:var(--fg-muted);flex:1;margin:0;font-size:14px;line-height:1.55}.project-tags{flex-wrap:wrap;gap:6px;display:flex}.project-open{color:var(--fg-faint);transition:color .15s var(--ease);position:absolute;top:18px;right:18px}.articles{flex-direction:column;display:flex}.article-row{border-top:1px solid var(--border);color:inherit;transition:background .15s var(--ease);grid-template-columns:80px 1fr auto;align-items:start;gap:24px;padding:18px 0;text-decoration:none;display:grid}.article-row:last-child{border-bottom:1px solid var(--border)}.article-row:hover{background:var(--bg-subtle);margin:0 -12px;padding-left:12px;padding-right:12px}.article-date{font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.02em;padding-top:3px;font-size:12px}.article-body h3{color:var(--fg);margin:0 0 4px;font-size:16px;font-weight:600}.article-body p{color:var(--fg-muted);margin:0;font-size:13.5px}.article-meta{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.article-tag{font-family:var(--font-mono);border:1px solid var(--border-strong);color:var(--fg-muted);letter-spacing:.05em;border-radius:9999px;padding:3px 9px;font-size:10px}.article-read{font-family:var(--font-mono);color:var(--fg-subtle);font-size:11px}.filter-row{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-bottom:24px;padding-bottom:24px;display:flex}.filter-chip{font-family:var(--font-mono);letter-spacing:.06em;border:1px solid var(--border);color:var(--fg-muted);cursor:pointer;transition:all .15s var(--ease);background:0 0;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:11px;text-decoration:none;display:inline-flex}.filter-chip:hover{border-color:var(--fg);color:var(--fg)}.filter-chip.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.filter-count{opacity:.6;font-variant-numeric:tabular-nums;font-size:10px}.empty-state{text-align:center;color:var(--fg-subtle);font-family:var(--font-mono);padding:40px 0;font-size:13px}.contact-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.contact-link{border:1px solid var(--border);color:var(--fg);transition:border-color .15s var(--ease);border-radius:12px;align-items:center;gap:14px;padding:16px 18px;font-size:14px;text-decoration:none;display:flex}.contact-link:hover{border-color:var(--fg)}.contact-link span{font-family:var(--font-mono);flex:1;font-size:13px}.contact-link svg:last-child{color:var(--fg-faint)}.footer{border-top:1px solid var(--border);padding:24px 32px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1100px;margin:0 auto;display:flex}.footer-left,.footer-right{color:var(--fg-subtle);align-items:center;gap:12px;display:flex}.footer .meta{font-family:var(--font-mono);letter-spacing:.05em;font-size:11px}.see-all{border-top:1px solid var(--border);justify-content:center;margin-top:40px;padding-top:24px;display:flex}.project-detail,.article-detail{padding:48px 0 96px}.project-detail .container{max-width:1000px}.article-detail{padding:0}.back-link{font-family:var(--font-mono);letter-spacing:.05em;color:var(--fg-muted);cursor:pointer;background:0 0;border:none;margin-bottom:32px;padding:0;font-size:12px;text-decoration:none;display:inline-block}.back-link:hover{color:var(--fg)}.detail-head{border-bottom:1px solid var(--border);margin-bottom:48px;padding-bottom:32px}.meta-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.detail-title{font-family:var(--font-mono);letter-spacing:-.01em;margin:0 0 16px;font-size:32px;font-weight:500}.detail-lead{color:var(--fg-muted);max-width:720px;margin:0;font-size:18px}.detail-actions{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.detail-grid{grid-template-columns:200px 1fr;gap:48px;display:grid}.detail-toc{align-self:start;position:sticky;top:80px}.detail-toc ol{counter-reset:toc;margin:12px 0 0;padding:0;list-style:none}.detail-toc ol li{counter-increment:toc;padding:4px 0;font-size:13px}.detail-toc ol li:before{content:counter(toc,decimal-leading-zero) " · ";font-family:var(--font-mono);color:var(--fg-faint);margin-right:4px}.detail-toc a{color:var(--fg-muted);text-decoration:none}.detail-toc a:hover{color:var(--fg)}.detail-content h2{font-family:var(--font-sans);margin:40px 0 12px;font-size:22px;font-weight:600}.detail-content p,.article-body-text p{margin:0 0 16px;font-size:16px;line-height:1.75}.detail-content pre,.article-body-text pre{background:var(--code-bg);border:1px solid var(--border);font-family:var(--font-mono);border-radius:12px;margin:0 0 16px;padding:16px 18px;font-size:13px;line-height:1.6;overflow-x:auto}.lessons{padding-left:20px}.lessons li{margin-bottom:8px;line-height:1.6}.article-detail-grid{grid-template-columns:200px 1fr;gap:32px;max-width:1400px;margin:0 auto;padding:40px 16px 96px;display:grid}.article-toc{flex-direction:column;align-self:start;gap:16px;display:flex;position:sticky;top:80px}.article-toc .back-link{margin-bottom:8px}.article-toc ol{counter-reset:toc;margin:8px 0 0;padding:0;list-style:none}.article-toc ol li{counter-increment:toc;padding:6px 0;font-size:13px}.article-toc ol li:before{content:counter(toc,decimal-leading-zero) " · ";font-family:var(--font-mono);color:var(--fg-faint);margin-right:4px}.article-toc a{color:var(--fg-muted);text-decoration:none}.article-toc a:hover{color:var(--fg)}.article-detail-main{min-width:0;max-width:none;margin:0;padding:0}.article-head{border-bottom:1px solid var(--border);margin-bottom:32px;padding-bottom:32px}.article-head h1{letter-spacing:-.02em;margin:16px 0;font-size:40px;font-weight:600;line-height:1.15}.article-head .lead{color:var(--fg-muted);margin:0;font-size:18px}.article-body-text h2{margin:36px 0 12px;font-size:24px;font-weight:600}.article-body-text h3{margin:28px 0 10px;font-size:18px;font-weight:600}.article-body-text ul,.article-body-text ol{padding-left:20px}.article-body-text ul li,.article-body-text ol li{margin-bottom:6px;font-size:16px;line-height:1.65}.article-body-text a{color:var(--accent);-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.article-body-text a:hover{color:var(--accent-hover);-webkit-text-decoration-color:var(--accent-hover);text-decoration-color:var(--accent-hover)}.article-body-text img,.article-body-text figure img,.detail-content img{border:1px solid var(--border);background:var(--bg-subtle);border-radius:12px;max-width:100%;height:auto;margin:24px 0;display:block}.article-body-text figure{flex-direction:column;gap:8px;margin:24px 0;display:flex}.article-body-text figure img{margin:0}.article-body-text figcaption{font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.02em;text-align:center;font-size:12px}.article-body-text table{border-collapse:collapse;width:100%;margin:24px 0;font-size:14.5px;line-height:1.55;display:block;overflow-x:auto}.article-body-text thead{background:var(--bg-subtle)}.article-body-text th,.article-body-text td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:10px 14px}.article-body-text th{color:var(--fg);border-bottom:1px solid var(--border-strong);font-weight:600}.article-body-text tr:last-child td{border-bottom:none}.article-body-text tbody tr:hover td{background:var(--bg-subtle)}.article-body-text td code,.article-body-text th code{padding:2px 5px;font-size:12.5px}.article-body-text th[align=right],.article-body-text td[align=right]{text-align:right;font-variant-numeric:tabular-nums}.callout{background:var(--accent-bg);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;grid-template-columns:auto 1fr;gap:14px;margin:24px 0;padding:18px;display:grid}.callout svg{color:var(--accent);margin-top:4px}.callout strong{color:var(--accent);margin-bottom:4px;font-size:14px;display:block}.callout p{color:var(--fg-muted);margin:0;font-size:14px}.reading-progress{background:var(--accent);z-index:100;width:0;height:2px;transition:width 80ms linear;position:fixed;top:0;left:0}.reveal{opacity:0;transition:opacity .6s var(--ease),transform .6s var(--ease);transform:translateY(14px)}.reveal.is-visible{opacity:1;transform:translateY(0)}.page-enter{animation:pageIn .4s var(--ease) both}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.motif-divider{color:var(--border-strong);justify-content:center;align-items:center;gap:14px;padding:32px 0;display:flex}.motif-line{background:currentColor;width:80px;height:1px;display:block}.motif-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;display:block}.admin-shell{grid-template-columns:220px 1fr;min-height:calc(100vh - 60px);display:grid}.admin-side{border-right:1px solid var(--border);background:var(--bg-subtle);flex-direction:column;gap:4px;padding:24px 16px;display:flex}.admin-side a{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--fg-muted);transition:all .15s var(--ease);border-radius:8px;padding:8px 12px;font-size:12px;text-decoration:none}.admin-side a:hover{background:var(--bg-muted);color:var(--fg)}.admin-side a.active{background:var(--fg);color:var(--bg)}.admin-main{padding:32px}.admin-head{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:16px;display:flex}.admin-head h1{font-size:24px;font-weight:600}.form{flex-direction:column;gap:16px;max-width:720px;display:flex}.form-row{flex-direction:column;gap:6px;display:flex}.form-row label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);font-size:11px}.form-row input[type=text],.form-row input[type=password],.form-row input[type=email],.form-row input[type=url],.form-row input[type=number],.form-row textarea,.form-row select{font-family:var(--font-sans);border:1px solid var(--border);background:var(--bg);color:var(--fg);transition:border-color .15s var(--ease);border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--accent);outline:none}.form-row textarea{font-family:var(--font-mono);resize:vertical;min-height:140px;font-size:13px;line-height:1.55}.form-row .hint{color:var(--fg-subtle);font-size:12px}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-actions{border-top:1px solid var(--border);gap:8px;margin-top:8px;padding-top:8px;display:flex}.alert{border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.5}.alert-error{background:var(--danger-bg);color:var(--danger)}.alert-success{background:var(--success-bg);color:var(--success)}.alert-info{background:var(--accent-bg);color:var(--accent)}.table{border-collapse:collapse;width:100%;font-size:14px}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 8px}.table th{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);font-size:11px;font-weight:500}.table tr:hover td{background:var(--bg-subtle)}.table .actions{justify-content:flex-end;gap:6px;display:flex}.login-shell{justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.login-card{border:1px solid var(--border);background:var(--bg-subtle);border-radius:14px;flex-direction:column;gap:16px;width:100%;max-width:380px;padding:32px;display:flex}.login-card h1{font-size:20px;font-weight:600}@media(max-width:800px){.projects-grid,.contact-grid,.about-grid,.detail-grid{grid-template-columns:1fr}.header-nav{display:none}.form-grid-2,.admin-shell{grid-template-columns:1fr}.admin-side{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap}.article-detail-grid{grid-template-columns:1fr;gap:24px;padding:24px 16px 80px}.article-toc{position:static}.article-row{grid-template-columns:1fr;gap:8px;padding:14px 0}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
