.site-header,#post-nav{padding:5% 10%}@media (max-width: 1000px){.site-header,#post-nav{padding:5% 5%}}article,.comments,article .post-content,.feature-image .post-content,.call-out,.posts .post-teaser,.site-footer{padding:8% 15%}@media (max-width: 1000px){article,.comments,article .post-content,.feature-image .post-content,.call-out,.posts .post-teaser,.site-footer{padding:12% 9.375%}}@media (max-width: 576px){article,.comments,article .post-content,.feature-image .post-content,.call-out,.posts .post-teaser,.site-footer{padding:8%}}.button{border-radius:0.3em;border:1px solid;display:inline-block;margin:1em 0;padding:0.5em 0.75em}.button-link:hover,a.button:hover{background:#35C5F0;border:1px solid #35C5F0;color:#fff;text-decoration:none}.body-link:hover,article a:hover,.posts .post-teaser p a:hover{text-decoration:underline;color:#0f9fca}.disabled{opacity:0.7}/*! normalize.css v3.0.2 | MIT License | git.io/normalize */html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:bold}dfn{font-style:italic}h1{font-size:2em;margin:0.67em 0}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace, monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0}input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{height:auto}input[type="search"]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid #c0c0c0;margin:0 2px;padding:0.35em 0.625em 0.75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:bold}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}.hll{background-color:#ffc}.c{color:#999988;font-style:italic}.err{color:#a61717;background-color:#e3d2d2}.k{color:#000000;font-weight:bold}.o{color:#000000;font-weight:bold}.cm{color:#999988;font-style:italic}.cp{color:#999999;font-weight:bold;font-style:italic}.c1{color:#999988;font-style:italic}.cs{color:#999999;font-weight:bold;font-style:italic}.gd{color:#000000;background-color:#fdd}.ge{color:#000000;font-style:italic}.gr{color:#a00}.gh{color:#999}.gi{color:#000000;background-color:#dfd}.go{color:#888}.gp{color:#555}.gs{font-weight:bold}.gu{color:#aaa}.gt{color:#a00}.kc{color:#000000;font-weight:bold}.kd{color:#000000;font-weight:bold}.kn{color:#000000;font-weight:bold}.kp{color:#000000;font-weight:bold}.kr{color:#000000;font-weight:bold}.kt{color:#445588;font-weight:bold}.m{color:#099}.s{color:#d01040}.na{color:teal}.nb{color:#0086B3}.nc{color:#445588;font-weight:bold}.no{color:teal}.nd{color:#3c5d5d;font-weight:bold}.ni{color:purple}.ne{color:#990000;font-weight:bold}.nf{color:#990000;font-weight:bold}.nl{color:#990000;font-weight:bold}.nn{color:#555}.nt{color:navy}.nv{color:teal}.ow{color:#000000;font-weight:bold}.w{color:#bbb}.mf{color:#099}.mh{color:#099}.mi{color:#099}.mo{color:#099}.sb{color:#d01040}.sc{color:#d01040}.sd{color:#d01040}.s2{color:#d01040}.se{color:#d01040}.sh{color:#d01040}.si{color:#d01040}.sx{color:#d01040}.sr{color:#009926}.s1{color:#d01040}.ss{color:#990073}.bp{color:#999}.vc{color:teal}.vg{color:teal}.vi{color:teal}.il{color:#099}*{margin:0;padding:0;box-sizing:border-box}figure{margin:0}.gist table tbody tr td{box-sizing:content-box}html{background:#f8f9fa}body{background:#f8f9fa}::selection{background:#E8F7FF}::-moz-selection{background:#E8F7FF}body{color:#333;font-family:"Source Sans Pro","Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",sans-serif;font-size:1.05em;word-wrap:break-word}h1,h2,h3,h4,h5,h6{font-family:"Source Sans Pro","Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",sans-serif;line-height:1.2;margin:0.67em 0}h1 a,h2 a,h3 a,h4 a,h5 a,h6 a{color:#333}h1{font-size:2.5em}h2{font-size:2em}h3{font-size:1.5em}h4{font-size:1.15em}blockquote{border-left:2px solid;padding:1em 1em}blockquote p:last-child,footer p:last-child{margin-bottom:0}table{table-layout:fixed;width:100%;word-wrap:break-word}td,th{padding:0.5em 1em;border:1px solid rgba(0,0,0,0.05);text-align:left}td{vertical-align:top}th{vertical-align:bottom}table,dl,blockquote,code,kbd,pre,samp{margin:1em 0}dt{font-weight:bold}dd{margin-left:2em}p,ol,ul,dl,.math-display{line-height:1.5;margin-bottom:1em}.math-display{display:inline-block;width:100%}li>ul,li>ol{margin-bottom:0;margin-left:1em}ol,ul{list-style-position:inside}hr{border:0;border-top:1px solid rgba(0,0,0,0.05);border-bottom:1px solid #fff;margin:1em 0}a{color:#35C5F0;text-decoration:none}.nav{list-style:none;margin:0;padding:0}iframe,img,embed,object,video{max-width:100%}img[align=left]{margin-right:3%}img[align=right]{margin-left:3%}.post-content>:last-child{margin-bottom:0}article,.comments{border-bottom:1px solid rgba(0,0,0,0.05);float:left;width:100%}article .subtitle{font-size:1.45em;font-weight:normal;margin:0}article header{margin-bottom:6%;text-align:center}article .footnotes{font-size:0.9em}header h1{margin:0}.meta,#post-nav p{color:rgba(51,51,51,0.5);font-size:0.9em;letter-spacing:0.1em;margin:0;text-transform:uppercase}.feature-image{padding:0%}.feature-image .post-link{color:#fff}.feature-image header{color:#fff;background-size:cover;margin-bottom:0;padding:6% 15%}.feature-image header .meta,.feature-image header #post-nav p,#post-nav .feature-image header p{color:rgba(255,255,255,0.7)}#post-nav{border-top:1px solid rgba(0,0,0,0.05);border-bottom:1px solid rgba(0,0,0,0.05);display:table;width:100%;table-layout:fixed}#post-nav .post-nav-post{display:table-cell;width:50%;height:120px;padding:1.5rem;text-align:center;vertical-align:middle;box-sizing:border-box}#post-nav .post-nav-post p{color:rgba(51,51,51,0.5);font-size:0.8em;letter-spacing:0.1em;margin:0 0 0.5em 0;text-transform:uppercase;line-height:1}#post-nav .post-nav-post a{font-weight:bold;color:#333;text-decoration:none;transition:color 0.2s ease;line-height:1.2;display:block}#post-nav .post-nav-post a:hover{color:#35C5F0}#post-nav .post-nav-post span{display:block;height:1.2em}#post-nav #previous-post{border-right:1px solid rgba(0,0,0,0.05)}.post-feature-image{text-align:center;margin:2rem 0}.post-feature-image img{max-width:100%;max-height:550px;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 8px rgba(0,0,0,0.1)}.call-out{display:inline-block;width:100%;background-color:#35C5F0;background-size:cover;font-size:1.2em;text-align:center;color:#FFF}.call-out p:last-child{margin-bottom:0}.call-out a{color:#09c}.posts-container{max-width:1200px;margin:0 auto;padding:60px 40px 0 40px}.posts-header{margin-bottom:60px}.posts-header .posts-title{font-size:2.5rem;font-weight:700;color:#000;margin:0 0 16px 0;letter-spacing:-0.5px;line-height:1.1}.posts-header .posts-subtitle{font-size:1.125rem;color:#666;font-weight:400;line-height:1.5;margin:0 0 40px 0}.posts-header .posts-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.posts-header .posts-categories .category-tag{font-size:0.9rem;color:#666;font-weight:500;text-decoration:none;margin-right:8px}.posts-header .posts-categories .category-tag:before{content:"#";color:#666;margin-right:2px}.posts-header .posts-categories .category-tag:hover{color:#000}.posts-grid{margin-top:60px}.post-card{padding:40px 0;border-bottom:1px solid #eee}.post-card:first-child{padding-top:0}.post-card:last-child{border-bottom:none}.post-card-category{margin-bottom:16px}.post-card-category .category-badge{color:#35C5F0;font-size:0.9rem;font-weight:600;text-decoration:none}.post-card-category .category-badge:hover{color:#0099CC}.post-card-header .post-card-title{margin:0 0 12px 0}.post-card-header .post-card-title .post-link{color:#000;text-decoration:none;font-size:1.75rem;font-weight:700;line-height:1.3;letter-spacing:-0.5px}.post-card-header .post-card-title .post-link:hover{color:#35C5F0}.post-card-header .post-card-subtitle{color:#666;font-size:1.125rem;line-height:1.5;margin:0 0 16px 0;font-weight:400}.post-card-footer .post-card-meta{display:flex;align-items:center;gap:12px;font-size:0.9rem;color:#999}.post-card-footer .post-card-meta .post-card-date{font-weight:400}.post-card-footer .post-card-meta .post-card-author{font-weight:500;color:#666}@media (max-width: 768px){.posts-container{padding:60px 20px 0 20px}.posts-header{margin-bottom:40px}.posts-header .posts-title{font-size:1.75rem;margin-bottom:12px}.posts-header .posts-subtitle{font-size:0.9rem;margin-bottom:24px}.posts-header .posts-categories{margin-bottom:32px;gap:6px}.posts-header .posts-categories .category-tag{font-size:0.8rem}.post-card{padding:32px 0}.post-card .post-card-header .post-card-title .post-link{font-size:1.25rem}.post-card .post-card-meta{flex-direction:column;align-items:flex-start;gap:4px}}.posts .post-teaser{width:100%;margin-bottom:0;display:inline-block;background-size:cover;border-bottom:1px solid rgba(0,0,0,0.05)}.posts .excerpt{margin-top:1em}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin:60px auto 80px auto;padding:0 40px;flex-wrap:wrap;max-width:1200px;width:100%}.pagination .pagination-btn{background:#333;color:white;padding:12px 16px;border-radius:4px;text-decoration:none;font-weight:500;font-size:0.875em;border:none;transition:background-color 0.2s ease;cursor:pointer}.pagination .pagination-btn:hover{background:#0099CC;color:white}.pagination .pagination-btn:disabled{background:#f5f5f5;color:#ccc;cursor:not-allowed}.pagination .pagination-numbers{display:flex;gap:4px;align-items:center;margin:0 16px}.pagination .pagination-number{background:transparent;color:#666;padding:8px 12px;border-radius:4px;text-decoration:none;font-weight:500;font-size:0.875em;transition:all 0.2s ease;border:1px solid #e5e5e5;cursor:pointer}.pagination .pagination-number:hover{background:#f5f5f5;color:#333}.pagination .pagination-current{background:#333;color:white;padding:8px 12px;border-radius:4px;font-weight:600;font-size:0.875em;border:1px solid #333}@media (max-width: 768px){.pagination{margin:40px auto 60px auto;padding:0 20px;gap:4px}.pagination .pagination-btn{padding:10px 12px;font-size:0.8em}.pagination .pagination-numbers{margin:0 8px}.pagination .pagination-number,.pagination .pagination-current{padding:6px 10px;font-size:0.8em}}@media (max-width: 480px){.pagination{margin:30px auto 50px auto;padding:0 15px}.pagination .pagination-btn{padding:8px 10px;font-size:0.75em}.pagination .pagination-numbers{margin:0 6px}.pagination .pagination-number,.pagination .pagination-current{padding:5px 8px;font-size:0.75em}}.tags-container{max-width:1200px;margin:0 auto;padding:0 20px}.tags-navigation{background:#f8f9fa;border-radius:12px;padding:2rem;margin-bottom:3rem;border:1px solid rgba(0,0,0,0.05)}.tags-navigation .tags-nav-title{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.tags-navigation .tag-list{display:flex;flex-wrap:wrap;gap:0.75rem;justify-content:center}.tags-navigation .tag-nav-item{display:inline-flex;align-items:center;padding:0.5rem 1rem;background:white;border:2px solid #35C5F0;border-radius:25px;color:#35C5F0;text-decoration:none;font-weight:500;transition:all 0.3s ease;font-size:0.9rem}.tags-navigation .tag-nav-item:hover{background:#35C5F0;color:white;transform:translateY(-2px);box-shadow:0 4px 12px rgba(53,197,240,0.3)}.tags-navigation .tag-nav-item .tag-count{margin-left:0.25rem;font-size:0.8rem;opacity:0.7}.tags-content .tag-section{margin-bottom:4rem}.tags-content .tag-section:last-child{margin-bottom:2rem}.tags-content .tag-title{color:#333;font-size:2rem;font-weight:700;margin-bottom:2rem;padding-bottom:0.75rem;border-bottom:3px solid #35C5F0;position:relative;display:flex;align-items:center;gap:0.5rem}.tags-content .tag-title .tag-hash{color:#35C5F0;font-weight:800}.tags-content .tag-title .tag-count-inline{font-size:1rem;color:rgba(51,51,51,0.6);font-weight:400;margin-left:auto}.tags-content .tag-title::after{content:'';position:absolute;bottom:-3px;left:0;width:60px;height:3px;background:linear-gradient(90deg, #35C5F0, #94e0f7);border-radius:2px}.tags-content .posts-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(350px, 1fr));gap:1.5rem;margin-top:2rem}.tags-content .tag-post-card{background:white;border:1px solid rgba(0,0,0,0.05);border-radius:12px;padding:1.5rem;transition:all 0.3s ease;position:relative;overflow:hidden}.tags-content .tag-post-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, #35C5F0, #94e0f7)}.tags-content .tag-post-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,0.1);border-color:#35C5F0}.tags-content .tag-post-card .post-title{margin:0 0 0.75rem 0;line-height:1.4}.tags-content .tag-post-card .post-title a{color:#333;text-decoration:none;font-weight:600;font-size:1.1rem;transition:color 0.3s ease}.tags-content .tag-post-card .post-title a:hover{color:#35C5F0}.tags-content .tag-post-card .post-meta{color:rgba(51,51,51,0.6);font-size:0.85rem;margin-bottom:0.75rem;display:flex;align-items:center}.tags-content .tag-post-card .post-meta time{font-weight:500}.tags-content .tag-post-card .post-meta::before{content:'📅';margin-right:0.5rem}.tags-content .tag-post-card .post-excerpt{color:rgba(51,51,51,0.8);font-size:0.9rem;line-height:1.5;margin-top:0.75rem;border-top:1px solid rgba(0,0,0,0.5);padding-top:0.75rem}@media (max-width: 768px){.tags-container{padding:0 15px}.tags-navigation{padding:1.5rem;margin-bottom:2rem}.tags-navigation .tags-nav-title{font-size:1.3rem;margin-bottom:1rem}.tags-navigation .tag-nav-item{font-size:0.8rem;padding:0.4rem 0.8rem}.tags-content .tag-title{font-size:1.5rem;flex-direction:column;align-items:flex-start;gap:0.25rem}.tags-content .tag-title .tag-count-inline{margin-left:0;font-size:0.9rem}.tags-content .posts-grid{grid-template-columns:1fr;gap:1rem}.tags-content .tag-post-card{padding:1.25rem}}@media (max-width: 480px){.tags-navigation .tag-list{gap:0.5rem}.tags-navigation .tag-nav-item{font-size:0.75rem;padding:0.35rem 0.7rem}.tags-content .tag-title{font-size:1.3rem}.tag-post-card{padding:1rem}.tag-post-card .post-title a{font-size:1rem}}.search h1,.search h2,.search h3,.search h4,.search h5{margin-bottom:0}.search a.search-link:hover{text-decoration:none;color:#333}.search #not-found{text-align:center;font-weight:bold}.site-header{background:#fff;border-bottom:1px solid rgba(0,0,0,0.05);display:inline-block;float:left;width:100%}.site-header a{color:#333}.site-header .avatar{height:2em;width:2em;float:left;margin-top:-3px;border-radius:0.2em;margin-right:1em}.site-header .site-title{float:left;font-weight:bold;font-size:1em;line-height:1.5}.site-header .site-nav ul{margin:0;padding:0;list-style:none;line-height:1.5;float:right;text-align:right}.site-header .site-nav li{display:inline;margin-right:1em;vertical-align:middle}.site-header .site-nav li:last-of-type{margin-right:0}@media (max-width: 1100px){.site-header .site-nav ul{display:inline-block;float:left;padding-top:8%;text-align:left;width:100%}}.site-header form{border:0;border-bottom:2px solid #666;outline:0}.site-header form *:focus{outline:none}.site-header form input[type=text]{box-sizing:border-box;border:0;outline:0;color:#666}.site-header form input::-moz-placeholder{color:#666;opacity:1}.site-header form input:-ms-input-placeholder,.site-header form input::-webkit-input-placeholder{color:#666}.site-header form button{border:none;font-size:0.9em;background-color:#fff;color:#666}.site-footer{display:inline-block;text-align:center;width:100%;color:gray;font-size:0.9em}.tags{width:100%;margin-top:1em}.tags .tag{margin-right:0.5em;color:#35C5F0}#post-nav{width:100%;border-bottom:1px solid rgba(0,0,0,0.05);float:left;text-align:center}#post-nav i{vertical-align:middle}#post-nav a{width:100%;display:inline-block;padding:0}#post-nav .post-nav-post+.post-nav-post{margin-top:1em}:root{--v-white-100: #ffffff;--v-white-200: #fafafa;--v-gray-1000: #171717;--v-gray-900: #666666;--v-gray-800: #7d7d7d;--v-gray-700: #8f8f8f;--v-gray-600: #a8a8a8;--v-gray-500: #c9c9c9;--v-gray-400: #eaeaea;--v-purple-700: #8e4ec6;--v-purple-900: #7820bc;--v-red-700: #e5484d;--v-red-900: #cb2a2f;--v-amber-700: #f5b047;--v-amber-900: #a35200;--v-green-700: #45a557;--v-green-900: #297a3a;--v-blue-600: #52aeff;--v-blue-700: #0072f5;--v-blue-900: #0068d6;--v-background: #282c34;--monospace: "GeistMono", "Soehne Mono", "Menlo", "Monaco", "Consolas", "Liberation Mono", monospace;--vercel-code-bg: #0f1117;--vercel-code-surface: #10121a;--vercel-code-border: rgba(94, 102, 126, 0.4);--vercel-code-text: #f5f7fb;--vercel-code-muted: #9ba7be;--vercel-code-keyword: var(--v-purple-700);--vercel-code-func: var(--v-blue-600);--vercel-code-string: var(--v-red-700);--vercel-code-number: var(--v-amber-700);--vercel-code-operator: var(--v-blue-600);--vercel-code-added: var(--v-green-700);--vercel-code-removed: var(--v-red-700);--vercel-inline-code-bg: rgba(15, 23, 42, 0.06);--vercel-inline-code-hover-bg: rgba(15, 23, 42, 0.1);--vercel-inline-code-border: rgba(15, 23, 42, 0.12);--vercel-inline-code-shadow: 0 10px 24px -20px rgba(15, 23, 42, 0.35);--vercel-inline-code-text: #121826;--vercel-inline-code-font-size: 0.84em;--vercel-inline-code-padding-y: 0.16em;--vercel-inline-code-padding-x: 0.42em;--vercel-inline-code-radius: 5px}html,body{background-color:#ffffff !important}.home{background-color:#ffffff !important}.home{border-top:none !important}header,.header,#header{border-bottom:none !important;box-shadow:none !important}.posts-container{border-top:none !important}article,main,.main{border-top:none !important}.ohouse-post-container{max-width:960px;margin:0 auto;padding:0 40px;background-color:#fff}.ohouse-post{padding:60px 0}.ohouse-post-header{margin-bottom:60px}.ohouse-post-categories{margin-bottom:20px}.ohouse-category-tag{display:inline-block;background-color:#f5f5f5;color:#666;padding:8px 16px;border-radius:4px;font-size:0.875rem;font-weight:500;margin-right:8px;text-decoration:none;transition:all 0.2s ease}.ohouse-category-tag:hover{background-color:#e9e9e9;color:#333}.ohouse-post-title{font-size:2.5rem;font-weight:700;line-height:1.2;margin:0 0 20px 0;color:#000;letter-spacing:-0.02em}.ohouse-post-subtitle{font-size:1.25rem;font-weight:400;color:#666;margin:0 0 30px 0;line-height:1.5}.ohouse-post-meta{display:flex;align-items:center;gap:16px;font-size:0.875rem;color:#999}.ohouse-post-date{font-weight:500}.ohouse-post-author{font-weight:500;color:#666}.post-category{margin-bottom:1rem}.category-tag{display:inline-block;background-color:#35C5F0;color:white;padding:0.4rem 1rem;border-radius:20px;font-size:0.85rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-right:0.8rem}.post-title{font-size:2.5rem;font-weight:700;line-height:1.2;margin:1rem 0;color:#333;letter-spacing:-0.02em}.post-subtitle{font-size:1.25rem;font-weight:400;color:#666;margin:0.5rem 0 1.5rem 0;line-height:1.4}.post-meta{display:flex;align-items:center;gap:1.5rem;font-size:0.9rem;color:#888;margin-top:1.5rem}.post-date{font-weight:500}.post-author{font-weight:500}.post-author::before{content:"•";margin-right:0.5rem;color:#ddd}.ohouse-post-content{line-height:1.8;font-size:1.125rem;color:#333;margin-bottom:80px}.ohouse-post-content h1,.ohouse-post-content h2,.ohouse-post-content h3,.ohouse-post-content h4,.ohouse-post-content h5,.ohouse-post-content h6{font-weight:700;margin:60px 0 24px 0;color:#000;line-height:1.3}.ohouse-post-content h1{font-size:2rem;margin-top:80px}.ohouse-post-content h2{font-size:1.75rem;margin-top:60px}.ohouse-post-content h3{font-size:1.5rem;margin-top:48px}.ohouse-post-content p{margin:24px 0;line-height:1.8}.ohouse-post-content ul,.ohouse-post-content ol{margin:24px 0;padding-left:24px}.ohouse-post-content li{margin:8px 0;line-height:1.7}.ohouse-post-content blockquote{border-left:4px solid #ddd;margin:40px 0;padding:20px 24px;background-color:#f9f9f9;color:#666;font-style:normal;font-size:1rem}.ohouse-post-content :not(pre)>code{background:var(--vercel-inline-code-bg);padding:var(--vercel-inline-code-padding-y) var(--vercel-inline-code-padding-x);border-radius:var(--vercel-inline-code-radius);font-size:var(--vercel-inline-code-font-size);color:var(--vercel-inline-code-text);font-family:var(--monospace);border:1px solid var(--vercel-inline-code-border);box-shadow:var(--vercel-inline-code-shadow);transition:transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease}.ohouse-post-content :not(pre)>code:hover{transform:translateY(-1px);background-color:var(--vercel-inline-code-hover-bg);box-shadow:0 16px 32px -26px rgba(15,23,42,0.42)}.ohouse-post-content :not(pre)>code::selection{background-color:rgba(82,174,255,0.22);color:var(--vercel-inline-code-text)}.ohouse-post-content pre code::selection,.ohouse-post-content pre span::selection,.ohouse-post-content pre::selection{background-color:rgba(82,174,255,0.28);color:var(--vercel-code-text)}.ohouse-post-content :not(pre)>code::-moz-selection{background-color:rgba(82,174,255,0.22);color:var(--vercel-inline-code-text)}.ohouse-post-content pre code::-moz-selection,.ohouse-post-content pre span::-moz-selection,.ohouse-post-content pre::-moz-selection{background-color:rgba(82,174,255,0.28);color:var(--vercel-code-text)}.ohouse-post-content pre{position:relative;background:linear-gradient(160deg, rgba(18,20,27,0.96) 0%, rgba(14,16,22,0.98) 55%, rgba(12,14,20,0.99) 100%);padding:28px 32px;border-radius:12px;overflow-x:auto;margin:40px 0;border:1px solid var(--vercel-code-border);font-family:var(--monospace);font-size:0.95rem;line-height:1.65;color:var(--vercel-code-text);box-shadow:0 32px 72px -38px rgba(9,11,16,0.95);font-variant-ligatures:none}.ohouse-post-content pre::before{content:"";position:absolute;inset:1px;border-radius:inherit;pointer-events:none;background:linear-gradient(140deg, rgba(82,174,255,0.14), rgba(255,255,255,0));opacity:0.55}.ohouse-post-content pre code,.ohouse-post-content pre span{background:transparent;padding:0;border:0;color:inherit;font-size:inherit;font-family:inherit}.ohouse-post-content pre .c,.ohouse-post-content pre .ch,.ohouse-post-content pre .cd,.ohouse-post-content pre .cm,.ohouse-post-content pre .cpf,.ohouse-post-content pre .c1,.ohouse-post-content pre .cs{color:var(--vercel-code-muted);font-style:italic}.ohouse-post-content pre .k,.ohouse-post-content pre .kd,.ohouse-post-content pre .kn,.ohouse-post-content pre .kp,.ohouse-post-content pre .kr,.ohouse-post-content pre .kt{color:var(--vercel-code-keyword)}.ohouse-post-content pre .nn,.ohouse-post-content pre .nc,.ohouse-post-content pre .nf,.ohouse-post-content pre .fm{color:var(--vercel-code-func)}.ohouse-post-content pre .nb,.ohouse-post-content pre .bp,.ohouse-post-content pre .nv,.ohouse-post-content pre .vc,.ohouse-post-content pre .vg,.ohouse-post-content pre .vi{color:var(--vercel-code-text)}.ohouse-post-content pre .s,.ohouse-post-content pre .sb,.ohouse-post-content pre .sc,.ohouse-post-content pre .s1,.ohouse-post-content pre .s2,.ohouse-post-content pre .sd,.ohouse-post-content pre .sh,.ohouse-post-content pre .sx,.ohouse-post-content pre .sr,.ohouse-post-content pre .ss,.ohouse-post-content pre .si,.ohouse-post-content pre .se{color:var(--vercel-code-string)}.ohouse-post-content pre .m,.ohouse-post-content pre .mb,.ohouse-post-content pre .mf,.ohouse-post-content pre .mh,.ohouse-post-content pre .mi,.ohouse-post-content pre .il,.ohouse-post-content pre .mo{color:var(--vercel-code-number)}.ohouse-post-content pre .o,.ohouse-post-content pre .ow,.ohouse-post-content pre .p{color:var(--vercel-code-operator)}.ohouse-post-content pre .gd{color:var(--vercel-code-removed)}.ohouse-post-content pre .gi{color:var(--vercel-code-added)}.ohouse-post-content img{max-width:100%;height:auto;margin:40px 0;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.1)}.ohouse-post-footer{padding:40px 0;border-top:1px solid #f0f0f0;margin-top:60px}.ohouse-post-tags{display:flex;align-items:center;flex-wrap:wrap;gap:12px}.ohouse-tags-label{font-size:0.875rem;font-weight:500;color:#666;margin-right:8px}.ohouse-tag{background-color:#f5f5f5;color:#666;padding:8px 16px;border-radius:20px;font-size:0.875rem;font-weight:400;text-decoration:none;transition:all 0.2s ease}.ohouse-tag:hover{background-color:#e9e9e9;color:#333}.ohouse-post-feature-image{margin:60px 0}.ohouse-post-feature-image img{width:100%;height:auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.1)}@media (max-width: 768px){.ohouse-post-container{padding:0 20px}.ohouse-post{padding:40px 0}.ohouse-post-header{margin-bottom:40px}.ohouse-post-title{font-size:1.75rem;margin-bottom:16px}.ohouse-post-subtitle{font-size:1.125rem;margin-bottom:24px}.ohouse-post-content{font-size:1rem;margin-bottom:60px}.ohouse-post-content h1{font-size:1.5rem;margin-top:60px}.ohouse-post-content h2{font-size:1.375rem;margin-top:48px}.ohouse-post-content h3{font-size:1.25rem;margin-top:40px}.ohouse-post-meta{flex-direction:column;align-items:flex-start;gap:8px}.ohouse-post-tags{flex-direction:column;align-items:flex-start;gap:8px}}.posts-container{max-width:1200px;margin:0 auto;padding:0 40px;padding-top:60px}.posts-header{margin-bottom:60px}.posts-title{font-size:2.5rem;font-weight:700;color:#000;margin:0 0 16px 0;letter-spacing:-0.5px;line-height:1.1}.posts-subtitle{font-size:1.125rem;color:#666;font-weight:400;line-height:1.5;margin:0 0 40px 0}.posts-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.posts-categories .category-tag{font-size:0.9rem;color:#666;font-weight:500;text-decoration:none;margin-right:8px}.posts-categories .category-tag:before{content:"#";color:#666;margin-right:2px}.posts-categories .category-tag:hover{color:#000}.posts-grid{margin-top:60px}.post-card{padding:40px 0;border-bottom:1px solid #eee;display:flex;gap:40px;align-items:flex-start}.post-card:first-child{padding-top:0}.post-card:last-child{border-bottom:none}.post-card-content{flex:1}.post-card-image{flex-shrink:0;width:200px;height:150px;border-radius:8px;overflow:hidden}.post-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}.post-card-image:hover img{transform:scale(1.05)}.post-card.no-image{display:block}.post-card.no-image .post-card-content{flex:none}.post-card-category{margin-bottom:16px}.category-badge{color:#35C5F0;font-size:0.9rem;font-weight:600;text-decoration:none}.category-badge:hover{color:#0099CC}.post-card-title{margin:0 0 12px 0;line-height:1.3}.post-card-title a{color:#000;text-decoration:none;font-size:1.75rem;font-weight:700;letter-spacing:-0.5px;line-height:1.3}.post-card-title a:hover{color:#35C5F0}.post-card-subtitle{color:#666;font-size:1.125rem;margin:0 0 16px 0;line-height:1.5;font-weight:400}.post-card-meta{display:flex;align-items:center;gap:12px;font-size:0.9rem;color:#999}.post-card-date{font-weight:400}.post-card-author{font-weight:500;color:#666}@media (max-width: 768px){.posts-container{padding:0 1.25rem}.posts-header{margin-bottom:40px}.posts-title{font-size:1.75rem;margin-bottom:12px}.posts-subtitle{font-size:0.9rem;margin-bottom:24px}.posts-categories{margin-bottom:32px;gap:6px}.posts-categories .category-tag{font-size:0.8rem}.post-card{padding:32px 0;flex-direction:column;gap:20px}.post-card-image{width:100%;height:200px;order:-1}.post-card-title a{font-size:1.25rem}.post-card-meta{flex-direction:column;align-items:flex-start;gap:4px}}.home .posts-container{font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif}.posts-categories .category-tag{background:none !important;color:#666 !important;padding:0 !important;border-radius:0 !important;text-transform:none !important;letter-spacing:normal !important;font-size:0.9rem !important;font-weight:500 !important;margin-right:16px !important}.posts-categories .category-tag:before{content:"#" !important;color:#666 !important;margin-right:4px !important}.posts-categories .category-tag:hover{color:#000 !important;background:none !important}.posts-header{text-align:left !important}.post-card-header{text-align:left !important}.post-card-title{text-align:left !important}.post-card-meta{text-align:left !important}
