/* ============================================================
   PingGalaxy - My Account Page CSS
   Sidebar navigation + dashboard layout with PingGalaxy design tokens
   ============================================================ */

/* === PAGE RESETS (my account page) === */
body.woocommerce-account {
    background-color: var(--pg-white);
}

body.woocommerce-account .entry-title,
body.woocommerce-account .entry-header {
    display: none;
}

body.woocommerce-account .entry-content {
    padding: 0;
    margin: 0;
}

/* Reset WooCommerce float-based my-account layout */
body.woocommerce-account .woocommerce-MyAccount-navigation,
body.woocommerce-account .woocommerce-MyAccount-content {
    float: none;
    width: auto;
    margin-right: 0;
    clear: none;
}

/* Hide default WooCommerce navigation (replaced by custom sidebar) */
body.woocommerce-account .woocommerce-MyAccount-navigation {
    display: none !important;
}

/* Reset WooCommerce default my-account content width */
body.woocommerce-account .woocommerce-MyAccount-content {
    padding: 0;
    margin: 0;
}


/* === PAGE LAYOUT === */
.pg-account-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 24px;
}

.pg-account-layout {
    display: flex;
    gap: 32px;
    align-items: flex-start;
}


/* === SIDEBAR NAVIGATION === */
.pg-account-sidebar {
    width: 260px;
    flex-shrink: 0;
}

.pg-account-nav {
    position: sticky;
    top: var(--pg-header-height);
    background: var(--pg-white);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    padding: 16px;
}

/* User info block */
.pg-account-user {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 16px;
    margin-bottom: 12px;
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-account-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
    flex-shrink: 0;
    text-transform: uppercase;
}

.pg-account-user-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.pg-account-user-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pg-account-user-email {
    font-size: 12px;
    color: var(--pg-grey-light);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Navigation list */
.pg-account-nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pg-account-nav-item a {
    display: flex;
    align-items: center;
    gap: 10px;
    height: 44px;
    padding: 0 12px;
    border-radius: 8px;
    color: var(--pg-grey);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}

.pg-account-nav-item a svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity 0.15s;
}

.pg-account-nav-item a:hover {
    background: var(--pg-light-grey);
    color: var(--pg-dark);
}

.pg-account-nav-item a:hover svg {
    opacity: 0.8;
}

/* Active navigation item */
.pg-account-nav-item.is-active a {
    background: var(--pg-galaxy-light-bg);
    color: var(--pg-galaxy);
    font-weight: 600;
}

.pg-account-nav-item.is-active a svg {
    opacity: 1;
    color: var(--pg-galaxy);
}

/* Logout item with red color */
.pg-account-nav-item.is-logout a {
    color: var(--pg-error);
}

.pg-account-nav-item.is-logout a:hover {
    background: rgba(220, 38, 38, 0.05);
    color: var(--pg-error);
}

.pg-account-nav-item.is-logout a svg {
    color: var(--pg-error);
}


/* === MAIN CONTENT === */
.pg-account-content {
    flex: 1;
    min-width: 0;
}


/* === DASHBOARD === */
.pg-account-dashboard {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* Welcome section */
.pg-account-welcome {
    margin-bottom: 8px;
}

.pg-account-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0 0 8px;
}

.pg-account-subtitle {
    font-size: 15px;
    color: var(--pg-grey);
    margin: 0;
}

/* Onboarding notice for new users */
.pg-onboarding-notice {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--pg-galaxy-light-bg);
    border: 1px solid rgba(79, 70, 229, 0.15);
    border-radius: 8px;
    margin-bottom: 20px;
}

.pg-onboarding-notice > svg {
    flex-shrink: 0;
    color: var(--pg-galaxy);
}

.pg-onboarding-notice-content {
    flex: 1;
    min-width: 0;
}

.pg-onboarding-notice-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0 0 2px;
}

.pg-onboarding-notice-text {
    font-size: 13px;
    color: var(--pg-grey);
    margin: 0;
    line-height: 1.4;
}

.pg-onboarding-notice-btn {
    flex-shrink: 0;
    padding: 8px 20px;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    font-size: 13px;
    font-weight: 600;
    border-radius: 6px;
    text-decoration: none;
    transition: background 0.2s;
}

.pg-onboarding-notice-btn:hover {
    background: var(--pg-galaxy-hover);
    color: var(--pg-white);
}

/* Quick links (3-column grid) */
.pg-account-quick-links {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.pg-account-quick-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 20px;
    background: var(--pg-white);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s;
}

.pg-account-quick-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.pg-account-quick-card svg {
    width: 24px;
    height: 24px;
    color: var(--pg-galaxy);
}

.pg-account-quick-card-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-account-quick-card-desc {
    font-size: 13px;
    color: var(--pg-grey);
    line-height: 1.4;
}

/* Recent orders section */
.pg-account-recent {
    background: var(--pg-white);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    padding: 24px;
}

.pg-account-recent-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.pg-account-recent-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-account-recent-link {
    font-size: 14px;
    color: var(--pg-galaxy);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.15s;
}

.pg-account-recent-link:hover {
    color: var(--pg-galaxy-hover);
}

/* Order cards */
.pg-account-recent-orders {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pg-account-order-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    border: 1px solid var(--pg-border-light);
    border-radius: 8px;
    text-decoration: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.pg-account-order-card:hover {
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 1px var(--pg-galaxy-light);
}

.pg-account-order-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    min-width: 0;
}

.pg-account-order-number {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-account-order-date {
    font-size: 13px;
    color: var(--pg-grey-light);
}

.pg-account-order-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-shrink: 0;
}

