/*
 * _BNFE-CompanyDetail.css
 * BNFES company detail experience.
 */

#bn-company-detail-app {
    --bn-detail-primary: var(--bn-shell-primary, #419bc0);
    --bn-detail-primary-dark: #245d72;
    --bn-detail-border: var(--bn-shell-border, #dfe7ed);
    --bn-detail-muted: var(--bn-shell-muted, #667685);
    --bn-detail-text: var(--bn-shell-text, #1f2d36);
    --bn-detail-soft: var(--bn-shell-bg, #f7fafb);
    --bn-detail-radius: var(--bn-shell-control-radius, 10px);
    --bn-detail-card-radius: 8px;
    color: var(--bn-detail-text);
}

#bn-company-detail-app,
#bn-company-detail-app * {
    box-sizing: border-box;
}

#bn-company-detail-app a {
    color: var(--bn-detail-primary);
    text-decoration: none;
}

#bn-company-detail-app a:hover {
    text-decoration: none;
}

.bn-detail-loading {
    display: grid;
    place-items: center;
    min-height: 320px;
    color: var(--bn-detail-primary);
    font-size: 3rem;
}

.bn-detail-error {
    display: grid;
    gap: 10px;
    max-width: 680px;
    border: 1px solid #f0c6c6;
    border-radius: var(--bn-detail-card-radius);
    background: #fff7f7;
    color: #7b2929;
    padding: 22px;
}

.bn-detail-guest-gate {
    display: grid;
    gap: 14px;
    max-width: 760px;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: var(--bn-detail-card-radius);
    background: #ffffff;
    box-shadow: 0 18px 46px rgba(31, 45, 54, .08);
    padding: clamp(24px, 4vw, 42px);
}

.bn-detail-guest-gate-icon {
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 999px;
    background: rgba(244, 122, 42, .12);
    color: var(--bn-shell-primary, #f47a2a);
    font-size: 18px;
}

.bn-detail-eyebrow {
    margin: 4px 0 0;
    color: var(--bn-detail-primary);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.bn-detail-guest-gate h1 {
    max-width: 620px;
    margin: 0;
    color: var(--bn-detail-text);
    font-size: clamp(30px, 4vw, 46px);
    line-height: 1.05;
    letter-spacing: 0;
}

.bn-detail-guest-gate p {
    max-width: 620px;
    margin: 0;
    color: var(--bn-detail-muted);
    font-size: 16px;
    line-height: 1.6;
}

.bn-detail-guest-gate-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.bn-detail-turnstile-gate {
    display: grid;
    gap: 14px;
    justify-items: start;
    max-width: 720px;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: var(--bn-detail-card-radius);
    background: #ffffff;
    box-shadow: 0 18px 46px rgba(31, 45, 54, .08);
    padding: clamp(24px, 4vw, 42px);
}

.bn-detail-turnstile-icon {
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 999px;
    background: rgba(65, 155, 192, .13);
    color: var(--bn-detail-primary);
    font-size: 18px;
}

.bn-detail-turnstile-gate h1 {
    margin: 0;
    color: var(--bn-detail-text);
    font-size: clamp(30px, 4vw, 42px);
    line-height: 1.08;
    letter-spacing: 0;
}

.bn-detail-turnstile-gate p {
    max-width: 620px;
    margin: 0;
    color: var(--bn-detail-muted);
    font-size: 16px;
    line-height: 1.6;
}

.bn-turnstile-widget {
    display: flex;
    justify-content: flex-start;
    min-height: 70px;
    margin: 6px 0 0;
}

.bn-turnstile-status,
.bn-turnstile-error {
    margin: 0;
    font-size: 14px;
    line-height: 1.45;
}

.bn-turnstile-status {
    color: var(--bn-detail-muted);
}

.bn-turnstile-error {
    color: #b42318;
    font-weight: 800;
}

.bn-detail-page {
    display: grid;
    gap: 16px;
    width: 100%;
}

.bn-detail-topline,
.bn-detail-topline-meta {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.bn-detail-topline-meta {
    flex-wrap: wrap;
    justify-content: flex-end;
    min-width: 0;
}

.bn-detail-crumbs {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 34px;
    color: var(--bn-detail-muted);
    font-size: .9rem;
    font-weight: 800;
}

.bn-detail-crumbs a {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--bn-detail-primary-dark);
    font-weight: 900;
}

.bn-detail-crumbs a:hover,
.bn-detail-crumbs a:focus {
    color: var(--bn-detail-primary);
    outline: 0;
}

.bn-detail-crumbs strong {
    color: var(--bn-detail-text);
    font-weight: 900;
}

.bn-detail-utility-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 34px;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-radius);
    background: #fff;
    color: var(--bn-detail-muted) !important;
    padding: 0 11px;
    font: inherit;
    font-size: .84rem;
    font-weight: 800;
    white-space: nowrap;
    cursor: pointer;
}

.bn-detail-utility-action:hover,
.bn-detail-utility-action:focus {
    border-color: var(--bn-detail-primary);
    background: #eef8fb;
    color: var(--bn-detail-primary) !important;
    outline: 0;
}

.bn-detail-button,
.bn-credit-note,
.bn-detail-primary-action,
.bn-detail-secondary-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 38px;
    border-radius: var(--bn-detail-radius);
    padding: 0 13px;
    font: inherit;
    font-size: .9rem;
    font-weight: 800;
    white-space: nowrap;
}

