:root {
    font-size: 100%;
    --main-color: #fffaee;
    --light-color: #ffffff;
    --dark-color: rgba(116, 6, 6, 0.8);
    --dark-bg-color: #212529;
    --gold: #c9a96e;
    --gold-dim: #a07840;
    --bg: #111010;
    --bg-card: #1a1918;
    --bg-raised: #222120;
    --text: #ede8e1;
    --text-muted: #8a7e72;
    --border: rgba(201, 169, 110, .14);
    --r: 10px;
    --transition: .22s ease;
}

html {
    height: 100%;
    -webkit-text-size-adjust: none;
    -ms-text-size-adjust: none;
    font-size: 62.5%;
}

body {
    color: var(--text);
    margin: 0;
    padding: 0;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    background: var(--bg);
    font-family: 'Inter', sans-serif;
    font-size: 15px;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--light-color);
    margin: 0;
    text-transform: uppercase;
}

.dark-text { color: var(--dark-color) !important; }
.light-text { color: var(--light-color) !important; }

/* ════════════════════════════════════════════════════
   HEADER
   ════════════════════════════════════════════════════ */

.header {
    background-color: #0a0908 !important;
    border-bottom: 1px solid rgba(201,169,110,.25);
    box-shadow: 0 2px 20px rgba(0,0,0,.6);
    font-family: 'Inter', sans-serif;
}
.header::after {
    content: '';
    display: block;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
    opacity: .4;
}

.header .logo,
.header .navbar-brand {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--gold) !important;
    letter-spacing: .05em;
    text-decoration: none;
}

.header a,
.header .nav-link {
    color: rgba(237,232,225,.75) !important;
    font-size: .78rem;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: color var(--transition);
    padding: .4rem .7rem;
}
.header a:hover,
.header .nav-link:hover { color: var(--gold) !important; }

.header .nav-link.active,
.header a.active { color: var(--gold) !important; }

.header .dropdown-menu {
    background: #0f0e0d;
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,.5);
    padding: .4rem 0;
    margin-top: 4px;
}
.header .dropdown-item {
    color: var(--text-muted) !important;
    font-size: .78rem;
    font-weight: 500;
    letter-spacing: .05em;
    text-transform: uppercase;
    padding: .5rem 1rem;
    transition: background var(--transition), color var(--transition);
}
.header .dropdown-item:hover {
    background: rgba(201,169,110,.08);
    color: var(--gold) !important;
}

/* ── Hamburger ── */
@media (min-width: 768px) {
    .navbar-toggler { display: none !important; }
}
@media (max-width: 767.98px) {
    .navbar-toggler { display: flex !important; }
}
.navbar-toggler {
    border: 1px solid rgba(201,169,110,.35) !important;
    border-radius: 6px !important;
    width: 38px !important;
    height: 38px !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
}
.navbar-toggler:focus {
    box-shadow: 0 0 0 2px rgba(201,169,110,.3) !important;
    outline: none !important;
}
.navbar-toggler-icon { display: none !important; }

.tog-bar {
    display: block !important;
    width: 20px !important;
    height: 2px !important;
    min-height: 2px !important;
    background: var(--gold) !important;
    border-radius: 2px !important;
    transition: transform .25s ease, opacity .2s ease !important;
    transform-origin: center !important;
    flex-shrink: 0 !important;
    font-size: 0 !important;
    line-height: 0 !important;
}
.navbar-toggler:not(.collapsed) .tog-bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg) !important;
}
.navbar-toggler:not(.collapsed) .tog-bar:nth-child(2) {
    opacity: 0 !important;
    transform: scaleX(0) !important;
}
.navbar-toggler:not(.collapsed) .tog-bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg) !important;
}

/* ════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════ */

.footer {
    background-color: #0a0908 !important;
    border-top: 1px solid rgba(201,169,110,.2);
    color: var(--text-muted) !important;
    font-size: .8rem;
    line-height: 1.8;
    padding: 1.5rem 1rem !important;
    box-shadow: none !important;
    margin-top: auto;
    text-align: center;
}
.footer::before {
    content: '';
    display: block;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(201,169,110,.4), transparent);
    margin-bottom: 1rem;
}
.footer a {
    color: var(--gold) !important;
    text-decoration: none;
    transition: opacity var(--transition);
}
.footer a:hover { opacity: .75; text-decoration: underline; }

