/* community.formscad.com — inherits FormsCAD brand, library-utilitarian.
   Tokens mirror the main site so it reads as a sibling. */
:root{
  --bg:#0d0d0d;--bg-2:#161616;--bg-3:#1d1d1d;
  --border:#ffffff10;--border-mid:#ffffff1a;
  --text:#f0f0f4;--text-mid:#c0c0cc;--text-dim:#7a7a85;
  --accent:#8B5CF6;--accent-border:#8B5CF645;--accent-dim:#8B5CF618;
  --sans:'Inter',system-ui,sans-serif;--mono:'DM Mono',monospace;--display:'Bebas Neue',sans-serif;
  --c-symbols:#8B5CF6;--c-title-blocks:#3b82f6;--c-linetypes:#22c55e;
  --c-templates:#f59e0b;--c-hatch-patterns:#ec4899;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.accent{color:var(--accent)}
main{min-height:60vh}

.btn{display:inline-block;font:600 13px/1 var(--sans);padding:11px 18px;border-radius:4px;border:1px solid transparent;transition:all 150ms ease;cursor:pointer}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#7c4ddc}
.btn-ghost{background:transparent;color:var(--text-mid);border-color:var(--border-mid)}
.btn-ghost:hover{color:var(--text);border-color:var(--accent-border)}
.btn-lg{padding:14px 22px;font-size:14px}
[aria-disabled=true]{opacity:.45;pointer-events:none}

/* nav (mirrors main site) */
.nav{position:sticky;top:0;z-index:200;background:var(--bg);border-bottom:1px solid var(--border)}
.nav-brand{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:10px}
.wordmark{font-family:var(--display);font-size:22px;letter-spacing:2px}
.nav-actions{display:flex;gap:10px;align-items:center}
.nav-tabs{height:44px;display:flex;align-items:stretch;padding:0 24px;gap:4px}
.nav-tab{display:flex;align-items:center}
.nav-tab>a{display:flex;align-items:center;height:100%;padding:0 14px;font-size:13px;color:var(--text-mid);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid transparent}
.nav-tab>a:hover,.nav-tab>a.nav-current{color:var(--text);border-bottom-color:var(--accent)}

/* community sub-nav */
.subnav{display:flex;gap:22px;align-items:center;padding:12px 24px;background:var(--bg-2);border-bottom:1px solid var(--border);font:500 12px var(--mono);text-transform:uppercase;letter-spacing:.06em}
.subnav a{color:var(--text-mid)}
.subnav a:hover{color:var(--accent)}
.subnav-soon{color:var(--text-dim)}

/* hero / headings */
.comm-hero,.section-head{max-width:1200px;margin:0 auto;padding:64px 24px 32px}
.headline{font-family:var(--display);font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:1px}
.hero-body{font-size:16px;color:var(--text-mid);line-height:1.8;max-width:560px;margin-top:18px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.big-title{font-family:var(--display);font-size:40px;letter-spacing:2px}
.sub-h{font-family:var(--display);font-size:24px;letter-spacing:1px;margin:28px 0 12px;color:var(--text)}
.prose{color:var(--text-mid);line-height:1.8;max-width:680px;margin-bottom:14px}

/* filter bar */
.filter-bar{max-width:1200px;margin:0 auto;padding:8px 24px 28px;display:flex;gap:8px;flex-wrap:wrap}
.filter{background:var(--bg-2);border:1px solid var(--border-mid);color:var(--text-mid);font:500 12px var(--mono);letter-spacing:.06em;padding:9px 16px;border-radius:4px;cursor:pointer;transition:all 150ms ease}
.filter:hover{color:var(--text)}
.filter.is-active{background:var(--accent);border-color:var(--accent);color:#fff}

/* pack grid */
.pack-grid{max-width:1200px;margin:0 auto;padding:0 24px 80px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pack-card{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:border-color 150ms ease}
.pack-card:hover{border-color:var(--accent-border)}
.pack-thumb{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:var(--bg-3);border-bottom:1px solid var(--border)}
.pack-thumb span{font:600 13px var(--mono);letter-spacing:.1em;text-transform:uppercase;opacity:.5}
.pack-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.pack-cat{display:inline-block;align-self:flex-start;font:600 10px var(--mono);text-transform:uppercase;letter-spacing:.08em;padding:4px 8px;border-radius:3px;background:var(--accent-dim);color:var(--accent)}
.pack-name{font-size:17px;font-weight:600}
.pack-desc{font-size:13px;color:var(--text-dim);line-height:1.6;flex:1}
.pack-meta{display:flex;gap:8px;font:500 11px var(--mono);color:var(--text-mid)}
.pack-meta span{background:var(--bg-3);padding:4px 8px;border-radius:3px}
.pack-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:14px;margin-top:6px}
.pack-author{font-size:12px;color:var(--text-dim)}
.pack-dl{font:600 12px var(--sans);color:var(--accent)}

/* category accent colors */
.cat-symbols{--c:var(--c-symbols)} .cat-title-blocks{--c:var(--c-title-blocks)}
.cat-linetypes{--c:var(--c-linetypes)} .cat-templates{--c:var(--c-templates)}
.cat-hatch-patterns{--c:var(--c-hatch-patterns)}
.pack-cat{background:color-mix(in srgb,var(--c,#8B5CF6) 14%,transparent);color:var(--c,#8B5CF6)}
.pack-thumb span{color:var(--c,#8B5CF6);opacity:.6}

/* pack detail */
.crumb{max-width:1100px;margin:0 auto;padding:24px 24px 0;font:500 12px var(--mono);color:var(--text-dim)}
.crumb a:hover{color:var(--accent)}
.pack-detail{max-width:1100px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start}
.pack-detail-preview{aspect-ratio:4/3;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center}
.pack-detail-preview span{font:600 14px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--c,#8B5CF6);opacity:.6}
.pack-detail-meta{font:500 13px var(--mono);color:var(--text-dim);margin:6px 0 16px}
.incl-list,.install-list{margin:0 0 8px 20px;color:var(--text-mid);line-height:1.9}
.code,pre.code{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;padding:18px;font:13px/1.6 var(--mono);color:var(--text-mid);overflow-x:auto;white-space:pre;margin:8px 0 14px}
code{background:var(--bg-2);padding:2px 6px;border-radius:3px;font:13px var(--mono)}
.spec-note{font-size:13px;color:var(--text-dim);margin-top:18px}
.spec-note a:hover{color:var(--accent)}
.spec-body{max-width:780px;margin:0 auto;padding:0 24px 80px}

.notify{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.notify input{background:var(--bg-2);border:1px solid var(--border-mid);color:var(--text);font:15px var(--sans);padding:13px 16px;border-radius:4px;min-width:260px}
.notify input:focus{outline:none;border-color:var(--accent-border)}

/* footer (mirrors main) */
.footer{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;border-top:1px solid var(--border);padding:40px 24px}
.foot-brand{font-family:var(--display);font-size:18px;letter-spacing:2px;color:var(--text-dim)}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-links a{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}
.foot-links a:hover{color:var(--text-mid)}
.foot-tag{font:10px var(--mono);color:var(--text-dim)}

@media (max-width:900px){.pack-grid{grid-template-columns:repeat(2,1fr)}.pack-detail{grid-template-columns:1fr}}
@media (max-width:640px){.pack-grid{grid-template-columns:1fr}.nav-tabs{overflow-x:auto}}