.bn-detail-button,
.bn-credit-note,
.bn-detail-secondary-action {
    border: 1px solid var(--bn-detail-border);
    background: #fff;
    color: var(--bn-detail-text) !important;
}

.bn-detail-button:hover,
.bn-detail-secondary-action:hover,
.bn-detail-secondary-action:focus {
    border-color: var(--bn-detail-primary);
    background: #eef8fb;
    color: var(--bn-detail-primary) !important;
}

.bn-credit-note {
    min-height: 28px;
    padding: 0 10px;
    color: var(--bn-detail-muted) !important;
    font-size: .85rem;
}

.bn-detail-primary-action {
    border: 1px solid var(--bn-detail-primary);
    background: var(--bn-detail-primary);
    color: #fff !important;
}

.bn-detail-primary-action:hover,
.bn-detail-primary-action:focus {
    border-color: #2f86aa;
    background: #2f86aa;
    color: #fff !important;
}

.bn-company-profile-card,
.bn-detail-tabs-card,
.bn-detail-section {
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
}

.bn-company-profile-card {
    overflow: hidden;
    border-top: 4px solid var(--bn-detail-primary);
    padding: 18px;
}

.bn-profile-grid {
    display: grid;
    grid-template-columns: minmax(400px, .92fr) minmax(440px, 1.08fr);
    gap: 14px;
    align-items: start;
}

.bn-company-hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.bn-company-identity-row {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 16px;
    align-items: center;
}

.bn-detail-logo {
    display: grid;
    place-items: center;
    width: 96px;
    min-height: 88px;
    align-self: start;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
}

.bn-detail-logo img {
    max-width: 82px;
    max-height: 66px;
    object-fit: contain;
}

.bn-company-hero-copy {
    min-width: 0;
}

.bn-company-heading-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.bn-detail-eyebrow {
    margin: 0 0 6px;
    color: var(--bn-detail-muted);
    font-size: .76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.bn-company-hero h1 {
    margin: 0;
    color: var(--bn-detail-text);
    font-size: clamp(1.55rem, 2.1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.08;
    overflow-wrap: anywhere;
}

.bn-company-location {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin: 10px 0 0;
    color: var(--bn-detail-muted);
    font-weight: 700;
}

.bn-detail-favorite {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 38px;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-radius);
    background: #fff;
    color: var(--bn-detail-muted);
    padding: 0 12px;
    font: inherit;
    font-size: .9rem;
    font-weight: 900;
    cursor: pointer;
    white-space: nowrap;
}

.bn-detail-favorite:hover,
.bn-detail-favorite:focus,
.bn-detail-favorite.is-active {
    border-color: #ef9fb2;
    background: #fff2f5;
    color: #c9345c;
    outline: 0;
}

.is-locked {
    position: relative;
}

.bn-lock-icon,
.bn-lock-inline {
    color: var(--bn-detail-muted);
    font-size: .78rem;
}

.bn-lock-icon {
    margin-right: 1px;
}

.bn-detail-favorite.is-locked,
.bn-detail-secondary-action.is-locked,
.bn-detail-utility-action.is-locked,
.bn-copy-button.is-locked {
    border-color: #d9b76c;
    background: #fff8e6;
    color: #8a641b !important;
}

.bn-detail-favorite.is-locked:hover,
.bn-detail-favorite.is-locked:focus,
.bn-detail-secondary-action.is-locked:hover,
.bn-detail-secondary-action.is-locked:focus,
.bn-detail-utility-action.is-locked:hover,
.bn-detail-utility-action.is-locked:focus,
.bn-copy-button.is-locked:hover,
.bn-copy-button.is-locked:focus {
    border-color: #c59631;
    background: #f4dca0;
    color: #5f4210 !important;
}

.bn-info-actions .is-locked .bn-lock-icon,
.bn-detail-topline .is-locked .bn-lock-icon,
.bn-review-empty .is-locked .bn-lock-icon {
    position: absolute;
    top: -7px;
    right: -6px;
    display: grid;
    place-items: center;
    width: 17px;
    height: 17px;
    border: 1px solid #d9b76c;
    border-radius: 50%;
    background: #fff8e6;
    color: #8a641b;
    font-size: .58rem;
    margin: 0;
}

.bn-detail-favorite:disabled,
.bn-detail-secondary-action:disabled {
    cursor: wait;
    opacity: .72;
}

.bn-category-pills,
.bn-brand-list {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.bn-category-pills span,
.bn-brand-badge {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border-radius: var(--bn-detail-radius);
    padding: 4px 10px;
    font-size: .84rem;
    font-weight: 800;
}

.bn-category-pills span {
    background: #e3f3f8;
    color: var(--bn-detail-primary-dark);
}

.bn-brand-badge {
    background: #f3f7fa;
    color: var(--bn-detail-text);
}

.bn-company-description {
    max-width: 860px;
    margin: 14px 0 0;
    color: var(--bn-detail-muted);
    font-size: 1rem;
    line-height: 1.6;
}

.bn-info-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding: 0 0 14px;
    margin-bottom: 14px;
    border-bottom: 1px solid #e7eef3;
}

.bn-profile-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.bn-profile-metrics div {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 30px;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-radius);
    background: var(--bn-detail-soft);
    padding: 4px 9px;
    color: var(--bn-detail-muted);
    font-size: .88rem;
    font-weight: 800;
}