/* ════════════════════════════════════════════════════
   LEGACY / ОБЩИЕ
   ════════════════════════════════════════════════════ */

.catalog-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
    padding: 20px;
}

.catalog-item {
    position: relative;
    width: 282px;
    height: 420px;
    overflow: hidden;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.catalog-item__details {
    padding: 10px;
    position: absolute;
    bottom: 0;
    width: 100%;
    background-color: var(--dark-color);
    font-size: small;
    color: var(--main-color);
    height: 120px;
    display: flex;
    flex-direction: column;
}
.catalog-item__details ul { display: inline-flex; padding: 0; margin: 0; }
.catalog-item__details li { list-style: none; display: inline-block; margin: 0; }

.parameters-down {
    display: flex;
    justify-content: space-between;
    padding: 10px;
    border: solid 1px var(--main-color);
}
.parameters-down span { font-size: small; color: var(--main-color); }

.detail-image {
    position: relative;
    width: 100%;
    height: auto;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.main-text { padding: 20px; color: var(--main-color); font-size: small; }

.title-wrapper { text-align: center; margin: 20px auto; }

.like-btn {
    position: absolute;
    top: 12px; right: 12px;
    background: rgba(17,16,16,.75);
    backdrop-filter: blur(8px);
    border: 1px solid var(--border);
    border-radius: 50px;
    color: var(--text);
    padding: 5px 13px;
    font-size: .82rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: background var(--transition), border-color var(--transition);
}
.like-btn:hover,
.like-btn.liked { background: var(--gold); border-color: var(--gold); color: #111; }
.like-icon { font-size: 1rem; line-height: 1; color: inherit; transition: color 0.2s; }
.like-count { color: inherit; transition: color 0.2s; }

.spisok-uslug li { list-style: none; padding: 0; margin: 0; color: var(--main-color); }
.spisok-uslug li a { color: var(--dark-color); text-decoration: none; }
.uslug { color: var(--light-color) !important; text-decoration: none; }
del { color: var(--dark-color); }

.page-wrap { padding: 2rem 0 4rem; }

/* ════════════════════════════════════════════════════
   GALLERY
   ════════════════════════════════════════════════════ */

.main-photo {
    position: relative;
    border-radius: var(--r);
    overflow: hidden;
    background: var(--bg-card);
    box-shadow: 0 20px 50px rgba(0,0,0,.55);
}
.main-photo img { width: 100%; display: block; transition: transform .4s ease; }
.main-photo:hover img { transform: scale(1.02); }

.thumb-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    margin-top: 6px;
}
.thumb-row a { border-radius: 7px; overflow: hidden; display: block; background: var(--bg-card); }
.thumb-row img { width: 100%; height: 90px; object-fit: cover; transition: transform .3s ease, opacity .3s; }
.thumb-row a:hover img { transform: scale(1.06); opacity: .9; }

.video-wrap { margin-top: 8px; border-radius: var(--r); overflow: hidden; background: var(--bg-card); }
.video-wrap video { width: 100%; display: block; }

/* ════════════════════════════════════════════════════
   DETAIL PAGE — INFO
   ════════════════════════════════════════════════════ */

.profile-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    color: var(--text);
    line-height: 1.1;
    margin: 0 0 .25rem;
}
.profile-sub {
    font-size: .78rem;
    color: var(--text-muted);
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-bottom: 1.4rem;
}

.phone-wrap { margin-bottom: 1.1rem; }
.phone-link {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--gold);
    text-decoration: none;
    letter-spacing: .02em;
    transition: color var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.phone-link:hover { color: var(--gold-dim); }

.phone-reveal-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 22px;
    background: transparent;
    border: 1px solid var(--gold);
    color: var(--gold);
    border-radius: 6px;
    font-size: .9rem; font-weight: 600;
    letter-spacing: .04em;
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}
.phone-reveal-btn:hover {
    background: var(--gold);
    color: #111;
}

