/* Brands page — light, airy, hairline rows (matches preview-v5/brands-partners.html).
   Reuses app.css for .container/.brow/.brows/.bcat/.bmain/.blogo/.cat-idx/.cta-band/.cta-inner/.eyebrow2;
   this file adds the classes app.css doesn't define. */

.bp-hero { padding: clamp(3rem, 7vw, 5.8rem) 0 clamp(1.6rem, 3vw, 2.4rem) }
.bp-hero h1 { font-size: clamp(2.5rem, 6.2vw, 5rem); letter-spacing: -.03em; line-height: 1; color: var(--on-light); margin: 1rem 0 0; max-width: 14ch; font-weight: 500 }
.bp-hero .lead { max-width: 62ch; margin-top: 1.3rem; color: var(--on-light-dim); font-size: clamp(1.04rem, 1.4vw, 1.2rem); line-height: 1.6 }
.bp-stats { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 2.1rem }
.lchip { font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .03em; color: var(--on-light-dim); border: 1px solid var(--line-light); border-radius: var(--r-pill); padding: .5em .9em }

/* flagship MOXA band */
.flag { border-top: 1px solid var(--on-light); padding-top: clamp(1.8rem, 3vw, 2.6rem); margin-top: clamp(2rem, 4vw, 3rem); display: grid; grid-template-columns: 1.35fr .9fr; gap: clamp(1.8rem, 4vw, 4.5rem); align-items: center }
.flag .frank { font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--brand) }
.flag h2 { font-size: clamp(2.2rem, 4.4vw, 3.2rem); letter-spacing: -.03em; color: var(--on-light); margin: .45rem 0 0; line-height: .98; font-weight: 500 }
.flag p { color: var(--on-light-dim); max-width: 52ch; line-height: 1.6; margin-top: .8rem }
.flag .fchips { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.1rem 0 .2rem }
.flag .frow { display: flex; gap: .9rem; align-items: center; flex-wrap: wrap; margin-top: 1.1rem }
.flag .flogo { aspect-ratio: 16/9; background: #f7f7f5; border: 1px solid var(--line-light); border-radius: var(--r-marketing); display: grid; place-items: center; padding: 2rem }
.flag .flogo img { max-height: 66px; max-width: 74%; object-fit: contain }
.btag { display: inline-block; font-family: var(--mono); font-size: .62rem; text-transform: uppercase; letter-spacing: .04em; color: var(--brand); background: var(--brand-soft); border: 1px solid rgba(255, 86, 10, .32); border-radius: var(--r-pill); padding: .34em .7em }

/* category sections */
.lsec { padding: clamp(2.6rem, 5vw, 4.4rem) 0 }
.lsec + .lsec { padding-top: 0 }
.cat-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.4rem; flex-wrap: wrap }
.cat-head h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); letter-spacing: -.03em; color: var(--on-light); max-width: 18ch; font-weight: 500; line-height: 1.05 }
.cat-count { font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--on-light-mute); white-space: nowrap }
.cat-sub { color: var(--on-light-dim); max-width: 54ch; margin-top: .7rem; line-height: 1.6 }

/* brand-row description + authorized tag */
.brow .brole { color: var(--on-light-dim); font-size: .9rem; line-height: 1.5; margin-top: .65rem; max-width: 46ch }
.brow .rtag { display: inline-block; margin-top: .75rem; font-family: var(--mono); font-size: .6rem; text-transform: uppercase; letter-spacing: .04em; color: var(--brand); border: 1px solid rgba(255, 86, 10, .35); border-radius: var(--r-pill); padding: .28em .62em }

@media (max-width: 760px) { .flag { grid-template-columns: 1fr } .flag .flogo { order: -1 } }
