/* ============================================================
THE VELVET ROOM — Bootstrap 5 Theme Override
Shared across all pages via <link rel="stylesheet">
============================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── CSS Variables ── */
:root {
    --vr-ink: #252525;
    --vr-ink-2: #141416;
    --vr-ink-3: #1E1E21;
    --vr-ink-4: #2A2A2E;
    --vr-gold: #ff4d12;
    --vr-gold-lt: #ff7a18;
    --vr-gold-dk: #cc3d0e;
    --vr-cream: #F7F3EC;
    --vr-cream-2: #EDE8DF;
    --vr-muted: #72716E;
    --vr-subtle: #3C3C40;
    --vr-border: rgba(255, 77, 18, .18);
    --vr-border-2: rgba(255, 77, 18, .32);
    --vr-radius-sm: 14px;
    --vr-radius-md: 20px;
    --vr-radius-lg: 28px;
    --vr-shadow-sm: 0 12px 30px rgba(0, 0, 0, .08);
    --vr-shadow-md: 0 18px 50px rgba(0, 0, 0, .12);
    --vr-shadow-lg: 0 28px 80px rgba(0, 0, 0, .18);
    --vr-green: #4ade80;
    --bs-body-bg: var(--vr-cream);
    --bs-body-color: var(--vr-ink);
    --bs-body-font-family: 'DM Sans', system-ui, sans-serif;
    --bs-link-color: var(--vr-gold-dk);
    --bs-link-hover-color: var(--vr-gold);
    --bs-border-radius: 14px;
    --vr-glass-dark: rgba(20, 20, 22, .72);
    --vr-glass-light: rgba(255, 255, 255, .72);
    --vr-ring-gold: 0 0 0 4px rgba(255, 77, 18, .10);
}

html {
    scroll-behavior: smooth;
}

body {
    font-weight: 400;
    line-height: 1.65;
    background:
        radial-gradient(circle at top center, rgba(255, 77, 18, .05), transparent 34%),
        linear-gradient(180deg, #faf7f2 0%, #f7f3ec 100%);
}

/* ── Typography ── */
.ff-display {
    font-family: 'Cormorant', Georgia, serif !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: 'Cormorant', Georgia, serif;
    font-weight: 300;
}

/* ── Topbar ── */
.vr-topbar {
    background: var(--vr-ink);
    border-bottom: 1px solid var(--vr-border);
    padding: 9px 0;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: .05em;
}

.vr-topbar .club-link {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--vr-gold);
    border: 1px solid var(--vr-border-2);
    padding: 4px 14px;
    border-radius: 999px;
    transition: all .22s;
    text-decoration: none;
}

.vr-topbar .club-link:hover {
    background: var(--vr-gold);
    color: var(--vr-ink);
}

.vr-topbar .phones {
    color: var(--vr-subtle);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.vr-topbar .phones strong {
    color: #fff;
    font-weight: 600;
}

.vr-topbar .phones a {
    color: var(--vr-gold);
    font-weight: 600;
    text-decoration: none;
    transition: color .2s;
}

.vr-topbar .phones a:hover {
    color: var(--vr-gold-lt);
}

.vr-topbar .phones .pipe {
    color: #f4f4f4;
}

/* ── Navbar ── */
.vr-navbar {
    background: rgba(11, 11, 12, 0.88) !important;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255, 77, 18, .12);
    box-shadow: 0 10px 30px rgba(0, 0, 0, .10);
}
.vr-navbar .navbar-brand {
    padding: 10px 0;
    line-height: 1;
}

.vr-navbar .brand-main {
    font-family: 'Cormorant', serif;
    font-size: 24px;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #fff;
    display: block;
    line-height: 1;
}

.vr-navbar .brand-sub {
    font-family: 'DM Sans', sans-serif;
    font-size: 9px;
    font-weight: 500;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--vr-gold);
    display: block;
    margin-top: 2px;
}

.vr-navbar .nav-link {
    font-size: 14px !important;
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #f4f4f4 !important;
    padding: 22px 13px !important;
    transition: color .2s;
    white-space: nowrap;
}

.vr-navbar .nav-link:hover,
.vr-navbar .nav-link.active {
    color: var(--vr-gold) !important;
}
.vr-navbar .nav-link.btn-nav-cta.active {
    color: white!important;
}
.vr-navbar .dropdown-menu {
    background: var(--vr-ink-3);
    border: 1px solid var(--vr-border);
    border-top: 2px solid var(--vr-gold);
    border-radius: var(--vr-radius-sm);
    box-shadow: var(--vr-shadow-md);
    overflow: hidden;
    padding: 6px 0;
    min-width: 210px;
    margin-top: 0;
}

.vr-navbar .dropdown-item {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: #777;
    padding: 8px 18px;
    transition: all .2s;
}

.vr-navbar .dropdown-item:hover {
    color: var(--vr-gold);
    background: rgba(255, 77, 18, .05);
}

.vr-navbar .dropdown-divider {
    border-color: rgba(255, 255, 255, .05);
}

.vr-navbar .dropdown-header {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--vr-gold-dk);
    padding: 6px 18px 3px;
}

.vr-navbar .btn-nav-cta {
    background: linear-gradient(135deg, var(--vr-gold) 0%, var(--vr-gold-lt) 100%);
    color: var(--vr-cream) !important;
    font-weight: 700 !important;
    padding: 10px 20px !important;
    margin-left: 8px;
    border-radius: 14px;
    box-shadow: 0 10px 24px rgba(255, 77, 18, .18);
    transition: transform .2s, box-shadow .2s, background .2s;
}

