/**
 * Brand vertical — layout styles (archive + single).
 *
 * Ported from ex-snippets 348 (archive) and 352 (single). The reveal + parallax
 * baseline are shared (editorial.css); this file holds brand-specific layout
 * only. Colors come from tokens.css and the snippets' Elementor-era !important
 * is dropped. The parallax scale(1.18) start state is owned by .js-parallax, so
 * .brs-hero-bg no longer sets its own transform/overscan. The single's ③ BANNER
 * section is omitted (it never rendered upstream), so its .brs-banner* rules are
 * gone; the CTA's no-image fallback is the .brs-cta-bg-overlay.solid modifier.
 */

/* ════════════════════════════════════════
   ARCHIVE BRAND (snippet 348)
   Front/back image hover swap; featured image doubles as the on-card logo.
   The snippet's inline Google-Fonts <link> and .ba-rv/.ba-serif/.ba-sans
   helpers are dropped (tokens.css + fonts.css + shared .rv own those).
   ════════════════════════════════════════ */

/* ══ WRAP + HEADER ══ */
.ba-wrap { background: var(--cream); }
.ba-head { padding: 80px 56px 64px; border-bottom: 1px solid rgba(14, 14, 12, .08); display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; font-family: var(--sans); }
.ba-eyebrow { font-size: 9px; letter-spacing: 4px; text-transform: uppercase; color: rgba(14, 14, 12, .35); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; font-family: var(--sans); }
.ba-eyebrow::before { content: ""; width: 20px; height: 1px; background: rgba(14, 14, 12, .25); }
.ba-title { font-family: var(--serif); font-size: clamp(40px, 6vw, 76px); font-weight: 700; color: var(--black); letter-spacing: -2px; line-height: .95; text-transform: none; }
.ba-count { font-family: var(--serif); font-size: 80px; font-weight: 300; color: rgba(14, 14, 12, .08); line-height: 1; letter-spacing: -3px; white-space: nowrap; }

