:root {
    --pp-blue-900: #2348a6;
    --pp-blue-700: #3f66cc;
    --pp-blue-500: #6288ea;
    --pp-gold-500: #f1ba2f;
    --pp-gold-400: #ffd86f;
    --pp-ink-900: #11183f;
    --pp-ink-700: #414b77;
    --pp-ink-500: #69739a;
    --pp-border: #d8e1f4;
    --pp-bg-soft: #f6f9ff;
    --pp-bg-alt: #eff4ff;
    --pp-shadow-md: 0 14px 30px rgba(39, 68, 151, 0.12);
    --pp-shadow-sm: 0 8px 20px rgba(38, 66, 146, 0.08);
    --pp-radius-xl: 24px;
    --pp-radius-lg: 16px;
    --pp-radius-md: 12px;
}

/* Refresh shared public header/footer so the page does not inherit legacy dark blocks. */
body {
    background: #f3f7ff;
    font-family: "Manrope", "Noto Sans", "Segoe UI", sans-serif;
}

header .navbar.navbar-expand-lg.navbar-light.sticky-top {
    background: rgba(255, 255, 255, 0.96) !important;
    border-bottom: 1px solid #d8e2f6;
    box-shadow: 0 10px 24px rgba(37, 63, 140, 0.08);
    backdrop-filter: blur(10px);
}

header .navbar .container {
    max-width: 1220px;
}

header .navbar-nav .nav-link {
    border-radius: 999px;
    color: #243f94 !important;
    font-weight: 700;
    padding: 0.5rem 0.95rem !important;
}

header .navbar-nav .nav-link:hover,
header .navbar-nav .nav-link:focus {
    color: #1d347f !important;
    background: #ecf2ff;
}

header .btn-outline-upwork {
    border-color: #b8cbfa;
    color: #2f4ea8;
    background: #fff;
}

header .btn-outline-upwork:hover {
    border-color: #9cb4f2;
    color: #213c91;
    background: #eef3ff;
}