.vr-navbar .btn-nav-cta:hover {
    background: linear-gradient(135deg, var(--vr-gold-lt) 0%, #ff7a18 100%) !important;
    color: var(--vr-cream) !important;
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(255, 77, 18, .24);
}

.vr-navbar .navbar-toggler {
    border: 1px solid var(--vr-border);
    color: var(--vr-gold);
    padding: 6px 10px;
    border-radius: 12px;
}

.vr-navbar .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='%23C8A96E' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* ── Breadcrumb ── */
.vr-breadcrumb {
    background: var(--vr-ink-3);
    border-bottom: 1px solid var(--vr-border);
    padding: 10px 0;
}

.vr-breadcrumb .breadcrumb {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.vr-breadcrumb .breadcrumb-item a {
    color: var(--vr-gold-dk);
    text-decoration: none;
    transition: color .2s;
}

.vr-breadcrumb .breadcrumb-item a:hover {
    color: var(--vr-gold);
}

.vr-breadcrumb .breadcrumb-item.active {
    color: var(--vr-cream);
}

.vr-breadcrumb .breadcrumb-item+.breadcrumb-item::before {
    color: var(--vr-subtle);
    content: "›";
}

/* ── Marquee ── */
.vr-marquee {
    background: var(--vr-ink-3);
    border-bottom: 1px solid var(--vr-border);
    padding: 10px 0;
    overflow: hidden;
}

.vr-marquee-track {
    display: flex;
    align-items: center;
    gap: 48px;
    animation: marquee-slide 30s linear infinite;
    width: max-content;
    white-space: nowrap;
}

@keyframes marquee-slide {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

.vr-marquee a {
    font-size: 10.5px;
    font-weight: 500;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--vr-gold);
    text-decoration: none;
    transition: color .2s;
}

.vr-marquee a:hover {
    color: var(--vr-gold-lt);
}

.vr-marquee-dot {
    width: 4px;
    height: 4px;
    background: var(--vr-border-2);
    border-radius: 50%;
    flex-shrink: 0;
}

/* ── Buttons ── */
.btn-vr-gold {
    color: var(--vr-ink);
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 13px 28px;
     background: linear-gradient(135deg, var(--vr-gold), var(--vr-gold-lt));
    border-radius: 999px;
    box-shadow: 0 10px 24px rgba(255, 77, 18, .18);
    transition: all .25s ease;
    transition: transform .22s, box-shadow .22s, background .22s;
}

.btn-vr-gold:hover {
    background: linear-gradient(135deg, var(--vr-gold-lt) 0%, #ff7a18 100%);
    color: var(--vr-ink);
    transform: translateY(-2px);
    box-shadow: 0 18px 40px rgba(255, 77, 18, .28);
}

.btn-vr-ghost {
    background: transparent;
    color: var(--vr-gold);
    border: 1px solid var(--vr-border-2);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 12px 26px;
    border-radius: 999px;
    transition: all .22s;
}

.btn-vr-ghost:hover {
    border-color: var(--vr-gold);
    background: rgba(255, 77, 18, .06);
    color: var(--vr-gold);
}

.btn-vr-ghost-w {
    background: transparent;
    color: rgba(255, 255, 255, .75);
    border: 1px solid rgba(255, 255, 255, .2);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 12px 26px;
    border-radius: 999px;
    transition: all .22s;
}

.btn-vr-ghost-w:hover {
    color: #fff;
    border-color: rgba(255, 255, 255, .5);
}

.btn-vr-dark {
    background: var(--vr-ink-3);
    color: #ccc;
    border: 1px solid var(--vr-border);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: 999px;
    transition: all .22s;
}

.btn-vr-dark:hover {
    background: var(--vr-gold);
    color: var(--vr-ink);
    border-color: var(--vr-gold);
}

.btn-vr-wa {
    background: #25D366;
    color: #fff;
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 14px;
    border-radius: 999px;
    transition: background .2s;
}

.btn-vr-wa:hover {
    background: #1da851;
    color: #fff;
}

/* ── Section Labels ── */
.sec-eyebrow {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--vr-gold);
    display: block;
    margin-bottom: 8px;
}

.sec-title {
    font-family: 'Cormorant', serif;
    font-size: clamp(30px, 4vw, 48px);
    font-weight: 300;
    letter-spacing: .03em;
    line-height: 1.15;
    color: var(--vr-ink);
}

.sec-title em {
    color: var(--vr-gold-dk);
    font-style: italic;
}

.sec-title-light {
    color: #fff !important;
}

.sec-title-light em {
    color: var(--vr-gold) !important;
}

.sec-rule {
    width: 48px;
    height: 1px;
    background: linear-gradient(90deg, var(--vr-gold), transparent);
    margin-top: 14px;
}

/* ── Live badge ── */
.live-dot {
    width: 7px;
    height: 7px;
    background: #4ade80;
    border-radius: 50%;
    display: inline-block;
    animation: vr-glow 2.2s ease-in-out infinite;
    flex-shrink: 0;
}

@keyframes vr-glow {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(74, 222, 128, .5);
    }

    50% {
        box-shadow: 0 0 0 5px rgba(74, 222, 128, 0);
    }
}

.live-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #f7f7f7;
}

.live-badge strong {
    color: var(--vr-gold);
}

/* ── Hero ── */
.vr-hero {
    background: #0b0b0c;
    overflow: hidden;
    padding: 96px 0 78px;
    position: relative;
}

.vr-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 1;
}

.vr-hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--vr-gold), transparent);
}

 .vr-hero h1 {
    font-family: 'Cormorant', serif;
    font-size: clamp(44px, 7vw, 82px);
    font-weight: 300;
    letter-spacing: .04em;
    line-height: 1.08;
    color: #fff;
}

