/* VinVic PRO — konto klienta WooCommerce (shell + górne menu .vv-mod-nav) */
body.vv-customer-account.woocommerce-account,
body.vv-rma-guest-page.vv-customer-account {
    /* Preset sklepu z Wygląd → Sklep (vv-admin_theme&vv_appearance_tab=store):
       kolory, promień i czcionka wstrzykiwane są globalnie jako --vvfs-* / --vv-harmony-* / --vv-ui-font. */
    --vv-ca-accent: var(--vvfs-accent, var(--vv-harmony-accent, var(--vv-accent, #8ab4f8)));
    --vv-ca-accent-glow: color-mix(in srgb, var(--vv-ca-accent) 28%, transparent);
    --vv-ca-radius: var(--vv-harmony-radius, var(--vvfs-radius, 16px));
    --vv-ca-radius-sm: var(--vv-harmony-radius-sm, max(6px, calc(var(--vv-ca-radius) - 6px)));
    --vv-ca-card-bg: var(--vvfs-bg, var(--vv-bg-card, #fff));
    --vv-ca-border: var(--vvfs-border, var(--vv-border, rgba(0, 0, 0, 0.08)));
    --vv-ca-text: var(--vvfs-text, inherit);
    --vv-ca-text-dim: var(--vvfs-text-dim, #64748b);
    --vv-ca-btn-bg: var(--vv-harmony-primary-bg, var(--vv-ca-accent));
    --vv-ca-btn-text: var(--vv-harmony-primary-text, #fff);
    --vv-ca-font: var(--vvfs-font, var(--vv-ui-font, "Inter", system-ui, -apple-system, sans-serif));
    --vv-ca-gutter: clamp(16px, 4vw, 40px);
    --vv-ca-max: min(1440px, 100%);
}

/* Czcionka sklepu (preset) na całym koncie — nie dziedziczymy fontu motywu */
body.vv-customer-account .woocommerce,
body.vv-customer-account .vv-ca-nav-wrap,
body.vv-customer-account .vv-ca-shell,
body.vv-customer-account .woocommerce-MyAccount-content,
body.vv-customer-account .woocommerce-MyAccount-content *,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap * {
    font-family: var(--vv-ca-font);
}

/* ===== Uniwersalny, wyśrodkowany layout konta — działa z KAŻDYM motywem =====
   Zasada (niezależna od nazw klas motywu): dowolny kontener, który ZAWIERA przerobioną
   nawigację konta (.vv-ca-nav-wrap), rozciągamy na pełną szerokość i wymuszamy układ
   jednokolumnowy, a sąsiednie paski boczne chowamy. Dzięki :has() to samo działa na
   OceanWP, Astra, GeneratePress, Storefront, Kadence, Twenty* i Elementorze — bez
   breakoutu 100vw (nic nie ucieka w lewo, każda podstrona wygląda identycznie). */

/* Kotwica „to jest treść konta” działa zarówno po zalogowaniu (.vv-ca-nav-wrap /
   .woocommerce-MyAccount-content) jak i na ekranie logowania/rejestracji
   (#customer_login / .woocommerce-form-login). Dzięki temu layout jest identyczny
   na KAŻDEJ podstronie konta, także wylogowanej. */

/* 1) Paski boczne na stronie konta — typowe wzorce wszystkich motywów. */
body:has(.vv-ca-nav-wrap) #secondary,
body:has(.vv-ca-nav-wrap) #right-sidebar,
body:has(.vv-ca-nav-wrap) #left-sidebar,
body:has(.vv-ca-nav-wrap) aside.widget-area,
body:has(.vv-ca-nav-wrap) aside[class*="sidebar"],
body:has(.vv-ca-nav-wrap) [id*="sidebar"]:not([id*="content"]),
body:has(.vv-ca-nav-wrap) .sidebar-container,
body:has(.vv-ca-nav-wrap) .widget-area:not(.elementor-element),
body:has(#customer_login) #secondary,
body:has(#customer_login) #right-sidebar,
body:has(#customer_login) #left-sidebar,
body:has(#customer_login) aside.widget-area,
body:has(#customer_login) aside[class*="sidebar"],
body:has(#customer_login) [id*="sidebar"]:not([id*="content"]),
body:has(#customer_login) .sidebar-container,
body:has(#customer_login) .widget-area:not(.elementor-element),
body:has(.vv-rma-guest-wrap) #secondary,
body:has(.vv-rma-guest-wrap) #right-sidebar,
body:has(.vv-rma-guest-wrap) #left-sidebar,
body:has(.vv-rma-guest-wrap) aside.widget-area,
body:has(.vv-rma-guest-wrap) aside[class*="sidebar"],
body:has(.vv-rma-guest-wrap) [id*="sidebar"]:not([id*="content"]),
body:has(.vv-rma-guest-wrap) .sidebar-container,
body:has(.vv-rma-guest-wrap) .widget-area:not(.elementor-element),
body.vv-customer-account #secondary,
body.vv-customer-account #right-sidebar,
body.vv-customer-account #left-sidebar,
body.vv-customer-account aside.widget-area,
body.vv-customer-account aside[class*="sidebar"],
body.vv-customer-account [id*="sidebar"]:not([id*="content"]),
body.vv-customer-account .sidebar-container,
body.vv-customer-account .widget-area:not(.elementor-element) {
    display: none !important;
}

/* 2) Każdy przodek treści konta (kolumna + kontener) na pełną szerokość,
      bez floatów/gridów rezerwujących miejsce na ukryty sidebar. */
body:has(.vv-ca-nav-wrap) main:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) article:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [id*="content"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [id*="primary"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="content-area"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="content-wrap"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="site-content"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="entry"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(#customer_login) main:has(#customer_login),
body:has(#customer_login) article:has(#customer_login),
body:has(#customer_login) [id*="content"]:has(#customer_login),
body:has(#customer_login) [id*="primary"]:has(#customer_login),
body:has(#customer_login) [class*="content-area"]:has(#customer_login),
body:has(#customer_login) [class*="content-wrap"]:has(#customer_login),
body:has(#customer_login) [class*="site-content"]:has(#customer_login),
body:has(#customer_login) [class*="entry"]:has(#customer_login),
body:has(.vv-rma-guest-wrap) #content-wrap,
body:has(.vv-rma-guest-wrap) #primary,
body:has(.vv-rma-guest-wrap) #content,
body:has(.vv-rma-guest-wrap) .content-area,
body:has(.vv-rma-guest-wrap) .site-content,
body:has(.vv-rma-guest-wrap) .single-page-article,
body:has(.vv-rma-guest-wrap) .entry,
body:has(.vv-rma-guest-wrap) [class*="content-wrap"],
body:has(.vv-rma-guest-wrap) main,
body:has(.vv-rma-guest-wrap) article {
    width: 100% !important;
    max-width: none !important;
    float: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    grid-template-columns: 1fr !important;
}

body:has(.vv-rma-guest-wrap) #content-wrap.container {
    display: block !important;
    max-width: min(1320px, 100%) !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
}

/* 3) Tło obszaru treści z presetu sklepu — bez jasnej ramki motywu wokół ciemnego
      panelu. Bez presetu: przezroczyste (tło motywu). */
body:has(.vv-ca-nav-wrap) main:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) article:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [id*="content"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [id*="primary"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="content-wrap"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="site-content"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(.vv-ca-nav-wrap) [class*="entry"]:has(.vv-ca-nav-wrap, #customer_login),
body:has(#customer_login) main:has(#customer_login),
body:has(#customer_login) article:has(#customer_login),
body:has(#customer_login) [id*="content"]:has(#customer_login),
body:has(#customer_login) [id*="primary"]:has(#customer_login),
body:has(#customer_login) [class*="content-wrap"]:has(#customer_login),
body:has(#customer_login) [class*="site-content"]:has(#customer_login),
body:has(#customer_login) [class*="entry"]:has(#customer_login),
body:has(.vv-rma-guest-wrap) #content-wrap,
body:has(.vv-rma-guest-wrap) #primary,
body:has(.vv-rma-guest-wrap) #content,
body:has(.vv-rma-guest-wrap) .content-area,
body:has(.vv-rma-guest-wrap) .site-content,
body:has(.vv-rma-guest-wrap) .single-page-article,
body:has(.vv-rma-guest-wrap) .entry,
body.vv-rma-guest-page.vv-customer-account main,
body.vv-rma-guest-page.vv-customer-account [id*="content"],
body.vv-rma-guest-page.vv-customer-account [id*="primary"],
body.vv-rma-guest-page.vv-customer-account [class*="content-wrap"],
body.vv-rma-guest-page.vv-customer-account [class*="site-content"],
body.vv-rma-guest-page.vv-customer-account [class*="entry"] {
    background: var(--vv-ca-page-bg, transparent) !important;
}

/* Jedna, wyśrodkowana kolumna dla całego konta — z własną powierzchnią z presetu sklepu
   (--vvfs-bg / --vvfs-text), żeby było czytelne i identyczne na każdym motywie: jasnym i ciemnym.
   Bez tego treść jest „przezroczysta" nad motywem i przy ciemnym szablonie znika tło. */
body.vv-customer-account .woocommerce,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap.woocommerce,
.woocommerce:has(> .vv-ca-account-head),
.woocommerce:has(> .vv-ca-nav-wrap),
.woocommerce:has(> #customer_login),
.woocommerce:has(> .woocommerce-form-login),
.woocommerce:has(.woocommerce-form-register) {
    box-sizing: border-box;
    width: 100%;
    max-width: var(--vv-ca-shell-max, 1320px);
    margin: 24px auto !important;
    padding: clamp(16px, 3vw, 32px);
    background: color-mix(in srgb, var(--vv-ca-text) 4%, var(--vv-ca-card-bg));
    color: var(--vv-ca-text);
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
}

body.vv-customer-account .woocommerce-MyAccount-content,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content,
.woocommerce:has(> .vv-ca-account-head) .woocommerce-MyAccount-content,
.woocommerce:has(> .vv-ca-nav-wrap) .woocommerce-MyAccount-content {
    width: 100%;
    max-width: none;
    color: var(--vv-ca-text);
}

/* Nav i shell równają do tej samej kolumny — koniec z pełnym bleedem i przesunięciami */
body.vv-customer-account .vv-ca-account-head,
body.vv-customer-account .vv-ca-nav-wrap,
body.vv-customer-account .vv-ca-shell--fullwidth {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

body.vv-customer-account .vv-ca-nav-wrap {
    padding: clamp(14px, 2vw, 22px) 0 0;
    background: transparent;
    max-width: 100%;
    overflow: visible;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px 16px;
}

body.vv-customer-account .vv-ca-nav-avatar-logo {
    flex: 0 0 auto;
}

body.vv-customer-account .vv-ca-nav-avatar-logo__link {
    display: block;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--vv-ca-border);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--vv-ca-text) 8%, transparent);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

body.vv-customer-account .vv-ca-nav-avatar-logo__link:hover,
body.vv-customer-account .vv-ca-nav-avatar-logo__link:focus-visible {
    border-color: var(--vv-ca-accent);
    box-shadow: 0 6px 18px color-mix(in srgb, var(--vv-ca-accent) 24%, transparent);
    transform: translateY(-1px);
}

body.vv-customer-account .vv-ca-nav-avatar-logo__link.is-current {
    border-color: var(--vv-ca-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--vv-ca-accent) 22%, transparent);
}

body.vv-customer-account .vv-ca-nav-avatar-logo__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.vv-customer-account .vv-ca-nav-wrap .vv-mod-nav.vv-ca-top-nav {
    flex: 1 1 100%;
    margin: 0 0 22px;
    max-width: 100%;
    min-width: 0;
}

body.vv-customer-account .vv-ca-shell--fullwidth {
    padding: clamp(16px, 2.5vw, 28px) 0 clamp(24px, 4vw, 48px);
    background: var(--vv-ca-card-bg);
    border: none;
    box-shadow: none;
    border-radius: 0;
}

body.vv-customer-account .vv-ca-shell--fullwidth .vv-ca-page-body,
body.vv-customer-account .vv-ca-dashboard--fullwidth {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
}

/* Każdy blok treści wypełnia kolumnę — lista zamówień, podgląd, kreator zwrotu, panel */
body.vv-customer-account .woocommerce-MyAccount-content > *,
body.vv-customer-account .vv-ca-dashboard,
body.vv-customer-account .vv-rma,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .vv-rma,
body.vv-customer-account .woocommerce-order-details,
body.vv-customer-account .woocommerce-customer-details {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
}

body.vv-customer-account .vv-ca-welcome {
    margin-bottom: 18px;
    padding: 14px 18px;
    border-radius: var(--vv-ca-radius);
    border: 1px solid var(--vv-ca-border);
    background: var(--vv-ca-card-bg);
    font-weight: 700;
    font-size: 14px;
}

/* Powitanie po zalogowaniu (zamiast domyślnego tekstu WooCommerce) */
body.vv-customer-account .vv-ca-login-welcome {
    margin: 0 0 20px;
    padding: 16px 20px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: color-mix(in srgb, var(--vv-ca-accent) 6%, var(--vv-ca-card-bg));
}

body.vv-customer-account .vv-ca-login-welcome__greeting {
    margin: 0 0 8px;
    font-size: 15px;
    line-height: 1.55;
    color: var(--vv-ca-text);
}

body.vv-customer-account .vv-ca-login-welcome__greeting strong {
    font-weight: 900;
}

body.vv-customer-account .vv-ca-login-welcome__logout {
    font-weight: 500;
    color: var(--vv-ca-text-dim);
    white-space: nowrap;
}

body.vv-customer-account .vv-ca-login-welcome__logout a {
    color: var(--vv-ca-accent);
    font-weight: 700;
    text-decoration: none;
}

body.vv-customer-account .vv-ca-login-welcome__logout a:hover {
    text-decoration: underline;
}

body.vv-customer-account .vv-ca-login-welcome__hint {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-login-welcome__hint a {
    color: var(--vv-ca-accent);
    font-weight: 700;
    text-decoration: none;
}

body.vv-customer-account .vv-ca-login-welcome__hint a:hover {
    text-decoration: underline;
}

/* Ukryj ewentualny pozostały tekst WooCommerce na dashboardzie */
body.vv-customer-account.vv-ca-endpoint-dashboard .woocommerce-MyAccount-content > p {
    display: none !important;
}

/* ========== Nagłówek podstrony ========== */
body.vv-customer-account .vv-ca-page-header {
    margin: 0 auto 18px;
    padding: 0 0 16px;
    border-bottom: 1px solid var(--vv-ca-border);
    max-width: var(--vv-ca-max);
    width: 100%;
}

body.vv-customer-account .vv-ca-page-header__title {
    margin: 0 0 6px;
    font-size: clamp(22px, 3vw, 28px);
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 1.15;
    color: var(--vv-ca-text) !important;
}

body.vv-customer-account .vv-ca-page-header__subtitle {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--vv-ca-text-dim);
    font-weight: 500;
}

body.vv-customer-account .vv-ca-page-intro {
    margin: 0 0 18px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-page-custom {
    margin-bottom: 18px;
}

body.vv-customer-account .vv-ca-page-body {
    min-width: 0;
}

/* ========== Górne menu — jak panel VinVic (.vv-mod-nav) ========== */
body.vv-customer-account .vv-mod-nav.vv-ca-top-nav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
    align-content: flex-start;
    gap: 6px 4px;
    margin: 0 auto 22px;
    padding: 0 0 14px;
    border-bottom: 1px solid var(--vv-ca-border);
    max-width: var(--vv-ca-max);
    width: 100%;
    min-width: 0;
    overflow: visible;
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin: 0;
    padding: 10px 16px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.25;
    text-decoration: none;
    color: var(--vv-ca-text-dim);
    background: color-mix(in srgb, var(--vv-ca-text) 4%, transparent);
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius-sm, 10px);
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    white-space: nowrap;
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item:hover {
    color: var(--vv-ca-text);
    background: color-mix(in srgb, var(--vv-ca-accent) 10%, var(--vv-ca-card-bg));
    border-color: color-mix(in srgb, var(--vv-ca-accent) 24%, var(--vv-ca-border));
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item.is-active {
    color: var(--vv-ca-btn-text, #fff);
    background: var(--vv-ca-btn-bg, var(--vv-ca-accent));
    border-color: var(--vv-ca-btn-bg, var(--vv-ca-accent));
    box-shadow: 0 4px 14px var(--vv-ca-accent-glow);
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item.vv-ca-nav-danger {
    color: #ef4444;
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item.vv-ca-nav-danger.is-active,
body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item.vv-ca-nav-danger:hover {
    color: #fff;
    background: #ef4444;
    border-color: #ef4444;
    box-shadow: 0 4px 14px color-mix(in srgb, #ef4444 35%, transparent);
}

body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item.vv-ca-nav-logout {
    font-weight: 800;
}

/* ========== Układ: ukryj nawigację motywu tylko gdy VinVic menu jest na stronie ========== */
body.vv-customer-account:has(.vv-ca-top-nav) .woocommerce-MyAccount-tabs,
body.vv-customer-account:has(.vv-ca-top-nav) .oceanwp-user-profile,
body.vv-customer-account:has(.vv-ca-top-nav) .woocommerce-MyAccount-navigation {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

body.vv-customer-account--nav-top:has(.vv-ca-top-nav) .woocommerce-MyAccount-navigation,
body.vv-customer-account--nav-sidebar:has(.vv-ca-top-nav) .woocommerce-MyAccount-navigation {
    display: none !important;
}

body.vv-customer-account--nav-top.woocommerce-account .woocommerce-account-wrap,
body.vv-customer-account--nav-top.woocommerce-account #primary.content-area,
body.vv-customer-account--nav-sidebar.woocommerce-account .woocommerce-account-wrap,
body.vv-customer-account--nav-sidebar.woocommerce-account #primary.content-area {
    display: block;
}

body.vv-customer-account--nav-top .woocommerce-MyAccount-content,
body.vv-customer-account--nav-sidebar .woocommerce-MyAccount-content {
    float: none;
    width: 100%;
}

/* ========== Treść WooCommerce w kartach ========== */
body.vv-customer-account--layout-cards .woocommerce-MyAccount-content > p,
body.vv-customer-account--layout-cards .woocommerce-MyAccount-content > .woocommerce-message,
body.vv-customer-account--layout-cards .woocommerce-MyAccount-content > .woocommerce-info,
body.vv-customer-account--layout-cards .woocommerce-MyAccount-content > .woocommerce-error {
    border-radius: var(--vv-ca-radius);
}

/* ========== Ulubione — pełna szerokość w obrębie konta ========== */
body.vv-customer-account .woocommerce-MyAccount-content > .vv-wl-page,
body.vv-customer-account .vv-ca-page-body > .vv-wl-page {
    width: 100%;
    max-width: 100%;
}

body.vv-customer-account .vv-wl-page--account .vv-fav-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr));
}

.vv-return-form {
    max-width: 640px;
    display: grid;
    gap: 14px;
}

.vv-return-form label {
    display: block;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
    opacity: 0.75;
}

.vv-return-form input,
.vv-return-form select,
.vv-return-form textarea {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid var(--vv-ca-border, rgba(0, 0, 0, 0.12));
}

.vv-return-history {
    margin-top: 28px;
    border-top: 1px solid var(--vv-ca-border, rgba(0, 0, 0, 0.08));
    padding-top: 20px;
}

.vv-return-row {
    padding: 12px 0;
    border-bottom: 1px solid var(--vv-ca-border, rgba(0, 0, 0, 0.06));
    font-size: 13px;
}

.vv-fav-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: none;
    background: transparent;
    cursor: pointer;
    font-weight: 700;
    font-size: 13px;
    padding: 6px 10px;
    border-radius: 999px;
    transition: background 0.2s;
}

.vv-fav-btn.is-active {
    color: #ef4444;
}

.vv-fav-btn:hover {
    background: rgba(0, 0, 0, 0.05);
}

@media (max-width: 1100px) {
    body.vv-customer-account .account-dashboard-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    body.vv-customer-account .vv-mod-nav.vv-ca-top-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        flex-wrap: wrap;
        overflow: visible;
        overscroll-behavior: auto;
        max-width: 100%;
        padding-bottom: 14px;
        margin-bottom: 16px;
    }

    body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item {
        flex: 1 1 auto;
        width: 100%;
        min-width: 0;
        padding: 10px 8px;
        font-size: 11px;
        white-space: normal;
        text-align: center;
        line-height: 1.35;
    }

    body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__label {
        display: block;
    }

    body.vv-customer-account .vv-ca-nav-wrap {
        align-items: flex-start;
    }

    body.vv-customer-account .vv-ca-nav-avatar-logo__link {
        width: 52px;
        height: 52px;
    }

    body.vv-customer-account .vv-ca-nav-wrap .vv-mod-nav.vv-ca-top-nav {
        flex-basis: 100%;
    }

    body.vv-customer-account .woocommerce-MyAccount-content {
        min-width: 0;
        overflow-x: clip;
    }

    body.vv-customer-account .woocommerce,
    body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap.woocommerce,
    .woocommerce:has(> .vv-ca-account-head),
    .woocommerce:has(> .vv-ca-nav-wrap),
    .woocommerce:has(> #customer_login) {
        margin: 12px auto !important;
        padding: 14px 12px;
        border-radius: var(--vv-ca-radius-sm);
    }

    body.vv-customer-account .account-user-profile {
        flex-direction: column;
        text-align: center;
        padding: 14px;
    }
}

@media (max-width: 640px) {
    body.vv-customer-account .vv-mod-nav.vv-ca-top-nav {
        grid-template-columns: 1fr;
    }

    body.vv-customer-account .vv-mod-nav.vv-ca-top-nav .vv-mod-nav__item {
        padding: 10px 12px;
        font-size: 12px;
        text-align: left;
    }

    body.vv-customer-account .vv-ca-shell--fullwidth {
        padding-left: 16px;
        padding-right: 16px;
    }

    body.vv-customer-account .account-welcome-banner {
        padding: 16px;
        flex-direction: column;
        align-items: flex-start;
    }

    body.vv-customer-account .account-user-profile {
        flex-direction: column;
        text-align: center;
    }

    body.vv-customer-account .account-dashboard-grid {
        grid-template-columns: 1fr;
    }

    body.vv-customer-account .dashboard-grid-tile .tile-actions {
        flex-direction: column;
        align-items: stretch;
    }

    body.vv-customer-account .dashboard-grid-tile .tile-button {
        width: 100%;
        justify-content: center;
    }
}

/* ========== Profil użytkownika ========== */
body.vv-customer-account .account-user-profile {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 0 0 22px;
    padding: 16px 18px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
    max-width: var(--vv-ca-max);
    width: 100%;
    box-sizing: border-box;
}

body.vv-customer-account .woocommerce-MyAccount-content > .vv-ca-profile-editable,
body.vv-customer-account .vv-ca-page-body > .vv-ca-profile-editable {
    max-width: 100%;
}

body.vv-customer-account--nav-sidebar .account-user-profile {
    max-width: 280px;
    margin-left: 0;
    margin-right: auto;
}

body.vv-customer-account .banner-logo {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 88px;
}

body.vv-customer-account .banner-logo__placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 10px 16px;
    border: 1px dashed var(--vv-ca-border);
    border-radius: 10px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--vv-ca-text-dim);
    background: color-mix(in srgb, var(--vv-ca-accent) 8%, var(--vv-ca-card-bg, #fff));
}

body.vv-customer-account .banner-logo img {
    max-height: clamp(40px, 8vw, 72px);
    width: auto;
    max-width: min(220px, 40vw);
    box-shadow: none !important;
    border-radius: 8px !important;
}

body.vv-customer-account .account-user-avatar img.avatar {
    display: block;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: none !important;
}

body.vv-customer-account .vv-ca-profile-editable .account-user-avatar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

body.vv-customer-account .vv-ca-avatar-upload {
    display: inline-flex;
    position: relative;
    cursor: pointer;
}

body.vv-customer-account .vv-ca-avatar-upload__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 4px 10px;
    border-radius: var(--vv-ca-radius-sm, 10px);
    border: 1px solid var(--vv-ca-border);
    background: color-mix(in srgb, var(--vv-ca-accent) 10%, var(--vv-ca-card-bg, #fff));
    color: var(--vv-ca-text);
    font-size: 11px;
    font-weight: 700;
}

body.vv-customer-account .vv-ca-avatar-upload__input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

body.vv-customer-account .vv-ca-profile-editable__status {
    margin: 8px 0 0;
    min-height: 1.2em;
    font-size: 12px;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-profile-editable__status.is-success {
    color: #15803d;
}

body.vv-customer-account .vv-ca-profile-editable__status.is-error {
    color: #b91c1c;
}

body.vv-customer-account .vv-ca-notifications__lead {
    margin: 0 0 14px;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-notifications__empty {
    margin: 0 0 12px;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-notifications__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

body.vv-customer-account .vv-ca-notifications__item {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px 14px;
    padding: 12px 14px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius-sm, 10px);
    background: var(--vv-ca-card-bg, #fff);
}

body.vv-customer-account .vv-ca-notifications__thumb {
    display: block;
    width: 64px;
    height: 64px;
    border-radius: var(--vv-ca-radius-sm, 10px);
    overflow: hidden;
    border: 1px solid var(--vv-ca-border);
    background: color-mix(in srgb, var(--vv-ca-text) 4%, var(--vv-ca-card-bg, #fff));
    flex-shrink: 0;
    text-decoration: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.vv-customer-account a.vv-ca-notifications__thumb:hover,
body.vv-customer-account a.vv-ca-notifications__thumb:focus-visible {
    border-color: color-mix(in srgb, var(--vv-ca-accent) 35%, var(--vv-ca-border));
    box-shadow: 0 4px 14px color-mix(in srgb, var(--vv-ca-accent) 14%, transparent);
}

body.vv-customer-account .vv-ca-notifications__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.vv-customer-account .vv-ca-notifications__img--placeholder {
    display: block;
    width: 100%;
    height: 100%;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--vv-ca-accent) 12%, var(--vv-ca-card-bg, #fff)), color-mix(in srgb, var(--vv-ca-text) 6%, var(--vv-ca-card-bg, #fff)));
}

body.vv-customer-account .vv-ca-notifications__main {
    display: grid;
    gap: 4px;
    min-width: 0;
}

body.vv-customer-account .vv-ca-notifications__title {
    font-weight: 700;
    color: var(--vv-ca-text);
    text-decoration: none;
}

body.vv-customer-account a.vv-ca-notifications__title:hover {
    color: var(--vv-ca-accent);
}

body.vv-customer-account .vv-ca-notifications__date {
    font-size: 12px;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .vv-ca-notifications__unsub {
    font-size: 12px;
    font-weight: 700;
    color: var(--vv-ca-accent);
    text-decoration: none;
    white-space: nowrap;
}

body.vv-customer-account a.vv-ca-notifications__unsub:hover,
body.vv-customer-account a.vv-ca-notifications__unsub:focus-visible {
    text-decoration: underline;
}

@media (max-width: 640px) {
    body.vv-customer-account .vv-ca-notifications__item {
        grid-template-columns: 56px minmax(0, 1fr);
    }

    body.vv-customer-account .vv-ca-notifications__thumb {
        width: 56px;
        height: 56px;
    }

    body.vv-customer-account .vv-ca-notifications__unsub {
        grid-column: 1 / -1;
        justify-self: flex-start;
    }
}

body.vv-customer-account .account-user-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

body.vv-customer-account .account-username {
    font-size: 16px;
    font-weight: 800;
    color: var(--vv-ca-text);
    line-height: 1.2;
}

body.vv-customer-account .account-user-email {
    font-size: 13px;
    color: var(--vv-ca-text-dim);
    word-break: break-word;
}

body.vv-customer-account .account-logout-link a {
    font-size: 12px;
    font-weight: 700;
    color: var(--vv-ca-accent);
    text-decoration: none;
}

body.vv-customer-account .account-logout-link a:hover {
    text-decoration: underline;
}

/* ========== Panel informacyjny (dashboard) ========== */
body.vv-customer-account .vv-ca-dashboard {
    display: grid;
    gap: 20px;
}

body.vv-customer-account .account-welcome-banner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
    padding: 22px 24px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: linear-gradient(135deg, color-mix(in srgb, var(--vv-ca-accent) 10%, var(--vv-ca-card-bg)), var(--vv-ca-card-bg));
}

body.vv-customer-account .banner-text {
    flex: 1;
    min-width: 220px;
}

body.vv-customer-account .banner-text h2 {
    margin: 0 0 8px;
    font-size: clamp(20px, 2.5vw, 26px);
    font-weight: 900;
    letter-spacing: -0.03em;
    color: var(--vv-ca-text) !important;
}

body.vv-customer-account .banner-text p {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .account-info-ribbon {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 16px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--vv-ca-accent) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--vv-ca-accent) 22%, transparent);
    font-size: 13px;
    font-weight: 700;
    color: var(--vv-ca-text);
}

body.vv-customer-account .account-info-ribbon .info-icon {
    font-size: 16px;
    line-height: 1;
}

body.vv-customer-account .account-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(12px, 2vw, 20px);
}

body.vv-customer-account .dashboard-grid-tile {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 18px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.03);
}

body.vv-customer-account .dashboard-grid-tile h3 {
    margin: 0;
    font-size: 15px;
    font-weight: 800;
    color: var(--vv-ca-text) !important;
    line-height: 1.35;
}

body.vv-customer-account .dashboard-grid-tile .tile-icon {
    margin-right: 4px;
}

body.vv-customer-account .dashboard-grid-tile .tile-description {
    margin: 0;
    flex: 1;
    font-size: 13px;
    line-height: 1.55;
    color: var(--vv-ca-text-dim);
}

body.vv-customer-account .dashboard-grid-tile .tile-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 4px;
}

body.vv-customer-account .dashboard-grid-tile .tile-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    border-radius: 999px !important;
    background: color-mix(in srgb, var(--vv-ca-accent) 12%, transparent) !important;
    color: var(--vv-ca-accent) !important;
    border: 1px solid color-mix(in srgb, var(--vv-ca-accent) 25%, transparent) !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    box-shadow: none !important;
}

body.vv-customer-account .dashboard-grid-tile .tile-button:hover {
    background: var(--vv-ca-accent) !important;
    color: #fff !important;
    border-color: var(--vv-ca-accent) !important;
}

/* ========== Formularze konta: edycja konta, adresy, logowanie/rejestracja ========== */
body.vv-customer-account .woocommerce-MyAccount-content h2,
body.vv-customer-account .woocommerce-MyAccount-content h3,
body.vv-customer-account .woocommerce-MyAccount-content legend,
body.vv-customer-account #customer_login h2,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content h2,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content h3 {
    color: var(--vv-ca-text) !important;
    font-weight: 800;
    letter-spacing: -0.02em;
}

/* Nagłówek strony z motywu (H1 „Moje konto”, breadcrumbs) — dopasowany do presetu sklepu:
   tło obszaru = preset, tekst = kolor panelu, czcionka = preset. Działa też dla logowania
   (body:has(#customer_login)) gdy klasa body bywa nieobecna. */
body.vv-customer-account .page-header,
body:has(#customer_login) .page-header {
    background: var(--vv-ca-page-bg, transparent) !important;
}

body.vv-customer-account .entry-title,
body.vv-customer-account .page-header-title,
body.vv-customer-account .page-header .breadcrumb-home,
body:has(#customer_login) .entry-title,
body:has(#customer_login) .page-header-title {
    font-family: var(--vv-ca-font) !important;
    color: var(--vv-ca-text, inherit) !important;
    letter-spacing: -0.02em;
}

body.vv-customer-account .page-header .site-breadcrumbs,
body.vv-customer-account .page-header .site-breadcrumbs a,
body.vv-customer-account .page-header .breadcrumb-sep,
body:has(#customer_login) .page-header .site-breadcrumbs,
body:has(#customer_login) .page-header .site-breadcrumbs a {
    color: var(--vv-ca-text-dim, inherit) !important;
}

/* Nagłówki sekcji wewnątrz panelu konta — spójna czcionka i kolor presetu. */
body.vv-customer-account .woocommerce-MyAccount-content h1,
body.vv-customer-account .woocommerce-MyAccount-content h2,
body.vv-customer-account .woocommerce-MyAccount-content h3,
body.vv-customer-account .woocommerce-order-details__title,
body.vv-customer-account .woocommerce-column__title {
    font-family: var(--vv-ca-font) !important;
    color: var(--vv-ca-text, inherit) !important;
}

body.vv-customer-account .woocommerce-MyAccount-content p,
body.vv-customer-account .woocommerce-MyAccount-content label,
body.vv-customer-account .woocommerce-MyAccount-content address,
body.vv-customer-account #customer_login label {
    color: var(--vv-ca-text);
}

body.vv-customer-account .woocommerce-MyAccount-content .form-row > label,
body.vv-customer-account #customer_login .form-row > label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 700;
}

/* Pola input/select/textarea */
body.vv-customer-account .woocommerce-MyAccount-content .input-text,
body.vv-customer-account .woocommerce-MyAccount-content input[type="text"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="email"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="tel"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="password"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="number"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="date"],
body.vv-customer-account .woocommerce-MyAccount-content input[type="file"],
body.vv-customer-account .woocommerce-MyAccount-content .vv-rma-input,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content input,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content select,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content textarea,
body.vv-rma-guest-wrap .vv-rma-input,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content input,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .vv-rma-input,
body.vv-customer-account .woocommerce-MyAccount-content select,
body.vv-customer-account .woocommerce-MyAccount-content textarea,
body.vv-customer-account #customer_login .input-text,
body.vv-customer-account #customer_login input[type="text"],
body.vv-customer-account #customer_login input[type="email"],
body.vv-customer-account #customer_login input[type="password"] {
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
    padding: 11px 14px;
    font-size: 14px;
    font-family: var(--vv-ca-font);
    color: var(--vv-ca-text) !important;
    -webkit-text-fill-color: var(--vv-ca-text) !important;
    background: var(--vv-ca-input-bg, var(--vv-ca-card-bg)) !important;
    border: 1px solid var(--vv-ca-border) !important;
    border-radius: var(--vv-ca-radius-sm, 10px) !important;
    box-shadow: none !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

body.vv-customer-account .woocommerce-MyAccount-content .input-text:focus,
body.vv-customer-account .woocommerce-MyAccount-content input:focus,
body.vv-customer-account .woocommerce-MyAccount-content select:focus,
body.vv-customer-account .woocommerce-MyAccount-content textarea:focus,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content input:focus,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content select:focus,
body.vv-rma-guest-wrap .woocommerce-MyAccount-content textarea:focus,
body.vv-customer-account #customer_login input:focus {
    outline: none;
    border-color: var(--vv-ca-accent) !important;
    box-shadow: 0 0 0 3px var(--vv-ca-accent-glow) !important;
}

body.vv-customer-account .woocommerce-MyAccount-content .input-text::placeholder,
body.vv-customer-account #customer_login .input-text::placeholder {
    color: color-mix(in srgb, var(--vv-ca-text-dim) 80%, transparent);
}

/* Wiersze formularzy pełnej szerokości (motyw potrafi je zwężać / float'ować) */
body.vv-customer-account #customer_login .form-row,
body.vv-customer-account #customer_login .woocommerce-form-row,
body.vv-customer-account .woocommerce-MyAccount-content .form-row,
body.vv-customer-account .woocommerce-MyAccount-content .woocommerce-form-row {
    box-sizing: border-box;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Pole hasła z przyciskiem „pokaż" */
body.vv-customer-account .woocommerce-MyAccount-content .password-input,
body.vv-customer-account #customer_login .password-input {
    display: flex;
    align-items: center;
    position: relative;
    width: 100% !important;
}

body.vv-customer-account .woocommerce-MyAccount-content .password-input .show-password-input,
body.vv-customer-account #customer_login .password-input .show-password-input {
    position: absolute;
    right: 12px;
    /* Ikona „oczka” (font WooCommerce, currentColor) — na ciemnym była niewidoczna. */
    color: var(--vv-ca-text, currentColor) !important;
    background: transparent !important;
    border: none !important;
    opacity: 0.7;
}

body.vv-customer-account .password-input .show-password-input::after,
body.vv-customer-account .password-input .show-password-input::before,
body.vv-customer-account #customer_login .password-input .show-password-input::after,
body.vv-customer-account #customer_login .password-input .show-password-input::before {
    color: inherit !important;
}

body.vv-customer-account .password-input .show-password-input:hover {
    opacity: 1;
}

/* Opisy / podpowiedzi */
body.vv-customer-account .woocommerce-MyAccount-content em,
body.vv-customer-account .woocommerce-MyAccount-content #account_display_name_description {
    color: var(--vv-ca-text-dim);
    font-size: 12px;
}

/* Fieldset „Zmiana hasła" */
body.vv-customer-account .woocommerce-MyAccount-content fieldset {
    margin: 8px 0 4px;
    padding: 18px 20px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
}

body.vv-customer-account .woocommerce-MyAccount-content fieldset legend {
    padding: 0 8px;
    font-size: 14px;
}

/* Przyciski formularzy (Zapisz, Zaloguj, Rejestr) */
body.vv-customer-account .woocommerce-MyAccount-content .woocommerce-Button,
body.vv-customer-account .woocommerce-MyAccount-content button.button,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content .woocommerce-Button,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content button.button,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .vv-rma .button,
.vv-rma-guest-wrap .woocommerce-MyAccount-content .woocommerce-Button,
.vv-rma-guest-wrap .woocommerce-MyAccount-content button.button,
.vv-rma-guest-wrap .vv-rma .button,
body.vv-customer-account #customer_login .woocommerce-Button,
body.vv-customer-account #customer_login button.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 11px 22px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    border: none !important;
    border-radius: var(--vv-ca-radius-sm, 10px) !important;
    background: var(--vv-harmony-primary-bg, var(--vv-ca-accent)) !important;
    color: var(--vv-harmony-primary-text, #fff) !important;
    box-shadow: none !important;
    cursor: pointer;
    transition: background 0.15s ease, transform 0.15s ease;
}

body.vv-customer-account .woocommerce-MyAccount-content .woocommerce-Button:hover,
body.vv-customer-account .woocommerce-MyAccount-content button.button:hover,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content .woocommerce-Button:hover,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .woocommerce-MyAccount-content button.button:hover,
body.vv-rma-guest-page.vv-customer-account .vv-rma-guest-wrap .vv-rma .button:hover,
.vv-rma-guest-wrap .woocommerce-MyAccount-content .woocommerce-Button:hover,
.vv-rma-guest-wrap .woocommerce-MyAccount-content button.button:hover,
.vv-rma-guest-wrap .vv-rma .button:hover,
body.vv-customer-account #customer_login .woocommerce-Button:hover,
body.vv-customer-account #customer_login button.button:hover {
    background: var(--vv-harmony-accent, var(--vv-ca-accent)) !important;
    transform: translateY(-1px);
}

/* Checkbox „Pamiętaj mnie" */
body.vv-customer-account #customer_login .woocommerce-form-login__rememberme {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}

/* Linki (zapomniane hasło itp.) */
body.vv-customer-account .woocommerce-MyAccount-content a,
body.vv-customer-account #customer_login a {
    color: var(--vv-ca-accent);
}

/* ===== Adresy — karty rozliczeniowy / wysyłka (PC + mobile) ===== */
body.vv-customer-account .woocommerce-MyAccount-content {
    background: transparent !important;
}

body.vv-customer-account .woocommerce-MyAccount-content > p:first-child {
    position: relative;
    margin: 0 0 clamp(16px, 2.5vw, 22px);
    padding: 14px 18px 14px 44px;
    border: 1px solid color-mix(in srgb, var(--vv-ca-accent) 22%, var(--vv-ca-border));
    border-radius: var(--vv-ca-radius);
    background: color-mix(in srgb, var(--vv-ca-accent) 7%, var(--vv-ca-card-bg));
    color: var(--vv-ca-text-dim);
    font-size: 14px;
    line-height: 1.55;
}

body.vv-customer-account .woocommerce-MyAccount-content > p:first-child::before {
    content: "ℹ";
    position: absolute;
    left: 16px;
    top: 14px;
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    color: var(--vv-ca-accent);
    background: color-mix(in srgb, var(--vv-ca-accent) 14%, var(--vv-ca-card-bg));
}

body.vv-customer-account .woocommerce-Addresses,
body.vv-customer-account .woocommerce-MyAccount-content .col2-set.addresses,
body.vv-customer-account .woocommerce-MyAccount-content .u-columns.addresses {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(16px, 2.5vw, 24px);
    align-items: stretch;
    margin-top: 0;
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
    background: transparent !important;
}

body.vv-vinvic-commerce-takeover.vv-customer-account .woocommerce-MyAccount-content .col2-set.addresses,
body.vv-vinvic-commerce-takeover.vv-customer-account .woocommerce-Addresses {
    display: grid !important;
}

body.vv-customer-account .woocommerce-MyAccount-content .col2-set.addresses::before,
body.vv-customer-account .woocommerce-MyAccount-content .col2-set.addresses::after,
body.vv-customer-account .woocommerce-MyAccount-content .u-columns.addresses::before,
body.vv-customer-account .woocommerce-MyAccount-content .u-columns.addresses::after {
    content: none !important;
    display: none !important;
}

body.vv-customer-account .woocommerce-MyAccount-content .u-column1,
body.vv-customer-account .woocommerce-MyAccount-content .u-column2,
body.vv-customer-account .woocommerce-MyAccount-content .col-1,
body.vv-customer-account .woocommerce-MyAccount-content .col-2 {
    display: flex;
    flex-direction: column;
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
    margin: 0 !important;
    background: transparent !important;
}

body.vv-customer-account .woocommerce-Address {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    width: 100%;
    min-height: 100%;
    min-width: 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg) !important;
    color: var(--vv-ca-text);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--vv-ca-text) 7%, transparent);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.vv-customer-account .woocommerce-Address:hover {
    border-color: color-mix(in srgb, var(--vv-ca-accent) 28%, var(--vv-ca-border));
    box-shadow: 0 12px 28px color-mix(in srgb, var(--vv-ca-text) 10%, transparent);
}

body.vv-customer-account .woocommerce-Address-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px 12px;
    flex-wrap: wrap;
    margin: 0;
    padding: 16px 18px;
    border-bottom: 1px solid var(--vv-ca-border);
    background: color-mix(in srgb, var(--vv-ca-text) 3%, var(--vv-ca-card-bg));
}

body.vv-customer-account .woocommerce-Address-title h2,
body.vv-customer-account .woocommerce-MyAccount-content .woocommerce-Address-title h3 {
    flex: 1 1 8rem;
    min-width: 0;
    margin: 0;
    font-size: clamp(15px, 1.5vw, 17px);
    font-weight: 800;
    line-height: 1.25;
    color: var(--vv-ca-text);
}

body.vv-customer-account .woocommerce-Address-title .edit {
    flex: 0 1 auto;
    max-width: 11rem;
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
    text-decoration: none;
    white-space: normal;
    border-radius: 999px;
    color: var(--vv-ca-accent);
    border: 1px solid color-mix(in srgb, var(--vv-ca-accent) 28%, transparent);
    background: color-mix(in srgb, var(--vv-ca-accent) 10%, transparent);
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

body.vv-customer-account .woocommerce-Address-title .edit:hover {
    background: var(--vv-ca-accent);
    border-color: var(--vv-ca-accent);
    color: #fff;
}

body.vv-customer-account .woocommerce-Address address {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 18px;
    font-style: normal;
    line-height: 1.75;
    color: var(--vv-ca-text);
    font-size: 14px;
    overflow-wrap: anywhere;
    word-break: break-word;
}

body.vv-customer-account .woocommerce-Address address .vv-ca-address-card-foot {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    margin: 18px -18px -18px;
    padding: 12px 18px;
    border-top: 1px solid var(--vv-ca-border);
    background: color-mix(in srgb, var(--vv-ca-text) 4%, var(--vv-ca-card-bg));
}

body.vv-customer-account .woocommerce-Address address .vv-ca-address-type-badge {
    display: inline-flex;
    align-items: center;
    margin: 0;
}

body.vv-customer-account .vv-ca-address-type-badge {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--vv-ca-accent);
    background: color-mix(in srgb, var(--vv-ca-accent) 12%, var(--vv-ca-card-bg));
    border: 1px solid color-mix(in srgb, var(--vv-ca-accent) 30%, transparent);
}

body.vv-customer-account .vv-ca-address-type-badge--business {
    color: var(--vv-ca-text);
    background: color-mix(in srgb, var(--vv-ca-text) 8%, var(--vv-ca-card-bg));
    border-color: var(--vv-ca-border);
}

@media (max-width: 900px) {
    body.vv-customer-account .woocommerce-Addresses,
    body.vv-customer-account .woocommerce-MyAccount-content .col2-set.addresses,
    body.vv-customer-account .woocommerce-MyAccount-content .u-columns.addresses {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {
    body.vv-customer-account .woocommerce-MyAccount-content > p:first-child {
        padding: 12px 14px 12px 40px;
        font-size: 13px;
    }

    body.vv-customer-account .woocommerce-MyAccount-content > p:first-child::before {
        left: 12px;
        top: 12px;
    }

    body.vv-customer-account .woocommerce-Address-title {
        flex-wrap: nowrap;
        align-items: flex-start;
        padding: 14px 16px;
    }

    body.vv-customer-account .woocommerce-Address-title h2,
    body.vv-customer-account .woocommerce-MyAccount-content .woocommerce-Address-title h3 {
        flex: 1 1 auto;
        font-size: 15px;
    }

    body.vv-customer-account .woocommerce-Address-title .edit {
        flex: 0 0 auto;
        max-width: 46%;
        padding: 6px 10px;
        font-size: 10px;
    }

    body.vv-customer-account .woocommerce-Address address {
        padding: 16px;
        font-size: 13px;
    }

    body.vv-customer-account .woocommerce-Address address .vv-ca-address-card-foot {
        margin: 16px -16px -16px;
        padding: 10px 16px;
    }
}

/* Edycja adresu rozliczeniowego + checkout — typ konta (preset sklepu) */
body.vv-customer-account .vv-ca-account-type,
body.woocommerce-checkout .vv-ca-account-type {
    margin: 0 0 20px;
    padding: 18px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: color-mix(in srgb, var(--vv-ca-accent) 5%, var(--vv-ca-card-bg));
    color: var(--vv-ca-text);
}

body.vv-customer-account .vv-ca-account-type__label,
body.woocommerce-checkout .vv-ca-account-type__label {
    margin: 0 0 10px;
    font-size: 13px;
    font-weight: 800;
    color: var(--vv-ca-text);
}

body.vv-customer-account .vv-ca-account-type__options,
body.woocommerce-checkout .vv-ca-account-type__options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

body.vv-customer-account .vv-ca-account-type__option,
body.woocommerce-checkout .vv-ca-account-type__option {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 12px 14px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius-sm, 10px);
    background: var(--vv-ca-card-bg);
    cursor: pointer;
    font-weight: 600;
    color: var(--vv-ca-text);
    transition: border-color 0.15s ease, background 0.15s ease;
}

body.vv-customer-account .vv-ca-account-type__option span,
body.woocommerce-checkout .vv-ca-account-type__option span {
    color: inherit;
}

body.vv-customer-account .vv-ca-account-type__option:has(input:checked),
body.woocommerce-checkout .vv-ca-account-type__option:has(input:checked) {
    border-color: var(--vv-ca-accent);
    background: color-mix(in srgb, var(--vv-ca-accent) 10%, var(--vv-ca-card-bg));
    box-shadow: 0 0 0 2px var(--vv-ca-accent-glow);
}

body.vv-customer-account .vv-ca-account-type__option input,
body.woocommerce-checkout .vv-ca-account-type__option input {
    width: auto !important;
    max-width: none !important;
    margin: 0;
    flex-shrink: 0;
    accent-color: var(--vv-ca-accent);
}

body.vv-customer-account .vv-ca-account-type__hint,
body.woocommerce-checkout .vv-ca-account-type__hint {
    margin: 10px 0 0 !important;
    color: var(--vv-ca-text-dim) !important;
    font-size: 12px !important;
}

body.woocommerce-checkout .vv-ca-account-type__hint.description {
    color: var(--vv-ca-text-dim) !important;
}

body.vv-customer-account .woocommerce-MyAccount-content form.woocommerce-EditAddressForm {
    padding: 20px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
}

body.vv-customer-account .woocommerce-MyAccount-content form.woocommerce-EditAccountForm {
    padding: 20px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
}

body.vv-customer-account .vv-ca-business-panel {
    margin: 8px 0 20px;
    padding: 18px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: color-mix(in srgb, var(--vv-ca-accent) 5%, var(--vv-ca-card-bg));
}

body.vv-customer-account .vv-ca-business-panel[hidden] {
    display: none !important;
}

body.vv-customer-account .vv-ca-business-panel__title {
    margin: 0 0 6px;
    font-size: 15px;
    font-weight: 800;
    color: var(--vv-ca-text);
}

body.vv-customer-account .vv-ca-business-panel__lead {
    margin: 0 0 14px !important;
    color: var(--vv-ca-text-dim) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
}

body.vv-customer-account .vv-ca-profile-type {
    margin-bottom: 22px;
}

@media (max-width: 768px) {
    body.vv-customer-account .vv-ca-account-type__options,
    body.woocommerce-checkout .vv-ca-account-type__options,
    body.vv-customer-account #customer_login.col2-set,
    body.vv-customer-account .account-dashboard-grid {
        grid-template-columns: 1fr;
    }
}

/* ===== Logowanie / Rejestracja ===== */
body.vv-customer-account #customer_login.col2-set {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(16px, 2.5vw, 28px);
    margin-top: 8px;
}

/* OceanWP/WooCommerce dodają do .col2-set clearfix ::before/::after, który w gridzie
   tworzy fałszywe komórki i rozjeżdża kolumny — usuwamy je. */
body.vv-customer-account #customer_login.col2-set::before,
body.vv-customer-account #customer_login.col2-set::after {
    content: none !important;
    display: none !important;
}

body.vv-customer-account #customer_login .col-1,
body.vv-customer-account #customer_login .col-2 {
    float: none !important;
    margin: 0 !important;
}

body.vv-customer-account #customer_login .col-1,
body.vv-customer-account #customer_login .col-2 {
    box-sizing: border-box;
    width: 100%;
    padding: 22px;
    border: 1px solid var(--vv-ca-border);
    border-radius: var(--vv-ca-radius);
    background: var(--vv-ca-card-bg);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.03);
}

/* ===== Checkout — typ konta prywatne / firmowe (tokeny z presetu sklepu) ===== */
body.woocommerce-checkout {
    --vv-ca-accent: var(--vv-co-accent, var(--vv-harmony-accent, var(--vvfs-accent, var(--vv-accent, #8ab4f8))));
    --vv-ca-accent-glow: color-mix(in srgb, var(--vv-ca-accent) 28%, transparent);
    --vv-ca-radius: var(--vv-co-radius, var(--vv-harmony-radius, var(--vvfs-radius, 16px)));
    --vv-ca-radius-sm: var(--vv-harmony-radius-sm, max(6px, calc(var(--vv-ca-radius) - 6px)));
    --vv-ca-card-bg: var(--vv-co-card, var(--vvfs-bg, var(--vv-bg-card, #fff)));
    --vv-ca-border: var(--vv-co-surface-border, var(--vvfs-border, var(--vv-border, rgba(0, 0, 0, 0.08))));
    --vv-ca-text: var(--vv-co-text, var(--vvfs-text, inherit));
    --vv-ca-text-dim: var(--vv-co-muted, var(--vvfs-text-dim, #64748b));
}

body.woocommerce-checkout .vv-ca-account-type--billing {
    margin-bottom: 20px;
}

body.woocommerce-checkout .vv-checkout-register-type {
    margin: 12px 0 4px;
    display: none;
}

body.woocommerce-checkout .vv-checkout-register-type .vv-ca-account-type {
    margin-bottom: 0;
    padding: 14px 16px;
}

body.woocommerce-checkout .woocommerce-billing-fields .form-row.vv-checkout-business-only {
    transition: opacity 0.15s ease;
}