.messengers { display: flex; gap: 8px; margin-bottom: 1.2rem; }
.msg-btn {
    width: 42px; height: 42px;
    border-radius: 50%;
    background: var(--bg-raised);
    border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    text-decoration: none;
    transition: border-color var(--transition), background var(--transition);
}
.msg-btn:hover { background: var(--gold); border-color: var(--gold); }
.msg-btn img { width: 24px; height: 24px; }

.badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 1.1rem; }
.badge-pill {
    display: inline-flex; align-items: center;
    padding: 5px 15px; border-radius: 50px;
    font-size: .75rem; font-weight: 600;
    letter-spacing: .07em; text-transform: uppercase;
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}
.badge-apt  { background: rgba(201,169,110,.1); color: var(--gold); border: 1px solid rgba(201,169,110,.35); }
.badge-vyezd{ background: rgba(100,160,220,.1); color: #6da4d8;     border: 1px solid rgba(100,160,220,.3); }
.badge-apt:hover   { background: var(--gold); color: #111; }
.badge-vyezd:hover { background: #6da4d8;     color: #111; }

.calltime { font-size: .82rem; color: var(--text-muted); display: flex; align-items: center; gap: 5px; }
.calltime strong { color: var(--text); }

.owner-btns { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 1.4rem; }
.owner-btns .btn {
    font-size: .78rem; padding: 5px 14px;
    border-color: var(--border); color: var(--text-muted);
    background: transparent; border-radius: 6px;
    transition: border-color var(--transition), color var(--transition);
}
.owner-btns .btn:hover { border-color: var(--gold); color: var(--gold); }

.price-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    margin-bottom: 1.6rem;
}
.price-card table { width: 100%; margin: 0; border-collapse: collapse; }
.price-card thead th {
    background: var(--bg-raised);
    color: var(--text-muted);
    font-size: .7rem; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase;
    padding: .6rem 1rem;
    border-bottom: 1px solid var(--border);
}
.price-card tbody td {
    padding: .6rem 1rem;
    border-bottom: 1px solid var(--border);
    font-size: .88rem;
}
.price-card tbody tr:last-child td { border-bottom: none; }
.price-card .row-lbl { color: var(--text-muted); font-size: .8rem; }
.price-val { color: var(--gold); font-weight: 700; }

.specs-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 1.5rem;
    margin-bottom: 1.4rem;
}
.spec-row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: .42rem 0;
    border-bottom: 1px solid var(--border);
    font-size: .87rem;
}
.spec-label { color: var(--text-muted); }
.spec-value { color: var(--text); font-weight: 500; text-align: right; }
.spec-value a { color: var(--gold); text-decoration: none; }
.spec-value a:hover { text-decoration: underline; }

.story-card {
    background: var(--bg-card);
    border-left: 3px solid var(--gold);
    border-radius: 0 var(--r) var(--r) 0;
    padding: 1.1rem 1.4rem;
    font-size: .9rem;
    line-height: 1.8;
    color: var(--text-muted);
}

/* ════════════════════════════════════════════════════
   SERVICES
   ════════════════════════════════════════════════════ */

.services-wrap {
    background: var(--bg-card);
    border-top: 1px solid var(--border);
    padding: 3rem 0 3.5rem;
    margin-top: 3rem;
}
.services-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem; font-weight: 700;
    color: var(--text);
    margin-bottom: 2rem;
    position: relative; display: inline-block;
}
.services-title::after {
    content: '';
    position: absolute; bottom: -6px; left: 0;
    width: 36px; height: 2px;
    background: var(--gold);
}