.vr-hero h1 em {
    color: var(--vr-gold);
    font-style: italic;
}

.vr-hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.vr-hero-overlay {
    position: relative;
    z-index: 2;
}

.hero-eyebrow {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: var(--vr-gold);
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}

.hero-eyebrow::before,
.hero-eyebrow::after {
    content: '';
    width: 32px;
    height: 1px;
    background: var(--vr-gold-dk);
    display: inline-block;
}

/* ── Escort Card ── */
.vr-card {
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    overflow: hidden;
    box-shadow: 0 18px 60px rgba(0,0,0,.08);
    transition: all .3s ease;
}

.vr-card:hover {
    transform: translateY(-6px) scale(1.01);
    box-shadow: 0 30px 90px rgba(0,0,0,.18);
}

.vr-card .card-img-wrap {
    aspect-ratio: 3/4;
    overflow: hidden;
    position: relative;
    background: var(--vr-cream-2);
}

.vr-card .card-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}

.vr-card:hover .card-img-wrap img {
    transform: scale(1.06);
}

.vr-card .card-ph {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: linear-gradient(160deg, #e8e2d8, #d8d1c4);
    color: #b0a89a;
}

.vr-card .card-ph i {
    font-size: 28px;
    opacity: .4;
}

.vr-card .card-ph span {
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    opacity: .5;
}

.vr-card .ec-badge {
    position: absolute;
    top: 0;
    left: 0;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 0 0 14px 0;
}

.vr-card .ec-badge.avl {
    background: #4ade80;
    color: #052e16;
}

.vr-card .ec-badge.nw {
    background: var(--vr-ink);
    color: var(--vr-gold);
}

.vr-card .ec-badge.elite {
    background: var(--vr-gold);
    color: var(--vr-ink);
}

.vr-card .card-body {
    padding: 16px 18px 14px;
}

.vr-card .ec-name {
    font-family: 'Cormorant', serif;
    font-size: 22px;
    font-weight: 400;
    letter-spacing: .04em;
    color: var(--vr-ink);
    margin-bottom: 4px;
}

.vr-card .ec-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vr-muted);
    margin-bottom: 12px;
}

.vr-card .ec-meta i {
    color: var(--vr-gold);
    font-size: 9px;
}

.vr-card .ec-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 9px 12px;
    /* background: var(--vr-cream);
    border: 1px solid #EDE8DF; */
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--vr-ink);
    text-decoration: none;
    transition: all .22s;
    border-radius: 14px;
}

.vr-card .ec-link i {
    color: var(--vr-gold);
    transition: transform .22s;
}


.vr-card:hover .ec-link i {
    transform: translateX(3px);
    color: var(--vr-ink);
}

/* ── Quick Search ── */
.vr-qs {
    background: var(--vr-ink-2);
    border-bottom: 1px solid var(--vr-border);
    padding: 26px 0;
}

.qs-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: var(--vr-gold-dk);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.qs-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--vr-border);
}

.vr-qs input,
.vr-qs select {
    background: var(--vr-ink-3) !important;
    border: 1px solid var(--vr-border) !important;
    color: #ccc !important;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px !important;
    padding: 10px 14px !important;
    border-radius: 2px !important;
    outline: none;
    height: 44px;
    transition: border-color .2s;
}

.vr-qs input::placeholder {
    color: #3a3a3e !important;
}

.vr-qs input:focus,
.vr-qs select:focus {
    border-color: var(--vr-gold-dk) !important;
    box-shadow: none !important;
}

.vr-qs select option {
    background: var(--vr-ink-3);
    color: #ccc;
}

.vr-qs .qs-field-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--vr-gold-dk);
    margin-bottom: 5px;
    display: block;
}

.vr-qs .toggle-wrap {
    height: 44px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.vr-toggle {
    position: relative;
    width: 42px;
    height: 24px;
    flex-shrink: 0;
}

.vr-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
}

.vr-toggle-slider {
    position: absolute;
    inset: 0;
    background: var(--vr-ink-4);
    border: 1px solid var(--vr-border);
    border-radius: 24px;
    cursor: pointer;
    transition: .3s;
}

.vr-toggle-slider::before {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    left: 3px;
    top: 3px;
    background: var(--vr-subtle);
    border-radius: 50%;
    transition: .3s;
}

.vr-toggle input:checked+.vr-toggle-slider {
    background: var(--vr-gold-dk);
    border-color: var(--vr-gold-dk);
}

.vr-toggle input:checked+.vr-toggle-slider::before {
    transform: translateX(18px);
    background: #fff;
}

.qs-toggle-text {
    font-size: 12px;
    color: #666;
}

.qs-results-info {
    font-size: 12px;
    color: var(--vr-subtle);
    margin-top: 12px;
    display: none;
}

.qs-results-info.show {
    display: block;
}

.qs-results-info strong {
    color: var(--vr-gold);
}

/* ── Guarantee boxes ── */
.vr-guarantee {
    background: linear-gradient(180deg, #fff 0%, #fcfaf6 100%);
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    padding: 22px 18px;
    position: relative;
    overflow: hidden;
    box-shadow: var(--vr-shadow-sm);
    transition: border-color .22s, transform .22s, box-shadow .22s;
}

.vr-guarantee:hover {
    border-color: var(--vr-gold-dk);
    transform: translateY(-3px);
    box-shadow: var(--vr-shadow-md);
}

.vr-guarantee::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--vr-gold), transparent);
}

.vr-guarantee i {
    color: var(--vr-gold);
    font-size: 18px;
    margin-bottom: 10px;
    display: block;
}

