:root{--bark:#2d6b67;--bark-dark:#275a56;--bark-lite:#3a7f7b;--honey:#8b6914;--honey-lite:#c49a3c;--moss:#2d6b67;--moss-lite:#3a7f7b;--water:#4e7fa8;--parchment:#eaebed;--cream:#e6e8eb;--sand:#d0d3d7;--drift:#5a6168;--soil:#1a1a1a;--white:#fff;--bg-page:var(--parchment);--bg-surface:var(--white);--bg-surface-raised:#fff;--bg-hero:var(--bark-dark);--bg-footer:#081f28;--bg-hover:#2c18100d;--text-body:var(--soil);--text-heading:var(--bark-dark);--text-muted:var(--drift);--text-link:var(--moss);--text-inverse:var(--white);--text-on-hero:#f5f0e8;--border-subtle:var(--cream);--border-input:var(--sand);--border-strong:var(--drift);--accent-primary:var(--bark);--accent-primary-hover:var(--bark-dark);--accent-secondary:var(--moss);--accent-secondary-hover:var(--moss-lite);--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--font-serif:"Playfair Display", Georgia, serif;--font-sans:"Source Sans 3", system-ui, sans-serif;--max-width:1200px;--max-width-prose:640px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #2c181014;--shadow-md:0 4px 8px #2c18101f;--shadow-lg:0 8px 24px #2c18102e}[data-theme=dark]{--bg-page:#0d2a35;--bg-surface:#12384a;--bg-surface-raised:#164258;--bg-hero:#081f28;--bg-footer:#06181f;--bg-hover:#e8e4dd0d;--text-body:#e8e4dd;--text-heading:#f5f0e8;--text-muted:#9aa5ad;--text-link:#6ea882;--text-inverse:#0d2a35;--text-on-hero:#f5f0e8;--border-subtle:#1d4a5f;--border-input:#2a5d76;--border-strong:#3a7590;--accent-primary:#c49a3c;--accent-primary-hover:#d4ac52;--accent-secondary:#6ea882;--accent-secondary-hover:#82bd97;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 8px #0006;--shadow-lg:0 8px 24px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}html,body{overflow-x:hidden}body{font-family:var(--font-sans);background-color:var(--bg-page);color:var(--text-body);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6;transition:background-color .2s,color .2s}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--text-heading);line-height:1.2}h1{letter-spacing:-.01em;font-size:2.75rem;font-weight:700}h2{font-size:2rem;font-weight:600}h3{font-size:1.35rem;font-weight:600}p{margin-bottom:var(--space-md)}p:last-child{margin-bottom:0}a{color:var(--text-link);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-secondary-hover)}.container{max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}.section{padding:var(--space-4xl) var(--space-lg)}.section--prose{padding:var(--space-3xl) var(--space-lg)}.section-divider{border:none;border-top:1px solid var(--border-subtle);max-width:var(--max-width);margin:0 auto}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border:none;min-height:44px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--bark);color:var(--white)}.btn-primary:hover{background:var(--bark-dark);color:var(--white)}.btn-on-hero-primary{background:var(--white);color:var(--bark-dark)}.btn-on-hero-primary:hover{background:var(--cream);color:var(--bark-dark)}.btn-on-hero-secondary{color:var(--white);background:0 0;border:1.5px solid #fff9}.btn-on-hero-secondary:hover{border-color:var(--white);color:var(--white);background:#ffffff1a}.btn-lg{padding:.9rem 1.85rem;font-size:1.05rem}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;transition:background-color .2s,border-color .2s,box-shadow .2s,transform .2s;display:flex;overflow:hidden}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-link{color:inherit;flex-direction:column;height:100%;display:flex}.card-link:hover{color:inherit}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-secondary);border-radius:50%;width:32px;height:32px;margin:0 auto;animation:.7s linear infinite spin}.loading-row{padding:var(--space-2xl) 0;justify-content:center;display:flex}.empty-row{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-muted);font-style:italic}@media (width<=768px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}.section{padding:var(--space-3xl) var(--space-md)}.section--prose{padding:var(--space-2xl) var(--space-md)}}@media (width<=480px){:root{--space-lg:1rem;--space-xl:1.5rem;--space-2xl:2rem;--space-3xl:2.5rem;--space-4xl:3rem}h1{font-size:1.75rem}.container{padding:0 var(--space-md)}}.topnav{z-index:10;background:var(--bg-hero);align-items:center;height:64px;display:flex;position:sticky;top:0}.topnav-inner{width:100%;max-width:var(--max-width);padding:0 var(--space-xl);align-items:center;gap:var(--space-xl);margin:0 auto;display:flex}.topnav-links{align-items:center;gap:var(--space-xl);flex:1;display:flex}.topnav-link{color:var(--text-on-hero);font-family:var(--font-sans);letter-spacing:.01em;border-bottom:2px solid #0000;align-items:center;height:64px;font-size:.94rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s,opacity .15s;display:inline-flex}.topnav-link:hover{color:var(--text-on-hero);opacity:.78}.topnav-link--active{border-bottom-color:var(--text-on-hero)}.topnav-link--icon{margin-left:auto}.topnav-hamburger{color:var(--text-on-hero);padding:var(--space-sm);cursor:pointer;background:0 0;border:0;border-radius:4px;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .15s;display:none}.topnav-hamburger:hover{opacity:.78}@media (width<=768px){.topnav{height:56px}.topnav-inner{padding:0 var(--space-md);gap:var(--space-md)}.topnav-link--search{margin-left:auto}.topnav-hamburger{display:inline-flex}.topnav-links{background:var(--bg-hero);padding:var(--space-sm) 0;border-top:1px solid #ffffff14;flex-direction:column;align-items:stretch;gap:0;display:none;position:absolute;top:56px;left:0;right:0;box-shadow:0 8px 16px #0003}.topnav-links.is-open{display:flex}.topnav-links .topnav-link{height:auto;padding:var(--space-md) var(--space-lg);border-bottom:1px solid #ffffff0a;font-size:1rem}.topnav-links .topnav-link:last-child{border-bottom:0}.topnav-links .topnav-link--active{background:#ffffff0a;border-bottom-color:#ffffff0a}}.site-footer{background:var(--bg-footer);color:var(--text-on-hero);padding:var(--space-2xl) var(--space-lg);margin-top:var(--space-2xl)}.site-footer-inner{max-width:var(--max-width);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;margin:0 auto;display:flex}.site-footer-nav{gap:var(--space-lg);flex-wrap:wrap;display:flex}.site-footer-nav a{color:var(--text-on-hero);opacity:.85;font-size:.95rem;transition:opacity .2s}.site-footer-nav a:hover{opacity:1;color:var(--text-on-hero)}.site-footer-copy{color:var(--text-on-hero);opacity:.7;margin:0;font-size:.875rem}@media (width<=600px){.site-footer-inner{text-align:center;flex-direction:column;align-items:center}}.hero{background:var(--bg-hero);color:var(--text-on-hero);padding:var(--space-4xl) var(--space-lg);text-align:center}.hero-inner{align-items:center;gap:var(--space-lg);flex-direction:column;max-width:1000px;margin:0 auto;display:flex}.hero-logo{width:600px;max-width:90%;height:auto;margin-bottom:var(--space-md)}.hero-tagline{color:var(--text-on-hero);margin:0;font-size:2.75rem;line-height:1.15}.hero-subhead{color:var(--text-on-hero);opacity:.9;max-width:560px;margin:0;font-size:1.2rem}.hero-ctas{gap:var(--space-md);margin-top:var(--space-lg);flex-wrap:wrap;justify-content:center;display:flex}@media (width<=768px){.hero{padding:var(--space-3xl) var(--space-md)}.hero-logo{width:90%}.hero-tagline{font-size:2rem}.hero-subhead{font-size:1.05rem}}@media (width<=480px){.hero-tagline{font-size:1.6rem}.hero-subhead{font-size:1rem}.hero-ctas .btn{width:100%;max-width:280px}}.what-we-do-inner{max-width:var(--max-width-prose);text-align:center;margin:0 auto}.what-we-do-inner h2{margin-bottom:var(--space-lg)}.what-we-do-inner p{color:var(--text-body);font-size:1.1rem;line-height:1.7}@media (width<=480px){.what-we-do-inner p{font-size:1rem}}.thread-card{height:100%}.thread-card-body{padding:var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.thread-card-title{color:var(--text-heading);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.15rem;line-height:1.3;display:-webkit-box;overflow:hidden}.thread-card-excerpt{color:var(--text-body);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.95rem;line-height:1.55;display:-webkit-box;overflow:hidden}.thread-card-attribution{align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.thread-card-avatar{object-fit:cover;background:var(--sand);border-radius:50%;flex-shrink:0;width:32px;height:32px}.thread-card-avatar--initial{font-family:var(--font-serif);color:var(--white);background:var(--bark);text-transform:uppercase;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:inline-flex}.thread-card-attribution-text{flex-direction:column;min-width:0;font-size:.85rem;line-height:1.3;display:flex}.thread-card-author{color:var(--text-link);font-weight:600}.thread-card-node{color:var(--text-muted);font-size:.8rem}.thread-card-meta{color:var(--text-muted);padding-top:var(--space-xs);margin:auto 0 0;font-size:.85rem}.featured-header{text-align:center;margin-bottom:var(--space-2xl)}.featured-header h2{margin:0 0 var(--space-sm)}.featured-subhead{color:var(--text-muted);max-width:540px;margin:0 auto;font-size:1rem}.featured--flies{background:var(--bg-surface);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.threads-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.flies-grid{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.featured-link-row{text-align:right;margin-top:var(--space-xl);font-size:1rem}.featured-link-row a{font-weight:500}@media (width<=900px){.threads-grid,.flies-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=540px){.featured-link-row{text-align:center}}.featured-header--with-logo{justify-content:center;align-items:center;gap:var(--space-lg);text-align:left;display:flex}.featured-header--with-logo h2,.featured-header--with-logo .featured-subhead{margin-left:0;margin-right:0}.featured-header-logo{flex-shrink:0;width:120px;height:auto}@media (width<=540px){.featured-header--with-logo{text-align:center;gap:var(--space-md);flex-direction:column}.featured-header-logo{width:96px}}.featured-header-link{align-items:center;gap:var(--space-lg);color:inherit;text-decoration:none;transition:opacity .15s;display:flex}.featured-header-link:hover{opacity:.8}.featured-header--with-logo .featured-header-link{text-align:left;flex-direction:row}@media (width<=540px){.featured-header--with-logo .featured-header-link{text-align:center;gap:var(--space-md);flex-direction:column}}.featured-header--with-toggle{justify-content:space-between;align-items:center;gap:var(--space-lg);text-align:left;flex-wrap:wrap;display:flex}.featured-header--with-toggle h2{margin:0}.thread-toggle{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:2px;display:inline-flex}.thread-toggle-btn{font-family:var(--font-sans);color:var(--text-muted);border-radius:calc(var(--radius-md) - 2px);cursor:pointer;background:0 0;border:none;padding:.45rem 1rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.thread-toggle-btn:hover{color:var(--text-body)}.thread-toggle-btn.is-active{background:var(--accent-primary);color:var(--text-inverse)}@media (width<=600px){.featured-header--with-toggle{text-align:center;justify-content:center}}.fly-card{height:100%}.fly-card-photo{aspect-ratio:4/3;background:var(--bg-page);width:100%;position:relative;overflow:hidden}.fly-card-photo-backdrop{object-fit:cover;object-position:center;filter:blur(16px);opacity:.5;width:100%;height:100%;position:absolute;inset:0;transform:scale(1.1)}.fly-card-photo-fg{object-fit:contain;object-position:center;width:100%;height:100%;position:absolute;inset:0}.fly-card-body{padding:var(--space-md) var(--space-lg);gap:var(--space-xs);flex-direction:column;display:flex}.fly-card-name{color:var(--text-heading);margin:0;font-size:1.1rem}.fly-card-tyer{color:var(--text-muted);margin:0;font-size:.875rem}.fly-card-tyer span{color:var(--text-link);font-weight:600}.product-card{height:100%}.product-card-photo{aspect-ratio:1;background:var(--white);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}[data-theme=dark] .product-card-photo{background:var(--bg-surface-raised)}.product-card-photo-img{object-fit:contain;object-position:center;width:100%;height:100%;padding:var(--space-md)}.product-card-body{padding:var(--space-md) var(--space-lg) var(--space-lg);gap:var(--space-xs);flex-direction:column;display:flex}.product-card-name{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.05rem;overflow:hidden}.product-card-price{color:var(--text-link);margin:0;font-size:.95rem;font-weight:600}.products-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.products-grid{grid-template-columns:repeat(2,1fr)}}.search-page-inner{max-width:var(--max-width-prose);text-align:center;padding:var(--space-2xl) 0;margin:0 auto}.search-page-inner h1{margin-bottom:var(--space-lg)}.search-page-inner p{color:var(--text-muted);font-size:1.1rem}
