/* =========================================================
   Anahit Nail Studio — Unified Styles (Light + Dark)
   Single CSS file merged from: nailsbyanahit-unified.css + overrides + block css.
   Theme switch uses: html[data-theme="light"] / html[data-theme="dark"]
========================================================= */

:root {
    /* Brand gold (from logo) */
    --gold-1: #E7CF8A;
    --gold-2: #C9A227;

    /* Light palette */
    --baa-bg: #FBF7F0;
    /* warm ivory */
    --baa-surface: #FFFFFF;
    /* cards */
    --baa-surface-2: #F6F0E6;
    /* subtle panels */
    --baa-ink: #1C1A17;
    --baa-ink-soft: rgba(28, 26, 23, .78);
    --baa-muted: #6F6A66;

    --baa-line: rgba(28, 26, 23, .12);
    --baa-rim: rgba(201, 162, 39, .35);

    --baa-cream-1: #F8F3ED;
    --baa-cream-2: #EFE6DA;
    --baa-cream-3: #E6DACF;

    --baa-radius: 22px;
    --baa-radius-pill: 999px;

    --baa-shadow: 0 10px 26px rgba(0, 0, 0, .10);
    --baa-shadow-hover: 0 16px 40px rgba(0, 0, 0, .14);
    --baa-speed: .26s;

    /* Compatibility aliases (used across older blocks) */
    --ink: var(--baa-ink);
    --sub: var(--baa-muted);
    --cream: var(--baa-bg);
    --cream-1: var(--baa-cream-1);
    --cream-2: var(--baa-cream-2);
    --cream-3: var(--baa-cream-3);
    --txt: var(--baa-muted);
    --veil: rgba(255, 255, 255, .55);

    --wrap: 1200px;
    --radius: var(--baa-radius);
    --pill: var(--baa-radius-pill);
    --br-lg: 22px;
    --shadow-1: var(--baa-shadow);
    --shadow-2: var(--baa-shadow-hover);

    /* Experience block aliases */
    --exp-bg: radial-gradient(120% 120% at 20% 0%, rgba(201, 162, 39, .18) 0%, rgba(0, 0, 0, 0) 46%),
        linear-gradient(180deg, rgba(20, 19, 18, .12) 0%, rgba(20, 19, 18, 0) 65%);
    --exp-surface: rgba(255, 255, 255, .08);
    --exp-border: rgba(201, 162, 39, .28);
    --exp-shadow: 0 18px 60px rgba(0, 0, 0, .22);
    --exp-text: rgba(28, 26, 23, .82);
    --exp-muted: rgba(28, 26, 23, .70);
    --exp-gold: var(--gold-2);
}

html[data-theme="dark"] {
    /* Dark palette */
    --baa-bg: #0D0C0B;
    --baa-surface: #141312;
    --baa-surface-2: #1A1918;
    --baa-ink: #FFFFFF;
    --baa-ink-soft: rgba(255, 255, 255, .78);
    --baa-muted: rgba(255, 255, 255, .70);

    --baa-line: rgba(255, 255, 255, .14);
    --baa-rim: rgba(201, 162, 39, .32);

    --veil: rgba(255, 255, 255, .06);

    /* Experience block in dark */
    --exp-text: rgba(255, 255, 255, .86);
    --exp-muted: rgba(255, 255, 255, .70);
    --exp-surface: rgba(255, 255, 255, .06);
    --exp-border: rgba(201, 162, 39, .22);
    --exp-shadow: 0 20px 70px rgba(0, 0, 0, .55);
}

/* Global background helper (optional): apply on body */
html,
body {
    background: var(--baa-bg);
}


/* =========================================================
   SR EFFECT · H1 slide LEFT → RIGHT (Luxury)
========================================================= */

.ans-about-hero__title.sr-item {
    opacity: 0;
    transform: translateX(-600px);
    /* движение слева направо */
    transition:
        opacity .7s ease,
        transform 2ю2s cubic-bezier(.22, 1, .36, 1);
    will-change: transform, opacity;
}

/* Когда появляется */
.ans-about-hero__title.sr-item.is-in {
    opacity: 1;
    transform: translateX(0);
}



/* ============== Эффект ================= */
/* ================================
   DIVIDER B: DIAMOND LUX
================================ */

.baa-divider-diamond {
    position: relative;
    width: 100%;
    height: 70px;
    margin: 0;
    display: grid;
    place-items: center;
    overflow: hidden;
    pointer-events: none;
}

/* the line */
.baa-divider-diamond::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 1px;
    transform: translateY(-50%);
}

/* center diamond */
.baa-divider-diamond__dot {
    width: 14px;
    height: 14px;
    transform: rotate(45deg);
    border-radius: 3px;
    position: relative;
    z-index: 2;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
}

/* DARK */
html[data-theme="dark"] .baa-divider-diamond::before {
    background: linear-gradient(90deg,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, .18) 35%,
            rgba(255, 255, 255, .28) 50%,
            rgba(255, 255, 255, .18) 65%,
            rgba(255, 255, 255, 0) 100%);
}

html[data-theme="dark"] .baa-divider-diamond__dot {
    background: linear-gradient(135deg, #c9a227, #d4b24c);
}

/* LIGHT */
html[data-theme="light"] .baa-divider-diamond::before {
    background: linear-gradient(90deg,
            rgba(0, 0, 0, 0) 0%,
            rgba(0, 0, 0, .14) 35%,
            rgba(0, 0, 0, .22) 50%,
            rgba(0, 0, 0, .14) 65%,
            rgba(0, 0, 0, 0) 100%);
}

html[data-theme="light"] .baa-divider-diamond__dot {
    background: linear-gradient(135deg, #c9a227, #d4b24c);
}

@media (max-width: 640px) {
    .baa-divider-diamond {
        height: 60px;
    }

    .baa-divider-diamond__dot {
        width: 12px;
        height: 12px;
    }
}

/* ============== AND Эффект ================= */


.ct-back-to-top {
    background: #a39e8c !important;
    border-radius: 999px !important;
}

.ct-back-to-top:hover {
    background: #6c6c6c !important;
}




/* ===================== nailsbyanahit-unified.css ===================== */
/* =========================================================
   Nails by Anahit — SINGLE CSS FILE
   Unified Design System + all homepage block styles

   HTML utility classes:
   - .baa-title : apply to all H1/H2/H3
   - .baa-text  : apply to all paragraphs
   - .baa-btn   : apply to all button-style links
     Variants via attribute data-variant:
       primary (default) | outline

   Future Light/Dark ready (token-based)
========================================================= */

:root {
    --baa-bg: #ffffff;
    --baa-surface: #ffffff;
    --baa-ink: #1c1a17;
    --baa-ink-soft: rgba(28, 26, 23, .78);

    /* Cream / champagne button palette */
    --baa-cream-1: #F8F3ED;
    --baa-cream-2: #EFE6DA;
    --baa-cream-3: #E6DACF;

    --baa-rim: rgba(201, 162, 39, .38);

    --baa-radius-pill: 999px;
    --baa-shadow: 0 7px 20px rgba(0, 0, 0, .40);
    --baa-shadow-hover: 0 16px 40px rgba(0, 0, 0, .14);
    --baa-speed: .26s;
}

html[data-theme="dark"] {
    --baa-bg: #0f0e0d;
    --baa-surface: #141312;
    --baa-ink: #ffffff;
    --baa-ink-soft: rgba(255, 255, 255, .78);
}

html[data-theme="dark"] #reviews .rv-card {
    background: #d5c9a7;
}

/* ---------- Typography ---------- */
.baa-title,
#services-alt .svc-title {
    font-family: inherit;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: #664819;
    margin: 0;
}

h1.baa-title {
    font-size: clamp(34px, 4vw, 52px);
    line-height: 1.08;
    letter-spacing: 3px;
    font-family: serif;
}

.ans-about-hero__kicker,
.ans-contact-hero__kicker {
    font-size: clamp(17px, 3vw, 24px);
    line-height: 2;
    font-family: "Playball", Sans-serif;
}

h2.baa-title {
    font-size: clamp(28px, 3vw, 40px);
    line-height: 2;
}

h3.baa-title {
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.18;
}

.baa-text {
    color: var(--baa-ink-soft);
    margin: 0;
    line-height: 1.65;
}

/* ---------- Buttons (one class) ---------- */
.baa-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    padding: 14px 34px;
    min-height: 44px;
    border-radius: var(--baa-radius-pill);

    font: inherit;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;

    cursor: pointer;
    user-select: none;
    -webkit-tap-highlight-color: transparent;

    color: var(--baa-ink);
    background: linear-gradient(180deg, var(--baa-cream-1) 0%, var(--baa-cream-2) 55%, var(--baa-cream-3) 100%);
    border: 1px solid rgba(0, 0, 0, .10);
    box-shadow: var(--baa-shadow), inset 0 1px 0 rgba(255, 255, 255, .78);

    transition: transform var(--baa-speed) ease, box-shadow var(--baa-speed) ease, filter var(--baa-speed) ease, background var(--baa-speed) ease, border-color var(--baa-speed) ease, color var(--baa-speed) ease;

    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.baa-btn[data-variant="outline"] {
    background: rgba(255, 255, 255, .10);
    border: 2px solid var(--baa-rim);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .08);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.baa-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--baa-shadow-hover);
    filter: saturate(1.02);
}

.baa-btn[data-variant="outline"]:hover {
    background: linear-gradient(180deg, rgba(248, 243, 237, .72) 0%, rgba(239, 230, 218, .55) 100%);
    border-color: rgba(201, 162, 39, .52);
}

.baa-btn:active {
    transform: translateY(0);
}

.baa-btn:focus {
    outline: none;
}

.baa-btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(201, 162, 39, .18), 0 0 0 1px rgba(201, 162, 39, .35), var(--baa-shadow);
}

@media (prefers-reduced-motion: reduce) {
    .baa-btn {
        transition: none !important;
    }

    .baa-btn:hover {
        transform: none !important;
    }
}


/* =========================================================
   BLOCK: HERO
========================================================= */
/* ===== Sizes/Colors (сделала выше) */
#nova-hero {
    --nh-height: clamp(600px, 68vh, 820px);
    /* выше и «шире» по кадру */
    --nh-height-m: 60vh;
    --gold-1: #E7CF8A;
    --gold-2: #C9A227;
    --ink: #111;
    --cream: #FBF9F6;
}

#nova-hero {
    position: relative;
    display: block;
    max-width: 1940px;
    margin: 0 auto
}

#nova-hero .nh-stage {
    position: relative;
    height: var(--nh-height);
    background: var(--cream);
    overflow: hidden;
    border-radius: 0
}

/* ===== Slide */
.nh-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity .7s ease
}

.nh-slide.is-active {
    opacity: 1;
    z-index: 2
}

.nh-slide picture,
.nh-slide img {
    display: block;
    width: 100%;
    height: 100%
}

.nh-slide img {
    object-fit: cover;
    transform-origin: 60% 50%;
    animation: kenburns 12s ease-out both
}

.nh-slide:nth-child(2) img {
    transform-origin: center 35%
}

.nh-slide:nth-child(3) img {
    transform-origin: 30% 50%
}

/* Мягкий Ken Burns */
@keyframes kenburns {
    0% {
        transform: scale(1.02)
    }

    100% {
        transform: scale(1.06)
    }
}

/* ===== Очень мягкая вуаль (без «мутности») */
.nh-slide::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .50;
    transition: opacity .4s ease;
    background: linear-gradient(90deg, rgba(0, 0, 0, .50) 0%, rgba(0, 0, 0, .22) 28%, rgba(0, 0, 0, 0) 58%);
}

html[data-theme="light"]::after {
    opacity: .16;
    background: linear-gradient(90deg, rgba(255, 255, 255, .20) 0%, rgba(255, 255, 255, .08) 24%, rgba(255, 255, 255, 0) 55%);
}

/* ===== Glass Card (по правому краю) */
.nh-card {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    max-width: min(560px, 45vw);
    padding: 22px 26px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .32);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    color: var(--ink);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .14);
    opacity: 0;
    translate: 0 10px;
    transition: opacity .5s ease, translate .5s ease
}

.nh-card.nh-right {
    right: clamp(24px, 6vw, 6%);
    text-align: right
}

.nh-slide.is-active .nh-card {
    opacity: 1;
    translate: 0 0
}

.nh-slide[data-theme="dark"] .nh-card {
    background: rgba(10, 10, 10, .34);
    color: #fff
}

/* ===== Gold shimmer title (h2) */
.nh-title {
    margin: 0 0 10px;
    line-height: 1.05;
    font-weight: 800;
    font-size: clamp(28px, 5vw, 56px);
    background: linear-gradient(110deg, #2B2B2B 0%, #2B2B2B 10%, #B89A2A 28%, #E6D08B 42%, #C9A227 60%, #E3CE87 78%, #B68F10 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    background-size: 220% 100%;
    animation: title-rise .45s ease-out forwards, title-shimmer 3.6s linear .5s infinite
}

@keyframes title-rise {
    from {
        opacity: 0;
        transform: translateY(8px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes title-shimmer {
    0% {
        background-position: 200% 50%
    }

    100% {
        background-position: 0% 50%
    }
}

/* ===== Sub + CTA */
.nh-sub {
    margin: 0 0 16px;
    font-size: clamp(14px, 1.25vw, 18px);
    opacity: .95
}

.nh-cta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end
}

.nh-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 10px 26px;
    border-radius: 16px;
    font-size: 18px;
    text-decoration: none;
    transition: transform .15s ease, filter .2s
}

.nh-btn:hover {
    transform: translateY(-2px);
    color: #705326;
}

.nh-btn--gold {
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    color: #111;
    border: 0
}

.nh-btn--ghost {
    border: 2px solid var(--gold-2);
    color: #333333;
    background: #ffffff85;
}

.nh-btn--ghost:hover {
    background: var(--gold-2);
    color: #ffffff;
}

/* ===== Arrows */
.nh-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 0;
    cursor: pointer;
    z-index: 5
}

.nh-prev {
    left: 14px
}

.nh-next {
    right: 14px
}

.nh-nav {
    background: rgba(0, 0, 0, .55);
    color: #fff;
    font-size: 26px;
    line-height: 44px;
    text-align: center
}

.nh-nav:hover {
    background: rgba(0, 0, 0, .75)
}

/* ===== Dots + progress */
.nh-dots {
    position: absolute;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 6
}

.nh-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(0, 0, 0, .7);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, .6);
    border: 0;
    cursor: pointer
}

.nh-dot.is-active {
    background: #111
}

.nh-progress {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: rgba(0, 0, 0, .08);
    z-index: 6
}

.nh-progress span {
    display: block;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--gold-2), var(--gold-1))
}

/* ===== Mobile */
@media (max-width: 768px) {
    #nova-hero .nh-stage {
        height: var(--nh-height-m)
    }

    .nh-card {
        left: 50%;
        right: auto;
        transform: translate(-50%, -50%);
        max-width: min(92vw, 520px);
        text-align: center;
        padding: 14px 16px
    }

    .nh-cta {
        justify-content: center
    }
}

/* отступ после блока */
#nova-hero+* {
    margin-top: 24px
}


/* ===== NovaHero · FIX arrows + Mobile wide bottom card ===== */

/* 1) Стрелки: остаются по краям и без глобального блика */
.nh-nav,
.nh-nav::after {
    animation: none !important;
    /* отключаем shimmer, чтобы не «вело» */
}

.nh-nav {
    position: absolute !important;
    top: 50%;
    transform: translateY(-50%);
    z-index: 6;
}

.nh-prev {
    left: 14px !important;
}

.nh-next {
    right: 14px !important;
}

/* 2) Мобайл: карточка шире (≈80%) и внизу */
@media (max-width: 768px) {

    /* сама карточка */
    .nh-card {
        left: 50% !important;
        right: auto !important;
        top: auto !important;
        bottom: 25px !important;
        /* у самого низа */
        transform: translateX(-50%) !important;
        width: 90vw !important;
        max-width: 90vw !important;
        /* 70–80%? меняй на 70vw если нужно */
        text-align: center !important;
        padding: 16px 18px !important;
    }

    /* кнопки по центру */
    .nh-cta {
        justify-content: center !important;
    }

    /* точки чуть ниже, чтобы не наезжали на карточку */
    .nh-dots {
        bottom: 8px !important;
    }
}


html[data-theme="dark"] .ct-icon-container svg {
    fill: #ffffff !important;
}

html[data-theme="dark"] [data-icons-type*=solid] .ct-icon-container {
    background-color: #262625 !important;
}

html[data-theme="light"] [data-icons-type*=solid] .ct-icon-container:hover {
    background-color: #d3ba71 !important;
}

html[data-theme="dark"] [data-icons-type*=solid] .ct-icon-container:hover {
    background-color: #a39e8c;
}

html[data-theme="dark"] [data-header*="type-1"] .ct-header [data-transparent-row="yes"] [data-id="button"],
html[data-theme="dark"] [data-header*="type-1"] .ct-header [data-sticky*="yes"] [data-id="button"] {
    --theme-button-background-initial-color: #262625;
    --theme-button-background-hover-color: #a39e8c;
}

html[data-theme="dark"] [data-footer*="type-1"] .ct-footer [data-row*="middle"] {
    --theme-border-top: 1px solid #595959;
    background-color: #333333;
}

html[data-theme="dark"] [data-footer*="type-1"] .ct-footer [data-row*="bottom"] {
    background-color: #A39E8C;
}

html[data-theme="dark"] .ct-footer [data-icons-type*=solid] .ct-icon-container {
    background-color: #A39E8C;
}

html[data-theme="dark"] .ct-footer [data-icons-type*=solid] .ct-icon-container:hover {
    background-color: #2b2b2b !important;
}

.cta-online:before {
    background: linear-gradient(180deg,
            #eeeeeead 0%,
            #cbcbcaa6 30%,
            #8e8c87b5 60%,
            #fdfdfdba 100%) !important;
}

html[data-theme="dark"] .cta-online:before {
    background: linear-gradient(180deg,
            #000000ad 0%,
            #000000c2 30%,
            #000000b5 60%,
            #000000d4 100%) !important;
}

/* =========================================================
   BLOCK: SIGNATURE (FIXED)
========================================================= */

/* Section */
#home-signature-flip {
    background: transparent;
    padding: 80px 20px;
}

#home-signature-flip .hf-wrap {
    max-width: 1200px;
    margin: 0 auto;
}

/* Head */
#home-signature-flip .hf-head {
    text-align: center;
    margin-bottom: 12px;
}

#home-signature-flip .hf-title {
    margin: 0 0 8px;
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: clamp(30px, 4.8vw, 48px);
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: .3px;
}

#home-signature-flip .hf-sub {
    margin: 0 auto;
    max-width: 760px;
    color: var(--txt);
    line-height: 1.75;
    font-size: clamp(14px, 1.6vw, 16px);
}

/* Grid: desktop 3 cols, ≤1100px 2 cols, ≤640px 2 cols */
#home-signature-flip .hf-grid {
    display: grid;
    gap: 18px;
    margin-top: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width:1100px) {
    :root {
        --hf-dia: 204px;
    }

    /* circle smaller on tablets */

    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }
}

@media (max-width:640px) {
    :root {
        --hf-dia: 188px;
    }

    #home-signature-flip {
        padding: 56px 4px 48px;
    }

    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }
}

@media (max-width:360px) {
    :root {
        --hf-dia: 170px;
    }
}

/* Card shell */
#home-signature-flip .hf-card {
    position: relative;
    background: #d2d1d1;
    border: 1px solid rgba(207, 163, 58, .26);
    border-radius: 7px;
    box-shadow: var(--shadow-1);
    padding: 14px 16px 16px;
    text-align: center;
    transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: calc(var(--hf-dia) + 110px);
}

#home-signature-flip .hf-card:hover {
    box-shadow: var(--shadow-2);
    border-color: rgba(207, 163, 58, .48);
    transform: translateY(-2px);
}