.vr-guarantee strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--vr-ink);
    margin-bottom: 6px;
}

.vr-guarantee p {
    font-size: 12.5px;
    color: var(--vr-muted);
    margin: 0;
    line-height: 1.55;
    font-weight: 300;
}

/* ── About section headers ── */
.vr-section-h3 {
    font-family: 'Cormorant', serif;
    font-size: 22px;
    font-weight: 400;
    color: var(--vr-ink);
    margin-bottom: 12px;
    letter-spacing: .03em;
    display: flex;
    align-items: center;
    gap: 14px;
}

.vr-section-h3::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #EDE8DF;
}

/* ── Locations ── */
.vr-loc-tag {
    display: inline-block;
    background: var(--vr-cream);
    padding: 8px 18px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--vr-subtle);
    border-radius: 999px;
    transition: all .22s;
    text-decoration: none;
}

.vr-loc-tag:hover {
    color: var(--vr-gold);
    background: var(--vr-cream-2);
}

/* ── Reviews ── */
.vr-review {
    background: linear-gradient(180deg, #fff 0%, #fcfaf6 100%);
    border: 1px solid rgba(255, 77, 18, .14);
    border-top: 3px solid var(--vr-gold);
    padding: 26px 22px;
    position: relative;
    border-radius: var(--vr-radius-md);
    box-shadow: var(--vr-shadow-sm);
}

.vr-review::before {
    content: '\201C';
    font-family: 'Cormorant', serif;
    font-size: 72px;
    opacity: .45;
    line-height: 1;
    color: #EDE8DF;
    position: absolute;
    top: 14px;
    left: 18px;
}
.vr-review .stars {
    position: relative;
}
.vr-review .stars i {
    color: var(--vr-gold);
    font-size: 14px;
}

.vr-review .review-text {
    font-size: 14px;
    color: var(--vr-muted);
    line-height: 1.8;
    font-style: italic;
    font-weight: 300;
}

.vr-review .review-author {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--vr-ink);
}

.vr-review .review-escort {
    font-size: 14px;
    color: var(--vr-gold-dk);
}

.vr-review .review-date {
    font-size: 14px;
    color: var(--vr-muted);
}

/* ── FAQ ── */
.vr-accordion .accordion-item {
    background: transparent;
    border: none;
    border-bottom: 1px solid #EDE8DF;
    border-radius: 0 !important;
}

.vr-accordion .accordion-button {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    font-weight: 500;
    color: var(--vr-ink);
    background: transparent;
    padding: 20px 0;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.vr-accordion .accordion-button:not(.collapsed) {
    color: var(--vr-ink);
    background: transparent;
}

.vr-accordion .accordion-button::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M1 3l5 5 5-5' stroke='%238B6E3A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
}

.vr-accordion .accordion-body {
    padding: 0 0 18px;
    font-size: 14px;
    color: var(--vr-muted);
    line-height: 1.85;
    font-weight: 300;
}

/* ── Footer ── */
.vr-footer {
    background: linear-gradient(180deg, #0a0b0c 0%, #070708 100%);
    border-top: 1px solid var(--vr-border);
    position: relative;
}

.vr-footer::before {
    content: '';
    position: absolute;
    top: -120px;
    pointer-events: none;
    left: 50%;
    transform: translateX(-50%);
    width: 780px;
    height: 320px;
    background: radial-gradient(ellipse, rgba(255, 77, 18, .08) 0%, transparent 70%);
}
.vr-footer .foot-brand-name {
    font-family: 'Cormorant', serif;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #fff;
}

.vr-footer .foot-brand-sub {
    font-size: 9px;
    font-weight: 500;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--vr-gold);
    display: block;
    margin-top: 2px;
    margin-bottom: 14px;
}

.vr-footer p {
    font-size: 13px;
    color: #f9f9f9;
    font-weight: 300;
    line-height: 1.75;
}

.vr-footer .foot-heading {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: var(--vr-gold-dk);
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--vr-border);
}

.vr-footer .foot-link {
    font-size: 12.5px;
    color: #f9f9f9;
    text-decoration: none;
    font-weight: 300;
    transition: color .2s;
    display: block;
    margin-bottom: 7px;
}

.vr-footer .foot-link:hover {
    color: var(--vr-gold);
}

.vr-footer .foot-social a {
    width: 32px;
    height: 32px;
    border: 1px solid var(--vr-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--vr-subtle);
    font-size: 12px;
    border-radius: 2px;
    margin-right: 6px;
    transition: all .2s;
    text-decoration: none;
}

.vr-footer .foot-social a:hover {
    border-color: var(--vr-gold-dk);
    color: var(--vr-gold);
}

.vr-footer .foot-copy {
    font-size: 14px;
    color: #f9f9f9;
}

.vr-footer .foot-legal {
    font-size: 14px;
    color: #f9f9f9;
    line-height: 1.65;
    font-weight: 300;
}

.vr-footer .foot-rule {
    height: 1px;
    background: linear-gradient(90deg, var(--vr-border), transparent);
}

/* ── Sidebar filters ── */
.vr-filter-card {
    background: #fff;
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    overflow: hidden;
    margin-bottom: 16px;
    box-shadow: var(--vr-shadow-sm);
}

.vr-filter-card .filter-head {
    background: var(--vr-ink-3);
    padding: 13px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.vr-filter-card .filter-head h3 {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--vr-gold);
    margin: 0;
}

.vr-filter-card .filter-head button {
    background: none;
    border: none;
    color: var(--vr-subtle);
    font-size: 14px;
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    transition: color .2s;
}

