:root{--cream:#f7f4ef;--text:#0a0a0a;--text-muted:#555;--accent:#084cfa;--border:#e2ddd4;--surface:#fff}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%}body{font-family:Noto Sans KR,system-ui,sans-serif;background:var(--cream);color:var(--text);line-height:1.6}a{color:var(--accent)}a:hover{text-decoration:underline;text-underline-offset:3px}.site-header{max-width:960px;margin:0 auto;padding:2rem 1.5rem 1rem;display:flex;align-items:baseline;flex-wrap:wrap}.site-header,.site-header--bar{justify-content:space-between;gap:1rem}.site-header--bar{flex-direction:row;align-items:center;text-align:left;flex-wrap:nowrap;max-width:none;width:100%;padding-left:2cm;padding-right:2cm}.site-logo{border-radius:0;object-fit:contain;background:transparent}.site-title{font-family:Noto Sans KR;font-size:1.75rem;font-weight:500;margin:0;line-height:1.2}.site-nav{display:flex;gap:1rem;font-size:.9rem;justify-content:center}.site-nav--end{margin-left:auto;justify-content:flex-end;flex-shrink:0;align-items:center;align-self:flex-end}.site-nav--end a{text-decoration:none}.site-nav--end a:hover{text-decoration:underline;text-underline-offset:3px}.header-logout-button{margin-left:1cm;border:none;background:transparent;color:var(--accent);padding:0;font:inherit;font-size:.9rem;cursor:pointer;text-decoration:none}.header-logout-button:hover{text-decoration:underline;text-underline-offset:3px}.admin-home-link{font-size:1rem;text-decoration:none;color:var(--text);padding:.3rem .75rem;transition:color .15s}.admin-home-link:hover{color:var(--accent);text-decoration:none}.site-main{max-width:960px;margin:0 auto;padding:1rem 1.5rem 4rem}.card-meta{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.article-page-title{font-size:1.35rem;font-weight:500;margin:0 0 .5rem;text-align:center}.article-page-date{font-size:.7rem;color:var(--text-muted);text-align:right;margin-bottom:2rem}.article-back-link{font-family:Noto Sans KR,Noto Sans,system-ui,sans-serif;font-size:.8em;color:#000;text-decoration:none}.article-back-link:hover{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.article-body-source{margin:1.2rem 0 0;font-size:.75rem;color:rgba(14,26,40,.42);text-align:right;white-space:pre-wrap;word-break:break-word}.article-body-source__label{font-weight:500}.article-block{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);grid-gap:1.5rem;gap:1.5rem;align-items:start;margin-bottom:2.5rem}.article-block--stacked{grid-template-columns:1fr}@media (max-width:768px){.article-block{grid-template-columns:1fr}}.article-block-images{display:flex;flex-direction:column;gap:.75rem}.figure-block{margin:0;position:relative}.figure-block img{width:100%;height:auto;display:block;border-radius:0}.figure-caption{font-size:.65rem;color:var(--text-muted);text-align:center;display:block;margin-top:.35rem}.article-block-text{margin-top:-.32rem}.article-block-text .subheading{font-size:.95rem;margin:0 0 .5rem;font-weight:600}.article-block-text .body{font-size:.85rem;line-height:1.75;white-space:pre-wrap;word-break:keep-all}.admin-root{text-align:center;font-family:Noto Sans KR,system-ui,sans-serif;color:var(--text);background:var(--cream);min-height:100%}.admin-shell{max-width:900px;margin:0 auto;padding:2rem 1.25rem 4rem}.admin-shell--narrow{max-width:26rem}.admin-shell--write{max-width:960px}.admin-shell h1{font-size:1.35rem;margin-top:0;font-family:Noto Sans KR,system-ui,sans-serif;font-weight:600}.login-form{display:flex;flex-direction:column;align-items:center}.login-form .form-field{width:100%;max-width:376px}.login-form .form-field label{text-align:center}.login-form .form-field input[type=password]{margin-left:auto;margin-right:auto;border-radius:0}.login-form .btn{border-radius:0}.login-shell{min-height:100vh;min-height:100dvh;position:relative;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch}.login-center-block{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:376px;text-align:center}.login-center-block>.muted{position:relative;top:-1cm}.admin-root .toolbar{justify-content:center}.admin-toolbar{margin-bottom:1cm}.admin-toolbar .btn{border-radius:0}.admin-root .admin-shell--narrow .form-field input,.admin-root .admin-shell--narrow .form-field textarea{width:100%;max-width:100%;margin-left:0;margin-right:0}.admin-section-title{font-family:Noto Sans KR;font-size:1.15rem;font-weight:500;margin:2rem 0 .75rem;text-align:center}.admin-card-list{list-style:none;padding:0;margin:1cm 0 0}.admin-list-item{display:flex;align-items:center;gap:1rem;padding:1.25rem 3rem 1.25rem 0;border-bottom:1px solid var(--border);text-align:left;position:relative}.admin-list-item__thumb-wrap{width:72px;flex-shrink:0}.admin-list-thumb{width:72px;height:72px;object-fit:cover;display:block;border-radius:0;background:#e8e3d9}.admin-list-item__content{min-width:0;flex:1 1;display:flex;flex-direction:column;align-items:flex-start}.admin-list-item .card-meta{margin-top:0}.admin-edit-link{display:inline-block;color:var(--accent);font-size:80%;text-decoration:none}.admin-edit-link:hover{text-decoration:underline;text-underline-offset:3px}.admin-item-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:.45rem}.admin-delete-link{border:none;background:transparent;padding:0;font:inherit;font-size:80%;color:var(--text-muted);cursor:pointer;text-decoration:none}.admin-delete-link:hover{text-decoration:underline;text-underline-offset:3px;color:var(--text-muted)}.write-site-header{max-width:960px;margin:0 auto;padding:1.25rem 1.5rem .5rem}.write-site-header.site-header{flex-direction:row;align-items:center;justify-content:center;text-align:initial}.write-top-nav{display:flex;align-items:center;justify-content:flex-start;width:100%;max-width:960px;font-size:.9rem}.write-top-nav a{color:var(--accent);text-decoration:none}.write-top-nav a:hover{text-decoration:underline;text-underline-offset:3px}.write-top-nav__left{margin-right:auto;font-size:.82rem}.admin-root .write-page{text-align:initial;max-width:960px;margin:0 auto;padding:0 1.5rem 4rem;overflow-anchor:none}.write-page .error-banner,.write-page .success-banner{max-width:32rem;margin-left:auto;margin-right:auto;text-align:center}.write-inline-article{padding-top:.5rem}.write-title-input.article-page-title{width:100%;max-width:100%;display:block;margin:0 0 .5rem;padding:.15rem 0;border:none;border-radius:0;background:transparent;color:var(--text);font:inherit;font-family:Noto Sans KR,system-ui,sans-serif;font-size:1.35rem;font-weight:500;text-align:center}.write-title-input.article-page-title:focus{outline:1px dashed var(--border);outline-offset:4px}.write-date-row{display:flex;align-items:baseline;justify-content:flex-end;gap:.15rem}.write-date-num{background:transparent;border:none;border-bottom:1.5px solid #2b4fff;font-size:.7rem;color:#f97316;font-family:inherit;text-align:center;padding:0 .05rem}.write-date-num--sm{width:1.6rem}.write-date-num--lg{width:2.6rem}.write-date-num:focus{outline:none;border-bottom-color:#f97316}.write-date-label{color:#2b4fff;font-size:.7rem}.write-slug-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.25rem .5rem;margin:0 auto 2rem;font-size:.75rem;color:var(--text-muted)}.write-slug-input{min-width:8rem;max-width:20rem;flex:1 1 auto;padding:.2rem .35rem;border:1px solid transparent;border-bottom:1px solid var(--border);border-radius:0;background:transparent;font:inherit;font-size:.75rem;color:var(--text)}.write-slug-input:focus{outline:none;border-bottom-color:var(--accent)}.write-figure-wrap{margin-bottom:1.25rem}.write-section-head{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--text-muted);margin-bottom:.35rem}.write-inline-img{width:100%;height:auto;display:block;border-radius:0}.write-image-nav{position:absolute;top:0;bottom:0;width:56px;border:none;touch-action:manipulation;background:transparent;color:#fff;font-size:1.45rem;line-height:1;opacity:0}.write-image-nav--prev{left:0;background:linear-gradient(90deg,hsla(0,0%,4%,.22),hsla(0,0%,4%,0));cursor:w-resize}.write-image-nav--next{right:0;background:linear-gradient(270deg,hsla(0,0%,4%,.22),hsla(0,0%,4%,0));cursor:e-resize}.write-image-nav:focus-visible,.write-image-nav:hover{opacity:1}@media (hover:none){.write-image-nav{opacity:0;transition:opacity .6s ease}.write-image-nav:active{opacity:1;transition:none}}.write-img-placeholder{min-height:calc(140px + 2cm + 2cm);text-align:center;padding:1rem;font-size:.75rem;color:var(--text-muted);border:1px dashed var(--border);background:hsla(0,0%,100%,.35)}.write-image-dots-row,.write-img-placeholder{display:flex;align-items:center;justify-content:center}.write-image-dots-row{gap:.55rem;margin:.35rem 0 .2rem;overflow:visible;position:relative;z-index:2}.write-image-dots-row:before{content:"점에서 이미지를 고른뒤 <앞><뒤>로 순서를 바꿀 수 있습니다.";position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);z-index:8;width:max-content;max-width:min(22rem,calc(100vw - 2rem));padding:0;background:none;border:none;box-shadow:none;font-size:.68rem;font-weight:600;line-height:1.45;text-align:center;color:#2563eb;white-space:pre-line;pointer-events:none;opacity:0;transition:opacity .12s ease}.write-image-dots-row:hover:before{opacity:1}.write-order-nudge{flex:0 0 auto;padding:.15rem .2rem;font:inherit;font-size:.68rem;font-weight:600;color:var(--text-muted);background:transparent;border:none;border-radius:0;cursor:pointer}.write-order-nudge:hover:not(:disabled){color:var(--accent);text-decoration:none}.write-order-nudge:disabled{opacity:.35;cursor:default}.write-image-dots{display:flex;align-items:center;justify-content:center;gap:.45rem;flex-shrink:0}.write-image-dot{position:relative;width:11px;height:11px;border:none;touch-action:manipulation;border-radius:50%;background:#c9c9c9;padding:0;cursor:pointer;flex-shrink:0}.write-image-dot:after{content:"";position:absolute;inset:-10px;z-index:1}.write-image-dot.is-active{background:#888}.write-caption-input{display:block;width:100%;margin-top:.45rem;padding:.2rem .25rem;border:none;border-radius:0;background:transparent;font:inherit;font-size:.65rem;color:var(--text-muted);text-align:center}.write-caption-input:focus{outline:1px dashed var(--border)}.write-caption-input:disabled{opacity:.45;cursor:not-allowed}.write-img-tools{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .3rem;margin-top:.45rem}.write-tool-input{flex:1 1 140px;min-width:0;padding:.25rem .35rem;font-size:.72rem;border:1px solid var(--border);border-radius:0;background:var(--surface)}.write-file-label{font-size:.72rem;color:#ff4f00;cursor:pointer;text-decoration:none;margin-left:.2cm}.write-file-label:focus-visible,.write-file-label:hover{color:var(--accent)}.write-tooltip-anchor--input{flex:1 1 140px;min-width:0;display:block;max-width:calc(100% - .4rem)}.write-tooltip-anchor--input .write-tool-input{width:100%}.write-floating-tooltip{position:fixed;z-index:2000;color:var(--accent);background:transparent;font-size:.68rem;line-height:1.2;white-space:nowrap;pointer-events:none}.write-file-input{display:none}.write-tool-btn{font:inherit;font-size:.72rem;padding:.2rem .45rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;text-decoration:none}.write-tool-btn:hover{color:var(--accent)}.write-cover-picker{margin-top:calc(.8rem + 1cm)}.write-cover-picker__title{font-size:.8rem;color:#084cfa;margin-bottom:.35rem}.write-cover-picker__grid{display:flex;flex-wrap:wrap;gap:.4rem;overflow:visible;padding:.2rem 0}.write-cover-thumb{width:56px;height:56px;padding:0;border:1px solid var(--border);background:var(--surface);position:relative;cursor:pointer;transition:transform .15s ease;transform-origin:center}.write-cover-thumb img{width:100%;height:100%;object-fit:cover;display:block}.write-cover-thumb.is-selected{border-color:var(--accent)}.write-cover-thumb.is-hovered,.write-cover-thumb:focus-visible{transform:scale(4);z-index:20}.write-cover-thumb__check{position:absolute;right:2px;bottom:2px;font-size:.7rem;line-height:1;color:#fff;background:#084cfa;padding:2px 3px}.write-inline-sub{display:block;width:100%;margin:0 0 .5rem;padding:.1rem 0;border:none;border-radius:0;background:transparent;color:var(--text);font:inherit;font-size:.95rem;font-weight:600}.write-inline-sub:focus{outline:1px dashed var(--border);outline-offset:2px}.write-inline-sub::placeholder{color:var(--text-muted);font-weight:400}.write-inline-body{display:block;width:100%;margin:0;padding:.1rem 0;border:none;border-radius:0;background:transparent;color:var(--text);font:inherit;font-size:.85rem;line-height:1.75;white-space:pre-wrap;word-break:keep-all;resize:none;overflow:hidden;min-height:10rem}.write-inline-body:focus{outline:1px dashed var(--border);outline-offset:2px}.write-inline-body::placeholder{color:var(--text-muted)}.write-link-btn{font:inherit;font-size:.75rem;padding:0;border:none;background:none;color:var(--text-muted);cursor:pointer;text-decoration:none}.write-link-btn:hover{color:var(--accent)}.write-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.write-source-row{margin-top:2cm;display:flex;align-items:baseline;gap:.4rem;color:var(--text-muted);font-size:.75rem}.write-actions .btn{min-width:92px;padding-left:1.25rem;padding-right:1.25rem;border-radius:0}.write-actions .write-draft-btn{border-color:var(--border);color:var(--text-muted)}.write-source-label{white-space:nowrap}.write-source-input{flex:1 1 auto;min-width:0;border:none;border-bottom:1px solid var(--text-muted);background:transparent;color:var(--text-muted);font:inherit;font-size:.75rem;padding:.1rem .1rem .15rem}.write-source-input:focus{outline:none;border-bottom-color:var(--text-muted)}.form-field{margin-bottom:1rem}.form-field label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.35rem}.form-field input[type=password],.form-field input[type=text],.form-field textarea{width:100%;padding:.55rem .65rem;border:1px solid var(--border);border-radius:0;font:inherit;background:var(--surface)}.form-field textarea{min-height:120px;resize:vertical}.btn{display:inline-block;padding:.55rem 1rem;font:inherit;font-size:.9rem;border-radius:0;border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;text-decoration:none}.btn:hover{opacity:.92}.btn.secondary{background:transparent;color:var(--accent)}.muted{color:var(--text-muted);font-size:.8rem}.error-banner{background:#fde8e8;color:#8a1f1f}.error-banner,.success-banner{padding:.65rem .75rem;border-radius:0;margin-bottom:1rem;font-size:.85rem}.success-banner{background:#e8f5e9;color:#1b5e20}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.article-side-toc{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:1cm;z-index:1200;display:block}.article-side-toc__trigger{width:1cm;height:100%;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.article-side-toc__trigger-logo{width:1cm;height:1cm;object-fit:contain;opacity:.88;transform:translateX(0);transition:opacity .24s ease,transform .34s cubic-bezier(.16,1,.3,1)}.article-side-toc:hover .article-side-toc__trigger-logo{opacity:0;transform:translateX(-4px)}.article-side-toc__panel{position:absolute;top:0;left:0;width:296px;height:100%;background:var(--cream);border-right:1px solid var(--border);box-shadow:10px 0 28px rgba(0,0,0,.08);transform:translateX(-100%);opacity:0;pointer-events:none;transition:transform .52s cubic-bezier(.16,1,.3,1),opacity .34s ease}.article-side-toc:hover .article-side-toc__panel{transform:translateX(0);opacity:1;pointer-events:auto}.article-side-toc__list{list-style:none;margin:0;padding:0;max-height:100%;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.article-side-toc__list::-webkit-scrollbar{width:0;height:0;display:none}.article-side-toc__list li a{display:flex;gap:.75rem;padding:.72rem .9rem;text-decoration:none}.article-side-toc__list li:hover a{background:#eef4ff}.article-side-toc__list li.is-active a{border-left:5px solid #fb4600;padding-left:.6rem;background:rgba(251,70,0,.04)}.article-side-toc__thumb-wrap{flex-shrink:0}.article-side-toc__thumb{display:block;width:48px;height:48px;background-size:cover;background-position:50%;background-repeat:no-repeat;border-radius:2px}.article-side-toc__thumb--empty{background:#f2f2f2;border:1px solid var(--border)}.article-side-toc__content{display:flex;flex-direction:column;min-width:0}.article-side-toc__title{font-size:.78rem;line-height:1.35;color:var(--text);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.article-block-text,.article-body-source,.article-page-date,.article-page-title{-moz-user-select:none;user-select:none;-webkit-user-select:none}