.pg-account-order-total {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-account-order-arrow {
    width: 16px;
    height: 16px;
    color: var(--pg-grey-light);
    flex-shrink: 0;
}


/* === ORDER STATUS BADGES === */
.pg-account-order-status {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

/* Completed / Processing - green */
.pg-account-order-status-completed,
.pg-account-order-status-processing {
    background: var(--pg-stock-in-bg);
    color: var(--pg-stock-in-text);
}

/* On-hold / Pending - orange */
.pg-account-order-status-on-hold,
.pg-account-order-status-pending {
    background: var(--pg-status-pending-bg);
    color: var(--pg-status-pending-text);
}

/* Cancelled / Failed / Refunded - red */
.pg-account-order-status-cancelled,
.pg-account-order-status-failed,
.pg-account-order-status-refunded {
    background: var(--pg-stock-out-bg);
    color: var(--pg-stock-out-text);
}


/* === EMPTY STATE === */
.pg-account-empty {
    text-align: center;
    padding: 60px 24px;
    background: var(--pg-white);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.pg-account-empty svg {
    width: 64px;
    height: 64px;
    color: var(--pg-grey-light);
    margin-bottom: 20px;
}

.pg-account-empty-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0 0 8px;
}

.pg-account-empty-text {
    font-size: 14px;
    color: var(--pg-grey);
    margin: 0 0 24px;
}

.pg-account-empty-btn {
    display: inline-block;
    padding: 12px 32px;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    border-radius: 4px;
    transition: background 0.2s;
    border: none;
    cursor: pointer;
}

.pg-account-empty-btn:hover {
    background: var(--pg-galaxy-hover);
    color: var(--pg-white);
}


/* === LOGIN / REGISTER PAGE (not logged in) === */
.pg-login-page {
    min-height: calc(100vh - var(--pg-header-height) - 100px);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 60px 24px;
}

.pg-login-container {
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.pg-login-card {
    background: var(--pg-white);
    padding: 32px;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* Register toggle (details/summary) */
.pg-register-toggle {
    margin-top: 16px;
}

.pg-register-trigger {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 14px 16px;
    background: var(--pg-bg-light);
    border: 1px solid var(--pg-border-light);
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    color: var(--pg-grey);
    transition: background 0.2s, border-color 0.2s;
    list-style: none;
}

.pg-register-trigger::-webkit-details-marker {
    display: none;
}

.pg-register-trigger:hover {
    background: var(--pg-galaxy-light-bg);
    border-color: var(--pg-galaxy);
}

.pg-register-trigger-link {
    font-weight: 700;
    color: var(--pg-galaxy);
}

.pg-register-trigger-icon {
    width: 16px;
    height: 16px;
    color: var(--pg-galaxy);
    transition: transform 0.2s;
    flex-shrink: 0;
}

.pg-register-toggle[open] .pg-register-trigger {
    border-radius: 8px 8px 0 0;
    border-bottom-color: transparent;
    background: var(--pg-white);
}

.pg-register-toggle[open] .pg-register-trigger-icon {
    transform: rotate(180deg);
}

.pg-register-card {
    margin-top: 0;
    padding: 32px;
    border: 1px solid var(--pg-border-light);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    box-sizing: border-box;
}

.pg-login-card:first-child {
    border-radius: 8px 8px 0 0;
    box-shadow: 0 -1px 3px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.08);
}

.pg-login-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0 0 8px;
}

.pg-login-subtitle {
    font-size: 14px;
    color: var(--pg-grey);
    margin: 0 0 24px;
    line-height: 1.5;
}

/* Social login (Google button) — selectors use div.nsl-container to beat Nextend specificity */
.pg-social-login {
    margin-bottom: 0;
}

.pg-social-login div.nsl-container {
    margin: 0 !important;
    padding: 0 !important;
}

.pg-social-login div.nsl-container.nsl-container-block .nsl-container-buttons {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    padding: 0 !important;
}

.pg-social-login div.nsl-container .nsl-container-buttons a[data-plugin="nsl"] {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    text-decoration: none !important;
    border: none !important;
    box-shadow: none !important;
}

/* The visible button */
.pg-social-login div.nsl-container .nsl-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    width: 100% !important;
    min-height: 48px;
    padding: 12px 16px !important;
    border: 1.5px solid var(--pg-border-light) !important;
    border-radius: 6px !important;
    background: var(--pg-white) !important;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box !important;
}

.pg-social-login div.nsl-container .nsl-button:hover {
    border-color: var(--pg-border-dark) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1) !important;
}

/* Google logo — override Nextend padding: 8px that shrinks the icon */
.pg-social-login div.nsl-container .nsl-button-svg-container {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 24px !important;
    padding: 0 !important;
    width: 24px !important;
    height: 24px !important;
    overflow: visible !important;
}

.pg-social-login div.nsl-container svg {
    width: 24px !important;
    height: 24px !important;
    display: block !important;
}

/* Button label — override Nextend font-family and margins */
.pg-social-login div.nsl-container .nsl-button-default div.nsl-button-label-container {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: var(--pg-dark) !important;
    font-family: inherit !important;
    line-height: 1.2 !important;
    letter-spacing: normal !important;
    flex: 0 1 auto !important;
}

.pg-social-login .nsl-button-label-container b {
    font-weight: 700 !important;
}

/* Hide Nextend default separator if any */
.pg-social-login .nsl-container-login-separator,
.pg-social-login .nsl-separator {
    display: none !important;
}

/* Custom "ou" separator */
.pg-login-separator {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 20px 0;
}

.pg-login-separator::before,
.pg-login-separator::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--pg-border-light);
}

.pg-login-separator span {
    font-size: 13px;
    color: var(--pg-grey-light);
    font-weight: 500;
    text-transform: lowercase;
}

.pg-register-card .pg-login-title {
    font-size: 20px;
}

/* Login/Register form fields */
.pg-login-card .form-row {
    margin-bottom: 16px;
    padding: 0;
}

.pg-login-card .form-row:last-of-type {
    margin-bottom: 20px;
}

.pg-login-card label {
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-dark);
    display: block;
    margin-bottom: 6px;
}

.pg-login-card label .required {
    color: var(--pg-error);
    text-decoration: none;
}

