@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}::view-transition-old(root){animation:.15s ease-in fade-out}::view-transition-new(root){animation:.25s ease-out fade-in}:root{font-size:18px;--bg: #f7f7f5;--surface: #ffffff;--border: #e4e4df;--text: #1a1a1a;--text-muted: #6a6a6a;--accent: #16a34a;--accent-dim: #dcfce7;--nav-bg: rgba(255,255,255,.88);--tag-bg: #efefeb;--transition: .18s ease}[data-theme=dark]{--bg: #111111;--surface: #1a1a1a;--border: #2a2a2a;--text: #e6e6e6;--text-muted: #888;--accent: #4ade80;--accent-dim: #14532d;--nav-bg: rgba(20,20,20,.88);--tag-bg: #242424}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;transition:background var(--transition),color var(--transition)}a{color:inherit;text-decoration:none}nav{position:sticky;top:0;z-index:100;background:var(--nav-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;padding:0 1.75rem;height:54px;transition:background var(--transition)}.nav-links{display:flex;align-items:center;gap:.15rem}.nav-item{display:inline-flex;align-items:center;gap:0;height:36px;padding:0 10px;border-radius:8px;color:var(--text-muted);cursor:pointer;overflow:hidden;transition:color var(--transition),background var(--transition)}.nav-item i{font-size:.95rem;flex-shrink:0}.nav-label{font-size:.73rem;font-weight:600;white-space:nowrap;max-width:0;opacity:0;overflow:hidden;transition:max-width .4s cubic-bezier(.4,0,.2,1),opacity .3s ease .1s,margin-left .4s cubic-bezier(.4,0,.2,1);margin-left:0}.nav-item:hover,.nav-item.active{color:var(--accent);background:var(--tag-bg)}.nav-item:hover .nav-label{max-width:120px;opacity:1;margin-left:.45rem}.nav-left{position:absolute;left:1.75rem;display:flex;align-items:center}.nav-logo img{height:28px;width:auto;display:block;opacity:.9;transition:opacity var(--transition)}.nav-logo:hover img{opacity:1}.nav-right{position:absolute;right:1.75rem;display:flex;align-items:center}.theme-toggle{background:none;border:1px solid var(--border);border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:.85rem;transition:color var(--transition),background var(--transition),border-color var(--transition)}.theme-toggle:hover{color:var(--accent);background:var(--tag-bg);border-color:var(--accent)}.nav-hamburger{display:none;background:none;border:1px solid var(--border);border-radius:8px;width:34px;height:34px;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:.9rem;margin-left:.5rem;transition:color var(--transition),background var(--transition),border-color var(--transition)}.nav-hamburger:hover{color:var(--accent);background:var(--tag-bg);border-color:var(--accent)}.mobile-nav{display:flex;flex-direction:column;position:fixed;inset:54px 0 0;z-index:99;background:var(--bg);padding:1.25rem 1.5rem;gap:.35rem;overflow-y:auto;opacity:0;transform:translateY(-12px);pointer-events:none;transition:opacity .2s ease,transform .2s ease;visibility:hidden}.mobile-nav.open{opacity:1;transform:translateY(0);pointer-events:auto;visibility:visible}.mobile-nav-item{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;border-radius:10px;color:var(--text-muted);font-size:.95rem;font-weight:600;text-decoration:none;transition:color var(--transition),background var(--transition)}.mobile-nav-item i{font-size:1rem;width:1.1rem;text-align:center}.mobile-nav-item:hover,.mobile-nav-item.active{color:var(--accent);background:var(--tag-bg)}body.mobile-nav-open{overflow:hidden}@media (max-width: 640px){.nav-links{display:none}.nav-hamburger{display:flex}}main{max-width:1080px;margin:0 auto;padding:3.5rem 2.5rem 6rem}.intro{margin-bottom:1.75rem}.intro h1{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.45rem}.intro p{font-size:.95rem;color:var(--text-muted);line-height:1.75}.socials-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.25rem;margin-bottom:3rem}.socials-group{display:flex;flex-direction:column;gap:.4rem}.socials-group-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.socials{display:flex;flex-wrap:wrap;gap:.5rem}.socials-divider{width:1px;align-self:stretch;background:var(--border);display:inline-block;margin-top:1.5rem}@media (max-width: 640px){.socials-divider{display:none}}.social-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:.8rem;font-weight:500;color:var(--text-muted);transition:color var(--transition),border-color var(--transition),background var(--transition)}.social-pill:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.social-pill i{font-size:.8rem}.social-pill.active i{transition:color var(--transition)}.social-pill.active:hover i{color:inherit}.social-pill.brand-threads i{color:var(--text)}.social-pill.brand-mastodon i{color:#6364ff}.social-pill.brand-instagram i{color:#e1306c}.social-pill.brand-facebook i{color:#1877f2}.social-pill.brand-tiktok i{color:#ee1d52}.social-pill.inactive{opacity:.4}.social-pill.inactive:hover{opacity:1}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem}.post-list{display:flex;flex-direction:column}.post-card{display:block;padding:1.1rem 0;border-bottom:1px solid var(--border);cursor:pointer}.post-card:first-child{border-top:1px solid var(--border)}.post-card:hover .post-title{color:var(--accent)}.post-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.post-date{font-size:.73rem;color:var(--text-muted)}.post-tag{font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.1rem .45rem;border-radius:999px;background:var(--tag-bg);color:var(--text-muted)}.post-title{font-size:.97rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.28rem;transition:color var(--transition)}.post-excerpt{font-size:.855rem;color:var(--text-muted);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-read-more{display:inline-block;margin-top:.4rem;font-size:.75rem;font-weight:600;color:var(--accent);opacity:0;transform:translate(-4px);transition:opacity .15s ease,transform .15s ease}.post-card:hover .post-read-more{opacity:1;transform:translate(0)}.post-header{margin-bottom:2.5rem}.post-header h1{font-size:1.8rem;font-weight:700;letter-spacing:-.03em;line-height:1.25;margin-bottom:.75rem}.post-header .post-meta{margin-bottom:0}.post-body{font-size:1rem;line-height:1.75;color:var(--text);max-width:680px}.post-body h2{font-size:1.3rem;font-weight:700;margin:2rem 0 .75rem;letter-spacing:-.02em}.post-body h3{font-size:1.1rem;font-weight:600;margin:1.75rem 0 .6rem}.post-body p{margin-bottom:1.25rem}.post-body ul,.post-body ol{padding-left:1.5rem;margin-bottom:1.25rem}.post-body li{margin-bottom:.4rem}.post-body blockquote{border-left:3px solid var(--accent);padding-left:1rem;color:var(--text-muted);font-style:italic;margin:1.5rem 0}.post-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.post-body strong{font-weight:600}.post-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:2rem;transition:color var(--transition)}.post-back:hover{color:var(--accent)}.now-header{margin-bottom:2.5rem}.now-header h1{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.4rem}.now-updated{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:.4rem}.now-section{margin-bottom:2.5rem}.now-section-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.9rem;padding-bottom:.6rem;border-bottom:1px solid var(--border)}.now-item{display:flex;align-items:flex-start;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.now-item:last-child{border-bottom:none}.now-item-icon{width:34px;height:34px;border-radius:8px;background:var(--tag-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.82rem;color:var(--text-muted);margin-top:.1rem}.now-item-title-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.15rem}.now-item-title{font-size:.92rem;font-weight:600}.now-item-sub{font-size:.82rem;color:var(--text-muted);line-height:1.55}.now-item-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:.3rem}.now-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;color:var(--accent)}.now-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}.now-item-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:.05rem .5rem;text-decoration:none;transition:background var(--transition),color var(--transition)}.now-item-link:hover{background:var(--accent);color:#fff}.now-item-link i{font-size:.6rem}.watching-row{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:none}.watching-row::-webkit-scrollbar{display:none}.watching-card{display:flex;flex-direction:column;gap:.55rem;flex-shrink:0;width:140px}.watching-card-poster{width:140px;height:210px;border-radius:10px;overflow:hidden;background:var(--tag-bg);transition:transform .15s ease,box-shadow .15s ease}.watching-card:hover .watching-card-poster{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.watching-card-poster img{width:100%;height:100%;object-fit:cover;display:block}.watching-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--tag-bg);color:var(--text-muted);font-size:1.5rem}.watching-card-title{font-size:.8rem;font-weight:600;text-align:center;line-height:1.3}.watching-card-platform{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:-.25rem}.gear-header{margin-bottom:2.5rem}.gear-header h1{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.5rem}.gear-subtitle{font-size:.85rem;color:var(--text-muted);line-height:1.65}.gear-section-header{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:1.8rem 0 .65rem;border-bottom:1px solid var(--border)}.gear-section-header:first-of-type{padding-top:0}.gear-category{display:grid;grid-template-columns:120px 1fr;border-bottom:1px solid var(--border)}.gear-category-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:1.2rem 1.5rem 1.2rem 0;position:sticky;top:62px;align-self:start}.gear-items{display:flex;flex-direction:column;border-left:1px solid var(--border);padding-left:1.75rem}.gear-item{padding:1.1rem 0;border-bottom:1px solid var(--border)}.gear-item:last-child{border-bottom:none}.gear-item-name{font-size:.93rem;font-weight:600;margin-bottom:.18rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.gear-buy-link{font-size:.7rem;font-weight:600;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:.05rem .5rem;transition:background var(--transition),color var(--transition)}.gear-buy-link:hover{background:var(--accent);color:#fff}.gear-item-desc{font-size:.835rem;color:var(--text-muted);line-height:1.6;margin-bottom:.45rem}.gear-tags{display:flex;flex-wrap:wrap;gap:.3rem}.gear-tag{font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.15rem .5rem;border-radius:999px;background:var(--tag-bg);color:var(--text-muted)}.gear-wip-notice{font-size:.8rem;color:var(--text-muted);padding:.75rem 1rem;background:var(--tag-bg);border-radius:8px;display:flex;align-items:center;gap:.5rem;margin-top:1.5rem}footer{border-top:1px solid var(--border);padding:2rem 1.5rem;text-align:center;font-size:.75rem;color:var(--text-muted)}.archives-header{margin-bottom:2.5rem}.archives-header h1{font-size:2rem;font-weight:700;margin-bottom:.4rem}.archives-subtitle{color:var(--text-muted);font-size:.9rem}.archive-year-group{display:grid;grid-template-columns:64px 1fr;gap:0 2rem;margin-bottom:2.5rem}.archive-year-label{font-size:1rem;font-weight:700;color:var(--accent);padding-top:.2rem;text-align:right}.archive-year-posts{border-left:1px solid var(--border);padding-left:1.75rem;display:flex;flex-direction:column;gap:0}.archive-post-row{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.archive-post-row:last-child{border-bottom:none}.archive-post-title{color:var(--text);text-decoration:none;font-size:.9rem;line-height:1.4;transition:color var(--transition);flex:1}.archive-post-title:hover{color:var(--accent)}.archive-post-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.archive-section-badge{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.1rem .45rem;border-radius:999px}.archive-section-blog{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.archive-section-unplugged{background:color-mix(in srgb,#a855f7 12%,transparent);color:#a855f7}.archive-post-date{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.mattmakes3d-header{margin-bottom:2.5rem}.mattmakes3d-header h1{font-size:2rem;font-weight:700;margin-bottom:.4rem}.mattmakes3d-subtitle{color:var(--text-muted);font-size:.9rem}.coming-soon-block{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;border:1px dashed var(--border);border-radius:12px;color:var(--text-muted);text-align:center}.coming-soon-block .fa-cube{font-size:2.5rem;color:var(--accent)}.coming-soon-block p{font-size:.95rem;margin:0}.coming-soon-link{font-size:.85rem;font-weight:600;color:var(--accent);text-decoration:none;border:1px solid var(--accent);border-radius:999px;padding:.4rem 1rem;transition:background var(--transition),color var(--transition)}.coming-soon-link:hover{background:var(--accent);color:#fff}.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}