#home-signature-flip .hf-h3 {
    margin: 2px 0 10px;
    color: var(--ink);
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: clamp(18px, 2.3vw, 22px);
    letter-spacing: .2px;
}

/* Flip circle */
#home-signature-flip .hf-flip {
    width: var(--hf-dia);
    height: var(--hf-dia);
    margin: 0 auto 12px;
    border-radius: 50%;
    position: relative;
    perspective: 1000px;
    outline: none;
    flex: 0 0 auto;

    /* FIX: ensure circle always clips content */
    overflow: hidden;

    /* Luxury ring + subtle background */
    background: radial-gradient(120% 120% at 50% 0%, #ffffff 0%, #f7f1e7 60%, #efe3d1 100%);
    border: 1px solid rgba(207, 163, 58, .28);
    box-shadow:
        inset 0 0 0 1px rgba(0, 0, 0, .06),
        0 14px 34px rgba(0, 0, 0, .08);
}

#home-signature-flip .hf-flip-inner {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    transform-style: preserve-3d;
    transition: transform .7s cubic-bezier(.2, .65, .2, 1);
}

/* Faces */
#home-signature-flip .hf-front,
#home-signature-flip .hf-back {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .2s ease;
}

#home-signature-flip .hf-front {
    opacity: 1;
    z-index: 2;
}

#home-signature-flip .hf-back {
    opacity: 0;
    z-index: 1;
    transform: rotateY(180deg);
}

/* Flip states */
#home-signature-flip .hf-card:hover .hf-flip-inner,
#home-signature-flip .hf-flip:focus-visible .hf-flip-inner,
#home-signature-flip .hf-flip.is-flipped .hf-flip-inner {
    transform: rotateY(180deg);
}

#home-signature-flip .hf-card:hover .hf-front,
#home-signature-flip .hf-flip:focus-visible .hf-front,
#home-signature-flip .hf-flip.is-flipped .hf-front {
    opacity: 0;
}

#home-signature-flip .hf-card:hover .hf-back,
#home-signature-flip .hf-flip:focus-visible .hf-back,
#home-signature-flip .hf-flip.is-flipped .hf-back {
    opacity: 1;
}



/* Soft hover */
#home-signature-flip .hf-card:hover .hf-front img {
    transform: scale(1.04);
    filter: saturate(1.03) contrast(1.02);
}

/* ===== FIX: image must fill the circle, not an oval ===== */
#home-signature-flip .hf-front img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 50% !important;
    display: block !important;

    /* Soft luxury finish */
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .55);
    border: 0 !important;
    background: transparent !important;

    transition: transform .55s ease, filter .55s ease;
}

/* Back side */
#home-signature-flip .hf-back {
    padding: 16px;
    color: #2B2B2B;
    line-height: 1.6;
    font-size: 15px;
    background: radial-gradient(120% 120% at 50% 0%, #FFFFFF 0%, #F7F1E7 60%, #F0E6D7 100%);
    border: 1px solid rgba(207, 163, 58, .28);
}

/* Button */
#home-signature-flip .hf-btn::after {
    content: "➜";
    font-size: 14px;
    line-height: 1;
    transform: translateY(1px);
}

#home-signature-flip .hf-btn:hover {
    color: #fff;
    transform: translateY(-1px);
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    #home-signature-flip .hf-flip-inner {
        transition: none;
    }

    #home-signature-flip .hf-front,
    #home-signature-flip .hf-back {
        transition: none;
    }
}

/* ===== Block Services ============ */
/* Section wrapper spacing */
#services-alt {
    padding: 50px 20px 20px;
}

#services-alt .svc-section {
    max-width: 1200px;
    margin: 45px auto 60px;
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    /* image/text */
    gap: 26px;
    align-items: center;
}

/* reverse layout (image right) */
#services-alt .svc-section.is-reverse {
    grid-template-columns: .9fr 1.1fr;
}

#services-alt .svc-section.is-reverse .svc-media {
    order: 2;
}

#services-alt .svc-section.is-reverse .svc-copy {
    order: 1;
}

/* Image */
#services-alt .svc-media {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 12px 28px rgb(0 0 0 / 21%);
    background: #F2F2F2;
    aspect-ratio: 4 / 3;
}

#services-alt .svc-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1.02);
    transition: transform .5s ease;
}

#services-alt .svc-media:hover img {
    transform: scale(1.10);
}

/* Text */
#services-alt .svc-copy {
    padding: 22px 24px;
    background: #fcfbf4;
    border: 1px solid rgb(211 186 113);
    box-shadow: 2px 2px 7px rgb(96 96 96 / 50%), -2px -2px 7px rgb(199 199 199 / 50%) inset;
    border-radius: 12px;
}

#services-alt .svc-lead {
    margin: 0 0 12px;
    color: var(--text);
    line-height: 1.75;
    font-size: 16px;
}

#services-alt .svc-points {
    margin: 0 0 14px 18px;
    color: var(--ink);
}

#services-alt .svc-points li {
    margin-bottom: 6px;
}

#services-alt .svc-cta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* Anchor offset so sticky header doesn't cover the titles */
#services-alt .svc-section {
    scroll-margin-top: 96px;
}

/* =========================
   Services image overlay
   Default: dark overlay
   Hover on whole block: clean image
========================= */

#services-alt .svc-media {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
}

/* DARK overlay by default */
#services-alt .svc-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    opacity: 1;
    /* <-- always visible initially */
    transition: opacity 0.45s ease;
    pointer-events: none;
}

/* LIGHT overlay by default */
html[data-theme="light"] #services-alt .svc-media::after {
    background: rgba(255, 255, 255, 0.45);
}

/* Optional luxury gold glow (subtle) */
#services-alt .svc-media::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(420px 260px at 20% 20%,
            rgba(201, 162, 39, .18),
            transparent 60%);
    opacity: 1;
    transition: opacity 0.45s ease;
    pointer-events: none;
}

/* 🔥 Hover on WHOLE service block */
#services-alt .svc-section:hover .svc-media::after,
#services-alt .svc-section:hover .svc-media::before {
    opacity: 0;
    /* overlay disappears */
}

/* Optional: very gentle zoom on hover */
#services-alt .svc-media img {
    transition: transform 0.6s ease;
}

#services-alt .svc-section:hover .svc-media img {
    transform: scale(1.22);
}

/* Responsive */
@media (max-width: 980px) {

    #services-alt .svc-section,
    #services-alt .svc-section.is-reverse {
        grid-template-columns: 1fr;
    }

    #services-alt .svc-section.is-reverse .svc-media {
        order: 0;
    }

    #services-alt .svc-section.is-reverse .svc-copy {
        order: 0;
    }

    #services-alt {
        padding: 40px 16px 10px;
    }
}

/* ===== MOBILE FIX: 2 cols, circle fits, flip without 3D ===== */
@media (max-width: 640px) {
    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 14px !important;
    }

    #home-signature-flip .hf-h3 span {
        display: none;
    }

    #home-signature-flip .hf-card {
        padding: 12px 12px 14px !important;
        border-radius: 20px !important;
        min-height: auto !important;
        overflow: hidden !important;
        transform: none !important;
    }

    #home-signature-flip .hf-h3 {
        font-size: 18px !important;
        margin: 2px 0 8px !important;
    }

    #home-signature-flip .hf-flip {
        width: clamp(136px, calc(50vw - 60px), 176px) !important;
        height: clamp(136px, calc(50vw - 60px), 176px) !important;
        margin: 0 auto 10px !important;
        border-radius: 50% !important;
        perspective: none !important;
    }

    #home-signature-flip .hf-flip-inner {
        transform: none !important;
    }

    #home-signature-flip .hf-front,
    #home-signature-flip .hf-back {
        position: absolute;
        inset: 0;
        border-radius: 50%;
        transform: none !important;
        backface-visibility: visible !important;
        -webkit-backface-visibility: visible !important;
        transition: opacity .25s ease !important;
    }

    #home-signature-flip .hf-front {
        opacity: 1 !important;
        z-index: 2;
    }

    #home-signature-flip .hf-back {
        opacity: 0 !important;
        z-index: 1;
        line-height: 1.4;
        font-size: 13px;
    }

    #home-signature-flip .hf-flip.is-flipped .hf-front {
        opacity: 0 !important;
    }

    #home-signature-flip .hf-flip.is-flipped .hf-back {
        opacity: 1 !important;
    }

    #home-signature-flip .hf-btn {
        padding: 9px 12px !important;
        font-size: 14px !important;
    }
}

@media (max-width: 360px) {
    #home-signature-flip .hf-flip {
        width: 130px !important;
        height: 130px !important;
    }
}


/* =========================================================
   BLOCK: SERVICES
========================================================= */
/* ===== Beauty By Anahit · Services (no animations) + CTA button ===== */

/* =========================
  SERVICES HERO (CSS)
  Uses your existing variables:
  --wrap, --baa-ink, --baa-muted, --baa-line, --baa-surface,
  --baa-radius, --baa-radius-pill, --baa-shadow, --gold-1, --gold-2, --veil
========================= */


/* Background gradient: top → bottom */
#bba-services-alt {
    padding: 80px 0;
    overflow: clip;
}

.bba-sa-wrap {
    max-width: var(--wrap);
    margin: 0 auto;
    padding: 0 24px;
}

/* Header: plain (no effects), you can style it later */
.bba-sa-head {
    text-align: left;
    margin: 0 0 56px;
}

.bba-sa-eyebrow {
    display: inline-block;
    font-size: 13px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--sub);
    background: rgba(255, 255, 255, .65);
    border: 1px solid rgba(0, 0, 0, .06);
    border-radius: 999px;
    padding: 8px 14px;
    margin-bottom: 14px;
    backdrop-filter: blur(6px);
}

.bba-underline {
    width: 112px;
    height: 6px;
    border-radius: 8px;
    background: linear-gradient(90deg, var(--gold-2), var(--gold-1));
    box-shadow: 0 3px 14px rgba(201, 162, 39, .25);
    margin: 16px 0 0;
}

.bba-sa-head p {
    color: var(--sub);
    font-size: 18px;
    margin: 16px 0 0;
}

/* List */
.bba-sa-list {
    display: flex;
    flex-direction: column;
    gap: 28px;
    margin-top: 44px;
    position: relative;
}

.bba-sa-list::before {
    content: "";
    position: absolute;
    left: 0;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: linear-gradient(to bottom, transparent, var(--gold-1), transparent);
    opacity: .3;
}

/* Card */
.bba-sa-item {
    position: relative;
    background: rgba(255, 255, 255, .82);
    backdrop-filter: blur(10px);
    border: 1px solid #8b8b8b;
    border-radius: 30px;
    padding: 26px 28px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, .07);
    transition: box-shadow .2s ease, transform .2s ease;
    /* small hover only */
}

.bba-sa-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, .09);
}

/* pearl marker */
/* .bba-sa-item::before {
    content: "";
    position: absolute;
    left: -9px;
    top: 30px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #fff, #fff 46%, #e6d398 47%, var(--gold-2) 100%);
    box-shadow: 0 0 0 3px #fff;
} */

/* Inner grid */
.bba-sa-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    align-items: center;
}

.bba-sa-item h3 {
    font-family: "Playfair Display", serif;
    margin: 0 0 6px;
    font-size: clamp(22px, 2.2vw, 28px);
    color: #2E2B29;
    letter-spacing: .2px;
}

.bba-sa-item p {
    color: var(--sub);
    font-size: 15.5px;
    line-height: 1.6;
    margin: 0;
}

.bba-sa-meta {
    display: flex;
    align-items: center;
    gap: 18px;
    white-space: nowrap;
}

.bba-price {
    font-weight: 700;
    font-size: 16px;
    color: var(--ink);
    padding: 10px 14px;
    border-radius: 999px;
    background: linear-gradient(180deg, #fff, #f7f3e6);
    border: 1px solid rgba(0, 0, 0, .06);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
}

/* Unified button style (no shine, no auto effects — only subtle hover) */
.bba-sa-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 26px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .2px;
    text-decoration: none;
    color: #1a1a1a;
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    box-shadow: 0 10px 22px rgba(201, 162, 39, .20);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.bba-sa-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(201, 162, 39, .28);
    background: linear-gradient(180deg, #F0D88A, var(--gold-2));
}

/* Section bottom CTA */
.bba-sa-cta {
    text-align: center;
    margin-top: 36px;
}

@media (max-width:900px) {
    .bba-sa-head {
        text-align: center;
        margin: 0 auto 46px;
    }

    .bba-underline {
        margin-left: auto;
        margin-right: auto;
    }

    .bba-sa-list::before {
        display: none;
    }

    .bba-sa-item::before {
        left: 14px;
    }

    .bba-sa-row {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .bba-sa-meta {
        justify-content: space-between;
    }

    .bba-sa-cta {
        margin-top: 28px;
    }
}

/* =========================================================
   BLOCK: WORK / GALLERY
========================================================= */

/* ===== Gallery section ===== */
.ans-gallery {
    padding: clamp(35px, 6vw, 55px) 0;
}

.ans-gallery__head {
    text-align: center;
    margin-bottom: 18px;
}

/* Filters */
.ans-gallery__filters {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 18px 0 20px;
}

.ans-filter {
    height: 42px;
    padding: 0 14px;
    border-radius: var(--baa-radius-pill);
    border: 1px solid var(--baa-line);
    background: var(--baa-surface);
    color: var(--baa-ink);
    font-weight: 800;
    font-size: 13px;
    letter-spacing: .02em;
    cursor: pointer;
    transition: transform var(--baa-speed) ease, box-shadow var(--baa-speed) ease, border-color var(--baa-speed) ease;
}

.ans-filter:hover {
    transform: translateY(-1px);
    box-shadow: var(--baa-shadow-soft);
    border-color: var(--baa-rim);
}

.ans-filter.is-active {
    background: linear-gradient(135deg, var(--gold-1), var(--gold-2));
    border-color: rgba(0, 0, 0, .12);
    color: #0b0b0c;
}

/* Grid */
.ans-gallery__grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 14px;
}

/* Item */
.ans-gitem {
    grid-column: span 4;
}

.ans-gitem__btn {
    width: 100%;
    border: 0;
    padding: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.ans-gitem__img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    display: block;
    border-radius: var(--baa-radius);
    border: 1px solid var(--baa-line);
    background: var(--baa-surface);
    box-shadow: var(--baa-shadow);
}

.ans-gitem__shine {
    position: absolute;
    inset: 0;
    border-radius: var(--baa-radius);
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--baa-speed) ease;
    background: radial-gradient(420px 240px at 18% 12%, rgba(201, 162, 39, .18), transparent 60%);
}

.ans-gitem {
    position: relative;
}

.ans-gitem__cap {
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 14px;
    padding: 12px 12px;
    border-radius: 16px;
    border: 1px solid var(--baa-line);
    background: rgba(20, 19, 18, .55);
    backdrop-filter: blur(10px);
    box-shadow: var(--baa-shadow-soft);
    transform: translateY(8px);
    opacity: 0;
    transition: transform var(--baa-speed) ease, opacity var(--baa-speed) ease;
}

html[data-theme="light"] .ans-gitem__cap {
    background: rgba(255, 255, 255, .72);
}

.ans-gitem__tag {
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--gold-2);
}

.ans-gitem__title {
    display: block;
    margin-top: 3px;
    font-size: 16px;
    color: var(--baa-ink);
}

html[data-theme="dark"] .ans-gitem__title {
    color: rgba(255, 255, 255, .92);
}

.ans-gitem__btn:hover .ans-gitem__cap {
    transform: translateY(0);
    opacity: 1;
}

.ans-gitem__btn:hover .ans-gitem__shine {
    opacity: 1;
}

/* Hide by filter */
.ans-gitem.is-hidden {
    display: none;
}

/* Responsive */
@media (max-width: 980px) {
    .ans-gitem {
        grid-column: span 6;
    }

    .ans-gitem__img {
        height: 300px;
    }
}

@media (max-width: 560px) {
    .ans-gitem {
        grid-column: span 12;
    }

    .ans-gitem__img {
        height: 290px;
    }
}

/* ===== Lightbox ===== */
.ans-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
}

.ans-lightbox.is-open {
    display: block;
}

.ans-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .72);
}

.ans-lightbox__dialog {
    position: relative;
    width: min(980px, calc(100% - 26px));
    margin: min(7vh, 60px) auto 0;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, .14);
    background: rgba(20, 19, 18, .75);
    backdrop-filter: blur(12px);
    box-shadow: var(--baa-shadow-hover);
    overflow: hidden;
}

html[data-theme="light"] .ans-lightbox__dialog {
    background: rgba(255, 255, 255, .90);
    border-color: rgba(0, 0, 0, .10);
}

.ans-lightbox__figure {
    margin: 0;
}

.ans-lightbox__img {
    width: 100%;
    height: min(70vh, 640px);
    object-fit: contain;
    background: rgba(0, 0, 0, .25);
    display: block;
}

html[data-theme="light"] .ans-lightbox__img {
    background: rgba(0, 0, 0, .04);
}

.ans-lightbox__cap {
    padding: 12px 16px 16px;
    color: rgba(255, 255, 255, .76);
}

html[data-theme="light"] .ans-lightbox__cap {
    color: rgba(0, 0, 0, .70);
}

.ans-lightbox__close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .16);
    background: rgba(0, 0, 0, .20);
    color: rgba(255, 255, 255, .92);
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
}

html[data-theme="light"] .ans-lightbox__close {
    border-color: rgba(0, 0, 0, .10);
    background: rgba(0, 0, 0, .04);
    color: rgba(0, 0, 0, .78);
}

.ans-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 56px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, .16);
    background: rgba(0, 0, 0, .20);
    color: rgba(255, 255, 255, .92);
    cursor: pointer;
    font-size: 30px;
    line-height: 1;
    display: grid;
    place-items: center;
}

html[data-theme="light"] .ans-lightbox__nav {
    border-color: rgba(0, 0, 0, .10);
    background: rgba(0, 0, 0, .04);
    color: rgba(0, 0, 0, .75);
}

.ans-lightbox__prev {
    left: 10px;
}

.ans-lightbox__next {
    right: 10px;
}

/* ===== SECTION ===== */
#home-work {
    padding: 60px 20px;
    background: linear-gradient(180deg, var(--cream-1) 0%, var(--cream-2) 42%, var(--cream-3) 100%);
}

.work-wrap {
    max-width: 1200px;
    margin: 0 auto
}

.work-head {
    text-align: center;
    margin-bottom: 24px
}

.work-head .sub {
    color: #6F6A66
}

/* ===== GRID ===== */
.work-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin-top: 28px;
    background: #D6C9B9;
}

.work-item {
    position: relative;
    display: block;
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, .28);
    margin: -.5px;
    cursor: pointer;
}

.work-item img {
    width: 100%;
    height: 100%;
    display: block;
    aspect-ratio: 4/5;
    object-fit: cover;
    user-select: none;
    -webkit-user-drag: none;
    transform: scale(1.02);
    transition: transform 0.6s ease;
}

.work-item:hover img {
    transform: scale(1.28)
}

