@import "https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700;800&family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Geist+Mono:wght@400;500&display=swap";:root{--color-bg:#080e1a;--color-surface:#0d1525;--color-border:#1e2d47;--color-border-light:#162038;--color-text:#e4eaf4;--color-muted:#6080a8;--color-dim:#2a3f5e;--color-accent:#f29106;--color-accent-hov:#ffaa2e;--color-accent-dim:#f291061a;--font-ui:"Geist", system-ui, sans-serif;--font-editor:"Lora", Georgia, serif;--font-mono:"Geist Mono", "Fira Code", monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-card:0 1px 3px #0006, 0 4px 16px #0000004d;--shadow-elevated:0 4px 24px #00000080;--transition-fast:.12s ease;--transition-base:.2s ease}[data-theme=light]{--color-bg:#efefef;--color-surface:#e5e5e5;--color-border:#bfcfe8;--color-border-light:#c8d8ee;--color-text:#0e1825;--color-muted:#4a6a96;--color-dim:#8aaace;--color-accent:#d97c00;--color-accent-hov:#bf6d00;--color-accent-dim:#d97c0014;--shadow-card:0 1px 3px #00000014, 0 4px 16px #0000000f;--shadow-elevated:0 4px 24px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-ui);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:var(--font-ui);cursor:pointer;background:0 0;border:none}.site-header{z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);-webkit-backdrop-filter:blur(12px);position:sticky;top:0}.site-header__inner{justify-content:space-between;align-items:center;gap:24px;max-width:1100px;height:56px;margin:0 auto;padding:0 24px;display:flex}.site-header__wordmark{letter-spacing:-.02em;color:var(--color-text);white-space:nowrap;font-size:15px;font-weight:700}.site-header__wordmark span{color:var(--color-accent)}.site-header__nav{align-items:center;gap:4px;display:flex}.site-header__nav a{color:var(--color-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);padding:5px 10px;font-size:13px;font-weight:500}.site-header__nav a:hover,.site-header__nav a.active{color:var(--color-text);background:var(--color-border-light)}.site-header__actions{align-items:center;gap:8px;display:flex}.theme-toggle{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-muted);transition:color var(--transition-fast), background var(--transition-fast);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{color:var(--color-text);background:var(--color-border-light)}.page-container{max-width:1100px;margin:0 auto;padding:8px 24px 96px}.tag{font-family:var(--font-mono);color:var(--color-accent);background:var(--color-accent-dim);border-radius:var(--radius-sm);white-space:nowrap;transition:background var(--transition-fast), border-color var(--transition-fast);border:1px solid #f2910633;align-items:center;padding:2px 7px;font-size:11px;font-weight:400;display:inline-flex}[data-theme=light] .tag{border-color:#d97c0040}.tag:hover{background:#f291062e;border-color:#f2910666}.tag-list{flex-wrap:wrap;gap:6px;display:flex}.author-chip{align-items:center;gap:8px;display:flex}.author-chip__avatar{object-fit:cover;background:var(--color-dim);border-radius:50%;flex-shrink:0;width:28px;height:28px}.author-chip__avatar--placeholder{color:var(--color-muted);background:var(--color-dim);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:10px;font-weight:700;display:flex}.author-chip__name{color:var(--color-muted);font-size:13px;font-weight:500}.state-loading,.state-error,.state-empty{min-height:320px;color:var(--color-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.state-loading__spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.state-error__code{font-family:var(--font-mono);color:var(--color-dim);margin-top:4px;font-size:12px}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.3s forwards fadeUp}@media (width<=640px){.site-header__inner{grid-template-columns:auto 1fr auto;align-items:center;gap:8px;height:56px;padding:0 16px;display:grid}.site-header__brand{flex-shrink:0;justify-self:start;align-items:center;gap:8px;min-width:0;display:inline-flex}.site-header__wordmark{white-space:nowrap;flex-shrink:0;font-size:14px}.site-header__nav{white-space:nowrap;-ms-overflow-style:none;scrollbar-width:none;justify-content:center;justify-self:center;align-items:center;gap:2px;min-width:0;display:flex;overflow-x:auto}.site-header__nav::-webkit-scrollbar{display:none}.site-header__nav a{padding:5px 8px;font-size:12px}.site-header__actions{flex-shrink:0;justify-self:end;align-items:center;gap:6px;margin-left:0;display:flex}.page-container{padding:2px 16px 72px}}.site-footer{border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;max-width:1100px;margin-top:48px;margin-left:auto;margin-right:auto;padding:24px 24px 40px;display:flex;position:relative}.site-footer__rss{opacity:.5;transition:opacity var(--transition-base);align-items:center;gap:6px;text-decoration:none;display:inline-flex}.site-footer__rss:hover{opacity:1}.site-footer__rss-label{font-family:var(--font-mono);color:var(--color-muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px}.site-footer__badge{opacity:.5;transition:opacity var(--transition-base);align-items:center;gap:8px;text-decoration:none;display:inline-flex;position:absolute;left:50%;transform:translate(-50%)}.site-footer__badge:hover{opacity:1}.site-footer__powered{font-family:var(--font-mono);color:var(--color-muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px}.site-footer__logo{width:auto;height:28px}.floating-time{z-index:9999;pointer-events:none;bottom:100px;left:calc(50% - 400px);position:fixed!important}.floating-time__circle{background:var(--color-muted);opacity:.6;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.floating-time__label{font-family:var(--font-mono);color:#fff;letter-spacing:-.1em;font-size:14px;font-weight:400;line-height:1}.floating-nav{z-index:9999;flex-direction:column;gap:6px;display:flex;bottom:100px;right:calc(50% - 400px);position:fixed!important}.floating-nav__btn{width:32px;height:32px;color:var(--color-muted);cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.floating-nav__btn:hover{opacity:1}.floating-nav__btn--dim{opacity:.2;cursor:default;pointer-events:none}@media (width<=900px){.floating-time{left:16px}.floating-nav{right:16px}}@media (width<=640px){.floating-time{bottom:16px;left:16px}.floating-nav{bottom:16px;right:16px}}.site-header__login-btn{color:var(--color-muted);border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;padding:5px 12px;font-size:13px;font-weight:600}.site-header__login-btn:hover{color:var(--color-text);border-color:var(--color-border);background:var(--color-border-light)}.site-header__brand{flex-shrink:0;align-items:center;gap:10px;min-width:0;display:inline-flex}.site-header__logo{object-fit:contain;border-radius:8px;flex-shrink:0;width:32px;height:32px;display:block}.site-header__logo-placeholder{width:32px;height:32px;font-size:12px;font-weight:700;font-family:var(--font-ui);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border-light);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.site-header__user{position:relative}.site-header__avatar-btn{border:1px solid var(--color-border);cursor:pointer;width:32px;height:32px;transition:border-color var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;overflow:hidden}.site-header__avatar-btn:hover{border-color:var(--color-accent)}.site-header__avatar-img{object-fit:cover;width:100%;height:100%}.site-header__avatar-placeholder{background:var(--color-dim);width:32px;height:32px;color:var(--color-muted);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.site-header__dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);z-index:500;min-width:160px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.site-header__dropdown-name{color:var(--color-muted);border-bottom:1px solid var(--color-border-light);white-space:nowrap;text-overflow:ellipsis;padding:10px 14px 8px;font-size:12px;font-weight:600;overflow:hidden}.site-header__dropdown-item{text-align:left;width:100%;color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;padding:9px 14px;font-size:13px;font-weight:500;text-decoration:none;display:block}.site-header__dropdown-item:hover{background:var(--color-border-light)}.site-header__dropdown-item--signout{color:var(--color-muted);border-top:1px solid var(--color-border-light)}.auth-modal__oauth-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;gap:10px;margin-bottom:0;padding:10px 14px;font-size:14px;font-weight:500;display:flex}.auth-modal__oauth-btn:hover{background:var(--color-border-light);border-color:var(--color-border)}.auth-modal__divider{color:var(--color-muted);align-items:center;gap:10px;margin:0;font-size:12px;display:flex}.auth-modal__divider:before,.auth-modal__divider:after{content:"";background:var(--color-border-light);flex:1;height:1px}.auth-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080e1aeb;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.auth-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 32px 80px #0009}.auth-modal__brand{align-items:center;gap:12px;padding:28px 28px 0;display:flex}.auth-modal__logo{width:auto;height:56px}.auth-modal__wordmark{letter-spacing:-.02em;color:var(--color-text);font-size:18px;font-weight:800;font-family:var(--font-ui)}.auth-modal__tabs{border-bottom:1px solid var(--color-border);margin:20px 0 0;display:flex}.auth-modal__tab{color:var(--color-muted);font-family:var(--font-ui);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px;font-size:14px;font-weight:500}.auth-modal__tab--active{color:var(--color-text);font-weight:700}.auth-modal__tab--active-login{border-bottom-color:#3296ab}.auth-modal__tab--active-signup{border-bottom-color:#c0392b}.auth-modal__body{flex-direction:column;gap:14px;padding:24px 28px 28px;display:flex}.auth-modal__error{border-radius:var(--radius-sm);color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;padding:10px 12px;font-size:13px}.auth-modal__success{border-radius:var(--radius-sm);color:#86efac;background:#2dd98a1a;border:1px solid #2dd98a4d;padding:10px 12px;font-size:13px}.auth-modal__field{flex-direction:column;gap:6px;margin-bottom:4px;display:flex}.auth-modal__label{color:var(--color-muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.auth-modal__input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:14px;font-family:var(--font-ui);box-sizing:border-box;width:100%;transition:border-color var(--transition-fast);outline:none;padding:11px 14px}.auth-modal__input:focus{border-color:#3296ab}.auth-modal__input-wrap{position:relative}.auth-modal__input--password{padding-right:40px}.auth-modal__eye{cursor:pointer;color:var(--color-muted);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.auth-modal__forgot{text-align:right;margin-top:-6px}.auth-modal__forgot-btn{color:#3296ab;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-ui);background:0 0;border:none}.auth-modal__submit{border-radius:var(--radius-md);color:#fff;font-family:var(--font-ui);cursor:pointer;width:100%;transition:background var(--transition-fast);background:#3296ab;border:none;margin-top:4px;padding:13px;font-size:15px;font-weight:700}.auth-modal__submit:hover{background:#2a849a}.auth-modal__submit--signup{background:#c0392b}.auth-modal__submit--signup:hover{background:#a93226}.auth-modal__submit:disabled{opacity:.6;cursor:not-allowed}.auth-modal__close{width:28px;height:28px;color:var(--color-muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;top:14px;right:14px}.auth-modal__close:hover{background:var(--color-border-light);color:var(--color-text)}.like-btn{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);font-family:var(--font-ui);background:0 0;border:none;align-items:center;gap:5px;padding:4px 8px;display:inline-flex}.like-btn:hover{background:var(--color-accent-dim)}.like-btn:disabled{cursor:default;opacity:.6}.like-btn__count{color:var(--color-muted);font-size:13px;font-family:var(--font-ui)}.like-btn--liked .like-btn__count{color:var(--color-accent)}.comments-section{max-width:680px;margin-top:52px;margin-left:auto;margin-right:auto}.comments{border-top:1px solid var(--color-border-light);padding-top:0}.comments__bar{cursor:pointer;width:100%;font-family:var(--font-ui);color:var(--color-text);background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:16px 0;display:flex}.comments__bar:hover .comments__bar-label{color:var(--color-accent)}.comments__bar-label{transition:color var(--transition-fast);font-size:15px;font-weight:700}.comments__bar-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.comments__bar-action{color:var(--color-accent);font-size:13px;font-weight:600}.comments__bar-action:hover{color:var(--color-accent-hov)}.comments__bar-caret{color:var(--color-muted);transition:transform var(--transition-base);flex-shrink:0}.comments__bar-caret--open{transform:rotate(180deg)}.comments__body{padding-bottom:40px}.comments__sticky-form{background:var(--color-bg);z-index:50;border-bottom:1px solid var(--color-border-light);margin-bottom:28px;padding:16px 0;position:sticky;top:56px}.comments__loading{color:var(--color-muted);padding:16px 0;font-size:13px}.comments__empty{color:var(--color-muted);padding:8px 0;font-size:13px}.comments__list{flex-direction:column;gap:28px;display:flex}.comment{align-items:flex-start;gap:14px;display:flex}.comment__avatar{flex-shrink:0;width:36px;height:36px}.comment__avatar img{object-fit:cover;border-radius:50%;width:36px;height:36px}.comment__avatar-placeholder{background:var(--color-dim);width:36px;height:36px;color:var(--color-muted);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.comment__body{flex:1;min-width:0}.comment__meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px;display:flex}.comment__name{color:var(--color-text);font-size:13px;font-weight:600;font-family:var(--font-ui)}.comment__date{color:var(--color-dim);font-size:11px;font-family:var(--font-mono)}.comment__actions{gap:8px;margin-left:auto;display:flex}.comment__action-btn{color:var(--color-muted);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-ui);transition:color var(--transition-fast);background:0 0;border:none;padding:0}.comment__action-btn:hover{color:var(--color-text)}.comment__action-btn--delete:hover{color:#ef4444}.comment__content{color:var(--color-text);font-size:15px;font-family:var(--font-ui);white-space:pre-wrap;line-height:1.65}.comment__edit{flex-direction:column;gap:8px;display:flex}.comment__edit-actions{gap:8px;display:flex}.comment-form{flex-direction:column;gap:10px;display:flex}.comment__textarea{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:var(--font-ui);resize:vertical;transition:border-color var(--transition-fast);box-sizing:border-box;outline:none;padding:12px 14px;font-size:14px;line-height:1.6}.comment__textarea:focus{border-color:var(--color-accent)}.comment-form__footer{justify-content:flex-end;display:flex}.comment__submit-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-sm);font-size:13px;font-weight:700;font-family:var(--font-ui);cursor:pointer;transition:background var(--transition-fast), opacity var(--transition-fast);border:none;padding:8px 18px}.comment__submit-btn:hover{background:var(--color-accent-hov)}.comment__submit-btn:disabled{opacity:.4;cursor:not-allowed}.comment__cancel-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font-ui);color:var(--color-muted);cursor:pointer;transition:background var(--transition-fast);background:0 0;padding:8px 14px}.comment__cancel-btn:hover{background:var(--color-border-light)}.comment-form__login-prompt{background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-muted);font-size:14px;font-family:var(--font-ui);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);text-align:center;padding:14px}.comment-form__login-prompt:hover{border-color:var(--color-accent);color:var(--color-accent)}.blog-hero{margin-bottom:8px;padding:8px 0 20px}.blog-hero__label-row{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.blog-hero__label{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:11px;font-weight:500;line-height:1}.blog-hero__tagline{color:var(--color-muted);font-size:13px;font-family:var(--font-ui);margin:0;line-height:1.2}.post-grid-featured{display:none}.post-grid{grid-template-columns:repeat(2,1fr);gap:20px;width:100%;display:grid}.post-card{background:var(--color-surface)}[data-theme=light] .post-card{background:#fff}.post-card{border:1px solid var(--color-border-light);cursor:pointer;opacity:0;border-radius:12px;flex-direction:column;min-width:0;height:100%;transition:background .15s,border-color .15s,transform .15s,box-shadow .15s;animation:.28s forwards fadeUp;display:flex;overflow:hidden}.post-card--hovered{border-color:var(--color-border);background:#121d30;transform:translateY(-2px);box-shadow:0 8px 32px #0006}[data-theme=light] .post-card--hovered{background:#f0f0f0;box-shadow:0 4px 20px #0000001a}.post-card:first-child{animation-delay:0s}.post-card:nth-child(2){animation-delay:40ms}.post-card:nth-child(3){animation-delay:80ms}.post-card:nth-child(4){animation-delay:.12s}.post-card:nth-child(5){animation-delay:.16s}.post-card:nth-child(6){animation-delay:.2s}.post-card:nth-child(n+7){animation-delay:.24s}.post-card--featured{display:none}.post-card__thumb{aspect-ratio:16/9;background:linear-gradient(135deg, var(--color-border) 0%, var(--color-border-light) 100%);flex-shrink:0;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}[data-theme=light] .post-card__thumb{background:linear-gradient(135deg,#dde6f3 0%,#ccd9ee 100%)}.post-card__thumb.post-card__thumb--featured{all:unset}.post-card--featured .post-card__content{justify-content:center;padding:28px 28px 20px}.post-card--featured .post-card__title{-webkit-line-clamp:3;font-size:22px}.post-card--featured .post-card__excerpt{-webkit-line-clamp:4;font-size:14px}.post-card__thumbnail{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.post-card__status-badge{font-size:11px;font-weight:700;font-family:var(--font-ui);-webkit-backdrop-filter:blur(8px);z-index:2;border:1px solid;border-radius:6px;align-items:center;gap:5px;padding:4px 10px;display:inline-flex;position:absolute;top:10px;right:10px}.post-card__content{flex-direction:column;flex:1;gap:10px;min-width:0;padding:16px 18px 14px;display:flex}.post-card__title{color:var(--color-text);font-size:18px;font-weight:700;font-family:var(--font-ui);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}.post-card__excerpt{color:var(--color-muted);font-size:13px;font-family:var(--font-ui);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}.post-card__top{justify-content:space-between;align-items:center;gap:8px;display:flex}.post-card__tags{flex-wrap:wrap;gap:5px;display:flex}.post-card__meta-icons{align-items:center;gap:3px;display:flex}.post-card__meta-icon{border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.post-card__footer{border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;gap:12px;min-width:0;margin-top:auto;padding-top:10px;display:flex}.post-card__footer-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.post-card__footer-left .author-chip{flex-shrink:1;min-width:0}.post-card__footer-left .author-chip__name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.post-card__footer-right{flex-shrink:0;align-items:center;gap:12px;margin-left:auto;display:flex}.post-card__meta{font-family:var(--font-mono);color:var(--color-dim);white-space:nowrap;flex-shrink:0;font-size:11px}.post-card__sep{color:var(--color-dim);font-size:11px;font-family:var(--font-ui);-webkit-user-select:none;user-select:none;flex-shrink:0}.post-card__stat{color:var(--color-muted);font-size:13px;font-family:var(--font-ui);white-space:nowrap;flex-shrink:0;align-items:center;gap:4px;display:inline-flex}.post-card__author-actions{align-items:center;gap:4px;margin-left:2px;display:inline-flex}.post-card__author-action{color:var(--color-muted);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-ui);transition:color var(--transition-fast);background:0 0;border:none;padding:0;text-decoration:none}.post-card__author-action svg{fill:currentColor;display:block}.post-card__author-action:hover{color:var(--color-accent)}.post-card__author-sep{color:var(--color-dim);font-size:11px}.blog-post-layout{max-width:680px;margin:0 auto}.blog-post-header{margin-top:20px;margin-bottom:0}.blog-post-header__tags{margin-bottom:16px}.blog-post-header__title{font-family:var(--font-ui);letter-spacing:-.03em;color:var(--color-text);margin-bottom:16px;font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.15}.blog-post-header__excerpt{font-family:var(--font-editor);color:var(--color-muted);margin-bottom:24px;font-size:20px;line-height:1.7}.blog-post-header__meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.blog-post-header__meta-left{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.blog-post-header__meta-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.blog-post-header__discovery-btn{border:1px solid var(--color-border);background:var(--color-surface);width:28px;height:28px;transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.blog-post-header__discovery-btn:hover{background:var(--color-border-light);border-color:var(--color-accent);transform:translateY(-1px)}.blog-post-header__discovery-icon{object-fit:contain;width:14px;height:14px;display:block}.blog-post-header__date,.blog-post-header__readtime{font-family:var(--font-mono);color:var(--color-dim);font-size:12px}.blog-post-header__stat{color:var(--color-accent);font-size:13px;font-family:var(--font-ui);align-items:center;gap:4px;display:inline-flex}.blog-post-header__stat--muted{color:var(--color-muted)}.blog-post-header__meta-icons{align-items:center;gap:4px;margin-left:4px;display:flex}.blog-post-header__meta-icon{border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.blog-post-header__divider{border:none;border-top:1px solid var(--color-border-light);margin:0 0 40px}.blog-post-hero-img{border-radius:var(--radius-lg);border:1px solid var(--color-border);width:100%;height:auto;margin-bottom:48px;display:block}.article-body{font-family:var(--font-editor);color:var(--color-text);font-size:19px;line-height:1.9}.article-body p{margin-bottom:1.5em}.article-body h1,.article-body h2,.article-body h3,.article-body h4{font-family:var(--font-ui);letter-spacing:-.025em;color:var(--color-text);margin:1.8em 0 .6em;font-weight:800;line-height:1.25}.article-body h1{font-size:28px}.article-body h2{font-size:23px}.article-body h3{font-size:19px}.article-body h4{font-size:16px}.article-body strong{font-weight:600}.article-body em{font-style:italic}.article-body a{color:var(--color-accent);text-underline-offset:3px;transition:color var(--transition-fast);text-decoration:underline}.article-body a:hover{color:var(--color-accent-hov)}.article-body ul,.article-body ol{margin-bottom:1.5em;padding-left:1.5em}.article-body li{margin-bottom:.4em}.article-body blockquote{border-left:3px solid var(--color-accent);color:var(--color-muted);margin:1.8em 0;padding:4px 0 4px 22px;font-size:1.05em;font-style:italic}.article-body code{font-family:var(--font-mono);background:var(--color-border-light);color:var(--color-accent);border-radius:4px;padding:2px 6px;font-size:14px}.article-body pre{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#040810;margin-bottom:1.5em;padding:20px 24px;overflow-x:auto}[data-theme=light] .article-body pre{background:#f5f2ec}.article-body pre code{color:var(--color-text);background:0 0;padding:0;font-size:13px;line-height:1.7}.article-body img{border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;height:auto;margin:1.5em auto;display:block}.article-body hr{border:none;border-top:1px solid var(--color-border);margin:2.5em 0}.blog-post-footer__tags{margin-top:48px}.author-block{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;gap:16px;margin-top:32px;padding:24px;display:flex}.author-block__avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:52px;height:52px}.author-block__avatar--placeholder{background:var(--color-dim);width:52px;height:52px;color:var(--color-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.author-block__info{flex-direction:column;gap:3px;display:flex}.author-block__label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--color-dim);font-size:10px}.author-block__name{color:var(--color-text);font-size:15px;font-weight:600}.author-block__bio{color:var(--color-muted);font-size:13px;line-height:1.55}.more-posts{border-top:1px solid var(--color-border-light);margin-top:24px;padding-top:40px}.more-posts__heading{font-size:13px;font-weight:700;font-family:var(--font-mono);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.more-posts__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.blog-empty{text-align:center;color:var(--color-muted);padding:72px 0}.blog-empty__icon{opacity:.4;margin-bottom:16px;font-size:40px}.blog-empty__text{font-size:15px}@media (width<=640px){.post-grid{grid-template-columns:1fr}.post-card__thumb.post-card__thumb--featured{width:100%;min-width:0;max-width:none;height:220px;min-height:200px}.blog-hero__tagline{display:none}.post-card--featured .post-card__title{font-size:18px}.post-card__top{justify-content:space-between;align-items:center;gap:8px;display:flex}.post-card__meta-icons{align-items:center;gap:3px;display:flex}.article-body{font-size:17px}.blog-post-header__title{font-size:28px}.author-block{flex-direction:column;align-items:flex-start}.more-posts__grid{grid-template-columns:1fr}}.blog-controls{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:flex-end;gap:12px;margin-top:20px;padding-bottom:12px;display:flex}.blog-controls__group{flex-direction:column;flex:1;gap:6px;display:flex}.blog-controls__group:nth-child(2){align-items:center}.blog-controls__group:last-child{align-items:flex-end}.blog-controls__label{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-weight:500}.blog-view-toggle{align-items:center;gap:4px;display:flex}.blog-view-toggle__btn{border-radius:var(--radius-sm);width:36px;height:36px;transition:background var(--transition-fast), border-color var(--transition-fast);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.blog-view-toggle__btn:hover{background:var(--color-border-light)}.blog-view-toggle__btn--active{background:var(--color-accent-dim);border-color:#f2910633}.blog-author-filters{align-items:center;gap:8px;display:flex}.blog-author-filter{cursor:pointer;transition:border-color var(--transition-fast), opacity var(--transition-fast);opacity:.7;background:0 0;border:2px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:2px;display:flex}.blog-author-filter:hover{opacity:1}.blog-author-filter--active{border-color:var(--color-accent);opacity:1}.blog-author-filter__avatar,.blog-author-filter__placeholder{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.blog-author-filter__placeholder{background:var(--color-dim);color:var(--color-muted);font-size:11px;font-weight:700;font-family:var(--font-ui);justify-content:center;align-items:center;display:flex}.blog-author-filter__count{color:var(--color-muted);font-size:12px;font-weight:600;font-family:var(--font-mono);white-space:nowrap;padding-right:6px}.blog-author-filter--active .blog-author-filter__count{color:var(--color-accent)}.blog-type-filters{align-items:center;gap:5px;display:flex}.blog-type-filter{cursor:pointer;width:32px;height:32px;transition:background var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);border:1px solid;border-radius:6px;justify-content:center;align-items:center;display:flex}.post-list{flex-direction:column;gap:0;max-width:680px;margin:0 auto;display:flex}.post-list-item{border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast);border-radius:var(--radius-md);align-items:flex-start;gap:20px;margin:0 -16px;padding:24px 16px;display:flex}.post-list-item:first-child{padding-top:0}.post-list-item--hovered{background:var(--color-surface)}[data-theme=light] .post-list-item--hovered{background:#f5f5f5}.post-list-item__thumb{aspect-ratio:16/9;border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-border) 0%, var(--color-border-light) 100%);flex-shrink:0;justify-content:center;align-items:center;width:220px;display:flex;overflow:hidden}[data-theme=light] .post-list-item__thumb{background:linear-gradient(135deg,#dde6f3 0%,#ccd9ee 100%)}.post-list-item__thumb img{object-fit:cover;width:100%;height:100%}.post-list-item__content{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.post-list-item__top{justify-content:space-between;align-items:center;gap:8px;display:flex}.post-list-item__tags{flex-wrap:wrap;gap:5px;display:flex}.post-list-item__meta-icons{align-items:center;gap:3px;display:flex}.post-list-item__meta-icon{border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.post-list-item__title{font-size:18px;font-weight:700;font-family:var(--font-ui);color:var(--color-text);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;line-height:1.35;overflow:hidden}.post-list-item__excerpt{color:var(--color-muted);font-size:14px;font-family:var(--font-ui);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}.post-list-item__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.post-list-item__footer-left{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.post-list-item__footer-right{align-items:center;gap:8px;display:flex}.post-list-item__meta{font-family:var(--font-mono);color:var(--color-dim);font-size:11px}.post-list-item__status{font-size:10px;font-weight:700;font-family:var(--font-ui);border:1px solid;border-radius:4px;align-items:center;gap:4px;padding:2px 7px;display:inline-flex}@media (width<=480px){.post-list-item{column-gap:10px}.post-list-item__thumb{aspect-ratio:16/9;width:100%;height:auto}.post-list-item__excerpt{-webkit-line-clamp:2}}.post-list-item__author-actions{align-items:center;gap:4px;display:inline-flex}.post-list-item__author-action{color:var(--color-muted);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-ui);transition:color var(--transition-fast);background:0 0;border:none;padding:0;text-decoration:none}.post-list-item__author-action:hover{color:var(--color-accent)}.post-list-item__author-sep{color:var(--color-dim);font-size:11px}.post-list-item__mobile-meta{display:none}@media (width<=640px){.post-list-item{grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"thumb content""mobilemeta content";align-items:start;gap:8px 12px;display:grid}.post-list-item__thumb{aspect-ratio:16/9;grid-area:thumb;align-self:start;width:100%;height:auto}.post-list-item__mobile-meta{flex-direction:column;grid-area:mobilemeta;gap:6px;width:100%;min-width:0;display:flex}.post-list-item__content{grid-area:content;gap:6px;min-width:0}.post-list-item__top--desktop,.post-list-item__footer--desktop{display:none}.post-list-item__mobile-meta .post-list-item__top{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.post-list-item__mobile-meta .post-list-item__tags{flex-wrap:wrap;gap:4px;display:flex}.post-list-item__mobile-meta .post-list-item__meta-icons{align-items:center;gap:3px;display:flex}.post-list-item__mobile-meta .post-list-item__footer{flex-direction:column;align-items:flex-start;gap:6px;margin-top:0;display:flex}.post-list-item__mobile-meta .post-list-item__footer-left,.post-list-item__mobile-meta .post-list-item__footer-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.post-list-item__title{white-space:normal;text-overflow:unset;font-size:15px;line-height:1.35;overflow:visible}.post-list-item__excerpt{-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}}.post-card__serial-badge{font-family:var(--font-mono);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;max-width:100%;transition:opacity var(--transition-fast);text-align:left;background:0 0;border:1px solid;border-radius:6px;align-items:center;gap:5px;padding:4px 9px;font-size:11px;font-weight:500;display:inline-flex;overflow:hidden}.post-card__serial-badge:hover{opacity:.75}.post-card__serial-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.post-card__serial-title{text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:600;overflow:hidden}.post-card__serial-sep{color:currentColor;opacity:.4;flex-shrink:0}.serial-page{max-width:680px;margin:0 auto;padding-top:28px;padding-bottom:80px}.serial-hero{align-items:flex-start;gap:32px;margin-bottom:56px;display:flex}.serial-hero__cover{border-radius:10px;flex-shrink:0;width:300px;overflow:hidden}.serial-hero__cover img{width:100%;height:auto;display:block}.serial-hero__info{flex-direction:column;flex:1;gap:16px;min-width:0;display:flex}.serial-hero__status-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.serial-hero__status{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.07em;border-radius:5px;align-items:center;gap:6px;padding:3px 9px 3px 7px;font-size:11px;font-weight:700;display:inline-flex}.serial-hero__status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.serial-hero__meta{font-family:var(--font-mono);color:var(--color-dim);font-size:11px}.serial-hero__tagline{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:12px;font-weight:500}.serial-hero__title{font-family:var(--font-ui);letter-spacing:-.03em;color:var(--color-text);margin:0;font-size:clamp(22px,3.5vw,32px);font-weight:800;line-height:1.15}.serial-hero__description{font-family:var(--font-editor);color:var(--color-muted);margin:0;font-size:15px;line-height:1.7}.serial-hero__cta{background:var(--color-accent);color:#fff;height:40px;font-family:var(--font-ui);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);border:none;border-radius:8px;align-self:flex-start;align-items:center;gap:10px;margin-top:4px;padding:0 18px;font-size:14px;font-weight:700;display:inline-flex}.serial-hero__cta:hover{opacity:.88;transform:translateY(-1px)}.serial-hero__cta-sub{opacity:.8;font-size:12px;font-weight:400;font-family:var(--font-mono)}.serial-progress{flex-direction:column;gap:8px;margin-bottom:28px;display:flex}.serial-progress__header{justify-content:space-between;align-items:center;display:flex}.serial-progress__label{font-family:var(--font-mono);color:var(--color-muted);font-size:11px}.serial-progress__pct{font-family:var(--font-mono);color:var(--color-accent);font-size:11px;font-weight:600}.serial-progress__track{background:var(--color-border-light);border-radius:3px;width:100%;height:5px;overflow:hidden}.serial-progress__fill{background:var(--color-accent);border-radius:3px;height:100%;transition:width .4s}.serial-chapters__header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.serial-chapters__heading{font-family:var(--font-mono);color:var(--color-dim);text-transform:uppercase;letter-spacing:.07em;font-size:11px;font-weight:600}.serial-chapters__toggle{font-family:var(--font-ui);color:var(--color-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-size:12px}.serial-chapters__toggle:hover{color:var(--color-accent)}.serial-chapters__list{flex-direction:column;display:flex}.serial-chapter-row{border-bottom:1px solid var(--color-border-light);cursor:pointer;text-align:left;border-radius:var(--radius-md);width:100%;transition:background var(--transition-fast);background:0 0;border-top:none;border-left:none;border-right:none;align-items:flex-start;gap:14px;margin:0 -16px;padding:14px 16px;display:flex}.serial-chapter-row:first-child{padding-top:0}.serial-chapter-row:hover,.serial-chapter-row--current{background:var(--color-surface)}.serial-chapter-row__index{font-family:var(--font-mono);color:var(--color-dim);text-align:right;flex-shrink:0;width:24px;padding-top:1px;font-size:13px}.serial-chapter-row--read .serial-chapter-row__index{color:var(--color-accent)}.serial-chapter-row__check{font-size:13px}.serial-chapter-row__info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.serial-chapter-row__title{font-family:var(--font-ui);color:var(--color-text);font-size:15px;font-weight:600;line-height:1.35}.serial-chapter-row__meta{flex-shrink:0;justify-content:center;align-items:center;min-width:92px;padding-top:1px;display:flex}.serial-chapter-row__readtime{font-family:var(--font-mono);color:var(--color-dim);white-space:nowrap;font-size:11px}.serial-chapter-row--read .serial-chapter-row__title{color:var(--color-muted)}.serial-chapter-row__excerpt{font-family:var(--font-ui);color:var(--color-dim);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.serial-chapter-row__right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.serial-chapter-row__date{font-family:var(--font-mono);color:var(--color-dim);white-space:nowrap;font-size:11px}.serial-chapter-row__badge{font-family:var(--font-ui);color:var(--color-accent);background:var(--color-accent-dim);white-space:nowrap;border:1px solid #f2910633;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}@media (width<=560px){.serial-hero{flex-direction:column;gap:20px;margin-bottom:40px}.serial-chapter-row{gap:10px;margin:0 -12px;padding-left:12px;padding-right:12px}.serial-chapter-row__meta{min-width:auto}.serial-chapter-row__readtime{font-size:10px}.serial-chapter-row__right{gap:4px}}