/* ══ GRID + CARD ══ */
.ba-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; padding: 40px 56px 80px; }
.ba-card { position: relative; overflow: hidden; aspect-ratio: 3/4; background: #1a1a18; cursor: pointer; text-decoration: none; display: block; }
.ba-photo, .ba-hover-img { position: absolute; inset: 0; background-size: cover; background-position: center; }
.ba-photo { transition: transform 1.1s cubic-bezier(.22, 1, .36, 1), opacity .6s ease; }
.ba-hover-img { opacity: 0; transform: scale(1.06); transition: opacity .7s ease, transform 1.1s cubic-bezier(.22, 1, .36, 1); }
.ba-card:hover .ba-hover-img { opacity: 1; transform: scale(1); }
.ba-card:hover .ba-photo { opacity: 0; transform: scale(1.06); }
.ba-overlay { position: absolute; inset: 0; z-index: 1; background: rgba(14, 14, 12, .38); transition: background .6s; }
.ba-card:hover .ba-overlay { background: rgba(14, 14, 12, .60); }
.ba-tag { position: absolute; top: 18px; left: 18px; z-index: 2; font-size: 8.5px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255, 255, 255, .45); display: flex; align-items: center; gap: 6px; font-family: var(--sans); }
.ba-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--yellow); flex-shrink: 0; }
.ba-logo { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 2; text-align: center; transition: transform .6s cubic-bezier(.22, 1, .36, 1), opacity .5s; width: 80%; }
.ba-card:hover .ba-logo { transform: translate(-50%, -68%); opacity: .7; }
.ba-logo-img { max-width: clamp(90px, 14vw, 160px); max-height: clamp(45px, 7vw, 80px); width: auto; height: auto; object-fit: contain; display: block; margin: 0 auto; filter: drop-shadow(0 2px 20px rgba(0, 0, 0, .5)); -webkit-user-drag: none; user-drag: none; }
.ba-logo-name { font-family: var(--serif); font-size: clamp(28px, 3.8vw, 48px); font-weight: 700; color: #fff; line-height: 1; letter-spacing: .5px; text-shadow: 0 2px 20px rgba(0, 0, 0, .4); }
.ba-logo-origin { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255, 255, 255, .45); margin-top: 12px; display: block; font-family: var(--sans); }
.ba-panel { position: absolute; bottom: 0; left: 0; right: 0; z-index: 3; padding: 24px 24px 28px; background: linear-gradient(to top, rgba(10, 10, 8, .95) 0%, rgba(10, 10, 8, .6) 70%, transparent 100%); transform: translateY(100%); transition: transform .65s cubic-bezier(.22, 1, .36, 1); }
.ba-card:hover .ba-panel { transform: translateY(0); }
.ba-desc { font-family: var(--sans); font-size: 13px; color: #fff; line-height: 1.65; margin-bottom: 18px; font-weight: 300; text-shadow: 0 1px 8px rgba(0, 0, 0, .7); }
.ba-panel .ba-desc, .ba-panel .ba-desc p, .ba-panel p { color: #fff; }
.ba-desc p { margin: 0 0 .5em; }
.ba-desc p:last-child { margin-bottom: 0; }
.ba-cta { display: inline-flex; align-items: center; gap: 10px; font-size: 9.5px; letter-spacing: 2.5px; text-transform: uppercase; color: #fff; border-bottom: 1px solid rgba(255, 255, 255, .25); padding-bottom: 3px; text-decoration: none; transition: gap .25s, border-color .25s, color .25s; font-family: var(--sans); }
.ba-cta:hover { gap: 16px; border-color: var(--yellow); color: var(--yellow); }
.ba-cta svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.ba-card::after { content: ""; position: absolute; bottom: 0; left: 0; z-index: 4; width: 0; height: 2px; background: var(--yellow); transition: width .7s cubic-bezier(.22, 1, .36, 1); }
.ba-card:hover::after { width: 100%; }
.ba-noresults { padding: 80px 56px; text-align: center; font-size: 14px; color: rgba(14, 14, 12, .4); font-family: var(--sans); }

/* ══ RESPONSIVE (archive) ══ */
@media (max-width: 1100px) {
    .ba-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
    .ba-head { padding: 60px 24px 48px; flex-direction: column; }
    .ba-grid { grid-template-columns: 1fr; padding: 24px 24px 60px; gap: 16px; }
    .ba-logo-img { max-width: clamp(60px, 20vw, 100px); max-height: clamp(30px, 9vw, 55px); }
}

/* ════════════════════════════════════════
   SINGLE BRAND (snippet 352)
   The snippet's :root token block + .brs-wrap *{box-sizing} reset are dropped
   (tokens.css + style.css own those); .brs-rv/.brs-d* map to the shared .rv/.d*.
   ════════════════════════════════════════ */

.brs-wrap { background: var(--cream); overflow-x: hidden; }

/* ══ ① HERO ══ */
.brs-hero { position: relative; height: calc(100vh - var(--header-h)); min-height: 520px; background: var(--black); overflow: hidden; display: flex; align-items: flex-end; }
.brs-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.brs-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(14, 14, 12, .85) 0%, rgba(14, 14, 12, .2) 60%), linear-gradient(to top, rgba(14, 14, 12, .9) 0%, transparent 55%); }
.brs-hero-logo { position: absolute; top: 48px; right: 56px; z-index: 10; font-family: var(--serif); font-size: 28px; font-weight: 700; color: rgba(255, 255, 255, .85); letter-spacing: 2px; }
.brs-hero-content { position: relative; z-index: 5; padding: 0 56px 72px; display: grid; grid-template-columns: 1fr auto; align-items: flex-end; gap: 48px; width: 100%; }
.brs-hero-name { font-family: var(--serif); font-size: clamp(48px, 8vw, 108px); font-weight: 700; color: #fff; line-height: .92; letter-spacing: -3px; margin-bottom: 12px; text-transform: none; }
.brs-hero-sub { font-family: var(--sans); font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255, 255, 255, .35); display: flex; align-items: center; gap: 8px; }
.brs-hero-sub::before { content: ""; width: 20px; height: 1px; background: var(--yellow); }
.brs-hero-year { text-align: right; padding-bottom: 8px; }
.brs-hero-year-n { font-family: var(--serif); font-size: 80px; font-weight: 300; color: rgba(255, 255, 255, .12); line-height: 1; letter-spacing: -2px; display: block; }
.brs-hero-year-l { font-family: var(--sans); font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255, 255, 255, .3); }
.brs-hero-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: rgba(255, 255, 255, .07); z-index: 10; }
.brs-hero-bar-fill { height: 100%; background: var(--yellow); width: 30%; }

