:root{--c-bg: #fbfaf7;--c-surface: #ffffff;--c-ink: #1c1b18;--c-ink-soft: #4b483f;--c-ink-faint: #807b6e;--c-line: #e6e2d8;--c-line-strong: #d2cdbf;--c-accent: #b4531f;--c-accent-ink: #8c3f17;--c-accent-wash: #fbeee5;--c-focus: #1f6feb;--font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;--maxw: 64rem;--gap: 1.5rem;--radius: 10px;--shadow: 0 1px 2px rgba(28, 27, 24, .04), 0 6px 20px rgba(28, 27, 24, .05);--nav-h: 3.25rem}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 1rem)}body{margin:0;background:var(--c-bg);color:var(--c-ink);font-family:var(--font-sans);font-size:1.0625rem;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:1.25rem}a{color:var(--c-accent-ink)}:focus-visible{outline:2px solid var(--c-focus);outline-offset:2px;border-radius:4px}.site-header{border-bottom:1px solid var(--c-line);background:var(--c-surface)}.hero{padding-block:3rem 2.25rem}.hero h1{font-size:clamp(2rem,5vw,3rem);line-height:1.08;letter-spacing:-.02em;margin:0 0 .6rem}.hero .lede{font-size:1.2rem;color:var(--c-ink-soft);max-width:42ch;margin:0}.kicker{display:inline-block;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--c-accent-ink);background:var(--c-accent-wash);border:1px solid var(--c-line-strong);padding:.2rem .6rem;border-radius:999px;margin-bottom:1rem}.site-nav{position:sticky;top:0;z-index:20;background:#fbfaf7eb;backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--c-line)}.site-nav-inner{min-height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{font-weight:700;font-size:1.02rem;letter-spacing:-.01em;color:var(--c-ink);text-decoration:none;white-space:nowrap}.brand:hover{color:var(--c-accent-ink)}.nav-links{display:flex;align-items:center;gap:.15rem;overflow-x:auto;scrollbar-width:thin}.nav-links a{flex:0 0 auto;font-size:.9rem;font-weight:550;color:var(--c-ink-soft);text-decoration:none;padding:.4rem .65rem;border-radius:999px;white-space:nowrap}.nav-links a:hover{background:var(--c-accent-wash);color:var(--c-accent-ink)}.nav-storefront{color:var(--c-accent-ink);font-weight:650}.category{padding-block:2.5rem .5rem}.category-head{margin-bottom:1.25rem}.category-head h2{font-size:1.6rem;letter-spacing:-.01em;margin:0 0 .25rem;scroll-margin-top:calc(var(--nav-h) + 1rem)}.category-head p{margin:0;color:var(--c-ink-faint);max-width:60ch}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(20rem,1fr));gap:var(--gap)}.tool-card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.25rem 1.1rem;display:flex;flex-direction:column;gap:.6rem}.tool-card.is-featured{border-color:var(--c-line-strong);box-shadow:var(--shadow),inset 3px 0 0 var(--c-accent)}.tool-card .maker{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--c-ink-faint)}.tool-card h3{font-size:1.22rem;line-height:1.2;margin:0}.tool-card .summary{color:var(--c-ink-soft);margin:0;font-size:.98rem}.tool-card .review{color:var(--c-ink-soft);margin:0;font-size:.96rem}.tool-card .review :first-child{margin-top:0}.tool-card .review :last-child{margin-bottom:0}.tool-card .thumb{width:100%;aspect-ratio:4 / 3;object-fit:contain;border-radius:8px;border:1px solid var(--c-line);background:#fff;padding:.5rem}.tool-card .card-foot{margin-top:auto;padding-top:.4rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.featured-tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--c-accent-ink)}.btn-out{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.95rem;text-decoration:none;color:#fff;background:var(--c-accent);padding:.5rem .9rem;border-radius:8px;border:1px solid var(--c-accent-ink)}.btn-out:hover{background:var(--c-accent-ink)}.btn-out .arrow{transition:transform .12s ease}.btn-out:hover .arrow{transform:translate(2px)}.link-kind{font-size:.78rem;color:var(--c-ink-faint)}.tool-card h3 .tool-title{color:var(--c-ink);text-decoration:none}.tool-card h3 .tool-title:hover{color:var(--c-accent-ink)}.tool-card .thumb-link{display:block}.read-more{font-size:.82rem;font-weight:600;color:var(--c-accent-ink);text-decoration:none;white-space:nowrap}.read-more:hover{text-decoration:underline}.cta-row{display:flex;align-items:center;gap:.75rem}.family-card .family-title{color:var(--c-ink);text-decoration:none}.family-card .family-title:hover,.family-card .featured-tag{color:var(--c-accent-ink)}.btn-out .count{font-weight:500;opacity:.9}.backlink{display:inline-block;font-size:.9rem;font-weight:550;text-decoration:none;color:var(--c-ink-soft);margin-bottom:.9rem}.backlink:hover{color:var(--c-accent-ink)}.family-overview{padding-block:1.5rem .5rem}.family-hero{width:100%;max-height:22rem;object-fit:contain;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:1rem;margin-bottom:1.75rem}.prose{max-width:68ch;color:var(--c-ink);font-size:1.08rem}.prose p{margin:0 0 1.1rem}.prose :last-child{margin-bottom:0}.line-link{margin-top:1.25rem;font-weight:600}.edc-class-list{list-style:none;margin:0;padding:0;display:grid;gap:.85rem}.edc-class-list>li{border:1px solid var(--c-line);border-radius:var(--radius);padding:1rem 1.15rem;background:var(--c-surface);transition:border-color .15s ease}.edc-class-list>li:hover{border-color:var(--c-line-strong)}.edc-class-list a{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;font-weight:700;font-size:1.1rem;text-decoration:none;color:var(--c-ink)}.edc-class-list a:hover .edc-class-name{color:var(--c-accent-ink)}.edc-class-count{font-size:.78rem;font-weight:600;color:var(--c-ink-faint);background:var(--c-bg);border:1px solid var(--c-line);border-radius:999px;padding:.1rem .6rem}.edc-class-list p{margin:.35rem 0 0;color:var(--c-ink-faint);font-size:.92rem}.affiliate-note{font-size:.85rem;line-height:1.5;color:var(--c-ink-faint);border-top:1px solid var(--c-line);padding-top:.85rem;margin-block:1.25rem .5rem;max-width:72ch}.site-footer{border-top:1px solid var(--c-line);margin-top:3rem;padding-block:2rem 2.5rem;color:var(--c-ink-faint);font-size:.9rem}.site-footer a{color:var(--c-ink-soft)}.empty{border:1px dashed var(--c-line-strong);border-radius:var(--radius);padding:1.5rem;color:var(--c-ink-faint);text-align:center}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap}.nav-search{flex:0 0 auto;margin-left:.25rem}.nav-search input{width:11rem;max-width:40vw;font:inherit;font-size:.9rem;color:var(--c-ink);background:var(--c-surface);border:1px solid var(--c-line-strong);border-radius:999px;padding:.35rem .8rem}.nav-search input::placeholder{color:var(--c-ink-faint)}.nav-search input:focus-visible{border-color:var(--c-focus)}.index-filter{margin:.5rem 0}.index-filter input{width:100%;font:inherit;color:var(--c-ink);background:var(--c-surface);border:1px solid var(--c-line-strong);border-radius:10px;padding:.6rem .9rem;box-shadow:var(--shadow)}.index-filter input::placeholder{color:var(--c-ink-faint)}.search-page-form{display:flex;gap:.6rem;margin-top:1.25rem;max-width:42rem}.search-page-form input{flex:1 1 auto;font:inherit;font-size:1.05rem;color:var(--c-ink);background:var(--c-surface);border:1px solid var(--c-line-strong);border-radius:10px;padding:.65rem 1rem}.search-page-form input:focus-visible{border-color:var(--c-focus)}.search-page-form button{flex:0 0 auto;font:inherit;font-weight:600;color:#fff;background:var(--c-accent);border:1px solid var(--c-accent-ink);border-radius:10px;padding:.65rem 1.2rem;cursor:pointer}.search-page-form button:hover{background:var(--c-accent-ink)}.search-status{color:var(--c-ink-faint);font-size:.95rem;margin:1.75rem 0 1.25rem}.search-result .result-context{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--c-accent-ink)}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.btn-out .arrow{transition:none}}
