:root{--bg: #fbfbfd;--bg-alt: #ffffff;--bg-soft: #f5f5f7;--border: rgba(0, 0, 0, .08);--fg: #1d1d1f;--fg-secondary: #424245;--fg-muted: #86868b;--accent: #0071e3;--accent-hover: #0077ed;--radius: 18px;--radius-sm: 10px}@media(prefers-color-scheme:dark){:root{--bg: #000000;--bg-alt: #0a0a0a;--bg-soft: #1d1d1f;--border: rgba(255, 255, 255, .1);--fg: #f5f5f7;--fg-secondary: #d2d2d7;--fg-muted: #86868b;--accent: #2997ff;--accent-hover: #5dade2}}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,SF Pro Display,Apple SD Gothic Neo,system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.5;letter-spacing:-.022em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}.site-header{position:sticky;top:0;z-index:50;background:#fbfbfdb8;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border)}@media(prefers-color-scheme:dark){.site-header{background:#000000b8}}.header-inner{max-width:1200px;margin:0 auto;padding:0 1.75rem;height:48px;display:flex;align-items:center;justify-content:space-between}.logo{font-size:1.02rem;font-weight:600;color:var(--fg);letter-spacing:-.02em}.logo:hover{color:var(--fg)}.nav{display:flex;gap:.25rem}.nav a{color:var(--fg-secondary);font-size:.82rem;padding:.25rem .75rem;font-weight:400;letter-spacing:-.01em}.nav a:hover{color:var(--fg)}main{display:block}.section{padding:5.5rem 1.75rem}.section.alt{background:var(--bg-soft)}.section-inner{max-width:1200px;margin:0 auto}.section-inner.narrow{max-width:780px}.section-inner.reading{max-width:680px}.hero{padding:7rem 1.75rem 4.5rem;text-align:center}.hero h1{font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:700;line-height:1.06;letter-spacing:-.035em;margin:0 auto 1.25rem;max-width:14ch}.hero .lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--fg-secondary);font-weight:400;max-width:34ch;margin:0 auto;line-height:1.4}.hero .cta{margin-top:2rem;display:inline-flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.cta-btn{display:inline-block;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border-radius:999px;font-size:.95rem;font-weight:500;letter-spacing:-.01em;transition:background .2s,transform .12s}.cta-btn:hover{background:var(--accent-hover);color:#fff}.cta-btn:active{transform:scale(.98)}.cta-btn.secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}.section-label{font-size:.78rem;font-weight:600;color:var(--fg-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}.section-title{font-size:clamp(1.9rem,3.5vw,2.75rem);font-weight:700;line-height:1.15;letter-spacing:-.025em;margin:0 0 .75rem}.section-desc{font-size:1.08rem;color:var(--fg-secondary);margin:0 0 2.5rem;max-width:48ch}.post-list{list-style:none;padding:0;margin:0}.post-list li{border-top:1px solid var(--border)}.post-list li:last-child{border-bottom:1px solid var(--border)}.post-list a{display:flex;flex-direction:column;padding:1.75rem 0;color:inherit;transition:opacity .2s}.post-list a:hover{opacity:.65;color:inherit}.post-list .post-title{font-size:1.4rem;font-weight:600;letter-spacing:-.02em;line-height:1.3;margin:0 0 .4rem;color:var(--fg)}.post-list .post-desc{color:var(--fg-secondary);font-size:.98rem;margin:0 0 .5rem;line-height:1.45}.post-list .post-meta{color:var(--fg-muted);font-size:.82rem;letter-spacing:-.005em}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.cat-item{padding:1.5rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);color:inherit;transition:transform .25s cubic-bezier(.2,.8,.2,1),border-color .2s}.cat-item:hover{transform:translateY(-2px);border-color:var(--fg-muted);color:inherit}.cat-item .cat-icon{font-size:1.7rem;line-height:1;margin-bottom:.75rem}.cat-item .cat-name{font-weight:600;font-size:1.02rem;color:var(--fg)}.cat-item .cat-desc{color:var(--fg-muted);font-size:.85rem;margin-top:.2rem}article h1{font-size:clamp(2rem,3.4vw,2.75rem);font-weight:700;line-height:1.15;letter-spacing:-.028em;margin:0 0 1.25rem;color:var(--fg)}article h2{font-size:1.65rem;font-weight:700;line-height:1.25;letter-spacing:-.022em;margin:3rem 0 1rem;color:var(--fg);padding-bottom:.5rem;border-bottom:1px solid var(--border)}article h3{font-size:1.25rem;font-weight:700;margin:2.25rem 0 .75rem;color:var(--fg)}article p{margin:1rem 0;font-size:1.08rem;line-height:1.78;color:var(--fg)}article ul,article ol{padding-left:1.4rem;margin:1rem 0}article li{margin:.5rem 0;line-height:1.72;color:var(--fg);font-size:1.05rem}article li::marker{color:var(--accent)}article strong{color:var(--accent);font-weight:700}article em{color:var(--fg);font-style:normal;background:linear-gradient(180deg,transparent 62%,rgba(0,113,227,.18) 62%);padding:0 .15rem;font-weight:600}article a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}article a:hover{text-decoration-thickness:2px}.post-meta-row{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;color:var(--fg-muted);font-size:.9rem;margin:0 0 2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.view-count-badge{font-size:.85rem;color:var(--fg-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.view-count-badge .view-count-num{font-weight:600;color:var(--fg-secondary)}code{background:var(--bg-soft);padding:.15rem .42rem;border-radius:6px;font-size:.88em;font-family:SF Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,monospace;color:var(--fg)}pre{background:#1d1d1f;color:#f5f5f7;padding:1.25rem 1.5rem;border-radius:var(--radius-sm);overflow-x:auto;font-size:.88em;line-height:1.6;margin:1.5rem 0}@media(prefers-color-scheme:dark){pre{background:var(--bg-soft)}}pre code{background:transparent;padding:0;color:inherit}blockquote{border-left:4px solid var(--accent);background:var(--bg-soft);padding:1rem 1.25rem;margin:1.75rem 0;color:var(--fg);font-style:normal;border-radius:0 12px 12px 0}blockquote p{margin:.35rem 0;color:inherit;font-size:1rem}blockquote strong{color:var(--accent)}table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.98rem;border:1px solid var(--border);border-radius:12px;overflow:hidden}th,td{border-bottom:1px solid var(--border);padding:.9rem 1.1rem;text-align:left}th{font-weight:700;color:var(--fg);letter-spacing:-.01em;background:var(--bg-soft);font-size:.95rem}td{color:var(--fg)}tr:last-child td{border-bottom:0}tr:hover td{background:var(--bg-soft)}article img{max-width:100%;height:auto;border-radius:var(--radius-sm);margin:1.75rem 0}hr{border:0;border-top:1px solid var(--border);margin:2.5rem 0}.pill{display:inline-block;background:var(--bg-soft);color:var(--fg-secondary);padding:.3rem .85rem;border-radius:999px;font-size:.82rem;font-weight:500;margin:0 .3rem .3rem 0;letter-spacing:-.005em;transition:background .15s,color .15s}a.pill:hover{background:var(--fg);color:var(--bg)}.site-footer{padding:3rem 1.75rem 4rem;border-top:1px solid var(--border);color:var(--fg-muted);font-size:.78rem;letter-spacing:-.005em}.footer-inner{max-width:1200px;margin:0 auto}.footer-links{display:flex;flex-wrap:wrap;gap:.25rem 1.5rem;margin-bottom:.75rem}.footer-links a{color:var(--fg-secondary);font-size:.82rem}.footer-links a:hover{color:var(--fg)}.footer-copy{color:var(--fg-muted)}.table-wrap,article table{max-width:100%}article{overflow-wrap:break-word;word-break:keep-all}article table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}@media(min-width:640px){article table{display:table;overflow-x:visible}}@media(max-width:1024px){.header-inner{padding:0 1.5rem}.section{padding:4.5rem 1.5rem}.hero{padding:5rem 1.5rem 3.5rem}}@media(max-width:640px){.section{padding:3.5rem 1.25rem}.hero{padding:4rem 1.25rem 2.5rem}.hero h1{max-width:none;font-size:2rem;line-height:1.12}.hero .lead{font-size:1rem;line-height:1.45}.section-title{font-size:1.6rem;line-height:1.2}.section-desc{font-size:.98rem}.post-list a{padding:1.4rem 0}.post-list .post-title{font-size:1.15rem}.post-list .post-desc{font-size:.92rem}.post-list .post-meta{font-size:.78rem}.header-inner{padding:0 1rem;height:46px}.logo{font-size:.98rem}.nav a{padding:.25rem .55rem;font-size:.82rem}.cta-btn{padding:.65rem 1.25rem;font-size:.9rem}.cat-item{padding:1.2rem}article h1{font-size:1.75rem;line-height:1.2}article h2{font-size:1.3rem;margin-top:2.25rem}article h3{font-size:1.1rem}article p,article li{font-size:1rem;line-height:1.72}blockquote{padding:.85rem 1rem}pre{padding:1rem;font-size:.82em;margin:1.25rem -.25rem;border-radius:8px}th,td{padding:.7rem .75rem;font-size:.88rem}.site-footer{padding:2.5rem 1.25rem 3rem}.footer-links{gap:.2rem 1rem}}@media(max-width:380px){.container{padding:1.5rem .95rem 3rem}.section{padding:2.75rem .95rem}.hero{padding:3rem .95rem 2rem}.hero h1{font-size:1.75rem}.hero .cta{flex-direction:column;gap:.5rem}.cta-btn{width:100%;text-align:center}.header-inner{padding:0 .85rem}.nav{gap:0}.nav a{padding:.25rem .4rem;font-size:.76rem}.logo{font-size:.92rem}.cat-grid{grid-template-columns:1fr}article h1{font-size:1.55rem}article h2{font-size:1.2rem}article p,article li{font-size:.96rem}}@media(min-width:641px)and (max-width:820px){.section{padding:4rem 1.5rem}.hero{padding:5rem 1.5rem 3rem}}@media(min-width:1441px){.container{max-width:780px}.container.wide{max-width:1040px}article p,article li{font-size:1.1rem}}@media(min-width:1920px){.container.wide{max-width:1120px}}@media print{.site-header,.site-footer,.cta{display:none}body{background:#fff;color:#000}article{max-width:100%}}@media(hover:none){.card:hover,.cat-item:hover{transform:none}a:hover{text-decoration:underline}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}