.pg-login-card input[type="text"],
.pg-login-card input[type="email"],
.pg-login-card input[type="password"] {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--pg-border-light);
    border-radius: 4px;
    font-size: 14px;
    color: var(--pg-dark);
    background: var(--pg-white);
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    font-family: inherit;
}

.pg-login-card input[type="text"]:focus,
.pg-login-card input[type="email"]:focus,
.pg-login-card input[type="password"]:focus {
    outline: none;
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 3px var(--pg-galaxy-light);
}

/* Hide WooCommerce "show password" toggle (injected via JS, appears as blue square) */
.pg-login-card .show-password-input,
.woocommerce-account .show-password-input {
    display: none !important;
}

/* Forgot password link below password field */
.pg-login-forgot-wrapper {
    text-align: right;
    margin: 8px 0 4px;
}

.pg-login-forgot {
    font-size: 13px;
    color: var(--pg-galaxy);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s;
}

.pg-login-forgot:hover {
    color: var(--pg-galaxy-hover);
    text-decoration: underline;
}

.pg-login-auto-password {
    font-size: 13px;
    color: var(--pg-grey);
    margin: 0 0 16px;
    padding: 10px 14px;
    background: var(--pg-bg-light);
    border-radius: 6px;
    line-height: 1.5;
}

/* Login/Register buttons */
.pg-login-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    font-size: 16px;
    font-weight: 700;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    transition: background 0.2s;
    box-sizing: border-box;
}

.pg-login-btn:hover {
    background: var(--pg-galaxy-hover);
}

.pg-register-btn {
    background: var(--pg-dark);
}

.pg-register-btn:hover {
    background: var(--pg-text);
}

/* WooCommerce privacy policy text in register form */
.pg-register-card .woocommerce-privacy-policy-text {
    font-size: 12px;
    color: var(--pg-grey);
    line-height: 1.6;
    margin: 0 0 16px;
}

.pg-register-card .woocommerce-privacy-policy-text p {
    margin: 0;
}

.pg-register-card .woocommerce-privacy-policy-text a {
    color: var(--pg-galaxy);
    text-decoration: underline;
}

/* Register card internal spacing */
.pg-register-card .pg-login-field {
    margin-bottom: 16px;
}

.pg-register-card form {
    margin: 0;
    padding: 0;
}

/* Lost password page */
.pg-lost-password-header {
    text-align: center;
    margin-bottom: 24px;
}

.pg-lost-password-header svg {
    margin: 0 auto 16px;
    display: block;
}

.pg-lost-password-header .pg-login-title {
    text-align: center;
}

.pg-lost-password-header .pg-login-subtitle {
    text-align: center;
}

.pg-lost-password-info {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 16px;
    background: var(--pg-bg-light);
    border-radius: 6px;
    font-size: 13px;
    color: var(--pg-grey);
    line-height: 1.5;
    margin-bottom: 20px;
}

.pg-lost-password-info svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--pg-grey-light);
}

.pg-lost-password-back {
    text-align: center;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--pg-border-light);
}

.pg-lost-password-back a {
    font-size: 14px;
    color: var(--pg-galaxy);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s;
}

.pg-lost-password-back a:hover {
    color: var(--pg-galaxy-hover);
    text-decoration: underline;
}

/* Password tips box */
.pg-password-tips {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 16px;
    background: var(--pg-bg-light);
    border-radius: 6px;
    margin-bottom: 24px;
}

.pg-password-tips svg {
    flex-shrink: 0;
    margin-top: 1px;
    color: var(--pg-grey-light);
}

.pg-password-tips p {
    font-size: 13px;
    color: var(--pg-grey);
    margin: 0;
    line-height: 1.5;
}

/* WooCommerce form messages on login page */
.pg-login-card .woocommerce-error,
.pg-login-card .woocommerce-message,
.pg-login-card .woocommerce-info {
    list-style: none;
    padding: 12px 16px;
    border-radius: 4px;
    margin: 0 0 16px;
    font-size: 14px;
}

.pg-login-card .woocommerce-error {
    background: var(--pg-stock-out-bg);
    border-left: 3px solid var(--pg-error);
    color: var(--pg-error);
}

.pg-login-card .woocommerce-message {
    background: var(--pg-stock-in-bg);
    border-left: 3px solid var(--pg-success);
    color: var(--pg-dark);
}

.pg-login-card .woocommerce-info {
    background: var(--pg-galaxy-light-bg);
    border-left: 3px solid var(--pg-galaxy);
    color: var(--pg-dark);
}

/* Password reset link on login page */
.pg-login-card .woocommerce-LostPassword {
    margin-top: 16px;
    text-align: center;
}

.pg-login-card .woocommerce-LostPassword a {
    color: var(--pg-galaxy);
    text-decoration: none;
    font-size: 13px;
}

.pg-login-card .woocommerce-LostPassword a:hover {
    text-decoration: underline;
}


/* === WOOCOMMERCE DEFAULT PAGES (CSS-only overrides) === */

/* --- Orders page (card layout) --- */
.pg-orders {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.pg-orders-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.pg-orders-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-orders-count {
    font-size: 13px;
    color: var(--pg-grey-medium);
    background: var(--pg-bg-light);
    padding: 4px 12px;
    border-radius: 12px;
    font-weight: 500;
}

.pg-orders-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Order card */
.pg-orders-card {
    display: block;
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 20px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
}

.pg-orders-card:hover {
    border-color: var(--pg-galaxy);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}

/* Card top: order info + status */
.pg-orders-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.pg-orders-card-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pg-orders-card-number {
    font-size: 15px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-orders-card:hover .pg-orders-card-number {
    color: var(--pg-galaxy);
}

.pg-orders-card-date {
    font-size: 13px;
    color: var(--pg-grey-medium);
}

/* Status badge */
.pg-orders-card-status {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    flex-shrink: 0;
}

.pg-orders-status--processing {
    background: var(--pg-info-light, #DBEAFE);
    color: var(--pg-info, #1D4ED8);
}

.pg-orders-status--completed {
    background: var(--pg-stock-in-bg);
    color: var(--pg-stock-in-text);
}

.pg-orders-status--on-hold {
    background: var(--pg-status-pending-bg);
    color: var(--pg-status-pending-text);
}

.pg-orders-status--pending {
    background: var(--pg-status-pending-bg);
    color: var(--pg-status-pending-text);
}

.pg-orders-status--cancelled,
.pg-orders-status--failed {
    background: var(--pg-stock-out-bg);
    color: var(--pg-stock-out-text);
}

.pg-orders-status--refunded {
    background: var(--pg-light-grey);
    color: var(--pg-grey-medium);
}

/* Card items (product thumbnails) */
.pg-orders-card-items {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-orders-card-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--pg-bg-light);
    padding: 6px 10px 6px 6px;
    border-radius: 6px;
    max-width: 220px;
}

.pg-orders-card-thumb {
    width: 36px;
    height: 36px;
    border-radius: 4px;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--pg-border-light);
}

.pg-orders-card-thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pg-border-light);
    color: var(--pg-grey-light);
}