.bn-profile-metrics i {
    color: var(--bn-detail-primary);
}

.bn-profile-metrics strong {
    color: var(--bn-detail-text);
}

.bn-star-row {
    display: inline-flex;
    gap: 2px;
    color: #d69a1b;
}

.bn-star-row i {
    color: #d69a1b;
}

.bn-profile-classification {
    margin-top: 12px;
}

.bn-map-panel {
    min-width: 0;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 14px;
}

.bn-company-info-panel {
    display: grid;
    gap: 12px;
    min-width: 0;
    margin-top: 14px;
    border-top: 1px solid #e7eef3;
    padding-top: 14px;
}

.bn-detail-layout,
.bn-detail-two-column {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    align-items: start;
}

.bn-detail-two-column {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.bn-detail-main,
.bn-detail-side {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.bn-detail-side {
    position: sticky;
    top: calc(var(--bn-shell-topbar-height, 64px) + 16px);
}

.bn-detail-section {
    padding: 18px;
}

.bn-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.bn-section-head h2 {
    margin: 0;
    color: var(--bn-detail-text);
    font-size: 1.08rem;
    font-weight: 900;
}

.bn-section-head span {
    color: var(--bn-detail-muted);
    font-size: .86rem;
    font-weight: 800;
}

.bn-info-composition {
    display: grid;
    gap: 12px;
    align-items: start;
}

.bn-location-panel {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    padding: 14px;
}

.bn-location-icon {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #e3f3f8;
    color: var(--bn-detail-primary);
    font-size: 1rem;
}

.bn-location-panel span:not(.bn-location-icon),
.bn-method-tile span:not(.bn-method-icon) {
    display: block;
    color: var(--bn-detail-muted);
    font-size: .76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.bn-location-panel strong,
.bn-method-tile strong {
    display: block;
    margin-top: 5px;
    color: var(--bn-detail-text);
    font-size: .96rem;
    line-height: 1.38;
    overflow-wrap: anywhere;
}

.bn-location-panel em {
    display: inline-flex;
    margin-top: 9px;
    border-radius: 999px;
    background: #f3f7fa;
    color: var(--bn-detail-muted);
    padding: 4px 9px;
    font-size: .82rem;
    font-style: normal;
    font-weight: 900;
}

.bn-method-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    align-items: start;
}

.bn-method-tile {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    min-height: 86px;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    padding: 12px;
}

.bn-method-icon {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #eef8fb;
    color: var(--bn-detail-primary);
}

.bn-method-tile.is-phone .bn-method-icon {
    background: #edf8f0;
    color: #2f8f50;
}

.bn-method-tile.is-email .bn-method-icon {
    background: #fff7e7;
    color: #c98317;
}

.bn-method-tile.is-website .bn-method-icon {
    background: #e9f7f8;
    color: #238b94;
}

.bn-method-tile.is-fax .bn-method-icon {
    background: #f1f4f8;
    color: #687887;
}

.bn-method-tile a {
    color: var(--bn-detail-text) !important;
}

.bn-method-tile a:hover,
.bn-method-tile a:focus {
    color: var(--bn-detail-primary) !important;
}

.bn-data-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 10px;
    align-items: start;
}

.bn-data-row {
    min-height: 72px;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    padding: 13px;
}

.bn-data-content {
    min-width: 0;
    display: grid;
    gap: 6px;
}

.bn-data-content span {
    display: block;
    color: var(--bn-detail-muted);
    font-size: .76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.bn-data-content strong {
    display: block;
    color: var(--bn-detail-text);
    font-size: .95rem;
    line-height: 1.35;
    overflow-wrap: break-word;
    word-break: normal;
}

.bn-data-content a {
    overflow-wrap: anywhere;
}

.bn-copy-button {
    display: inline-grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-radius);
    background: #fff;
    color: var(--bn-detail-muted);
    cursor: pointer;
}

.bn-copy-button.is-locked {
    color: #8a641b;
}

.bn-copy-button.is-locked .bn-lock-icon {
    position: absolute;
    top: -6px;
    right: -5px;
    display: grid;
    place-items: center;
    width: 16px;
    height: 16px;
    border: 1px solid #d9b76c;
    border-radius: 50%;
    background: #fff8e6;
    color: #8a641b;
    font-size: .58rem;
    margin: 0;
}

.bn-copy-button:hover,
.bn-copy-button:focus {
    border-color: var(--bn-detail-primary);
    color: var(--bn-detail-primary);
    outline: 0;
}

.bn-contact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.bn-contact-card {
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 13px;
}

.bn-contact-card-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px;
    gap: 10px;
    align-items: start;
}

