.oppv2-page {
    --oppv2-primary: #1b6ec2;
    --oppv2-primary-strong: #1861ac;
    --oppv2-link: #0077cc;
    --oppv2-surface: #f7f9fc;
    --oppv2-border: #d9e2ef;
    --oppv2-ink: #13233a;
    --oppv2-muted: #5f728a;
    --oppv2-survey: #2cb1a5;
    --oppv2-accent-soft: #edf4ff;
    margin: 0 auto;
    max-width: 1180px;
    color: var(--oppv2-ink);
    padding-bottom: calc(96px + env(safe-area-inset-bottom));
}

.oppv2-lang-switch {
    display: flex;
    gap: 0.38rem;
    justify-content: flex-end;
    margin: 0 0 0.55rem;
}

.oppv2-lang-link {
    border: 1px solid var(--oppv2-border);
    background: #fff;
    color: #395271;
    border-radius: 999px;
    padding: 0.2rem 0.58rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: none;
}

.oppv2-lang-link.is-active,
.oppv2-lang-link:hover {
    border-color: var(--oppv2-primary);
    color: var(--oppv2-primary-strong);
}

.oppv2-hero {
    border: 1px solid var(--oppv2-border);
    border-radius: 18px;
    background: linear-gradient(132deg, #f6fbff 0%, #edf5ff 70%, #e9f2ff 100%);
    padding: 0.92rem;
    box-shadow: 0 10px 22px rgba(18, 57, 105, 0.07);
}

.oppv2-hero-head {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 0.8rem;
}

.oppv2-kicker {
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.78rem;
    color: var(--oppv2-primary-strong);
    font-weight: 700;
}

.oppv2-title {
    margin: 0.18rem 0 0.28rem;
    font-size: clamp(1.36rem, 2.6vw, 2rem);
    font-weight: 700;
    line-height: 1.16;
}

.oppv2-subtitle {
    margin: 0;
    color: var(--oppv2-muted);
    max-width: 58ch;
    font-size: 1rem;
}

.oppv2-filter-panel {
    margin-top: 0.76rem;
    border-top: 1px solid #d7e5f7;
    padding-top: 0.58rem;
}

.oppv2-filter-panel summary {
    list-style: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border: 1px solid #c6d8ef;
    border-radius: 999px;
    background: #fff;
    color: #244565;
    font-weight: 600;
    padding: 0.34rem 0.74rem;
}

.oppv2-filter-panel summary::-webkit-details-marker {
    display: none;
}

.oppv2-filters {
    margin-top: 0.62rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.oppv2-chip {
    border: 1px solid #c8d6ea;
    background: #fff;
    color: #1f3957;
    border-radius: 999px;
    padding: 0.34rem 0.74rem;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 160ms ease, color 160ms ease, border-color 160ms ease;
}

.oppv2-chip:hover,
.oppv2-chip:focus-visible {
    border-color: var(--oppv2-primary);
    color: var(--oppv2-primary-strong);
}

.oppv2-chip.is-active {
    background: var(--oppv2-primary);
    border-color: var(--oppv2-primary);
    color: #fff;
}

.oppv2-feed-wrap {
    margin-top: 0.95rem;
    border-radius: 16px;
    background: #f9fbff;
    border: 1px solid var(--oppv2-border);
    padding: 0.55rem;
}

.oppv2-feed {
    display: grid;
    gap: 0.62rem;
    max-height: 72vh;
    overflow-y: auto;
    scroll-snap-type: y mandatory;
    padding-right: 0.22rem;
}

.oppv2-feed-item {
    scroll-snap-align: start;
}

.oppv2-card {
    border: 1px solid #cfdbeb;
    border-radius: 15px;
    background: #fff;
    padding: 0.84rem;
    box-shadow: 0 6px 16px rgba(18, 57, 105, 0.06);
    transition: transform 170ms ease, box-shadow 170ms ease;
}

.oppv2-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(18, 57, 105, 0.1);
}

.oppv2-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.7rem;
}

.oppv2-card-title {
    margin: 0.22rem 0 0;
    font-size: clamp(1.04rem, 1.45vw, 1.28rem);
    line-height: 1.25;
}