.svc-cat { margin-bottom: 2rem; }
.svc-cat-title {
    font-size: .68rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--gold);
    margin-bottom: .7rem; padding-bottom: .5rem;
    border-bottom: 1px solid var(--border);
}
.svc-list { list-style: none; padding: 0; margin: 0; }
.svc-list li {
    padding: .32rem 0;
    border-bottom: 1px solid rgba(201,169,110,.06);
    font-size: .87rem; line-height: 1.4;
}
.svc-list li:last-child { border-bottom: none; }
.svc-list a { color: var(--text); text-decoration: none; transition: color var(--transition); }
.svc-list a:hover { color: var(--gold); }
.svc-price {
    margin-left: 6px;
    background: rgba(201,169,110,.1); color: var(--gold);
    border-radius: 4px; padding: 1px 6px;
    font-size: .74rem; font-weight: 700;
}
.svc-comment { font-size: .77rem; color: var(--text-muted); margin: 2px 0 0; line-height: 1.4; }

/* ════════════════════════════════════════════════════
   CATALOG PAGE
   ════════════════════════════════════════════════════ */

.catalog-page { padding: 2rem 0 4rem; }

.catalog-heading {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    font-weight: 700;
    color: var(--text);
    text-transform: none;
    letter-spacing: .02em;
    margin: 0 0 .3rem;
}
.catalog-heading::after {
    content: '';
    display: block; height: 2px; width: 40px;
    background: var(--gold); margin-top: 8px;
}

.filter-accordion {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    margin-bottom: 1.8rem;
    overflow: hidden;
}
.filter-toggle {
    display: flex; align-items: center; justify-content: space-between;
    padding: .85rem 1.2rem;
    cursor: pointer; user-select: none;
    background: var(--bg-raised);
    border: none; width: 100%;
    color: var(--text);
    font-family: 'Inter', sans-serif;
    font-size: .82rem; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase;
    transition: background var(--transition);
}
.filter-toggle:hover { background: #2a2826; }
.filter-toggle-label { display: flex; align-items: center; gap: 8px; }
.filter-toggle-label svg { color: var(--gold); }
.filter-arrow { transition: transform .25s ease; color: var(--text-muted); }
.filter-toggle[aria-expanded="true"] .filter-arrow { transform: rotate(180deg); }

.filter-body {
    display: none;
    padding: 1.2rem 1.4rem 1.4rem;
    border-top: 1px solid var(--border);
}
.filter-body.open { display: block; }

.filter-group-label {
    font-size: .68rem; font-weight: 600;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--gold); margin-bottom: .6rem;
}
.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 1rem; }
.filter-chip {
    display: inline-flex; align-items: center;
    padding: 4px 13px; border-radius: 50px;
    font-size: .74rem; font-weight: 500;
    border: 1px solid var(--border);
    color: var(--text-muted); background: transparent;
    cursor: pointer; text-decoration: none;
    transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.filter-chip:hover,
.filter-chip.active { border-color: var(--gold); color: var(--gold); background: rgba(201,169,110,.08); }

.filter-apply {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 20px;
    background: var(--gold); color: #111;
    border: none; border-radius: 6px;
    font-size: .78rem; font-weight: 700;
    letter-spacing: .06em; text-transform: uppercase;
    cursor: pointer;
    transition: background var(--transition);
}
.filter-apply:hover { background: var(--gold-dim); }

.filter-group-toggle {
    display: inline-flex; align-items: center; gap: 8px;
    background: none; border: none; padding: 0;
    cursor: pointer; color: var(--gold);
    font-size: .68rem; font-weight: 600;
    letter-spacing: .12em; text-transform: uppercase;
    margin-bottom: .4rem;
}
.filter-group-toggle .filter-arrow {
    transition: transform .25s ease;
    color: var(--text-muted);
}
.filter-group-toggle[aria-expanded="true"] .filter-arrow {
    transform: rotate(180deg);
}

.filter-services-body {
    display: none;
    border-top: 1px solid var(--border);
    padding-top: .8rem;
    margin-top: .2rem;
}
.filter-services-body.open {
    display: block;
}

.anketa-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 16px;
}