.bn-contact-card h3 {
    margin: 0;
    color: var(--bn-detail-text);
    font-size: 1rem;
    font-weight: 900;
}

.bn-contact-card p,
.bn-muted {
    margin: 5px 0 0;
    color: var(--bn-detail-muted);
}

.bn-detail-tabs-card {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    min-width: 0;
    min-height: 100%;
    overflow: hidden;
    border-top: 0;
}

.bn-detail-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-bottom: 1px solid #e7eef3;
    background: #fff;
    padding: 0 12px;
}

.bn-detail-tabs button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 48px;
    border: 0;
    border-bottom: 3px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--bn-detail-muted);
    margin-bottom: -1px;
    padding: 0 13px;
    font: inherit;
    font-size: .86rem;
    font-weight: 900;
    cursor: pointer;
    white-space: nowrap;
}

.bn-detail-tabs button:hover,
.bn-detail-tabs button:focus {
    background: #f8fbfd;
    color: var(--bn-detail-primary);
    outline: 0;
}

.bn-detail-tabs button.is-active {
    border-bottom-color: var(--bn-detail-primary);
    background: #fff;
    color: var(--bn-detail-primary-dark);
}

.bn-detail-tabs button em {
    display: inline-grid;
    place-items: center;
    min-width: 22px;
    height: 22px;
    border-radius: 999px;
    background: #eef3f6;
    color: var(--bn-detail-muted);
    font-style: normal;
    font-size: .75rem;
    font-weight: 900;
    padding: 0 6px;
}

.bn-detail-tabs button.is-active em {
    background: #fff;
    color: var(--bn-detail-primary-dark);
}

.bn-detail-tab-panel {
    min-width: 0;
    padding: 14px;
    display: flex;
    flex-direction: column;
}

.bn-detail-accordion {
    display: none;
}

.bn-detail-tab-panel > .bn-detail-section {
    border: 0;
    border-radius: 0;
    padding: 0;
    flex: 1 1 auto;
}

.bn-detail-tab-panel .bn-map-panel {
    border: 0;
    background: transparent;
    padding: 0;
    height: 100%;
    min-height: 560px;
}

.bn-accordion-item {
    border-bottom: 1px solid #e7eef3;
}

.bn-accordion-item:last-child {
    border-bottom: 0;
}

.bn-accordion-item > button {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 50px;
    border: 0;
    background: #fff;
    color: var(--bn-detail-text);
    padding: 0 14px;
    font: inherit;
    font-weight: 900;
    text-align: left;
    cursor: pointer;
    box-shadow: inset 0 -1px 0 #dfe7ed;
}

.bn-accordion-item > button:hover,
.bn-accordion-item > button:focus {
    background: #f8fbfd;
    color: var(--bn-detail-primary-dark);
    outline: 0;
}

.bn-accordion-item > button > span {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-width: 0;
}

.bn-accordion-item > button em {
    display: inline-grid;
    place-items: center;
    min-width: 22px;
    height: 22px;
    border-radius: 999px;
    background: #eef3f6;
    color: var(--bn-detail-muted);
    font-size: .75rem;
    font-style: normal;
    padding: 0 6px;
}

.bn-accordion-item.is-open > button {
    color: var(--bn-detail-primary-dark);
}

.bn-accordion-item.is-open > button > i:last-child {
    transform: rotate(180deg);
}

.bn-accordion-panel {
    padding: 0 12px 12px;
}

.bn-accordion-panel > .bn-detail-section {
    border: 0;
    border-radius: 0;
    padding: 0;
}

.bn-location-list {
    display: grid;
    gap: 10px;
}

.bn-location-card {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 12px;
}

.bn-location-card > i {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #e3f3f8;
    color: var(--bn-detail-primary);
}

.bn-location-card strong {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    color: var(--bn-detail-text);
    font-weight: 900;
}

.bn-location-card strong span {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 2px 8px;
    border-radius: 999px;
    background: #ffffff;
    color: var(--bn-detail-primary);
    font-size: 0.72rem;
    font-weight: 900;
}

.bn-location-card p {
    margin: 4px 0 0;
    color: var(--bn-detail-muted);
    line-height: 1.45;
}

.bn-location-card button {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 34px;
    margin-top: 10px;
    border: 1px solid #dbeaf0;
    border-radius: var(--bn-detail-radius);
    background: #ffffff;
    color: var(--bn-detail-primary-dark);
    padding: 0 11px;
    font-weight: 900;
    cursor: pointer;
}

.bn-location-card button:hover,
.bn-location-card button:focus {
    border-color: var(--bn-detail-primary);
    color: var(--bn-detail-primary);
    outline: 0;
}

.bn-detail-info-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
}

.bn-detail-info-list li {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    color: var(--bn-detail-muted);
    font-size: .88rem;
    line-height: 1.4;
    min-width: 0;
}

.bn-detail-info-list.compact li span,
.bn-detail-info-list.compact li a {
    min-width: 0;
    overflow-wrap: anywhere;
}

.bn-detail-info-list i {
    margin-top: 2px;
    color: var(--bn-detail-primary);
}

.bn-map-frame {
    overflow: hidden;
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    aspect-ratio: 16 / 9;
    min-height: 560px;
    height: 100%;
}