header .btn-upwork {
    border-color: #f3c556;
    color: #3f2b00;
    background: linear-gradient(135deg, #f8ce5b 0%, #f0b32a 100%);
    box-shadow: 0 8px 20px rgba(240, 179, 42, 0.3);
}

header .btn-upwork:hover {
    color: #332200;
    background: linear-gradient(135deg, #f8d168 0%, #f2ba3e 100%);
}

.footer {
    margin-top: 0;
    padding: 52px 0 24px;
    background:
        radial-gradient(circle at 88% 14%, rgba(255, 218, 120, 0.24), transparent 34%),
        radial-gradient(circle at 8% 5%, rgba(190, 214, 255, 0.3), transparent 35%),
        linear-gradient(145deg, #f9fbff 0%, #eef4ff 66%, #fbf5e8 100%);
    color: #2d407f;
    border-top: 1px solid #d5e1f8;
}

.footer h5 {
    color: #1a327e;
}

.footer a {
    color: #3551a8;
}

.footer a:hover {
    color: #1f3d93;
}

.footer p,
.footer .text,
.footer .text-muted,
.footer [class*="text-"] {
    color: #50639f !important;
}

.footer .btn.btn-outline-primary {
    border-color: #c5d5fb;
    color: #2f4fa9;
    background: #fff;
}

.footer .btn.btn-outline-primary:hover {
    border-color: #a8bff6;
    color: #203d94;
    background: #edf3ff;
}

.footer .row.mt-4.pt-4 {
    border-top: 1px solid #d7e3fa !important;
}

.prox-list-page,
.prox-detail-page {
    background: linear-gradient(180deg, #f8fbff 0%, #f2f6ff 100%);
    padding: 56px 0 72px;
}

.prox-shell {
    max-width: 1220px;
    margin: 0 auto;
}

.prox-hero,
.prox-toolbar,
.prox-card,
.prox-side-card,
.prox-block {
    border-radius: var(--pp-radius-xl);
    border: 1px solid var(--pp-border);
    background: #fff;
    box-shadow: var(--pp-shadow-sm);
}

.prox-hero {
    padding: 26px;
    margin-bottom: 20px;
    background:
        radial-gradient(circle at 88% 15%, rgba(255, 216, 110, 0.28), transparent 36%),
        radial-gradient(circle at 15% 2%, rgba(178, 206, 255, 0.3), transparent 34%),
        linear-gradient(128deg, #f9fbff 0%, #edf3ff 62%, #f8f2e2 100%);
}

.prox-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid #c8d5f8;
    background: #fff;
    color: #2e4ca7;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 12px;
}

.prox-kicker i {
    color: var(--pp-gold-500);
}

.prox-title {
    margin: 0 0 8px;
    color: var(--pp-ink-900);
    font-size: clamp(1.6rem, 3.2vw, 2.7rem);
    line-height: 1.12;
    letter-spacing: -0.02em;
}

.prox-subtitle {
    margin: 0;
    color: var(--pp-ink-700);
    max-width: 720px;
}

.prox-toolbar {
    padding: 16px;
    margin-bottom: 18px;
}

.prox-toolbar form {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr auto auto;
    gap: 10px;
    align-items: end;
}

.prox-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.prox-field label {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--pp-ink-500);
}

.prox-field input,
.prox-field select {
    width: 100%;
    min-height: 44px;
    border: 1px solid #d3dcf2;
    border-radius: 11px;
    background: var(--pp-bg-soft);
    color: var(--pp-ink-900);
    font-weight: 600;
    padding: 0 12px;
}

.prox-field input:focus,
.prox-field select:focus {
    outline: none;
    border-color: #84a0ee;
    box-shadow: 0 0 0 4px rgba(94, 129, 226, 0.16);
}

.prox-btn,
.prox-btn-outline {
    min-height: 44px;
    border-radius: 11px;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
    padding: 0 16px;
    font-weight: 700;
    transition: all 0.2s ease;
}

.prox-btn {
    background: linear-gradient(135deg, #f6c546 0%, #eeae1f 100%);
    color: #3a2600;
    box-shadow: 0 10px 22px rgba(238, 173, 31, 0.32);
}

.prox-btn:hover {
    color: #2f1f00;
    transform: translateY(-1px);
}

.prox-btn-outline {
    border-color: #b8c8f2;
    background: #fff;
    color: #2f4da9;
}

.prox-btn-outline:hover {
    color: #1f3b8f;
    border-color: #8099e8;
    background: #eef3ff;
}

.prox-results {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    color: var(--pp-ink-700);
    font-weight: 600;
}

.prox-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.prox-card {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.prox-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--pp-shadow-md);
}

.prox-card-head {
    padding: 14px;
    background: linear-gradient(130deg, #f7faff 0%, #e7efff 64%, #f7efda 100%);
}

.prox-avatar-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
}

.prox-avatar,
.prox-avatar-fallback {
    width: 66px;
    height: 66px;
    border-radius: 999px;
    border: 2px solid #fff;
    box-shadow: 0 6px 14px rgba(41, 69, 161, 0.22);
    flex-shrink: 0;
}

.prox-avatar {
    object-fit: cover;
}

.prox-avatar-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, #2f54be 0%, #5f80e9 100%);
}

.prox-name {
    margin: 0 0 2px;
    color: var(--pp-ink-900);
    font-size: 1.12rem;
    line-height: 1.2;
}

.prox-company {
    margin: 0;
    color: var(--pp-ink-500);
    font-size: 0.87rem;
}

.prox-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 12px;
}

.prox-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 0.74rem;
    font-weight: 700;
}

.prox-badge.category {
    background: #fff6de;
    color: #7c5a00;
    border: 1px solid #f5da8f;
}

.prox-badge.city {
    background: #e9f1ff;
    color: #2d4ca7;
    border: 1px solid #bcd0fb;
}

.prox-badge.premium {
    background: #edf9f3;
    color: #1d8f5c;
    border: 1px solid #b7e8cf;
}

.prox-card-body {
    padding: 14px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 10px;
}

