:root{--font: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--profile-width: 420px;--page-width: 640px;--bg: #f4f5f7;--bg-soft: #eef0f4;--surface: #ffffff;--text: #191f28;--text-secondary: #4e5968;--text-muted: #8b95a1;--accent: #3182f6;--accent-soft: #e8f3ff;--border: rgba(0, 0, 0, .06);--shadow: 0 1px 3px rgba(0, 0, 0, .04), 0 4px 12px rgba(0, 0, 0, .03);--shadow-hover: 0 2px 8px rgba(0, 0, 0, .06), 0 8px 24px rgba(49, 130, 246, .08);--radius-btn: 14px;--radius-avatar: 50%}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font);font-size:16px;line-height:1.5;color:var(--text);-webkit-font-smoothing:antialiased}.body-profile{background:var(--bg);background-image:radial-gradient(ellipse 70% 50% at 50% -10%,rgba(49,130,246,.08),transparent),radial-gradient(ellipse 50% 40% at 100% 100%,rgba(167,139,250,.06),transparent)}.body-page{background:var(--bg)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.profile-page{width:min(100% - 2.5rem,var(--profile-width));margin-inline:auto;padding:2.5rem 0 3rem}.profile-hero{text-align:center;margin-bottom:2rem}.avatar{width:88px;height:88px;margin:0 auto 1.25rem;border-radius:var(--radius-avatar);background:linear-gradient(135deg,#3182f6,#6b9fff);color:#fff;font-size:2rem;font-weight:700;line-height:88px;box-shadow:0 4px 16px #3182f640}.profile-name{margin:0 0 .35rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.profile-bio{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-secondary)}.profile-sub{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.5}.link-stack{display:flex;flex-direction:column;gap:.65rem}.section-label{margin:1.25rem 0 .35rem;padding-left:.25rem;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.section-label:first-child{margin-top:0}.link-btn{display:flex;align-items:center;gap:.85rem;width:100%;padding:.95rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);box-shadow:var(--shadow);color:var(--text);text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.link-btn:hover{transform:translateY(-1px);border-color:#3182f633;box-shadow:var(--shadow-hover);text-decoration:none}.link-btn:active{transform:translateY(0)}.link-btn-icon{flex-shrink:0;font-size:1.35rem;line-height:1}.link-btn-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem;text-align:left}.link-btn-label{font-size:.95rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-btn-sub{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-btn-arrow{flex-shrink:0;font-size:1rem;color:var(--text-muted);opacity:.6}.profile-footer-nav{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:.35rem;margin-top:2rem;font-size:.85rem}.profile-footer-nav a{color:var(--text-secondary);font-weight:500}.profile-footer-nav a:hover{color:var(--accent)}.profile-footer-nav .dot{color:var(--text-muted);user-select:none}.profile-footer{margin-top:1.5rem;text-align:center;font-size:.8rem;color:var(--text-muted)}.profile-footer a{color:var(--text-muted)}.profile-footer a:hover{color:var(--accent)}.page-wrap{width:min(100% - 2rem,var(--page-width));margin-inline:auto;padding:1.5rem 0 3rem}.page-back{display:inline-flex;align-items:center;gap:.25rem;margin-bottom:1.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none}.page-back:hover{color:var(--accent);text-decoration:none}.page-header h1{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.page-header .lead{margin:0 0 1.5rem;font-size:.95rem;color:var(--text-secondary);line-height:1.6}.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.25rem}.filter-bar a{padding:.4rem .9rem;font-size:.8rem;font-weight:500;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);text-decoration:none}.filter-bar a:hover,.filter-bar a.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);text-decoration:none}.project-list{display:flex;flex-direction:column;gap:.65rem}.project-detail{padding-bottom:2rem}.project-detail-header{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.project-detail-header h1{margin:.75rem 0 .5rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.project-detail-header .lead{margin:0;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.card-meta{display:flex;flex-wrap:wrap;gap:.4rem}.badge{display:inline-block;padding:.2rem .55rem;font-size:.7rem;font-weight:600;border-radius:6px;background:var(--bg-soft);color:var(--text-muted)}.badge-tier-1{background:#e8faf0;color:#16a34a}.badge-tier-2{background:#fef9e8;color:#ca8a04}.badge-tier-3{background:#f3eeff;color:#7c3aed}.badge-live{background:#e8faf0;color:#16a34a}.badge-internal{background:#fef9e8;color:#ca8a04}.tech-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin:1rem 0}.tech-badge{padding:.25rem .55rem;font-size:.72rem;font-weight:500;background:var(--bg-soft);border-radius:6px;color:var(--text-secondary)}.highlights{margin:1rem 0 0;padding:0;list-style:none}.highlights li{position:relative;padding-left:1rem;margin-bottom:.4rem;font-size:.875rem;color:var(--text-secondary)}.highlights li:before{content:"·";position:absolute;left:0;color:var(--accent);font-weight:700}.project-links{display:flex;gap:.65rem;margin-top:1rem;flex-wrap:wrap}.project-detail-footer{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.project-detail-footer-label{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.project-detail-footer-links{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem}.project-detail-footer-links a{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.project-detail-footer-links a:hover{color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1rem;font-size:.85rem;font-weight:600;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);text-decoration:none;box-shadow:var(--shadow)}.btn:hover{border-color:#3182f640;color:var(--accent);text-decoration:none}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#1b6fe0;border-color:#1b6fe0;color:#fff}.prose{max-width:100%}.prose h2{margin-top:1.75rem;margin-bottom:.5rem;font-size:1.1rem;font-weight:700;color:var(--text)}.prose p,.prose li{font-size:.9rem;color:var(--text-secondary);line-height:1.7}.prose ul{padding-left:1.25rem}.prose code{font-size:.85em;padding:.15em .4em;background:var(--bg-soft);border-radius:4px;color:var(--text)}.prose table{width:100%;font-size:.85rem;border-collapse:collapse}.prose th,.prose td{padding:.5rem .75rem;border:1px solid var(--border);text-align:left}.prose th{background:var(--bg-soft);font-weight:600}.stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.stack-group{padding:1.1rem;border:1px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);box-shadow:var(--shadow)}.stack-group h3{margin:0 0 .6rem;font-size:.8rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.stack-group ul{margin:0;padding:0;list-style:none}.stack-group li{padding:.2rem 0;font-size:.875rem;color:var(--text-secondary)}@media(max-width:480px){.profile-page{padding-top:2rem}.avatar{width:76px;height:76px;line-height:76px;font-size:1.75rem}}