.vr-filter-card .filter-head button:hover {
    color: var(--vr-gold);
}

.filter-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--vr-muted);
    margin-bottom: 8px;
    display: block;
}

.filter-input {
    width: 100%;
    background: var(--vr-cream);
    border: 1px solid #EDE8DF;
    color: var(--vr-ink);
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    padding: 9px 12px;
    outline: none;
    border-radius: 14px;
    transition: border-color .2s;
}

.filter-input:focus {
    border-color: var(--vr-gold-dk);
    box-shadow: none;
}

.filter-input::placeholder {
    color: #bbb;
}

.filter-check {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    margin-bottom: 7px;
}

.filter-check input[type=checkbox] {
    width: 15px;
    height: 15px;
    accent-color: var(--vr-gold-dk);
    cursor: pointer;
    flex-shrink: 0;
}

.filter-check .fc-label {
    font-size: 13px;
    color: var(--vr-muted);
    font-weight: 400;
    transition: color .2s;
}

.filter-check:hover .fc-label {
    color: var(--vr-ink);
}

.filter-check .fc-count {
    margin-left: auto;
    font-size: 10px;
    color: #bbb;
    background: var(--vr-cream-2, #EDE8DF);
    padding: 1px 7px;
    border-radius: 20px;
}

.filter-avail {
    display: flex;
    align-items: center;
    gap: 10px;
}

.filter-avail span {
    font-size: 12.5px;
    color: var(--vr-muted);
}

.filter-select {
    width: 100%;
    background: var(--vr-cream);
    border: 1px solid #EDE8DF;
    color: var(--vr-ink);
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    padding: 9px 12px;
    outline: none;
    border-radius: 14px;
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238B6E3A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 28px;
}

.filter-select:focus {
    border-color: var(--vr-gold-dk);
    box-shadow: none;
}

.btn-filter-reset {
    width: 100%;
    padding: 9px;
    background: transparent;
    border: 1px solid #EDE8DF;
    color: var(--vr-muted);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: 999px;
    transition: all .2s;
}

.btn-filter-reset:hover {
    border-color: var(--vr-gold-dk);
    color: var(--vr-gold-dk);
}

.filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--vr-ink-3);
    border: 1px solid var(--vr-border);
    padding: 4px 10px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--vr-gold);
    border-radius: 999px;
}

.filter-tag button {
    background: none;
    border: none;
    color: var(--vr-subtle);
    font-size: 9px;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: color .2s;
}

.filter-tag button:hover {
    color: var(--vr-gold);
}

/* ── Listing toolbar ── */
.listing-count {
    font-size: 13px;
    color: var(--vr-muted);
    font-weight: 300;
}

.listing-count strong {
    color: var(--vr-ink);
    font-weight: 600;
}

.view-btn {
    background: none;
    border: 1px solid #EDE8DF;
    color: var(--vr-muted);
    width: 34px;
    height: 34px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    transition: all .2s;
    padding: 0;
    border-radius: 12px;
}

.view-btn.active,
.view-btn:hover {
    border-color: var(--vr-gold-dk);
    color: var(--vr-gold-dk);
}

/* list view */
.list-view .vr-card {
    display: grid !important;
    grid-template-columns: 180px 1fr;
}

.list-view .vr-card .card-img-wrap {
    aspect-ratio: unset;
    min-height: 220px;
}

.list-view .vr-card .card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 22px 24px;
}

.list-view .vr-card .ec-name {
    font-size: 28px;
}

/* ── Profile: Stats grid ── */
.stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: #EDE8DF;
    border: 1px solid #EDE8DF;
    margin-bottom: 32px;
}

.stat-cell {
    background: #fff;
    padding: 14px 16px;
}

.stat-cell .s-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--vr-muted);
    margin-bottom: 3px;
}

.stat-cell .s-value {
    font-family: 'Cormorant', serif;
    font-size: 19px;
    font-weight: 400;
    color: var(--vr-ink);
}

/* ── Profile: Rates table ── */
.vr-rates {
    width: 100%;
    border-collapse: collapse;
}

.vr-rates th {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--vr-muted);
    text-align: left;
    padding: 10px 14px;
    background: var(--vr-cream-2, #EDE8DF);
    border-bottom: 1px solid #EDE8DF;
}

.vr-rates td {
    padding: 12px 14px;
    font-size: 14px;
    color: var(--vr-muted);
    font-weight: 300;
    border-bottom: 1px solid #EDE8DF;
    background: #fff;
    vertical-align: middle;
}

.vr-rates tr:last-child td {
    border-bottom: none;
}

.vr-rates td strong {
    color: var(--vr-ink);
    font-weight: 600;
}

.vr-rates td.price {
    font-family: 'Cormorant', serif;
    font-size: 18px;
    color: var(--vr-gold-dk);
    font-weight: 400;
}

.vr-rates tr:hover td {
    background: var(--vr-cream);
}

/* ── Booking sidebar ── */
.booking-card {
    background: #fff;
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: var(--vr-shadow-sm);
}

.booking-head {
    background: var(--vr-cream);
    padding: 20px 22px;
    position: relative;
}

.booking-head::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--vr-gold), transparent);
}

.booking-head .b-name {
    font-family: 'Cormorant', serif;
    font-size: 30px;
    font-weight: 300;
    letter-spacing: .06em;
    color: var(--vr-ink-2);
    line-height: 1.1;
}

.booking-head .b-tier {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--vr-gold);
}

.avail-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(74, 222, 128, .12);
    border: 1px solid rgba(74, 222, 128, .25);
    color: #1a6b33;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 999px;
    margin-top: 10px;
}