.oppv2-card-summary {
    margin: 0.5rem 0 0;
    color: #213954;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.oppv2-meta {
    margin-top: 0.48rem;
    display: flex;
    gap: 0.48rem;
    flex-wrap: wrap;
    color: #375574;
    font-size: 0.9rem;
}

.oppv2-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.36rem;
}

.oppv2-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.16rem 0.56rem;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.oppv2-badge--category {
    color: #17395b;
    background: #e7f1ff;
    border-color: #c9dcf7;
}

.oppv2-badge--urgency {
    color: #5f3b00;
    background: #ffe9b3;
    border-color: #ffd372;
}

.oppv2-badge--verified {
    color: #08463d;
    background: #cff8ef;
    border-color: #99eddd;
}

.oppv2-badge--visibility {
    color: #4a5b72;
    background: #f0f3f8;
    border-color: #d9e0eb;
}

.oppv2-badge--time {
    color: #4d2f6f;
    background: #eee6ff;
    border-color: #d9cbfa;
}

.oppv2-actions {
    margin-top: 0.6rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.oppv2-btn {
    border: 1px solid var(--oppv2-border);
    border-radius: 11px;
    padding: 0.4rem 0.78rem;
    font-weight: 600;
    text-decoration: none;
    background: #fff;
    color: #1e3350;
    cursor: pointer;
}

.oppv2-btn:hover,
.oppv2-btn:focus-visible {
    border-color: var(--oppv2-primary);
    color: var(--oppv2-primary-strong);
}

.oppv2-btn--primary {
    border-color: var(--oppv2-primary);
    background: var(--oppv2-primary);
    color: #fff;
}

.oppv2-btn--primary:hover,
.oppv2-btn--primary:focus-visible {
    background: var(--oppv2-primary-strong);
    border-color: var(--oppv2-primary-strong);
    color: #fff;
}

.oppv2-survey {
    border: 1px solid color-mix(in srgb, var(--oppv2-survey) 35%, #d5f0ec);
    border-radius: 15px;
    background: linear-gradient(145deg, #f3fffc 0%, #eafcf8 100%);
    padding: 0.8rem;
    box-shadow: 0 8px 20px rgba(35, 142, 132, 0.1);
}

.oppv2-survey-title {
    margin: 0.25rem 0 0.4rem;
    font-size: 1.18rem;
}

.oppv2-survey-options {
    margin-top: 0.6rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.oppv2-loader,
.oppv2-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    color: var(--oppv2-muted);
}

.oppv2-hidden {
    display: none !important;
}

.oppv2-detail {
    border: 1px solid var(--oppv2-border);
    border-radius: 16px;
    background: linear-gradient(145deg, #ffffff 0%, #f8fbff 100%);
    padding: 0.86rem;
    box-shadow: 0 10px 24px rgba(18, 57, 105, 0.08);
}

.oppv2-detail h1 {
    font-size: clamp(1.4rem, 2.3vw, 2rem);
    margin-top: 0.5rem;
}

.oppv2-detail-grid {
    margin-top: 0.8rem;
    display: grid;
    gap: 0.8rem;
}

.oppv2-md p:last-child {
    margin-bottom: 0;
}

.oppv2-md pre {
    background: #f3f7fd;
    border: 1px solid #d4e1f2;
    border-radius: 10px;
    padding: 0.55rem;
    overflow-x: auto;
}

.oppv2-md table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 0.35rem;
}

.oppv2-md table th,
.oppv2-md table td {
    border: 1px solid #d7e4f4;
    padding: 0.34rem 0.45rem;
}

.oppv2-md img {
    max-width: 100%;
    border-radius: 10px;
}

.oppv2-detail-section {
    border: 1px solid #dbe5f2;
    border-radius: 14px;
    background: #fff;
    padding: 0.76rem;
}

.oppv2-detail-dl {
    margin: 0;
    display: grid;
    gap: 0.32rem;
}

.oppv2-detail-row {
    display: flex;
    gap: 0.55rem;
}

.oppv2-detail-row dt {
    width: 7.4rem;
    color: #4a6079;
}

.oppv2-detail-row dd {
    margin: 0;
    font-weight: 600;
}

.oppv2-submit {
    border: 1px solid var(--oppv2-border);
    border-radius: 16px;
    background: #fff;
    padding: 0.86rem;
    box-shadow: 0 10px 24px rgba(18, 57, 105, 0.08);
}

.oppv2-stepper {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.8rem;
}

.oppv2-step-dot {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 2px solid #b5c8e1;
    color: #5e7592;
    font-weight: 700;
    display: inline-flex;
    justify-content: center;
    align-items: center;
}

.oppv2-step-dot.is-active {
    border-color: var(--oppv2-primary);
    background: var(--oppv2-primary);
    color: #fff;
}

.oppv2-grid {
    display: grid;
    gap: 0.72rem;
}

.oppv2-field {
    display: grid;
    gap: 0.32rem;
}

.oppv2-field label {
    margin: 0;
    font-weight: 600;
    color: #203952;
}

.oppv2-inline-check {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.oppv2-country-search {
    width: 100%;
    border: 1px solid #bfd0e6;
    border-radius: 11px;
    padding: 0.45rem 0.66rem;
}

.oppv2-field input,
.oppv2-field textarea,
.oppv2-field select {
    width: 100%;
    border: 1px solid #bfd0e6;
    border-radius: 11px;
    padding: 0.5rem 0.66rem;
}

.oppv2-field textarea {
    min-height: 120px;
}

.oppv2-audience {
    border: 1px dashed #b8cbde;
    border-radius: 14px;
    padding: 0.62rem;
    background: #f9fcff;
}

.oppv2-advanced-visibility {
    border: 1px dashed #bed0e5;
    border-radius: 12px;
    background: #f8fbff;
    padding: 0.5rem 0.62rem;
}

.oppv2-advanced-visibility summary {
    list-style: none;
    cursor: pointer;
    font-weight: 650;
    color: #2a4768;
}

.oppv2-advanced-visibility summary::-webkit-details-marker {
    display: none;
}

.oppv2-audience-list {
    display: grid;
    gap: 0.5rem;
}

.oppv2-audience-row {
    display: grid;
    gap: 0.4rem;
    border: 1px solid #d8e4f2;
    border-radius: 12px;
    padding: 0.5rem;
    background: #fff;
}

.oppv2-submit-actions {
    margin-top: 0.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.52rem;
}

.oppv2-result {
    margin-top: 0.72rem;
    border-radius: 12px;
    padding: 0.7rem;
}

.oppv2-result--ok {
    background: #def7ea;
    color: #11563a;
}

.oppv2-result--err {
    background: #ffe8e8;
    color: #852b2b;
}

.oppv2-review-drawer {
    position: fixed;
    inset: 0;
    background: rgba(5, 20, 39, 0.42);
    z-index: 1050;
    display: grid;
    place-items: center;
    padding: 1rem;
}

.oppv2-review-panel {
    width: min(1040px, 100%);
    max-height: 92vh;
    overflow: auto;
    border-radius: 16px;
    background: #fff;
    border: 1px solid var(--oppv2-border);
    box-shadow: 0 24px 60px rgba(10, 34, 62, 0.26);
    padding: 1rem;
}

.oppv2-review-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    margin-bottom: 0.9rem;
}

.oppv2-review-grid {
    display: grid;
    gap: 0.8rem;
}

.oppv2-review-section {
    border: 1px solid #d6e2f1;
    border-radius: 12px;
    background: #fbfdff;
    padding: 0.72rem;
}

.oppv2-checklist {
    display: grid;
    gap: 0.3rem;
    font-size: 0.95rem;
}

.oppv2-skeleton {
    border: 1px solid #d8e2f0;
    border-radius: 15px;
    background: #fff;
    padding: 0.84rem;
}

.oppv2-skeleton-line {
    border-radius: 7px;
    height: 0.85rem;
    margin-bottom: 0.5rem;
    background: linear-gradient(90deg, #edf2f8 25%, #f6f9fd 40%, #edf2f8 60%);
    background-size: 220% 100%;
    animation: oppv2-skeleton 1.15s linear infinite;
}

.oppv2-skeleton-line.w-70 { width: 70%; }
.oppv2-skeleton-line.w-60 { width: 60%; }
.oppv2-skeleton-line.w-40 { width: 40%; }

@keyframes oppv2-skeleton {
    from { background-position: 100% 0; }
    to { background-position: 0 0; }
}

@media (min-width: 980px) {
    .oppv2-grid.cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .oppv2-grid .full {
        grid-column: 1 / -1;
    }
}

@media (max-width: 740px) {
    .oppv2-page {
        max-width: 100%;
    }

    .oppv2-hero {
        border-radius: 15px;
    }

    .oppv2-hero-head {
        flex-direction: column;
    }

    .oppv2-hero-head .oppv2-btn {
        width: 100%;
        text-align: center;
    }

    .oppv2-feed-wrap {
        padding: 0.45rem;
    }

    .oppv2-feed {
        max-height: 76vh;
    }

    .oppv2-meta {
        gap: 0.32rem;
        font-size: 0.85rem;
    }

    .oppv2-actions .oppv2-btn {
        flex: 1 1 auto;
        text-align: center;
    }
}

/* Opportunities V3 surface */
.oppv3-page {
    --oppv3-primary: #1b6ec2;
    --oppv3-primary-strong: #1861ac;
    --oppv3-surface: #f5f8fd;
    --oppv3-card: #ffffff;
    --oppv3-border: #d4dfec;
    --oppv3-ink: #13233a;
    --oppv3-muted: #627892;
    --oppv3-verified: #12a37c;
    margin: 0 auto;
    max-width: 920px;
    color: var(--oppv3-ink);
    padding-bottom: 84px;
}

.oppv3-header {
    display: grid;
    gap: 0.32rem;
}

.oppv3-lang-switch {
    display: flex;
    justify-content: flex-end;
    gap: 0.4rem;
}

.oppv3-lang-link {
    border: 1px solid var(--oppv3-border);
    border-radius: 999px;
    color: #325172;
    background: #fff;
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 700;
    padding: 0.26rem 0.6rem;
}

.oppv3-lang-link.is-active,
.oppv3-lang-link:hover {
    border-color: var(--oppv3-primary);
    color: var(--oppv3-primary-strong);
}

.oppv3-shell {
    border: 1px solid var(--oppv3-border);
    border-radius: 16px;
    background: #f7faff;
    padding: 0.52rem 0.52rem 0.42rem;
    box-shadow: 0 4px 12px rgba(17, 51, 92, 0.06);
}

.oppv3-top-rail {
    display: flex;
    align-items: center;
    gap: 0.32rem;
}

.oppv3-kicker {
    margin: 0;
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--oppv3-primary-strong);
    font-weight: 700;
}

.oppv3-title {
    margin: 0.12rem 0 0.52rem;
    font-size: clamp(1.5rem, 3.5vw, 2.15rem);
    line-height: 1.15;
    font-weight: 700;
}

.oppv3-tabs {
    display: flex;
    align-items: center;
    gap: 0.18rem;
    overflow-x: auto;
    scrollbar-width: none;
    flex: 1;
    min-width: 0;
}

.oppv3-tabs::-webkit-scrollbar {
    display: none;
}

.oppv3-tab {
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    background: transparent;
    color: #4f6986;
    font-weight: 700;
    font-size: 0.96rem;
    padding: 0.48rem 0.66rem 0.38rem;
    cursor: pointer;
    white-space: nowrap;
    flex: 0 0 auto;
}

.oppv3-tab.is-active {
    border-bottom-color: var(--oppv3-primary);
    color: #112842;
}

.oppv3-filter-toggle {
    border: 1px solid #bfd0e5;
    background: #fff;
    color: #284868;
    border-radius: 999px;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.18rem;
    line-height: 1;
}

.oppv3-active-filters {
    margin-top: 0.28rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.26rem;
}

.oppv3-active-chip {
    border: 1px solid #c5d7eb;
    border-radius: 999px;
    background: #fff;
    color: #345575;
    font-size: 0.78rem;
    font-weight: 650;
    padding: 0.12rem 0.48rem;
}

.oppv3-filter-details {
    margin-top: 0.54rem;
}

.oppv3-filter-details summary {
    display: inline-flex;
    list-style: none;
    cursor: pointer;
    border: 1px solid #bfd1e8;
    border-radius: 999px;
    background: #fff;
    padding: 0.28rem 0.7rem;
    font-size: 0.87rem;
    font-weight: 600;
    color: #315171;
}

.oppv3-filter-details summary::-webkit-details-marker {
    display: none;
}

.oppv3-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
    margin-top: 0.52rem;
}

.oppv3-chip {
    border: 1px solid #c4d5ea;
    border-radius: 999px;
    background: #fff;
    color: #284664;
    font-size: 0.9rem;
    font-weight: 650;
    padding: 0.36rem 0.76rem;
    cursor: pointer;
}

.oppv3-chip.is-active {
    border-color: var(--oppv3-primary);
    background: var(--oppv3-primary);
    color: #fff;
}

.oppv3-feed-wrap {
    margin-top: 0.46rem;
    border: 1px solid var(--oppv3-border);
    border-radius: 14px;
    background: var(--oppv3-surface);
    padding: 0.42rem;
}

.oppv3-feed {
    display: grid;
    gap: 0.44rem;
    max-height: 74vh;
    overflow-y: auto;
    scroll-snap-type: y mandatory;
    padding-right: 0.12rem;
}

.oppv3-feed.oppv3-feed--inline-open {
    scroll-snap-type: none;
}

.oppv3-card {
    scroll-snap-align: start;
    border: 1px solid #cad9ec;
    border-radius: 14px;
    background: var(--oppv3-card);
    padding: 0.82rem;
    min-height: 260px;
    box-shadow: 0 3px 10px rgba(20, 54, 95, 0.07);
    content-visibility: auto;
    contain-intrinsic-size: 250px;
}

.oppv3-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.6rem;
}

.oppv3-card-title {
    margin: 0.22rem 0 0.2rem;
    font-size: clamp(1.04rem, 2.2vw, 1.42rem);
    line-height: 1.2;
}

.oppv3-card-summary {
    margin: 0.05rem 0 0;
    color: #26425f;
    font-size: 0.96rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.oppv3-meta {
    margin-top: 0.32rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    color: #3a5674;
    font-size: 0.86rem;
}

.oppv3-cta-row {
    margin-top: 0.52rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.oppv3-cta-btn {
    border: 1px solid var(--oppv3-primary);
    background: var(--oppv3-primary);
    color: #fff;
    border-radius: 10px;
    padding: 0.4rem 0.72rem;
    font-weight: 700;
    font-size: 0.9rem;
    cursor: pointer;
}

.oppv3-cta-btn--soft {
    border-color: #bfd0e5;
    background: #fff;
    color: #284868;
}

.oppv3-inline-panel {
    margin-top: 0.46rem;
    border: 1px solid #d7e2f1;
    background: #f9fcff;
    border-radius: 12px;
    padding: 0.55rem;
}

.oppv3-inline-form {
    display: grid;
    gap: 0.48rem;
}

.oppv3-inline-grid {
    display: grid;
    gap: 0.4rem;
}

.oppv3-inline-row {
    display: grid;
    gap: 0.2rem;
}

.oppv3-inline-row label {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 650;
    color: #345474;
}

.oppv3-inline-row input,
.oppv3-inline-input {
    border: 1px solid #bfd0e5;
    border-radius: 10px;
    padding: 0.38rem 0.58rem;
    background: #fff;
    width: 100%;
}

.oppv3-inline-input {
    min-height: 44px;
}

.oppv3-inline-fields {
    display: grid;
    gap: 0.35rem;
}

.oppv3-inline-check {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

.oppv3-inline-actions {
    display: flex;
    justify-content: flex-end;
}

.oppv3-inline-question {
    font-weight: 700;
    color: #193553;
}

.oppv3-inline-status {
    font-size: 0.83rem;
    color: #1c567f;
}

.oppv3-inline-status.is-error {
    color: #a52222;
}

.oppv3-badges {
    display: flex;
    gap: 0.34rem;
    flex-wrap: wrap;
}

.oppv3-badge {
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.16rem 0.56rem;
    font-size: 0.76rem;
    font-weight: 700;
}

.oppv3-badge--category {
    background: #e7f1ff;
    color: #1c4064;
    border-color: #c8ddf7;
}

.oppv3-badge--verified {
    background: #d5f6ec;
    color: #0b5d48;
    border-color: #a7ebd7;
}

.oppv3-badge--time {
    background: #eee6ff;
    color: #4d2f6f;
    border-color: #d7c8f9;
}

.oppv3-badge--visibility {
    background: #eef3fb;
    color: #3f5775;
    border-color: #d0dceb;
}

.oppv3-badge--registration {
    background: #d8ecff;
    color: #1a4b78;
    border-color: #b9d9f7;
}

.oppv3-badge--answered {
    background: #eef5ff;
    color: #2a4f78;
    border-color: #cfdef3;
}

.oppv3-primary-actions {
    margin-top: 0.42rem;
    display: flex;
    gap: 0.28rem;
    align-items: center;
}

.oppv3-icon-btn {
    border: 1px solid #bfd0e5;
    background: #fff;
    color: #284868;
    border-radius: 999px;
    min-width: 38px;
    height: 38px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: 1.02rem;
    cursor: pointer;
}

.oppv3-btn--soft {
    border-color: #bfd0e5;
    background: #fff;
    color: #284868;
}

.oppv3-icon-btn.is-active {
    border-color: var(--oppv3-primary);
    color: var(--oppv3-primary-strong);
    background: #edf5ff;
}

.oppv3-loader,
.oppv3-empty {
    min-height: 74px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--oppv3-muted);
}

.oppv3-hidden {
    display: none !important;
}

.oppv3-undo-banner {
    position: fixed;
    left: 50%;
    bottom: calc(74px + env(safe-area-inset-bottom));
    transform: translateX(-50%);
    border: 1px solid #bfd0e5;
    background: rgba(255, 255, 255, 0.98);
    border-radius: 999px;
    padding: 0.28rem 0.32rem 0.28rem 0.62rem;
    box-shadow: 0 8px 18px rgba(17, 47, 86, 0.18);
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    z-index: 1200;
}

.oppv3-community-lock {
    border: 1px solid var(--oppv3-border);
    border-radius: 16px;
    background: #fff;
    padding: 0.9rem;
    margin-top: 0.75rem;
}

.oppv3-community-lock h2 {
    margin-top: 0;
    margin-bottom: 0.4rem;
    font-size: 1.18rem;
}

.oppv3-community-lock p {
    margin-bottom: 0.65rem;
    color: var(--oppv3-muted);
}

.oppv3-btn {
    border: 1px solid #bfd0e5;
    border-radius: 12px;
    background: #fff;
    color: #284868;
    font-weight: 650;
    padding: 0.46rem 0.85rem;
    text-decoration: none;
    cursor: pointer;
}

.oppv3-btn--primary {
    border-color: var(--oppv3-primary);
    background: var(--oppv3-primary);
    color: #fff;
}

.oppv3-sheet {
    position: fixed;
    inset: 0;
    z-index: 1150;
}

.oppv3-sheet-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(6, 19, 38, 0.54);
}

.oppv3-sheet-panel {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: min(560px, 100%);
    border-radius: 18px 18px 0 0;
    background: #fff;
    border: 1px solid var(--oppv3-border);
    padding: 0.85rem;
    box-shadow: 0 -10px 30px rgba(17, 47, 86, 0.2);
}

.oppv3-sheet-panel--filters {
    max-height: min(76vh, 600px);
    overflow-y: auto;
}

.oppv3-filter-group {
    margin-bottom: 0.7rem;
}

.oppv3-filter-group-title {
    margin: 0;
    color: #395a7a;
    font-size: 0.86rem;
    font-weight: 700;
}

.oppv3-sheet-panel h3 {
    margin-top: 0;
    margin-bottom: 0.55rem;
}

.oppv3-sheet-item {
    width: 100%;
    text-align: left;
    border: 1px solid #d0ddec;
    border-radius: 10px;
    background: #fff;
    color: #1f3f61;
    padding: 0.5rem 0.7rem;
    margin-bottom: 0.42rem;
    font-weight: 620;
    cursor: pointer;
}

.oppv3-sheet-actions {
    margin-top: 0.6rem;
    display: flex;
    gap: 0.45rem;
    justify-content: flex-end;
}

.oppv3-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: 64px;
    border-top: 1px solid #cad9eb;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(8px);
    display: none;
    z-index: 1120;
    padding: 0.2rem 0.2rem 0.15rem;
}

.oppv3-bottom-nav a,
.oppv3-bottom-nav button {
    flex: 1;
    border: none;
    background: transparent;
    color: #2a4968;
    font-size: 0.84rem;
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    flex-direction: column;
    gap: 0.12rem;
    align-items: center;
    justify-content: center;
    min-width: 0;
}

.oppv3-nav-icon {
    font-size: clamp(1.18rem, 2.8vw, 1.38rem);
    line-height: 1;
}

.oppv3-nav-label {
    font-size: clamp(0.75rem, 1.8vw, 0.82rem);
    line-height: 1.1;
    white-space: nowrap;
}

.oppv3-nav-slot {
    flex: 1;
}

#oppv3-bottom-nav .oppv3-bottom-plus {
    flex: 0 0 46px !important;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 1px solid #8bb4e4 !important;
    background: #1b6ec2 !important;
    background-color: #1b6ec2 !important;
    background-image: none !important;
    color: #fff !important;
    font-size: 1.78rem !important;
    line-height: 1;
    align-self: flex-start;
    justify-self: center;
    margin-top: -12px;
    box-shadow: 0 8px 14px rgba(17, 56, 98, 0.3);
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 800;
    forced-color-adjust: none;
}

