@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";
:root{--color-black:#1a1a1a;--color-gray-900:#2d2d2d;--color-gray-700:#4a4a4a;--color-gray-500:#757575;--color-gray-400:#9e9e9e;--color-gray-300:#dedede;--color-gray-200:#efefef;--color-gray-100:#f7f7f7;--color-white:#fff;--color-accent:#3182f6;--color-accent-bg:#ebf3ff;--color-accent-hover:#1b64da;--bg-primary:var(--color-white);--bg-secondary:#fafafa;--bg-tertiary:var(--color-gray-100);--text-primary:var(--color-black);--text-secondary:var(--color-gray-700);--text-tertiary:var(--color-gray-500);--text-placeholder:var(--color-gray-400);--border-color:var(--color-gray-300);--divider-color:var(--color-gray-200);--code-color:#eb5757;--code-bg:#f2f3f5;--tag-bg:var(--color-accent-bg);--tag-color:var(--color-accent);--font-family:"Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--text-4xl:2rem;--text-3xl:1.5rem;--text-2xl:1.25rem;--text-xl:1.125rem;--text-base:1rem;--text-sm:.875rem;--text-xs:.75rem;--fw-bold:700;--fw-semibold:600;--fw-medium:500;--fw-normal:400;--lh-tight:1.3;--lh-base:1.6;--lh-loose:1.8;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--max-width:720px;--nav-height:56px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--transition:.15s ease}[data-theme=dark]{--bg-primary:#0f0f0f;--bg-secondary:#181818;--bg-tertiary:#222;--text-primary:#e8e8e8;--text-secondary:#aaa;--text-tertiary:#777;--border-color:#333;--divider-color:#2a2a2a;--code-color:#ff6b6b;--code-bg:#2c2c2c;--tag-bg:#3182f626;--tag-color:#5ba3f5;--color-accent:#5ba3f5;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--text-base);line-height:var(--lh-base);color:var(--text-primary);background-color:var(--bg-primary);transition:background-color .2s,color .2s}a{color:inherit;transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-accent)}ul,ol{list-style:none}img{max-width:100%;height:auto}button{font-family:var(--font-family);cursor:pointer;background:0 0;border:none}.container{max-width:var(--max-width);padding:0 var(--sp-6);margin:0 auto}.progress-bar{background:var(--color-accent);z-index:1000;pointer-events:none;height:2px;transition:width .1s linear;position:fixed;top:0;left:0}.nav{z-index:100;background:var(--bg-primary);border-bottom:1px solid var(--divider-color);-webkit-backdrop-filter:blur(12px);background:#ffffffe0;transition:background .2s;position:sticky;top:0}[data-theme=dark] .nav{background:#0f0f0fe0}.nav-inner{height:var(--nav-height);justify-content:space-between;align-items:center;display:flex}.nav-logo{color:var(--text-primary);justify-content:center;align-items:center;display:inline-flex}.nav-tabs{gap:var(--sp-1);display:flex}.nav-tab{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--text-tertiary);transition:color var(--transition), background var(--transition)}.nav-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.nav-tab.active{color:var(--text-primary);font-weight:var(--fw-semibold)}.nav-right{align-items:center;gap:var(--sp-2);display:flex}.theme-toggle{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-tertiary);transition:background var(--transition), color var(--transition);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.lang-toggle{height:36px;padding:0 var(--sp-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--fw-bold);letter-spacing:.04em;color:var(--text-tertiary);transition:background var(--transition), color var(--transition);justify-content:center;align-items:center;display:flex}.lang-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.main{padding:var(--sp-10) 0 var(--sp-16)}.section{margin-bottom:var(--sp-10);animation:.4s both fadeSlideUp}.section:first-child{animation-delay:0s}.section:nth-child(2){animation-delay:60ms}.section:nth-child(3){animation-delay:.12s}.section:nth-child(4){animation-delay:.18s}.section:nth-child(5){animation-delay:.24s}.section-header{font-size:var(--text-2xl);font-weight:var(--fw-bold);margin-bottom:var(--sp-3);letter-spacing:-.02em}.section-divider{background:var(--border-color);height:1px;margin-bottom:var(--sp-6)}.profile{align-items:center;gap:var(--sp-8);margin-bottom:var(--sp-8);display:flex}.profile-avatar{object-fit:cover;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:50%;flex-shrink:0;width:96px;height:96px}.profile-avatar-placeholder{width:96px;height:96px;font-size:2rem;font-weight:var(--fw-bold);color:#fff;letter-spacing:-.03em;background:linear-gradient(135deg,#3182f6,#1b64da);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-avatar-img{flex-shrink:0;justify-content:center;align-items:center;width:96px;height:96px;display:flex}.profile-info{flex:1}.profile-name{font-size:var(--text-4xl);font-weight:var(--fw-bold);letter-spacing:-.03em;line-height:var(--lh-tight);margin-bottom:var(--sp-2)}.profile-role{font-size:var(--text-xl);color:var(--text-secondary);margin-bottom:var(--sp-1);font-weight:var(--fw-medium)}.profile-meta{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--sp-4)}.profile-links{gap:var(--sp-3);flex-wrap:wrap;display:flex}.profile-link{align-items:center;gap:var(--sp-1);font-size:var(--text-sm);color:var(--text-secondary);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);border:1px solid var(--border-color);transition:border-color var(--transition), color var(--transition), background var(--transition);display:inline-flex}.profile-link:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--tag-bg)}.profile-intro{font-size:var(--text-base);line-height:var(--lh-loose);color:var(--text-secondary)}.work-item{margin-bottom:var(--sp-10)}.work-item:last-child{margin-bottom:0}.work-callout{align-items:center;gap:var(--sp-3);background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-4);display:flex}.work-callout-text{font-size:var(--text-sm);color:var(--text-secondary);font-style:italic;line-height:1.5}.mermaid{margin:var(--sp-6) 0;text-align:center;overflow-x:auto}.mermaid svg{max-width:100%;height:auto}.work-header{margin-bottom:var(--sp-1);justify-content:space-between;align-items:baseline;display:flex}.work-company{font-size:var(--text-base);font-weight:var(--fw-bold)}.work-location{font-size:var(--text-sm);color:var(--text-tertiary);text-align:right}.work-sub{margin-bottom:var(--sp-4);justify-content:space-between;align-items:baseline;display:flex}.work-role{font-size:var(--text-sm);color:var(--text-secondary)}.work-period{font-size:var(--text-sm);color:var(--text-tertiary);white-space:nowrap;text-align:right}.work-period strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.work-desc{font-size:var(--text-sm);line-height:var(--lh-loose);color:var(--text-secondary)}.work-desc ul{padding-left:var(--sp-5);margin-bottom:var(--sp-3);list-style:outside}.work-desc li{margin-bottom:var(--sp-2)}.work-desc strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.web-nested-list{margin-top:var(--sp-1);padding-left:var(--sp-4);list-style-type:circle}.web-nested-list li{margin-bottom:var(--sp-1);color:var(--text-tertiary);font-size:.95em}.work-desc a{color:var(--color-accent);text-underline-offset:2px;text-decoration:underline}.work-tags{gap:var(--sp-2);margin-top:var(--sp-4);flex-wrap:wrap;display:flex}.tag{border-radius:var(--radius-sm);background:var(--tag-bg);color:var(--tag-color);font-size:var(--text-xs);font-weight:var(--fw-medium);white-space:nowrap;transition:background var(--transition), color var(--transition);padding:2px 8px;display:inline-block}.tag.gray{background:var(--bg-tertiary);color:var(--text-secondary)}.tag.clickable{cursor:pointer}.tag.clickable:hover,.tag.active{background:var(--color-accent);color:#fff}.skills-grid{gap:var(--sp-4);flex-direction:column;display:flex}.skill-group{gap:var(--sp-4);display:flex}.skill-group-label{font-size:var(--text-sm);color:var(--text-tertiary);flex-shrink:0;width:100px;padding-top:3px}.skill-tags{gap:var(--sp-2);flex-wrap:wrap;display:flex}.cert-item{padding:var(--sp-3) 0;border-bottom:1px solid var(--divider-color);justify-content:space-between;align-items:flex-start;display:flex}.cert-item:last-child{border-bottom:none}.cert-name{font-size:var(--text-sm);font-weight:var(--fw-semibold)}.cert-meta{font-size:var(--text-xs);color:var(--text-tertiary);text-align:right}.portfolio-filter{gap:var(--sp-2);margin-bottom:var(--sp-6);flex-wrap:wrap;display:flex}.filter-btn{padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--text-secondary);background:var(--bg-tertiary);transition:all var(--transition);border:1px solid #0000}.filter-btn:hover{color:var(--text-primary);border-color:var(--border-color)}.filter-btn.active{background:var(--color-accent);color:#fff}.case-list{gap:var(--sp-4);flex-direction:column;display:flex}.case-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:box-shadow var(--transition), transform var(--transition), border-color var(--transition);overflow:hidden}.case-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-accent)}.case-card-header{padding:var(--sp-5) var(--sp-6);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition);justify-content:space-between;align-items:center;display:flex}.case-card-header:hover{background:var(--bg-secondary)}.case-card-header-left{align-items:center;gap:var(--sp-4);flex:1;min-width:0;display:flex}.case-number{font-size:var(--text-xs);font-weight:var(--fw-bold);color:var(--color-accent);background:var(--tag-bg);border-radius:var(--radius-sm);white-space:nowrap;padding:3px 8px}.case-title{font-size:var(--text-base);font-weight:var(--fw-semibold);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.case-card.open .case-title{white-space:normal;text-overflow:unset;overflow:visible}.case-card.open .case-card-header-left{align-items:flex-start}.case-card.open .case-number{flex-shrink:0;margin-top:2px}.case-company-badge{font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.case-chevron{color:var(--text-tertiary);flex-shrink:0;align-self:flex-start;margin-top:2px;transition:transform .2s}.case-card.open .case-chevron{transform:rotate(180deg)}.case-body{padding:0 var(--sp-6) var(--sp-6);border-top:1px solid var(--divider-color);animation:.25s both fadeSlideUp;display:none}.case-card.open .case-body{display:block}.case-body .markdown-body>ul{margin-top:0;padding-left:0;list-style:none}.case-body .markdown-body>ul>li{margin-top:var(--sp-6);font-size:var(--text-sm);line-height:var(--lh-loose);color:var(--text-secondary);margin-bottom:0}.case-body .markdown-body>ul>li>p:first-child>strong:first-child,.case-body .markdown-body>ul>li>strong:first-child{font-size:var(--text-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:var(--sp-3);display:block}.case-body .markdown-body>ul>li>ul,.case-body .markdown-body>ul>li>ol{font-size:var(--text-sm);line-height:var(--lh-loose);color:var(--text-secondary);padding-left:var(--sp-5);list-style:outside}.case-body .markdown-body>ul>li>ul>li,.case-body .markdown-body>ul>li>ol>li{margin-bottom:var(--sp-2)}.case-body .markdown-body>ul>li>ul strong,.case-body .markdown-body>ul>li>ol strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.case-blog-link{margin-top:var(--sp-6);padding-top:var(--sp-4);border-top:1px solid var(--border-primary)}.case-blog-btn{align-items:center;gap:var(--sp-2);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-accent);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);border:1px solid var(--color-accent);transition:background var(--transition), color var(--transition);text-decoration:none;display:inline-flex}.case-blog-btn:hover{background:var(--color-accent);color:#fff}.case-part{margin-top:var(--sp-6)}.case-part-label{font-size:var(--text-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:var(--sp-3)}@media print{@page{margin:15mm}body{font-size:10pt;line-height:1.6;font-family:var(--font-family);-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#1a1a1a!important;background:#fff!important}.nav,.progress-bar,#theme-toggle,#lang-toggle,.back-link,.post-nav{display:none!important}.main{padding:0!important}.print-container{max-width:100%;margin:0;padding:0}.print-header{border-bottom:2.5px solid #111;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;display:flex}.print-header-left{flex:1}.print-name{color:#111;letter-spacing:-.02em;margin-bottom:4px;font-size:22pt;font-weight:800;line-height:1.1}.print-header-role{text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:10.5pt;font-weight:600;color:#4f46e5!important}.print-header-right{text-align:right;color:#555;font-size:9pt;line-height:2}.print-section{margin-bottom:32px}.print-section-title{color:#111;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e5e5;margin-bottom:16px;padding-bottom:6px;font-size:14pt;font-weight:700}.print-work-item{margin-bottom:28px}.print-work-header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.print-work-title-group{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.print-work-company{color:#111;font-size:13pt;font-weight:700}.print-work-role{color:#333;font-size:11pt;font-weight:600}.print-work-team{color:#757575;font-size:10pt;font-weight:500}.print-work-meta{text-align:right;color:#666;white-space:nowrap;margin-left:16px;font-size:10pt;font-weight:500}.print-callout{color:#475569;border-radius:0 4px 4px 0;margin-bottom:12px;padding:8px 12px;font-size:9.5pt;font-style:italic;border-left:3px solid var(--color-accent)!important;background:#f8fafc!important}.print-desc{color:#333;margin:0;padding-left:20px;font-size:10pt}.print-desc>li{margin-bottom:10px;padding-left:4px}.print-desc>li::marker{color:#888}.print-desc strong{color:#111;font-weight:600}.print-nested-list{margin-top:4px;padding-left:18px;list-style-type:disc}.print-nested-list li{color:#4a4a4a;margin-bottom:4px;font-size:9.5pt}.print-nested-list li::marker{color:#a3a3a3}.print-skills-grid{grid-template-columns:140px 1fr;gap:12px;margin-bottom:12px;font-size:10pt;display:grid}.print-skill-category{color:#4a4a4a;font-weight:600}.avoid-break,.avoid-break-children>*,.print-desc li,.print-desc p{page-break-inside:avoid;break-inside:avoid}.no-print{display:none!important}.print-portfolio-case{border-bottom:1px solid #e0e0e0;margin-bottom:32px;padding-bottom:28px}.print-portfolio-case:last-child{border-bottom:none;margin-bottom:0}.print-portfolio-header{align-items:flex-start;gap:14px;margin-bottom:14px;display:flex}.print-portfolio-number{color:#d4d4d4;flex-shrink:0;min-width:44px;font-size:20pt;font-weight:800;line-height:1.1}.print-portfolio-title-area{flex:1;padding-top:2px}.print-portfolio-title{color:#111;margin-bottom:5px;font-size:13pt;font-weight:700;line-height:1.3}.print-portfolio-meta{flex-wrap:wrap;align-items:center;gap:5px;font-size:9pt;display:flex}.print-portfolio-company{color:#333;margin-right:4px;font-weight:600}.print-portfolio-tag{border-radius:3px;padding:1px 5px;font-size:7.5pt;color:#4b5563!important;border:1px solid #d1d5db!important}.print-pf-section{margin-bottom:10px;padding-left:58px}.print-pf-label{text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;font-size:8pt;font-weight:700;color:#6b7280!important}.print-pf-label--result{color:#059669!important}.print-pf-summary{margin:0 0 4px;font-size:9.5pt;line-height:1.6;color:#222!important}.print-pf-list{margin:0;padding-left:16px;list-style:outside}.print-pf-list>li{margin-bottom:3px;padding-left:2px;font-size:9.5pt;line-height:1.6;color:#222!important}.print-pf-list>li::marker{color:#9ca3af!important}.print-code{border-radius:2px;padding:0 3px;font-family:SFMono-Regular,Consolas,monospace;font-size:.88em;color:#1f2937!important;background:#f3f4f6!important}}.case-part-content{font-size:var(--text-sm);line-height:var(--lh-loose);color:var(--text-secondary)}.case-part-content ul{padding-left:var(--sp-5);list-style:outside}.case-part-content li{margin-bottom:var(--sp-2)}.case-part-content strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.case-result-highlight{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--tag-bg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-accent);margin:var(--sp-1);display:inline-flex}.case-results-grid{margin:-var(--sp-1);margin-top:var(--sp-2);flex-wrap:wrap;display:flex}.blog-list{flex-direction:column;display:flex}.blog-card{padding:var(--sp-5) 0;border-bottom:1px solid var(--divider-color);transition:all var(--transition);display:block}.blog-card:last-child{border-bottom:none}.blog-card:hover .blog-card-title{color:var(--color-accent)}.blog-card-meta{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-2);display:flex}.blog-card-date{font-size:var(--text-xs);color:var(--text-tertiary)}.blog-card-category{font-size:var(--text-xs);font-weight:var(--fw-medium);border-radius:var(--radius-sm);padding:1px 6px}.blog-card-category.troubleshooting{color:#e85d04;background:#fff0eb}.blog-card-category.feature{background:var(--tag-bg);color:var(--color-accent)}.blog-card-category.retrospective{color:#2e7d32;background:#f0fff4}[data-theme=dark] .blog-card-category.troubleshooting{color:#ff8c5a;background:#e85d0426}[data-theme=dark] .blog-card-category.retrospective{color:#66bb6a;background:#2e7d3226}.blog-card-title{font-size:var(--text-base);font-weight:var(--fw-semibold);line-height:var(--lh-tight);margin-bottom:var(--sp-2);transition:color var(--transition);letter-spacing:-.01em}.blog-card-summary{font-size:var(--text-sm);color:var(--text-tertiary);line-height:var(--lh-base);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.blog-card-read-time{font-size:var(--text-xs);color:var(--text-placeholder);margin-top:var(--sp-2)}.post-header{margin-bottom:var(--sp-8)}.post-meta{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4);display:flex}.post-title{font-size:var(--text-3xl);font-weight:var(--fw-bold);letter-spacing:-.02em;line-height:var(--lh-tight);margin-bottom:var(--sp-4)}.post-summary{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--lh-loose);padding-bottom:var(--sp-6);border-bottom:1px solid var(--divider-color)}.markdown-body{font-size:var(--text-base);line-height:var(--lh-loose);color:var(--text-primary)}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{font-weight:var(--fw-bold);letter-spacing:-.02em;margin-top:var(--sp-10);margin-bottom:var(--sp-4)}.markdown-body h1{font-size:var(--text-3xl);padding-bottom:var(--sp-4);border-bottom:1px solid var(--divider-color)}.markdown-body h2{font-size:var(--text-2xl);padding-bottom:var(--sp-3);border-bottom:1px solid var(--divider-color)}.markdown-body h3{font-size:var(--text-xl)}.markdown-body h4{font-size:var(--text-base);color:var(--text-secondary)}.markdown-body p{margin-bottom:var(--sp-4);color:var(--text-secondary)}.markdown-body ul,.markdown-body ol{padding-left:var(--sp-6);margin-bottom:var(--sp-4);color:var(--text-secondary)}.markdown-body ul{list-style:outside}.markdown-body ol{list-style:decimal}.markdown-body li{margin-bottom:var(--sp-2)}.markdown-body strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.markdown-body a{color:var(--color-accent);text-underline-offset:2px;text-decoration:underline}.markdown-body code{border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--color-accent);padding:1px 5px;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.875em}.markdown-body pre{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--sp-5);margin-bottom:var(--sp-5);overflow-x:auto}.markdown-body pre code{color:var(--text-primary);font-size:var(--text-sm);background:0 0;padding:0}.markdown-body table{border-collapse:collapse;width:100%;margin-bottom:var(--sp-6);font-size:var(--text-sm);text-align:left}.markdown-body th,.markdown-body td{padding:var(--sp-3) var(--sp-4);border:1px solid var(--divider-color)}.markdown-body th{background-color:var(--bg-tertiary);font-weight:var(--fw-bold);color:var(--text-primary)}.markdown-body tr:nth-child(2n){background-color:var(--bg-secondary)}.markdown-body blockquote{border-left:3px solid var(--color-accent);padding-left:var(--sp-5);margin-left:0;margin-bottom:var(--sp-5);color:var(--text-tertiary);font-style:italic}.post-nav{margin-top:var(--sp-12);padding-top:var(--sp-6);border-top:1px solid var(--divider-color);justify-content:space-between;gap:var(--sp-4);display:flex}.post-nav-link{width:100%;padding:var(--sp-4);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:border-color var(--transition), background var(--transition);flex:1;display:block}.post-nav-link:hover{border-color:var(--color-accent);background:var(--tag-bg);color:inherit}.post-nav-link.next{text-align:right}.post-nav-label{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--sp-1)}.post-nav-title{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.back-link{align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--sp-6);transition:color var(--transition);display:inline-flex}.back-link:hover{color:var(--color-accent)}.empty-state{text-align:center;padding:var(--sp-16) var(--sp-6);color:var(--text-tertiary)}.empty-state-icon{margin-bottom:var(--sp-4);font-size:2.5rem}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.container{padding:0 var(--sp-4)}.profile{align-items:flex-start;gap:var(--sp-4);flex-direction:column}.profile-name{font-size:var(--text-3xl)}.work-header,.work-sub{gap:var(--sp-1);flex-direction:column}.work-location,.work-period{text-align:left}.case-card-header{align-items:flex-start;gap:var(--sp-3);flex-direction:column}.skill-group{gap:var(--sp-2);flex-direction:column}.skill-group-label{width:auto}}@media print{.nav,.progress-bar,.theme-toggle,.profile-links{display:none}.main{padding:0}.section{animation:none}body{color:#000;background:#fff}.case-body{display:block!important}.case-card{box-shadow:none;break-inside:avoid;border:none}}
pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#abb2bf;background:#282c34}.hljs-comment,.hljs-quote{color:#5c6370;font-style:italic}.hljs-doctag,.hljs-keyword,.hljs-formula{color:#c678dd}.hljs-section,.hljs-name,.hljs-selector-tag,.hljs-deletion,.hljs-subst{color:#e06c75}.hljs-literal{color:#56b6c2}.hljs-string,.hljs-regexp,.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string{color:#98c379}.hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-type,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-number{color:#d19a66}.hljs-symbol,.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-title{color:#61aeee}.hljs-built_in,.hljs-title.class_,.hljs-class .hljs-title{color:#e6c07b}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}