.avail-pill-dot {
    width: 6px;
    height: 6px;
    background: #4ade80;
    border-radius: 50%;
    animation: vr-glow 2s infinite;
}

.bq-item {
    background: var(--vr-cream);
    border: 1px solid #EDE8DF;
    padding: 10px 12px;
    border-radius: 14px;
}

.bq-label {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--vr-muted);
    margin-bottom: 3px;
}

.bq-val {
    font-family: 'Cormorant', serif;
    font-size: 17px;
    font-weight: 400;
    color: var(--vr-ink);
}

.btn-book-call {
    width: 100%;
    padding: 15px;
    background: var(--vr-gold);
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--vr-ink);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background .2s;
    border-radius: 999px;
    margin-bottom: 8px;
}

.btn-book-call:hover {
    background: var(--vr-gold-lt);
}

.btn-book-wa {
    width: 100%;
    padding: 13px;
    background: #25D366;
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background .2s;
    border-radius: 999px;
    margin-bottom: 8px;
}

.btn-book-wa:hover {
    background: #1da851;
}

.btn-book-email {
    width: 100%;
    padding: 12px;
    background: transparent;
    border: 1px solid #EDE8DF;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--vr-muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all .2s;
    border-radius: 999px;
}

.btn-book-email:hover {
    border-color: var(--vr-gold-dk);
    color: var(--vr-gold-dk);
}

.book-note {
    font-size: 14px;
    color: var(--vr-muted);
    text-align: center;
    line-height: 1.6;
    font-weight: 300;
    margin-top: 12px;
}

.book-note i {
    color: var(--vr-gold-dk);
}

.info-card {
    background: #fff;
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    padding: 18px 20px;
    margin-bottom: 14px;
    box-shadow: var(--vr-shadow-sm);
}

.info-card h4 {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--vr-gold-dk);
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid #EDE8DF;
}

.info-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 7px 0;
    border-bottom: 1px solid #EDE8DF;
}

.info-row:last-child {
    border-bottom: none;
}

.info-row .ik {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--vr-muted);
}

.info-row .iv {
    font-family: 'Cormorant', serif;
    font-size: 16px;
    font-weight: 400;
    color: var(--vr-ink);
}

.info-row .iv.gold {
    color: var(--vr-gold-dk);
}

.guarantee-card {
    background: linear-gradient(180deg, var(--vr-cream-2) 0%, #f4f4f4 100%);
    border: 1px solid var(--vr-border);
    padding: 18px 20px;
    border-radius: var(--vr-radius-md);
    box-shadow: 0 20px 50px rgba(0, 0, 0, .24);
}

.guarantee-card h4 {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--vr-gold);
    margin-bottom: 12px;
}

.guarantee-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 9px;
}

.guarantee-item:last-child {
    margin-bottom: 0;
}

.guarantee-item i {
    color: var(--vr-gold);
    font-size: 12px;
    margin-top: 2px;
    flex-shrink: 0;
}

.guarantee-item span {
    font-size: 12px;
    color: #666;
    line-height: 1.55;
    font-weight: 300;
}

/* ── Gallery ── */
.vr-gallery-main {
    /* background: var(--vr-ink-3); */
    overflow: hidden;
    aspect-ratio: 4/5;
    /* max-height: 620px; */
    width: 100%;
    border-radius: 14px;
    position: relative;
}

.vr-gallery-main .gallery-ph {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: linear-gradient(160deg, #1e1e22, #141416);
    color: var(--vr-subtle);
}

.vr-gallery-main .gallery-ph i {
    font-size: 48px;
    opacity: .3;
}

.vr-gallery-main .gallery-ph em {
    font-family: 'Cormorant', serif;
    font-size: 28px;
    font-weight: 300;
    color: var(--vr-gold-dk);
    opacity: .6;
    font-style: italic;
}

.vr-gallery-main .gallery-ph span {
    font-size: 14px;
    letter-spacing: .14em;
    text-transform: uppercase;
    opacity: .4;
}

.gallery-avail-badge {
    position: absolute;
    top: 16px;
    right: 16px;
    background: #4ade80;
    color: #052e16;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 6px 14px;
    display: flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
}

.gallery-avail-dot {
    width: 6px;
    height: 6px;
    background: #052e16;
    border-radius: 50%;
    animation: vr-glow 2s infinite;
}

.gallery-nav-btns {
    position: absolute;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 6px;
}

.gallery-nav-btn {
    width: 36px;
    height: 36px;
    background: rgba(0, 0, 0, .6);
    border: 1px solid rgba(255, 255, 255, .15);
    color: rgba(255, 255, 255, .8);
    font-size: 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    border-radius: 12px;
}

.gallery-nav-btn:hover {
    background: var(--vr-gold);
    border-color: var(--vr-gold);
    color: var(--vr-ink);
}

.gallery-count {
    position: absolute;
    bottom: 16px;
    right: 16px;
    background: rgba(0, 0, 0, .6);
    color: rgba(255, 255, 255, .7);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .08em;
    padding: 4px 10px;
}

.gallery-thumb {
    aspect-ratio: 3/4;
    /* background: #EDE8DF; */
    cursor: pointer;
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #bbb;
    font-size: 12px;
}

.gallery-thumb.active {
    border-color: var(--vr-gold);
    border-radius: 18px;
}

.gallery-thumb:hover {
    border-color: var(--vr-gold-dk);
}

/* ── Profile header ── */
.profile-tier-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--vr-gold);
    margin-bottom: 10px;
}

.profile-name {
    font-family: 'Cormorant', serif;
    font-size: clamp(44px, 6vw, 68px);
    font-weight: 300;
    letter-spacing: .06em;
    line-height: 1;
    margin-bottom: 16px;
    color: var(--vr-ink);
}