.anketa-card {
    position: relative;
    border-radius: var(--r); overflow: hidden;
    background: var(--bg-card);
    border: 1px solid var(--border);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.anketa-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0,0,0,.5);
    border-color: rgba(201,169,110,.35);
}
.anketa-card__img-wrap {
    position: relative; overflow: hidden; aspect-ratio: 2/3;
}
.anketa-card__img-wrap img {
    width: 100%; height: 100%; object-fit: cover;
    display: block; transition: transform .4s ease;
}
.anketa-card:hover .anketa-card__img-wrap img { transform: scale(1.05); }

.card-status-badges {
    position: absolute; top: 8px; left: 8px;
    display: flex; flex-direction: column; gap: 4px;
}
.card-badge-vip {
    background: var(--gold); color: #111;
    font-size: .6rem; font-weight: 800;
    letter-spacing: .1em; text-transform: uppercase;
    padding: 2px 8px; border-radius: 3px;
}
.card-badge-top {
    background: rgba(231,76,106,.85); color: #fff;
    font-size: .6rem; font-weight: 800;
    letter-spacing: .1em; text-transform: uppercase;
    padding: 2px 8px; border-radius: 3px;
}

.anketa-card .like-btn {
    position: absolute; top: 8px; right: 8px;
    background: rgba(17,16,16,.7);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 50px; color: #ccc;
    padding: 3px 9px; font-size: .75rem; cursor: pointer;
    display: flex; align-items: center; gap: 4px;
    transition: background .2s, color .2s;
    z-index: 2;
}
.anketa-card .like-btn:hover,
.anketa-card .like-btn.liked { background: #e74c6a; color: #fff; border-color: #e74c6a; }

.anketa-card__body { padding: 10px 12px 12px; }
.anketa-card__name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem; font-weight: 700;
    color: var(--text); text-decoration: none;
    display: block; line-height: 1.2; margin-bottom: 2px;
    transition: color var(--transition);
}
.anketa-card__name:hover { color: var(--gold); }
.anketa-card__age { font-size: .74rem; color: var(--text-muted); margin-bottom: 8px; }

.anketa-card__price { display: flex; align-items: baseline; gap: 5px; margin-bottom: 8px; }
.price-label { font-size: .68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; }
.price-amount { font-size: .95rem; font-weight: 700; color: var(--gold); }
.price-unit { font-size: .7rem; color: var(--text-muted); }

.anketa-card__metro {
    font-size: .72rem; color: var(--text-muted);
    display: flex; align-items: center; gap: 4px; margin-bottom: 8px;
}
.anketa-card__metro svg { flex-shrink: 0; color: var(--gold); }
.anketa-card__metro a { color: var(--text-muted); text-decoration: none; transition: color var(--transition); }
.anketa-card__metro a:hover { color: var(--gold); }

.anketa-card__params {
    display: flex; gap: 6px; flex-wrap: wrap;
    border-top: 1px solid var(--border); padding-top: 8px;
}
.param-chip {
    font-size: .68rem; background: var(--bg-raised);
    border-radius: 4px; padding: 2px 7px;
    display: flex; gap: 3px; align-items: center;
}
.param-chip span:first-child { color: var(--text-muted); }
.param-chip span:last-child  { color: var(--text); font-weight: 500; }

.catalog-pagination {
    display: flex; justify-content: center; flex-wrap: wrap; gap: 6px;
    margin-top: 2.5rem;
}
.catalog-pagination .page-link {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-muted);
    border-radius: 6px; padding: 6px 14px; font-size: .8rem;
    transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.catalog-pagination .page-link:hover {
    border-color: var(--gold); color: var(--gold); background: rgba(201,169,110,.07);
}
.catalog-pagination .page-item.active .page-link {
    background: var(--gold); border-color: var(--gold); color: #111; font-weight: 700;
}

.seo-block {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1.5rem 1.8rem; margin-top: 2.5rem;
    font-size: .87rem; line-height: 1.8; color: var(--text-muted);
}
.seo-block h2,
.seo-block h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem; font-weight: 700;
    color: var(--text); text-transform: none;
    margin: 1rem 0 .4rem;
}

