@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-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--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;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-serif:"Noto Serif SC", "Source Han Serif SC", "Georgia", ui-serif, serif;--font-mono:"Google Sans Code", "JetBrains Mono", "Fira Code", ui-monospace, monospace;--color-red-500:#fb2c36;--color-gray-200:#e5e7eb;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--leading-relaxed:1.625;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Noto Sans SC", "Inter", ui-sans-serif, system-ui, sans-serif;--default-mono-font-family:"Google Sans Code", "JetBrains Mono", "Fira Code", ui-monospace, monospace}@supports (color:lab(0% 0 0)){:root,:host{--color-red-500:lab(55.4814% 75.0732 48.8528);--color-gray-200:lab(91.6229% -.159115 -2.26791)}}}@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;-webkit-text-decoration:inherit;-webkit-text-decoration: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 components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.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}}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.ml-1{margin-left:calc(var(--spacing) * 1)}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.min-h-screen{min-height:100vh}.w-full{width:100%}.flex-1{flex:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.rounded-\[4px\]{border-radius:4px}.rounded-\[8px\]{border-radius:8px}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.p-5{padding:calc(var(--spacing) * 5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-16{padding-block:calc(var(--spacing) * 16)}.text-center{text-align:center}.font-logo{font-family:Ubuntu,Fugaz One,sans-serif}.font-mono{font-family:Google Sans Code,JetBrains Mono,Fira Code,ui-monospace,monospace}.font-sans{font-family:Noto Sans SC,Inter,ui-sans-serif,system-ui,sans-serif}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-red-500{color:var(--color-red-500)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.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))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:48rem){.md\:flex{display:flex}.md\:hidden{display:none}}@media (min-width:64rem){.lg\:block{display:block}.lg\:grid{display:grid}}@media (min-width:80rem){.xl\:block{display:block}}}html{height:100%;overflow:hidden}body{height:100%;margin:0}.blog-main{background:inherit;overflow-y:scroll!important}html.lightbox-active .blog-main{overflow-y:hidden!important}html.lightbox-active,html.lightbox-active body{overflow:hidden!important}.blog-main::-webkit-scrollbar{width:10px}.blog-main::-webkit-scrollbar-track{background:inherit}.blog-main::-webkit-scrollbar-thumb{background:#0000001f;border-radius:5px}.blog-main::-webkit-scrollbar-thumb:hover{background:#00000040}.dashboard-shell main.overflow-y-auto{overflow-y:scroll!important}::-webkit-scrollbar{width:10px}.dashboard-shell main::-webkit-scrollbar{width:10px}.dashboard-shell main::-webkit-scrollbar-track{background:var(--color-bg-main,#f5f7fa)}.dashboard-shell main::-webkit-scrollbar-thumb{border:2px solid var(--color-bg-main,#f5f7fa);background:#0000001f;border-radius:5px}.dashboard-shell main::-webkit-scrollbar-thumb:hover{background:#00000040}.dashboard-shell main{scrollbar-color:#0000001f var(--color-bg-main,#f5f7fa)}*{scrollbar-width:thin;scrollbar-color:transparent transparent}:hover,:focus-within{scrollbar-color:#00000026 transparent}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:0 0;border-radius:3px;transition:background .3s}:hover::-webkit-scrollbar-thumb{background:#0000001f}:hover::-webkit-scrollbar-thumb:hover{background:#00000040}@font-face{font-family:Fugaz One;src:url(https://static.utterlog.com/fonts/fugaz-one-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Ubuntu;src:url(https://static.utterlog.com/fonts/ubuntu-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Ubuntu;src:url(https://static.utterlog.com/fonts/ubuntu-500.woff2)format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Ubuntu;src:url(https://static.utterlog.com/fonts/ubuntu-700.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Google Sans Code;src:url(https://static.utterlog.com/fonts/google-sans-code-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Google Sans Code;src:url(https://static.utterlog.com/fonts/google-sans-code-700.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Pro";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-light-300.woff2)format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Pro";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-regular-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Pro";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-solid-900.woff2)format("woff2");font-weight:900;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Brands";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-brands-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Sharp";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-sharp-light-300.woff2)format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:"Font Awesome 7 Sharp";src:url(https://static.utterlog.com/libs/fontawesome/7.2.0/webfonts/fa-sharp-solid-900.woff2)format("woff2");font-weight:900;font-style:normal;font-display:swap}:root,[data-color=steel]{--color-primary:#0052d9;--color-primary-hover:#0044b8;--color-primary-active:#003a9e;--color-bg-main:#fff;--color-bg-card:#fff;--color-bg-soft:#f5f7fa;--color-border:#e1e6eb;--color-divider:#eef2f5;--color-text-main:#0d1a2d;--color-text-sub:#5a6b7f;--color-text-dim:#9aa5b0;--color-focus-ring:#0052d9}[data-color=blue]{--color-primary:#5b9bd5;--color-primary-hover:#4a8bc7;--color-primary-active:#3d7cb5;--color-bg-main:#f5f8fc;--color-bg-card:#fff;--color-bg-soft:#eaf1fa;--color-border:#c8dae8;--color-divider:#e3edf5;--color-text-main:#1a2b3d;--color-text-sub:#5a7a94;--color-text-dim:#8eaab8;--color-focus-ring:#5b9bd5}[data-color=green]{--color-primary:#4caf73;--color-primary-hover:#3e9b62;--color-primary-active:#358753;--color-bg-main:#f6fbf8;--color-bg-card:#fff;--color-bg-soft:#eafbf1;--color-border:#bfe8cf;--color-divider:#dff5e7;--color-text-main:#1f3d2b;--color-text-sub:#4e7c64;--color-text-dim:#8faf9f;--color-focus-ring:#4caf73}[data-color=mint]{--color-primary:#00a88e;--color-primary-hover:#009078;--color-primary-active:#007a66;--color-bg-main:#f3fbf9;--color-bg-card:#fff;--color-bg-soft:#e6f7f3;--color-border:#b8e8dd;--color-divider:#d4f0e9;--color-text-main:#1a3330;--color-text-sub:#3d7068;--color-text-dim:#7eada4;--color-focus-ring:#00a88e}[data-color=claude]{--color-primary:#da7756;--color-primary-hover:#c4633f;--color-primary-active:#b05535;--color-bg-main:#faf9f6;--color-bg-card:#fff;--color-bg-soft:#f5f0eb;--color-border:#e8e0d8;--color-divider:#f2ede7;--color-text-main:#1a1410;--color-text-sub:#6b5b52;--color-text-dim:#9b8e85;--color-focus-ring:#da7756}[data-color=ocean],[data-theme=Azure],[data-theme=azure]{--color-primary:#0052d9;--color-primary-hover:#0044b8;--color-primary-active:#003a9e;--color-bg-main:#fff;--color-bg-card:#fff;--color-bg-soft:#f5f7fa;--color-border:#e1e6eb;--color-divider:#eef2f5;--color-text-main:#0d1a2d;--color-text-sub:#5a6b7f;--color-text-dim:#9aa5b0;--color-focus-ring:#0052d9}[data-theme=Chred],[data-theme=chred]{--color-primary:#f53102;--color-primary-hover:#dc2c02;--color-primary-active:#b82301;--color-bg-main:#fff;--color-bg-card:#fff;--color-bg-soft:#fcf4f2;--color-border:#ece3e1;--color-divider:#f5efee;--color-text-main:#0d1a2d;--color-text-sub:#5a6b7f;--color-text-dim:#9aa5b0;--color-focus-ring:#f53102}[data-color=dark]{--color-primary:#7ca0c4;--color-primary-hover:#93b5d5;--color-primary-active:#5a86b2;--color-bg-main:#0f1117;--color-bg-card:#1a1d27;--color-bg-soft:#252830;--color-border:#353840;--color-divider:#2d3039;--color-text-main:#f0f1f3;--color-text-sub:#a0a8b4;--color-text-dim:#6b7280;--color-focus-ring:#7ca0c4}*{box-sizing:border-box;margin:0;padding:0}html{max-width:100vw;overflow-x:hidden}body{max-width:100vw;color:var(--color-text-main);background:var(--color-bg-main)}.bg-main{background-color:var(--color-bg-main)}.bg-card{background-color:var(--color-bg-card)}.bg-soft{background-color:var(--color-bg-soft)}.bg-primary{background-color:var(--color-primary)}.hover\:bg-primary-hover:hover{background-color:var(--color-primary-hover)}.bg-primary-active{background-color:var(--color-primary-active)}.text-main{color:var(--color-text-main)}.text-sub{color:var(--color-text-sub)}.text-dim{color:var(--color-text-dim)}.border-line{border-color:var(--color-border)}.border-divider{border-color:var(--color-divider)}.font-logo{font-family:Ubuntu,Fugaz One,sans-serif}.blog-page-title{border-bottom:1px solid var(--color-border,#e5e5e5);justify-content:space-between;align-items:center;gap:16px;margin:0 0 24px;padding:24px 32px;display:flex;position:relative}.blog-page-title-rail{display:none}.blog-page-title-main{align-items:center;gap:10px;min-width:0;display:flex}.blog-page-title-icon{color:var(--color-primary,#0052d9);flex:none;justify-content:center;align-items:center;font-size:24px;display:inline-flex}.blog-page-title-copy{min-width:0}.blog-page-title-text{color:var(--color-text-main,#1a1a1a);letter-spacing:0;overflow-wrap:anywhere;margin:0;font-size:24px;font-weight:700;line-height:1.2}.blog-page-title-subtitle{color:var(--color-text-dim,#999);margin-top:4px;font-size:13px;line-height:1.4}.blog-page-title-side{flex:none;justify-content:flex-end;align-items:center;gap:8px;display:flex}.blog-page-title-meta{border:1px solid var(--color-border,#d9d9d9);color:var(--color-text-sub,#666);flex-wrap:wrap;align-items:center;gap:10px;padding:6px 14px;font-size:13px;line-height:1.3;display:flex}.blog-page-title-meta strong{color:var(--color-text-main,#1a1a1a);font-weight:600}.blog-page-title-stat{white-space:nowrap}@media (max-width:768px){.blog-page-title{flex-direction:column;align-items:flex-start;gap:12px;padding:20px 16px}.blog-page-title-side{flex-wrap:wrap;justify-content:flex-start}.blog-page-title-meta{padding:5px 10px;font-size:12px}}.site-title{font-feature-settings:"palt";font-family:Alimama FangYuanTi VF,Noto Sans SC,Ubuntu,PingFang SC,Microsoft YaHei,sans-serif}.text-primary-themed{color:var(--color-primary)}.hover\:text-primary-themed:hover{color:var(--color-primary-hover)}.focus-ring:focus{box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}@supports (color:color-mix(in lab, red, red)){.focus-ring:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--color-focus-ring) 25%, transparent)}}.focus-ring:focus{border-color:var(--color-focus-ring)}.focus-ring:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}@supports (color:color-mix(in lab, red, red)){.focus-ring:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb, var(--color-focus-ring) 25%, transparent)}}.focus-ring:focus-visible{border-color:var(--color-focus-ring)}.btn{cursor:pointer;appearance:none;border:1px solid #0000;border-radius:4px;outline:none;justify-content:center;align-items:center;gap:.5rem;min-height:48px;padding:.625rem 1rem;font-size:.875rem;font-weight:500;line-height:1.5;transition:background-color .15s,box-shadow .15s;display:inline-flex}.btn:focus-visible{box-shadow:0 0 0 2px var(--color-bg-card), 0 0 0 4px var(--color-focus-ring)}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-primary:active{background-color:var(--color-primary-active)}.btn-secondary{background-color:var(--color-bg-soft);color:var(--color-text-main);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-divider)}.btn-danger{color:#fff;background-color:#dc2626}.btn-danger:hover{background-color:#b91c1c}.btn-ghost{color:var(--color-text-sub);background-color:#0000}.btn-ghost:hover{background-color:var(--color-bg-soft);color:var(--color-text-main)}.action-btn{border:1px solid var(--color-border);background:var(--color-bg-card);cursor:pointer;width:30px;min-width:30px;max-width:30px;height:30px;min-height:30px;max-height:30px;color:var(--color-text-sub);box-sizing:border-box;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:inline-flex}.action-btn:hover{background:var(--color-bg-soft);color:var(--color-text-main)}.action-btn.danger{color:#dc2626}.action-btn.danger:hover{background:#fef2f2}.archive-cat-card{transition:box-shadow .3s}.archive-cat-card:hover{box-shadow:0 4px 16px #00000014}.archive-cat-card:hover>i:first-child{opacity:.1;transform:translateY(-50%)scale(1.25)}.archive-cat-card:after{content:"";-webkit-backdrop-filter:blur();backdrop-filter:blur();pointer-events:none;z-index:0;background:#fff0;transition:-webkit-backdrop-filter .3s,backdrop-filter .3s,background .3s;position:absolute;inset:0}.archive-cat-card:hover:after{-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);background:#ffffff26}.input{border:1px solid var(--color-border);width:100%;color:var(--color-text-main);background:var(--color-bg-card);border-radius:1px;padding:.5rem .75rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s;display:block}.input::placeholder{color:var(--color-text-dim)}.input:focus{border-color:var(--color-focus-ring);box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}@supports (color:color-mix(in lab, red, red)){.input:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--color-focus-ring) 20%, transparent)}}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:4px}.card-hover:hover{box-shadow:0 4px 12px #00000014}.badge{border-radius:3px;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:500;display:inline-flex}.table{border-collapse:collapse;min-width:100%}.table th{text-align:left;color:var(--color-text-sub);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);padding:.625rem .75rem;font-size:.75rem;font-weight:500}.table td{white-space:nowrap;color:var(--color-text-main);border-bottom:1px solid var(--color-divider);padding:.75rem;font-size:.875rem}:root{--claude-bg:#faf9f6;--claude-surface:#fff;--claude-primary:#da7756;--claude-primary-light:#e8956f;--claude-primary-dark:#c4633f;--claude-text:#1a1410;--claude-text-secondary:#6b5b52;--claude-text-muted:#9b8e85;--claude-border:#e8e0d8;--claude-tag:#f5f0eb;--claude-code:#f8f5f1;--claude-hover:#f2ede7}.reply-mention:hover .reply-mention-card{display:block!important}.comment-hint{transition:opacity .2s}div:hover>.comment-hint{opacity:.75!important}.blog-image{cursor:zoom-in;background:var(--color-bg-soft);border-radius:0;min-height:80px;margin:1.5rem 0;display:block;position:relative;overflow:hidden}.blog-image img{aspect-ratio:16/9;object-fit:cover;background-color:var(--color-bg-soft);filter:blur(20px);width:100%;transition:opacity .5s ease-in-out;display:block}.blog-image.loaded img{filter:blur();opacity:1;transition:filter .5s linear}.blog-image-loader{z-index:2;color:var(--color-text-dim);opacity:1;pointer-events:none;justify-content:center;align-items:center;transition:opacity .35s ease-out;display:flex;position:absolute;inset:0}.blog-image.loaded .blog-image-loader{opacity:0}.blog-image-caption{z-index:3;color:#fff;cursor:default;background:#0006;border-radius:0;max-width:70%;margin-bottom:4px;padding:8px;font-size:13px;line-height:1.4;position:absolute;bottom:0;right:0}.image-grid{border-radius:0;gap:6px;margin:1.5rem 0;display:grid;overflow:hidden}.image-grid .blog-image{border-radius:0;width:100%;min-height:0;margin:0}.image-grid .blog-image img{aspect-ratio:4/3;object-fit:cover;width:100%;height:100%}.image-grid-1{max-width:65%;margin-left:auto;margin-right:auto}.image-grid-1 .blog-image img{aspect-ratio:auto;object-fit:contain}.image-grid-2{grid-template-columns:1fr 1fr}.image-grid-2 .blog-image img{aspect-ratio:4/3}.image-grid-3{grid-template-columns:1fr 1fr 1fr}.image-grid-3 .blog-image img{aspect-ratio:1}.image-grid-4{grid-template-columns:repeat(4,1fr)}.image-grid-5{grid-template-columns:repeat(6,1fr)}.image-grid-5 .blog-image:nth-child(-n+2){grid-column:span 3}.image-grid-5 .blog-image:nth-child(n+3){grid-column:span 2}.image-grid-6{grid-template-columns:repeat(3,1fr)}.image-grid-7{grid-template-columns:repeat(12,1fr)}.image-grid-7 .blog-image:nth-child(-n+3){grid-column:span 4}.image-grid-7 .blog-image:nth-child(n+4){grid-column:span 3}.image-grid-8{grid-template-columns:repeat(4,1fr)}.image-grid-9{grid-template-columns:repeat(3,1fr)}.image-grid-10{grid-template-columns:repeat(12,1fr)}.image-grid-10 .blog-image:nth-child(-n+6){grid-column:span 4}.image-grid-10 .blog-image:nth-child(n+7){grid-column:span 3}.image-grid-overflow{grid-template-columns:1fr 1fr 1fr}@media (max-width:640px){.image-grid-3,.image-grid-4,.image-grid-5,.image-grid-6,.image-grid-7,.image-grid-8,.image-grid-9,.image-grid-10,.image-grid-overflow{grid-template-columns:1fr 1fr}.image-grid-5 .blog-image,.image-grid-7 .blog-image,.image-grid-10 .blog-image{grid-column:span 1!important}.image-grid-1{max-width:100%}}@media (max-width:400px){.image-grid{grid-template-columns:1fr!important}.image-grid .blog-image img{aspect-ratio:16/9}.image-grid-5 .blog-image{grid-column:span 1!important}}.blog-image-exif-trigger{z-index:4;color:#fff;cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;transition:opacity .2s;display:flex;position:absolute;bottom:8px;left:8px}.blog-image:hover .blog-image-exif-trigger{opacity:1}.blog-image-exif-panel{z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;white-space:nowrap;background:#000c;border-radius:0;padding:10px 14px;font-size:12px;line-height:1.6;position:absolute;bottom:44px;left:8px}.blog-image-exif-panel .exif-row{align-items:baseline;gap:8px;display:flex}.blog-image-exif-panel .exif-label{color:#ffffff80;min-width:48px;font-size:10px}.blog-image-exif-panel .exif-params{border-top:1px solid #ffffff1a;border-bottom:1px solid #ffffff1a;gap:10px;margin:4px 0;padding:4px 0;font-size:13px;font-weight:500;display:flex}.vi-overlay{z-index:9999;will-change:opacity;background:#121418f5;flex-direction:column;padding:1rem;animation:.3s both vi-in;display:flex;position:fixed;inset:0}.vi-overlay.vi-closing{animation:.3s forwards vi-out}@keyframes vi-in{0%{opacity:0}to{opacity:1}}@keyframes vi-out{0%{opacity:1}to{opacity:0}}.vi-stage{flex:1;justify-content:center;align-items:center;height:0;min-height:0;display:flex;position:relative}.vi-stage .vi-img{object-fit:contain;-webkit-user-select:none;user-select:none;z-index:1;will-change:transform, opacity;border-radius:0;max-width:100%;max-height:100%;animation:.3s both vi-img-in;display:block;position:relative}.vi-stage.vi-img-out .vi-img{animation:.3s forwards vi-img-out}@keyframes vi-img-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes vi-img-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.vi-stage .vi-backstop{cursor:zoom-out;z-index:0;position:absolute;inset:0}.vi-loading{z-index:1;pointer-events:none;background:#ffffff1f;width:8rem;height:3px;margin:-1.5px -4rem;position:absolute;top:50%;left:50%;overflow:hidden}.vi-loading:after{content:"";background:#ffffff8c;width:40%;animation:.9s ease-in-out infinite vi-loading;position:absolute;top:0;bottom:0;left:0}@keyframes vi-loading{0%{transform:translate(-100%)}to{transform:translate(350%)}}.vi-tools{bottom:calc(1rem + env(safe-area-inset-bottom));color:#fff;z-index:2;background:#00000080;border-radius:0;justify-content:space-between;align-items:center;max-width:600px;margin:0 auto;padding:10px 12px;display:flex;position:absolute;left:1rem;right:1rem}.vi-count{font-variant-numeric:tabular-nums;text-align:center;min-width:60px;font-size:13px}.vi-nav{gap:10px;display:flex}.vi-btn{cursor:pointer;color:#fff;background:#ffffff2e;border:none;border-radius:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.vi-btn:hover{background:#fff6}.vi-btn:disabled{opacity:.35;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-soft);border-radius:1px}::-webkit-scrollbar-thumb{background:var(--color-text-dim);border-radius:1px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-sub)}.hljs{color:#3c3836;background:#f8f5f1}.hljs-comment,.hljs-quote{color:#928374;font-style:italic}.hljs-keyword,.hljs-selector-tag,.hljs-addition{color:#9d0006}.hljs-number,.hljs-string,.hljs-meta .hljs-meta-string,.hljs-literal,.hljs-doctag,.hljs-regexp{color:#b57614}.hljs-title,.hljs-section,.hljs-name,.hljs-selector-id,.hljs-selector-class{color:#da7756}.hljs-attribute,.hljs-tag .hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-class .hljs-title,.hljs-type{color:#427b58}.hljs-symbol,.hljs-bullet,.hljs-subst,.hljs-meta,.hljs-meta .hljs-keyword,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-link{color:#af3a03}.hljs-built_in,.hljs-deletion{color:#076678}.hljs-formula{background:#f5f0eb}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}[data-color=dark] .hljs{color:#e5e7eb;background:#1e2130}[data-color=dark] .hljs-comment,[data-color=dark] .hljs-quote{color:#6b7280}[data-color=dark] .hljs-keyword{color:#f87171}[data-color=dark] .hljs-string,[data-color=dark] .hljs-number{color:#fbbf24}[data-color=dark] .hljs-title,[data-color=dark] .hljs-section{color:#60a5fa}[data-color=dark] .hljs-attribute,[data-color=dark] .hljs-type{color:#34d399}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}@keyframes vinyl-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vinyl-spinning{animation:8s linear infinite vinyl-spin}.vinyl-paused{animation-play-state:paused}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}:root{--img-effect-duration:.5s}:where([data-blog-image] img,img[data-blog-image]){will-change:opacity, transform, filter, clip-path;backface-visibility:hidden}img[data-blog-image][data-loaded="0"]{background-color:var(--color-bg-soft,#f0f0f0)}.md-download-card{--md-download-bg:#1a1a1a;--md-download-accent:#f5a623;--md-download-text:#fff;background:var(--md-download-bg);color:var(--md-download-text);border-radius:8px;align-items:center;gap:16px;margin:16px 0;padding:16px 20px;display:flex}.md-download-icon{background:var(--md-download-accent);width:44px;height:44px;color:var(--md-download-bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.md-download-info{flex:1;min-width:0}.md-download-title{text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;line-height:1.4;overflow:hidden}.md-download-desc{opacity:.7;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.md-download-btn{background:var(--md-download-accent);color:var(--md-download-bg);white-space:nowrap;border-radius:6px;flex-shrink:0;padding:8px 20px;font-size:13px;font-weight:600;text-decoration:none;transition:filter .15s,transform .15s}.md-download-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.md-download-btn:active{transform:translateY(0)}@media (max-width:480px){.md-download-card{flex-wrap:wrap;gap:12px;padding:14px}.md-download-info{flex-basis:calc(100% - 56px)}.md-download-btn{text-align:center;flex-basis:100%}}.cover-zoom :where([data-blog-image] img,img[data-blog-image]){transition:transform .6s cubic-bezier(.4,0,.2,1);transform:translate(0)scale(1)}.cover-zoom:hover :where([data-blog-image] img,img[data-blog-image]){transform:translate(0)scale(1.04)}@media (prefers-reduced-motion:reduce){.cover-zoom :where([data-blog-image] img,img[data-blog-image]),.cover-zoom:hover :where([data-blog-image] img,img[data-blog-image]){transition:none!important;transform:none!important}}html[data-img-effect=fade] :where(img[data-blog-image][data-loaded="0"],[data-blog-image] img[data-loaded="0"]){background-color:var(--color-bg-soft);filter:blur(20px);-webkit-transition:opacity var(--img-effect-duration) ease-in-out, transform .6s cubic-bezier(.4, 0, .2, 1);transition:opacity var(--img-effect-duration) ease-in-out, transform .6s cubic-bezier(.4, 0, .2, 1)}html[data-img-effect=fade] :where(img[data-blog-image][data-loaded="1"],[data-blog-image] img[data-loaded="1"]){filter:blur();opacity:1;-webkit-transition:filter var(--img-effect-duration) linear, -webkit-filter var(--img-effect-duration) linear, transform .6s cubic-bezier(.4, 0, .2, 1);transition:filter var(--img-effect-duration) linear, -webkit-filter var(--img-effect-duration) linear, transform .6s cubic-bezier(.4, 0, .2, 1)}.pixel-overlay{pointer-events:none;z-index:2;grid-template-rows:repeat(10,1fr);grid-template-columns:repeat(10,1fr);display:grid;position:absolute;inset:0}.pixel-tile{animation:pixel-reveal var(--img-effect-duration) forwards;animation-delay:calc(var(--delay,0) * 50ms);background:#000000e6}@keyframes pixel-reveal{to{background:0 0}}html[data-img-effect=pixel] :where([data-blog-image] img,img[data-blog-image]){animation:none}html[data-img-effect=scale] :where([data-blog-image] img,img[data-blog-image])[data-img-effect-visible="1"]{animation:img-scale calc(var(--img-effect-duration) * 1.3) cubic-bezier(.34, 1.56, .64, 1) both}html[data-img-effect=scale] :where([data-blog-image] img,img[data-blog-image]):not([data-img-effect-visible]){opacity:0}@keyframes img-scale{0%{opacity:0;filter:blur(4px);transform:scale(.9)}to{opacity:1;filter:blur();transform:scale(1)}}html[data-img-effect=none] :where([data-blog-image] img,img[data-blog-image]){animation:none}@keyframes lazy-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (prefers-reduced-motion:reduce){html[data-img-effect] :where([data-blog-image] img,img[data-blog-image]){opacity:1!important;filter:none!important;clip-path:none!important;animation:none!important;transform:none!important}}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@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}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