@media (max-width:1100px) {
    .work-grid {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media (max-width:900px) {
    .work-grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

/* ====== ТОНКАЯ НАСТРОЙКА ВСТРОЕННОГО ELEMENTOR LIGHTBOX ====== */

/* 1) Один, стабильный фон ≈ 80% */
.dialog-type-lightbox .dialog-widget-content {
    background: rgba(0, 0, 0, .8) !important;
}

/* 2) По центру и “по рамке” (contain), в т.ч. на мобильном */
.elementor-lightbox .swiper-slide img {
    max-width: calc(100vw - 40px);
    max-height: calc(100vh - 120px);
    width: auto;
    height: auto;
    object-fit: contain;
    margin: 0 auto;
    /* центрируем */
    display: block;
}

/* 3) Скрыть лишние кнопки (оставить только fullscreen и закрыть) */
/* zoom +/- */
.elementor-slideshow__header i.eicon-zoom-in-bold,
.elementor-slideshow__header i.eicon-zoom-out-bold {
    display: none !important;
}

/* share (если он есть) */
.elementor-slideshow__header i.eicon-share-arrow {
    display: none !important;
}

/* иконка “лупа” фикс (если тема её добавляет отдельно) */
.elementor-slideshow__header i.eicon-search {
    display: none !important;
}

/* Цвет кнопок под бренд — по желанию */
.elementor-slideshow__header i {
    color: #fff;
    opacity: .95;
    transition: opacity .2s ease, color .2s ease, background-color .2s ease;
}

.elementor-slideshow__header i:hover {
    color: #fff;
    opacity: 1;
}

/* 4) Немного причесываем кнопки */
.elementor-slideshow__header {
    gap: 8px;
    background: transparent;
    /* убираем доп. подложку полоски сверху */
}

.elementor-slideshow__header i {
    font-size: 20px;
    background: rgba(0, 0, 0, .35);
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.elementor-slideshow__header i:hover {
    background: rgba(0, 0, 0, .5);
}

/* Счётчик оставим как есть, но можно усилить читаемость */
.elementor-slideshow__counter {
    font-weight: 600;
    letter-spacing: .2px;
    background: rgba(0, 0, 0, .45);
    padding: 6px 10px;
    border-radius: 999px;
}



/* === Elementor Lightbox · PATCH (smaller arrows + fix clicks) === */

/* Size & shape of nav arrows */
.elementor-lightbox .elementor-swiper-button,
.dialog-type-lightbox .dialog-lightbox-next,
.dialog-type-lightbox .dialog-lightbox-prev {
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, .32) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .22) !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    pointer-events: auto !important;
    /* ensure clicks */
    z-index: 100000010 !important;
}

/* Position */
.elementor-lightbox .elementor-swiper-button-prev,
.dialog-type-lightbox .dialog-lightbox-prev {
    left: 14px !important;
}

.elementor-lightbox .elementor-swiper-button-next,
.dialog-type-lightbox .dialog-lightbox-next {
    right: 14px !important;
}

/* Icon inside arrows */
.elementor-lightbox .elementor-swiper-button i,
.elementor-lightbox .elementor-swiper-button svg,
.elementor-lightbox .elementor-swiper-button path {
    display: block !important;
    color: #fff !important;
    stroke: #fff !important;
    fill: none !important;
    stroke-width: 2 !important;
    opacity: .95 !important;
}

.elementor-lightbox .elementor-swiper-button:hover i,
.elementor-lightbox .elementor-swiper-button:hover svg,
.elementor-lightbox .elementor-swiper-button:hover path {
    opacity: 1 !important;
}

/* Tighten on very small screens */
@media (max-width: 480px) {

    .elementor-lightbox .elementor-swiper-button-prev,
    .dialog-type-lightbox .dialog-lightbox-prev {
        left: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button-next,
    .dialog-type-lightbox .dialog-lightbox-next {
        right: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button,
    .dialog-type-lightbox .dialog-lightbox-next,
    .dialog-type-lightbox .dialog-lightbox-prev {
        width: 30px !important;
        height: 30px !important;
    }
}

/* Header buttons (close, fullscreen) — make sure they work & look neat */
.elementor-lightbox .elementor-slideshow__header {
    background: transparent !important;
    gap: 8px !important;
    z-index: 100000020 !important;
}

.elementor-lightbox .elementor-slideshow__header button,
.elementor-lightbox .elementor-slideshow__header i {
    pointer-events: auto !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0, 0, 0, .35) !important;
    color: #fff !important;
}

.elementor-lightbox .elementor-slideshow__header button:hover,
.elementor-lightbox .elementor-slideshow__header i:hover {
    background: rgba(0, 0, 0, .5) !important;
}

/* Make sure the slide itself doesn't sit above controls */
.elementor-lightbox .elementor-lightbox-item,
.elementor-lightbox .swiper {
    z-index: 100000000 !important;
}


/* ===== Elementor Lightbox · HARD FIX (show arrows, own chevrons, clickable) ===== */

/* 1) Всегда показывать и включить клики на всех вариантах кнопок */
.elementor-lightbox .elementor-swiper-button,
.elementor-lightbox .elementor-slideshow__next,
.elementor-lightbox .elementor-slideshow__prev,
.dialog-type-lightbox .dialog-lightbox-next,
.dialog-type-lightbox .dialog-lightbox-prev {
    position: fixed !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, .32) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .22) !important;

    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    z-index: 100000020 !important;
    /* выше слайда и оверлеев */
}

/* 2) Позиции */
.elementor-lightbox .elementor-swiper-button-prev,
.elementor-lightbox .elementor-slideshow__prev,
.dialog-type-lightbox .dialog-lightbox-prev {
    left: 16px !important;
}

.elementor-lightbox .elementor-swiper-button-next,
.elementor-lightbox .elementor-slideshow__next,
.dialog-type-lightbox .dialog-lightbox-next {
    right: 16px !important;
}

/* 3) Рисуем стрелку сами, не зависим от иконок темы */
.elementor-lightbox .elementor-swiper-button::after,
.elementor-lightbox .elementor-slideshow__next::after,
.elementor-lightbox .elementor-slideshow__prev::after,
.dialog-type-lightbox .dialog-lightbox-next::after,
.dialog-type-lightbox .dialog-lightbox-prev::after {
    content: "";
    width: 14px;
    height: 14px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    display: block;
}

.elementor-lightbox .elementor-swiper-button-next::after,
.elementor-lightbox .elementor-slideshow__next::after,
.dialog-type-lightbox .dialog-lightbox-next::after {
    transform: rotate(45deg);
}

.elementor-lightbox .elementor-swiper-button-prev::after,
.elementor-lightbox .elementor-slideshow__prev::after,
.dialog-type-lightbox .dialog-lightbox-prev::after {
    transform: rotate(-135deg);
}

/* 4) На узких экранах чуть меньше и ближе к краям */
@media (max-width: 480px) {

    .elementor-lightbox .elementor-swiper-button,
    .elementor-lightbox .elementor-slideshow__next,
    .elementor-lightbox .elementor-slideshow__prev,
    .dialog-type-lightbox .dialog-lightbox-next,
    .dialog-type-lightbox .dialog-lightbox-prev {
        width: 30px !important;
        height: 30px !important;
    }

    .elementor-lightbox .elementor-swiper-button-prev,
    .elementor-lightbox .elementor-slideshow__prev,
    .dialog-type-lightbox .dialog-lightbox-prev {
        left: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button-next,
    .elementor-lightbox .elementor-slideshow__next,
    .dialog-type-lightbox .dialog-lightbox-next {
        right: 10px !important;
    }
}

/* 5) На всякий случай прячем конфликтные внутренние иконки,
          чтобы они не перекрывали наш ::after и не ломали клики */
.elementor-lightbox .elementor-swiper-button i,
.elementor-lightbox .elementor-swiper-button svg {
    display: none !important;
}

/* 6) Слайд и контейнер не перекрывают стрелки */
.elementor-lightbox .swiper,
.elementor-lightbox .elementor-lightbox-item {
    z-index: 100000000 !important;
    overflow: visible !important;
}



/* === Lightbox UX: lock page scroll, cursor zones, working close === */

/* Cursor: default outside, pointer only on image */
.elementor-lightbox {
    cursor: default !important;
}

.elementor-lightbox .swiper-slide {
    cursor: default !important;
}

.elementor-lightbox .swiper-slide img {
    cursor: pointer !important;
}

/* Close button (always on top & clickable) */
.elementor-lightbox .elementor-slideshow__close,
.elementor-lightbox [data-elementor-action="close"] {
    position: fixed !important;
    top: 16px !important;
    right: 16px !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0, 0, 0, .42) !important;
    z-index: 100000030 !important;
    /* выше стрелок и слайда */
    pointer-events: auto !important;
}

.elementor-lightbox .elementor-slideshow__close:hover,
.elementor-lightbox [data-elementor-action="close"]:hover {
    background: rgba(0, 0, 0, .55) !important;
}

.elementor-lightbox .elementor-slideshow__close i,
.elementor-lightbox .elementor-slideshow__close svg,
.elementor-lightbox [data-elementor-action="close"] i,
.elementor-lightbox [data-elementor-action="close"] svg {
    color: #fff !important;
    stroke: #fff !important;
    fill: none !important;
    stroke-width: 2 !important;
}

/* Class to actually lock scrolling (JS добавит её на <html> и <body>) */
.no-scroll {
    overflow: hidden !important;
}


.elementor-lightbox .dialog-lightbox-close-button {
    z-index: 999999999 !important;
}

/* =========================================================
   BLOCK: CLIENTS
========================================================= */
/* layout */
#why-me .head {
    text-align: center;
    margin-bottom: 10px;
}

#why-me .grid {
    display: grid;
    gap: var(--baa-gap);
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 24px;
}

/* cards */
#why-me .card {
    background: linear-gradient(180deg, #FFFFFF 0%, var(--veil) 100%);
    border: 1px solid rgba(207, 163, 58, .26);
    border-radius: var(--baa-radius);
    padding: 22px;
    text-align: center;
    box-shadow: var(--baa-shadow);
    transition: transform var(--baa-speed), box-shadow var(--baa-speed);
    margin: 7px;
}

#why-me .card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 36px rgba(0, 0, 0, .14);
}

/* icons */
#why-me .icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 12px;
    display: grid;
    place-items: center;
}

#why-me .icon svg {
    width: 64px;
    height: 64px;
    display: block;
    stroke: var(--baa-gold);
    fill: none;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, .06));
    transition: stroke var(--baa-speed), transform var(--baa-speed), filter var(--baa-speed);
}

#why-me .card:hover .icon svg {
    transform: translateY(-1px);
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, .1));
}

/* text */
#why-me .title {
    font-weight: 700;
    margin: 6px 0;
    color: var(--baa-text);
}

#why-me .desc {
    color: var(--baa-muted);
    line-height: 1.6;
}

/* responsive */
@media (max-width: 1000px) {
    #why-me .grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    #why-me .grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   BLOCK: TESTIMONIALS
========================================================= */
/* ================= SCOPE ================= */

html[data-theme="dark"] .slider-rew {
    background: #1c1c1c !important;
}

html[data-theme="light"] .slider-rew {
    background: #FBF9F6 !important;
}


.slider-rew .e-con-inner {
    display: block !important;
}

#reviews {
    padding: 70px 0;
}

html[data-theme="light"] #reviews {
    background: #FBF9F6;
}

#reviews * {
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent
}

/* ================= HEAD ================= */
#reviews .rv-head {
    text-align: center;
    margin: 0 0 28px
}

#reviews .rv-eyebrow {
    font-size: clamp(18px, 2.2vw, 22px);
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #7a6f5a;
    margin-bottom: 10px
}


/* ================= VIEWPORT & TRACK ================= */
#reviews .rv-wrap {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 16px
}

#reviews .rv-viewport {
    position: relative;
    overflow: hidden
}

#reviews .rv-track {
    display: flex;
    gap: 0;
    /* ключ: никаких зазоров между страницами */
    transition: transform .55s ease;
    will-change: transform
}

#reviews .rv-slide {
    flex: 0 0 100%;
    /* жёсткая «страница» шириной в 100% */
    max-width: 100%;
}

/* ================= CARD ================= */
#reviews .rv-card {
    background: #fff;
    border-radius: 22px;
    border: 1px solid #8b8b8b;
    width: min(860px, 92%);
    margin: 0 auto;
    padding: 30px 32px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04)
}

#reviews .rv-quote {
    font-size: 34px;
    line-height: 1;
    color: #B89A2A;
    margin-bottom: 8px
}

#reviews .rv-stars {
    color: #C9A227;
    letter-spacing: .2em;
    margin-bottom: 10px
}

#reviews .rv-text {
    font-size: clamp(16px, 1.8vw, 20px);
    line-height: 1.65;
    margin: 0 0 14px;
    color: #2b2b2b
}

#reviews .rv-name {
    font-weight: 700;
    margin-bottom: 6px
}

#reviews .rv-meta {
    opacity: .75
}

/* ================= ARROWS ================= */
#reviews .rv-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: linear-gradient(180deg, #fff, #F1E9D2);
    border: 2px solid rgba(201, 162, 39, .35);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
    display: grid;
    place-items: center;
    z-index: 3;
    cursor: pointer
}

#reviews .rv-arrow svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: #6b5b2e;
    stroke-width: 2.2
}

#reviews .rv-prev {
    left: 20px
}

#reviews .rv-next {
    right: 20px
}

#reviews .rv-arrow,
#reviews .rv-arrow::after {
    animation: none !important
}

/* ================= DOTS ================= */
#reviews .rv-dots {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-top: 16px;
    position: relative
}

#reviews .rv-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #d8d3c6;
    border: 0;
    cursor: pointer;
    position: relative
}

#reviews .rv-dot.is-active {
    background: #C9A227
}

#reviews .rv-dot.is-active::after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(201, 162, 39, .35)
}

/* ================= MOBILE ================= */
@media (max-width:768px) {
    #reviews .rv-viewport {
        padding-bottom: 96px !important
    }

    #reviews .rv-arrow {
        top: auto !important;
        bottom: 24px !important;
        transform: none !important;
        width: 46px;
        height: 46px;
        background: linear-gradient(180deg, #fff, #F5EDDA)
    }

    #reviews .rv-prev {
        left: 16px !important
    }

    #reviews .rv-next {
        right: 16px !important
    }

    #reviews .rv-dots {
        position: absolute !important;
        left: 50% !important;
        bottom: 24px !important;
        transform: translateX(-50%) !important;
        margin-top: 0 !important
    }

    #reviews .rv-card {
        width: 90%;
        padding: 22px 18px
    }
}

/* =========================================================
   BLOCK: FAQ
========================================================= */
/* ===== Section ===== */
#home-faq {
    width: 100%;
    padding: 80px 20px 80px;
}

html[data-theme="light"] #home-faq {
    background: linear-gradient(180deg, #FFFFFF 0%, #FBF9F6 100%);
}

#home-faq .faq-wrap {
    max-width: 1200px;
    margin: 0 auto;
}



/* ===== Independent columns (no cross-column stretching) ===== */
#home-faq .faq-list {
    column-count: 2;
    /* независимые колонки */
    column-gap: 16px;
}

.faq-item {
    display: inline-block;
    /* для columns */
    width: 100%;
    break-inside: avoid;
    /* не рвать карточки */
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, .08);
    background: #fff;
    box-shadow: 0 10px 28px rgba(0, 0, 0, .06);
    margin: 0 0 16px;
    /* вертикальный зазор в колонке */
    transition: box-shadow .25s ease, transform .25s ease;
}

.faq-item[open] {
    box-shadow: 0 14px 40px rgba(0, 0, 0, .10);
    transform: translateY(-1px);
}

.faq-q:focus-visible {
    box-shadow: 0 0 0 3px rgba(207, 163, 58, .35) inset;
}

.faq-q .faq-q-text {
    pointer-events: none;
}

/* Chevron */
.faq-q::after {
    content: "";
    position: absolute;
    right: 18px;
    top: 50%;
    width: 12px;
    height: 12px;
    border-right: 2px solid #1A1A1A;
    border-bottom: 2px solid #1A1A1A;
    transform: translateY(-50%) rotate(-45deg);
    transition: transform .25s ease, border-color .25s ease, opacity .25s ease;
    opacity: .75;
}

.faq-item[open] .faq-q::after {
    transform: translateY(-50%) rotate(45deg);
    border-color: #CFA33A;
    opacity: 1;
}

/* Answer wrapper for smooth animation */
.faq-a {
    overflow: hidden;
    /* для анимации высоты */
    height: 0;
    /* изначально скрыто */
    transition: height .32s ease, opacity .32s ease;
    opacity: 0;
    background: #F8FBFF;
    border-top: 1px solid rgba(207, 163, 58, .18);
}

.faq-item[open] .faq-a {
    opacity: 1;
}

/* высотой управляет JS */
.faq-inner {
    padding: 18px 24px 24px;
    color: #4B4B4B;
    line-height: 1.7;
}

/* CTA */
#home-faq .faq-cta {
    text-align: center;
    margin-top: 26px;
}

/* Responsive */
@media (max-width: 900px) {
    #home-faq {
        padding: 70px 16px 80px;
    }

    #home-faq .faq-list {
        column-count: 1;
    }

    .faq-q {
        padding: 18px 50px 18px 18px;
    }
}

@media (prefers-reduced-motion: reduce) {

    .faq-item,
    .faq-q::after,
    .faq-a {
        transition: none !important;
    }
}

/* =========================================================
   BLOCK: APPOINTMENT CTA
========================================================= */
/* =========================================================
   Appointment CTA (Book Time to Get Manicure) — FINAL
   Картинка заполняет коробку как cover, без "криво"
   ========================================================= */

/* Section padding */
#cta-appointment.cta-bg {
    padding: clamp(64px, 7vw, 100px) clamp(16px, 4vw, 32px);
}

/* Grid: немного увеличили колонку с картинкой */
#cta-appointment .cta-appt {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(360px, clamp(460px, 42vw, 600px)) 1fr;
    align-items: center;
    gap: clamp(20px, 3vw, 44px);
}

/* ----- MEDIA as FIXED BOX ----- */
#cta-appointment .cta-appt__media {
    width: 100%;
    max-width: clamp(460px, 42vw, 600px);
    aspect-ratio: 4 / 3;
    /* форма коробки (можно 3/2 или 16/10) */
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    box-shadow: 0 18px 46px rgba(0, 0, 0, .12);
}

/* ВАЖНО: удаляем любые прежние высоты/макс-высоты, заполняем коробку */
#cta-appointment .cta-appt__media>img {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    /* ровный кроп без искажений */
    object-position: center;
    /* сместить кадр: 40% center; left center; right center */
    display: block;
    border-radius: 18px;
}

/* Glass content card */
#cta-appointment .cta-appt__content {
    background: rgba(255, 255, 255, .5);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    padding: clamp(18px, 2.6vw, 28px);
    border-radius: 18px;
    box-shadow: 0 12px 34px rgba(0, 0, 0, .08);
    border: 1px solid rgba(255, 255, 255, .55);
    outline: 1px solid rgba(0, 0, 0, .04);
    color: #2D2A28;
}

#cta-appointment .cta-appt__eyebrow {
    margin: 0 0 6px;
    color: #C9A227;
    font-family: "Playfair Display", serif;
    font-style: italic;
    letter-spacing: .5px;
    opacity: .95;
}

#cta-appointment .cta-appt__text {
    margin: 0 0 22px;
    color: #615D59;
    line-height: 1.75;
    font-size: clamp(15px, 1.2vw, 16.5px);
    text-shadow: 0 1px 6px rgba(255, 255, 255, .3);
}

/* Laptop: чуть компактнее заголовок */
@media (max-width: 1200px) {
    #cta-appointment .h-title-xl {
        font-size: clamp(30px, 4.4vw, 40px);
        line-height: 1.15;
    }
}

/* Mobile */
@media (max-width: 980px) {
    #cta-appointment.cta-bg {
        padding: 56px 14px;
    }

    #cta-appointment .cta-appt {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    #cta-appointment .cta-appt__content {
        order: -1;
        margin: 0 6px;
        padding: clamp(16px, 3.4vw, 22px);
    }

    #cta-appointment .cta-appt__media {
        max-width: 92%;
        margin: 0 auto;
        aspect-ratio: 4 / 3;
        /* сохраняем пропорции на мобиле */
    }
}

/* Very small screens */
@media (max-width: 420px) {
    #cta-appointment .cta-appt__media {
        max-width: 96%;
    }
}

