:root{--bg:#0b0d10;--bg-2:#111418;--bg-3:#161a1f;--fg:#e6edf3;--fg-2:#c9d1d9;--dim:#7d8590;--dim-2:#484f58;--line:#21262d;--line-2:#30363d;--accent:#facc15;--sel:#facc152e;--mono:"JetBrains Mono", "SF Mono", "Menlo", ui-monospace, monospace;--sans:"JetBrains Mono", "SF Mono", "Menlo", ui-monospace, monospace}[data-mode=light]{--bg:#f7f5f0;--bg-2:#efece4;--bg-3:#e6e2d8;--fg:#14181c;--fg-2:#2b3238;--dim:#6b7178;--dim-2:#a8ada8;--line:#d9d4c8;--line-2:#c3bdae;--sel:#facc1524}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:40px}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.6}body:before{content:"";pointer-events:none;z-index:200;background:repeating-linear-gradient(#ffffff03 0 1px,#0000 1px 3px),radial-gradient(#0000 60%,#00000080 100%);position:fixed;inset:0}[data-mode=light] body:before{background:repeating-linear-gradient(#00000004 0 1px,#0000 1px 3px),radial-gradient(#0000 65%,#00000014 100%)}a{color:inherit;text-decoration:none}::selection{background:var(--sel)}.cursor-dot,.cursor-ring{display:none}[data-magnet]{transition:transform .16s,color .16s,border-color .16s,background .16s}[data-magnet]:hover{transform:translateY(-1px)}.plain-shell{max-width:900px;min-height:100vh;margin:0 auto;padding:88px 32px 120px}@media (max-width:940px){.plain-shell{padding:40px 22px 80px}}.icon-masked{vertical-align:-2px;background-color:currentColor;flex-shrink:0;display:inline-block}.hero{padding:12px 0 56px}.hero-meta{font-family:var(--mono);color:var(--dim);border:1px solid var(--line);background:var(--bg-2);border-radius:999px;align-items:center;gap:10px;margin-bottom:28px;padding:6px 12px 6px 10px;font-size:12px;display:inline-flex}.hero-meta>span{white-space:nowrap}.hm-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.8s ease-in-out infinite heroPulse}@keyframes heroPulse{0%{box-shadow:0 0 #facc1566}70%{box-shadow:0 0 0 8px #facc1500}to{box-shadow:0 0 #facc1500}}.hm-status{display:contents}.hm-sep{color:var(--dim-2)}.hm-cta{border:1px solid var(--line-2);color:var(--accent);font-family:var(--mono);background:0 0;border-radius:999px;align-items:center;gap:6px;margin-left:10px;padding:4px 10px;font-size:11.5px;text-decoration:none;transition:border-color .14s,background .14s,transform .14s;display:inline-flex}.hm-cta:hover{border-color:var(--accent);background:color-mix(in oklab, var(--accent) 10%, transparent);transform:translate(1px)}.hero-title{font-family:var(--mono);letter-spacing:-.03em;color:var(--fg);margin:0 0 20px;font-size:clamp(36px,5.2vw,56px);font-weight:600;line-height:1.1}.hero-last{color:var(--accent)}.hero-wave{vertical-align:middle;transform-origin:70% 70%;margin-left:14px;font-size:.7em;animation:2.4s ease-in-out infinite wave;display:inline-block}@keyframes wave{0%,60%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}.hero-role{color:var(--fg-2);text-wrap:pretty;max-width:62ch;margin:0 0 32px;font-size:18px;line-height:1.6}.hero-nav{font-family:var(--mono);flex-wrap:wrap;gap:8px;margin-top:32px;display:flex}.nav-pill{border:1px solid var(--line-2);color:var(--fg-2);border-radius:4px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;text-decoration:none;transition:all .14s;display:inline-flex}.nav-pill .icon-masked{color:var(--dim);flex-shrink:0;transition:color .14s}.nav-pill:hover{border-color:var(--accent);color:var(--accent)}.nav-pill:hover .icon-masked{color:var(--accent)}.section{border-top:1px solid var(--line);margin-top:16px;padding:32px 0 12px}.section-head{margin-bottom:16px}.section-label{font-family:var(--mono);letter-spacing:.1em;color:var(--accent);text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:500}.section-title{font-family:var(--mono);letter-spacing:-.015em;color:var(--fg);margin:0;font-size:clamp(20px,2.2vw,26px);font-weight:600;line-height:1.15}.section-kicker{font-family:var(--mono);color:var(--fg-2);max-width:60ch;margin:6px 0 0;font-size:15px}@keyframes reveal{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.about-copy{color:var(--fg-2);max-width:70ch;font-size:15px;line-height:1.7}.proj-list{border-top:1px solid var(--line);flex-direction:column;gap:0;display:flex}.proj-item{border-bottom:1px solid var(--line);opacity:0;grid-template-columns:1fr auto;grid-template-areas:"head head""desc desc""foot foot";gap:10px 16px;padding:22px 0;transition:padding .16s;animation:.5s forwards reveal;display:grid}.proj-item:hover{padding-left:4px}.pi-head{grid-area:head;justify-content:space-between;align-items:baseline;gap:16px;display:flex}.pi-name{font-family:var(--mono);letter-spacing:-.01em;color:var(--fg);margin:0;font-size:16px;font-weight:600}.pi-period{font-family:var(--mono);color:var(--dim);letter-spacing:.02em;white-space:nowrap;font-size:12px}.pi-desc{color:var(--fg-2);grid-area:desc;max-width:70ch;margin:0;font-size:14.5px;line-height:1.55}.pi-foot{flex-wrap:wrap;grid-area:foot;align-items:center;gap:8px;margin-top:4px;display:flex}.pi-tag{font-size:11.5px;font-family:var(--mono);border:1px solid var(--line-2);color:var(--fg-2);background:var(--bg-2);border-radius:3px;padding:2px 9px;display:inline-block}.pi-tag.has-icon{align-items:center;gap:5px;padding:3px 9px 3px 7px;display:inline-flex}.pi-tag.has-icon .tag-icon{color:currentColor;opacity:.85;width:11px;height:11px}.pi-src{font-family:var(--mono);color:var(--accent);border-bottom:1px solid #0000;align-items:center;gap:4px;margin-left:auto;padding:2px 0;font-size:12px;line-height:1;text-decoration:none;transition:border-color .12s;display:inline-flex}.pi-src:hover{border-bottom-color:var(--accent)}.pi-star{font-family:var(--mono);color:var(--accent);align-items:center;gap:5px;font-size:12px;line-height:1;display:inline-flex}.lang-swift,.pi-tag.lang-swift,.lang-swiftui,.pi-tag.lang-swiftui{color:#ff7e52;background:#ff7e520f;border-color:#ff7e5266}.lang-bash,.pi-tag.lang-bash,.lang-shell,.pi-tag.lang-shell{color:#89e88c;background:#89e88c0f;border-color:#89e88c66}.lang-typescript,.pi-tag.lang-typescript{color:#4da3ff;background:#4da3ff0f;border-color:#4da3ff66}.tag-icon{color:var(--dim);flex-shrink:0;width:14px;height:14px;transition:color .14s;display:inline-block}.tag-icon-masked{background-color:currentColor}.tag-icon-dot{background:currentColor;border-radius:50%;width:6px;height:6px;margin:0 2px}.filters{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.filter{font-family:var(--mono);border:1px solid var(--line-2);color:var(--dim);cursor:pointer;text-transform:lowercase;letter-spacing:.02em;background:0 0;border-radius:3px;padding:5px 12px;font-size:12px;transition:all .12s}.filter:hover{color:var(--fg-2)}.filter.on{border-color:var(--accent);color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, transparent)}.filters-count{font-family:var(--mono);color:var(--dim-2);margin-left:auto;font-size:12px}.stack{flex-direction:column;gap:20px;display:flex}.stack-key{font-family:var(--mono);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:500}.stack-items{flex-wrap:wrap;gap:8px;display:flex}.tag{font-family:var(--mono);border:1px solid var(--line-2);color:var(--fg-2);cursor:pointer;border-radius:3px;align-items:center;gap:6px;padding:5px 11px 5px 9px;font-size:13px;transition:all .14s;display:inline-flex}.tag:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in oklab, var(--accent) 6%, transparent)}.tag:hover .tag-icon{color:var(--accent)}.articles{gap:14px;display:grid}.article-card{border:1px solid var(--line);background:var(--bg-2);color:var(--fg);opacity:0;border-radius:8px;padding:22px 24px;text-decoration:none;transition:border-color .16s,transform .16s,background .16s;animation:.5s forwards reveal;display:block}.article-card:hover{border-color:var(--accent);background:color-mix(in oklab, var(--accent) 4%, var(--bg-2));transform:translateY(-2px)}.ac-meta{font-family:var(--mono);color:var(--dim);letter-spacing:.02em;align-items:center;gap:8px;margin-bottom:10px;font-size:11.5px;display:flex}.ac-sep{color:var(--line-2)}.ac-title{font-family:var(--mono);letter-spacing:-.01em;color:var(--fg);margin:0 0 8px;font-size:18px;font-weight:600;line-height:1.3}.article-card:hover .ac-title{color:var(--accent)}.ac-excerpt{font-family:var(--mono);color:var(--fg-2);max-width:70ch;margin:0 0 16px;font-size:13.5px;line-height:1.6}.ac-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.ac-tags{flex-wrap:wrap;gap:6px;display:flex}.ac-read{font-family:var(--mono);color:var(--accent);align-items:center;gap:6px;font-size:12px;transition:transform .16s;display:inline-flex}.article-card:hover .ac-read{transform:translate(3px)}.heatmap{flex-direction:column;gap:3px;margin:8px 0 14px;display:flex;overflow-x:auto}.hm-row{gap:3px;display:flex}.hm-cell{background:var(--line);opacity:0;border-radius:2px;width:14px;height:14px;transform:scale(.4)}.hm-cell.shown{animation:.3s forwards hmIn}@keyframes hmIn{to{opacity:1;transform:scale(1)}}.hm-cell.lvl-0{background:var(--line)}.hm-cell.lvl-1{background:color-mix(in oklab, var(--accent) 22%, transparent)}.hm-cell.lvl-2{background:color-mix(in oklab, var(--accent) 44%, transparent)}.hm-cell.lvl-3{background:color-mix(in oklab, var(--accent) 70%, transparent)}.hm-cell.lvl-4{background:var(--accent)}.hm-legend{color:var(--dim);font-size:11px;font-family:var(--mono);align-items:center;gap:3px;display:flex}.hm-legend span{margin:0 6px}.hm-legend .hm-cell{opacity:1;animation:none;transform:scale(1)}.hm-tooltip{pointer-events:none;z-index:500;background:var(--bg-3);border:1px solid var(--line-2);color:var(--fg);font-family:var(--mono);white-space:nowrap;border-radius:4px;padding:5px 10px;font-size:11.5px;position:fixed;transform:translate(-50%,calc(-100% - 10px));box-shadow:0 4px 16px #0006}.stats-strip{border-top:1px solid var(--line);grid-template-columns:repeat(5,1fr);gap:14px;margin-top:32px;padding-top:28px;display:grid}.stat-k{font-family:var(--mono);color:var(--dim);text-transform:uppercase;letter-spacing:.1em;font-size:11px}.stat-v{color:var(--accent);letter-spacing:-.02em;margin-top:8px;font-size:32px;font-weight:500}.contact-blurb{color:var(--fg-2);max-width:620px;margin:0 0 28px;font-size:16px;line-height:1.65}.contact-links{gap:10px;max-width:520px;display:grid}.cl-link{border:1px solid var(--line);background:var(--bg-2);color:var(--fg);border-radius:10px;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:16px 18px;text-decoration:none;transition:border-color .16s,transform .16s,background .16s;display:grid}.cl-link:hover{border-color:var(--accent);background:color-mix(in oklab, var(--accent) 5%, var(--bg-2));transform:translateY(-1px)}.cl-icon{background:color-mix(in oklab, var(--accent) 12%, transparent);width:36px;height:36px;color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.cl-body{flex-direction:column;gap:2px;min-width:0;display:flex}.cl-k{color:var(--fg);letter-spacing:-.005em;font-size:14px;font-weight:500}.cl-v{font-family:var(--mono);color:var(--dim);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.cl-a{color:var(--dim);transition:color .16s,transform .16s;display:inline-flex}.cl-link:hover .cl-a{color:var(--accent);transform:translate(1px,-1px)}.con-foot{font-family:var(--mono);color:var(--dim);margin-top:36px;font-size:12px}.loading-container{color:var(--dim);font-family:var(--mono);align-items:center;gap:10px;padding:24px 0;font-size:13px;display:flex}.dim{color:var(--dim);font-family:var(--mono);font-size:12.5px}.accent{color:var(--accent)}.pagination{align-items:center;gap:12px;margin-top:20px;display:flex}.pi-name-link{font-family:var(--mono);letter-spacing:-.01em;color:var(--fg);border-bottom:1px solid #0000;font-size:16px;font-weight:600;text-decoration:none;transition:color .14s,border-color .14s}.pi-name-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.navbar-wrapper{z-index:100;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}.navbar-pill{background:var(--bg-2);border:1px solid var(--line-2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:999px;align-items:center;gap:2px;padding:6px 10px;display:flex;box-shadow:0 8px 32px #0006}.nb-link{width:34px;height:34px;color:var(--dim);border-radius:999px;justify-content:center;align-items:center;font-size:13px;transition:color .14s,background .14s;display:flex}.nb-link:hover,.nb-link.active{color:var(--accent);background:color-mix(in oklab, var(--accent) 10%, transparent)}.nb-sep{background:var(--line-2);width:1px;height:20px;margin:0 4px}.nb-toggle{width:34px;height:34px;color:var(--dim);cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;font-size:13px;transition:color .14s,background .14s;display:flex}.nb-toggle:hover{color:var(--accent);background:color-mix(in oklab, var(--accent) 10%, transparent)}.article-page{padding:48px 0 80px}.article-header{border-bottom:1px solid var(--line);margin-bottom:48px;padding-bottom:32px}.back-btn{color:var(--dim);font-family:var(--mono);cursor:pointer;background:0 0;border:none;width:fit-content;padding:0;font-size:13px;transition:color .14s}.back-btn:hover{color:var(--accent)}.article-meta{color:var(--dim);font-family:var(--mono);letter-spacing:.02em;align-items:center;gap:6px;margin:16px 0 12px;font-size:12px;display:flex}.article-meta .sep{opacity:.5}.article-title{font-family:var(--mono);letter-spacing:-.025em;color:var(--fg);margin:0 0 12px;font-size:26px;font-weight:700;line-height:1.3}.article-excerpt{color:var(--fg-2);max-width:680px;margin:0 0 16px;font-size:15px;line-height:1.65}.article-tags{flex-wrap:wrap;gap:6px;display:flex}.article-body{max-width:680px;color:var(--fg-2);font-size:15px;line-height:1.75}.article-body h1,.article-body h2,.article-body h3,.article-body h4{font-family:var(--mono);color:var(--fg);letter-spacing:-.02em;margin:2em 0 .5em;font-weight:600;line-height:1.3}.article-body h2{font-size:20px}.article-body h3{font-size:17px}.article-body h4{font-size:15px}.article-body p{margin:0 0 1em}.article-body a{color:var(--accent);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .12s}.article-body a:hover{border-bottom-color:var(--accent)}.article-body ul,.article-body ol{margin:0 0 1em;padding-left:1.5em}.article-body li{margin-bottom:.25em}.article-body code{font-family:var(--mono);background:var(--bg-3);border:1px solid var(--line);color:var(--fg);border-radius:3px;padding:1px 5px;font-size:13px}.article-body pre{background:var(--bg-3);border:1px solid var(--line);border-radius:6px;margin:0 0 1.5em;padding:16px;overflow-x:auto}.article-body pre code{background:0 0;border:none;padding:0;font-size:13px;line-height:1.6}.article-body blockquote{border-left:3px solid var(--accent);color:var(--fg-2);margin:0 0 1em;padding:4px 0 4px 16px;font-style:italic}.article-body img{border:1px solid var(--line);border-radius:6px;max-width:100%;margin:8px 0}.article-body hr{border:none;border-top:1px solid var(--line);margin:2em 0}@media (max-width:820px){.stats-strip{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.plain-shell{padding:28px 18px 72px}.hero{padding:0 0 36px}.hero-meta{border-radius:12px;flex-direction:column;align-items:flex-start;gap:8px;width:100%;padding:14px 16px;font-size:11.5px;display:flex}.hm-status{align-items:center;gap:8px;display:flex}.hm-sep{display:none}.hm-cta{justify-content:center;width:100%;margin-top:4px;margin-left:0;padding:10px 14px}.hero-title{letter-spacing:-.04em;font-size:40px!important}.hero-role{font-size:14.5px}.hero-nav{gap:6px;margin-top:24px}.hero-nav .nav-pill{padding:6px 10px;font-size:12px}.section{margin-top:12px;padding:24px 0 8px}.section-title{font-size:22px!important}.proj-item{padding:18px 0}.proj-item:hover{padding-left:0}.pi-head{flex-direction:column;align-items:flex-start;gap:4px}.article-card{padding:18px}.ac-title{font-size:15.5px}.heatmap-wrap{-webkit-overflow-scrolling:touch;padding-bottom:4px;overflow-x:auto}.heatmap{min-width:560px}.stats-strip{grid-template-columns:repeat(2,1fr)}.contact-blurb{font-size:13.5px}}@media (max-width:380px){.hero-title{font-size:34px!important}}body.admin-page{width:100%;min-width:100%;margin:0}#seo-content{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.router-loading{min-height:100vh;color:var(--dim);font-family:var(--mono);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.admin-login-container{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.admin-login-form{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;width:100%;max-width:360px;padding:2rem}.admin-login-form h1{text-align:center;color:var(--fg);font-family:var(--mono);letter-spacing:-.02em;margin-bottom:2rem;font-size:18px;font-weight:600}.form-group{margin-bottom:1rem}.form-group label{color:var(--dim);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.35rem;font-size:10px;font-weight:500;display:block}.form-group input,.form-group textarea,.form-group select{border:1px solid var(--line);background:var(--bg-3);width:100%;color:var(--fg);font-family:var(--mono);box-sizing:border-box;border-radius:4px;padding:.6rem .75rem;font-size:13px;transition:border-color .14s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);outline:none}.form-group textarea{resize:vertical}.admin-btn{background:var(--accent);color:#0b0d10;font-family:var(--mono);cursor:pointer;border:none;border-radius:4px;padding:7px 16px;font-size:12px;font-weight:600;transition:opacity .14s}.admin-btn:hover:not(:disabled){opacity:.85}.admin-btn:disabled{opacity:.4;cursor:not-allowed}.admin-btn-full{justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;display:flex}.admin-btn-ghost{color:var(--dim);border:1px solid var(--line);font-family:var(--mono);cursor:pointer;background:0 0;border-radius:4px;padding:7px 16px;font-size:12px;font-weight:600;transition:all .14s}.admin-btn-ghost:hover:not(:disabled){color:var(--fg-2);border-color:var(--line-2)}.admin-btn-ghost:disabled{opacity:.4;cursor:not-allowed}.admin-error{color:#ff6b6b;font-family:var(--mono);text-align:center;background:#dc3c3c14;border:1px solid #dc3c3c38;border-radius:4px;margin-bottom:1rem;padding:.6rem .75rem;font-size:12px}.admin-link-text{text-align:center;color:var(--dim);font-family:var(--mono);margin-top:1rem;font-size:12px}.admin-link-text a{color:var(--accent)}.dashboard{background:var(--bg);width:100%;min-height:100vh;display:flex}.dashboard-mobile-header{background:var(--bg-2);border-bottom:1px solid var(--line);z-index:1001;justify-content:space-between;align-items:center;height:52px;padding:0 1rem;display:none;position:fixed;top:0;left:0;right:0}.dashboard-mobile-header h1{font-family:var(--mono);color:var(--fg);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:12px;font-weight:500}.burger-menu{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:space-around;width:20px;height:20px;padding:0;display:flex}.burger-menu span{background:var(--fg-2);border-radius:1px;width:20px;height:1.5px}.sidebar-overlay{z-index:999;background:#000000a6;display:none;position:fixed;inset:0}.dashboard-sidebar{background:var(--bg-2);border-right:1px solid var(--line);z-index:1000;flex-direction:column;width:210px;min-height:100vh;transition:transform .25s;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--line);padding:22px 18px 14px}.sidebar-header h1{font-family:var(--mono);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:10px;font-weight:500}.sidebar-nav-items{flex:1;padding:6px 0}.sidebar-footer{border-top:1px solid var(--line);padding:6px 0}.nav-item{width:100%;color:var(--fg-2);text-align:left;cursor:pointer;font-family:var(--mono);background:0 0;border:none;border-left:2px solid #0000;align-items:center;gap:10px;padding:9px 18px;font-size:13px;transition:all .14s;display:flex}.nav-item:hover{background:var(--bg-3);border-left-color:var(--line-2);color:var(--fg)}.nav-item.active{background:color-mix(in oklab, var(--accent) 10%, transparent);border-left-color:var(--accent);color:var(--accent)}.nav-item i{text-align:center;opacity:.75;width:14px;font-size:12px}.nav-item.site-link{color:var(--dim)!important}.nav-item.site-link:hover{border-left-color:var(--accent);background:var(--bg-3);color:var(--accent)!important}.nav-item.logout-btn{color:var(--dim)!important}.nav-item.logout-btn:hover{color:#ff6b6b!important;background:#dc3c3c12!important;border-left-color:#dc3c3c80!important}.dashboard-content{background:var(--bg);flex:1;width:calc(100vw - 210px);max-width:calc(100vw - 210px);min-height:100vh;margin-left:210px;overflow-x:hidden}.manager{box-sizing:border-box;width:100%;padding:2rem}.manager-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.manager-header h2{font-family:var(--mono);letter-spacing:-.02em;color:var(--fg);margin:0;font-size:18px;font-weight:600}.form-container{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.form-container h3{font-family:var(--mono);color:var(--fg-2);letter-spacing:-.01em;margin:0 0 1.5rem;font-size:14px;font-weight:600}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-actions{gap:8px;margin-top:1.25rem;display:flex}.tags-input{gap:6px;display:flex}.tags-input .form-group{flex:1;margin-bottom:0}.tags-input .form-group input{width:100%}.tags-list{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.admin-tag{background:var(--bg-3);color:var(--fg-2);border:1px solid var(--line-2);font-family:var(--mono);border-radius:3px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.admin-tag button{color:var(--dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;line-height:1;transition:color .14s}.admin-tag button:hover{color:#ff6b6b}.checkbox-label{cursor:pointer;font-family:var(--mono);color:var(--fg-2);align-items:center;gap:8px;font-size:12px;display:flex}.checkbox-label input[type=checkbox]{width:auto;accent-color:var(--accent)}.item-list{border-top:1px solid var(--line);flex-direction:column;display:flex}.list-item{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 0;transition:padding-left .14s;display:flex}.list-item:hover{padding-left:4px}.list-item-content{flex:1;min-width:0}.list-item-content h4{font-family:var(--mono);color:var(--fg);letter-spacing:-.01em;margin:0 0 4px;font-size:14px;font-weight:600}.list-item-date{color:var(--dim);font-family:var(--mono);letter-spacing:.02em;margin:2px 0 6px;font-size:11px}.list-item-desc{color:var(--fg-2);margin:0 0 8px;font-size:13px;line-height:1.5}.list-item-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.item-actions{flex-shrink:0;gap:6px;display:flex}.item-actions button{border:1px solid var(--line);color:var(--dim);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;transition:all .14s;display:flex}.item-actions button:first-child:hover{border-color:var(--accent);color:var(--accent)}.item-actions button.delete:hover{color:#ff6b6b;border-color:#dc3c3c80}.item-actions button:disabled{opacity:.3;cursor:not-allowed}.admin-pagination{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}.admin-pagination-info{color:var(--dim);font-family:var(--mono);letter-spacing:.02em;font-size:11px}.admin-pagination-controls{align-items:center;gap:4px;display:flex}.pager-btn{border:1px solid var(--line);color:var(--fg-2);cursor:pointer;font-family:var(--mono);background:0 0;border-radius:3px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:5px 10px;font-size:12px;transition:all .14s;display:flex}.pager-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pager-btn.active{background:color-mix(in oklab, var(--accent) 15%, transparent);border-color:var(--accent);color:var(--accent)}.pager-btn:disabled{opacity:.3;cursor:not-allowed}.pager-ellipsis{color:var(--dim-2);font-family:var(--mono);padding:0 4px;font-size:12px}.status-badge{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid;border-radius:3px;padding:2px 6px;font-size:10px}.status-badge.published{color:#4ade80;background:#4ade8012;border-color:#4ade804d}.status-badge.draft{color:var(--dim);border-color:var(--line-2);background:0 0}.quill-wrapper{border-radius:4px;overflow:hidden}.quill-wrapper .ql-toolbar{background:var(--bg-3)!important;border-color:var(--line)!important}.quill-wrapper .ql-container{background:var(--bg-3)!important;border-color:var(--line)!important;font-family:var(--mono)!important;font-size:13px!important}.quill-wrapper .ql-editor{min-height:300px;color:var(--fg)!important;line-height:1.7!important}.logs-filter-bar{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:16px;display:flex}.logs-filter-bar .form-group{min-width:140px;margin-bottom:0}.quick-filters{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.log-entry{border-bottom:1px solid var(--line);cursor:pointer;padding:10px 0}.log-entry:hover{background:var(--bg-2);padding-left:6px;transition:padding-left .14s}.log-meta{font-family:var(--mono);align-items:center;gap:10px;font-size:11px;display:flex}.log-level{letter-spacing:.05em;text-transform:uppercase;border-radius:3px;padding:1px 6px;font-weight:600}.log-level.error{color:#ff6b6b;background:#dc3c3c1f}.log-level.warn{color:var(--accent);background:#facc151f}.log-level.info{color:#4da3ff;background:#4da3ff1f}.log-level.debug{color:var(--dim);background:#7d85901f}.log-message{font-family:var(--mono);color:var(--fg-2);margin-top:4px;font-size:13px}.log-details{background:var(--bg-3);border:1px solid var(--line);font-family:var(--mono);color:var(--dim);white-space:pre-wrap;border-radius:4px;margin-top:8px;padding:10px;font-size:12px;overflow-x:auto}.auto-refresh-toggle{font-family:var(--mono);color:var(--dim);cursor:pointer;align-items:center;gap:6px;font-size:12px;display:flex}.auto-refresh-toggle input{accent-color:var(--accent)}.new-logs-badge{background:color-mix(in oklab, var(--accent) 15%, transparent);color:var(--accent);border:1px solid color-mix(in oklab, var(--accent) 40%, transparent);font-family:var(--mono);border-radius:999px;padding:2px 8px;font-size:11px}@media (max-width:768px){.dashboard-mobile-header{display:flex}.dashboard-sidebar{transform:translate(-100%)}.dashboard-sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.dashboard-content{width:100vw;max-width:100vw;margin-left:0;padding-top:52px}.manager{padding:1rem}.form-row{grid-template-columns:1fr}.admin-pagination{flex-direction:column;align-items:stretch}.admin-pagination-info{text-align:center}.admin-pagination-controls{justify-content:center}}.manager-wrap{box-sizing:border-box;width:100%;padding:2rem}.create-button{background:var(--accent);color:#0b0d10;font-family:var(--mono);cursor:pointer;border:none;border-radius:4px;padding:7px 16px;font-size:12px;font-weight:600;transition:opacity .14s}.create-button:hover{opacity:.85}.mgr-error{color:#ff6b6b;font-family:var(--mono);background:#dc3c3c12;border:1px solid #dc3c3c33;border-radius:4px;margin-bottom:1rem;padding:.75rem 1rem;font-size:12px}.loading-row{color:var(--dim);font-family:var(--mono);justify-content:center;align-items:center;gap:8px;padding:2rem;font-size:13px;display:flex}.items-list{border-top:1px solid var(--line);flex-direction:column;display:flex}.item-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 0;transition:padding-left .14s;display:flex}.item-row:hover{padding-left:4px}.item-content{flex:1;min-width:0}.item-content h4{font-family:var(--mono);color:var(--fg);letter-spacing:-.01em;margin:0 0 4px;font-size:14px;font-weight:600}.item-date{color:var(--dim);font-family:var(--mono);letter-spacing:.02em;margin:2px 0 6px;font-size:11px}.item-desc{color:var(--fg-2);margin:0 0 8px;font-size:13px;line-height:1.5}.item-link{font-family:var(--mono);color:var(--accent);border-bottom:1px solid #0000;font-size:12px;text-decoration:none;transition:border-color .12s}.item-link:hover{border-bottom-color:var(--accent)}.item-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.tag-chip{background:var(--bg-3);color:var(--fg-2);border:1px solid var(--line-2);font-family:var(--mono);border-radius:3px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.tag-chip button{color:var(--dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;line-height:1;transition:color .14s}.tag-chip button:hover{color:#ff6b6b}.tag-chip.small{padding:1px 6px;font-size:10px}.tags-input-row{gap:6px;display:flex}.tags-input-row input{flex:1}.tags-input-row button{color:var(--fg-2);border:1px solid var(--line);font-family:var(--mono);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:.6rem .75rem;font-size:12px;transition:all .14s}.tags-input-row button:hover{border-color:var(--accent);color:var(--accent)}.form-row-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.checkbox-group label{cursor:pointer;font-family:var(--mono);color:var(--fg-2);align-items:center;gap:8px;font-size:12px;display:flex}.checkbox-group input[type=checkbox]{width:auto;accent-color:var(--accent)}.btn-primary{background:var(--accent);color:#0b0d10;font-family:var(--mono);cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;gap:6px;padding:7px 16px;font-size:12px;font-weight:600;transition:opacity .14s;display:flex}.btn-primary:hover:not(:disabled){opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{color:var(--dim);border:1px solid var(--line);font-family:var(--mono);cursor:pointer;background:0 0;border-radius:4px;align-items:center;gap:6px;padding:7px 16px;font-size:12px;transition:all .14s;display:flex}.btn-secondary:hover:not(:disabled){color:var(--fg-2);border-color:var(--line-2)}.btn-secondary.active{border-color:var(--accent);color:var(--accent)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.mgr-pagination{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}.pgn-info{color:var(--dim);font-family:var(--mono);letter-spacing:.02em;font-size:11px}.pgn-controls{align-items:center;gap:4px;display:flex}.pgn-btn{border:1px solid var(--line);color:var(--fg-2);cursor:pointer;font-family:var(--mono);background:0 0;border-radius:3px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:5px 10px;font-size:12px;transition:all .14s;display:flex}.pgn-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pgn-btn.active{background:color-mix(in oklab, var(--accent) 15%, transparent);border-color:var(--accent);color:var(--accent)}.pgn-btn:disabled{opacity:.3;cursor:not-allowed}.pgn-ellipsis{color:var(--dim-2);font-family:var(--mono);padding:0 4px;font-size:12px}.badge-pub{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:#4ade80;background:#4ade8012;border:1px solid #4ade804d;border-radius:3px;margin-left:6px;padding:2px 6px;font-size:10px}.login-container{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-form{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;width:100%;max-width:360px;padding:2rem}.login-form h1{text-align:center;color:var(--fg);font-family:var(--mono);letter-spacing:-.02em;margin-bottom:2rem;font-size:18px;font-weight:600}.auth-error{color:#ff6b6b;font-family:var(--mono);text-align:center;background:#dc3c3c14;border:1px solid #dc3c3c38;border-radius:4px;margin-bottom:1rem;padding:.6rem .75rem;font-size:12px}.auth-success{color:#50c878;font-family:var(--mono);text-align:center;background:#50c87814;border:1px solid #50c87840;border-radius:4px;margin-bottom:1rem;padding:.6rem .75rem;font-size:12px}.auth-submit{background:var(--accent);color:#0b0d10;width:100%;font-family:var(--mono);cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:.65rem;font-size:13px;font-weight:600;transition:opacity .14s;display:flex}.auth-submit:hover:not(:disabled){opacity:.85}.auth-submit:disabled{opacity:.4;cursor:not-allowed}.auth-footer{text-align:center;color:var(--dim);font-family:var(--mono);margin-top:1rem;font-size:12px}.auth-footer a{color:var(--accent);text-decoration:none}.mobile-header{background:var(--bg-2);border-bottom:1px solid var(--line);z-index:1001;justify-content:space-between;align-items:center;height:52px;padding:0 1rem;display:none;position:fixed;top:0;left:0;right:0}.mobile-header h1{font-family:var(--mono);color:var(--fg);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:12px;font-weight:500}.sidebar{background:var(--bg-2);border-right:1px solid var(--line);z-index:1000;flex-direction:column;width:210px;min-height:100vh;transition:transform .25s;display:flex;position:fixed;top:0;left:0}.nav-items{flex:1;padding:6px 0}.nav-item.logout-button{color:var(--dim)!important}.nav-item.logout-button:hover{color:#ff6b6b!important;background:#dc3c3c12!important;border-left-color:#dc3c3c80!important}.content{background:var(--bg);flex:1;width:calc(100vw - 210px);max-width:calc(100vw - 210px);min-height:100vh;margin-left:210px;overflow-x:hidden}.logs-header-actions{align-items:center;gap:8px;display:flex}.logs-filters{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.filter-row select,.filter-row input{border:1px solid var(--line);background:var(--bg-3);color:var(--fg);font-family:var(--mono);border-radius:4px;padding:.5rem .6rem;font-size:12px;transition:border-color .14s}.filter-row select:focus,.filter-row input:focus{border-color:var(--accent);outline:none}.date-range{align-items:center;gap:6px;display:flex}.date-range span{color:var(--dim);font-family:var(--mono);font-size:12px}.filter-chip{border:1px solid var(--line);color:var(--dim);font-family:var(--mono);cursor:pointer;background:0 0;border-radius:3px;padding:4px 10px;font-size:11px;transition:all .14s}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.logs-meta{margin-bottom:8px}.logs-list{border-top:1px solid var(--line);flex-direction:column;display:flex}.log-item{border-bottom:1px solid var(--line);cursor:pointer;padding:10px 0;transition:padding-left .14s}.log-item:hover{background:var(--bg-2);padding-left:6px}.log-head{font-family:var(--mono);flex-wrap:wrap;align-items:baseline;gap:10px;font-size:11px;display:flex}.log-error .log-level{color:#ff6b6b;background:#dc3c3c1f}.log-warn .log-level{color:var(--accent);background:#facc151f}.log-info .log-level{color:#4da3ff;background:#4da3ff1f}.log-debug .log-level{color:var(--dim);background:#7d85901f}.log-time{color:var(--dim-2)}.log-session{color:var(--dim-2);font-size:10px}.log-message{color:var(--fg-2);flex:1;font-size:13px}.log-extra{background:var(--bg-3);border:1px solid var(--line);font-family:var(--mono);color:var(--dim);white-space:pre-wrap;border-radius:4px;margin-top:8px;padding:10px;font-size:12px;overflow-x:auto}.logs-manager .manager-wrap{padding:2rem}.scroll-to-top{border:1px solid var(--line);background:var(--bg-2);width:40px;height:40px;color:var(--dim);cursor:pointer;z-index:50;border-radius:50%;justify-content:center;align-items:center;transition:border-color .14s,background .14s,color .14s;display:flex;position:fixed;bottom:32px;right:32px}.scroll-to-top:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, transparent)}@media (max-width:640px){.scroll-to-top{bottom:20px;right:20px}}.site-main{max-width:900px;min-height:100vh;margin:0 auto;padding:88px 32px 120px}@media (max-width:940px){.site-main{padding:40px 22px 80px}}@media (max-width:640px){.site-main{padding:28px 18px 72px}}@media (max-width:768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.content{width:100vw;max-width:100vw;margin-left:0;padding-top:52px}.manager-wrap{padding:1rem}.form-row-2{grid-template-columns:1fr}.mgr-pagination{flex-direction:column;align-items:stretch}.pgn-info{text-align:center}.pgn-controls{justify-content:center}}
