@font-face{font-family:Snapdeck Sans;font-weight:300;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-Light.otf) format("opentype")}@font-face{font-family:Snapdeck Sans;font-weight:400;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-Regular.otf) format("opentype")}@font-face{font-family:Snapdeck Sans;font-weight:500;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-Medium.otf) format("opentype")}@font-face{font-family:Snapdeck Sans;font-weight:600;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-SemiBold.otf) format("opentype")}@font-face{font-family:Snapdeck Sans;font-weight:700;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-Bold.otf) format("opentype")}@font-face{font-family:Snapdeck Sans;font-weight:800;font-style:normal;font-display:swap;src:url(/fonts/SnapdeckSans/SnapdeckSans-ExtraBold.otf) format("opentype")}:root{--bg: #050505;--text: #ffffff;--border: rgba(255, 255, 255, .1);--border-dotted: rgba(255, 255, 255, .14);--muted: rgba(255, 255, 255, .5);--card-bg: rgba(255, 255, 255, .03);--surface: #050505;--surface-soft: rgba(255, 255, 255, .04);font-family:Snapdeck Sans,system-ui,sans-serif;line-height:1.6;color:var(--text);background-color:var(--bg);scrollbar-gutter:stable}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg);color:var(--text)}#app{min-height:100vh}a{color:var(--text);text-decoration:none}a:hover{text-decoration:none;opacity:.8}.theme-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.theme-shell{flex:1;display:flex;flex-direction:column;width:100%;max-width:1024px;margin:0 auto;border-left:1px dotted var(--border-dotted);border-right:1px dotted var(--border-dotted);background:var(--surface)}.announcement-bar{width:100%;border-bottom:1px dotted var(--border-dotted);background:var(--surface-soft)}.announcement-bar__link{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem 1rem;font-size:.75rem;line-height:1.4;font-weight:500;color:#ffffffb8;transition:color .15s,background-color .15s}.announcement-bar__link:hover{color:var(--text);background:#ffffff08;opacity:1}.announcement-bar__mark{flex-shrink:0;color:#fff6}@media(min-width:768px){.announcement-bar__link{font-size:.8125rem}}.top-nav{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border);background:#050505d1;backdrop-filter:blur(12px)}.top-nav__inner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:3.25rem;padding:.75rem 1rem .5rem}.top-nav__brand{display:flex;align-items:center;gap:.75rem;min-width:0;flex-shrink:0;color:var(--text);transition:opacity .15s}.top-nav__brand:hover{opacity:.8}.top-nav__logo{width:2.5rem;height:2.5rem;flex-shrink:0;object-fit:contain;transform:translateY(-2px)}.top-nav__wordmark{font-size:1.35rem;font-weight:500;line-height:1;letter-spacing:-.02em}.top-nav__actions{display:flex;align-items:center;gap:1.25rem;min-width:0;flex-shrink:0}.top-nav__links{display:flex;align-items:center;gap:1.25rem;min-width:0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.top-nav__links::-webkit-scrollbar{display:none}.top-nav__link{flex-shrink:0;white-space:nowrap;font-size:.8125rem;font-weight:400;color:var(--muted);transition:color .15s}.top-nav__link:hover{color:#ffffffd1;opacity:1}.top-nav__link--active{color:var(--text)}.top-nav__btn{flex-shrink:0;display:inline-flex;align-items:center;padding:.4rem .875rem;border:1px solid rgba(255,255,255,.18);border-radius:6px;background:#ffffff0f;color:var(--text);font-family:inherit;font-size:.8125rem;font-weight:500;line-height:1;white-space:nowrap;transition:background-color .15s,border-color .15s}.top-nav__btn:hover{background:#ffffff1a;border-color:#ffffff47;opacity:1}.top-nav__auth{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}@media(min-width:768px){.top-nav__inner{min-height:3.75rem;gap:2rem;padding:.875rem 1.5rem .625rem}.top-nav__logo{width:2.875rem;height:2.875rem;transform:translateY(-3px)}.top-nav__wordmark{font-size:1.625rem}.top-nav__links{gap:1.5rem}.top-nav__link,.top-nav__btn{font-size:.875rem}}.main-content{flex:1;width:100%;padding:0;overflow-x:clip}.featured-post{margin-bottom:1.25rem;max-width:100%}.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;width:100%;align-items:stretch;border-top:1px dotted var(--border-dotted)}.post-grid .post-card{min-height:100%}.post-card{background:var(--card-bg);border:none;border-bottom:1px dotted var(--border-dotted);overflow:hidden;display:flex;flex-direction:column}.post-grid .post-card:nth-child(odd){border-right:1px dotted var(--border-dotted)}.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{--post-pad-x: 1.5rem;width:100%;max-width:none;min-width:0;padding:2rem var(--post-pad-x) 3.5rem;padding-left:max(var(--post-pad-x),env(safe-area-inset-left));padding-right:max(var(--post-pad-x),env(safe-area-inset-right));overflow-x:clip}.post-detail__back{display:inline-flex;align-items:center;gap:.25rem;min-height:2.75rem;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:clamp(1.35rem,5vw,2rem);font-weight:700;margin:.6rem 0 0;line-height:1.3;letter-spacing:-.025em;overflow-wrap:break-word;word-break:keep-all}.post-detail__hero{width:calc(100% + 2 * var(--post-pad-x));max-width:none;margin-left:calc(-1 * var(--post-pad-x));margin-right:calc(-1 * var(--post-pad-x));aspect-ratio:16 / 9;object-fit:cover;border-radius:0;margin-top:1.75rem;display:block}.post-detail__body{margin-top:2rem;min-width:0;max-width:100%}.prose{line-height:1.85;font-size:.9375rem;color:#ffffffa6;letter-spacing:.01em;min-width:0;max-width:100%;overflow-wrap:break-word}.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{position:relative;border-left:3px solid rgba(255,255,255,.35);margin:2rem 0;padding:1rem 1.25rem 1rem 1.5rem;background:#ffffff0a;border-radius:0 8px 8px 0;color:#ffffffb3;font-style:normal}.prose blockquote:before{content:"“";position:absolute;top:-.1rem;left:1rem;font-size:3rem;line-height:1;color:#ffffff1f;font-family:Georgia,serif;pointer-events:none}.prose blockquote p{margin:0;line-height:1.75}.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;-webkit-overflow-scrolling:touch;max-width:100%;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%;max-width:100%;border-collapse:collapse;margin:0 0 1.25rem;font-size:.875rem;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.prose th,.prose td{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}.prose th{background:#ffffff0d;font-weight:600}.prose img{width:calc(100% + 2 * var(--post-pad-x, 1.5rem));max-width:calc(100% + 2 * var(--post-pad-x, 1.5rem));margin:1.5rem calc(-1 * var(--post-pad-x, 1.5rem));border-radius:0;display:block;height:auto}.prose img[alt=TIPS]{width:auto;max-width:7.5rem;margin:1.25rem 0 1.5rem}.prose .post-media{width:calc(100% + 2 * var(--post-pad-x, 1.5rem));max-width:calc(100% + 2 * var(--post-pad-x, 1.5rem));margin:1.75rem calc(-1 * var(--post-pad-x, 1.5rem)) 2rem}.prose .post-media__video{display:block;width:100%;aspect-ratio:16 / 9;background:#000}.prose .post-media figcaption{margin:.75rem var(--post-pad-x, 1.5rem) 0;color:#ffffff73;font-size:.8125rem;line-height:1.6}.prose a{color:var(--text);text-decoration:underline;text-decoration-color:#ffffff40;text-underline-offset:3px;transition:text-decoration-color .15s;overflow-wrap:anywhere}.prose a:hover{text-decoration-color:var(--text)}.prose strong{font-weight:600;color:#ffffffe6}.prose em{color:#ffffff8c}.site-footer{margin-top:auto;border-top:1px dotted var(--border-dotted);background:var(--surface-soft)}.site-footer__inner{display:grid;gap:2rem;padding:2.5rem 1rem}.site-footer__brand{min-width:0}.site-footer__logo-link{display:inline-flex;align-items:center;gap:.75rem;color:var(--text)}.site-footer__logo{width:2rem;height:2rem;object-fit:contain}.site-footer__wordmark{font-size:1.125rem;font-weight:500;line-height:1}.site-footer__desc{margin:1rem 0 0;max-width:18rem;font-size:.8125rem;line-height:1.5;color:var(--muted)}.site-footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1.25rem 1rem 1.5rem;border-top:1px dotted var(--border-dotted)}@media(min-width:768px){.site-footer__inner{grid-template-columns:auto auto;justify-content:start;align-items:start;column-gap:4rem;padding:2.5rem 1.5rem}.footer-sitemap{margin-right:0}}.footer-sitemap{display:flex;flex-wrap:wrap;gap:2rem 2.5rem;margin-bottom:0}.footer-copy{font-size:.75rem;color:var(--muted);margin:0}.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}.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){.theme-shell{max-width:100%;border-left:none;border-right:none}}@media(max-width:768px){:root{scrollbar-gutter:auto}.top-nav__inner{padding:.625rem .75rem .5rem}.top-nav__wordmark{font-size:1.2rem}.top-nav__actions{gap:.75rem}.top-nav__links{gap:.875rem}.top-nav__auth{display:none}.post-grid{grid-template-columns:1fr}.post-grid .post-card:nth-child(odd){border-right:none}.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{--post-pad-x: 1rem;padding-top:1rem;padding-bottom:2.5rem}.post-detail__back{margin-bottom:.75rem;min-height:2.5rem}.post-detail__meta{flex-direction:column;align-items:flex-start;gap:.2rem;font-size:.75rem;line-height:1.4}.post-detail__meta>*:not(:first-child):before{display:none}.post-detail__title{font-size:clamp(1.25rem,6.5vw,1.5rem);margin-top:.5rem;line-height:1.35}.post-detail__hero{width:100%;max-width:100%;margin-left:0;margin-right:0;aspect-ratio:auto;height:auto;object-fit:contain;margin-top:1rem}.post-detail__body{margin-top:1.25rem}.prose{font-size:.9375rem;line-height:1.8;word-break:keep-all;overflow-wrap:break-word}.prose p{margin-bottom:1rem}.prose h2{font-size:1.1rem;margin:1.75rem 0 .5rem;line-height:1.4}.prose h3{font-size:1rem;margin:1.25rem 0 .4rem;line-height:1.4}.prose hr{margin:1.75rem 0}.prose ul,.prose ol{padding-left:1rem;margin-bottom:1rem}.prose ul>li:before{left:-1rem}.prose ol>li:before{left:-1rem}.prose li{margin-bottom:.4rem;line-height:1.65}.prose blockquote{margin:1.25rem 0;padding:.75rem .875rem .75rem 1rem;border-radius:0 6px 6px 0}.prose blockquote:before{left:.5rem;font-size:2rem}.prose pre{padding:.75rem .875rem;border-radius:6px;font-size:.8125rem;margin-left:0;margin-right:0}.prose pre code{font-size:.8125rem}.prose img:not([alt=TIPS]){width:100%;max-width:100%;margin-left:0;margin-right:0;height:auto;object-fit:contain}.prose table{font-size:.8125rem;margin-left:0;margin-right:0}.prose th,.prose td{padding:.45rem .6rem;white-space:nowrap}.prose img[alt=TIPS]{width:auto;max-width:5.5rem;margin:.875rem 0 1rem}.prose .post-media{width:100%;max-width:100%;margin-left:0;margin-right:0}.prose .post-media figcaption{margin-left:0;margin-right:0;font-size:.75rem}.site-footer__inner,.site-footer__bottom{padding-left:.75rem;padding-right:.75rem}.site-footer__bottom{flex-wrap:wrap}.footer-sitemap{gap:1.5rem 2rem}.footer-copy{font-size:.6875rem}}@media(max-width:400px){.top-nav__inner{padding:.5rem .625rem}.post-detail{--post-pad-x: .875rem;padding-bottom:2rem}.post-card__title{font-size:1.05rem}.post-detail__title{font-size:1.2rem}.prose{font-size:.875rem;line-height:1.75}.prose h2{font-size:1.025rem}.prose blockquote{padding:.625rem .75rem .625rem .875rem}}