/* =========================================================
   THEME (Light/Dark) — safe overrides (does NOT break slider)
   Requires: <html class="theme-light"> or <html class="theme-dark">
   ========================================================= */



/* 1) Keep slider mechanics intact even if earlier edits existed */
#nova-hero .nh-slide {
    position: absolute;
    inset: 0;
}

#nova-hero .nh-slide.is-active {
    z-index: 2;
}

/* 2) Make sure overlay layer is above image but below content */

#nova-hero .nh-slide picture,
#nova-hero .nh-slide img {
    position: relative;
    z-index: 0;
    pointer-events: none;
}

#nova-hero .nh-slide::after {
    z-index: 1;
    opacity: .45;
}

#nova-hero .nh-card {
    z-index: 2;
    pointer-events: auto;
}

/* 3) Theme-dependent overlay ABOVE the image (this is what you wanted) */
html[data-theme="light"] #nova-hero .nh-slide::after {
    /* soft bright veil so picture stays airy */
    opacity: .22;
    background: linear-gradient(90deg,
            rgba(255, 255, 255, .28) 0%,
            rgba(255, 255, 255, .16) 34%,
            rgba(255, 255, 255, 0) 62%);
}

html[data-theme="dark"] #nova-hero .nh-slide::after,
html[data-theme="dark"] .elementor-704 .elementor-element.elementor-element-51387ac::before {
    opacity: .50 !important;
    background: #1c1c1c !important;
}

html[data-theme="light"] #nova-hero .nh-slide::after,
html[data-theme="light"] .elementor-704 .elementor-element.elementor-element-51387ac::before {
    opacity: .30 !important;
    background: #e3b68d !important;
}

html[data-theme="dark"] #nova-hero .nh-card.nh-right h2 {
    color: #ffffff;
}

.nh-slide img {
    height: 100vh !important;
}

/* Optional: make the whole page background switchable too (if blocks use vars) */
html[data-theme="light"] {
    --baa-bg: #fbf7f2;
    --baa-surface: #ffffff;
    --baa-ink: #1a1a1a;
    --baa-ink-soft: rgba(26, 26, 26, .72);
}

html[data-theme="dark"] {
    --baa-bg: #0f0e0d;
    --baa-surface: #141312;
    --baa-ink: #ffffff;
    --baa-ink-soft: rgba(255, 255, 255, .78);
}

body {
    background: var(--baa-bg, #fbf7f2);
    color: var(--baa-ink, #1a1a1a);
}

/* 4) Theme toggle (uses ONLY: html[data-theme="dark"]) */
.theme-toggle,
.nba-theme-toggle {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 1px solid #eea465;
    background: linear-gradient(135deg, #fbf5ee, #F2EAB0);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .10);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    position: relative;
    transition: transform .25s ease, box-shadow .35s ease, background .35s ease, border-color .35s ease;
}

/* Keep emojis visible even if theme/css resets spans */
.theme-toggle__sun,
.theme-toggle__moon,
.nba-theme-toggle .sun,
.nba-theme-toggle .moon {
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif !important;
    font-size: 14px !important;
    line-height: 1;
}

/* Default: LIGHT => show sun */
.theme-toggle__sun,
.nba-theme-toggle .sun {
    display: inline-flex;
    color: #c9a24d;
}

.theme-toggle__moon,
.nba-theme-toggle .moon {
    display: none;
}

/* DARK => show moon */
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .nba-theme-toggle {
    background: linear-gradient(135deg, #1f1f1f, #2b2b2b);
    border-color: rgba(255, 255, 255, .16);
    box-shadow: 0 10px 22px rgba(0, 0, 0, .55);
}

html[data-theme="dark"] .theme-toggle__sun,
html[data-theme="dark"] .nba-theme-toggle .sun {
    display: none;
}

html[data-theme="dark"] .theme-toggle__moon,
html[data-theme="dark"] .nba-theme-toggle .moon {
    display: inline-flex;
    color: #f3e6c8;
}

.theme-toggle:hover,
.nba-theme-toggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}



/* =========================
   SIGNATURE: HARD FIX (sizes + force front visible)
   Paste at the VERY END of your CSS
========================= */

#home-signature-flip {
    --hf-dia: 240px;
    /* IMPORTANT: base size */
}

@media (max-width:1100px) {
    #home-signature-flip {
        --hf-dia: 204px;
    }
}

@media (max-width:640px) {
    #home-signature-flip {
        --hf-dia: 150px;
    }

    #header [data-items]>* {
        margin: var(--margin, 0 6px);
    }

    .nba-theme-toggle {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        min-height: 30px !important;
    }
}

@media (max-width:360px) {
    #home-signature-flip {
        --hf-dia: 140px;
    }
}

/* Force the circle to have real size */
#home-signature-flip .hf-flip {
    width: var(--hf-dia) !important;
    height: var(--hf-dia) !important;
    overflow: hidden !important;
}

/* Make sure front is visible by default */
#home-signature-flip .hf-front {
    opacity: 1 !important;
    z-index: 2 !important;
}

#home-signature-flip .hf-back {
    z-index: 1 !important;
}

/* Images can be inside picture/source/img — catch all */
#home-signature-flip .hf-front img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    border-radius: 50% !important;
}

html[data-theme="dark"] .baa-btn {
    background: linear-gradient(180deg, #e5d090 0%, #d8c079 55%, #d3ba71 100%);
}

html[data-theme="dark"] .baa-btn:hover {
    background: linear-gradient(180deg, #d3ba71 0%, #d8c079 55%, #e5d090 100%);
    color: #e4e3e3;
}

html[data-theme="dark"] .bba-sa-item,
html[data-theme="dark"] .faq-item,
html[data-theme="dark"] #reviews .rv-card,
html[data-theme="dark"] #home-signature-flip .hf-card {
    background: #444444;
}

html[data-theme="dark"] .baa-title,
html[data-theme="dark"] h1 {
    color: #EDCB75;
}

html[data-theme="dark"] #reviews .rv-text {
    color: #ffffff;
}

html[data-theme="dark"] #reviews .rv-name {
    color: #dcc88f;
}

html[data-theme="dark"] .ct-breadcrumbs {
    color: #d0c297;
    --has-link-decoration: false;
}

html[data-theme="dark"] .first-item a {
    color: #b48e04;
}

html[data-theme="dark"] #reviews .rv-meta,
html[data-theme="dark"] .faq-q {
    color: #dddddd;
}

html[data-theme="dark"] .faq-q::after {
    border-right: 2px solid #c2c2c2;
    border-bottom: 2px solid #c2c2c2;
}

html[data-theme="dark"] .faq-inner {
    color: #d7d7d7;
    background-color: rgb(51 51 51);
}

html[data-theme="dark"] #services-alt .svc-media {
    box-shadow: 0 12px 28px rgba(116, 116, 116, 0.358);
}

html[data-theme="dark"] #services-alt .svc-copy {
    box-shadow: 0 12px 28px rgba(116, 116, 116, 0.358);
    background: #333333;
    border: 1px solid rgb(80 80 80 / 87%);
}

html[data-theme="dark"] #services-alt .svc-title {
    color: #EDCB75;
}

html[data-theme="dark"] #services-alt .svc-lead {
    color: #ffffff;
}

html[data-theme="dark"] #services-alt .svc-points {
    color: #c5c5c5;
}


html[data-theme="dark"] #services-alt .svc-cta a {
    color: #c5af9a;
}

html[data-theme="dark"] #services-alt .svc-cta a:hover {
    color: #EDCB75;
}


/* ===============================
   1) Toggle premium animations
================================ */

/* Smooth press */
.nba-theme-toggle,
.theme-toggle {
    transition: transform .18s ease, box-shadow .35s ease, background .35s ease, border-color .35s ease;
    will-change: transform;
}

.nba-theme-toggle:active,
.theme-toggle:active {
    transform: translateY(0) scale(0.96);
}

/* Icon animation */
.nba-theme-toggle .sun,
.nba-theme-toggle .moon,
.theme-toggle__sun,
.theme-toggle__moon {
    transition: opacity .25s ease, transform .35s ease, filter .35s ease;
}

/* Light glow */
html[data-theme="light"] .nba-theme-toggle,
html[data-theme="light"] .theme-toggle {
    box-shadow: 0 8px 22px rgba(201, 162, 77, .18), 0 6px 16px rgba(0, 0, 0, .10);
}

/* Dark glow */
html[data-theme="dark"] .nba-theme-toggle,
html[data-theme="dark"] .theme-toggle {
    box-shadow: 0 14px 30px rgba(0, 0, 0, .60);
}

html[data-theme="dark"] .nba-theme-toggle .moon,
html[data-theme="dark"] .theme-toggle__moon {
    filter: drop-shadow(0 4px 10px rgba(243, 230, 200, .28));
}

/* Optional: rotate effect (when theme changes) */
html[data-theme="dark"] .nba-theme-toggle .moon,
html[data-theme="dark"] .theme-toggle__moon {
    transform: translate(-50%, -50%) rotate(-10deg) scale(1);
}

html[data-theme="light"] .nba-theme-toggle .sun,
html[data-theme="light"] .theme-toggle__sun {
    transform: translate(-50%, -50%) rotate(10deg) scale(1);
}

/* ===============================
   3) Luxury theme tokens
================================ */

html {
    --baa-bg: #fbf7f2;
    --baa-surface: #ffffff;
    --baa-ink: #1b1b1b;
    --baa-muted: rgba(27, 27, 27, .68);
    --baa-gold: #c9a24d;
    --baa-line: rgba(27, 27, 27, .10);
}

html[data-theme="dark"] {
    --baa-bg: #1c1c1c;
    /* deep black, not pure */
    --baa-surface: #141416;
    /* soft surface */
    --baa-ink: rgba(255, 255, 255, .92);
    --baa-muted: rgba(255, 255, 255, .68);
    --baa-gold: #d6b15f;
    /* warmer gold in dark */
    --baa-line: rgba(255, 255, 255, .12);
}

/* Apply tokens globally (safe) */
body {
    background: var(--baa-bg);
    color: var(--baa-ink);
}

/* Common UI (optional but beautiful) */
a {
    color: var(--baa-ink);
}

a:hover {
    color: var(--baa-gold);
}

hr,
.is-style-wide hr {
    border-color: var(--baa-line);
}



/* =========================================================
   FIX: nba-theme-toggle alignment + remove weird circles
   Put this block at the VERY END of your CSS file
========================================================= */

.nba-theme-toggle {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    min-height: 30px !important;
    padding: 0 !important;
    margin: 0 !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    border-radius: 999px !important;
    overflow: hidden !important;

    line-height: 1 !important;
    text-decoration: none !important;

    /* prevents theme/header styles from shifting it */
    vertical-align: middle !important;
    box-sizing: border-box !important;
}

/* Make both icons perfectly centered and identical box model */
.nba-theme-toggle>span {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;

    padding: 0 !important;
    margin: 0 !important;

    width: auto !important;
    height: auto !important;

    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;

    font-size: 14px !important;
    line-height: 1 !important;

    display: block !important;
    opacity: 0 !important;

    pointer-events: none !important;
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif !important;
}

/* Light = show sun */
.nba-theme-toggle>span.sun {
    opacity: 1 !important;
}

/* Dark = show moon */
html[data-theme="dark"] .nba-theme-toggle>span.sun {
    opacity: 0 !important;
}

html[data-theme="dark"] .nba-theme-toggle>span.moon {
    opacity: 1 !important;
}





/* =========================
   NAILS BY ANAHIT — EXPERIENCE
   Works with: html[data-theme="light"] / html[data-theme="dark"]
========================= */

html[data-theme="light"] {
    --exp-bg: #fbf6ef;
    --exp-surface: rgba(255, 255, 255, 0.72);
    --exp-border: rgba(35, 35, 35, 0.14);
    --exp-text: #1d1b17;
    --exp-muted: rgba(29, 27, 23, 0.68);
    --exp-gold: #c9a227;
    --exp-shadow: 0 18px 40px rgba(0, 0, 0, .08);
}

html[data-theme="dark"] {
    --exp-bg: #1c1c1c;
    --exp-surface: rgba(255, 255, 255, 0.06);
    --exp-border: rgba(255, 255, 255, 0.12);
    --exp-text: rgba(255, 255, 255, 0.92);
    --exp-muted: rgba(255, 255, 255, 0.62);
    --exp-gold: #d4b24c;
    --exp-shadow: 0 18px 50px rgba(0, 0, 0, .35);
}

.nba-exp {
    padding: clamp(56px, 6vw, 50px) 20px;
    background: radial-gradient(1200px 380px at 15% 10%, rgba(201, 162, 39, .14), transparent 60%),
        radial-gradient(900px 320px at 85% 35%, rgba(212, 178, 76, .10), transparent 55%),
        var(--exp-bg);
}

.nba-exp__wrap {
    max-width: 1200px;
    margin: 0 auto;
}

.nba-exp__head {
    text-align: center;
    margin-bottom: 26px;
}

.nba-exp__kicker {
    display: inline-block;
    padding: 8px 14px;
    border: 1px solid var(--exp-border);
    border-radius: 999px;
    color: var(--exp-muted);
    background: var(--exp-surface);
    letter-spacing: .12em;
    text-transform: uppercase;
    font-size: 12px;
}

.nba-exp__title {
    margin: 14px 0 8px;
    color: #664819;
    font-size: clamp(28px, 3.2vw, 44px);
    line-height: 1.05;
}

html[data-theme="dark"] .nba-exp__title {
    color: #EDCB75;
}

.nba-exp__sub {
    margin: 0 auto;
    max-width: 720px;
    color: var(--exp-muted);
    font-size: 16px;
}

.nba-exp__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-top: 28px;
}

.nba-exp__card {
    background: var(--exp-surface);
    border: 1px solid var(--exp-border);
    border-radius: 22px;
    padding: 18px 18px 16px;
    box-shadow: var(--exp-shadow);
    backdrop-filter: blur(10px);
    transform: translateY(0);
    transition: transform .25s ease, border-color .25s ease;
}

.nba-exp__card:hover {
    transform: translateY(-4px);
    border-color: rgba(201, 162, 39, .35);
}

.nba-exp__icon {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(201, 162, 39, .22), rgba(212, 178, 76, .10));
    border: 1px solid rgba(201, 162, 39, .28);
    color: var(--exp-gold);
    margin-bottom: 12px;
    font-size: 18px;
}

.nba-exp__h {
    margin: 0 0 6px;
    color: var(--exp-text);
    font-size: 18px;
}

.nba-exp__p {
    margin: 0;
    color: var(--exp-muted);
    font-size: 14px;
    line-height: 1.55;
}

.nba-exp__bar {
    margin-top: 18px;
    padding: 16px;
    border-radius: 22px;
    border: 1px solid var(--exp-border);
    background: var(--exp-surface);
    backdrop-filter: blur(10px);
    display: flex;
    gap: 14px;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.nba-exp__chips {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.nba-exp__chip {
    padding: 10px 12px;
    border-radius: 999px;
    border: 1px solid var(--exp-border);
    color: var(--exp-muted);
    font-size: 13px;
}

.nba-exp__actions {
    display: flex;
    gap: 10px;
}

.nba-exp__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid var(--exp-border);
    text-decoration: none;
    font-weight: 600;
    letter-spacing: .04em;
    transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.nba-exp__btn:hover {
    transform: translateY(-1px);
}

.nba-exp__btn--primary {
    background: linear-gradient(135deg, rgba(201, 162, 39, .22), rgba(212, 178, 76, .10));
    border-color: rgba(201, 162, 39, .35);
    color: var(--exp-text);
}

.nba-exp__btn--ghost {
    background: transparent;
    color: var(--exp-text);
}

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

@media (max-width: 560px) {
    .nba-exp__grid {
        grid-template-columns: 1fr;
    }

    .nba-exp__actions {
        width: 100%;
    }

    .nba-exp__btn {
        width: 100%;
    }
}



/* GOLD PARALLAX GLOW LAYER */
.nba-exp {
    position: relative;
    overflow: hidden;
}

/* Moving gold glow */
.nba-exp::after {
    content: "";
    position: absolute;
    inset: -20%;
    pointer-events: none;

    background:
        radial-gradient(420px 420px at var(--gold-x, 50%) var(--gold-y, 30%),
            rgba(201, 162, 39, .22),
            transparent 65%);

    opacity: .55;
    transform: translateY(var(--gold-shift, 0px));
    transition: opacity .3s ease;
}



html[data-theme="light"] .nba-exp::after {
    opacity: .35;
}


.wp-block-list li a {
    color: #C8BFA9;
}

.ct-social-box .ct-icon-container svg {
    fill: #FFFFFF;
}

html[data-theme="light"] [data-icons-type*=solid] .ct-icon-container:hover {
    background-color: #6c6c6c !important;
}

html[data-theme="light"] [data-icons-type*=solid] .ct-icon-container:hover svg {
    fill: #FFFFFF;
}


/* ===================== overrides.css ===================== */
/* =======================================================================
   Beauty By Anahit — Clean CSS (2025) · FIXED
   - color-mix() corrected
   - Shimmer scope narrowed (no more overlay blocking clicks)
   - Navigation underline stabilized
   - Lightbox z-index normalized
   - Minor polish for reviews arrows
   ======================================================================= */

/* =========================
   0) Global Design Tokens
   ========================= */

/* Utilities */
.baa-container {
    max-width: var(--baa-maxw);
    margin: 0 auto;
    padding: 48px 20px;
}

.fade-up {
    opacity: 0;
    transform: translateY(18px);
    animation: fadeUp .6s ease .05s forwards;
}

@keyframes fadeUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* =========================
   1) Typography & Base
   ========================= */
body {
    background: var(--ivory);
    color: var(--baa-text);
    /* Prefer normal/medium weights for body text; Black for headings only */
    font-family: 'Playfair Display', Georgia, serif !important;
    line-height: 1.7;
}

h2 {
    font-weight: 700 !important;
    letter-spacing: .3px !important;
    font-size: clamp(28px, 5.4vw, 44px) !important;
    line-height: 1.15;
    margin: 0 0 28px !important;
    text-align: center;
    color: var(--heading);
}

/* Eyebrow text */
.gold-eyebrow {
    display: block;
    margin-bottom: 8px;
    font: 600 12px/1.2 system-ui, "Poppins", Arial, sans-serif;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--baa-muted);
}

/* =========================
   3) Navigation & Links
   ========================= */
.ct-main-navigation a {
    font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
    color: var(--baa-text);
    font-weight: 500;
    letter-spacing: .4px;
    position: relative;
    display: inline-block;
    /* stabilize underline box */
    transition: color .25s ease;
}

.ct-main-navigation a:hover {
    color: #f4e2b5;
}

.ct-main-navigation a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    /* tighter than -10px to avoid overflow */
    height: 2px;
    width: 0;
    background: #f4e2b5;
    pointer-events: none;
    transition: width .25s ease;
}

.ct-main-navigation a:hover::after {
    width: 100%;
}

a {
    color: #f4e2b5;
    text-decoration: none;
    transition: color .25s ease;
}

a:hover,
a:focus {
    /* FIX: color-mix syntax corrected (80% first color, 20% second) */
    color: color-mix(in srgb, #f4e2b5 80%, #000 20%);
}

::selection {
    background: #f4e2b5;
    color: #fff;
}

/* =========================
   4) Cards / Sections
   ========================= */
.section-light,
.card,
.wp-block-group.has-background {
    background: var(--linen);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--baa-shadow);
}

hr,
.wp-block-separator {
    border-color: var(--border);
}



/* Outline variant */
.button-outline {
    background: transparent !important;
    border: 1.5px solid #f4e2b5 !important;
    color: #f4e2b5 !important;
}

.button-outline:hover {
    background: #f4e2b5 !important;
    color: #fff !important;
}

/* === Global shimmer — SAFE, narrowed scope ===
   Only apply to actual site buttons to avoid overlay issues.
*/