.bn-map-frame iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

.bn-leaflet-map {
    width: 100%;
}

.bn-map-pin-icon {
    display: grid;
    place-items: center;
}

.bn-map-pin-icon span {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border: 4px solid #ffffff;
    border-radius: 50% 50% 50% 0;
    background: var(--bn-detail-primary);
    color: #ffffff;
    box-shadow: 0 12px 26px rgba(20, 35, 60, 0.28);
    transform: rotate(-45deg);
}

.bn-map-pin-icon i {
    transform: rotate(45deg);
    font-size: 1.35rem;
}

.bn-map-pin-icon.is-selected span {
    background: #c98317;
    box-shadow: 0 0 0 9px rgba(201, 131, 23, 0.2), 0 14px 30px rgba(20, 35, 60, 0.34);
}

.bn-map-loading {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    min-height: 560px;
    color: var(--bn-detail-muted);
    font-size: .9rem;
    font-weight: 800;
}

.bn-map-caption {
    margin: 8px 0 0;
    color: var(--bn-detail-muted);
    font-size: .84rem;
    font-weight: 800;
}

.bn-map-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .88rem;
    font-weight: 900;
}

.bn-map-empty {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    border: 1px dashed var(--bn-detail-border);
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 14px;
}

.bn-map-empty > i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #e3f3f8;
    color: var(--bn-detail-primary);
}

.bn-map-empty strong,
.bn-map-empty p {
    display: block;
    margin: 0;
}

.bn-map-empty p {
    margin-top: 3px;
    color: var(--bn-detail-muted);
    font-size: .9rem;
}

.bn-gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.bn-gallery-stage {
    display: grid;
    gap: 12px;
}

.bn-gallery-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -2px 0 14px;
}

.bn-gallery-filters button {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid var(--bn-detail-border);
    border-radius: 999px;
    background: #fff;
    color: var(--bn-detail-text);
    font-size: .82rem;
    font-weight: 700;
}

.bn-gallery-filters button span {
    display: inline-grid;
    place-items: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: #eff6f8;
    color: var(--bn-detail-muted);
    font-size: .72rem;
}

.bn-gallery-filters button.is-active {
    border-color: var(--bn-detail-primary);
    background: #e9f6fa;
    color: var(--bn-detail-primary);
}

.bn-gallery-item {
    margin: 0;
    min-width: 0;
}

.bn-gallery-item button {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: zoom-in;
    text-align: left;
}

.bn-gallery-item picture {
    display: block;
}

.bn-gallery-grid img {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: var(--bn-detail-card-radius);
    object-fit: cover;
    background: #edf4f7;
}

.bn-gallery-item figcaption {
    margin-top: 6px;
    color: var(--bn-detail-muted);
    font-size: .82rem;
    line-height: 1.35;
}

.bn-gallery-carousel-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.bn-gallery-carousel-controls button,
.bn-gallery-modal-close,
.bn-gallery-modal-nav {
    display: inline-grid;
    place-items: center;
    border: 1px solid var(--bn-detail-border);
    background: #fff;
    color: var(--bn-detail-text);
    box-shadow: var(--bn-detail-shadow-soft);
}

.bn-gallery-carousel-controls button {
    width: 38px;
    height: 38px;
    border-radius: 50%;
}

.bn-gallery-carousel-controls span {
    min-width: 54px;
    color: var(--bn-detail-muted);
    font-size: .82rem;
    font-weight: 900;
    text-align: center;
}

.bn-gallery-modal {
    position: fixed;
    inset: 0;
    z-index: 10030;
    display: grid;
    place-items: center;
    padding: 24px;
}

.bn-gallery-modal-backdrop {
    position: fixed;
    inset: 0;
    border: 0;
    background: rgba(9, 20, 28, .76);
    backdrop-filter: blur(6px);
    cursor: zoom-out;
}

.bn-gallery-modal-dialog {
    position: relative;
    z-index: 1;
    width: min(1040px, 100%);
    max-height: calc(100vh - 48px);
    display: grid;
    place-items: center;
}

.bn-gallery-modal-figure {
    width: 100%;
    margin: 0;
    display: grid;
    gap: 12px;
    justify-items: center;
}

.bn-gallery-modal-figure picture {
    width: 100%;
    display: block;
}

.bn-gallery-modal-figure img {
    display: block;
    width: 100%;
    max-height: calc(100vh - 140px);
    object-fit: contain;
    border-radius: 12px;
    background: #f5f8fa;
    box-shadow: 0 24px 70px rgba(0,0,0,.36);
}

.bn-gallery-modal-figure figcaption,
.bn-gallery-modal-count {
    color: #fff;
    text-shadow: 0 2px 12px rgba(0,0,0,.42);
}

.bn-gallery-modal-figure figcaption {
    max-width: 760px;
    font-size: .95rem;
    line-height: 1.45;
    text-align: center;
}

.bn-gallery-modal-close {
    position: absolute;
    top: -14px;
    right: -14px;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    z-index: 3;
}

.bn-gallery-modal-nav {
    position: absolute;
    top: 50%;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    transform: translateY(-50%);
    z-index: 3;
}