/* ════════════════════════════════════════════════════
   FAQ — Bootstrap accordion dark theme
   ════════════════════════════════════════════════════ */

.faq { margin: 2rem 0; }

.faq h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; font-weight: 700;
    color: var(--text); text-transform: none;
    margin-bottom: 1.2rem;
    display: inline-block; position: relative;
}
.faq h2::after {
    content: ''; display: block;
    height: 2px; width: 36px;
    background: var(--gold); margin-top: 6px;
}

.faq .accordion-item {
    background: var(--bg-raised);
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    margin-bottom: 6px; overflow: hidden;
}
.faq .accordion-button {
    background: var(--bg-raised);
    color: var(--text);
    font-size: .87rem; font-weight: 500;
    padding: .85rem 1.1rem;
    box-shadow: none !important; border: none;
}
.faq .accordion-button:hover { color: var(--gold); }
.faq .accordion-button:not(.collapsed) {
    background: var(--bg-raised); color: var(--gold);
    box-shadow: none !important;
}
.faq .accordion-button::after {
    filter: invert(1) sepia(1) saturate(2) hue-rotate(5deg) brightness(.9);
}
.faq .accordion-button:not(.collapsed)::after {
    filter: invert(72%) sepia(30%) saturate(600%) hue-rotate(5deg) brightness(1);
}
.faq .accordion-collapse { border-top: 1px solid var(--border); }
.faq .accordion-body {
    background: var(--bg-card);
    color: var(--text-muted) !important;
    font-size: .84rem; line-height: 1.75;
    padding: .9rem 1.1rem;
}
.faq .accordion-body.dark-text { color: var(--text-muted) !important; }

/* ════════════════════════════════════════════════════
   DETAIL PAGE — специфичные классы
   ════════════════════════════════════════════════════ */

.page-body { padding: 24px 0 60px; }

.update-date {
    font-size: .74rem;
    color: var(--text-muted);
    margin-bottom: 10px;
}

/* Галерея — боковые миниатюры */
.thumbs-list {
    display: flex; flex-direction: column; gap: 6px;
    width: 80px; flex-shrink: 0;
}
.thumbs-list a {
    display: block; border-radius: 4px; overflow: hidden;
    border: 2px solid transparent;
    transition: border-color .2s;
}
.thumbs-list a:hover,
.thumbs-list a.active { border-color: var(--gold); }
.thumbs-list img { width: 80px; height: 60px; object-fit: cover; display: block; }

.main-photo-area { display: flex; gap: 8px; align-items: flex-start; }
.main-photo-wrap {
    flex: 1; position: relative;
    border-radius: var(--r); overflow: hidden;
    background: var(--bg-card);
}
.main-photo-wrap img { width: 100%; display: block; }

.photo-count-badge {
    position: absolute; bottom: 10px; left: 10px;
    background: rgba(0,0,0,.6);
    color: #fff; font-size: .75rem; font-weight: 600;
    padding: 3px 10px; border-radius: 4px;
    display: flex; align-items: center; gap: 5px;
}
.photo-count-badge svg { width: 13px; height: 13px; }

.fancybox-hidden { display: none; }

/* Шапка профиля */
.profile-header {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 10px;
}
.profile-num { color: var(--text-muted); font-size: .78rem; font-weight: 500; }

.profile-desc {
    font-size: .88rem; color: var(--text-muted);
    margin-bottom: 14px; font-style: italic;
}

/* Телефон */
.phone-row {
    display: flex; align-items: center; gap: 12px;
    flex-wrap: wrap; margin-bottom: 14px;
}

