:root{--bg-pink: #fff3f6;--bg-peach: #ffe7df;--ink: #2f2532;--ink-soft: #6b5b70;--accent: #e8598f;--accent-strong: #d83f7c;--accent-on-bg: #c8407d;--on-accent: #fff;--on-accent-translucent: rgba(255, 255, 255, .25);--panel: rgba(255, 255, 255, .62);--line: rgba(255, 255, 255, .72);--shadow: 0 16px 42px rgba(181, 67, 118, .14);--body-gradient-1: rgba(255, 196, 217, .48);--body-gradient-2: rgba(255, 225, 202, .5);--code-bg: #f8edf2;--modal-overlay: rgba(22, 14, 26, .72);--tag-bg: rgba(233, 89, 143, .15);--tag-color: #b03f70;--input-bg: rgba(255, 255, 255, .9);--input-border: #f3bfd2;--blockquote-bg: rgba(255, 184, 210, .16);--blockquote-color: #7c4a63;--split-gradient: linear-gradient(to right, transparent, #efadc9, transparent);--float-btn-bg: rgba(255, 255, 255, .85);--float-btn-color: #333;--search-btn-gradient: linear-gradient(140deg, #d83f7c, #c8407d);--scrollbar-track: rgba(255, 214, 227, .62);--scrollbar-thumb: rgba(232, 89, 143, .62);--scrollbar-thumb-hover: rgba(216, 63, 124, .82);--rose-50: oklch(.985 .008 350);--rose-100: oklch(.965 .012 350);--rose-200: oklch(.92 .018 350);--rose-300: oklch(.85 .025 350);--rose-400: oklch(.72 .035 350);--rose-500: oklch(.58 .05 350);--rose-600: oklch(.48 .05 350);--rose-700: oklch(.38 .045 350);--rose-800: oklch(.28 .04 350);--rose-900: oklch(.18 .03 350);--link-author: var(--accent-strong);--panel-solid: rgba(255, 255, 255, .88);--display-letter-spacing: -.005em;--brand-letter-spacing: .02em}[data-theme=dark]{--bg-pink: #1a1220;--bg-peach: #1c1028;--ink: #e4dcec;--ink-soft: #b0a0c0;--accent: #f0a0c0;--accent-strong: #f2b0d0;--accent-on-bg: #ffc4d8;--on-accent: #1a1220;--on-accent-translucent: rgba(26, 18, 32, .18);--panel: rgba(25, 18, 35, .78);--line: rgba(255, 255, 255, .1);--shadow: 0 16px 42px rgba(0, 0, 0, .35);--body-gradient-1: rgba(60, 20, 50, .5);--body-gradient-2: rgba(30, 20, 50, .5);--code-bg: #2a2035;--modal-overlay: rgba(0, 0, 0, .8);--tag-bg: rgba(240, 140, 180, .2);--tag-color: #f0b0c8;--input-bg: rgba(30, 20, 40, .85);--input-border: #5a3a5a;--blockquote-bg: rgba(200, 160, 200, .12);--blockquote-color: #c8b0d0;--split-gradient: linear-gradient(to right, transparent, #5a3a5a, transparent);--float-btn-bg: rgba(30, 20, 40, .85);--float-btn-color: #e0d0e8;--search-btn-gradient: linear-gradient(140deg, #b85090, #9b3768);--scrollbar-track: rgba(41, 28, 52, .78);--scrollbar-thumb: rgba(240, 160, 192, .52);--scrollbar-thumb-hover: rgba(246, 188, 214, .78);--link-author: var(--accent);--panel-solid: rgba(25, 18, 35, .92);--rose-50: oklch(.2 .018 350);--rose-100: oklch(.24 .022 350);--rose-200: oklch(.3 .028 350);--rose-300: oklch(.42 .035 350);--rose-400: oklch(.55 .04 350);--rose-500: oklch(.68 .05 350);--rose-600: oklch(.76 .05 350);--rose-700: oklch(.84 .045 350);--rose-800: oklch(.9 .035 350);--rose-900: oklch(.96 .02 350)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track);scrollbar-gutter:stable}html::-webkit-scrollbar{width:12px;height:12px}html::-webkit-scrollbar-track{background:var(--scrollbar-track)}html::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--scrollbar-thumb),var(--scrollbar-thumb-hover));border:3px solid transparent;border-radius:999px;background-clip:padding-box}html::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--scrollbar-thumb-hover),var(--scrollbar-thumb));border:3px solid transparent;background-clip:padding-box}html::-webkit-scrollbar-corner{background:transparent}body{color:var(--ink);background:radial-gradient(circle at 15% 10%,var(--body-gradient-1) 0%,transparent 48%),radial-gradient(circle at 90% 15%,var(--body-gradient-2) 0%,transparent 35%),linear-gradient(145deg,var(--bg-pink),var(--bg-peach));min-height:100vh;font-family:Noto Sans SC,sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}.skip-to-content{position:absolute;top:-100%;left:16px;z-index:999;padding:10px 18px;background:var(--accent-on-bg);color:var(--on-accent);border-radius:0 0 8px 8px;font-weight:600;transition:top .2s}.skip-to-content:focus{top:0}:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px;box-shadow:0 0 0 4px #e8598f47;border-radius:4px}html.is-theme-changing body,html.is-theme-changing .glass-panel,html.is-theme-changing .background-overlay,html.is-theme-changing .background-image,html.is-theme-changing .post-card,html.is-theme-changing .widget,html.is-theme-changing .navbar,html.is-theme-changing .sidebar,html.is-theme-changing .theme-toggle-fab:not(.is-toggling){transition:none!important}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}*:hover,*:focus,*:focus-visible,*:active{transform:none!important}}.glass-panel{background:var(--panel);border:1px solid var(--line);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 12px 30px #b543761f;border-radius:18px;position:relative;overflow:hidden;transform:translateY(0) scale(1);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease,background .24s ease}.glass-panel:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.22),transparent 38%,rgba(255,255,255,.08));opacity:0;pointer-events:none;transition:opacity .24s ease}.glass-panel:hover,.glass-panel:focus-within{transform:translateY(-2px);box-shadow:0 14px 26px #30223e1f,inset 0 1px #ffffff1f}.glass-panel:hover:before,.glass-panel:focus-within:before{opacity:1}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.glass-panel,.menu-links,.theme-toggle-fab{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--panel-solid, var(--panel))}}@media(prefers-reduced-transparency:reduce){.glass-panel,.menu-links,.theme-toggle-fab{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--panel-solid, var(--panel))}}.post-detail.glass-panel,.archive-stream.glass-panel{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--panel-solid, var(--panel))}.post-detail{content-visibility:auto;contain-intrinsic-size:900px}.post-detail:hover,.post-detail:focus-within{transform:none;box-shadow:0 12px 30px #b543761f}.post-detail:hover:before,.post-detail:focus-within:before{opacity:0}.sidebar,.widget{content-visibility:auto;contain-intrinsic-size:280px}.sidebar,.widget,.post-card{contain:paint}.background-image{position:fixed;inset:0;background-image:var(--bg-url, linear-gradient(160deg, #ffe1ec 0%, #f7c7d8 45%, #f2a8c4 100%));background-size:cover;background-position:center;opacity:var(--bg-opacity);filter:blur(var(--bg-blur));z-index:-2;transition:background-image .35s ease}[data-theme=dark] .background-image{background-image:var(--bg-url, linear-gradient(160deg, #1c1730 0%, #261c3a 50%, #382146 100%))}.background-overlay{position:fixed;inset:0;background:linear-gradient(to bottom,#ffffff26,#ffffffb8);z-index:-1}[data-theme=dark] .background-overlay{background:linear-gradient(to bottom,#00000026,#0000008c)}.navbar-wrap{position:sticky;top:0;z-index:50;padding:14px 18px}.navbar{position:relative;max-width:1220px;margin:0 auto;display:grid;grid-template-columns:220px 1fr auto;gap:16px;align-items:center;padding:14px 18px;animation:component-rise .55s cubic-bezier(.2,.7,.2,1) both;overflow:visible}.navbar-actions{display:flex;align-items:center;gap:10px}.nav-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;padding:0;border:1px solid var(--input-border);border-radius:999px;background:var(--input-bg);color:var(--ink-soft);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.nav-toggle:hover{color:var(--accent-strong);border-color:#e85f9566}.nav-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.brand{font-family:"Noto Serif SC",serif;font-size:1.7rem;color:var(--accent-strong);display:inline-flex;align-items:center;gap:6px;transition:transform .22s ease,color .22s ease,text-shadow .22s ease}.brand{letter-spacing:var(--brand-letter-spacing)}.brand:hover{transform:translateY(-1px);text-shadow:0 6px 18px rgba(232,95,149,.24)}.search-form{display:flex;gap:8px}.search-input-wrap{position:relative;flex:1}.search-form input{width:100%;min-height:44px;border:1px solid var(--input-border);border-radius:999px;padding:10px 52px 10px 14px;background:var(--input-bg);color:var(--ink);font-size:.95rem;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease}.search-kbd{position:absolute;right:12px;top:50%;transform:translateY(-50%);padding:2px 8px;border:1px solid var(--input-border);border-radius:6px;background:color-mix(in srgb,var(--input-bg) 50%,transparent);font-family:JetBrains Mono,monospace;font-size:.72rem;line-height:1.2;color:var(--ink-soft);pointer-events:none;letter-spacing:0;opacity:.85;transition:opacity .18s ease}.search-input-wrap input:focus+.search-kbd,.search-input-wrap input:not(:placeholder-shown)+.search-kbd{opacity:0}.search-form input::placeholder{color:var(--ink-soft)}.search-form input:focus-visible{transform:translateY(-1px);border-color:#e85f9580;box-shadow:0 0 0 4px #e85f9524}.search-form button{min-height:44px;border:0;border-radius:999px;padding:10px 14px;background:var(--search-btn-gradient);color:#fff;cursor:pointer;font-size:.9rem;white-space:nowrap;transition:transform .2s ease,filter .2s ease,box-shadow .2s ease}.search-form button:hover{transform:translateY(-1px);filter:brightness(1.05)}.search-form button:active{transform:translateY(0) scale(.98)}.menu-links{display:flex;gap:14px}.menu-links a{position:relative;min-height:44px;display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;color:var(--ink-soft);transition:background .2s,color .2s,transform .2s ease}.menu-links a:after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;border-radius:999px;background:currentColor;opacity:0;transform:scaleX(.2);transform-origin:center;transition:opacity .2s ease,transform .2s ease}.menu-links a.active,.menu-links a:hover{background:#ec659629;color:var(--accent-strong);transform:translateY(-1px)}.menu-links a.active:after,.menu-links a:hover:after{opacity:.75;transform:scaleX(1)}.page-wrap{max-width:1220px;margin:0 auto;padding:18px}.three-column{display:grid;grid-template-columns:260px 1fr 290px;gap:18px}.sticky-col{position:sticky;top:95px;align-self:start}.sidebar{padding:20px;display:flex;flex-direction:column;gap:14px;animation:component-rise .55s cubic-bezier(.2,.7,.2,1) both}.avatar-wrap{width:110px;height:110px;border-radius:999px;overflow:hidden;margin:0 auto;border:4px solid rgba(255,150,193,.35);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.avatar-wrap img,.avatar-wrap .avatar-emoji{width:100%;height:100%;object-fit:cover;display:grid;place-items:center;font-size:2.8rem;background:linear-gradient(120deg,#ffbfd5,#eec8ff);transition:transform .28s ease,filter .28s ease}.sidebar:hover .avatar-wrap{transform:translateY(-2px) scale(1.02);border-color:#ff96c185;box-shadow:0 10px 20px #e85f952e}.sidebar:hover .avatar-wrap img,.sidebar:hover .avatar-wrap .avatar-emoji{transform:scale(1.06);filter:saturate(1.06)}.sidebar h2{text-align:center;margin:0}.bio{margin:0;color:var(--ink-soft);line-height:1.6;font-size:.94rem}.info-list p{margin:6px 0;font-size:.92rem}.info-list a{color:var(--accent-strong)}.split-line{height:1px;background:var(--split-gradient)}.sidebar blockquote{margin:0;padding:12px;border-radius:12px;background:var(--blockquote-bg);font-size:.9rem;line-height:1.7;white-space:pre-line;color:var(--blockquote-color);transition:transform .22s ease,background .22s ease}.sidebar:hover blockquote{background:color-mix(in srgb,var(--blockquote-bg) 86%,white 14%)}.quote-panel,.result-bar,.empty-tips{padding:14px 16px;margin-bottom:12px}.quote-panel{position:relative;min-height:54px;white-space:pre-line}.quote-panel.typing:after{content:"|";margin-left:4px;color:var(--accent-strong);animation:quote-caret-blink .9s steps(1,end) infinite}.post-list{display:grid;gap:12px}.post-list[aria-busy=true]{min-height:260px}.post-card{display:block;padding:20px;position:relative;transition:transform .22s ease,background .3s ease,box-shadow .22s ease;content-visibility:auto;contain-intrinsic-size:260px}.post-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 34%,rgba(255,255,255,.08));opacity:0;transition:opacity .22s ease;pointer-events:none}.post-card:hover{transform:translateY(-2px);box-shadow:0 12px 22px #4f253d1a}.post-card:hover:before{opacity:1}.search-highlight{padding:0 3px;border-radius:6px;background:linear-gradient(180deg,#fff4fa2e,#fff4fa00),linear-gradient(120deg,#ffcbe1f2,#ffe1cde6);color:inherit;box-shadow:0 0 0 1px #e85f9514,0 0 14px #e85f9529,inset 0 -.42em #ffffff38;text-shadow:0 0 .01px currentColor}[data-theme=dark] .search-highlight{background:linear-gradient(180deg,#ffffff14,#fff0),linear-gradient(120deg,#ff94c2d1,#ffcea4ad);box-shadow:0 0 0 1px #ffaad21a,0 0 16px #ff8fc138,inset 0 -.42em #ffffff1a}.post-skeleton{pointer-events:none}.skeleton-line,.skeleton-row span{display:block;border-radius:999px;background:linear-gradient(90deg,#e85f9514,#e85f952e,#e85f9514)}.skeleton-title{width:62%;height:24px;margin-bottom:12px}.skeleton-body{width:100%;height:14px;margin-bottom:10px}.skeleton-body.short{width:74%}.skeleton-row{display:flex;justify-content:space-between;gap:12px;margin-top:14px}.skeleton-row span{width:38%;height:14px}.post-card h3{margin:0 0 10px;color:var(--ink);font-size:1.5rem;line-height:1.35;letter-spacing:var(--display-letter-spacing)}[data-theme=dark] .post-card h3{color:#e8d8f0}.post-card p{margin:0;color:var(--ink-soft);line-height:1.65}.post-meta{display:flex;justify-content:space-between;margin-top:12px;color:var(--ink-soft);font-size:.86rem;flex-wrap:wrap;gap:8px}.post-meta .author-name{color:var(--link-author);font-weight:500}.post-tags{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.post-tags span,.post-tags .post-tag-link{background:var(--tag-bg);color:var(--tag-color);border-radius:999px;font-size:.78rem;padding:4px 10px;transition:transform .2s ease,background .2s ease;text-decoration:none}.post-tags span:hover,.post-tags .post-tag-link:hover{background:var(--accent-on-bg);color:var(--on-accent)}.post-card-title-link{color:inherit;text-decoration:none}.post-card-title-link:after{content:"";position:absolute;inset:0;z-index:0}.post-card h3,.post-card p,.post-card .post-meta,.post-card .post-tags{position:relative;z-index:1}.post-meta-link,.post-tag-link{position:relative;z-index:1;text-decoration:none;color:inherit;transition:color .18s ease}.post-meta-link.author-name{cursor:pointer}.post-meta-link.author-name:hover{text-decoration:underline;text-underline-offset:3px}.post-meta-date{color:var(--ink-soft)}.post-meta-date:hover{color:var(--accent-strong)}.right-sidebar{display:grid;gap:12px}.widget{padding:14px;transition:box-shadow .22s ease,border-color .22s ease}.widget:hover{box-shadow:0 10px 20px #4f253d14}.widget h3{margin:0 0 10px;font-size:1rem}.carousel{position:relative;height:180px;border-radius:12px;overflow:hidden;background:#fbdce7}[data-theme=dark] .carousel{background:#2a1a30}.carousel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease,transform .6s ease}.carousel:hover img.active{transform:scale(1.04)}.carousel img.active{opacity:1}.emoji-fallback{height:100%;display:grid;place-items:center;font-size:3rem}.calendar-root .month-title{text-align:center;margin:0 0 8px;color:var(--accent-strong);font-weight:600}.weekday-row,.day-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.weekday-row span,.day-grid span{text-align:center;font-size:.8rem;padding:4px 0}.day-grid span.today{background:#e85f95;border-radius:8px;color:#fff}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{min-height:44px;border:0;border-radius:999px;padding:5px 12px;background:#e85f952e;color:#9f3465;cursor:pointer;font-size:.85rem;transition:background .2s,color .2s,transform .2s ease,box-shadow .2s ease}.tag-chip:hover{transform:translateY(-1px);box-shadow:0 6px 12px #e85f951a}.tag-chip:active{transform:translateY(0) scale(.98)}.tag-chip.active{background:linear-gradient(120deg,#ef6fa2,#d74887);color:#fff}.pagination{margin-top:16px;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.pagination-pages{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.pagination-summary{color:var(--ink-soft);font-size:.86rem;white-space:nowrap}.pagination-link{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;height:auto;padding:0 14px;border-radius:999px;border:1px solid rgba(232,95,149,.18);background:#ffffff8f;color:var(--ink);transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease}.pagination-link:hover{transform:translateY(-1px);background:#ffffffc7;border-color:#e85f954d}.pagination-link.is-current{background:var(--accent-on-bg);color:var(--on-accent);border-color:transparent}.pagination-link.is-disabled{opacity:.45;pointer-events:none}.single-column{display:grid;gap:16px}.archive-layout{display:grid;grid-template-columns:260px 1fr;grid-template-areas:"toolbar toolbar" "side    stream";gap:18px;align-items:start}.archive-toolbar{grid-area:toolbar;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 18px;flex-wrap:wrap}.archive-mode-tabs{display:inline-flex;background:var(--code-bg);border-radius:999px;padding:4px;gap:2px}.archive-mode-tab{border:0;background:transparent;padding:7px 18px;border-radius:999px;font-size:.92rem;font-family:inherit;color:var(--ink-soft);cursor:pointer;transition:background .18s ease,color .18s ease}.archive-mode-tab:hover{color:var(--ink)}.archive-mode-tab.is-active{background:var(--accent-on-bg);color:var(--on-accent)}.archive-toolbar-meta{margin:0;color:var(--ink-soft);font-size:.86rem}.archive-side{grid-area:side;padding:16px;display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 180px);overflow-y:auto}.archive-side-panel[hidden]{display:none}.archive-side-title{margin:0 0 4px;font-size:.92rem;font-weight:600;color:var(--ink-soft);letter-spacing:.05em;text-transform:uppercase}.archive-tag-list{display:flex;flex-direction:column;gap:4px}.archive-tag-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;color:var(--ink);text-decoration:none;font-size:.92rem;transition:background .18s ease,color .18s ease,transform .18s ease}.archive-tag-item:hover{background:var(--code-bg);transform:translate(2px)}.archive-tag-item .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.archive-tag-item .count{flex:0 0 auto;font-size:.78rem;background:var(--tag-bg);color:var(--tag-color);border-radius:999px;padding:2px 9px;transition:background .18s ease,color .18s ease}.archive-tag-item.is-active{background:var(--accent-on-bg);color:var(--on-accent)}.archive-tag-item.is-active .count{background:var(--on-accent-translucent);color:var(--on-accent)}.archive-toc-list{display:flex;flex-direction:column;gap:12px}.archive-toc-year{display:flex;flex-direction:column;gap:4px}.archive-toc-year-label{font-size:.85rem;font-weight:600;color:var(--ink-soft);padding-left:8px}.archive-toc-list ul{list-style:none;margin:0;padding:0 0 0 8px;display:flex;flex-direction:column;gap:2px}.archive-toc-list a{display:block;padding:5px 8px;border-radius:8px;color:var(--ink);text-decoration:none;font-size:.86rem;transition:background .18s ease,color .18s ease}.archive-toc-list a:hover{background:var(--code-bg);color:var(--accent-strong)}.archive-stream{grid-area:stream;padding:22px 24px;background:var(--panel-solid)}.archive-stream-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--input-border);margin-bottom:14px}.archive-stream-head h1{margin:0;font-family:"Noto Serif SC",serif;font-weight:700;font-size:1.5rem;letter-spacing:var(--display-letter-spacing);color:var(--accent-strong)}.archive-stream-meta{margin:0;color:var(--ink-soft);font-size:.88rem}.archive-year+.archive-year{margin-top:26px}.archive-year-label{margin:0 0 12px;font-family:"Noto Serif SC",serif;font-size:1.8rem;font-weight:700;color:var(--accent-strong);letter-spacing:var(--brand-letter-spacing)}.archive-month{margin:14px 0;padding:10px 12px;border-radius:12px;scroll-margin-top:100px;transition:background .4s ease,box-shadow .4s ease}.archive-month:target{background:var(--code-bg);box-shadow:inset 3px 0 0 var(--accent);animation:archive-month-pulse 1.6s ease-out 1}@keyframes archive-month-pulse{0%{background:#e8598f2e}to{background:var(--code-bg)}}.archive-month-label{margin:0 0 8px;font-size:1rem;font-weight:600;color:var(--ink);display:flex;align-items:baseline;gap:10px;background-image:var(--split-gradient);background-repeat:no-repeat;background-position:bottom left;background-size:100% 1px;padding-bottom:4px}.archive-month-count{font-size:.78rem;color:var(--ink-soft);font-weight:400}.archive-articles{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.archive-empty{margin:24px 0 0;text-align:center;color:var(--ink-soft)}[data-mode=tag] .archive-month-label{display:none}[data-mode=tag] .archive-month{margin:0;padding:0;scroll-margin-top:0}[data-mode=tag] .archive-month:target{background:transparent;box-shadow:none;animation:none}[data-mode=tag] .archive-year+.archive-year{margin-top:18px}.article-item a{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:12px;padding:10px 6px;border-radius:8px;text-decoration:none;color:var(--ink);transition:background .18s ease,transform .18s ease}.article-item a:hover{background:var(--code-bg);transform:translate(3px)}.article-item time{font-variant-numeric:tabular-nums;font-size:.84rem;color:var(--ink-soft)}.article-item .title{font-size:.96rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.article-item a:hover .title{color:var(--accent-strong)}.article-tags{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.article-tag{font-size:.72rem;color:var(--tag-color);background:var(--tag-bg);border-radius:999px;padding:1px 8px}.hidden{display:none!important}.theme-toggle-fab{position:relative;display:grid;place-items:center;width:40px;height:40px;padding:0;border:1px solid rgba(233,180,202,.72);border-radius:999px;flex:0 0 auto;background:linear-gradient(160deg,#fffffff0,#fff0f6c7),radial-gradient(circle at 32% 26%,rgba(255,224,235,.86),transparent 46%);backdrop-filter:blur(6px) saturate(112%);-webkit-backdrop-filter:blur(6px) saturate(112%);box-shadow:0 10px 20px #302a3b1f,inset 0 1px #ffffffdb;color:#9a3f66;cursor:pointer;touch-action:manipulation;transition:transform .2s cubic-bezier(.2,.8,.2,1),filter .2s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease,color .18s ease;isolation:isolate;overflow:hidden}[data-theme=dark] .theme-toggle-fab{border-color:#827494a8;background:linear-gradient(160deg,#221a2ceb,#18131fd1),radial-gradient(circle at 30% 26%,rgba(126,96,156,.42),transparent 46%);color:#dfe5ff;box-shadow:0 12px 26px #05060a57,inset 0 1px #ffffff1a}.theme-toggle-fab:hover{transform:translateY(-1px);filter:saturate(1.04)}.theme-toggle-fab:active{transform:translateY(0) scale(.97)}.theme-toggle-fab:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px;box-shadow:0 0 0 4px #e8598f47}.theme-toggle-fab:before{content:"";position:absolute;inset:7px;border-radius:inherit;background:radial-gradient(circle at 35% 30%,#ffffffc2,#fff0);opacity:.62;z-index:-1;transition:opacity .22s ease,transform .22s ease}.theme-toggle-fab:after{content:"";position:absolute;inset:-4px;border-radius:inherit;background:radial-gradient(circle,rgba(232,89,143,.2),transparent 68%);opacity:0;transform:scale(.62);transition:opacity .32s ease,transform .32s cubic-bezier(.2,.8,.2,1);z-index:-2}.theme-toggle-icon{position:absolute;top:50%;left:50%;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;transform-origin:center;will-change:transform,opacity;transition:opacity .22s ease,transform .36s cubic-bezier(.22,1,.36,1)}.theme-toggle-icon svg{width:19px;height:19px;display:block;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.theme-toggle-sun{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}.theme-toggle-moon{opacity:0;transform:translate(-50%,calc(-50% + 12px)) rotate(-32deg) scale(.72)}.theme-toggle-moon svg path:first-child,.theme-toggle-moon svg path:last-child{fill:none;stroke:currentColor}.theme-toggle-fab.is-dark .theme-toggle-sun{opacity:0;transform:translate(-50%,calc(-50% - 12px)) rotate(48deg) scale(.72)}.theme-toggle-fab.is-dark .theme-toggle-moon{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}.theme-toggle-fab.is-dark:before{opacity:.34}.theme-toggle-fab.is-dark:after{background:radial-gradient(circle,rgba(150,164,255,.2),transparent 68%)}.theme-toggle-fab.is-toggling{box-shadow:0 16px 28px #302a3b2e,inset 0 1px #ffffffb8}.theme-toggle-fab.is-toggling:after{opacity:1;transform:scale(1)}.theme-toggle-fab.is-toggling .theme-toggle-icon{animation:theme-toggle-orbit .42s cubic-bezier(.22,1,.36,1)}@keyframes theme-toggle-orbit{0%{filter:brightness(1)}45%{filter:brightness(1.12)}to{filter:brightness(1)}}@keyframes quote-caret-blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes component-rise{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1080px){.three-column{grid-template-columns:1fr}.archive-layout{grid-template-columns:1fr;grid-template-areas:"toolbar" "side" "stream"}.archive-side{max-height:none}.archive-tag-list{flex-direction:row;flex-wrap:wrap;gap:6px}.archive-tag-item{padding:6px 10px}.sticky-col{position:static}.center-col{order:1}.left-col{order:2}.right-col{order:3}.carousel-widget,.calendar-widget{display:none}.navbar{grid-template-columns:1fr auto;grid-auto-flow:dense;gap:10px 12px}.search-form{grid-column:1 / -1}.nav-toggle{display:inline-flex}.search-kbd{display:none}.menu-links{display:none;position:absolute;top:calc(100% + 6px);right:18px;z-index:60;min-width:168px;flex-direction:column;gap:4px;padding:10px;background:var(--panel-solid);border:1px solid var(--line);border-radius:14px;box-shadow:0 14px 28px #30223e2e;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.menu-links.is-open{display:flex}.menu-links a{width:100%;border-radius:10px}.pagination{gap:8px}.pagination-summary{width:100%;text-align:center;order:3}}@media(max-width:640px){.archive-stream{padding:16px 14px}.article-item a{grid-template-columns:48px 1fr;grid-template-rows:auto auto}.article-tags{grid-column:2 / -1;justify-content:flex-start}.post-tags .post-tag-link,.post-tags span,.archive-tag-item,.archive-mode-tab{min-height:44px;display:inline-flex;align-items:center}.post-meta-link{display:inline-flex;align-items:center;min-height:44px}.entry-copy{--entry-shift: -7vh;min-width:94vw;padding:20px 18px}.entry-line-primary{font-size:clamp(1.7rem,8.3vw,2.55rem)}.entry-line-secondary{font-size:clamp(.95rem,4.1vw,1.2rem);letter-spacing:.1em}.page-wrap{padding:12px}.post-detail h1{font-size:1.6rem}.navbar{padding:10px 12px}.theme-toggle-fab{width:38px;height:38px}}.info-list p{display:flex;align-items:center;gap:8px}.info-icon{flex:0 0 auto;width:16px;height:16px;fill:none;stroke:var(--accent-strong);stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.meta-icon{width:14px;height:14px;vertical-align:-2px;margin-right:4px;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.post-card-cover{display:block;aspect-ratio:16 / 9;margin:-20px -20px 16px;overflow:hidden;background:var(--rose-100);border-bottom:1px solid var(--line)}.post-card-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.post-card:hover .post-card-cover img{transform:scale(1.03)}.result-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.result-bar:empty{display:none}.filter-summary{color:var(--ink-soft);font-size:.88rem;margin-right:2px}.filter-count{color:var(--ink-soft);font-size:.86rem;margin-left:auto}.filter-chip{display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:4px 10px 4px 12px;border-radius:999px;border:1px solid var(--input-border);background:var(--rose-100);color:var(--accent-strong);font-family:inherit;font-size:.86rem;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease,border-color .18s ease}.filter-chip:hover{background:var(--accent-on-bg);color:var(--on-accent);border-color:transparent;transform:translateY(-1px)}.filter-chip-close{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:999px;background:color-mix(in srgb,currentColor 18%,transparent);font-size:.7rem;line-height:1}.filter-clear-all{margin-left:4px;padding:4px 12px;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--ink-soft);font-family:inherit;font-size:.84rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .18s ease}.filter-clear-all:hover{color:var(--accent-strong)}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