.pg-orders-card-item-name {
    font-size: 13px;
    color: var(--pg-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.3;
}

.pg-orders-card-qty {
    color: var(--pg-grey-medium);
    font-size: 12px;
}

.pg-orders-card-more {
    display: flex;
    align-items: center;
    font-size: 12px;
    color: var(--pg-grey-medium);
    padding: 6px 10px;
    background: var(--pg-bg-light);
    border-radius: 6px;
}

/* Card bottom: total + action */
.pg-orders-card-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.pg-orders-card-summary {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.pg-orders-card-total {
    font-size: 16px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-orders-card-items-count {
    font-size: 13px;
    color: var(--pg-grey-medium);
}

.pg-orders-card-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-galaxy);
    transition: gap 0.2s;
}

.pg-orders-card:hover .pg-orders-card-action {
    gap: 8px;
}

/* Pagination */
.pg-orders-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 8px;
}

.pg-orders-pagination-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-galaxy);
    background: none;
    border: 1px solid var(--pg-border-light);
    border-radius: 6px;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
}

.pg-orders-pagination-btn:hover {
    background: var(--pg-galaxy-light);
    border-color: var(--pg-galaxy);
}

.pg-orders-pagination-pages {
    display: flex;
    gap: 4px;
}

.pg-orders-pagination-page {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    color: var(--pg-grey);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.pg-orders-pagination-page:hover {
    background: var(--pg-bg-light);
    color: var(--pg-dark);
}

.pg-orders-pagination-page--current {
    background: var(--pg-galaxy);
    color: var(--pg-white);
}

/* --- View order page (custom) --- */
.pg-view-order {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pg-view-order-back {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-galaxy);
    text-decoration: none;
    transition: gap 0.2s;
}

.pg-view-order-back:hover {
    gap: 8px;
}

.pg-view-order-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 20px 24px;
}

.pg-view-order-header-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pg-view-order-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-view-order-date {
    font-size: 13px;
    color: var(--pg-grey-medium);
}

/* Section cards */
.pg-view-order-section {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 24px;
}

.pg-view-order-section-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--pg-border-light);
}

/* Product items */
.pg-view-order-items {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.pg-view-order-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-view-order-item:last-child {
    border-bottom: none;
}

.pg-view-order-item-thumb {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--pg-border-light);
}

.pg-view-order-item-thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pg-bg-light);
    color: var(--pg-grey-light);
}

.pg-view-order-item-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pg-view-order-item-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--pg-dark);
    text-decoration: none;
}

a.pg-view-order-item-name:hover {
    color: var(--pg-galaxy);
}

.pg-view-order-item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
}

.pg-view-order-item-meta-item {
    font-size: 12px;
    color: var(--pg-grey-medium);
}

.pg-view-order-item-qty {
    font-size: 13px;
    color: var(--pg-grey-medium);
}

.pg-view-order-item-price {
    font-size: 14px;
    font-weight: 700;
    color: var(--pg-dark);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Totals */
.pg-view-order-totals {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--pg-border-light);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pg-view-order-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    color: var(--pg-grey);
}

.pg-view-order-total-row--grand {
    padding-top: 10px;
    margin-top: 4px;
    border-top: 2px solid var(--pg-dark);
    font-size: 16px;
    font-weight: 700;
    color: var(--pg-dark);
}

.pg-view-order-total-label {
    font-weight: 500;
}

.pg-view-order-total-row--grand .pg-view-order-total-value {
    font-size: 18px;
}

/* Addresses */
.pg-view-order-addresses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.pg-view-order-address-card {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 20px;
}

.pg-view-order-address-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-view-order-address-header svg {
    color: var(--pg-galaxy);
    flex-shrink: 0;
}

.pg-view-order-address-header h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-view-order-address-card address {
    font-size: 14px;
    color: var(--pg-grey);
    line-height: 1.7;
    font-style: normal;
}

.pg-view-order-address-phone,
.pg-view-order-address-email {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--pg-grey-medium);
    margin: 8px 0 0;
}

.pg-view-order-address-phone svg,
.pg-view-order-address-email svg {
    color: var(--pg-grey-light);
    flex-shrink: 0;
}

/* Timeline */
.pg-view-order-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
    padding-left: 24px;
}

.pg-view-order-timeline::before {
    content: '';
    position: absolute;
    left: 5px;
    top: 8px;
    bottom: 8px;
    width: 2px;
    background: var(--pg-border-light);
}

.pg-view-order-timeline-item {
    position: relative;
    padding: 8px 0;
}

.pg-view-order-timeline-dot {
    position: absolute;
    left: -24px;
    top: 14px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--pg-white);
    border: 2px solid var(--pg-galaxy);
}

.pg-view-order-timeline-item:first-child .pg-view-order-timeline-dot {
    background: var(--pg-galaxy);
}

.pg-view-order-timeline-date {
    font-size: 12px;
    color: var(--pg-grey-medium);
    font-weight: 500;
}