.bn-gallery-modal-nav.is-prev {
    left: -24px;
}

.bn-gallery-modal-nav.is-next {
    right: -24px;
}

.bn-gallery-modal-count {
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
    font-size: .86rem;
    font-weight: 900;
}

.bn-social-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bn-social-link {
    display: inline-grid;
    place-items: center;
    width: 40px;
    height: 40px;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-radius);
    background: #fff;
    color: var(--bn-detail-primary) !important;
    font-size: 1.1rem;
}

.bn-social-link:hover {
    border-color: var(--bn-detail-primary);
    background: var(--bn-detail-primary);
    color: #fff !important;
}

.bn-review-empty {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    border: 1px dashed var(--bn-detail-border);
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 14px;
}

.bn-detail-toast {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 10030;
    border-radius: var(--bn-detail-radius);
    background: var(--bn-detail-text);
    color: #fff;
    padding: 10px 13px;
    font-size: .9rem;
    font-weight: 800;
    box-shadow: 0 12px 34px rgba(31, 45, 54, .22);
}

.bn-review-empty > i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #fff8e6;
    color: #a97812;
}

.bn-review-empty strong,
.bn-review-empty p {
    display: block;
    margin: 0;
}

.bn-review-empty p {
    margin-top: 3px;
    color: var(--bn-detail-muted);
    font-size: .9rem;
}

.bn-review-list {
    display: grid;
    gap: 12px;
}

.bn-review-card {
    border: 1px solid #edf1f4;
    border-radius: var(--bn-detail-card-radius);
    background: var(--bn-detail-soft);
    padding: 13px;
}

.bn-review-card-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
}

.bn-review-card h3 {
    margin: 6px 0 0;
    color: var(--bn-detail-text);
    font-size: 1rem;
    font-weight: 900;
}

.bn-review-card-head > span,
.bn-review-card footer {
    color: var(--bn-detail-muted);
    font-size: .84rem;
    font-weight: 800;
}

.bn-review-card p {
    margin: 10px 0;
    color: var(--bn-detail-text);
    line-height: 1.55;
}

.bn-review-form {
    display: grid;
    gap: 14px;
    margin-top: 16px;
    border: 1px solid #dbe8ef;
    border-radius: var(--bn-detail-card-radius);
    background: linear-gradient(180deg, #ffffff 0%, #f8fbfd 100%);
    box-shadow: 0 14px 34px rgba(31, 45, 54, .08);
    padding: 16px;
}

.bn-review-form-grid {
    display: grid;
    grid-template-columns: minmax(150px, .35fr) minmax(0, .65fr);
    gap: 12px;
}

.bn-review-form label {
    display: grid;
    gap: 7px;
    color: var(--bn-detail-muted);
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.bn-review-form label > span {
    display: inline-flex;
    align-items: center;
    min-height: 18px;
}

.bn-review-form input,
.bn-review-form select,
.bn-review-form textarea {
    width: 100%;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-radius);
    background: #fff;
    color: var(--bn-detail-text);
    font: inherit;
    font-size: .95rem;
    font-weight: 700;
    padding: 10px 11px;
    text-transform: none;
    box-shadow: 0 1px 0 rgba(31, 45, 54, .03);
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.bn-review-form input:focus,
.bn-review-form select:focus,
.bn-review-form textarea:focus {
    border-color: var(--bn-detail-primary);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(68, 161, 192, .16);
    outline: 0;
}

.bn-review-form textarea {
    min-height: 120px;
    resize: vertical;
    line-height: 1.45;
}

.bn-review-form-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
    border-top: 1px solid #e7eef3;
    padding-top: 12px;
}

.bn-review-trigger {
    margin-top: 14px;
}

.bn-review-trigger.is-disabled {
    border-color: #b7dfc2;
    background: #f0fbf3;
    color: #276338;
    cursor: default;
}

.bn-review-trigger.is-disabled:hover,
.bn-review-trigger.is-disabled:focus {
    border-color: #b7dfc2;
    background: #f0fbf3;
    color: #276338;
    outline: 0;
}

.bn-review-star-input {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
    min-height: 44px;
}

.bn-review-star-input button {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid #dce8ef;
    border-radius: 50%;
    background: #fff;
    color: #a5b4bd;
    cursor: pointer;
    font-size: 1rem;
    transition: transform .16s ease, border-color .16s ease, background .16s ease, color .16s ease;
}

.bn-review-star-input button:hover,
.bn-review-star-input button:focus {
    border-color: #e7b94f;
    background: #fff9e8;
    color: #d89516;
    outline: 0;
    transform: translateY(-1px);
}

.bn-review-star-input button.is-selected {
    border-color: #f0cf77;
    background: #fff4d6;
    color: #d89516;
}

.bn-review-star-input > span {
    margin-left: 6px;
    color: var(--bn-detail-muted);
    font-size: .86rem;
    font-weight: 900;
}

.bn-review-submitted {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    border: 1px solid #b7dfc2;
    border-radius: var(--bn-detail-radius);
    background: #f0fbf3;
    color: #276338;
    padding: 10px 12px;
    font-weight: 800;
}

.bn-review-modal {
    position: fixed;
    inset: 0;
    z-index: 10070;
    display: grid;
    place-items: center;
    padding: 18px;
}

.bn-review-modal-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(23, 35, 42, .52);
    cursor: pointer;
}