/* Disable shimmer programmatically if needed */
.no-shine,
.no-shine::after {
    animation: none !important;
}



/* =========================
   6) Socials
   ========================= */
.ct-header .ct-header-socials a {
    color: #fff !important;
    background: #DCD5D2 !important;
    border-radius: 999px;
    width: 33px;
    height: 33px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all .25s ease;
}

.ct-header .ct-header-socials a:hover,
#footer .ct-socials-block a:hover {
    transform: translateY(-2px);
    color: #fff !important;
}

/* =========================
   7) Gallery & Forms
   ========================= */
.modula-item-content:hover img {
    transform: scale(1.1);
}

.gallery-section img {
    border-radius: 12px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, .05);
    transition: all .3s;
}

.gallery-section img:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .08);
}

input,
select,
textarea {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 12px 14px;
    transition: border-color .25s, box-shadow .25s;
}

input:focus,
select:focus,
textarea:focus {
    border-color: #f4e2b5;
    box-shadow: 0 0 0 4px rgba(201, 162, 39, .15);
    outline: none;
}

/* =========================
   8) Footer (Dior Gradient)
   ========================= */
#footer [data-row="middle"] {
    background: linear-gradient(180deg, var(--dior-1) 0%, var(--dior-2) 50%, var(--dior-3) 100%) !important;
    color: var(--footer-text);
}

#footer [data-row="bottom"] {
    background: linear-gradient(180deg, var(--dior-3) 0%, #574C47 100%) !important;
    color: var(--footer-text);
    border-top: 1px solid rgba(255, 255, 255, .08);
}

#footer a {
    color: var(--footer-text);
    transition: color .25s;
}

#footer a:hover {
    color: #e6cb7b;
}

#footer .footer-brand__title {
    color: #fff;
    font-family: 'Playfair Display', serif !important;
}

#footer .footer-brand__tagline {
    color: #C8BFA9;
}

/* Footer spacing — desktop explicit */
[data-footer*="type-1"] .ct-footer [data-row*="middle"]>div {
    --widgets-gap: 20px;
    --vertical-alignment: center;
    --theme-border: none;
    --theme-border-top: none;
    --theme-border-bottom: none;
    --grid-template-columns: 1fr 2fr 1fr;
    padding-top: 110px !important;
    /* top spacing */
    padding-bottom: 60px !important;
    /* bottom spacing */
}

/* Footer — mobile layout */
@media (max-width: 768px) {
    #footer.ct-footer [data-row="middle"] [data-column="widget-area-1"] {
        display: none !important;
    }

    #footer.ct-footer [data-row="middle"] .ct-container {
        display: grid !important;
        grid-template-columns: 1fr !important;
        justify-items: center;
        align-items: start;
        gap: 22px;
    }

    #footer.ct-footer [data-row="middle"] [data-column="widget-area-2"],
    #footer.ct-footer [data-row="middle"] [data-column="widget-area-3"] {
        width: 100% !important;
        max-width: 720px;
        margin: 0 auto;
        text-align: center;
    }

    [data-footer*="type-1"] .ct-footer [data-row*="middle"]>div {
        padding-top: 56px !important;
        padding-bottom: 48px !important;
    }

    #footer.ct-footer .ct-container * {
        line-height: 1.6;
    }

    #footer.ct-footer .ct-social-box,
    #footer.ct-footer .social-icons {
        justify-content: center !important;
        gap: 12px !important;
    }

    #footer.ct-footer [data-row="middle"] [data-column="widget-area-2"] {
        order: 1 !important;
    }

    #footer.ct-footer [data-row="middle"] [data-column="widget-area-3"] {
        order: 2 !important;
    }
}

/* =========================
   9) Reviews (Carousel)
   ========================= */
#reviews .rv-viewport {
    position: relative;
    overflow: hidden;
    border-radius: var(--baa-radius);
    box-shadow: var(--baa-shadow);
}

#reviews .rv-track {
    display: flex;
    flex-wrap: nowrap;
    will-change: transform;
    transition: transform var(--baa-speed, .42s) cubic-bezier(.22, .61, .36, 1);
}

#reviews .rv-track>.rv-slide {
    flex: 0 0 100%;
    max-width: 100%;
    padding: clamp(20px, 3.2vw, 40px);
    display: grid;
    align-items: center;
}

#reviews .rv-card {
    max-width: 820px;
    margin: 0 auto;
    position: relative;
}

#reviews .rv-card p {
    margin: 0 0 12px;
}

/* Arrows */
#reviews .rv-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    height: 44px;
    width: 44px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    border: 1px solid color-mix(in srgb, var(--baa-gold, #C9A227) 60%, #fff 40%);
    background: linear-gradient(180deg, #fff, #fbf8f1);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .1);
    z-index: 2;
    outline: none;
    backdrop-filter: blur(2px);
}

#reviews .rv-prev {
    left: clamp(16px, 1.6vw, 22px);
}

#reviews .rv-next {
    right: clamp(16px, 1.6vw, 22px);
}

#reviews .rv-arrow svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: var(--baa-gold, #C9A227);
    stroke-width: 2;
}

@media (max-width: 480px) {
    #reviews .rv-prev {
        left: 12px;
    }

    #reviews .rv-next {
        right: 12px;
    }
}

/* Dots */
#reviews .rv-dots {
    display: flex;
    gap: 10px;
    justify-content: center;
    align-items: center;
    padding: 14px 0 0;
}

#reviews .rv-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #D8D8D8;
    transition: transform .18s, background .18s;
}

#reviews .rv-dot[aria-current="true"] {
    background: var(--baa-gold, #C9A227);
    transform: scale(1.15);
}

/* =========================
   10) Elementor Lightbox (Unified)
   ========================= */
.elementor-lightbox,
.dialog-type-lightbox {
    /* Use max 32-bit safe value */
    z-index: 2147483647 !important;
}

.elementor-lightbox .elementor-slideshow__next,
.elementor-lightbox .elementor-slideshow__prev,
.elementor-lightbox .elementor-swiper-button,
.dialog-type-lightbox .dialog-lightbox-next,
.dialog-type-lightbox .dialog-lightbox-prev {
    opacity: 1 !important;
    visibility: visible !important;
    position: fixed !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0, 0, 0, .32) !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, .25) !important;
    cursor: pointer !important;
}

.elementor-lightbox .elementor-swiper-button-prev,
.dialog-type-lightbox .dialog-lightbox-prev {
    left: 18px !important;
}

.elementor-lightbox .elementor-swiper-button-next,
.dialog-type-lightbox .dialog-lightbox-next {
    right: 18px !important;
}

@media (max-width: 480px) {

    .elementor-lightbox .elementor-swiper-button-prev,
    .dialog-type-lightbox .dialog-lightbox-prev {
        left: 12px !important;
    }

    .elementor-lightbox .elementor-swiper-button-next,
    .dialog-type-lightbox .dialog-lightbox-next {
        right: 12px !important;
    }
}

/* Arrow icon ensure visible regardless of theme */
.elementor-lightbox .elementor-slideshow__icon,
.elementor-lightbox .elementor-swiper-button i,
.elementor-lightbox .elementor-swiper-button svg,
.elementor-lightbox .elementor-swiper-button path {
    color: #fff !important;
    stroke: #fff !important;
    fill: none !important;
    stroke-width: 2 !important;
}

/* Close button on top of everything (safe cap) */
.elementor-lightbox .dialog-lightbox-close-button {
    z-index: 2147483647 !important;
}

/* =========================
   11) Utilities (for Elementor)
   ========================= */
.text-gold {
    color: #f4e2b5 !important;
}

.text-muted {
    color: var(--baa-muted) !important;
}

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

.text-white {
    color: #fff !important;
}

.bg-cream {
    background: var(--baa-bg-cream) !important;
}

.bg-linen {
    background: var(--baa-bg-linen) !important;
}

.bg-ivory {
    background: var(--ivory) !important;
}

.bg-dior {
    background: linear-gradient(180deg, var(--dior-1) 0%, var(--dior-2) 50%, var(--dior-3) 100%) !important;
    color: var(--footer-text) !important;
}

.shadow-sm {
    box-shadow: 0 4px 12px rgba(0, 0, 0, .06) !important;
}

.shadow-md {
    box-shadow: 0 8px 24px rgba(0, 0, 0, .08) !important;
}

.shadow-lg {
    box-shadow: 0 14px 40px rgba(0, 0, 0, .12) !important;
}

.radius-sm {
    border-radius: 8px !important;
}

.radius-md {
    border-radius: 14px !important;
}

.radius-lg {
    border-radius: 22px !important;
}

.border-gold {
    border: 1px solid #f4e2b5 !important;
}

.btn-gold {
    background: linear-gradient(180deg, var(--gold-10) 0%, var(--gold-60) 60%, var(--gold-80) 100%) !important;
    color: #1A1A1A !important;
    border: none;
    border-radius: 14px;
    padding: 12px 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    letter-spacing: .4px;
    text-transform: uppercase;
}

.btn-gold:hover {
    color: #fff !important;
    background: linear-gradient(180deg, var(--gold-20) 0%, var(--gold-70) 70%, var(--gold-80) 100%) !important;
}

.btn-gold-outline {
    background: transparent !important;
    border: 1.5px solid #f4e2b5 !important;
    color: #f4e2b5 !important;
    border-radius: 14px;
    padding: 12px 26px;
}

.btn-gold-outline:hover {
    background: #f4e2b5 !important;
    color: #fff !important;
}

.text-center {
    text-align: center !important;
}

.flex-center {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}


/* ==== QUICK PATCH · 2025-11-09 ===================================== */
/* 1) Вернём нормальные шрифты: sans для текста, Playfair оставим для h2 */
body {
    font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
}

/* 2) Починка глобального оверрайда секций:
      я случайно дал фон всем .wp-block-group.has-background */
.wp-block-group.has-background {
    background: transparent !important;
    /* вернуть прозрачность */
    border: none !important;
    box-shadow: none !important;
}

/* (опционально) если тебе нужна «карточка» – добавляй класс .section-light на нужный блок */
.section-light {
    background: var(--linen) !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px !important;
    box-shadow: var(--baa-shadow) !important;
}

/* 3) Блок «Why Clients Choose Me» — базовая читабельность поверх фото */
#why-choose,
#why-clients-choose-me,
#home-why,
.why-choose {
    position: relative;
}

#why-choose .ct-container,
#why-clients-choose-me .ct-container,
#home-why .ct-container,
.why-choose .ct-container {
    position: relative;
    z-index: 2;
}

#why-choose::before,
#why-clients-choose-me::before,
#home-why::before,
.why-choose::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, .0), rgba(0, 0, 0, .10) 45%, rgba(0, 0, 0, .12));
    z-index: 1;
    pointer-events: none;
}



/* 6) Навигация — подчёркивание не «толкает» */
.ct-main-navigation a {
    display: inline-block;
    position: relative;
}

.ct-main-navigation a::after {
    bottom: -6px;
    pointer-events: none;
}

/* 7) color-mix синтаксис (на всякий случай ещё раз) */
a:hover,
a:focus {
    color: color-mix(in srgb, #f4e2b5 80%, #000 20%);
}

/* ==================================================================== */


/* =========================
   4) Buttons · Luxury Satin Gold (REPLACE)
   ========================= */



/* OUTLINE / GHOST button look (Book Now) */
.bba-btn--ghost,
.elementor .elementor-button.bba-btn--ghost,
.elementor a.elementor-button.bba-btn--ghost,
a.elementor-button.bba-btn--ghost {
    background: rgba(255, 255, 255, .22);
    border: 1px solid var(--btn-border-gold);
    color: #1A1A1A;
    box-shadow: 0 10px 24px rgba(0, 0, 0, .08);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

/* Outline hover: elegant dark fill (premium) */
.bba-btn--ghost:hover,
.elementor .elementor-button.bba-btn--ghost:hover,
.elementor a.elementor-button.bba-btn--ghost:hover,
a.elementor-button.bba-btn--ghost:hover {
    background: rgba(26, 26, 26, .88);
    color: var(--btn-text-on-dark);
    border-color: rgba(26, 26, 26, .22);
    box-shadow: 0 18px 44px rgba(0, 0, 0, .16);
}









/* =========================
   Luxury Buttons (Cream)
   Primary = filled cream
   Ghost   = outline cream
   Works for Elementor + WPForms + custom classes
========================= */

/* --- Design tokens --- */
:root {
    --bba-radius: 999px;
    --bba-pad-y: 12px;
    --bba-pad-x: 28px;

    /* Cream / Champagne palette */
    --bba-cream-1: #fffaf5;
    --bba-cream-2: #f5ede3;
    --bba-cream-3: #eadbc8;

    --bba-ink: #1d1b18;
    --bba-ink-soft: #5b5349;

    --bba-border: rgba(140, 120, 95, .32);

    --bba-shadow: 0 10px 26px rgba(0, 0, 0, .10);
    --bba-shadow-hover: 0 18px 44px rgba(0, 0, 0, .14);
    --bba-ring: 0 0 0 4px rgba(210, 190, 160, .35);
}


/* ===================== hero.css ===================== */
/* ===== Sizes/Colors (сделала выше) */
#nova-hero {
    --nh-height: clamp(600px, 68vh, 820px);
    /* выше и «шире» по кадру */
    --nh-height-m: 60vh;
    --gold-1: #E7CF8A;
    --gold-2: #C9A227;
    --ink: #111;
    --cream: #FBF9F6;
}

#nova-hero {
    position: relative;
    display: block;
    max-width: 1940px;
    margin: 0 auto
}

#nova-hero .nh-stage {
    position: relative;
    height: var(--nh-height);
    background: var(--cream);
    overflow: hidden;
    border-radius: 0
}

/* ===== Slide */
.nh-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity .7s ease
}

.nh-slide.is-active {
    opacity: 1;
    z-index: 2
}

.nh-slide picture,
.nh-slide img {
    display: block;
    width: 100%;
    height: 100%
}

.nh-slide img {
    object-fit: cover;
    transform-origin: 60% 50%;
    animation: kenburns 12s ease-out both
}

.nh-slide:nth-child(2) img {
    transform-origin: center 35%
}

.nh-slide:nth-child(3) img {
    transform-origin: 30% 50%
}

/* Мягкий Ken Burns */
@keyframes kenburns {
    0% {
        transform: scale(1.02)
    }

    100% {
        transform: scale(1.06)
    }
}

/* ===== Очень мягкая вуаль (без «мутности») */
.nh-slide::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .50;
    transition: opacity .4s ease;
    background: linear-gradient(90deg, rgba(0, 0, 0, .50) 0%, rgba(0, 0, 0, .22) 28%, rgba(0, 0, 0, 0) 58%);
}

.nh-slide[data-theme="light"]::after {
    opacity: .16;
    background: linear-gradient(90deg, rgba(255, 255, 255, .20) 0%, rgba(255, 255, 255, .08) 24%, rgba(255, 255, 255, 0) 55%);
}

/* ===== Glass Card (по правому краю) */
.nh-card {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    max-width: min(560px, 45vw);
    padding: 22px 26px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .32);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    color: var(--ink);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .14);
    opacity: 0;
    translate: 0 10px;
    transition: opacity .5s ease, translate .5s ease
}

.nh-card.nh-right {
    right: clamp(24px, 6vw, 6%);
    text-align: right
}

.nh-slide.is-active .nh-card {
    opacity: 1;
    translate: 0 0
}

.nh-slide[data-theme="dark"] .nh-card {
    background: rgb(215 215 215 / 34%);
    color: #fff
}

/* ===== Gold shimmer title (h2) */
.nh-title {
    margin: 0 0 10px;
    line-height: 1.05;
    font-weight: 800;
    font-size: clamp(28px, 5vw, 56px);
    background: linear-gradient(110deg, #2B2B2B 0%, #2B2B2B 10%, #B89A2A 28%, #E6D08B 42%, #C9A227 60%, #E3CE87 78%, #B68F10 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    background-size: 220% 100%;
    animation: title-rise .45s ease-out forwards, title-shimmer 3.6s linear .5s infinite
}

@keyframes title-rise {
    from {
        opacity: 0;
        transform: translateY(8px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes title-shimmer {
    0% {
        background-position: 200% 50%
    }

    100% {
        background-position: 0% 50%
    }
}

/* ===== Sub + CTA */
.nh-sub {
    margin: 0 0 16px;
    font-size: clamp(14px, 1.25vw, 18px);
    opacity: .95
}

.nh-cta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end
}

.nh-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 10px 26px;
    border-radius: 16px;
    font-size: 18px;
    text-decoration: none;
    transition: transform .15s ease, filter .2s
}

.nh-btn--gold {
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    color: #111;
    border: 0
}

.nh-btn--ghost {
    border: 2px solid var(--gold-2);
    color: #333333;
    background: #ffffff85;
}

.nh-btn--ghost:hover {
    background: var(--gold-2);
    color: #ffffff;
}

/* ===== Arrows */
.nh-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 0;
    cursor: pointer;
    z-index: 5
}

.nh-prev {
    left: 14px
}

.nh-next {
    right: 14px
}

.nh-nav {
    background: rgba(0, 0, 0, .55);
    color: #fff;
    font-size: 26px;
    line-height: 44px;
    text-align: center
}

.nh-nav:hover {
    background: rgba(0, 0, 0, .75)
}

/* ===== Dots + progress */
.nh-dots {
    position: absolute;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 6
}

.nh-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(0, 0, 0, .7);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, .6);
    border: 0;
    cursor: pointer
}

.nh-dot.is-active {
    background: #111
}

.nh-progress {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: rgba(0, 0, 0, .08);
    z-index: 6
}

.nh-progress span {
    display: block;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--gold-2), var(--gold-1))
}

/* ===== Mobile */
@media (max-width: 768px) {
    #nova-hero .nh-stage {
        height: var(--nh-height-m)
    }

    .nh-card {
        left: 50%;
        right: auto;
        transform: translate(-50%, -50%);
        max-width: min(92vw, 520px);
        text-align: center;
        padding: 14px 16px
    }

    .nh-cta {
        justify-content: center
    }
}

/* отступ после блока */
#nova-hero+* {
    margin-top: 24px
}


/* ===== NovaHero · FIX arrows + Mobile wide bottom card ===== */

/* 1) Стрелки: остаются по краям и без глобального блика */
.nh-nav,
.nh-nav::after {
    animation: none !important;
    /* отключаем shimmer, чтобы не «вело» */
}

.nh-nav {
    position: absolute !important;
    top: 50%;
    transform: translateY(-50%);
    z-index: 6;
}

.nh-prev {
    left: 14px !important;
}

.nh-next {
    right: 14px !important;
}

/* 2) Мобайл: карточка шире (≈80%) и внизу */
@media (max-width: 768px) {

    /* сама карточка */
    .nh-card {
        left: 50% !important;
        right: auto !important;
        top: auto !important;
        bottom: 25px !important;
        /* у самого низа */
        transform: translateX(-50%) !important;
        width: 90vw !important;
        max-width: 90vw !important;
        /* 70–80%? меняй на 70vw если нужно */
        text-align: center !important;
        padding: 16px 18px !important;
    }

    /* кнопки по центру */
    .nh-cta {
        justify-content: center !important;
    }

    /* точки чуть ниже, чтобы не наезжали на карточку */
    .nh-dots {
        bottom: 8px !important;
    }
}


/* Hero buttons — use global luxury button system */
.nh-btn {
    border-radius: 999px !important;
    padding: 12px 26px !important;
    font-weight: 600 !important;
    letter-spacing: .22px !important;
    text-transform: uppercase !important;
}

.nh-btn--primary {
    /* Primary is already covered by global button styles */
}

.nh-btn--ghost {
    background: rgba(255, 255, 255, .22) !important;
    border: 1px solid rgba(201, 162, 39, .55) !important;
    color: #1A1A1A !important;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.nh-btn--ghost:hover {
    background: rgba(26, 26, 26, .88) !important;
    color: #fff !important;
    border-color: rgba(26, 26, 26, .22) !important;
}