#oppv3-bottom-nav .oppv3-bottom-plus::before {
    content: none;
}

.oppv2-page--padded {
    padding-bottom: 90px;
}

@media (max-width: 1024px) {
    .oppv3-page {
        padding-bottom: 86px;
    }

    .oppv3-feed-wrap {
        padding-bottom: calc(0.48rem + env(safe-area-inset-bottom));
    }

    .oppv3-feed {
        max-height: none;
        overflow-y: visible;
        scroll-snap-type: none;
        padding-bottom: calc(90px + env(safe-area-inset-bottom));
    }

    .oppv3-inline-panel {
        scroll-margin-bottom: calc(124px + env(safe-area-inset-bottom));
        padding-bottom: calc(1.2rem + env(safe-area-inset-bottom));
    }

    .oppv3-inline-actions {
        position: sticky;
        bottom: calc(70px + env(safe-area-inset-bottom));
        z-index: 3;
        background: linear-gradient(180deg, rgba(249, 252, 255, 0.7) 0%, rgba(249, 252, 255, 1) 38%);
        padding-top: 0.45rem;
        margin-top: 0.3rem;
    }

    .oppv2-submit-actions {
        position: sticky;
        bottom: calc(70px + env(safe-area-inset-bottom));
        background: rgba(255, 255, 255, 0.96);
        border: 1px solid #d7e2f1;
        border-radius: 12px;
        padding: 0.5rem;
        z-index: 12;
        backdrop-filter: blur(4px);
    }

    .oppv3-bottom-nav {
        display: flex;
        align-items: center;
        gap: 0.24rem;
        padding-bottom: max(0.15rem, env(safe-area-inset-bottom));
    }
}

@media (max-width: 720px) {
    .oppv3-shell {
        border-radius: 13px;
    }

    .oppv3-tabs {
        gap: 0.08rem;
    }

    .oppv3-feed {
        max-height: none;
    }

    .oppv3-meta {
        display: grid;
        gap: 0.25rem;
    }

    .oppv3-cta-btn {
        flex: 1;
        text-align: center;
    }
}

@media (max-width: 420px) {
    .oppv3-bottom-nav {
        height: 62px;
        gap: 0.12rem;
        padding-inline: 0.08rem;
    }

    .oppv3-nav-label {
        font-size: 0.72rem;
    }

    #oppv3-bottom-nav .oppv3-bottom-plus {
        width: 44px;
        height: 44px;
        flex-basis: 44px !important;
    }
}