.profile-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .06em;
    background: #fff;
    border: 1px solid #EDE8DF;
    padding: 6px 14px;
    color: var(--vr-muted);
    border-radius: 999px;
}

.profile-tag i {
    color: var(--vr-gold);
    font-size: 10px;
}

.profile-tag.tag-avail {
    background: #4ade80;
    border-color: #4ade80;
    color: #052e16;
    font-weight: 600;
}

.profile-tag.tag-avail i {
    color: #052e16;
}

/* ── Services ── */
.service-item {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid #EDE8DF;
    padding: 10px 13px;
    font-size: 13px;
    color: var(--vr-muted);
    font-weight: 300;
    border-radius: 14px;
}

.service-item i {
    color: var(--vr-gold);
    font-size: 10px;
    flex-shrink: 0;
}

/* ── Profile review ── */
.vr-profile-review {
    background: linear-gradient(180deg, #fff 0%, #fcfaf6 100%);
    border: 1px solid rgba(255, 77, 18, .14);
    border-radius: var(--vr-radius-md);
    padding: 24px 22px;
    position: relative;
    margin-bottom: 16px;
    box-shadow: var(--vr-shadow-sm);
}

.vr-profile-review::before {
    content: '\201C';
    font-family: 'Cormorant', serif;
    font-size: 60px;
    line-height: 1;
    color: #EDE8DF;
    position: absolute;
    top: 12px;
    left: 16px;
}

.verified-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    color: #1a6b33;
    background: rgba(74, 222, 128, .12);
    padding: 2px 8px;
    border-radius: 999px;
    font-weight: 600;
    letter-spacing: .06em;
}

/* ── Pagination ── */
.vr-page-btn {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 1px solid #EDE8DF;
    font-size: 13px;
    font-weight: 500;
    color: var(--vr-muted);
    cursor: pointer;
    transition: all .2s;
    text-decoration: none;
    border-radius: 12px;
}

.vr-page-btn:hover,
.vr-page-btn.active {
    background: var(--vr-gold);
    border-color: var(--vr-gold);
    color: var(--vr-ink);
}

.vr-page-btn.disabled {
    opacity: .35;
    pointer-events: none;
}

/* ── Modern surface polish ── */
.vr-card .ec-link,
.vr-loc-tag,
.filter-input,
.filter-select,
.btn-filter-reset,
.service-item,
.bq-item,
.profile-tag,
.vr-page-btn,
.view-btn {
    transition: all .22s ease;
}

.filter-input:focus,
.filter-select:focus {
    box-shadow: 0 0 0 4px rgba(255, 77, 18, .10);
}

.vr-loc-tag:hover,
.profile-tag:hover,
.service-item:hover {
    transform: translateY(-1px);
}

/* ── Duo section ── */
.vr-duo {
    background: var(--vr-ink);
    position: relative;
    overflow: hidden;
}

.vr-duo::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 80% at 50% 50%, rgba(255, 77, 18, .07) 0%, transparent 65%);
    pointer-events: none;
}

/* ── Recruit section ── */
.vr-recruit {
    background: var(--vr-ink);
    position: relative;
    overflow: hidden;
}

.vr-recruit::before {
    content: '';
    position: absolute;
    bottom: -100px;
    left: 50%;
    transform: translateX(-50%);
    width: 600px;
    height: 400px;
    background: radial-gradient(ellipse, rgba(255, 77, 18, .06) 0%, transparent 65%);
    pointer-events: none;
}