/* ══ ② INTRO ══ */
.brs-intro { display: grid; grid-template-columns: 5fr 7fr; min-height: 560px; }
.brs-intro-left { padding: 100px 56px; background: var(--black); display: flex; flex-direction: column; justify-content: space-between; }
.brs-intro-kicker { font-family: var(--sans); font-size: 9px; letter-spacing: 3.5px; text-transform: uppercase; color: rgba(255, 255, 255, .3); margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.brs-intro-kicker::before { content: ""; width: 16px; height: 1px; background: var(--yellow); }
.brs-for-what { display: inline-flex; align-items: center; gap: 6px; background: rgba(242, 236, 26, .1); border: 1px solid rgba(242, 236, 26, .2); padding: 5px 12px; margin-bottom: 24px; width: fit-content; }
.brs-for-what span { font-family: var(--sans); font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--yellow); }
.brs-intro-quote { font-family: var(--serif); font-size: clamp(22px, 2.8vw, 38px); font-weight: 300; color: #fff; line-height: 1.3; flex: 1; display: flex; align-items: center; }
.brs-intro-meta { display: flex; flex-direction: column; gap: 14px; padding-top: 40px; border-top: 1px solid rgba(255, 255, 255, .06); }
.brs-intro-meta-row { display: flex; justify-content: space-between; align-items: baseline; }
.brs-intro-meta-label { font-family: var(--sans); font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255, 255, 255, .3); }
.brs-intro-meta-value { font-family: var(--sans); font-size: 11px; color: rgba(255, 255, 255, .7); font-weight: 300; }
.brs-intro-right { padding: 100px 64px; background: var(--cream); display: flex; flex-direction: column; justify-content: center; }
.brs-intro-body { font-family: var(--sans); font-size: clamp(15px, 1.5vw, 18px); font-weight: 300; line-height: 1.9; color: rgba(14, 14, 12, .7); margin-bottom: 32px; }
.brs-intro-body strong { color: var(--black); font-weight: 500; }
.brs-stats { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(14, 14, 12, .08); padding-top: 40px; margin-top: 16px; }
.brs-stat { padding-right: 24px; border-right: 1px solid rgba(14, 14, 12, .08); }
.brs-stat:last-child { border-right: none; padding-right: 0; padding-left: 24px; }
.brs-stat:nth-child(2) { padding: 0 24px; }
.brs-stat-n { font-family: var(--serif); font-size: 44px; font-weight: 300; color: var(--black); line-height: 1; display: block; }
.brs-stat-l { font-family: var(--sans); font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(14, 14, 12, .35); margin-top: 6px; display: block; }