.prox-desc {
    margin: 0;
    color: var(--pp-ink-700);
    font-size: 0.9rem;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.prox-card-foot {
    padding: 0 14px 14px;
    margin-top: auto;
}

.prox-empty {
    text-align: center;
    padding: 44px 16px;
    border: 1px dashed #c4d4fd;
    border-radius: var(--pp-radius-lg);
    background: #f8fbff;
    color: var(--pp-ink-700);
}

.prox-empty i {
    font-size: 2rem;
    color: #6687e8;
    margin-bottom: 10px;
}

.prox-pagination {
    margin-top: 22px;
}

.prox-pagination .page-link {
    border-radius: 10px;
    border-color: #ced9f3;
    color: #3150ac;
    font-weight: 600;
    margin: 0 3px;
}

.prox-pagination .page-item.active .page-link {
    background: linear-gradient(135deg, #f5c646 0%, #efb022 100%);
    border-color: #f3c75a;
    color: #402b00;
}

.prox-back {
    margin-bottom: 16px;
}

.prox-back a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: #3150ac;
    font-weight: 700;
}

.prox-back a:hover {
    color: #1f3b8f;
}

.prox-detail-hero {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 18px;
    align-items: center;
}

.prox-detail-avatar,
.prox-detail-avatar-fallback {
    width: 118px;
    height: 118px;
    border-radius: 999px;
    border: 3px solid #fff;
    box-shadow: 0 10px 20px rgba(36, 64, 150, 0.2);
}

.prox-detail-avatar {
    object-fit: cover;
}

.prox-detail-avatar-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, #2f54be 0%, #5f80e9 100%);
}

.prox-detail-name {
    margin: 0 0 6px;
    color: var(--pp-ink-900);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    line-height: 1.1;
}

.prox-detail-company {
    margin: 0 0 10px;
    color: var(--pp-ink-700);
    font-weight: 600;
}

.prox-rating {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 22px;
    font-weight: 700;
    color: var(--pp-ink-700);
}

.prox-rating.is-empty {
    visibility: hidden;
}

.prox-stars {
    display: inline-flex;
    gap: 2px;
}

.prox-stars i {
    color: #d6deee;
}

.prox-stars i.is-active {
    color: #f0b62d;
}

.prox-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(0, 1fr);
    gap: 16px;
}

.prox-side-col {
    position: sticky;
    top: 18px;
    align-self: start;
}

.prox-inline-meta {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}

.prox-block {
    padding: 18px;
    margin-bottom: 14px;
}

.prox-block h3,
.prox-side-card h3 {
    margin: 0 0 12px;
    font-size: 1.1rem;
    color: var(--pp-ink-900);
}

.prox-block p,
.prox-side-card p {
    color: var(--pp-ink-700);
    line-height: 1.65;
    margin: 0;
}

.prox-side-card {
    padding: 18px;
    margin-bottom: 14px;
}

.prox-info-list {
    display: grid;
    gap: 8px;
}

.prox-info-item {
    border: 1px solid #dbe4f6;
    border-radius: 10px;
    background: var(--pp-bg-soft);
    padding: 10px;
}

.prox-info-item strong {
    color: var(--pp-ink-900);
    font-size: 0.85rem;
}

.prox-info-item span {
    display: block;
    margin-top: 2px;
    color: var(--pp-ink-700);
    font-size: 0.9rem;
}

.prox-verify-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid #d8e2f5;
    border-radius: 12px;
    overflow: hidden;
}

.prox-verify-table th,
.prox-verify-table td {
    padding: 10px;
    border-bottom: 1px solid #e3e9f6;
    font-size: 0.9rem;
    color: var(--pp-ink-700);
    vertical-align: top;
}

.prox-verify-table th {
    background: #f6f9ff;
    color: var(--pp-ink-900);
    font-weight: 700;
}

.prox-verify-table tr:last-child td {
    border-bottom: none;
}

.prox-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 700;
}

.prox-status .dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
}

.prox-status.ok {
    color: #1f8e5b;
}