.bn-review-modal-dialog {
    position: relative;
    z-index: 1;
    width: min(680px, 100%);
    max-height: min(760px, calc(100vh - 36px));
    overflow: auto;
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    box-shadow: 0 28px 78px rgba(31, 45, 54, .28);
    padding: 22px;
}

.bn-review-modal-dialog.compact {
    width: min(520px, 100%);
}

.bn-review-modal-close {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 1px solid transparent;
    border-radius: 50%;
    background: transparent;
    color: var(--bn-detail-muted);
    cursor: pointer;
}

.bn-review-modal-close:hover,
.bn-review-modal-close:focus {
    border-color: var(--bn-detail-border);
    background: #f7fafb;
    color: var(--bn-detail-text);
    outline: 0;
}

.bn-review-modal-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    padding-right: 38px;
}

.bn-review-modal-icon {
    display: inline-grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: #fff4d6;
    color: #d89516;
    flex: 0 0 auto;
}

.bn-review-modal-head h2 {
    margin: 0;
    color: var(--bn-detail-text);
    font-size: 1.32rem;
    line-height: 1.2;
}

.bn-review-modal-head p {
    margin: 4px 0 0;
    color: var(--bn-detail-muted);
    font-size: .92rem;
}

.bn-review-modal .bn-review-form {
    margin-top: 0;
}

.bn-listing-request-choice-grid {
    display: grid;
    gap: 12px;
}

.bn-listing-request-choice {
    display: grid;
    gap: 6px;
    width: 100%;
    padding: 16px;
    text-align: left;
    border: 1px solid var(--bn-detail-border);
    border-radius: 16px;
    background: #fff;
    color: var(--bn-detail-text);
    cursor: pointer;
    box-shadow: 0 12px 26px rgba(31, 45, 54, .06);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.bn-listing-request-choice:hover,
.bn-listing-request-choice:focus {
    transform: translateY(-1px);
    border-color: rgba(65, 155, 192, .34);
    box-shadow: 0 16px 34px rgba(31, 45, 54, .10);
    outline: 0;
}

.bn-listing-request-choice strong {
    font-size: 1rem;
}

.bn-listing-request-choice span {
    color: var(--bn-detail-muted);
    font-size: .9rem;
    line-height: 1.45;
}

.bn-review-status-card {
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 13px;
    align-items: start;
    border: 1px solid #b7dfc2;
    border-radius: var(--bn-detail-card-radius);
    background: #f0fbf3;
    color: #276338;
    padding: 16px;
}

.bn-review-status-card.pending {
    border-color: #f0cf77;
    background: #fff8e6;
    color: #806016;
}

.bn-review-status-card.rejected {
    border-color: #e5c4c4;
    background: #fff6f6;
    color: #7b2929;
}

.bn-review-status-icon {
    display: grid;
    place-items: center;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: #fff;
    font-size: 1.25rem;
}

.bn-review-status-card h2,
.bn-review-status-card p,
.bn-review-status-card small {
    display: block;
    margin: 0;
}

.bn-review-status-card h2 {
    color: inherit;
    font-size: 1.25rem;
    line-height: 1.2;
}

.bn-review-status-card p {
    margin-top: 6px;
    color: inherit;
    font-weight: 800;
}

.bn-review-status-card small {
    margin-top: 6px;
    color: inherit;
    opacity: .82;
    line-height: 1.45;
}

.bn-review-form-actions.clean {
    border-top: 0;
    padding-top: 14px;
}

.bn-detail-promo-modal {
    position: fixed;
    inset: 0;
    z-index: 10080;
    display: grid;
    place-items: center;
    padding: 18px;
}

.bn-detail-promo-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(23, 35, 42, .48);
    cursor: pointer;
}

.bn-detail-promo-dialog {
    position: relative;
    z-index: 1;
    width: min(430px, 100%);
    border: 1px solid var(--bn-detail-border);
    border-radius: var(--bn-detail-card-radius);
    background: #fff;
    box-shadow: 0 24px 70px rgba(31, 45, 54, .24);
    padding: 26px;
    text-align: center;
}

.bn-detail-promo-close {
    position: absolute;
    top: 10px;
    right: 10px;
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid transparent;
    border-radius: 50%;
    background: transparent;
    color: var(--bn-detail-muted);
    cursor: pointer;
}

.bn-detail-promo-close:hover,
.bn-detail-promo-close:focus {
    border-color: var(--bn-detail-border);
    background: #f7fafb;
    color: var(--bn-detail-text);
    outline: 0;
}

.bn-detail-promo-icon {
    display: inline-grid;
    place-items: center;
    width: 54px;
    height: 54px;
    margin-bottom: 14px;
    border-radius: 50%;
    background: #e3f3f8;
    color: var(--bn-detail-primary);
    font-size: 1.35rem;
}

.bn-detail-promo-dialog h2 {
    margin: 0 0 8px;
    color: var(--bn-detail-text);
    font-size: 1.35rem;
    line-height: 1.2;
}