.pg-view-order-timeline-text {
    font-size: 14px;
    color: var(--pg-dark);
    line-height: 1.5;
    margin-top: 2px;
}

.pg-view-order-timeline-text p {
    margin: 0;
}


/* --- My Addresses page (custom) --- */
.pg-addresses {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pg-addresses-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-addresses-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.pg-addresses-card {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 20px;
}

.pg-addresses-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-addresses-card-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.pg-addresses-card-title svg {
    color: var(--pg-galaxy);
    flex-shrink: 0;
}

.pg-addresses-card-title h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-addresses-card-edit {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-galaxy);
    text-decoration: none;
    transition: color 0.15s;
}

.pg-addresses-card-edit:hover {
    color: var(--pg-galaxy-hover);
}

.pg-addresses-card-address {
    font-size: 14px;
    color: var(--pg-grey);
    line-height: 1.7;
    font-style: normal;
}

.pg-addresses-card-empty {
    text-align: center;
    padding: 20px 0;
}

.pg-addresses-card-empty p {
    font-size: 14px;
    color: var(--pg-grey-light);
    margin: 0 0 12px;
}

.pg-addresses-card-add-btn {
    display: inline-block;
    padding: 8px 20px;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    font-size: 13px;
    font-weight: 600;
    border-radius: 6px;
    text-decoration: none;
    transition: background 0.2s;
}

.pg-addresses-card-add-btn:hover {
    background: var(--pg-galaxy-hover);
    color: var(--pg-white);
}


/* --- Edit Account page (custom) --- */
.pg-edit-account {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pg-edit-account-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-edit-account-card {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    overflow: hidden;
}

.pg-edit-account-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 24px;
    background: var(--pg-bg-light);
    border-bottom: 1px solid var(--pg-border-light);
}

.pg-edit-account-card-header svg {
    color: var(--pg-galaxy);
    flex-shrink: 0;
}

.pg-edit-account-card-header h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-edit-account-card-body {
    padding: 24px;
}

.pg-edit-account-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.pg-edit-account-field {
    margin-bottom: 16px;
}

.pg-edit-account-field:last-child {
    margin-bottom: 0;
}

.pg-edit-account-field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-dark);
    margin-bottom: 6px;
}

.pg-edit-account-required {
    color: var(--pg-error);
}

.pg-edit-account-field input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--pg-border-dark);
    border-radius: 6px;
    font-size: 14px;
    color: var(--pg-dark);
    background: var(--pg-white);
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    font-family: inherit;
}

.pg-edit-account-field input:focus {
    outline: none;
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 3px var(--pg-galaxy-shadow);
}

.pg-edit-account-hint {
    display: block;
    font-size: 12px;
    color: var(--pg-grey-light);
    margin-top: 4px;
}

.pg-edit-account-readonly {
    background: var(--pg-bg-light) !important;
    color: var(--pg-grey) !important;
    cursor: not-allowed;
    border-color: var(--pg-border-light) !important;
}

.pg-edit-account-password-hint {
    font-size: 13px;
    color: var(--pg-grey-medium);
    margin: 0 0 16px;
    padding: 10px 14px;
    background: var(--pg-bg-light);
    border-radius: 6px;
}

.pg-edit-account-submit {
    margin-top: 4px;
}

.pg-edit-account-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 32px;
    font-size: 15px;
    font-weight: 600;
    color: var(--pg-white);
    background: var(--pg-galaxy);
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s;
    font-family: inherit;
}

.pg-edit-account-btn:hover {
    background: var(--pg-galaxy-hover);
}


/* --- Payment Methods page (custom) --- */
.pg-payment-methods {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.pg-payment-methods-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.pg-payment-methods-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-payment-methods-count {
    font-size: 13px;
    color: var(--pg-grey-medium);
    background: var(--pg-bg-light);
    padding: 4px 12px;
    border-radius: 12px;
    font-weight: 500;
}

.pg-payment-methods-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Payment card */
.pg-payment-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 18px 20px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.pg-payment-card:hover {
    border-color: var(--pg-border-medium, #d0d0d0);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.pg-payment-card--default {
    border-color: var(--pg-galaxy);
    background: var(--pg-galaxy-light-bg, #f5f3ff);
}

.pg-payment-card-left {
    display: flex;
    align-items: center;
    gap: 16px;
    min-width: 0;
}

.pg-payment-card-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 32px;
    color: var(--pg-grey-medium);
}

.pg-payment-card-icon svg {
    display: block;
}

.pg-payment-card-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.pg-payment-card-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--pg-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pg-payment-card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--pg-grey-medium);
}

.pg-payment-card-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    color: var(--pg-galaxy);
    background: var(--pg-galaxy-light, rgba(79, 70, 229, 0.1));
    border-radius: 100px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.pg-payment-card-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.pg-payment-card-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-grey);
    background: none;
    border: 1px solid var(--pg-border-light);
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s;
}

