.toast-container{position:fixed;top:20px;right:20px;z-index:9999;pointer-events:none;display:flex;flex-direction:column;gap:10px}.toast-item{padding:15px 20px;min-width:250px;max-width:350px;border-radius:8px;color:#fff;font-weight:600;box-shadow:0 4px 12px var(--color-shadow-strong);transition:all .3s cubic-bezier(.25,.8,.25,1);pointer-events:auto;cursor:pointer;display:flex;align-items:center}.toast-item,.toast-transition-enter{opacity:0;transform:translateX(100%)}.toast-transition-enter-active,.toast-transition-exit{opacity:1;transform:translateX(0)}.toast-transition-exit-active{opacity:0;transform:translateX(100%)}:root{--font-family-main:"Spoqa Han Sans Neo","Inter",sans-serif;--font-family-cursive:var(--font-caveat),cursive;--color-background:#fff;--color-primary:#fff;--color-secondary:#f5f5f5;--color-bg-sub:#f5f5f5;--color-text-main:#111;--color-text-sub:#5c5c5c;--color-accent:#111;--color-accent-hover:#000;--color-on-accent:#fff;--color-link:#111;--color-logo:#111;--color-border:rgba(0,0,0,.1);--color-shadow:rgba(0,0,0,.06);--color-shadow-strong:rgba(0,0,0,.12);--color-success:#1b5e20;--color-error:#b71c1c}body.dark-mode{--color-background:#000;--color-primary:#000;--color-secondary:#141414;--color-bg-sub:#141414;--color-text-main:#f5f5f5;--color-text-sub:#a3a3a3;--color-accent:#f0f0f0;--color-accent-hover:#fff;--color-on-accent:#0a0a0a;--color-link:#e5e5e5;--color-logo:#f5f5f5;--color-border:hsla(0,0%,100%,.14);--color-shadow:rgba(0,0,0,.4);--color-shadow-strong:rgba(0,0,0,.55);--color-success:#81c784;--color-error:#ef9a9a}html{box-sizing:border-box}*,:after,:before{box-sizing:inherit;transition:background-color .3s,color .3s,border-color .3s}body{margin:0;padding:0;font-family:var(--font-family-main);background-color:var(--color-background);color:var(--color-text-main);line-height:1.6}a{color:var(--color-link);text-decoration:none}a:hover{color:var(--color-accent)}.cursive-title{font-family:var(--font-family-cursive)!important;font-size:1.6rem!important;font-weight:400!important;margin-bottom:15px!important}.App{display:flex;flex-direction:column;min-height:100vh}.main-content-container{flex-grow:1;max-width:1200px;width:100%;margin:0 auto;padding:20px}.main-content-container:has(.auth-page){display:flex;align-items:center;justify-content:center}.btn-link-primary,.btn-primary,.btn-secondary{cursor:pointer;padding:12px 20px;border-radius:8px;font-weight:600;text-align:center;transition:all .2s ease-in-out;border:none}.btn-primary{background-color:var(--color-accent);color:var(--color-on-accent)}.btn-primary:hover{background-color:var(--color-accent-hover);box-shadow:0 4px 10px var(--color-shadow-strong)}.btn-secondary{background-color:var(--color-secondary);color:var(--color-text-main);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border)}.btn-primary-small,.btn-secondary-small{padding:8px 15px;border-radius:6px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .2s ease-in-out;border:none}.btn-primary-small{background-color:var(--color-accent);color:var(--color-on-accent)}.btn-primary-small:hover{background-color:var(--color-accent-hover)}.btn-secondary-small{background-color:var(--color-secondary);color:var(--color-text-main);border:1px solid var(--color-border)}.btn-secondary-small:hover{background-color:var(--color-border)}.tag-badge{padding:6px 12px;margin-right:8px;margin-bottom:8px;background-color:var(--color-secondary);border:1px solid var(--color-border);border-radius:20px;font-size:.9em;font-weight:500}.category-link,.tag-badge{display:inline-block;color:var(--color-text-main);transition:all .3s}.category-link{padding:10px 20px;background-color:var(--color-primary);border:1px solid var(--color-border);border-radius:10px;font-weight:600}.category-link:hover{border-color:var(--color-accent);box-shadow:0 4px 12px var(--color-shadow);text-decoration:none;transform:translateY(-2px)}.markdown-body{line-height:1.8;color:var(--color-text-main)}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--color-text-main);margin-top:40px;margin-bottom:20px;font-weight:700}.markdown-body h1{font-size:2.2em;border-bottom:2px solid var(--color-border);padding-bottom:8px}.markdown-body h2{font-size:1.8em;border-bottom:1px dashed var(--color-border);padding-bottom:6px}.markdown-body h3{font-size:1.5em}.markdown-body p{margin-bottom:1em}.markdown-body a{color:var(--color-accent);text-decoration:underline}.markdown-blockquote{margin:20px 0;padding:15px 20px;border-left:5px solid var(--color-accent);color:var(--color-text-main);font-style:italic}.markdown-blockquote,.markdown-inline-code{background-color:var(--color-secondary);border-radius:4px}.markdown-inline-code{color:var(--color-accent);padding:3px 6px;font-family:monospace;font-size:.9em}.markdown-fenced{margin:1rem 0;padding:1rem 1.1rem;border-radius:8px;overflow-x:auto;background:var(--color-secondary,#1e1e1e);border:1px solid var(--color-border,#333)}.markdown-fenced code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em;line-height:1.5;white-space:pre;display:block;color:var(--color-text-main,#e0e0e0);background:transparent;padding:0}.markdown-fenced[data-lang]:before{content:attr(data-lang);display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;opacity:.55;margin-bottom:.5rem;font-family:system-ui,sans-serif}.post-form-input,.post-form-textarea{width:100%;padding:15px;border:1px solid var(--color-border);border-radius:8px;font-size:1.1em;background-color:var(--color-secondary);color:var(--color-text-main);transition:border-color .2s,box-shadow .2s}.post-form-input:focus,.post-form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent);outline:none}.post-list-page{width:100%;max-width:min(1200px,100%);margin:0 auto;padding:clamp(24px,5vw,40px) clamp(12px,4vw,28px) clamp(48px,8vw,80px);box-sizing:border-box}.post-list-page .list-header h1{font-size:clamp(1.45rem,5vw,2.5rem);line-height:1.2}.post-list-page .post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));grid-gap:clamp(16px,3vw,28px);gap:clamp(16px,3vw,28px)}.post-detail-container{max-width:min(800px,100%);margin:0 auto;padding:clamp(24px,5vw,40px) clamp(12px,4vw,22px) clamp(40px,8vw,56px);box-sizing:border-box}.post-detail-title{font-size:clamp(1.65rem,5.5vw,3rem);font-weight:900;margin-bottom:15px;line-height:1.2;color:var(--color-text-main)}.write-page-shell{padding:clamp(24px,5vw,40px) clamp(12px,4vw,24px);max-width:min(1200px,100%);margin:0 auto;box-sizing:border-box}.write-page-title{color:var(--color-text-main);font-size:clamp(1.35rem,4vw,2rem);margin:0}.write-page-cover-uploads{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.write-page-file-label{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-secondary);color:var(--color-text-main);font-size:.9rem;cursor:pointer;overflow:hidden}.write-page-file-label.is-busy{opacity:.65;cursor:wait}.write-page-file-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;font-size:0}.write-page-file-input:disabled{cursor:not-allowed}.write-page-editor-row{display:flex;flex-direction:row;gap:20px;min-height:min(600px,70vh);align-items:stretch}.write-page-textarea{border-radius:8px;background-color:var(--color-primary);resize:vertical;font-size:1rem;line-height:1.6}.write-page-preview,.write-page-textarea{flex:1 1;min-width:0;min-height:280px;padding:20px;border:1px solid var(--color-border);color:var(--color-text-main)}.write-page-preview{border-radius:8px;background-color:var(--color-bg-sub);overflow-y:auto}@media (max-width:900px){.write-page-editor-row{flex-direction:column;min-height:0}.write-page-preview,.write-page-textarea{min-height:240px}}.comments-section{margin-top:40px;padding:30px 0}.comments-section .section-title{font-size:1.8rem;color:var(--color-text-main);margin-bottom:30px;padding-bottom:10px;border-bottom:2px solid var(--color-border);font-weight:700}.login-prompt,.no-comments{text-align:center;color:var(--color-text-sub);padding:30px 0;font-style:italic}.comment-form{margin-bottom:40px;padding:25px;background-color:var(--color-primary);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 2px 8px var(--color-shadow);transition:all .3s;display:flex;flex-direction:column;gap:15px}.comment-form textarea{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:6px;font-size:1em;background-color:var(--color-secondary);color:var(--color-text-main);resize:vertical}.comment-form textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 1px var(--color-accent)}.comment-form button{align-self:flex-end;max-width:100px}.comments-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--color-border);background-color:var(--color-primary);border-radius:10px;padding:0 20px}.comment-item{padding:20px 0;border-bottom:1px solid var(--color-border)}.comments-list .comment-item:last-child{border-bottom:none}.comment-meta{display:flex;justify-content:space-between;align-items:center;font-size:.9em;color:var(--color-text-sub);margin-bottom:10px}.comment-author{font-weight:700;color:var(--color-accent);margin-right:10px;font-size:1em}.comment-date{font-size:.8em;color:var(--color-text-sub)}.comment-content{white-space:pre-wrap;word-break:break-word;margin:0;font-size:1em}.comment-badge{display:inline-block;background-color:var(--color-accent);color:var(--color-on-accent,#fff);padding:2px 8px;border-radius:4px;font-size:.7em;font-weight:600;margin-left:5px}.comment-actions{text-align:right;margin-top:10px;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.comment-replies{margin-top:16px;padding-left:16px;border-left:2px solid var(--color-border)}.comment-item--depth-1,.comment-item--depth-2,.comment-item--depth-3,.comment-item--depth-4{padding-top:16px}.comment-reply-wrap{margin-top:12px;padding:12px;background:var(--color-secondary);border-radius:8px;border:1px solid var(--color-border)}.comment-reply-form{display:flex;flex-direction:column;gap:10px}.comment-reply-form textarea{width:100%;padding:10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-primary);color:var(--color-text-main);font-size:.95rem;resize:vertical}.comment-reply-form__actions{display:flex;gap:8px;justify-content:flex-end}