.recruit-icon {
    width: 56px;
    height: 56px;
    border: 1px solid var(--vr-border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 22px;
}

.recruit-icon i {
    color: var(--vr-gold);
    font-size: 20px;
}

/* ── Page hero ── */
.vr-page-hero {
    background: var(--vr-ink);
    padding: 52px 0 46px;
    position: relative;
    overflow: hidden;
}

.vr-page-hero::before {
    content: '';
    position: absolute;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    width: 700px;
    height: 400px;
    background: radial-gradient(ellipse, rgba(255, 77, 18, .08) 0%, transparent 65%);
    pointer-events: none;
}

.vr-page-hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--vr-gold), transparent);
}
a, button, .btn, .nav-link {
    transition: all .22s ease;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: none;
    box-shadow: var(--vr-ring-gold);
}
.vr-hero-search {
        margin-top: 40px;
        max-width: 860px;
        margin-left: auto;
        margin-right: auto;
    }

    .ai-search-hero-trigger {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 22px;
        width: 100%;
        border: 1px solid rgba(255, 255, 255, 0.08);
        background: rgba(255, 255, 255, 0.04);
        color: #fff;
        border-radius: 30px;
        padding: 20px 22px;
        text-align: left;
        overflow: hidden;
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.28);
        transition: transform 0.28s ease, border-color 0.28s ease, background 0.28s ease, box-shadow 0.28s ease;
    }

    .ai-search-hero-trigger::before {
        content: "";
        position: absolute;
        inset: 0;
        background: radial-gradient(circle at top left, rgba(255, 100, 40, 0.16), transparent 34%), radial-gradient(circle at bottom right, rgba(255, 160, 90, 0.09), transparent 34%);
        pointer-events: none;
    }

    .ai-search-hero-trigger:hover {
        transform: translateY(-4px) scale(1.01);
        border-color: rgba(255, 120, 60, 0.28);
        background: rgba(255, 255, 255, 0.06);
        box-shadow: 0 26px 80px rgba(0, 0, 0, 0.34);
    }

    .ai-search-hero-trigger:focus-visible {
        outline: none;
        border-color: rgba(255, 120, 60, 0.48);
        box-shadow: 0 0 0 4px rgba(255, 120, 60, 0.12), 0 26px 80px rgba(0, 0, 0, 0.34);
    }

    .ai-search-hero-text {
        position: relative;
        z-index: 1;
        display: flex;
        flex-direction: column;
        gap: 7px;
        min-width: 0;
        flex: 1 1 auto;
    }

    .ai-search-hero-label {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        color: #ff7a3d;
        text-transform: uppercase;
        letter-spacing: 0.18em;
        font-size: 14px;
        font-weight: 700;
    }

    .ai-search-hero-label::before {
        content: "";
        width: 8px;
        height: 8px;
        border-radius: 999px;
        background: linear-gradient(135deg, #ff5a1f 0%, #ff9a4a 100%);
        box-shadow: 0 0 14px rgba(255, 90, 31, 0.65);
        flex-shrink: 0;
    }

    .ai-search-hero-placeholder {
        color: rgba(255, 255, 255, 0.9);
        font-size: 19px;
        font-weight: 400;
        line-height: 1.45;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .ai-search-hero-hint {
        color: rgba(255, 255, 255, 0.42);
        font-size: 13px;
        font-weight: 400;
        line-height: 1.4;
    }

    .ai-search-hero-btn {
        position: relative;
        z-index: 1;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        min-width: 170px;
        padding: 14px 20px;
        border-radius: 18px;
        background: #fff;
        color: #111;
        font-size: 12px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        flex-shrink: 0;
        box-shadow: 0 10px 30px rgba(255, 255, 255, 0.08);
        transition: transform 0.22s ease, box-shadow 0.22s ease;
    }

    .ai-search-hero-trigger:hover .ai-search-hero-btn {
        transform: translateY(-1px);
        box-shadow: 0 16px 40px rgba(255, 255, 255, 0.12);
    }

    .ai-search-overlay {
        position: fixed;
        inset: 0;
        z-index: 9999;
        display: flex;
        align-items: stretch;
        justify-content: stretch;
        background: rgba(0, 0, 0, 0);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity 0.2s ease, visibility 0.2s ease, background 0.2s ease;
    }

    .ai-search-overlay.is-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        background: rgba(7, 7, 7, 0.96);
    }

    .ai-search-shell {
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
    }

    .ai-search-inner {
        position: relative;
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: #070707;
        padding: 32px;
        transform: scale(1.005);
        opacity: 0;
        transition: transform 0.2s ease, opacity 0.2s ease;
    }

    .ai-search-overlay.is-open .ai-search-inner {

        transform: scale(1);

        opacity: 1;

    }

    .ai-search-panel {
        width: 100%;
        max-width: 760px;
        margin: 0 auto;
        text-align: left;
    }




    .ai-search-form {

        width: 100%;

        max-width: 100%;

        margin: 0;

    }

    .ai-search-input-wrap {
        position: relative;
        border: 0;
        border-bottom: 0px solid rgba(255, 255, 255, 0.14);
        padding-bottom: 0px;
    }

    .ai-search-input-wrap:focus-within {
        border-bottom-color: rgba(255, 255, 255, 0.2);
    }

    .ai-search-textarea {
        width: 100%;
        min-height: 72px;
        height: auto;
        resize: none;
        border: 0;
        border-radius: 0;
        background: transparent;
        color: #f3f3f3;
        padding: 0;
        font-size: clamp(20px, 2.2vw, 28px);
        line-height: 1.35;
        font-weight: 400;
        text-align: left;
        outline: none;
        box-shadow: none;
        overflow: hidden;
        letter-spacing: -0.01em;
    }

    .ai-search-textarea::placeholder {
        color: rgba(255, 255, 255, 0.38);
    }



    .ai-search-close {
        position: absolute;
        top: 22px;
        right: 22px;
        width: 40px;
        height: 40px;
        border: 0;
        border-radius: 999px;
        background: transparent;
        color: rgba(255, 255, 255, 0.72);
        font-size: 16px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: color 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
        opacity: 0.9;
    }

    .ai-search-close:hover {
        transform: scale(1.04);
        color: #fff;
        opacity: 1;
    }

    body.ai-search-active {
        overflow: hidden;
    }

    @media (max-width: 991.98px) {
        .ai-search-hero-trigger {
            border-radius: 26px;
            padding: 18px;
        }

        .ai-search-hero-placeholder {
            font-size: 17px;
        }

        .ai-search-hero-btn {
            min-width: 150px;
            padding: 13px 16px;
        }

        .ai-search-inner {
            padding: 24px;
        }
    }

    @media (max-width: 767.98px) {
        .vr-hero-search {
            margin-top: 24px;
        }

        .ai-search-hero-trigger {
            flex-direction: column;
            align-items: stretch;
            gap: 14px;
            border-radius: 24px;
            padding: 16px;
        }

        .ai-search-hero-placeholder {
            white-space: normal;
            font-size: 16px;
        }

        .ai-search-hero-hint {
            font-size: 12px;
        }

        .ai-search-hero-btn {
            width: 100%;
            min-width: 0;
        }

        .ai-search-inner {
            padding: 20px;
            align-items: center;
        }

        .ai-search-panel {
            margin-top: auto;
            margin-bottom: auto;
        }

        .ai-search-textarea {
            min-height: 56px;
            font-size: clamp(18px, 5.6vw, 24px);
            line-height: 1.4;
        }

        .ai-search-close {
            top: 12px;
            right: 12px;
            width: 36px;
            height: 36px;
            font-size: 14px;
        }
    }