/* ============================================================
   Builder hub page (M3M) — extends styles.css + project.css
   Reuses: trust-grid, project-grid, tile-split, sector-grid,
   inv-table, faq, stat-bar, lead, breadcrumb.
   ============================================================ */

/* ---------- builder hero (teal band) ---------- */
.builder-hero { position: relative; overflow: hidden; background: var(--c-primary); color: #fff; padding: clamp(30px, 5vw, 52px) 0 clamp(34px, 5vw, 54px); }
.builder-hero .bh-motif { position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image: linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 44px 44px; mask-image: radial-gradient(90% 120% at 100% 0%, #000, transparent 70%); -webkit-mask-image: radial-gradient(90% 120% at 100% 0%, #000, transparent 70%); }
.bh-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr; gap: 24px; align-items: center; }

.bh-headline { display: flex; flex-direction: column; gap: 14px; }
.bh-brandrow { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.bh-logo { width: 64px; height: 64px; flex: none; border-radius: 14px; background: #fff; display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; font-size: 32px; color: var(--c-primary); }
.bh-brandmeta .bm-name { font-family: var(--font-head); font-weight: 600; font-size: 19px; }
.bh-brandmeta .bm-tags { display: flex; gap: 8px; margin-top: 6px; flex-wrap: wrap; }
.bh-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 600; padding: 4px 10px; border-radius: 100px; background: rgba(255,255,255,.12); color: #fff; white-space: nowrap; }
.bh-tag.verify { background: rgba(255,255,255,.95); color: var(--verify); }
.bh-tag.verify svg { width: 13px; height: 13px; }
.builder-hero h1 { font-size: clamp(30px, 6vw, 52px); letter-spacing: -.02em; max-width: 16ch; }
.builder-hero h1 em { font-style: italic; color: #f2d9c9; }
.bh-sub { font-size: clamp(15px, 2.2vw, 18px); color: rgba(255,255,255,.82); max-width: 56ch; line-height: 1.6; }
.bh-cta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }

/* hero stats on teal */
.bh-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius); overflow: hidden; }
.bh-stats .st { background: var(--c-primary); padding: 16px 18px; }
.bh-stats .st .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.6); }
.bh-stats .st .v { font-family: var(--font-head); font-weight: 600; font-size: 21px; margin-top: 4px; color: #fff; }
.bh-stats .st .v small { font-family: var(--font-body); font-size: 12.5px; font-weight: 500; color: rgba(255,255,255,.6); }
@media (min-width: 560px) { .bh-stats { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 940px) { .bh-inner { grid-template-columns: 1.2fr 1fr; gap: 48px; } .bh-stats { grid-template-columns: repeat(2, 1fr); } }

/* ---------- intro prose lead ---------- */
.builder-intro { padding: clamp(40px,6vw,60px) 0 0; }
.builder-intro .prose { max-width: 70ch; }
.builder-intro .prose p { font-size: 16.5px; }

/* ---------- price guide note ---------- */
.guide-note { font-size: 12.5px; color: var(--ink-3); margin-top: 12px; }

/* ---------- related searches (compact, discoverability) ---------- */
.related-searches { padding: clamp(40px,6vw,60px) 0; background: var(--surface-2); }
.related-searches .rs-cols { display: grid; grid-template-columns: 1fr; gap: 26px; margin-top: 22px; }
.rs-group h4 { font-size: 13px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--ink); margin-bottom: 12px; }
.rs-links { display: flex; flex-wrap: wrap; gap: 8px; }
.rs-links a { font-size: 13.5px; color: var(--ink-2); background: var(--surface); border: 1px solid var(--line); padding: 7px 13px; border-radius: 100px; transition: border-color .15s, color .15s; }
.rs-links a:hover { border-color: var(--c-primary-300); color: var(--c-primary); }
@media (min-width: 720px) { .related-searches .rs-cols { grid-template-columns: repeat(3, 1fr); } }

/* ---------- presence sector cards: reuse .sector-grid / .sector-card ---------- */
/* ---------- price table: reuse .inv-table + .table-scroll from project.css ---------- */