.bn-detail-promo-message,
.bn-detail-promo-detail {
    margin: 0;
    line-height: 1.45;
}

.bn-detail-promo-message {
    color: var(--bn-detail-text);
    font-size: 1rem;
}

.bn-detail-promo-detail {
    margin-top: 8px;
    color: var(--bn-detail-muted);
    font-size: .92rem;
}

.bn-detail-promo-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.bn-detail-promo-primary,
.bn-detail-promo-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    border: 0;
    border-radius: var(--bn-detail-radius);
    padding: 0 16px;
    font-family: inherit;
    font-size: .92rem;
    font-weight: 900;
    cursor: pointer;
}

.bn-detail-promo-primary {
    border: 1px solid var(--bn-detail-primary);
    background: var(--bn-detail-primary);
    color: #fff !important;
}

.bn-detail-promo-secondary {
    border: 1px solid var(--bn-detail-border);
    background: #fff;
    color: var(--bn-detail-text) !important;
}

@media (max-width: 1120px) {
    .bn-detail-layout,
    .bn-profile-grid,
    .bn-detail-two-column {
        grid-template-columns: 1fr;
    }

    .bn-detail-side {
        position: static;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .bn-contact-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .bn-detail-topline,
    .bn-detail-topline-meta,
    .bn-company-heading-row,
    .bn-info-actions,
    .bn-detail-promo-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .bn-detail-topline {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
    }

    .bn-detail-crumbs {
        min-width: 0;
        flex: 1 1 auto;
        gap: 6px;
        font-size: .84rem;
    }

    .bn-detail-topline-meta {
        display: flex;
        flex: 0 0 auto;
    }

    .bn-detail-utility-action {
        min-height: 32px;
        padding: 0 9px;
        font-size: .78rem;
    }

    .bn-credit-note {
        width: auto;
        min-height: 26px;
        padding: 0 8px;
        font-size: .76rem;
    }

    .bn-company-hero,
    .bn-company-identity-row,
    .bn-contact-grid,
    .bn-contact-card,
    .bn-data-grid,
    .bn-data-secondary,
    .bn-method-grid,
    .bn-location-panel,
    .bn-review-form-grid,
    .bn-profile-grid,
    .bn-detail-two-column,
    .bn-detail-side,
    .bn-map-empty,
    .bn-review-empty {
        grid-template-columns: 1fr;
    }

    .bn-gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bn-detail-logo,
    .bn-detail-favorite,
    .bn-detail-primary-action,
    .bn-detail-secondary-action,
    .bn-detail-promo-primary,
    .bn-detail-promo-secondary {
        width: 100%;
    }

    .bn-detail-logo {
        min-height: 96px;
    }

    .bn-company-profile-card {
        padding: 16px;
    }

    .bn-company-identity-row {
        grid-template-columns: 82px minmax(0, 1fr);
        gap: 12px;
    }

    .bn-detail-logo {
        width: 82px;
    }

    .bn-map-frame {
        aspect-ratio: 4 / 3;
        min-height: 420px;
    }

    .bn-map-loading {
        min-height: 420px;
    }

    .bn-detail-section {
        padding: 15px;
    }

    .bn-detail-info-list {
        grid-template-columns: 1fr;
        margin-top: 10px;
    }

    .bn-detail-tabs {
        display: none;
    }

    .bn-detail-tab-panel {
        display: none;
    }

    .bn-detail-accordion {
        display: block;
    }

    .bn-accordion-panel {
        padding-top: 12px;
        padding-bottom: 16px;
    }

    .bn-accordion-panel > .bn-detail-section {
        padding-bottom: 4px;
    }

    .bn-method-tile {
        min-height: 76px;
    }

    .bn-info-actions {
        display: flex;
        align-items: center;
        justify-content: flex-start;
    }

    .bn-info-actions .bn-detail-favorite,
    .bn-info-actions .bn-detail-primary-action,
    .bn-info-actions .bn-detail-secondary-action {
        width: auto;
        min-height: 36px;
        padding: 0 11px;
        font-size: .84rem;
    }

    .bn-review-modal-dialog {
        padding: 18px;
    }

    .bn-review-star-input button {
        width: 36px;
        height: 36px;
    }
}

@media (max-width: 480px) {
    .bn-detail-topline {
        display: grid;
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .bn-detail-topline-meta {
        justify-content: stretch;
        width: 100%;
    }

    .bn-detail-utility-action {
        width: 100%;
    }

    .bn-gallery-grid {
        gap: 8px;
    }

    .bn-gallery-item figcaption {
        font-size: .76rem;
    }

    .bn-gallery-modal {
        padding: 14px;
    }

    .bn-gallery-modal-dialog {
        max-height: calc(100vh - 28px);
    }

    .bn-gallery-modal-close {
        top: 8px;
        right: 8px;
    }

    .bn-gallery-modal-nav {
        width: 40px;
        height: 40px;
    }

    .bn-gallery-modal-nav.is-prev {
        left: 8px;
    }

    .bn-gallery-modal-nav.is-next {
        right: 8px;
    }
}