/* ===================== signature.css ===================== */
/* Section */
#home-signature-flip {
    background: transparent;
    padding: 80px 20px;
}

#home-signature-flip .hf-wrap {
    max-width: 1200px;
    margin: 0 auto;
}

/* Head */
#home-signature-flip .hf-head {
    text-align: center;
    margin-bottom: 12px;
}

#home-signature-flip .hf-title {
    margin: 0 0 8px;
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: clamp(30px, 4.8vw, 48px);
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: .3px;
}

#home-signature-flip .hf-sub {
    margin: 0 auto;
    max-width: 760px;
    color: var(--txt);
    line-height: 1.75;
    font-size: clamp(14px, 1.6vw, 16px);
}

/* Grid: desktop 3 cols, ≤1100px 2 cols, ≤640px 2 cols */
#home-signature-flip .hf-grid {
    display: grid;
    gap: 18px;
    margin-top: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width:1100px) {
    :root {
        --hf-dia: 204px;
    }

    /* уменьшаем круг на планшетах */
    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }
}

@media (max-width:640px) {
    :root {
        --hf-dia: 188px;
    }

    /* телефоны */
    #home-signature-flip {
        padding: 56px 4px 48px;
    }

    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

}

@media (max-width:360px) {
    :root {
        --hf-dia: 170px;
    }

    /* очень узкие */
}

/* Card shell — фиксируем минимальную высоту по кругу */
#home-signature-flip .hf-card {
    position: relative;
    background: linear-gradient(180deg, #FFFFFF 0%, var(--veil) 100%);
    border: 1px solid rgba(207, 163, 58, .26);
    border-radius: var(--br-lg);
    box-shadow: var(--shadow-1);
    padding: 14px 16px 16px;
    text-align: center;
    transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: calc(var(--hf-dia) + 110px);
    /* заголовок + круг + кнопка */
}

#home-signature-flip .hf-card:hover {
    box-shadow: var(--shadow-2);
    border-color: rgba(207, 163, 58, .48);
    transform: translateY(-2px);
}

#home-signature-flip .hf-h3 {
    margin: 2px 0 10px;
    color: var(--ink);
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: clamp(18px, 2.3vw, 22px);
    letter-spacing: .2px;
}

/* Flip circle — ЧЁТКИЙ размер от переменной, центрируем */
#home-signature-flip .hf-flip {
    width: var(--hf-dia);
    height: var(--hf-dia);
    margin: 0 auto 12px;
    border-radius: 50%;
    position: relative;
    perspective: 1000px;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .06);
    outline: none;
    flex: 0 0 auto;
    /* не давим круг */
}

#home-signature-flip .hf-flip-inner {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    transform-style: preserve-3d;
    transition: transform .7s cubic-bezier(.2, .65, .2, 1);
}

/* Faces — НЕ ПРОСВЕЧИВАТЬ */
#home-signature-flip .hf-front,
#home-signature-flip .hf-back {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .2s ease;
}

#home-signature-flip .hf-front {
    opacity: 1;
    z-index: 2;
}

#home-signature-flip .hf-back {
    opacity: 0;
    z-index: 1;
    transform: rotateY(180deg);
}

/* Состояния flip */
#home-signature-flip .hf-flip:hover .hf-flip-inner,
#home-signature-flip .hf-flip:focus-visible .hf-flip-inner,
#home-signature-flip .hf-flip.is-flipped .hf-flip-inner {
    transform: rotateY(180deg);
}

#home-signature-flip .hf-flip:hover .hf-front,
#home-signature-flip .hf-flip:focus-visible .hf-front,
#home-signature-flip .hf-flip.is-flipped .hf-front {
    opacity: 0;
}

#home-signature-flip .hf-flip:hover .hf-back,
#home-signature-flip .hf-flip:focus-visible .hf-back,
#home-signature-flip .hf-flip.is-flipped .hf-back {
    opacity: 1;
}

#home-signature-flip .hf-front img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1.03);
    transition: transform .55s ease;
}

#home-signature-flip .hf-flip:hover .hf-front img {
    transform: scale(1.08);
}

#home-signature-flip .hf-back {
    padding: 16px;
    color: #2B2B2B;
    line-height: 1.6;
    font-size: 15px;
    background: radial-gradient(120% 120% at 50% 0%, #FFFFFF 0%, #F7F1E7 60%, #F0E6D7 100%);
    border: 1px solid rgba(207, 163, 58, .28);
}

/* Button under circle */
/*#home-signature-flip .hf-btn {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     gap: 8px;
     padding: 11px 16px;
     border-radius: var(--pill);
     font-weight: 700;
     text-decoration: none;
     border: 1px solid rgba(207, 163, 58, .55);
     color: #A8791F;
     background: #FFFFFF;
     box-shadow: 0 6px 16px rgba(0, 0, 0, .06);
     transition: color .2s ease, background .2s ease, transform .2s ease;
     margin-top: auto;
     кнопка прилипает книзу карточки, но внутри 
 }*/

#home-signature-flip .hf-btn::after {
    content: "➜";
    font-size: 14px;
    line-height: 1;
    transform: translateY(1px);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    #home-signature-flip .hf-flip-inner {
        transition: none;
    }

    #home-signature-flip .hf-front,
    #home-signature-flip .hf-back {
        transition: none;
    }
}

/* ===== MOBILE FIX: 2-в-ряд, круг идеально входит, flip без 3D ===== */
@media (max-width: 640px) {

    /* сетка — две колонки */
    #home-signature-flip .hf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 14px !important;
    }

    #home-signature-flip .hf-h3 span {
        display: none;
    }

    /* компактные карточки, без лишних ограничений по высоте */
    #home-signature-flip .hf-card {
        padding: 12px 12px 14px !important;
        border-radius: 20px !important;
        min-height: auto !important;
        overflow: hidden !important;
        transform: none !important;
    }

    #home-signature-flip .hf-h3 {
        font-size: 18px !important;
        margin: 2px 0 8px !important;
    }

    /* КРУГ: диаметр под ширину колонки
     calc(50vw - 60px) ≈ половина экрана минус поля + gap */
    #home-signature-flip .hf-flip {
        width: clamp(136px, calc(50vw - 60px), 176px) !important;
        height: clamp(136px, calc(50vw - 60px), 176px) !important;
        margin: 0 auto 10px !important;
        border-radius: 50% !important;
        perspective: none !important;
        /* отключаем 3D на мобиле */
    }

    /* Мобильный flip через прозрачность (без rotate) */
    #home-signature-flip .hf-flip-inner {
        transform: none !important;
    }

    #home-signature-flip .hf-front,
    #home-signature-flip .hf-back {
        position: absolute;
        inset: 0;
        border-radius: 50%;
        transform: none !important;
        backface-visibility: visible !important;
        -webkit-backface-visibility: visible !important;
        transition: opacity .25s ease !important;
    }

    #home-signature-flip .hf-front {
        opacity: 1 !important;
        z-index: 2;
    }

    #home-signature-flip .hf-back {
        opacity: 0 !important;
        z-index: 1;
        line-height: 1.4;
        font-size: 13px;
    }

    /* показываем тыл по тапу/клику */
    #home-signature-flip .hf-flip.is-flipped .hf-front {
        opacity: 0 !important;
    }

    #home-signature-flip .hf-flip.is-flipped .hf-back {
        opacity: 1 !important;
    }

    /* Кнопка поменьше */
    #home-signature-flip .hf-btn {
        padding: 9px 12px !important;
        font-size: 14px !important;
    }

    #reviews .rv-quote {
        margin-bottom: 0px;
    }

    #reviews .rv-text {
        line-height: 1.35;
    }

    .baa-btn {
        padding: 12px 17px;
        letter-spacing: .0em;
    }

    .ans-badge {
        padding: 10px 12px;
    }

    .ans-contact-hero__wrap {
        padding: 0 10px;
    }

}

/* Очень узкие экраны — круг ещё на шаг меньше */
@media (max-width: 360px) {
    #home-signature-flip .hf-flip {
        width: 130px !important;
        height: 130px !important;
    }
}


/* ===================== services.css ===================== */
/* ===== Beauty By Anahit · Services (no animations) + CTA button ===== */

/* Background gradient: top → bottom */
#bba-services-alt {
    padding: 80px 0;
    overflow: clip;
}

.bba-sa-wrap {
    max-width: var(--wrap);
    margin: 0 auto;
    padding: 0 24px;
}

/* Header: plain (no effects), you can style it later */
.bba-sa-head {
    text-align: left;
    margin: 0 0 56px;
}

.bba-sa-eyebrow {
    display: inline-block;
    font-size: 13px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--sub);
    background: rgba(255, 255, 255, .65);
    border: 1px solid rgba(0, 0, 0, .06);
    border-radius: 999px;
    padding: 8px 14px;
    margin-bottom: 14px;
    backdrop-filter: blur(6px);
}

.bba-underline {
    width: 112px;
    height: 6px;
    border-radius: 8px;
    background: linear-gradient(90deg, var(--gold-2), var(--gold-1));
    box-shadow: 0 3px 14px rgba(201, 162, 39, .25);
    margin: 16px 0 0;
}

.bba-sa-head p {
    color: var(--sub);
    font-size: 18px;
    margin: 16px 0 0;
}

/* List */
.bba-sa-list {
    display: flex;
    flex-direction: column;
    gap: 28px;
    margin-top: 44px;
    position: relative;
}

.bba-sa-list::before {
    content: "";
    position: absolute;
    left: 0;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: linear-gradient(to bottom, transparent, var(--gold-1), transparent);
    opacity: .3;
}

/* Card */
.bba-sa-item {
    position: relative;
    background: rgba(255, 255, 255, .82);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(0, 0, 0, .04);
    border-radius: var(--radius);
    padding: 26px 28px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, .07);
    transition: box-shadow .2s ease, transform .2s ease;
    /* small hover only */
}

.bba-sa-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, .09);
}

/* pearl marker */
.bba-sa-item::before {
    content: "";
    position: absolute;
    left: -9px;
    top: 30px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #fff, #fff 46%, #e6d398 47%, var(--gold-2) 100%);
    box-shadow: 0 0 0 3px #fff;
}

/* Inner grid */
.bba-sa-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    align-items: center;
}

.bba-sa-item h3 {
    font-family: "Playfair Display", serif;
    margin: 0 0 6px;
    font-size: clamp(22px, 2.2vw, 28px);
    color: #2E2B29;
    letter-spacing: .2px;
}

.bba-sa-item p {
    color: var(--sub);
    font-size: 15.5px;
    line-height: 1.6;
    margin: 0;
}

.bba-sa-meta {
    display: flex;
    align-items: center;
    gap: 18px;
    white-space: nowrap;
}

.bba-price {
    font-weight: 700;
    font-size: 16px;
    color: var(--ink);
    padding: 10px 14px;
    border-radius: 999px;
    background: linear-gradient(180deg, #fff, #f7f3e6);
    border: 1px solid rgba(0, 0, 0, .06);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
}

/* Unified button style (no shine, no auto effects — only subtle hover) */
.bba-sa-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 26px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .2px;
    text-decoration: none;
    color: #1a1a1a;
    background: linear-gradient(180deg, var(--gold-1), var(--gold-2));
    box-shadow: 0 10px 22px rgba(201, 162, 39, .20);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.bba-sa-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(201, 162, 39, .28);
    background: linear-gradient(180deg, #F0D88A, var(--gold-2));
}

/* Section bottom CTA */
.bba-sa-cta {
    text-align: center;
    margin-top: 36px;
}

@media (max-width:900px) {
    .bba-sa-head {
        text-align: center;
        margin: 0 auto 46px;
    }

    .bba-underline {
        margin-left: auto;
        margin-right: auto;
    }

    .bba-sa-list::before {
        display: none;
    }

    .bba-sa-item::before {
        left: 14px;
    }

    .bba-sa-row {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .bba-sa-meta {
        justify-content: space-between;
    }

    .bba-sa-cta {
        margin-top: 28px;
    }
}


/* ===================== work.css ===================== */
/* ===== SECTION ===== */
html[data-theme="dark"] #home-work {
    background:
        radial-gradient(1200px 380px at 15% 10%, rgb(196 149 8 / 24%), transparent 60%),
        radial-gradient(900px 320px at 85% 35%, rgb(183 150 46 / 36%), #1c1c1c1c 55%), var(--exp-bg);
}

.work-wrap {
    max-width: 1200px;
    margin: 0 auto
}

.work-head {
    text-align: center;
    margin-bottom: 24px
}

.work-head .sub {
    color: #6F6A66
}

/* ===== GRID ===== */
.work-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin-top: 28px;
    background: #D6C9B9;
}

.work-item {
    position: relative;
    display: block;
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, .28);
    margin: -.5px;
    cursor: pointer;
}

@media (max-width:1100px) {
    .work-grid {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media (max-width:900px) {
    .work-grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

/* ====== ТОНКАЯ НАСТРОЙКА ВСТРОЕННОГО ELEMENTOR LIGHTBOX ====== */

/* 1) Один, стабильный фон ≈ 80% */
.dialog-type-lightbox .dialog-widget-content {
    background: rgba(0, 0, 0, .8) !important;
}

/* 2) По центру и “по рамке” (contain), в т.ч. на мобильном */
.elementor-lightbox .swiper-slide img {
    max-width: calc(100vw - 40px);
    max-height: calc(100vh - 120px);
    width: auto;
    height: auto;
    object-fit: contain;
    margin: 0 auto;
    /* центрируем */
    display: block;
}

/* 3) Скрыть лишние кнопки (оставить только fullscreen и закрыть) */
/* zoom +/- */
.elementor-slideshow__header i.eicon-zoom-in-bold,
.elementor-slideshow__header i.eicon-zoom-out-bold {
    display: none !important;
}

/* share (если он есть) */
.elementor-slideshow__header i.eicon-share-arrow {
    display: none !important;
}

/* иконка “лупа” фикс (если тема её добавляет отдельно) */
.elementor-slideshow__header i.eicon-search {
    display: none !important;
}

/* Цвет кнопок под бренд — по желанию */
.elementor-slideshow__header i {
    color: #fff;
    opacity: .95;
    transition: opacity .2s ease, color .2s ease, background-color .2s ease;
}

.elementor-slideshow__header i:hover {
    color: #fff;
    opacity: 1;
}

/* 4) Немного причесываем кнопки */
.elementor-slideshow__header {
    gap: 8px;
    background: transparent;
    /* убираем доп. подложку полоски сверху */
}

.elementor-slideshow__header i {
    font-size: 20px;
    background: rgba(0, 0, 0, .35);
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.elementor-slideshow__header i:hover {
    background: rgba(0, 0, 0, .5);
}

/* Счётчик оставим как есть, но можно усилить читаемость */
.elementor-slideshow__counter {
    font-weight: 600;
    letter-spacing: .2px;
    background: rgba(0, 0, 0, .45);
    padding: 6px 10px;
    border-radius: 999px;
}



/* === Elementor Lightbox · PATCH (smaller arrows + fix clicks) === */

/* Size & shape of nav arrows */
.elementor-lightbox .elementor-swiper-button,
.dialog-type-lightbox .dialog-lightbox-next,
.dialog-type-lightbox .dialog-lightbox-prev {
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, .32) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .22) !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    pointer-events: auto !important;
    /* ensure clicks */
    z-index: 100000010 !important;
}

/* Position */
.elementor-lightbox .elementor-swiper-button-prev,
.dialog-type-lightbox .dialog-lightbox-prev {
    left: 14px !important;
}

.elementor-lightbox .elementor-swiper-button-next,
.dialog-type-lightbox .dialog-lightbox-next {
    right: 14px !important;
}

/* Icon inside arrows */
.elementor-lightbox .elementor-swiper-button i,
.elementor-lightbox .elementor-swiper-button svg,
.elementor-lightbox .elementor-swiper-button path {
    display: block !important;
    color: #fff !important;
    stroke: #fff !important;
    fill: none !important;
    stroke-width: 2 !important;
    opacity: .95 !important;
}

.elementor-lightbox .elementor-swiper-button:hover i,
.elementor-lightbox .elementor-swiper-button:hover svg,
.elementor-lightbox .elementor-swiper-button:hover path {
    opacity: 1 !important;
}

/* Tighten on very small screens */
@media (max-width: 480px) {

    .elementor-lightbox .elementor-swiper-button-prev,
    .dialog-type-lightbox .dialog-lightbox-prev {
        left: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button-next,
    .dialog-type-lightbox .dialog-lightbox-next {
        right: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button,
    .dialog-type-lightbox .dialog-lightbox-next,
    .dialog-type-lightbox .dialog-lightbox-prev {
        width: 30px !important;
        height: 30px !important;
    }
}

/* Header buttons (close, fullscreen) — make sure they work & look neat */
.elementor-lightbox .elementor-slideshow__header {
    background: transparent !important;
    gap: 8px !important;
    z-index: 100000020 !important;
}

.elementor-lightbox .elementor-slideshow__header button,
.elementor-lightbox .elementor-slideshow__header i {
    pointer-events: auto !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0, 0, 0, .35) !important;
    color: #fff !important;
}

.elementor-lightbox .elementor-slideshow__header button:hover,
.elementor-lightbox .elementor-slideshow__header i:hover {
    background: rgba(0, 0, 0, .5) !important;
}

/* Make sure the slide itself doesn't sit above controls */
.elementor-lightbox .elementor-lightbox-item,
.elementor-lightbox .swiper {
    z-index: 100000000 !important;
}


/* ===== Elementor Lightbox · HARD FIX (show arrows, own chevrons, clickable) ===== */

/* 1) Всегда показывать и включить клики на всех вариантах кнопок */
.elementor-lightbox .elementor-swiper-button,
.elementor-lightbox .elementor-slideshow__next,
.elementor-lightbox .elementor-slideshow__prev,
.dialog-type-lightbox .dialog-lightbox-next,
.dialog-type-lightbox .dialog-lightbox-prev {
    position: fixed !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, .32) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .22) !important;

    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    z-index: 100000020 !important;
    /* выше слайда и оверлеев */
}

/* 2) Позиции */
.elementor-lightbox .elementor-swiper-button-prev,
.elementor-lightbox .elementor-slideshow__prev,
.dialog-type-lightbox .dialog-lightbox-prev {
    left: 16px !important;
}

.elementor-lightbox .elementor-swiper-button-next,
.elementor-lightbox .elementor-slideshow__next,
.dialog-type-lightbox .dialog-lightbox-next {
    right: 16px !important;
}

/* 3) Рисуем стрелку сами, не зависим от иконок темы */
.elementor-lightbox .elementor-swiper-button::after,
.elementor-lightbox .elementor-slideshow__next::after,
.elementor-lightbox .elementor-slideshow__prev::after,
.dialog-type-lightbox .dialog-lightbox-next::after,
.dialog-type-lightbox .dialog-lightbox-prev::after {
    content: "";
    width: 14px;
    height: 14px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    display: block;
}

.elementor-lightbox .elementor-swiper-button-next::after,
.elementor-lightbox .elementor-slideshow__next::after,
.dialog-type-lightbox .dialog-lightbox-next::after {
    transform: rotate(45deg);
}

.elementor-lightbox .elementor-swiper-button-prev::after,
.elementor-lightbox .elementor-slideshow__prev::after,
.dialog-type-lightbox .dialog-lightbox-prev::after {
    transform: rotate(-135deg);
}

/* 4) На узких экранах чуть меньше и ближе к краям */
@media (max-width: 480px) {

    .elementor-lightbox .elementor-swiper-button,
    .elementor-lightbox .elementor-slideshow__next,
    .elementor-lightbox .elementor-slideshow__prev,
    .dialog-type-lightbox .dialog-lightbox-next,
    .dialog-type-lightbox .dialog-lightbox-prev {
        width: 30px !important;
        height: 30px !important;
    }

    .elementor-lightbox .elementor-swiper-button-prev,
    .elementor-lightbox .elementor-slideshow__prev,
    .dialog-type-lightbox .dialog-lightbox-prev {
        left: 10px !important;
    }

    .elementor-lightbox .elementor-swiper-button-next,
    .elementor-lightbox .elementor-slideshow__next,
    .dialog-type-lightbox .dialog-lightbox-next {
        right: 10px !important;
    }
}

/* 5) На всякий случай прячем конфликтные внутренние иконки,
          чтобы они не перекрывали наш ::after и не ломали клики */
.elementor-lightbox .elementor-swiper-button i,
.elementor-lightbox .elementor-swiper-button svg {
    display: none !important;
}

/* 6) Слайд и контейнер не перекрывают стрелки */
.elementor-lightbox .swiper,
.elementor-lightbox .elementor-lightbox-item {
    z-index: 100000000 !important;
    overflow: visible !important;
}



/* === Lightbox UX: lock page scroll, cursor zones, working close === */

/* Cursor: default outside, pointer only on image */
.elementor-lightbox {
    cursor: default !important;
}

.elementor-lightbox .swiper-slide {
    cursor: default !important;
}

.elementor-lightbox .swiper-slide img {
    cursor: pointer !important;
}

/* Close button (always on top & clickable) */
.elementor-lightbox .elementor-slideshow__close,
.elementor-lightbox [data-elementor-action="close"] {
    position: fixed !important;
    top: 16px !important;
    right: 16px !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0, 0, 0, .42) !important;
    z-index: 100000030 !important;
    /* выше стрелок и слайда */
    pointer-events: auto !important;
}