/* Badges */
.badges-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.tag-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 4px 13px; border-radius: 4px;
    font-size: .74rem; font-weight: 600;
    letter-spacing: .04em; text-transform: uppercase;
    border: 1px solid; text-decoration: none;
    transition: background .2s;
}
.tag-apt   { border-color: var(--gold);  color: var(--gold);  background: transparent; }
.tag-vyezd { border-color: #5b9bd5;      color: #5b9bd5;      background: transparent; }
.tag-apt:hover   { background: var(--gold);  color: #111; }
.tag-vyezd:hover { background: #5b9bd5;      color: #111; }
.tag-calltime { font-size: .78rem; color: var(--text-muted); display: flex; align-items: center; gap: 4px; }
.tag-calltime strong { color: var(--text); }

/* Owner row */
.owner-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.owner-row .btn {
    font-size: .75rem; padding: 4px 12px;
    border: 1px solid var(--border);
    color: var(--text-muted); background: transparent;
    border-radius: 4px;
    transition: border-color var(--transition), color var(--transition);
}
.owner-row .btn:hover { border-color: var(--gold); color: var(--gold); }

/* Характеристики */
.chars-table { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.chars-table td {
    padding: 5px 6px;
    border-bottom: 1px solid var(--border);
    font-size: .82rem;
}
.chars-table .char-label { color: var(--text-muted); width: 38%; }
.chars-table .char-value { font-weight: 600; text-transform: uppercase; font-size: .78rem; color: var(--text); }
.chars-table .char-value a { color: var(--gold); text-decoration: none; }
.chars-table .char-value a:hover { text-decoration: underline; }

/* Цены */
.prices-section { margin-bottom: 20px; }
.section-title {
    font-size: .7rem; font-weight: 700; letter-spacing: .14em;
    text-transform: uppercase; color: var(--text-muted);
    margin-bottom: 10px; padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
    display: inline-block;
}

.price-table { width: 100%; border-collapse: collapse; }
.price-table th {
    background: var(--bg-raised);
    border: 1px solid var(--border);
    padding: 6px 10px;
    font-size: .72rem; font-weight: 600;
    letter-spacing: .06em; text-transform: uppercase;
    color: var(--text-muted); text-align: left;
}
.price-table td {
    border: 1px solid var(--border);
    padding: 7px 10px; font-size: .82rem;
    color: var(--text);
}
.price-table .row-lbl {
    font-size: .78rem; color: var(--text-muted);
    display: flex; align-items: center; gap: 6px;
}
.price-dash { color: var(--text-muted); }

/* Услуги на детальной */
.services-section {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 20px 24px;
    margin-top: 28px;
}
.services-section .section-title { margin-bottom: 16px; }

.svc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0 28px;
}
.svc-cat-name {
    font-size: .68rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 7px; padding-bottom: 4px;
    border-bottom: 1px solid var(--border);
}

/* История */
.story-section {
    background: var(--bg-card);
    border-left: 3px solid var(--gold);
    border-radius: 0 var(--r) var(--r) 0;
    padding: 16px 20px;
    font-size: .88rem; line-height: 1.75;
    color: var(--text-muted);
    margin-top: 16px;
}
.story-section p { margin: 0 0 .5em; }
.story-section p:last-child { margin: 0; }

/* ════════════════════════════════════════════════════
   REVIEWS
   ════════════════════════════════════════════════════ */

.reviews-section {
    margin-top: 2.5rem;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1.5rem 1.8rem;
}

.reviews-header {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 1.4rem;
}
.reviews-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; font-weight: 700;
    color: var(--text);
    position: relative; display: inline-block;
}
.reviews-title::after {
    content: '';
    position: absolute; bottom: -4px; left: 0;
    width: 30px; height: 2px;
    background: var(--gold);
}
.reviews-count {
    background: rgba(201,169,110,.12);
    color: var(--gold);
    font-size: .72rem; font-weight: 700;
    padding: 2px 8px; border-radius: 50px;
    border: 1px solid rgba(201,169,110,.3);
}

/* Список */
.reviews-list { margin-bottom: 2rem; }

.review-item {
    padding: 1rem 0;
    border-bottom: 1px solid var(--border);
}
.review-item:last-child { border-bottom: none; }

.review-top {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap; margin-bottom: .5rem;
}
.review-author {
    font-weight: 600; font-size: .85rem;
    color: var(--text);
}
.review-stars { display: flex; gap: 1px; line-height: 1; }
.review-stars .star       { color: var(--text-muted); font-size: 1rem; }
.review-stars .star.filled{ color: var(--gold);       font-size: 1rem; }
.review-date {
    font-size: .73rem; color: var(--text-muted);
    margin-left: auto;
}
.review-text {
    font-size: .87rem; line-height: 1.7;
    color: var(--text-muted);
}

/* Пусто */
.reviews-empty {
    font-size: .85rem; color: var(--text-muted);
    padding: 1rem 0; margin-bottom: 1.5rem;
}

/* Форма */
.review-form-wrap {
    border-top: 1px solid var(--border);
    padding-top: 1.4rem;
    margin-top: .5rem;
}
.review-form-title {
    font-size: .7rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 1rem;
}

.form-label-dark {
    display: block;
    font-size: .74rem; font-weight: 600;
    letter-spacing: .06em; text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: .35rem;
}

.form-control-dark {
    background: var(--bg-raised) !important;
    border: 1px solid var(--border) !important;
    border-radius: 6px !important;
    color: var(--text) !important;
    font-size: .85rem !important;
    padding: .5rem .8rem !important;
    transition: border-color var(--transition) !important;
    width: 100%;
}
.form-control-dark::placeholder { color: var(--text-muted) !important; }
.form-control-dark:focus {
    border-color: rgba(201,169,110,.5) !important;
    box-shadow: 0 0 0 3px rgba(201,169,110,.1) !important;
    outline: none !important;
    background: var(--bg-raised) !important;
    color: var(--text) !important;
}

.form-select-dark {
    background: var(--bg-raised) !important;
    border: 1px solid var(--border) !important;
    border-radius: 6px !important;
    color: var(--text) !important;
    font-size: .85rem !important;
    padding: .5rem .8rem !important;
    width: 100%;
    cursor: pointer;
    transition: border-color var(--transition) !important;
    /* Стрелка */
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23c9a96e' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right .7rem center !important;
    background-size: 14px !important;
    -webkit-appearance: none;
    appearance: none;
}
.form-select-dark:focus {
    border-color: rgba(201,169,110,.5) !important;
    box-shadow: 0 0 0 3px rgba(201,169,110,.1) !important;
    outline: none !important;
}
.form-select-dark option { background: #222120; color: var(--text); }

.review-submit-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 22px;
    background: transparent;
    border: 1px solid var(--gold);
    color: var(--gold);
    border-radius: 6px;
    font-size: .78rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}
.review-submit-btn:hover {
    background: var(--gold);
    color: #111;
}

/* ════════════════════════════════════════════════════
   LATEST REVIEWS (главная)
   ════════════════════════════════════════════════════ */

.latest-reviews {
    margin-top: 2rem;
    margin-bottom: 2rem;
}
.latest-reviews__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; font-weight: 700;
    color: var(--text);
    margin-bottom: 1rem;
    position: relative; display: inline-block;
}
.latest-reviews__title::after {
    content: '';
    position: absolute; bottom: -4px; left: 0;
    width: 30px; height: 2px;
    background: var(--gold);
}
.latest-reviews__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
}

.latest-review-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 1rem 1.2rem;
    transition: border-color var(--transition);
}
.latest-review-card:hover {
    border-color: rgba(201,169,110,.35);
}
.latest-review-card__top {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: .35rem;
}
.latest-review-card__name {
    font-weight: 700; font-size: .9rem;
    color: var(--gold);
    text-decoration: none;
    transition: opacity var(--transition);
}
.latest-review-card__name:hover { opacity: .8; }

.latest-review-card__stars { display: flex; gap: 1px; }
.latest-review-card__stars .star        { color: var(--text-muted); font-size: .9rem; }
.latest-review-card__stars .star.filled { color: var(--gold);       font-size: .9rem; }

.latest-review-card__author {
    font-size: .72rem; color: var(--text-muted);
    margin-bottom: .5rem;
}
.latest-review-card__text {
    font-size: .83rem; line-height: 1.6;
    color: var(--text-muted);
    margin-bottom: .6rem;
}
.latest-review-card__date {
    font-size: .7rem; color: var(--text-muted);
    opacity: .7;
}