:root{--bg: #050505;--text: #ffffff;--border: rgba(255, 255, 255, .1);--muted: rgba(255, 255, 255, .5);--card-bg: rgba(255, 255, 255, .03);font-family:Goorm Sans,sans-serif;line-height:1.6;color:var(--text);background-color:var(--bg);scrollbar-gutter:stable}*{box-sizing:border-box}body{margin:0;padding-top:6px;min-height:100vh;background-color:var(--bg);color:var(--text)}#app{min-height:100vh;display:flex;flex-direction:column}a{color:var(--text);text-decoration:none}a:hover{text-decoration:none;opacity:.8}.app-header{border-bottom:1px solid var(--border);padding:0 2rem;height:56px;display:flex;align-items:center;flex-shrink:0;margin-bottom:.5rem}.header-logo{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.05rem;color:var(--text)}.header-logo:hover{opacity:1}.header-logo__img{height:28px;width:auto;display:block}.header-logo__text{margin-top:2px;font-family:Goorm Sans,sans-serif;font-size:1.35rem;font-weight:600}.header-nav{display:flex;align-items:center;gap:1.5rem;font-size:.75rem}.header-nav a{color:var(--muted);transition:color .15s}.header-nav a:hover{color:var(--text);opacity:1}.header-cta{display:flex;align-items:center;gap:.75rem}.btn-login{color:var(--muted);background:transparent;border:none;font-size:.75rem;cursor:pointer;padding:.4rem .75rem;font-family:inherit}.btn-login:hover{color:var(--text)}.btn-primary{display:inline-flex;align-items:center;background:var(--text);color:var(--bg);font-size:.75rem;font-weight:500;padding:.4rem 1rem;border-radius:8px;border:none;cursor:pointer;text-decoration:none;font-family:inherit}.btn-primary:hover{opacity:.9}.app-body{flex:1;min-height:0;display:flex;justify-content:center;padding:0 2rem}.app-body-inner{display:flex;flex:1;min-height:0;max-width:1200px;width:100%}.sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);padding:2.5rem 1.5rem 2.5rem 0}.sidebar-title{font-size:1.375rem;font-weight:700;margin:0 0 .25rem}.sidebar-desc{font-size:.8125rem;color:var(--muted);margin:0 0 1.75rem;line-height:1.4}.sidebar-nav{display:flex;flex-direction:column;gap:.125rem}.sidebar-nav a{font-size:.875rem;color:var(--muted);padding:.3rem 0;transition:color .15s}.sidebar-nav a:hover{color:var(--text);opacity:1}.main-content{flex:1;overflow:auto;padding:2.5rem 0 3rem 2rem}.featured-post{margin-bottom:1.25rem;max-width:100%}.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%;align-items:stretch}.post-grid .post-card{min-height:100%}.post-card{background:var(--card-bg);border:none;overflow:hidden;display:flex;flex-direction:column}.post-card__thumb{background:#ffffff05;aspect-ratio:16 / 9;flex-shrink:0;width:100%;object-fit:cover;display:block}.post-card__body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;flex:1}.post-card__category{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.4rem}.post-card__title{font-size:1.4rem;font-weight:700;margin:0 0 .5rem;line-height:1.25;letter-spacing:-.025em}.post-card__title a{color:inherit}.post-card__excerpt{font-size:.8125rem;color:var(--muted);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card__meta{font-size:.75rem;color:var(--muted);margin-top:auto;padding-top:.875rem}.post-detail{max-width:42rem}.post-detail__back{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;color:var(--muted);margin-bottom:1.5rem;transition:color .15s}.post-detail__back:hover{color:var(--text);opacity:1}.post-detail__meta{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.8125rem}.post-detail__meta>*:not(:first-child):before{content:"·";margin-right:.5rem}.post-detail__author{color:var(--text)}.post-detail__title{font-size:2rem;font-weight:700;margin:.6rem 0 0;line-height:1.3;letter-spacing:-.025em}.post-detail__hero{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:12px;margin-top:1.75rem;display:block}.post-detail__body{margin-top:2rem}.prose{line-height:1.85;font-size:.9375rem;color:#ffffffa6;letter-spacing:.01em}.prose>*:first-child{margin-top:0}.prose h2{font-size:1.15rem;font-weight:600;margin:2.5rem 0 .75rem;color:var(--text);letter-spacing:-.01em}.prose h3{font-size:1rem;font-weight:600;margin:2rem 0 .5rem;color:var(--text)}.prose p{margin:0 0 1.25rem}.prose hr{border:none;height:1px;background:var(--border);margin:2.5rem 0}.prose ul,.prose ol{margin:0 0 1.25rem;padding-left:1.25rem}.prose ul{list-style:none}.prose ul>li{position:relative;padding-left:.25rem}.prose ul>li:before{content:"—";position:absolute;left:-1.25rem;color:#ffffff40}.prose ol{list-style:none;counter-reset:prose-ol}.prose ol>li{position:relative;padding-left:.25rem;counter-increment:prose-ol}.prose ol>li:before{content:counter(prose-ol);position:absolute;left:-1.25rem;color:#ffffff59;font-size:.8125rem;font-weight:500}.prose li{margin-bottom:.5rem;line-height:1.7}.prose blockquote{border-left:2px solid rgba(255,255,255,.15);margin:1.5rem 0;padding:.25rem 1.25rem;color:#ffffff8c;font-style:italic}.prose code{background:#ffffff14;padding:.15rem .35rem;border-radius:4px;font-size:.85em}.prose pre{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;overflow-x:auto;margin:0 0 1.25rem}.prose pre code{background:none;padding:0;border-radius:0;font-size:.8125rem;line-height:1.6}.prose table{width:100%;border-collapse:collapse;margin:0 0 1.25rem;font-size:.875rem}.prose th,.prose td{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}.prose th{background:#ffffff0d;font-weight:600}.prose img{max-width:100%;border-radius:8px;margin:1.5rem 0}.prose a{color:var(--text);text-decoration:underline;text-decoration-color:#ffffff40;text-underline-offset:3px;transition:text-decoration-color .15s}.prose a:hover{text-decoration-color:var(--text)}.prose strong{font-weight:600;color:#ffffffe6}.prose em{color:#ffffff8c}.app-footer{border-top:1px solid var(--border);margin-top:auto;padding:2.5rem 2rem 2rem;flex-shrink:0}.footer-inner{max-width:1200px;margin:0 auto}.footer-sitemap{display:flex;flex-wrap:wrap;gap:2.5rem 3rem;margin-bottom:2rem}.footer-col-title{display:block;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.75rem}.footer-col ul{list-style:none;margin:0;padding:0}.footer-col li{margin-bottom:.35rem}.footer-col a{font-size:.875rem;color:var(--muted);transition:color .15s}.footer-col a:hover{color:var(--text);opacity:1}.footer-bottom{display:flex;align-items:center;justify-content:space-between}.footer-copy{font-size:.75rem;color:var(--muted);margin:0}.lang-pill{position:relative;display:inline-flex;background:#ffffff0f;border-radius:6px;padding:2px}.lang-pill:before{content:"";position:absolute;top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px);background:#ffffff1a;border-radius:4px;transition:transform .2s ease}.lang-pill--ko:before{transform:translate(100%)}.lang-pill__btn{position:relative;z-index:1;background:none;border:none;color:var(--muted);font-family:inherit;font-size:.6875rem;font-weight:500;letter-spacing:.03em;padding:.2rem .6rem;cursor:pointer;transition:color .2s}.lang-pill:not(.lang-pill--ko)>.lang-pill__btn:first-child,.lang-pill--ko>.lang-pill__btn:last-child{color:var(--text)}@media(max-width:1024px){.sidebar{width:180px;padding:2rem 1rem 2rem 0}.main-content{padding:2rem 0 2.5rem 1.5rem}}@media(max-width:768px){:root{scrollbar-gutter:auto}.app-header{padding:0 1rem;height:48px}.header-logo__text{font-size:1.15rem}.header-nav,.btn-login{display:none}.app-body{padding:0 1rem}.sidebar{display:none}.main-content{padding:1.25rem 0 2rem;overflow:visible}.post-grid{grid-template-columns:1fr;gap:1rem}.post-card__title{font-size:1.15rem}.post-card__body{padding:.75rem 1rem 1rem}.post-card__excerpt{font-size:.75rem}.post-card__meta{font-size:.6875rem}.post-detail{max-width:100%}.post-detail__back{margin-bottom:1rem}.post-detail__meta{flex-wrap:wrap;gap:.25rem .5rem;font-size:.75rem}.post-detail__title{font-size:1.4rem;margin-top:.4rem}.post-detail__hero{border-radius:8px;margin-top:1.25rem}.post-detail__body{margin-top:1.5rem}.prose{font-size:.875rem;line-height:1.75;word-break:keep-all;overflow-wrap:break-word}.prose h2{font-size:1.05rem;margin:2rem 0 .6rem}.prose h3{font-size:.95rem;margin:1.5rem 0 .4rem}.prose hr{margin:2rem 0}.prose blockquote{margin:1rem 0;padding:.2rem 1rem}.prose pre{padding:.75rem 1rem;border-radius:6px;font-size:.8rem}.prose table{font-size:.8rem;display:block;overflow-x:auto}.prose th,.prose td{padding:.4rem .5rem;white-space:nowrap}.app-footer{padding:2rem 1rem 1.5rem}.footer-sitemap{gap:1.5rem 2rem}.footer-bottom{flex-wrap:wrap;gap:.75rem}.footer-copy{font-size:.6875rem}}@media(max-width:400px){.app-header,.app-body{padding:0 .75rem}.post-card__title{font-size:1.05rem}.post-detail__title{font-size:1.25rem}.btn-primary{font-size:.6875rem;padding:.35rem .75rem}.app-footer{padding:1.5rem .75rem 1.25rem}}