.prox-status.ok .dot {
    background: #23b173;
}

.prox-status.no {
    color: #9b2943;
}

.prox-status.no .dot {
    background: #d64566;
}

.prox-doc-list,
.prox-review-list {
    display: grid;
    gap: 10px;
}

.prox-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.prox-gallery-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.prox-gallery-head h3 {
    margin: 0;
}

.prox-gallery-open-all {
    border: none;
    background: transparent;
    color: #2f4ea9;
    font-weight: 700;
    font-size: 0.9rem;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0;
}

.prox-gallery-open-all:hover {
    color: #1f3b8f;
    text-decoration: underline;
}

.prox-gallery-item {
    border: 1px solid #dbe5f8;
    border-radius: 12px;
    background: #f7faff;
    overflow: hidden;
    padding: 0;
    cursor: pointer;
    min-height: 120px;
}

.prox-gallery-item img {
    width: 100%;
    height: 100%;
    min-height: 120px;
    object-fit: cover;
    display: block;
    transition: transform 0.2s ease;
}

.prox-gallery-item:hover img {
    transform: scale(1.04);
}

.prox-gallery-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(17, 24, 39, 0.9);
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.prox-gallery-lightbox[hidden] {
    display: none !important;
}

.prox-gallery-figure {
    margin: 0;
    max-width: min(100%, 980px);
    max-height: 100%;
    text-align: center;
}

.prox-gallery-figure img {
    width: auto;
    max-width: 100%;
    max-height: calc(100vh - 140px);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: #fff;
}

.prox-gallery-figure figcaption {
    margin-top: 10px;
    color: #e5edff;
    font-size: 0.95rem;
}

.prox-gallery-close,
.prox-gallery-nav {
    border: 1px solid rgba(255, 255, 255, 0.3);
    background: rgba(15, 23, 42, 0.62);
    color: #fff;
    border-radius: 10px;
    min-width: 40px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.prox-gallery-close {
    position: absolute;
    top: 24px;
    right: 24px;
}

.prox-gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.prox-gallery-nav.prev {
    left: 20px;
}

.prox-gallery-nav.next {
    right: 20px;
}

.prox-doc-item,
.prox-review-item {
    border: 1px solid #dbe5f8;
    border-radius: 11px;
    background: #fff;
    padding: 11px;
}

.prox-doc-item a {
    color: #2b4ba6;
    text-decoration: none;
    font-weight: 700;
}

.prox-doc-item a:hover {
    color: #1d3988;
    text-decoration: underline;
}

.prox-review-head {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 6px;
}

.prox-review-name {
    margin: 0;
    color: var(--pp-ink-900);
    font-weight: 700;
}

.prox-review-meta {
    margin: 0;
    color: var(--pp-ink-500);
    font-size: 0.82rem;
}

.prox-copy-btn {
    border: 1px solid #bfd0fb;
    border-radius: 9px;
    background: #fff;
    color: #2f4ea9;
    font-weight: 700;
    padding: 6px 10px;
}

.prox-copy-btn:hover {
    background: #eef3ff;
}

@media (max-width: 1199px) {
    .prox-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .prox-toolbar form {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 991px) {
    .prox-detail-grid {
        grid-template-columns: 1fr;
    }

    .prox-side-col {
        position: static;
        top: auto;
    }
}

@media (max-width: 767px) {
    .prox-list-page,
    .prox-detail-page {
        padding: 36px 0 56px;
    }

    .prox-grid {
        grid-template-columns: 1fr;
    }

    .prox-toolbar form {
        grid-template-columns: 1fr;
    }

    .prox-detail-hero {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .prox-detail-avatar,
    .prox-detail-avatar-fallback {
        margin: 0 auto;
    }

    .prox-results {
        flex-direction: column;
    }

    .prox-gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .prox-gallery-close {
        top: 10px;
        right: 10px;
    }

    .prox-gallery-nav.prev {
        left: 8px;
    }

    .prox-gallery-nav.next {
        right: 8px;
    }
}