.elementor-lightbox .elementor-slideshow__close:hover,
.elementor-lightbox [data-elementor-action="close"]:hover {
    background: rgba(0, 0, 0, .55) !important;
}

.elementor-lightbox .elementor-slideshow__close i,
.elementor-lightbox .elementor-slideshow__close svg,
.elementor-lightbox [data-elementor-action="close"] i,
.elementor-lightbox [data-elementor-action="close"] svg {
    color: #fff !important;
    stroke: #fff !important;
    fill: none !important;
    stroke-width: 2 !important;
}

/* Class to actually lock scrolling (JS добавит её на <html> и <body>) */
.no-scroll {
    overflow: hidden !important;
}


.elementor-lightbox .dialog-lightbox-close-button {
    z-index: 999999999 !important;
}


/* ===================== clients.css ===================== */
/* layout */
#why-me .head {
    text-align: center;
    margin-bottom: 10px;
}

#why-me .grid {
    display: grid;
    gap: var(--baa-gap);
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 24px;
}

/* cards */
html[data-theme="dark"] #why-me .card {
    background: #00000075;
    border: 1px solid rgb(90 89 89 / 82%);
    border-radius: var(--baa-radius);
    padding: 22px;
    text-align: center;
    box-shadow: var(--baa-shadow-hover);
    transition: transform var(--baa-speed), box-shadow var(--baa-speed);
    margin: 7px;
}

#why-me .card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 36px rgba(0, 0, 0, .14);
}

/* icons */
#why-me .icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 12px;
    display: grid;
    place-items: center;
}

#why-me .icon svg {
    width: 64px;
    height: 64px;
    display: block;
    stroke: var(--baa-gold);
    fill: none;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, .06));
    transition: stroke var(--baa-speed), transform var(--baa-speed), filter var(--baa-speed);
}

#why-me .card:hover .icon svg {
    transform: translateY(-1px);
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, .1));
}

/* text */
html[data-theme="dark"] #why-me .title {
    color: #d2bd88;
}

#why-me .desc {
    color: var(--baa-muted);
    line-height: 1.6;
}

/* responsive */
@media (max-width: 1000px) {
    #why-me .grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    #why-me .grid {
        grid-template-columns: 1fr;
    }
}


/* ===================== testimonials.css ===================== */
/* ================= SCOPE ================= */
#reviews * {
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent
}

/* ================= HEAD ================= */
#reviews .rv-head {
    text-align: center;
    margin: 0 0 28px
}

#reviews .rv-eyebrow {
    font-size: clamp(18px, 2.2vw, 22px);
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #7a6f5a;
    margin-bottom: 10px
}


/* ================= VIEWPORT & TRACK ================= */
#reviews .rv-wrap {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 16px
}

#reviews .rv-viewport {
    position: relative;
    overflow: hidden
}

#reviews .rv-track {
    display: flex;
    gap: 0;
    /* ключ: никаких зазоров между страницами */
    transition: transform .55s ease;
    will-change: transform
}

#reviews .rv-slide {
    flex: 0 0 100%;
    /* жёсткая «страница» шириной в 100% */
    max-width: 100%;
}

/* ================= CARD ================= */
#reviews .rv-card {
    background: #fff;
    border-radius: 22px;
    width: min(860px, 92%);
    margin: 0 auto;
    padding: 30px 32px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04)
}

#reviews .rv-quote {
    font-size: 34px;
    line-height: 1;
    color: #B89A2A;
    margin-bottom: 8px
}

#reviews .rv-stars {
    color: #C9A227;
    letter-spacing: .2em;
    margin-bottom: 10px
}

#reviews .rv-text {
    font-size: clamp(16px, 1.8vw, 20px);
    line-height: 1.65;
    margin: 0 0 14px;
    color: #2b2b2b
}

#reviews .rv-name {
    font-weight: 700;
    margin-bottom: 6px
}

#reviews .rv-meta {
    opacity: .75
}

/* ================= ARROWS ================= */
html[data-theme="dark"] #reviews .rv-arrow {
    background: linear-gradient(180deg, #646464, #484848);
    border: 2px solid rgb(231 231 229 / 44%);
    box-shadow: 0 8px 24px rgb(217 217 217 / 41%);
}

html[data-theme="dark"] #reviews .rv-arrow svg {
    stroke: #e5d29e;
}

#reviews .rv-prev {
    left: 20px
}

#reviews .rv-next {
    right: 20px
}

#reviews .rv-arrow,
#reviews .rv-arrow::after {
    animation: none !important
}

/* ================= DOTS ================= */
#reviews .rv-dots {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-top: 16px;
    position: relative
}

#reviews .rv-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #d8d3c6;
    border: 0;
    cursor: pointer;
    position: relative
}

#reviews .rv-dot.is-active {
    background: #C9A227
}

#reviews .rv-dot.is-active::after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(201, 162, 39, .35)
}

/* ================= MOBILE ================= */
@media (max-width:768px) {
    #reviews .rv-viewport {
        padding-bottom: 65px !important
    }

    #reviews .rv-arrow {
        top: auto !important;
        bottom: 24px !important;
        transform: none !important;
        width: 46px;
        height: 46px;
        background: linear-gradient(180deg, #fff, #F5EDDA)
    }

    #reviews .rv-prev {
        left: 16px !important
    }

    #reviews .rv-next {
        right: 16px !important
    }

    #reviews .rv-dots {
        position: absolute !important;
        left: 50% !important;
        bottom: 24px !important;
        transform: translateX(-50%) !important;
        margin-top: 0 !important
    }

    #reviews .rv-card {
        width: 90%;
        padding: 22px 18px
    }
}


/* ===================== faq.css ===================== */
/* ===== Section ===== */
#home-faq .faq-wrap {
    max-width: 1200px;
    margin: 0 auto;
}



/* ===== Independent columns (no cross-column stretching) ===== */
#home-faq .faq-list {
    column-count: 2;
    /* независимые колонки */
    column-gap: 16px;
}

.faq-item {
    display: inline-block;
    /* для columns */
    width: 100%;
    break-inside: avoid;
    /* не рвать карточки */
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, .08);
    background: #fff;
    box-shadow: 0 10px 28px rgba(0, 0, 0, .06);
    margin: 0 0 16px;
    /* вертикальный зазор в колонке */
    transition: box-shadow .25s ease, transform .25s ease;
}

.faq-item[open] {
    box-shadow: 0 14px 40px rgba(0, 0, 0, .10);
    transform: translateY(-1px);
}

/* Summary */
.faq-q {
    list-style: none;
    cursor: pointer;
    padding: 20px 56px 20px 22px;
    position: relative;
    font-weight: 700;
    color: #1A1A1A;
    user-select: none;
    outline: none;
}

.faq-q:focus-visible {
    box-shadow: 0 0 0 3px rgba(207, 163, 58, .35) inset;
}

.faq-q .faq-q-text {
    pointer-events: none;
}

/* Chevron */
.faq-q::after {
    content: "";
    position: absolute;
    right: 18px;
    top: 50%;
    width: 12px;
    height: 12px;
    border-right: 2px solid #1A1A1A;
    border-bottom: 2px solid #1A1A1A;
    transform: translateY(-50%) rotate(-45deg);
    transition: transform .25s ease, border-color .25s ease, opacity .25s ease;
    opacity: .75;
}

.faq-item[open] .faq-q::after {
    transform: translateY(-50%) rotate(45deg);
    border-color: #CFA33A;
    opacity: 1;
}

/* Answer wrapper for smooth animation */
.faq-a {
    overflow: hidden;
    /* для анимации высоты */
    height: 0;
    /* изначально скрыто */
    transition: height .32s ease, opacity .32s ease;
    opacity: 0;
    background: #F8FBFF;
    border-top: 1px solid rgba(207, 163, 58, .18);
}

.faq-item[open] .faq-a {
    opacity: 1;
}

/* высотой управляет JS */
.faq-inner {
    padding: 18px 24px 24px;
    color: #4B4B4B;
    line-height: 1.7;
}

/* CTA */
#home-faq .faq-cta {
    text-align: center;
    margin-top: 26px;
}

/* Responsive */
@media (max-width: 900px) {
    #home-faq {
        padding: 70px 16px 80px;
    }

    #home-faq .faq-list {
        column-count: 1;
    }

    .faq-q {
        padding: 18px 50px 18px 18px;
    }
}

@media (prefers-reduced-motion: reduce) {

    .faq-item,
    .faq-q::after,
    .faq-a {
        transition: none !important;
    }
}


[data-icons-type*=solid] .ct-icon-container {
    background-color: #a39e8c !important;
}


/* ===================== appointment.css ===================== */
/* =========================================================
   Appointment CTA (Book Time to Get Manicure) — FINAL
   Картинка заполняет коробку как cover, без "криво"
   ========================================================= */


/* Glass content card */
html[data-theme="dark"] #cta-appointment .cta-appt__content {
    background: rgb(0 0 0 / 52%);
    border: 1px solid rgb(139 139 139 / 55%);
}

html[data-theme="dark"] #cta-appointment .cta-appt__text {
    color: #eeeeee;
}

html[data-theme="dark"] #cta-appointment .cta-appt__media>img {
    opacity: 0.65;
}

#cta-appointment .cta-appt__eyebrow {
    margin: 0 0 6px;
    color: #C9A227;
    font-family: "Playfair Display", serif;
    font-style: italic;
    letter-spacing: .5px;
    opacity: .95;
}

/* Laptop: чуть компактнее заголовок */
@media (max-width: 1200px) {
    #cta-appointment .h-title-xl {
        font-size: clamp(30px, 4.4vw, 40px);
        line-height: 1.15;
    }
}

/* Mobile */
@media (max-width: 980px) {
    #cta-appointment.cta-bg {
        padding: 56px 14px;
    }

    #cta-appointment .cta-appt {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    #cta-appointment .cta-appt__content {
        order: 0;
        margin: 0 6px;
        padding: clamp(16px, 3.4vw, 22px);
    }

    #cta-appointment .cta-appt__media {
        max-width: 92%;
        margin: 0 auto;
        aspect-ratio: 3 / 3;
        /* сохраняем пропорции на мобиле */
    }
}

/* Very small screens */
@media (max-width: 420px) {
    #cta-appointment .cta-appt__media {
        max-width: 96%;
    }
}





/* =========================================================
   Luxury Parallax CTA · Anahit Nail Studio
   supports:
   html[data-theme="light"] / html[data-theme="dark"]
========================================================= */

.lux-parallax {
    position: relative;
    overflow: hidden;
    padding: clamp(70px, 6vw, 120px) 18px;
    border-radius: 20px;
}

.lux-parallax__wrap {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    place-items: center;
}



/* overlays for readability */
.lux-parallax::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

/* Card */
.lux-parallax__card {
    position: relative;
    z-index: 2;
    width: min(920px, 100%);
    border-radius: 22px;
    padding: clamp(22px, 3.2vw, 44px);

    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    box-shadow: 0 24px 70px rgba(0, 0, 0, .18);
    border: 1px solid rgba(255, 255, 255, .18);

    text-align: center;
}

.lux-parallax__kicker {
    margin: 0 0 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    font-size: 12px;
    opacity: .9;
}

.lux-parallax__title {
    margin: 0 0 12px;
    font-size: clamp(34px, 4.2vw, 56px);
    line-height: 1.05;
}

.lux-parallax__text {
    margin: 0 auto 22px;
    max-width: 62ch;
    font-size: 16px;
    line-height: 1.7;
    opacity: .92;
}

.lux-parallax__actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.lux-parallax__chips {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 8px;
}

.lux-parallax__chip {
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 13px;
    line-height: 1;
    border: 1px solid rgba(255, 255, 255, .18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* ---------- LIGHT THEME ---------- */
html[data-theme="light"] .lux-parallax::before {
    background:
        radial-gradient(700px 300px at 20% 15%, rgba(212, 178, 76, .22), transparent 60%),
        radial-gradient(600px 320px at 80% 75%, rgba(201, 162, 39, .14), transparent 60%),
        linear-gradient(to bottom, rgba(255, 255, 255, .55), rgba(255, 255, 255, .22));
    border-radius: 20px;
}

html[data-theme="light"] .lux-parallax__card {
    background: rgba(255, 255, 255, .72);
    color: #1a1a1a;
    border-color: rgba(30, 30, 30, .10);
}

html[data-theme="light"] .lux-parallax__chip {
    background: rgba(255, 255, 255, .55);
    color: #1a1a1a;
    border-color: rgba(30, 30, 30, .10);
}

/* ---------- DARK THEME ---------- */
html[data-theme="dark"] .lux-parallax::before {
    background:
        radial-gradient(800px 340px at 18% 20%, rgba(212, 178, 76, .22), transparent 60%),
        radial-gradient(700px 360px at 85% 75%, rgba(201, 162, 39, .14), transparent 60%),
        linear-gradient(to bottom, rgba(0, 0, 0, .62), rgba(0, 0, 0, .34));
}

html[data-theme="dark"] .lux-parallax__card {
    background: rgba(18, 18, 18, .62);
    color: #f1f1f1;
    border-color: rgba(255, 255, 255, .14);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .45);
}

html[data-theme="dark"] .lux-parallax__chip {
    background: rgba(0, 0, 0, .20);
    color: #f1f1f1;
    border-color: rgba(255, 255, 255, .14);
}

.lux-parallax__chips.sr-item {
    transform: translateY(20px);
}

/* ---------- Mobile (disable fixed for iOS performance) ---------- */
@media (max-width: 1024px) {
    .lux-parallax__bg {
        background-attachment: scroll;
    }
}

@media (max-width: 640px) {

    .lux-parallax {
        padding: clamp(55px, 6vw, 120px) 4px;
    }

    .lux-parallax__card {
        border-radius: 18px;
        text-align: left;
    }

    .lux-parallax__actions {
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
    }

    .baa-btn.sr-item.is-in {
        width: 100%;
    }

    .lux-parallax__actions {
        display: flex;
        justify-content: center;
        gap: 20px;
    }

    .nba-exp__actions {
        gap: 20px;
        width: 100%;
        justify-content: center;
    }

    .lux-parallax__chips {
        gap: 7px;
        flex-wrap: nowrap;
        margin-top: 8px;
    }

    .nba-exp__chips {
        flex-wrap: wrap;
        justify-content: center;
    }

    .nba-exp__btn {
        padding: 0 10px;
    }


    .lux-parallax__chip {
        padding: 10px 11px;
        font-size: 12px;
    }
}







/* =========================================
   Scroll Reveal (stagger) — Anahit Nail Studio
========================================= */
/* .sr-item {
    opacity: 0;
    transform: translate3d(0, 200px, 0);
    filter: blur(4px);
    transition:
        opacity 1.35s ease,
        transform 1.35s cubic-bezier(.18, .85, .25, 1),
        filter 1.35s ease;
    transition-delay: var(--sr-delay, 0ms);
    will-change: opacity, transform, filter;
} */


.sr-item {
    opacity: 0;
    transform: translateY(200px);
    transition:
        opacity 0.9s ease,
        transform 1.1s cubic-bezier(.22, .61, .36, 1);
    transition-delay: var(--sr-delay, 0ms);
}


.sr-item.is-in {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
}

/* Optional: a tiny scale for images/cards */
.sr-pop {
    transform: translate3d(0, 200px, 0) scale(1.35);
}

.sr-pop.is-in {
    transform: translate3d(0, 0, 0) scale(1);
}



/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .sr-item {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}





/* =========================================================
   ABOUT PAGE · Anahit Nail Studio
   Light/Dark via html[data-theme]
   Uses existing: .baa-title, .baa-text, .baa-btn, sr-item reveal
========================================================= */

.ans-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 18px;
}

/* ---------- HERO ---------- */
.ans-about-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(80px, 7vw, 140px) 18px;
}

.ans-about-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url("/wp-content/uploads/2026/02/about-hero.jpg");
    /* <-- replace */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    transform: scale(1.02);
}

.ans-about-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.ans-about-hero__wrap {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    place-items: center;
}

.ans-about-hero__card {
    width: min(980px, 100%);
    border-radius: 24px;
    padding: clamp(22px, 3.4vw, 46px);
    text-align: center;

    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    border: 1px solid rgba(255, 255, 255, .18);
    box-shadow: 0 28px 90px rgba(0, 0, 0, .20);
}



.ans-contact-hero__kicker,
.ans-about-hero__kicker {
    margin: 0 0 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    font-size: 16px;
    opacity: .9;
}

.ans-about-hero__title {
    margin: 0 0 12px;
    font-size: clamp(40px, 5.2vw, 68px);
    line-height: 1.02;
}

.ans-about-hero__sub {
    margin: 0 auto 22px;
    max-width: 62ch;
    line-height: 1.7;
    opacity: .92;
}

.ans-about-hero__actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.ans-about-hero__chips {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}

.ans-chip {
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 13px;
    border: 1px solid rgba(255, 255, 255, .18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* ---------- STORY ---------- */
.ans-about-story {
    padding: clamp(54px, 6vw, 92px) 0;
}

.ans-grid-2 {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(18px, 3vw, 44px);
    align-items: center;
}

.ans-media {
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .12);
    border: 1px solid rgba(255, 255, 255, .12);
}

.ans-media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transform: scale(1.01);
}

.ans-eyebrow {
    margin: 0 0 10px;
    letter-spacing: .20em;
    text-transform: uppercase;
    font-size: 12px;
    opacity: .85;
}

.ans-h2 {
    margin: 0 0 14px;
    font-size: clamp(30px, 3.2vw, 44px);
    line-height: 1.08;
}

.ans-p {
    margin: 0 0 14px;
    line-height: 1.75;
}

.ans-inline {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 14px;
}

.ans-badge {
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 13px;
    border: 1px solid rgba(255, 255, 255, .16);
}

/* ---------- PILLARS ---------- */
.ans-about-pillars {
    padding: clamp(54px, 6vw, 96px) 0;
}

.ans-head {
    text-align: center;
    max-width: 820px;
    margin: 0 auto 26px;
}

.ans-sub {
    margin: 0 auto;
    max-width: 70ch;
    line-height: 1.7;
    opacity: .92;
}

.ans-cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.ans-card {
    border-radius: 20px;
    padding: 18px 16px;
    border: 1px solid rgba(255, 255, 255, .14);
    box-shadow: 0 18px 60px rgba(0, 0, 0, .10);
}