.pg-payment-card-btn:hover {
    background: var(--pg-bg-light);
    border-color: var(--pg-border-medium, #d0d0d0);
    color: var(--pg-dark);
}

.pg-payment-card-btn--delete:hover {
    background: var(--pg-stock-out-bg, #fef2f2);
    border-color: var(--pg-error, #ef4444);
    color: var(--pg-error, #ef4444);
}

/* Add payment method button */
.pg-payment-methods-footer {
    margin-top: 8px;
}

.pg-payment-methods-add-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
    color: var(--pg-galaxy);
    background: none;
    border: 1.5px solid var(--pg-galaxy);
    border-radius: 100px;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s;
}

.pg-payment-methods-add-btn:hover {
    background: var(--pg-galaxy);
    color: var(--pg-white);
}

.pg-payment-methods-add-btn svg {
    transition: transform 0.15s;
}

.pg-payment-methods-add-btn:hover svg {
    transform: rotate(90deg);
}


/* --- Mes demandes / Contact Requests page (custom) --- */
.pg-requests {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.pg-requests-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.pg-requests-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pg-dark);
    margin: 0;
}

.pg-requests-count {
    font-size: 13px;
    color: var(--pg-grey-medium);
    background: var(--pg-bg-light);
    padding: 4px 12px;
    border-radius: 12px;
    font-weight: 500;
}

.pg-requests-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Request card */
.pg-request-card {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.pg-request-card:hover {
    border-color: var(--pg-border-medium, #d0d0d0);
}

.pg-request-card--open {
    border-color: var(--pg-galaxy);
    box-shadow: 0 4px 20px rgba(79, 70, 229, 0.08);
}

/* Card header (clickable) */
.pg-request-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
    padding: 18px 20px;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
    transition: background 0.15s;
}

.pg-request-card-header:hover {
    background: var(--pg-bg-light, #fafafa);
}

.pg-request-card-header:focus,
.pg-request-card-header:focus-visible,
.pg-request-card-header:active {
    outline: none;
    background: none;
    box-shadow: none;
    -webkit-tap-highlight-color: transparent;
}

.pg-request-card-header:focus-visible {
    outline: 2px solid var(--pg-galaxy);
    outline-offset: -2px;
    border-radius: 10px;
}

.pg-request-card-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    flex: 1;
}

.pg-request-card-subject {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 600;
    color: var(--pg-dark);
}

.pg-request-card--open .pg-request-card-subject {
    color: var(--pg-galaxy);
}

.pg-request-card-replies {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    font-size: 11px;
    font-weight: 700;
    color: var(--pg-white);
    background: var(--pg-galaxy);
    border-radius: 100px;
}

.pg-request-card-preview {
    font-size: 13px;
    color: var(--pg-grey-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.4;
}

.pg-request-card--open .pg-request-card-preview {
    display: none;
}

.pg-request-card-date {
    font-size: 12px;
    color: var(--pg-grey, #999);
    margin-top: 2px;
}

.pg-request-card-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

/* Status badges */
.pg-request-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    font-size: 12px;
    font-weight: 600;
    border-radius: 100px;
    white-space: nowrap;
}

.pg-request-badge--new {
    background: var(--pg-status-pending-bg);
    color: var(--pg-status-pending-text);
}

.pg-request-badge--replied {
    background: var(--pg-stock-in-bg, #ecfdf5);
    color: var(--pg-success, #059669);
}

.pg-request-badge--closed {
    background: var(--pg-bg-light, #f5f5f5);
    color: var(--pg-grey-medium, #888);
}

/* Chevron animation */
.pg-request-card-chevron {
    color: var(--pg-grey, #999);
    transition: transform 0.25s ease, color 0.2s;
    flex-shrink: 0;
}

.pg-request-card--open .pg-request-card-chevron {
    transform: rotate(180deg);
    color: var(--pg-galaxy);
}

/* Conversation thread */
.pg-request-thread {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
}

.pg-request-thread-inner {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 20px 24px;
    border-top: 1px solid var(--pg-border-light, #f0f0f0);
}

/* Message bubble */
.pg-request-bubble {
    padding: 20px 0;
    border-bottom: 1px solid var(--pg-border-light, #f0f0f0);
}

.pg-request-bubble:last-child,
.pg-request-bubble:last-of-type {
    border-bottom: none;
}

.pg-request-bubble-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.pg-request-bubble-avatar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 13px;
    font-weight: 700;
}

.pg-request-bubble-avatar--user {
    background: var(--pg-galaxy-light, rgba(79, 70, 229, 0.1));
    color: var(--pg-galaxy);
}

.pg-request-bubble-avatar--admin {
    background: var(--pg-dark, #1a1a1a);
    color: var(--pg-white);
}

.pg-request-bubble-meta {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.pg-request-bubble-author {
    font-size: 14px;
    font-weight: 600;
    color: var(--pg-dark);
}

.pg-request-bubble-date {
    font-size: 12px;
    color: var(--pg-grey, #999);
}

.pg-request-bubble-content {
    font-size: 14px;
    line-height: 1.65;
    color: var(--pg-text, #333);
    padding-left: 42px;
}

/* Pending note */
.pg-request-pending-note {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    margin-top: 16px;
    background: var(--pg-status-pending-bg);
    border-radius: 8px;
    font-size: 13px;
    color: var(--pg-status-pending-text);
    line-height: 1.4;
}

.pg-request-pending-note svg {
    flex-shrink: 0;
    color: var(--pg-status-pending-text);
}

/* New request button */
.pg-requests-footer {
    margin-top: 8px;
}

.pg-requests-new-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
    color: var(--pg-galaxy);
    background: none;
    border: 1.5px solid var(--pg-galaxy);
    border-radius: 100px;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s;
}

.pg-requests-new-btn:hover {
    background: var(--pg-galaxy);
    color: var(--pg-white);
}

.pg-requests-new-btn svg {
    transition: transform 0.15s;
}

.pg-requests-new-btn:hover svg {
    transform: rotate(90deg);
}


/* --- Edit address page (form) --- */
.woocommerce-account .woocommerce-address-fields {
    background: var(--pg-white);
    border: 1px solid var(--pg-border-light);
    border-radius: 10px;
    padding: 24px;
}

.woocommerce-account .woocommerce-address-fields .form-row {
    margin-bottom: 16px;
    padding: 0;
}

.woocommerce-account .woocommerce-address-fields label {
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-dark);
    display: block;
    margin-bottom: 6px;
}

.woocommerce-account .woocommerce-address-fields label .required {
    color: var(--pg-error);
    text-decoration: none;
}

.woocommerce-account .woocommerce-address-fields input[type="text"],
.woocommerce-account .woocommerce-address-fields input[type="email"],
.woocommerce-account .woocommerce-address-fields input[type="tel"],
.woocommerce-account .woocommerce-address-fields select,
.woocommerce-account .woocommerce-address-fields textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--pg-border-dark);
    border-radius: 6px;
    font-size: 14px;
    color: var(--pg-dark);
    background: var(--pg-white);
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    font-family: inherit;
}

.woocommerce-account .woocommerce-address-fields input:focus,
.woocommerce-account .woocommerce-address-fields select:focus,
.woocommerce-account .woocommerce-address-fields textarea:focus {
    outline: none;
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 3px var(--pg-galaxy-shadow);
}

.woocommerce-account .woocommerce-address-fields .button {
    display: inline-block;
    padding: 14px 32px;
    background: var(--pg-galaxy);
    color: var(--pg-white);
    font-size: 15px;
    font-weight: 700;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    transition: background 0.2s;
    margin-top: 8px;
}

.woocommerce-account .woocommerce-address-fields .button:hover {
    background: var(--pg-galaxy-hover);
}

/* Select2 overrides for address page */
.woocommerce-account .woocommerce-address-fields .select2-container .select2-selection--single {
    height: auto;
    padding: 10px 12px;
    border: 1px solid var(--pg-border-light);
    border-radius: 4px;
    background: var(--pg-white);
}

.woocommerce-account .woocommerce-address-fields .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--pg-dark);
    font-size: 14px;
    line-height: normal;
    padding: 0;
}

.woocommerce-account .woocommerce-address-fields .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100%;
    right: 8px;
}

.woocommerce-account .woocommerce-address-fields .select2-container--open .select2-selection--single,
.woocommerce-account .woocommerce-address-fields .select2-container--focus .select2-selection--single {
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 3px var(--pg-galaxy-light);
}

/* --- General WooCommerce form-row styling for account pages --- */
.woocommerce-account .woocommerce-form-row,
.woocommerce-account .woocommerce .form-row {
    padding: 0;
}

/* WooCommerce notices on account pages */
.woocommerce-account .woocommerce-error,
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info {
    list-style: none;
    padding: 12px 16px;
    border-radius: 4px;
    margin: 0 0 20px;
    font-size: 14px;
}

.woocommerce-account .woocommerce-error {
    background: var(--pg-stock-out-bg);
    border-left: 3px solid var(--pg-error);
    color: var(--pg-error);
}

.woocommerce-account .woocommerce-message {
    background: var(--pg-stock-in-bg);
    border-left: 3px solid var(--pg-success);
    color: var(--pg-dark);
}

.woocommerce-account .woocommerce-info {
    background: var(--pg-galaxy-light-bg);
    border-left: 3px solid var(--pg-galaxy);
    color: var(--pg-dark);
}

/* Hide "Browse products" button in empty orders/downloads notices */
.woocommerce-account .woocommerce-info .woocommerce-Button,
.woocommerce-account .woocommerce-info .button,
.woocommerce-account .woocommerce-info .wc-forward,
.woocommerce-account .woocommerce-Message .woocommerce-Button,
.woocommerce-account .woocommerce-Message .button,
.woocommerce-account .woocommerce-message .button,
.woocommerce-account .woocommerce-message .wc-forward {
    display: none !important;
}

.woocommerce-account .woocommerce-error a,
.woocommerce-account .woocommerce-message a,
.woocommerce-account .woocommerce-info a {
    color: var(--pg-galaxy);
    font-weight: 600;
}

/* Old WooCommerce pagination (kept as fallback) */
.woocommerce-account .woocommerce-pagination {
    display: none;
}

/* === Lost / Reset Password Forms === */
.woocommerce-account .woocommerce-ResetPassword {
    max-width: 480px;
    margin: 0 auto;
    background: var(--pg-white);
    border-radius: 16px;
    padding: 40px 36px;
    border: 1px solid var(--pg-border-light, #f0f0f0);
}

.woocommerce-account .woocommerce-ResetPassword > p:first-child {
    font-size: 14px;
    color: var(--pg-text-light, #666);
    line-height: 1.6;
    margin: 0 0 24px;
}

.woocommerce-account .woocommerce-ResetPassword .woocommerce-form-row {
    margin: 0 0 16px;
}

.woocommerce-account .woocommerce-ResetPassword label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--pg-dark, #1a1a1a);
    margin-bottom: 6px;
}

.woocommerce-account .woocommerce-ResetPassword .woocommerce-Input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--pg-border-light, #e0e0e0);
    border-radius: 10px;
    font-size: 14px;
    background: var(--pg-bg-light, #fafafa);
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
}

.woocommerce-account .woocommerce-ResetPassword .woocommerce-Input:focus {
    outline: none;
    border-color: var(--pg-galaxy);
    box-shadow: 0 0 0 3px var(--pg-galaxy-light);
    background: var(--pg-white);
}

.woocommerce-account .woocommerce-ResetPassword .woocommerce-Button {
    display: block;
    width: 100%;
    padding: 14px;
    border: none;
    border-radius: 100px;
    background: var(--pg-galaxy, #4f46e5);
    color: var(--pg-white);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    margin-top: 24px;
}

.woocommerce-account .woocommerce-ResetPassword .woocommerce-Button:hover {
    background: var(--pg-galaxy-dark, #3730a3);
}

/* === RESPONSIVE TABLET (768px) === */
@media (max-width: 768px) {
    /* Stack layout: sidebar above content */
    .pg-account-layout {
        flex-direction: column;
    }

    .pg-account-sidebar {
        width: 100%;
    }

    .pg-account-nav {
        position: static;
    }

    /* Horizontal nav on tablet */
    .pg-account-nav-list {
        flex-direction: row;
        gap: 4px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
    }

    .pg-account-nav-list::-webkit-scrollbar {
        display: none;
    }

    .pg-account-nav-item {
        flex-shrink: 0;
    }

    .pg-account-nav-item a {
        white-space: nowrap;
        padding: 0 14px;
        height: 40px;
        font-size: 13px;
    }

    .pg-account-nav-item a span {
        display: inline;
    }

    .pg-account-page {
        padding: 24px 16px;
    }

    /* Quick links 2 columns */
    .pg-account-quick-links {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Orders cards responsive */
    .pg-orders-card {
        padding: 16px;
    }

    .pg-orders-card-item {
        max-width: 180px;
    }

    /* View order responsive */
    .pg-view-order-header {
        flex-direction: column;
        gap: 10px;
    }

    .pg-view-order-addresses {
        grid-template-columns: 1fr;
    }

    /* Addresses responsive */
    .pg-addresses-grid {
        grid-template-columns: 1fr;
    }

    /* Edit account responsive */
    .pg-edit-account-row {
        grid-template-columns: 1fr;
    }

    /* Address columns stack */
    .woocommerce-account .woocommerce-columns--addresses,
    .woocommerce-account .woocommerce-Addresses {
        flex-direction: column;
    }

    /* Order card layout */
    .pg-account-order-card {
        flex-wrap: wrap;
        gap: 12px;
    }

    .pg-account-order-meta {
        gap: 12px;
    }

    /* Payment methods responsive tablet */
    .pg-payment-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .pg-payment-card-actions {
        width: 100%;
        justify-content: flex-end;
    }

    /* Requests responsive tablet */
    .pg-request-card-header {
        padding: 14px 16px;
    }

    .pg-request-card-preview {
        display: none;
    }

    .pg-request-thread-inner {
        padding: 0 16px 20px;
    }

    .pg-request-bubble-content {
        padding-left: 0;
        margin-top: 8px;
    }
}


/* === RESPONSIVE MOBILE (480px) === */
@media (max-width: 480px) {
    .pg-account-page {
        padding: 16px 12px;
    }

    .pg-account-title {
        font-size: 20px;
    }

    .pg-account-subtitle {
        font-size: 14px;
    }

    /* Onboarding notice stacks on mobile */
    .pg-onboarding-notice {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
        padding: 14px 16px;
    }

    .pg-onboarding-notice > svg {
        display: none;
    }

    .pg-onboarding-notice-btn {
        width: 100%;
        text-align: center;
    }

    /* Quick links single column */
    .pg-account-quick-links {
        grid-template-columns: 1fr;
    }

    .pg-account-quick-card {
        padding: 16px;
    }

    /* Recent orders section */
    .pg-account-recent {
        padding: 20px;
    }

    .pg-account-recent-title {
        font-size: 16px;
    }

    .pg-account-order-card {
        padding: 12px;
    }

    .pg-account-order-number {
        font-size: 13px;
    }

    .pg-account-order-date {
        font-size: 12px;
    }

    .pg-account-order-total {
        font-size: 13px;
    }

    /* Empty state */
    .pg-account-empty {
        padding: 40px 16px;
    }

    .pg-account-empty svg {
        width: 48px;
        height: 48px;
    }

    .pg-account-empty-title {
        font-size: 16px;
    }

    /* Requests responsive mobile */
    .pg-request-card-header {
        padding: 12px 14px;
        gap: 10px;
    }

    .pg-request-card-subject {
        font-size: 14px;
    }

    .pg-request-card-right {
        flex-direction: column-reverse;
        align-items: flex-end;
        gap: 6px;
    }

    .pg-request-badge {
        font-size: 11px;
        padding: 3px 10px;
    }

    .pg-request-thread-inner {
        padding: 0 14px 16px;
    }

    .pg-request-bubble {
        padding: 14px 0;
    }

    .pg-request-bubble-avatar {
        width: 28px;
        height: 28px;
        font-size: 11px;
    }

    .pg-request-bubble-content {
        font-size: 13px;
        padding-left: 0;
        margin-top: 8px;
    }

    .pg-request-pending-note {
        font-size: 12px;
        padding: 10px 12px;
    }

    /* Login page full width */
    .pg-login-page {
        padding: 24px 12px;
    }

    .pg-login-card {
        padding: 24px 16px;
    }

    .pg-login-title {
        font-size: 20px;
    }

    .pg-login-btn {
        font-size: 15px;
        padding: 12px;
    }

    /* Social login mobile */
    .pg-social-login div.nsl-container .nsl-button {
        min-height: 44px;
        padding: 10px 12px !important;
    }

    .pg-social-login div.nsl-container .nsl-button-default div.nsl-button-label-container {
        font-size: 14px !important;
    }

    /* Sidebar nav smaller on mobile */
    .pg-account-nav {
        padding: 12px;
    }

    .pg-account-user {
        padding-bottom: 12px;
        margin-bottom: 8px;
    }

    .pg-account-avatar {
        width: 36px;
        height: 36px;
        font-size: 14px;
    }

    .pg-account-nav-item a {
        height: 36px;
        font-size: 12px;
        padding: 0 10px;
    }

    .pg-account-nav-item a svg {
        width: 16px;
        height: 16px;
    }

    /* Orders cards mobile */
    .pg-orders-card {
        padding: 14px;
    }

    .pg-orders-card-top {
        flex-direction: column;
        gap: 8px;
    }

    .pg-orders-card-item {
        max-width: 100%;
    }

    .pg-orders-card-items {
        flex-direction: column;
        gap: 6px;
    }

    .pg-orders-card-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .pg-orders-card-action {
        align-self: flex-end;
    }

    .pg-orders-title {
        font-size: 18px;
    }

    .pg-orders-pagination {
        flex-wrap: wrap;
    }

    /* View order mobile */
    .pg-view-order-section {
        padding: 16px;
    }

    .pg-view-order-item-thumb {
        width: 44px;
        height: 44px;
    }

    .pg-view-order-address-card {
        padding: 16px;
    }

    .pg-view-order-title {
        font-size: 18px;
    }

    /* Addresses mobile */
    .pg-addresses-card {
        padding: 16px;
    }

    .pg-addresses-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    /* Edit account mobile */
    .pg-edit-account-card-body {
        padding: 16px;
    }

    .pg-edit-account-card-header {
        padding: 12px 16px;
    }

    .pg-edit-account-btn {
        width: 100%;
    }

    /* Edit address forms mobile */
    .woocommerce-account .woocommerce-address-fields {
        padding: 16px;
    }

    .woocommerce-account .woocommerce-address-fields .button {
        width: 100%;
        text-align: center;
    }
}
