* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
}

body.pro2-drawer-open,
body.pro2-overlay-open,
body.pro2-settings-open,
body.pro2-profile-settings-open,
body.pro2-filter-visibility-open,
body.pro2-mobile-sidebar-open,
body.pro2-lightbox-open,
body.pro2-quick-actions-open,
body.pro2-price-library-open,
body.pro2-install-open,
body.pro2-reserves-open,
body.pro2-my-installs-open,
body.pro2-bonus-open {
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

code {
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    font-size: 0.92em;
}

.pro2-app {
    padding-bottom: 56px;
}

.pro2-app-download-cta {
    display: none;
}

.pro2-app-download-cta__button {
    width: auto;
    justify-content: center;
    gap: 10px;
    box-shadow: 0 16px 34px rgba(8, 15, 26, 0.18);
    white-space: nowrap;
}

.pro2-app-download-cta__button .pro2-icon {
    width: 16px;
    height: 16px;
}

@media (max-width: 1080px) {
    .pro2-app-download-cta {
        display: block;
        position: fixed;
        left: 50%;
        bottom: var(--pro2-app-download-bottom, calc(env(safe-area-inset-bottom, 0px) + 96px));
        z-index: 46;
        pointer-events: none;
        transform: translateX(-50%);
    }

    .pro2-app-download-cta[hidden] {
        display: none !important;
    }

    .pro2-app-download-cta__button {
        pointer-events: auto;
    }
}

.pro2-shell {
    width: var(--shell);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr) minmax(280px, 320px);
    grid-template-areas:
        "sidebar topbar context"
        "sidebar search context"
        "sidebar results context";
    gap: var(--workspace-gap);
    align-items: start;
}

.pro2-shell--no-context {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    grid-template-areas:
        "sidebar topbar"
        "sidebar search"
        "sidebar results";
}

.pro2-hero {
    position: relative;
    overflow: clip;
    padding: 32px 0 24px;
}

.pro2-hero--catalog-app {
    padding-bottom: 12px;
}

.pro2-hero__backdrop {
    position: absolute;
    inset: 30px 24px auto;
    height: 520px;
    border-radius: 40px;
    background:
        linear-gradient(135deg, rgba(88, 209, 201, 0.16), rgba(127, 230, 203, 0.04)),
        rgba(255, 255, 255, 0.02);
    filter: blur(0);
    pointer-events: none;
}

.pro2-topbar,
.pro2-hero__grid,
.pro2-grid {
    position: relative;
    z-index: 1;
}

.pro2-topbar {
    grid-area: topbar;
    display: grid;
    gap: 18px;
    align-items: start;
    margin-bottom: 18px;
    z-index: 40;
    overflow: visible;
}

.pro2-topbar--compact {
    padding-top: 24px;
    margin-bottom: 18px;
}

.pro2-topbar--workspace {
    padding-top: 18px;
    margin-bottom: 0;
    align-items: start;
    gap: 12px;
    overflow: visible;
}

.pro2-topbar--workspace::before {
    content: '';
    position: absolute;
    inset: -8px 0 auto 0;
    height: 124px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 0% 18%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 28%),
        radial-gradient(circle at 100% 10%, rgba(235, 196, 116, 0.14), transparent 24%),
        linear-gradient(112deg, color-mix(in srgb, var(--bg-soft) 48%, transparent), color-mix(in srgb, transparent 100%, var(--panel) 0%));
    -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 76%, transparent 100%);
    mask-image: linear-gradient(180deg, #000 0%, #000 76%, transparent 100%);
    pointer-events: none;
    z-index: -1;
    opacity: 0.92;
}

.pro2-topbar--workspace::after {
    display: none;
}

.pro2-topbar__meta-line {
    display: flex;
    align-items: baseline;
    gap: 14px;
    flex-wrap: wrap;
    width: auto;
    min-width: 0;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--border) 92%, rgba(255, 255, 255, 0.22));
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 68%),
        color-mix(in srgb, var(--glass-surface) 90%, transparent);
    backdrop-filter: var(--surface-blur);
    box-shadow:
        0 12px 30px rgba(8, 15, 26, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.pro2-topbar__brand-rail .pro2-topbar__meta-line {
    width: auto;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    backdrop-filter: none;
    box-shadow: none;
}

.pro2-topbar__back-link {
    display: inline-flex;
    align-items: baseline;
    line-height: 1.2;
    color: color-mix(in srgb, var(--text) 88%, var(--text-soft));
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, var(--accent) 32%, transparent);
    text-underline-offset: 0.18em;
}

.pro2-topbar__primary {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
}

.pro2-topbar__controls {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
    flex: 0 0 auto;
}

