.astro-route-announcer{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;top:0;left:0;overflow:hidden}:root{--bg:#fbf7f0;--sidebar:#f5eee6;--surface:#fffaf3;--surface-soft:#f3e8dc;--text:#2b2118;--muted:#7a6a5c;--primary:#d76f4a;--primary-dark:#b85638;--primary-soft:#f1d8ca;--border:#e4d4c3;--code-bg:#fff7ed;--code-border:#e8d2bf;--code-panel:#ead8c7;--code-panel-soft:#f1dfcf;--code-text:#5b3b2b;--shadow-soft:0 14px 34px #2b21180d;--radius:8px;--serif:Georgia, "Times New Roman", Times, serif;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:0;color:var(--text);background:var(--bg);font-family:var(--sans);margin:0;line-height:1.68;overflow-x:hidden}@keyframes page-main-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@keyframes page-main-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes page-aside-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@keyframes page-aside-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes details-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}::view-transition-old(root),::view-transition-new(root){animation:none}::view-transition-old(shell-topbar),::view-transition-new(shell-topbar),::view-transition-old(shell-sidebar),::view-transition-new(shell-sidebar){mix-blend-mode:normal;animation:none}::view-transition-old(page-main){animation:.16s both page-main-out}::view-transition-old(page-aside){animation:.16s 80ms both page-aside-out}::view-transition-new(page-main){animation:.19s .21s both page-main-in}::view-transition-new(page-aside){animation:.19s .3s both page-aside-in}a{color:inherit;text-decoration:none}button,input{font:inherit}svg{display:block}.app-shell{background:var(--bg);min-height:100vh}.topbar{z-index:20;border-bottom:1px solid var(--border);backdrop-filter:blur(16px);view-transition-name:shell-topbar;background:#fbf7f0eb;justify-content:space-between;align-items:center;gap:16px;height:58px;padding:0 24px;display:flex;position:sticky;top:0}.window-controls,.topbar-actions{align-items:center;display:flex}.window-controls{gap:9px;min-width:92px}.topbar-actions{color:var(--muted);gap:12px;font-size:14px}.dot{border:1px solid #2b211814;border-radius:999px;width:12px;height:12px}.dot.red{background:#f25f58}.dot.yellow{background:#e9b44c}.dot.green{background:#54b86a}.topbar-icon{border-radius:999px;place-items:center;width:34px;height:34px;display:grid}.topbar-icon svg,.nav-link svg,.light-status svg,.meta svg,.section-heading svg,.external-link svg,.copy-button svg{stroke:currentColor;stroke-width:1.8px;fill:none;stroke-linecap:round;stroke-linejoin:round;width:17px;height:17px}.search-box{width:min(260px,30vw);height:36px;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);background:#fffaf3d1;align-items:center;gap:8px;padding:0 12px;display:flex}.search-box kbd{color:#9a8877;font-family:var(--sans);margin-left:auto;font-size:12px}.avatar{width:30px;height:30px;color:var(--primary-dark);background:var(--primary-soft);border-radius:999px;place-items:center;font-size:13px;font-weight:700;display:grid}.layout{align-items:start;max-width:1480px;min-height:calc(100vh - 58px);margin:0 auto;display:grid}.layout-page,.layout-article{grid-template-columns:260px minmax(0,1fr) 300px}.sidebar{border-right:1px solid var(--border);view-transition-name:shell-sidebar;background:#f5eee6bd;flex-direction:column;min-height:calc(100vh - 58px);padding:30px 26px 24px;display:flex;position:sticky;top:58px}.brand{align-items:center;gap:14px;margin-bottom:30px;display:flex}.brand-mark{background:repeating-conic-gradient(from 0deg, var(--primary) 0deg 8deg, transparent 8deg 18deg);border-radius:999px;flex:none;width:34px;height:34px;position:relative}.brand-mark:after{content:"";background:var(--sidebar);border-radius:999px;position:absolute;inset:12px}.brand-title,.brand-subtitle{display:block}.brand-title{font-family:var(--serif);letter-spacing:0;font-size:25px;font-weight:700;line-height:1.1}.brand-subtitle{color:var(--muted);margin-top:4px;font-size:13px;line-height:1.3}.nav-list,.recent-posts,.external-list{gap:7px;margin:0;padding:0;list-style:none;display:grid}.nav-link{min-height:38px;color:var(--text);border-radius:var(--radius);align-items:center;gap:11px;padding:8px 11px;font-size:14px;font-weight:650;display:flex}.nav-link:hover,.nav-link.is-active{color:var(--primary-dark);background:var(--primary-soft)}.sidebar-section{border-top:1px solid var(--border);margin-top:30px;padding-top:26px}.sidebar-label{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0 0 15px;font-size:12px;font-weight:800}.recent-posts{gap:12px}.recent-post{border-radius:var(--radius);gap:2px;padding:8px 8px 8px 20px;display:grid;position:relative}.recent-post:before{content:"";background:#cab9a8;border-radius:999px;width:6px;height:6px;position:absolute;top:16px;left:7px}.recent-post.is-current{background:#f1d8ca8c}.recent-post.is-current:before{background:var(--primary)}.recent-post a{font-size:12px;font-weight:650;line-height:1.45}.light-status{color:var(--muted);border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding-top:22px;font-size:13px;display:flex}.main{view-transition-name:page-main;min-width:0;padding:32px 42px 64px}.layout-article .main,.layout-page .main{border-right:1px solid #e4d4c3b8}.page-main{place-items:start center;min-height:calc(100vh - 58px);display:grid}.home-board,.posts-board{width:min(100%,860px);padding-top:58px}.home-workbench{text-align:center;margin:0 auto 34px}.eyebrow{color:var(--primary-dark);font-family:var(--mono);margin:0 0 10px;font-size:12px;font-weight:800}.home-workbench h1,.page-header h1{font-family:var(--serif);letter-spacing:0;margin:0;font-size:clamp(34px,6vw,58px);line-height:1.08}.home-workbench>p:not(.eyebrow),.page-header p{max-width:640px;color:var(--muted);margin:16px auto 0;font-size:16px}.composer{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:680px;box-shadow:var(--shadow-soft);text-align:left;margin:30px auto 0;padding:10px}.composer-input{min-height:92px;color:var(--muted);padding:18px 18px 8px;font-size:16px}.composer-actions{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:8px;display:flex}.composer-chip{min-height:32px;color:var(--text);background:var(--code-bg);border:1px solid var(--code-border);border-radius:999px;align-items:center;padding:6px 11px;font-size:13px;font-weight:700;display:inline-flex}.recommended,.posts-section{margin-top:38px}.section-title,.page-header h2{letter-spacing:0;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-size:13px;font-weight:800}.post-grid,.post-list{gap:14px;display:grid}.post-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.post-card{border:1px solid var(--border);border-radius:var(--radius);background:#fffaf3e6;transition:background .18s,border-color .18s,box-shadow .18s,transform .18s}.post-card-link{min-height:100%;padding:20px;display:grid}.post-card-kicker{color:var(--primary-dark);font-family:var(--mono);font-size:12px;font-weight:800}.post-card h2{font-family:var(--serif);letter-spacing:0;margin:10px 0;font-size:24px;line-height:1.2}.post-card p{color:var(--muted);margin:0;font-size:14px}.post-card-meta,.post-card-tags{flex-wrap:wrap;gap:8px 12px;display:flex}.post-card-meta{color:var(--muted);margin-top:18px;font-size:13px}.post-card-tags{margin-top:14px}.post-card-tags span{background:var(--primary-soft);border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700}.post-card:hover,.post-card:focus-within{background:#f7ecdf;border-color:#d6b79c;transform:translateY(-2px);box-shadow:inset 0 0 0 1px #d76f4a1f,0 10px 24px #2b211812}.page-header{text-align:left;margin-bottom:30px}.page-header p{margin-left:0}.breadcrumbs{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:22px;font-size:13px;display:flex}.breadcrumbs a{color:var(--text);font-weight:650}.article{max-width:780px;margin:0 auto}.article h1{font-family:var(--serif);letter-spacing:0;margin:0 0 14px;font-size:clamp(34px,4.2vw,54px);line-height:1.08}.lead{color:#3d3027;margin:0 0 18px;font-size:18px;line-height:1.76}.meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px 16px;margin:20px 0 28px;font-size:13px;display:flex}.meta span{align-items:center;gap:7px;display:inline-flex}.article p{margin:0 0 18px;font-size:16px}.article code,.inline-code{color:var(--primary-dark);background:var(--code-bg);border:1px solid var(--code-border);font-family:var(--mono);border-radius:5px;padding:.13em .35em;font-size:.88em}.article blockquote{color:var(--text);background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius);box-shadow:var(--shadow-soft);font-family:var(--serif);margin:26px 0 30px;padding:22px 24px;font-size:21px;line-height:1.55}.article blockquote p{font-size:inherit;margin:0}.article h2{font-family:var(--serif);letter-spacing:0;align-items:center;gap:10px;margin:42px 0 18px;padding-top:4px;font-size:28px;line-height:1.22;display:flex}.article h2:before{content:"›";color:var(--primary-dark);font-family:var(--mono);font-size:24px;line-height:1}.tool-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:20px 0 30px;display:grid}.tool-card,.panel-card,.prompt-card,.code-card,.note-card{border:1px solid var(--border);border-radius:var(--radius);background:#fffaf3e6}.tool-card{padding:17px 17px 16px}.tool-number{width:30px;height:30px;color:var(--primary-dark);background:var(--primary-soft);font-family:var(--mono);border-radius:999px;place-items:center;margin-bottom:12px;font-size:13px;font-weight:800;display:grid}.tool-card h3{margin:0 0 8px;font-size:17px;line-height:1.25}.tool-card p{color:var(--muted);margin:0;font-size:14px;line-height:1.62}.code-card,.prompt-card{margin:18px 0 24px;overflow:hidden}.card-header{border-bottom:1px solid var(--border);background:#f3e8dc8a;justify-content:space-between;align-items:center;gap:12px;min-height:48px;padding:11px 12px 10px 16px;display:flex}.card-title{min-width:0;margin:0;font-size:14px;font-weight:800;line-height:1.3}.copy-button{min-width:78px;min-height:32px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:700;display:inline-flex}.copy-button:hover,.copy-button.copied{color:var(--primary-dark);background:var(--primary-soft);border-color:#e0bba6}.copy-card-body{background:var(--code-panel)}.copy-card-body pre,.copy-card-body pre.astro-code{font-family:var(--mono);tab-size:2;white-space:pre;-webkit-overflow-scrolling:touch;margin:0;padding:18px 20px;font-size:13px;line-height:1.42;overflow-x:auto;color:var(--code-text)!important;background:var(--code-panel)!important}.copy-card-body code,.copy-card-body .line,.copy-card-body .line span{color:var(--code-text)!important;background:0 0!important}.prompt-card .copy-card-body pre{white-space:pre-wrap;overflow-wrap:anywhere}details{border:1px solid var(--border);border-radius:var(--radius);background:#fffaf3c2;margin:26px 0 34px;overflow:hidden}summary{cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:16px 18px;font-weight:800;list-style:none;display:flex}summary::-webkit-details-marker{display:none}summary:before{content:"›";color:var(--primary-dark);font-family:var(--mono);font-size:20px;transition:transform .16s}details[open] summary{border-bottom:1px solid var(--border)}details[open] summary:before{transform:rotate(90deg)}.details-body{transform-origin:top;will-change:height, opacity, transform;padding:2px 16px 16px}details[open]:not([data-animating=true]) .details-body{animation:.18s both details-slide-in}.details-body .prompt-card:last-child{margin-bottom:0}.note-card{color:var(--muted);background:#f3e8dc73;gap:12px;margin:22px 0 24px;padding:15px 16px;font-size:14px;display:flex}.note-card strong{color:var(--text);margin-bottom:2px;display:block}.aside{view-transition-name:page-aside;gap:14px;min-width:0;max-height:calc(100vh - 58px);padding:24px 24px 34px;display:grid;position:sticky;top:58px;overflow-y:auto}.panel-card{padding:18px}.section-heading{color:var(--text);letter-spacing:0;text-transform:uppercase;align-items:center;gap:10px;margin:0 0 14px;font-size:12px;font-weight:800;display:flex}.pill-cloud{flex-wrap:wrap;gap:10px;display:flex}.pill{min-height:30px;color:var(--text);background:#f1d8caa8;border:1px solid #e8d2bfad;border-radius:999px;align-items:center;padding:5px 13px;font-size:13px;font-weight:700;line-height:1.25;display:inline-flex}.resource-list{gap:14px;display:grid}.resource-item{border-top:1px solid var(--border);padding-top:12px}.resource-item:first-child{border-top:0;padding-top:0}.resource-item h3{margin:0 0 4px;font-size:15px;font-weight:800;line-height:1.35}.resource-item p{color:var(--muted);margin:0 0 12px;font-size:13px;line-height:1.5}.resource-button{color:#fffaf3;background:var(--primary);border:1px solid var(--primary);border-radius:var(--radius);justify-content:center;align-items:center;width:100%;min-height:36px;padding:8px 12px;font-size:13px;font-weight:800;display:inline-flex}.resource-button:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.resource-button.secondary{color:var(--primary-dark);background:var(--surface);border-color:var(--code-border)}.resource-button.secondary:hover{background:var(--primary-soft)}.external-list{gap:8px}.external-link{min-height:34px;color:var(--text);align-items:center;gap:10px;padding:5px 0;font-size:14px;font-weight:650;display:flex}.external-link .link-badge{width:24px;height:24px;color:var(--primary-dark);background:var(--primary-soft);border-radius:6px;flex:none;place-items:center;font-size:11px;font-weight:900;line-height:1;display:grid}.external-link svg{color:var(--muted);width:15px;height:15px;margin-left:auto}.external-link:hover{color:var(--primary-dark)}@media (width<=1180px){.layout-article,.layout-page{grid-template-columns:220px minmax(0,1fr)}.sidebar{padding-inline:18px}.brand{gap:10px}.brand-title{font-size:23px}.main{padding-inline:32px}.layout-article .main{border-right:0}.aside{grid-column:2;grid-template-columns:repeat(3,minmax(0,1fr));max-height:none;padding:0 32px 52px;position:static;overflow:visible}}@media (width<=920px){.topbar{height:54px;padding-inline:16px}.search-box{display:none}.layout-article,.layout-page{grid-template-columns:1fr;min-height:auto}.sidebar{border-right:0;border-bottom:1px solid var(--border);min-height:auto;padding:24px 20px 18px;position:static}.brand{margin-bottom:18px}.nav-list{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.nav-link{justify-content:center;min-height:36px;padding-inline:8px;font-size:13px}.nav-link svg{display:none}.sidebar-section{margin-top:20px;padding-top:18px}.recent-posts{grid-template-columns:repeat(2,minmax(0,1fr))}.light-status{margin-top:18px}.main{padding:28px 20px 36px}.home-board,.posts-board{padding-top:16px}.tool-grid,.post-grid{grid-template-columns:1fr}.aside{grid-column:auto;grid-template-columns:1fr;padding:0 20px 42px}}@media (width<=620px){.window-controls{min-width:auto}.topbar-actions{gap:6px}.brand-mark{width:30px;height:30px}.brand-mark:after{inset:11px}.brand-title{font-size:22px}.nav-list{grid-template-columns:repeat(2,minmax(0,1fr))}.nav-link{justify-content:flex-start}.recent-posts{grid-template-columns:1fr}.home-workbench h1,.page-header h1,.article h1{font-size:clamp(30px,10vw,40px)}.lead{font-size:16px}.article blockquote{padding:18px;font-size:18px}.article h2{font-size:24px}.card-header{flex-direction:column;align-items:flex-start}.copy-button{width:100%}.copy-card-body pre{white-space:pre-wrap;overflow-wrap:anywhere;padding:16px;font-size:12px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}::view-transition-old(root),::view-transition-new(root),::view-transition-old(page-main),::view-transition-new(page-main),::view-transition-old(page-aside),::view-transition-new(page-aside),::view-transition-old(shell-topbar),::view-transition-new(shell-topbar),::view-transition-old(shell-sidebar),::view-transition-new(shell-sidebar){animation:none!important}.post-card:hover,.post-card:focus-within{transform:none}}