.ans-ico {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    margin-bottom: 12px;
    border: 1px solid rgba(255, 255, 255, .16);
    opacity: .95;
}

.ans-h3 {
    margin: 0 0 8px;
    font-size: 18px;
}

/* ---------- CTA ---------- */
.ans-about-cta {
    padding: clamp(54px, 6vw, 96px) 0;
}

.ans-cta-box {
    border-radius: 24px;
    padding: clamp(20px, 3vw, 40px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border: 1px solid rgba(255, 255, 255, .14);
    box-shadow: 0 22px 70px rgba(0, 0, 0, .12);
}

.ans-cta-actions {
    display: flex;
    gap: 12px;
    flex-wrap: nowrap;
    justify-content: flex-end;
}

/* ---------- LIGHT THEME ---------- */
html[data-theme="light"] .ans-about-hero::before {
    background:
        radial-gradient(900px 360px at 22% 18%, rgba(212, 178, 76, .20), transparent 60%),
        radial-gradient(800px 380px at 86% 78%, rgba(201, 162, 39, .12), transparent 60%),
        linear-gradient(to bottom, rgba(255, 255, 255, .55), rgba(255, 255, 255, .18));
}

html[data-theme="light"] .ans-about-hero__card {
    background: rgba(255, 255, 255, .55);
    color: #1a1a1a;
    border-color: rgba(30, 30, 30, .10);
}

html[data-theme="light"] .ans-chip,
html[data-theme="light"] .ans-badge {
    background: rgba(255, 255, 255, .58);
    color: #1a1a1a;
    border-color: rgba(30, 30, 30, .10);
}

html[data-theme="light"] .ans-card,
html[data-theme="light"] .ans-cta-box {
    background: rgba(255, 255, 255, .70);
    color: #1a1a1a;
    border-color: rgba(30, 30, 30, .10);
}

/* ---------- DARK THEME ---------- */
html[data-theme="dark"] .ans-about-hero::before {
    background:
        radial-gradient(900px 360px at 18% 18%, rgba(212, 178, 76, .22), transparent 60%),
        radial-gradient(900px 420px at 86% 80%, rgba(201, 162, 39, .12), transparent 60%),
        linear-gradient(to bottom, rgba(0, 0, 0, .66), rgba(0, 0, 0, .30));
}

html[data-theme="dark"] .ans-about-hero__card {
    background: rgba(14, 14, 14, .62);
    color: #f2f2f2;
    border-color: rgba(255, 255, 255, .14);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .45);
}

html[data-theme="dark"] .ans-chip,
html[data-theme="dark"] .ans-badge {
    background: rgba(0, 0, 0, .22);
    color: #f2f2f2;
    border-color: rgba(255, 255, 255, .14);
}

html[data-theme="dark"] .ans-eyebrow.sr-item.is-in {
    color: #fff;
}

html[data-theme="dark"] .ans-card,
html[data-theme="dark"] .ans-cta-box {
    background: #444444cc;
    color: #f2f2f2;
    border-color: rgba(255, 255, 255, .14);
    box-shadow: 0 26px 80px rgba(0, 0, 0, .35);
}

html[data-theme="dark"] .ans-ico {
    background: rgba(201, 162, 39, .10);
}

.ans-about-hero__chips.sr-item {
    transform: translateY(10px) !important;
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
    .ans-about-hero__bg {
        background-attachment: scroll;
    }

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

@media (max-width: 820px) {
    .ans-grid-2 {
        grid-template-columns: 1fr;
    }

    .ans-head {
        text-align: left;
    }

    .ans-cta-box {
        flex-direction: column;
        align-items: flex-start;
    }

    .ans-cta-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 520px) {
    .ans-cards {
        grid-template-columns: 1fr;
    }

    .ans-about-hero__card {
        text-align: left;
    }

    .ans-about-hero__chips {
        justify-content: flex-start;
    }
}




/* =========================================================
   SR LEFT → RIGHT (Fix for mobile + override)
========================================================= */

/* Start state */
.sr-item.sr-left {
    opacity: 0 !important;
    transform: translate3d(-120px, 0, 0) !important;
}

/* Visible state */
.sr-item.sr-left.is-in {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
}

/* Optional: smoother for H1 */
.ans-about-hero__title.sr-item.sr-left {
    transition:
        opacity .9s ease,
        transform 1.1s cubic-bezier(.22, 1, .36, 1) !important;
}






/* =========================================================
   CONTACT PAGE (uses existing brand variables from your CSS)
========================================================= */

/* Layout helper (your project already uses --wrap, keep consistent) */

.ans-container,
.ans-services,
.ans-gallery {
    max-width: var(--wrap);
    margin: 0 auto;
}

/* ===== Contact Hero ===== */
.ans-contact-hero,
.ans-services-hero,
.ans-gallery-hero {
    position: relative;
    padding: clamp(70px, 7vw, 110px) 0;
    overflow: hidden;
    background: transparent;
}

.ans-contact-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url(/wp-content/uploads/2026/02/contact-hero.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    transform: scale(1.02);
}

.ans-gallery-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url(/wp-content/uploads/2026/02/gallery-hero.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    transform: scale(1.02);
}

.ans-contact-hero__bg::after,
.ans-services-hero__bg::after,
.ans-gallery-hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(120% 120% at 20% 0%, rgba(201, 162, 39, .22) 0%, rgba(0, 0, 0, 0) 55%),
        linear-gradient(180deg, rgba(0, 0, 0, .35) 0%, rgba(0, 0, 0, .55) 60%, rgba(0, 0, 0, .75) 100%);
    pointer-events: none;
}

.ans-contact-hero .ans-contact-hero__actions {
    display: flex;
    justify-content: center;
    align-items: center;
}

html[data-theme="light"] .ans-contact-hero__bg::after,
html[data-theme="light"] .ans-services-hero__bg::after,
html[data-theme="light"] .ans-gallery-hero__bg::after {
    background:
        radial-gradient(120% 120% at 20% 0%, rgba(201, 162, 39, .18) 0%, rgba(0, 0, 0, 0) 55%),
        linear-gradient(180deg, rgba(251, 247, 240, .15) 0%, rgba(251, 247, 240, .32) 55%, rgba(251, 247, 240, .58) 100%);
}



.ans-services-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url("/wp-content/uploads/2026/02/services-hero.jpg");
    /* <-- replace */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    transform: scale(1.02);
}

.ans-services-hero::before,
.ans-gallery-hero::before,
.ans-contact-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.ans-services-hero__wrap,
.ans-gallery-hero__wrap,
.ans-contact-hero__wrap {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    place-items: center;
}

.ans-contact-hero__card {
    width: min(760px, 100%);
    margin: 0 auto;
    padding: clamp(22px, 3vw, 34px);
    border-radius: var(--baa-radius);
    border: 1px solid var(--baa-line);
    background: var(--veil);
    backdrop-filter: blur(10px);
    box-shadow: var(--baa-shadow);
}


/* ===== Contact Details ===== */
.ans-contact {
    padding: clamp(50px, 6vw, 75px) 0;
    background: transparent;
}

.ans-contact__head {
    text-align: center;
    margin-bottom: 26px;
}

.ans-contact__grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 16px;
}

.ans-contact__card {
    grid-column: span 6;
    padding: 20px 18px;
    border-radius: var(--baa-radius);
    border: 1px solid var(--baa-line);
    background: var(--baa-surface);
    box-shadow: var(--baa-shadow);
    transition: transform var(--baa-speed) ease, box-shadow var(--baa-speed) ease, border-color var(--baa-speed) ease;
}

html[data-theme="dark"] .ans-contact__card {
    background: #444444cc;
}

.ans-contact__card:hover {
    transform: translateY(-4px);
    box-shadow: var(--baa-shadow-hover);
    border-color: var(--baa-rim);
}

.ans-contact__icon {
    width: 50px;
    height: 50px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    margin-bottom: 15px;
    border: 1px solid var(--baa-rim);
    background: linear-gradient(135deg, rgba(231, 207, 138, .28), rgba(201, 162, 39, .12));
    color: var(--gold-2);
    font-size: 18px;
    padding: 5px;
}

.ans-contact__h3 {
    margin: 0 0 6px;
    font-size: 18px;
    color: var(--baa-ink);
}

.ans-contact__p {
    margin: 0;
    color: var(--baa-muted);
    line-height: 1.7;
}

.ans-contact__link {
    color: var(--baa-ink);
    text-decoration: none;
    border-bottom: 1px dashed rgba(201, 162, 39, .55);
    transition: opacity var(--baa-speed) ease, border-color var(--baa-speed) ease;
}

.ans-contact__link:hover {
    opacity: .9;
    border-color: rgba(201, 162, 39, .95);
}





/* ===== Map ===== */
.ans-map {
    padding: clamp(50px, 6vw, 75px) 0;
    background: transparent;
}

.ans-map__head {
    text-align: center;
    margin-bottom: 18px;
}

.ans-map__frame {
    border-radius: var(--baa-radius);
    overflow: hidden;
    border: 1px solid var(--baa-line);
    background: var(--baa-surface);
    box-shadow: var(--baa-shadow);
    position: relative;
}

.ans-map__frame iframe {
    display: block;
    width: 100%;
    height: min(520px, 62vh);
    border: 0;
}

/* Yelp icon styling */
.ans-contact__icon--yelp svg {
    width: 22px;
    height: 22px;
    display: block;
    fill: #fff;
    /* will be overridden in light theme below */
}

html[data-theme="light"] .ans-contact__icon--yelp svg {
    fill: #111;
}

/* Make Yelp icon circle a bit more "brand" */
.ans-contact__icon--yelp {
    background: linear-gradient(135deg, rgba(231, 207, 138, .24), rgba(201, 162, 39, .10));
}


/* Optional: make embedded map feel nicer in dark theme */
html[data-theme="dark"] .ans-map__frame iframe {
    filter: grayscale(.15) contrast(1.05) brightness(.92);
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
    .ans-contact__card {
        grid-column: span 12;
    }
}

@media (max-width: 520px) {
    .ans-contact-hero__card {
        padding: 18px;
    }

    .ans-contact-hero__actions {
        gap: 10px;
    }

    .ans-chip {
        padding: 8px 11px;
        font-size: 12px;
    }

    #services-alt .svc-lead {
        line-height: 1.35;
        font-size: 14px;
    }

    #services-alt .svc-points {
        margin: 0 0 14px 7px;
    }

    ul.svc-points {
        padding-left: 20px;
    }

    #services-alt .svc-points li {
        margin-bottom: 5px;
        font-size: 14px;
    }

    h2.svc-title {
        font-size: 26px;
    }
}



/* =========================================================
   LEGAL PAGES (Privacy Policy / Terms)
   - Uses existing brand variables: --baa-*, --gold-*, --veil, --wrap
   - Dark/Light via html[data-theme]
========================================================= */

.ans-legal {
    position: relative;
    padding: clamp(70px, 7vw, 110px) 0;
    background: transparent;
}

.ans-legal__wrap {
    max-width: 920px;
    /* читаемо и дорого */
    margin: 0 auto;
}

/* Head */
.ans-legal__head {
    text-align: center;
    margin-bottom: 22px;
}

.ans-legal__title {
    margin: 0 0 10px;
    line-height: 1.05;
    font-size: clamp(34px, 4.2vw, 56px);
    color: var(--baa-ink);
}

.ans-legal__meta {
    margin: 0 0 10px;
    color: var(--baa-muted);
    font-size: 14px;
}

.ans-legal__intro {
    margin: 0 auto;
    max-width: 70ch;
    color: var(--baa-muted);
    font-size: 16px;
    line-height: 1.8;
}

/* Block */
.ans-legal__block {
    border-radius: var(--baa-radius);
    border: 1px solid var(--baa-line);
    background: var(--baa-surface);
    box-shadow: var(--baa-shadow);
    padding: clamp(18px, 2.4vw, 26px);
}

/* Dark surface feel a bit more "glass" */
html[data-theme="dark"] .ans-legal__block {
    background: rgba(255, 255, 255, .04);
    border-color: rgba(255, 255, 255, .12);
    box-shadow: var(--baa-shadow);
}

/* Light surface stays clean */
html[data-theme="light"] .ans-legal__block {
    background: rgba(255, 255, 255, .75);
}

/* H2 */
.ans-legal__h2 {
    margin: 0 0 10px;
    font-size: 20px;
    line-height: 1.25;
    color: var(--baa-ink);
    position: relative;
    padding-left: 14px;
}

/* small gold accent line */
.ans-legal__h2::before {
    content: "";
    position: absolute;
    left: 0;
    top: .22em;
    width: 6px;
    height: 1.05em;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--gold-1), var(--gold-2));
    opacity: .95;
}

/* Paragraphs */
.ans-legal__p {
    margin: 0 0 12px;
    color: var(--baa-muted);
    line-height: 1.85;
    font-size: 15.5px;
}

.ans-legal__p:last-child {
    margin-bottom: 0;
}

/* Lists */
.ans-legal__list {
    margin: 0 0 12px;
    padding-left: 0;
    list-style: none;
    display: grid;
    gap: 10px;
    color: var(--baa-muted);
    font-size: 15.5px;
    line-height: 1.75;
}

.ans-legal__list li {
    position: relative;
    padding-left: 28px;
}

/* diamond bullet */
.ans-legal__list li::before {
    content: "✦";
    position: absolute;
    left: 0;
    top: 0.05em;
    color: var(--gold-2);
    opacity: .95;
}

/* Links */
.ans-legal__link {
    color: var(--baa-ink);
    text-decoration: none;
    border-bottom: 1px dashed rgba(201, 162, 39, .55);
    transition: border-color var(--baa-speed) ease, opacity var(--baa-speed) ease;
}

.ans-legal__link:hover {
    opacity: .92;
    border-bottom-color: rgba(201, 162, 39, .95);
}

/* Contact box */
.ans-legal__contact {
    margin-top: 10px;
    border-radius: var(--baa-radius);
    border: 1px solid var(--baa-line);
    background: var(--veil);
    padding: 14px 16px;
}

html[data-theme="dark"] .ans-legal__contact {
    background: rgba(255, 255, 255, .04);
    border-color: rgba(255, 255, 255, .12);
}

html[data-theme="light"] .ans-legal__contact {
    background: rgba(255, 255, 255, .65);
}

.ans-legal__contact p {
    margin: 0 0 8px;
    color: var(--baa-muted);
    line-height: 1.7;
}

.ans-legal__contact p:last-child {
    margin-bottom: 0;
}

/* Divider spacing */
.ans-legal .baa-divider-diamond {
    margin: 22px auto;
}

/* Optional: subtle focus frame on hover (premium feel) */
.ans-legal__block {
    transition: transform var(--baa-speed) ease, border-color var(--baa-speed) ease, box-shadow var(--baa-speed) ease;
}

.ans-legal__block:hover {
    transform: translateY(-2px);
    border-color: var(--baa-rim);
    box-shadow: var(--baa-shadow-hover);
}

/* Responsive */
@media (max-width: 640px) {
    .ans-legal__wrap {
        max-width: 100%;
    }

    .ans-legal__h2 {
        font-size: 18px;
    }

    .ans-legal__p,
    .ans-legal__list {
        font-size: 15px;
    }

    .ans-legal__block {
        padding: 16px;
    }
}




/* ========================
     Footer brand – final
     ======================== */

/* knobs */
.footer-brand {
    --logo-desktop: 46px;
    --logo-tablet: 42px;
    --logo-mobile: 36px;

    --title-desktop: 30px;
    --title-tablet: 26px;
    --title-mobile: 22px;

    --gap-desktop: 10px;
    --gap-mobile: 10px;
}

/* Outer container centers the whole block */
.footer-brand {
    display: flex;
    justify-content: center;
    margin: 0 auto;
    max-width: 760px;
}

/* KEY FIX: build a row for logo + title, tagline goes to the next row */
.footer-brand__text {
    display: flex;
    align-items: center;
    gap: var(--gap-desktop);
    flex-wrap: wrap;
    /* allows tagline to go to the next line */
    justify-content: center;
    /* center row content */
}

/* tagline occupies whole line under the row */
.footer-brand__tagline {
    flex-basis: 100%;
    text-align: center;
    margin-top: 6px;
    font-size: 16px;
    line-height: 1.5;
    color: #C8BFA9;
}

/* logo + title on one line */
.footer-brand__logo-link {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.footer-brand__logo {
    height: var(--logo-desktop);
    width: auto;
    display: block;
    margin: 0;
}

.footer-brand__title {
    display: inline-block;
    margin: 0;
    font-family: "Playfair Display", serif;
    font-weight: 700;
    font-size: var(--title-desktop);
    line-height: 1.15;
    letter-spacing: .2px;
    color: #FFFFFF;
    text-decoration: none;
    white-space: nowrap;
    /* keep title on one line with logo */
    transform: translateY(1px);
    /* tiny optical baseline alignment */
}

.footer-brand__title span {
    color: #e6cb7b;
}

/* gold accent */

/* Tablet */
@media (max-width:1024px) {
    .footer-brand__logo {
        height: var(--logo-tablet);
    }

    .footer-brand__title {
        font-size: var(--title-tablet);
    }
}

/* Mobile: stack everything and center */
@media (max-width:768px) {
    .footer-brand__text {
        flex-direction: column;
        gap: var(--gap-mobile);
    }

    .footer-brand__logo {
        height: var(--logo-mobile);
    }

    .footer-brand__title {
        font-size: var(--title-mobile);
        white-space: normal;
        transform: none;
        text-align: center;
    }
}


/* Mobile fix: stack logo, title, tagline centered */
@media (max-width: 768px) {
    .ct-footer .footer-brand {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 10px !important;
        text-align: center !important;
    }

    .ct-footer .footer-brand__text {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .ct-footer .footer-brand__logo {
        height: 70px !important;
        /* было 36 — чуть компактнее на телефоне */
    }

    .ct-footer .footer-brand__title {
        font-size: 22px !important;
        line-height: 1.2 !important;
        white-space: normal !important;
        /* разрешаем перенос, чтобы не уезжало вправо */
        transform: none !important;
    }

    .ct-footer .footer-brand__tagline {
        flex-basis: auto !important;
        /* чтобы не пыталась встать в ту же строку */
        font-size: 15px !important;
        margin-top: 4px !important;
        padding: 0 12px;
        /* чуть воздуха по краям */
        max-width: 36ch;
        /* ограничим длину строки для читабельности */
    }
}















/* =========================
   Scroll Reveal (smooth + visible)
   Works even on refresh mid-page
========================= */
html.sr-ready .sr-item {
    opacity: 0;
    transform: translate3d(0, 18px, 0);
    transition:
        opacity 750ms ease,
        transform 750ms cubic-bezier(.2, .8, .2, 1);
    transition-delay: var(--sr-delay, 0ms);
    will-change: opacity, transform;
}

html.sr-ready .sr-item.sr-left {
    transform: translate3d(-22px, 0, 0);
}

html.sr-ready .sr-item.is-in {
    opacity: 1;
    transform: translateY(0);
}

html.sr-ready .sr-item.sr-pop {
    transform: translate3d(0, 18px, 0) scale(.985);
}

html.sr-ready .sr-item.sr-show {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    html.sr-ready .sr-item {
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
    }
}


/* =========================================
   SR SAFETY FIX — never leave content hidden
========================================= */

/* Bars, actions, chips — MUST NEVER stay hidden */
.nba-exp__bar.sr-item,
.nba-exp__actions.sr-item,
.nba-exp__chips.sr-item {
    opacity: 1;
    transform: none;
}

/* On mobile — disable reveal for critical CTAs */
@media (max-width: 768px) {

    .nba-exp__bar,
    .nba-exp__actions,
    .nba-exp__chips {
        opacity: 1 !important;
        transform: none !important;
    }
}