.pro2-topbar__brand-rail {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    max-width: min(100%, 760px);
    padding: 10px 14px;
    border: 1px solid color-mix(in srgb, var(--border) 86%, rgba(255, 255, 255, 0.18));
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 68%),
        color-mix(in srgb, var(--glass-surface) 90%, transparent);
    backdrop-filter: var(--surface-blur);
    box-shadow:
        0 12px 24px rgba(8, 15, 26, 0.065),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.pro2-topbar__brand-rail .pro2-topbar__back-link {
    text-decoration-thickness: 1px;
}

.pro2-topbar__secondary {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
}

.pro2-topbar h1,
.pro2-locked h1,
.pro2-panel h2,
.pro2-card h3 {
    margin: 0;
    line-height: 1.02;
}

.pro2-topbar h1 {
    max-width: 9ch;
    font-size: clamp(2.8rem, 6vw, 5.6rem);
    font-weight: 800;
    letter-spacing: -0.06em;
}

.pro2-title-small {
    max-width: 18ch;
    font-size: clamp(2.4rem, 5vw, 4.2rem);
    font-weight: 800;
    letter-spacing: -0.055em;
}

.pro2-workspace,
.pro2-workspace--no-context {
    display: contents;
}

.pro2-search-panel {
    grid-area: search;
    position: sticky;
    top: var(--sticky-top);
    z-index: 30;
    padding: 14px 18px;
    background:
        radial-gradient(circle at top left, rgba(88, 209, 201, 0.1), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 40%),
        var(--glass-surface);
    backdrop-filter: var(--search-blur);
    box-shadow:
        0 18px 34px rgba(0, 0, 0, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.pro2-sidebar {
    grid-area: sidebar;
    position: sticky;
    top: var(--sticky-top);
    display: grid;
    grid-template-rows: auto auto auto minmax(0, 1fr);
    height: calc(100vh - (var(--sticky-top) + 16px));
    max-height: calc(100vh - (var(--sticky-top) + 16px));
}

.pro2-sidebar__head-main,
.pro2-context-sidebar__head-main,
.pro2-sidebar__active-block,
.pro2-sidebar__fixed-controls,
.pro2-sidebar__scroll {
    min-width: 0;
}

.pro2-sidebar__scroll,
.pro2-context-sidebar__scroll {
    display: grid;
    gap: 18px;
    min-height: 0;
    overflow: auto;
    align-content: start;
    padding-top: 8px;
    padding-right: 10px;
    scrollbar-gutter: stable;
}

.pro2-results {
    grid-area: results;
    display: grid;
    gap: 18px;
}

.pro2-results-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
        "head controls"
        "simple simple"
        "list list"
        "load load"
        "pagination pagination";
    align-items: start;
    column-gap: 12px;
}

.pro2-results-card__head {
    grid-area: head;
    align-items: flex-start;
    margin-bottom: 0;
    min-width: 0;
}

.pro2-results-card__title {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.pro2-results-simple-mode {
    grid-area: simple;
}

.pro2-product-list {
    grid-area: list;
}

.pro2-load-more {
    grid-area: load;
}

.pro2-pagination {
    grid-area: pagination;
}

.pro2-results-controls {
    grid-area: controls;
    position: sticky;
    top: calc(var(--sticky-top) + var(--search-panel-sticky-height) + var(--workspace-gap));
    z-index: 25;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    width: max-content;
    margin: 0 0 14px auto;
    align-self: flex-start;
}

.pro2-scroll-top-button {
    position: fixed;
    right: var(--pro2-scroll-top-right, max(22px, calc((100vw - min(1440px, 100vw - 40px)) / 2 + 22px)));
    bottom: var(--pro2-scroll-top-bottom, max(36px, calc(env(safe-area-inset-bottom, 0px) + 36px)));
    z-index: 35;
    width: 52px;
    min-width: 52px !important;
    height: 52px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-color: var(--border);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 62%),
        var(--glass-surface-strong);
    backdrop-filter: var(--surface-blur);
    box-shadow: 0 16px 36px rgba(8, 15, 26, 0.12);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px) scale(0.96);
    transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.pro2-scroll-top-button.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.pro2-scroll-top-button svg {
    width: 18px;
    height: 18px;
}

.pro2-scroll-top-button:hover,
.pro2-scroll-top-button:focus-visible {
    transform: translateY(-1px) scale(1);
    box-shadow: 0 20px 40px rgba(8, 15, 26, 0.16);
}

.pro2-scroll-top-button--modal {
    position: absolute;
    right: 18px;
    bottom: 18px;
    z-index: 1486;
}

.pro2-context-sidebar {
    grid-area: context;
    position: sticky;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    align-self: start;
    top: var(--sticky-top);
    height: calc(100vh - (var(--sticky-top) + 16px));
    max-height: calc(100vh - (var(--sticky-top) + 16px));
}