/* ══ ③ WHY ══ */
.brs-why { background: #fff; padding: 120px 56px; position: relative; }
.brs-why::before { content: ""; position: absolute; top: 0; left: 56px; right: 56px; height: 1px; background: rgba(14, 14, 12, .08); }
.brs-why-head { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; margin-bottom: 80px; }
.brs-why-kicker { font-family: var(--sans); font-size: 9px; letter-spacing: 3.5px; text-transform: uppercase; color: rgba(14, 14, 12, .35); margin-bottom: 20px; display: flex; align-items: center; gap: 10px; }
.brs-why-kicker::before { content: ""; width: 16px; height: 1px; background: var(--yellow); }
.brs-why-title { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 48px); font-weight: 700; color: var(--black); letter-spacing: -.8px; line-height: 1.05; text-transform: none; }
.brs-why-intro { font-family: var(--sans); font-size: 17px; font-weight: 300; line-height: 1.85; color: rgba(14, 14, 12, .65); padding-top: 60px; }
.brs-why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(14, 14, 12, .08); border: 1px solid rgba(14, 14, 12, .08); }
.brs-why-item { background: var(--cream); padding: 44px 32px; }
.brs-why-num { font-family: var(--serif); font-size: 48px; font-weight: 300; color: rgba(14, 14, 12, .08); line-height: 1; display: block; margin-bottom: 20px; transition: color .3s; }
.brs-why-item:hover .brs-why-num { color: var(--yellow); }
.brs-why-item-title { font-family: var(--sans); font-size: 14px; font-weight: 600; color: var(--black); margin-bottom: 12px; }
.brs-why-item-text { font-family: var(--sans); font-size: 13.5px; font-weight: 300; line-height: 1.75; color: rgba(14, 14, 12, .55); }

/* ══ ④ CTA ══ */
.brs-cta { position: relative; overflow: hidden; padding: 140px 56px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 60px; }
.brs-cta-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.brs-cta-bg-overlay { position: absolute; inset: 0; background: rgba(14, 14, 12, .78); }
.brs-cta-bg-overlay.solid { background: var(--black); }
.brs-cta-text { position: relative; z-index: 1; }
.brs-cta-eyebrow { font-family: var(--sans); font-size: 9px; letter-spacing: 3.5px; text-transform: uppercase; color: rgba(255, 255, 255, .4); margin-bottom: 20px; display: flex; align-items: center; gap: 10px; }
.brs-cta-eyebrow::before { content: ""; width: 16px; height: 1px; background: var(--yellow); }
.brs-cta-title { font-family: var(--serif); font-size: clamp(28px, 4vw, 60px); font-weight: 700; color: #fff; letter-spacing: -1px; line-height: 1.05; text-transform: none; }
.brs-cta-title em { font-style: normal; color: var(--yellow); }
.brs-cta-btn { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 14px; background: var(--yellow); color: var(--black); padding: 18px 40px; white-space: nowrap; font-family: var(--sans); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; font-weight: 600; text-decoration: none; transition: background .2s, gap .25s; }
.brs-cta-btn:hover { background: #fff; gap: 20px; }
.brs-cta-btn svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.6; }

/* ══ RESPONSIVE (single) ══ */
@media (max-width: 900px) {
    .brs-hero { height: auto; min-height: calc(100vh - var(--header-h)); }
    .brs-hero-content { grid-template-columns: 1fr; padding: 60px 24px 60px; }
    .brs-hero-year { display: none; }
    .brs-hero-logo { right: 24px; }
    .brs-intro { grid-template-columns: 1fr; }
    .brs-intro-left, .brs-intro-right { padding: 60px 24px; }
    .brs-why { padding: 80px 24px; }
    .brs-why-head { grid-template-columns: 1fr; gap: 0; }
    .brs-why-intro { padding-top: 24px; }
    .brs-why-grid { grid-template-columns: 1fr 1fr; }
    .brs-cta { grid-template-columns: 1fr; padding: 80px 24px; }
}
@media (max-width: 600px) {
    .brs-why-grid { grid-template-columns: 1fr; }
    .brs-stats { grid-template-columns: 1fr; gap: 24px; }
    .brs-stat { border-right: none; padding: 0 0 24px; border-bottom: 1px solid rgba(14, 14, 12, .08); }
    .brs-stat:last-child { border-bottom: none; padding-bottom: 0; padding-left: 0; }
    .brs-stat:nth-child(2) { padding: 0 0 24px; }
}
