.cmd-kbd[data-v-81ee8178]{color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:2px;padding:2px 5px;font:400 9px/1 JetBrains Mono,monospace}.switcher-btn[data-v-4909d181]{z-index:200;background:var(--paper,#f5f0e8);cursor:pointer;color:var(--ink,#1a1a1a);letter-spacing:.04em;border:1.5px solid #00000026;border-radius:3px;align-items:center;gap:6px;padding:8px 14px;font-family:DM Mono,monospace;font-size:11px;transition:box-shadow .15s,transform .15s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 16px #00000040,0 1px 4px #00000026}.switcher-btn[data-v-4909d181]:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0000004d,0 2px 6px #00000026}.switcher-btn--open[data-v-4909d181]{background:var(--ink,#1a1a1a);color:var(--paper,#f5f0e8);border-color:#0000}.switcher-icon[data-v-4909d181]{font-size:13px}.switcher-backdrop[data-v-4909d181]{z-index:190;background:#00000026;position:fixed;inset:0}.switcher-panel[data-v-4909d181]{z-index:195;background:var(--paper,#f5f0e8);border:1.5px solid #0000001f;border-radius:4px;width:300px;max-height:70vh;position:fixed;bottom:72px;right:28px;overflow-y:auto;box-shadow:0 12px 40px #0000004d,0 4px 12px #00000026}.switcher-panel[data-v-4909d181]:before{content:"";pointer-events:none;height:0;display:block;position:sticky;top:0}.panel-header[data-v-4909d181]{background:var(--paper,#f5f0e8);z-index:1;border-bottom:1px solid #0000001a;padding:16px 18px 12px;position:sticky;top:0}.panel-title[data-v-4909d181]{color:var(--ink,#1a1a1a);margin-bottom:4px;font-family:Caveat,cursive;font-size:22px;font-weight:700;line-height:1}.panel-sub[data-v-4909d181]{color:var(--ink-light,#4a4040);letter-spacing:.02em;font-family:DM Mono,monospace;font-size:9px}.designs-list[data-v-4909d181]{padding:4px 0}.group-label[data-v-4909d181]{letter-spacing:.1em;text-transform:uppercase;color:#4a404073;border-top:1px solid #0000000f;padding:10px 18px 4px;font-family:DM Mono,monospace;font-size:9px}.group-label[data-v-4909d181]:first-child{border-top:none}.design-item[data-v-4909d181]{align-items:center;gap:12px;padding:8px 18px;transition:background .12s;display:flex}.design-item--clickable[data-v-4909d181]{cursor:pointer}.design-item--clickable[data-v-4909d181]:hover{background:#0000000a}.design-item--active[data-v-4909d181]{background:#cc22220d}.design-dot[data-v-4909d181]{border-radius:3px;flex-shrink:0;width:26px;height:26px;box-shadow:0 1px 4px #00000026}.dot--notebook[data-v-4909d181]{background:linear-gradient(135deg,#ede6d6 50%,#1b2838 50%)}.dot--terminal[data-v-4909d181]{background:linear-gradient(135deg,#0d1117 0%,#00ff41 100%)}.dot--editorial[data-v-4909d181]{background:linear-gradient(135deg,#f8f4ee 0%,#c1440e 100%)}.dot--graph[data-v-4909d181]{background:linear-gradient(135deg,#050510 0%,#48f 100%)}.dot--combined[data-v-4909d181]{background:linear-gradient(135deg,#0f172a 50%,#f8f4ee 50%)}.dot--newspaper[data-v-4909d181]{background:linear-gradient(135deg,#f5f0e5 0%,#1a1a1a 100%)}.dot--wiki[data-v-4909d181]{background:linear-gradient(135deg,#1a1a1a 0%,#7c6ef8 100%)}.dot--cards[data-v-4909d181]{background:linear-gradient(135deg,#0f172a 0%,#7fdbca 100%)}.dot--timeline[data-v-4909d181]{background:linear-gradient(135deg,#0d1117 0%,#c1440e 100%)}.design-info[data-v-4909d181]{flex:1;min-width:0}.design-name[data-v-4909d181]{color:var(--ink,#1a1a1a);margin-bottom:2px;font-family:"Source Serif 4",Georgia,serif;font-size:12.5px;font-weight:600;line-height:1.2}.design-desc[data-v-4909d181]{color:var(--ink-light,#4a4040);letter-spacing:.02em;font-family:DM Mono,monospace;font-size:10px}.design-detail[data-v-4909d181]{color:#4a404080;letter-spacing:.02em;margin-top:1px;font-family:DM Mono,monospace;font-size:9px}.design-badge[data-v-4909d181]{letter-spacing:.06em;text-transform:uppercase;color:#c22;background:#cc22221a;border:1px solid #cc222240;border-radius:2px;flex-shrink:0;padding:2px 6px;font-family:DM Mono,monospace;font-size:8px}.design-arrow[data-v-4909d181]{color:#4a404047;flex-shrink:0;font-family:Caveat,cursive;font-size:18px;transition:color .12s,transform .12s}.design-item--clickable:hover .design-arrow[data-v-4909d181]{color:var(--ink,#1a1a1a);transform:translate(1px,-1px)}.panel-footer[data-v-4909d181]{color:#4a404066;letter-spacing:.02em;border-top:1px solid #00000014;padding:10px 18px;font-family:DM Mono,monospace;font-size:9px}.fade-enter-active[data-v-4909d181],.fade-leave-active[data-v-4909d181]{transition:opacity .2s}.fade-enter-from[data-v-4909d181],.fade-leave-to[data-v-4909d181]{opacity:0}.panel-slide-enter-active[data-v-4909d181],.panel-slide-leave-active[data-v-4909d181]{transition:opacity .2s,transform .2s}.panel-slide-enter-from[data-v-4909d181],.panel-slide-leave-to[data-v-4909d181]{opacity:0;transform:translateY(8px)}.app[data-v-2a2eb7d3]{background:var(--bg);min-height:100vh}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}:root,html[data-theme=light]{--bg:#fff;--paper:#fff;--paper-2:#fafafa;--paper-3:#f4f4f5;--ink:#0a0a0a;--ink-2:#1f2937;--ink-3:#4b5563;--ink-4:#6b7280;--ink-5:#9ca3af;--ink-6:#d4d4d8;--border:#ececee;--border-2:#f4f4f5;--brand:#4f46e5;--brand-soft:#eef2ff;--brand-2:#ec4899;--cat-net-fg:#4f46e5;--cat-net-bg:#eef2ff;--cat-be-fg:#047857;--cat-be-bg:#ecfdf5;--cat-fe-fg:#c2410c;--cat-fe-bg:#fff7ed;--cat-db-fg:#0369a1;--cat-db-bg:#f0f9ff;--cat-os-fg:#7c3aed;--cat-os-bg:#faf5ff;--cat-ds-fg:#b91c1c;--cat-ds-bg:#fef2f2;--info:#4f46e5;--info-soft:#eef2ff;--success:#059669;--success-soft:#ecfdf5;--warning:#d97706;--warning-soft:#fffbeb;--danger:#dc2626;--danger-soft:#fef2f2;--code-bg:#0a0a0a;--code-fg:#e5e7eb;--code-pink:#f472b6;--code-green:#86efac;--code-blue:#93c5fd;--code-purple:#a78bfa;--code-orange:#fb923c;--code-dim:#71717a;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "DM Mono", monospace;--type-display-1:700 56px/1 var(--font-sans);--type-display-2:700 40px/1.1 var(--font-sans);--type-h1:700 32px/1.15 var(--font-sans);--type-h2:700 24px/1.3 var(--font-sans);--type-h3:600 17px/1.3 var(--font-sans);--type-body:400 16px/1.75 var(--font-sans);--type-ui:400 14px/1.55 var(--font-sans);--type-small:400 12.5px/1.5 var(--font-sans);--type-meta:500 11px/1.4 var(--font-mono);--type-code:500 12.5px/1.75 var(--font-mono);--type-display-letter:-.025em;--type-h-letter:-.015em;--s-1:4px;--s-2:8px;--s-3:14px;--s-4:22px;--s-5:36px;--s-6:56px;--s-7:88px;--s-8:140px;--r-0:0;--r-1:3px;--r-2:6px;--r-3:8px;--r-4:12px;--r-full:9999px;--sh-0:none;--sh-1:0 1px 2px #0000000a;--sh-2:0 4px 12px #00000014;--sh-3:0 12px 28px #00000026;--m-1:.1s;--m-2:.15s;--m-3:.25s;--m-4:.4s;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--prose-max:720px;--frame-max:1280px;--sidebar-w:240px;--page-px:48px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}html[data-theme=dark]{--bg:#09090b;--paper:#0f0f11;--paper-2:#18181b;--paper-3:#27272a;--ink:#fafafa;--ink-2:#e4e4e7;--ink-3:#a1a1aa;--ink-4:#71717a;--ink-5:#52525b;--ink-6:#3f3f46;--border:#27272a;--border-2:#18181b;--brand:#818cf8;--brand-soft:#818cf81a;--brand-2:#f0abfc;--cat-net-fg:#a5b4fc;--cat-net-bg:#a5b4fc1a;--cat-be-fg:#6ee7b7;--cat-be-bg:#6ee7b71a;--cat-fe-fg:#fdba74;--cat-fe-bg:#fdba741a;--cat-db-fg:#7dd3fc;--cat-db-bg:#7dd3fc1a;--cat-os-fg:#c4b5fd;--cat-os-bg:#c4b5fd1a;--cat-ds-fg:#fda4af;--cat-ds-bg:#fda4af1a;--info:#818cf8;--info-soft:#818cf81a;--success:#34d399;--success-soft:#34d3991a;--warning:#fbbf24;--warning-soft:#fbbf241a;--danger:#f87171;--danger-soft:#f871711a;--sh-1:0 1px 2px #0006;--sh-2:0 4px 12px #00000080;--sh-3:0 12px 28px #000000b3;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::selection{background:var(--brand-soft);color:var(--ink)}html[data-theme=dark] ::selection{background:var(--brand);color:var(--bg)}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--r-1)}.cs-gradient{background:linear-gradient(90deg, var(--brand), var(--brand-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}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-feature-settings:normal;font-variation-settings:normal;font-family:JetBrains Mono,DM Mono,monospace;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}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.\!block{display:block!important}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.outline{outline-style:solid}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f);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)}.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,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-family:var(--font-sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.top-nav{z-index:100;background:var(--bg);border-bottom:1px solid var(--border);height:64px;padding:0 var(--page-px);align-items:center;gap:var(--s-4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;position:sticky;top:0}.top-nav-brand{font:700 18px/1 var(--font-sans);letter-spacing:-.02em;color:var(--ink);margin-right:auto;text-decoration:none}.top-nav-brand em{font-style:normal}.brand-cs{color:var(--brand)}.brand-log{color:var(--ink-3)}.top-nav-link{font:500 14px/1 var(--font-sans);color:var(--ink-3);border-radius:var(--r-2);transition:color var(--m-1), background var(--m-1);padding:6px 10px;text-decoration:none}.top-nav-link:hover{color:var(--ink);background:var(--paper-2)}.top-nav-link.active{color:var(--brand)}.hero{padding:var(--s-6) var(--page-px) var(--s-5);border-bottom:1px solid var(--border)}.hero-eyebrow{font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--brand);margin-bottom:var(--s-3);align-items:center;gap:var(--s-2);display:flex}.hero-eyebrow-dot{background:var(--success);border-radius:50%;width:6px;height:6px}.hero-h1{font:700 48px/1.05 var(--font-sans);letter-spacing:-.025em;color:var(--ink);margin-bottom:var(--s-3)}.hero-h1 em{font-style:normal}.hero-cs{color:var(--brand)}.hero-log{color:var(--brand);opacity:.55}.hero-sub{font:400 16px/1.6 var(--font-sans);color:var(--ink-3);max-width:560px;margin-bottom:var(--s-4)}.hero-meta{gap:var(--s-4);flex-wrap:wrap;display:flex}.hero-stat{font:500 11px/1 var(--font-mono);letter-spacing:.04em;color:var(--ink-4)}.hero-stat span{color:var(--ink-2);margin-right:4px;font-weight:700}.cat-bar{gap:var(--s-2);padding:var(--s-3) var(--page-px);border-bottom:1px solid var(--border);scrollbar-width:none;flex-wrap:nowrap;display:flex;overflow-x:auto}.cat-bar::-webkit-scrollbar{display:none}.cat-chip{font:500 11px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border-radius:var(--r-full);border:1px solid var(--border);background:var(--paper);color:var(--ink-3);cursor:pointer;transition:all var(--m-1);white-space:nowrap;flex-shrink:0;padding:5px 12px}.cat-chip:hover{border-color:var(--ink-5);color:var(--ink)}.cat-chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.cat-chip.active[data-cat=Network]{background:var(--cat-net-fg);color:#fff;border-color:var(--cat-net-fg)}.cat-chip.active[data-cat=BE]{background:var(--cat-be-fg);color:#fff;border-color:var(--cat-be-fg)}.cat-chip.active[data-cat=FE]{background:var(--cat-fe-fg);color:#fff;border-color:var(--cat-fe-fg)}.cat-chip.active[data-cat=DB]{background:var(--cat-db-fg);color:#fff;border-color:var(--cat-db-fg)}.cat-chip.active[data-cat=OS]{background:var(--cat-os-fg);color:#fff;border-color:var(--cat-os-fg)}.cat-chip.active[data-cat=자료구조]{background:var(--cat-ds-fg);color:#fff;border-color:var(--cat-ds-fg)}.card-grid{gap:var(--s-4);padding:var(--s-5) var(--page-px);max-width:var(--frame-max);grid-template-columns:repeat(3,1fr);margin:0 auto;display:grid}@media (width<=1024px){.card-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.card-grid{padding:var(--s-4) var(--s-4);grid-template-columns:1fr}}.post-card{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);padding:var(--s-4);cursor:pointer;transition:border-color var(--m-1);gap:var(--s-2);text-align:left;flex-direction:column;width:100%;display:flex}.post-card:hover{border-color:var(--ink-5)}.post-card-header{justify-content:space-between;align-items:center;display:flex}.post-card-badge{font:500 9.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-1);padding:3px 8px}.post-card-date{font:400 11px/1 var(--font-mono);color:var(--ink-5)}.post-card-title{font:600 15px/1.35 var(--font-sans);color:var(--ink);letter-spacing:-.005em;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.post-card-summary{font:400 13px/1.6 var(--font-sans);color:var(--ink-3);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.post-card-tags{gap:var(--s-1);padding-top:var(--s-2);flex-wrap:wrap;margin-top:auto;display:flex}.post-card-tag{font:500 10px/1 var(--font-mono);color:var(--ink-4);background:var(--paper-3);border-radius:var(--r-1);padding:2px 6px}.post-card-footer{padding-top:var(--s-2);border-top:1px solid var(--border-2);margin-top:var(--s-1);justify-content:space-between;align-items:center;display:flex}.post-card-read-time{font:400 11px/1 var(--font-mono);color:var(--ink-5)}.post-card-stats{gap:var(--s-3);font:400 11px/1 var(--font-mono);color:var(--ink-5);display:flex}.post-card--featured{background:var(--brand-soft);border-color:#4f46e540;grid-column:span 2}@media (width<=1024px){.post-card--featured{grid-column:span 1}}.post-card--featured .post-card-title{color:var(--ink);-webkit-line-clamp:3;font-size:18px}.post-card--featured .post-card-summary{color:var(--ink-3)}.post-card--featured .post-card-date{color:var(--ink-5)}.post-card--featured .post-card-footer{border-top-color:var(--border-2)}.post-card--featured .post-card-stats{color:var(--ink-5)}.post-layout{max-width:var(--frame-max);padding:var(--s-5) var(--page-px);grid-template-columns:minmax(0, 1fr) var(--sidebar-w);gap:var(--s-6);align-items:start;margin:0 auto;display:grid}@media (width<=960px){.post-layout{grid-template-columns:1fr}}.post-meta-bar{align-items:center;gap:var(--s-3);margin-bottom:var(--s-4);flex-wrap:wrap;display:flex}.post-meta-badge{font:500 9.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-1);padding:3px 8px}.post-meta-date,.post-meta-read,.post-meta-views{font:400 11px/1 var(--font-mono);color:var(--ink-5)}.post-title{font:700 36px/1.15 var(--font-sans);letter-spacing:-.02em;color:var(--ink);margin-bottom:var(--s-4)}.post-tags{gap:var(--s-1);margin-bottom:var(--s-5);flex-wrap:wrap;display:flex}.post-tag-chip{font:500 10px/1 var(--font-mono);color:var(--ink-3);background:var(--paper-3);border:1px solid var(--border);border-radius:var(--r-full);cursor:pointer;transition:all var(--m-1);padding:4px 10px}.post-tag-chip:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-soft)}.prose{font:400 16px/1.75 var(--font-sans);color:var(--ink-2);max-width:var(--prose-max)}.prose h1,.prose h2,.prose h3,.prose h4{color:var(--ink);font-family:var(--font-sans)}.prose h2{font:700 22px/1.3 var(--font-sans);margin:var(--s-5) 0 var(--s-3);letter-spacing:-.015em}.prose h3{font:600 17px/1.3 var(--font-sans);margin:var(--s-4) 0 var(--s-2)}.prose p{margin-bottom:var(--s-3)}.prose ul,.prose ol{margin:0 0 var(--s-3) var(--s-4)}.prose li{margin-bottom:var(--s-1)}.prose a{color:var(--brand);text-underline-offset:3px;text-decoration:underline}.prose strong{color:var(--ink);font-weight:600}.prose blockquote{border-left:3px solid var(--brand);padding:var(--s-2) var(--s-4);background:var(--brand-soft);border-radius:0 var(--r-2) var(--r-2) 0;margin:var(--s-4) 0;color:var(--ink-3);font-style:italic}.prose code{font:500 12.5px/1.5 var(--font-mono);background:var(--paper-3);color:var(--brand);border-radius:var(--r-1);padding:2px 6px}.prose pre{margin:var(--s-4) 0;border-radius:var(--r-3);position:relative;overflow:hidden;background:var(--code-bg)!important;color:var(--code-fg)!important}.prose pre code,.prose pre code.hljs{overflow-x:auto;color:inherit!important;padding:var(--s-3)!important;font:500 12.5px/1.75 var(--font-mono)!important;background:0 0!important;border-radius:0!important;display:block!important}.prose img{border-radius:var(--r-3);max-width:100%}.prose hr{border:none;border-top:1px solid var(--border);margin:var(--s-5) 0}.prose table{border-collapse:collapse;width:100%;margin:var(--s-4) 0;font-size:14px}.prose th,.prose td{border:1px solid var(--border);padding:8px 12px}.prose th{background:var(--paper-2);color:var(--ink);font-weight:600}.code-bar{height:36px;padding:0 var(--s-3);background:#ffffff0a;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;display:flex;position:relative}.code-lang{font:500 10px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--code-dim)}.code-copy{font:500 10px/1 var(--font-mono);border-radius:var(--r-1);cursor:pointer;color:var(--code-purple);letter-spacing:.03em;transition:background var(--m-1);background:#ffffff0f;border:1px solid #ffffff1f;padding:3px 8px}.code-copy:hover{background:#ffffff1a}.prose pre.with-lines code{counter-reset:line;position:relative;padding-left:48px!important}.post-sidebar{position:sticky;top:88px}.toc-panel{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);padding:var(--s-3) 0}.toc-head{font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-5);padding:0 var(--s-3) var(--s-2);border-bottom:1px solid var(--border-2);margin-bottom:var(--s-2)}.toc-entry{text-align:left;width:100%;padding:5px var(--s-3);font:400 12.5px/1.4 var(--font-sans);color:var(--ink-3);cursor:pointer;transition:all var(--m-1);background:0 0;border:none;border-left:2px solid #0000;display:block}.toc-entry:hover{color:var(--ink)}.toc-entry.active{color:var(--brand);border-left-color:var(--brand);background:var(--brand-soft);font-weight:600}.toc-entry.toc-l3{padding-left:calc(var(--s-3) + 12px);font-size:12px}.wikilink{color:var(--brand);text-underline-offset:3px;cursor:pointer;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.wikilink-popup{z-index:9000;background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);box-shadow:var(--sh-3);padding:var(--s-3) var(--s-4);pointer-events:none;min-width:200px;max-width:300px;position:fixed}.wlp-title{font:600 14px/1.4 var(--font-sans);color:var(--ink);margin-bottom:4px}.wlp-meta{font:400 11px/1 var(--font-mono);color:var(--ink-4);margin-bottom:6px}.wlp-summary{font:400 12px/1.5 var(--font-sans);color:var(--ink-3);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:6px;display:-webkit-box;overflow:hidden}.wlp-hint{font:500 10px/1 var(--font-mono);color:var(--brand)}.wlp-notfound{font:400 12px/1.5 var(--font-sans);color:var(--ink-4)}.search-bar{align-items:center;gap:var(--s-2);background:var(--paper-2);border:1px solid var(--border);border-radius:var(--r-2);cursor:pointer;transition:border-color var(--m-1);padding:6px 12px;display:flex}.search-bar:hover{border-color:var(--ink-5)}.search-bar-text{font:400 13px/1 var(--font-sans);color:var(--ink-5)}.search-bar-kbd{font:500 9px/1 var(--font-mono);background:var(--paper-3);border:1px solid var(--border);border-radius:var(--r-1);color:var(--ink-5);padding:2px 5px}.theme-toggle{border:1px solid var(--border);border-radius:var(--r-2);font:400 14px/1 var(--font-sans);color:var(--ink-3);cursor:pointer;transition:all var(--m-1);background:0 0;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:6px 10px;display:flex}.theme-toggle:hover{border-color:var(--ink-5);color:var(--ink)}.cmd-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:flex-start;padding-top:15vh;display:flex;position:fixed;inset:0}.cmd-palette{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);box-shadow:var(--sh-3);width:580px;max-width:calc(100vw - 32px);overflow:hidden}.cmd-input-wrap{align-items:center;gap:var(--s-2);padding:var(--s-3) var(--s-4);border-bottom:1px solid var(--border);display:flex}.cmd-input-icon{color:var(--ink-4);font-size:16px}.cmd-input{font:400 15px/1 var(--font-sans);color:var(--ink);background:0 0;border:none;outline:none;flex:1}.cmd-kbd{font:500 9px/1 var(--font-mono);background:var(--paper-3);border:1px solid var(--border);border-radius:var(--r-1);color:var(--ink-5);padding:2px 6px}.cmd-results{max-height:400px;overflow-y:auto}.cmd-group-label{font:500 9.5px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-5);padding:var(--s-2) var(--s-4) var(--s-1)}.cmd-item{align-items:center;gap:var(--s-2);padding:9px var(--s-4);text-align:left;cursor:pointer;width:100%;font:400 14px/1 var(--font-sans);color:var(--ink-2);transition:background var(--m-1);background:0 0;border:none;display:flex}.cmd-item:hover,.cmd-item--active{background:var(--brand-soft);color:var(--brand)}.cmd-item-icon{color:var(--ink-5);font-size:12px}.cmd-item-meta{font:400 11px/1 var(--font-mono);color:var(--ink-5);margin-left:auto}.cmd-empty{padding:var(--s-4);text-align:center;font:400 13px/1 var(--font-sans);color:var(--ink-5)}.related-section{margin-top:var(--s-5)}.section-label{font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-5);margin-bottom:var(--s-3)}.related-cards{gap:var(--s-2);flex-direction:column;display:flex}.related-card{background:var(--paper-2);border:1px solid var(--border);border-radius:var(--r-3);padding:var(--s-3);cursor:pointer;transition:border-color var(--m-1);text-align:left;width:100%}.related-card:hover{border-color:var(--ink-5)}.related-card-title{font:500 13px/1.35 var(--font-sans);color:var(--ink);margin-bottom:4px}.related-card-tags{font:400 10px/1 var(--font-mono);color:var(--ink-4)}.pn{gap:var(--s-3);margin-top:var(--s-5);display:flex}.pn-card{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-3);padding:var(--s-3) var(--s-4);text-align:left;cursor:pointer;transition:border-color var(--m-1);flex-direction:column;flex:1;gap:4px;display:flex}.pn-card--next{text-align:right}.pn-card:not(:disabled):hover{border-color:var(--brand)}.pn-card:disabled{opacity:.35;cursor:default}.pn-label{font:500 9.5px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-5)}.pn-title{font:500 13px/1.35 var(--font-sans);color:var(--ink)}.pn-meta{font:400 10px/1 var(--font-mono);color:var(--ink-5)}.backlinks-section{margin-top:var(--s-5)}.backlink-item{text-align:left;border:none;border-left:2px solid var(--border);width:100%;padding:var(--s-2) var(--s-3);margin-bottom:var(--s-2);cursor:pointer;transition:border-color var(--m-1);background:0 0;display:block}.backlink-item:hover{border-color:var(--brand)}.backlink-title{font:500 13px/1.4 var(--font-sans);color:var(--ink-2)}.backlink-item:hover .backlink-title{color:var(--brand)}.backlink-excerpt{font:400 11px/1.4 var(--font-sans);color:var(--ink-4);margin-top:2px}.comments-section{margin-top:var(--s-5);padding-top:var(--s-5);border-top:1px solid var(--border)}.comments-heading{font:600 16px/1 var(--font-sans);color:var(--ink);margin-bottom:var(--s-4)}.comment-item{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);padding:var(--s-4);margin-bottom:var(--s-3)}.comment-meta{align-items:center;gap:var(--s-2);margin-bottom:var(--s-2);display:flex}.comment-avatar{border-radius:var(--r-full);background:linear-gradient(135deg, var(--brand), var(--brand-2));width:28px;height:28px;font:600 12px/1 var(--font-sans);color:#fff;justify-content:center;align-items:center;display:flex}.comment-nick{font:600 14px/1 var(--font-sans);color:var(--ink)}.comment-date{font:400 11px/1 var(--font-mono);color:var(--ink-5);margin-left:auto}.comment-delete-btn{cursor:pointer;font:400 12px/1 var(--font-sans);color:var(--danger);border-radius:var(--r-1);transition:background var(--m-1);background:0 0;border:none;padding:2px 6px}.comment-delete-btn:hover{background:var(--danger-soft)}.comment-body{font:400 14px/1.6 var(--font-sans);color:var(--ink-2)}.comments-empty{font:400 13px/1 var(--font-sans);color:var(--ink-5);padding:var(--s-4) 0}.comment-form{gap:var(--s-2);margin-top:var(--s-4);flex-direction:column;display:flex}.comment-input{font:400 14px/1 var(--font-sans);color:var(--ink);background:var(--paper);border:1px solid var(--border);border-radius:var(--r-2);padding:10px var(--s-3);transition:border-color var(--m-1);outline:none}.comment-input:focus{border-color:var(--ink-5)}.comment-input--body{resize:none;line-height:1.5}.comment-form-footer{align-items:center;gap:var(--s-2);display:flex}.comment-char{font:400 11px/1 var(--font-mono);color:var(--ink-5);margin-left:auto}.comment-error{font:400 12px/1 var(--font-sans);color:var(--danger)}.comment-submit{font:500 13px/1 var(--font-sans);color:#fff;background:var(--ink);border-radius:var(--r-2);padding:9px var(--s-4);cursor:pointer;transition:opacity var(--m-1);border:none}.comment-submit:disabled{opacity:.4;cursor:default}.comment-submit:not(:disabled):hover{opacity:.8}.admin-toast{bottom:var(--s-5);right:var(--s-5);z-index:9999;background:var(--ink);color:var(--bg);font:500 12px/1 var(--font-mono);padding:var(--s-2) var(--s-3);border-radius:var(--r-2);box-shadow:var(--sh-2);position:fixed}.admin-toast.error{background:var(--danger)}.admin-input-box{gap:var(--s-2);margin-bottom:var(--s-2);align-items:center;display:flex}.admin-secret-input{font:400 13px/1 var(--font-mono);color:var(--ink);background:var(--paper);border:1px solid var(--border);border-radius:var(--r-2);outline:none;flex:1;padding:7px 10px}.admin-input-confirm,.admin-input-cancel{font:500 12px/1 var(--font-sans);border-radius:var(--r-2);cursor:pointer;border:1px solid;padding:7px 12px}.admin-input-confirm{background:var(--ink);color:var(--bg);border-color:var(--ink)}.admin-input-cancel{color:var(--ink-3);border-color:var(--border);background:0 0}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skel{background:linear-gradient(90deg, var(--paper-2) 0%, var(--paper-3) 50%, var(--paper-2) 100%);border-radius:var(--r-3);background-size:200% 100%;animation:1.5s infinite shimmer}.skel-card{width:100%;height:180px}.confirm-overlay{z-index:9999;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-box{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-4);padding:var(--s-5) var(--s-5) var(--s-4);min-width:240px;box-shadow:var(--sh-3);text-align:center}.confirm-msg{font:400 14px/1.5 var(--font-sans);color:var(--ink-2);margin:0 0 var(--s-4)}.confirm-btns{gap:var(--s-2);justify-content:center;display:flex}.confirm-btn{font:500 12px/1 var(--font-sans);padding:8px var(--s-4);border-radius:var(--r-2);cursor:pointer;transition:opacity var(--m-1);border:1px solid}.confirm-btn--ok{color:#fff;background:var(--danger);border-color:var(--danger)}.confirm-btn--cancel{color:var(--ink-3);border-color:var(--border);background:0 0}.tag-page{max-width:var(--frame-max);padding:var(--s-5) var(--page-px);margin:0 auto}.tag-hero{margin-bottom:var(--s-5)}.tag-hero-symbol{font:700 80px/1 var(--font-mono);color:var(--brand);opacity:.15}.tag-hero-name{font:700 40px/1.1 var(--font-sans);letter-spacing:-.025em;color:var(--ink);margin-top:-16px}.tag-hero-count{font:400 14px/1 var(--font-mono);color:var(--ink-4);margin-top:var(--s-2)}.graph-view{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.gv-header{align-items:center;gap:var(--s-3);padding:var(--s-3) var(--page-px);border-bottom:1px solid var(--border);display:flex}.gv-back{border:1px solid var(--border);border-radius:var(--r-2);padding:6px var(--s-3);font:400 13px/1 var(--font-sans);color:var(--ink-3);cursor:pointer;transition:border-color var(--m-1);background:0 0}.gv-back:hover{border-color:var(--brand);color:var(--brand)}.gv-title{font:600 14px/1 var(--font-mono);letter-spacing:.06em;color:var(--ink)}.gv-count{font:400 11px/1 var(--font-mono);color:var(--ink-5);margin-left:auto}.gv-canvas{flex:1;overflow:hidden}.gv-svg{width:100%;height:100%}.gv-edge{stroke:var(--border);stroke-width:1px;opacity:.6}.gv-node{cursor:pointer;transition:r .1s}.gv-node:hover{filter:brightness(1.2)}.recent-section{padding:var(--s-3) 0}.recent-label{font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-5);margin-bottom:var(--s-2);padding:0 var(--s-3)}.recent-item{align-items:center;gap:var(--s-2);padding:var(--s-1) var(--s-3);cursor:pointer;transition:background var(--m-1);border-radius:var(--r-2);display:flex}.recent-item:hover{background:var(--paper-2)}.recent-item-title{font:400 12px/1.3 var(--font-sans);color:var(--ink-2);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.recent-item-time{font:400 10px/1 var(--font-mono);color:var(--ink-5);flex-shrink:0}.tag-cloud{padding:var(--s-3)}.tag-cloud-head{font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-5);margin-bottom:var(--s-2)}.tag-cloud-wrap{gap:var(--s-1);flex-wrap:wrap;display:flex}.tag-cloud-chip{font:500 10px/1 var(--font-mono);color:var(--ink-4);background:var(--paper-3);border-radius:var(--r-full);cursor:pointer;transition:all var(--m-1);border:1px solid #0000;padding:4px 8px}.tag-cloud-chip:hover{color:var(--brand);border-color:var(--brand-soft)}.tag-cloud-chip.active{background:var(--ink);color:var(--bg)}.cal-wrap{padding:var(--s-3)}.cal-head{font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-5);margin-bottom:var(--s-2)}.cal-grid{gap:2px;display:flex}.cal-week{flex-direction:column;gap:2px;display:flex}.cal-cell{background:var(--paper-3);cursor:pointer;border-radius:2px;width:10px;height:10px;transition:opacity .1s}.cal-cell:hover{opacity:.8}.cal-cell--1{background:#4f46e533}.cal-cell--2{background:#4f46e566}.cal-cell--3{background:#4f46e5a6}.cal-cell--4{background:var(--brand)}html[data-theme=dark] .cal-cell--1{background:#818cf833}html[data-theme=dark] .cal-cell--2{background:#818cf866}html[data-theme=dark] .cal-cell--3{background:#818cf8a6}html[data-theme=dark] .cal-cell--4{background:var(--brand)}.sync-indicator{align-items:center;gap:var(--s-1);font:400 10px/1 var(--font-mono);color:var(--ink-5);cursor:pointer;border-radius:var(--r-2);transition:background var(--m-1);padding:4px 8px;display:inline-flex}.sync-indicator:hover{background:var(--paper-2)}.sync-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.sync-dot--fresh{background:var(--success)}.sync-dot--stale{background:var(--warning)}.sync-dot--old{background:var(--ink-5)}.bookmark-btn{cursor:pointer;color:var(--ink-5);transition:color var(--m-1), transform var(--m-1);background:0 0;border:none;padding:4px;font-size:14px;line-height:1}.bookmark-btn:hover{color:var(--warning);transform:scale(1.1)}.bookmark-btn--active{color:var(--warning)!important}.read-progress{background:linear-gradient(90deg, var(--brand), var(--brand-2));z-index:99;height:3px;transition:width .1s linear;position:fixed;top:64px;left:0}.is-focus .top-nav .top-nav-link{opacity:0;pointer-events:none}.is-focus .hero,.is-focus .cat-bar{display:none}.bottom-tab-bar{background:var(--paper);border-top:1px solid var(--border);z-index:100;grid-template-columns:repeat(4,1fr);height:56px;display:none;position:fixed;bottom:0;left:0;right:0}.tab-btn{cursor:pointer;font:500 9px/1 var(--font-mono);color:var(--ink-4);transition:color var(--m-1);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;display:flex}.tab-btn.active{color:var(--brand)}.tab-btn-icon{font-size:18px}@media (width<=640px){.bottom-tab-bar{display:grid}html{padding-bottom:56px}.top-nav .top-nav-link{display:none}.hero-h1{font-size:32px}.post-layout{padding:var(--s-4)}.card-grid{padding:var(--s-3);gap:var(--s-3)}.page-px{--page-px:16px}}.admin-toast-enter-active,.admin-toast-leave-active{transition:opacity var(--m-2), transform var(--m-2)}.admin-toast-enter-from,.admin-toast-leave-to{opacity:0;transform:translateY(8px)}.confirm-modal-enter-active,.confirm-modal-leave-active{transition:opacity var(--m-2)}.confirm-modal-enter-from,.confirm-modal-leave-to{opacity:0}.page-fade-enter-active,.page-fade-leave-active{transition:opacity var(--m-2)}.page-fade-enter-from,.page-fade-leave-to{opacity:0}
