:root {
    /* Primary Colors */
    --common-purple: #602da5;
    --common-orange: #faa52d;
    --common-dark-gray: #282e3c;
    --common-light-gray: #d2d2e6;
    --common-teal: #47c0a5;
    --common-lavender: #b29ad6;
    --common-peach: #ffc573;
    --common-gray: #7f7f7f;
    --common-off-white: #f4f4f8;
    --common-mint: #91d9c9;

    /* Component Colors */
    --common-input-active: #007bff;

    /* Shades of Dark Gray */
    --common-dark-gray-dark: #202531;
    --common-dark-gray-medium: #3c4755;
    --common-dark-gray-light: #565e68;
}

/* --- Global Animations --- */
@keyframes cfw-spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

@keyframes cfw-loading-progress-bar-animation {
    0%, 100% {
        transform: translateX(-90%);
    }
    50% {
        transform: translateX(90%);
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes cfw-slideDown {
    from {
        transform: translateY(-100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes cfw-slideUp {
    from {
        transform: translateY(0);
        opacity: 1;
    }
    to {
        transform: translateY(-100%);
        opacity: 0;
    }
}

@keyframes cfw-loading-bar {
    0% {
        left: -50%;
    }
    50% {
        left: 100%;
    }
    100% {
        left: -50%;
    }
}

/* --- Mobile / Reset --- */
body {
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}

.woocommerce input.input-text,
.woocommerce-page input.input-text {
    width: 100%;
    padding: 10px;
    font-size: 14px;
    box-sizing: border-box;
    min-width: 50px;
    max-width: 100%;
}

/* --- Alert Styles --- */
#cfw-alert-container {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    max-width: 300px;
}

.cfw-alert {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    border-radius: 3px;
    color: #ffffff;
    font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    font-size: 14px;
    line-height: 1.4;
}

.cfw-alert-warning {
    background-color: #ff9800;
}

.cfw-alert-error {
    background-color: #f44336;
}

.cfw-alert-success {
    background-color: #4caf50;
}

.cfw-alert-content {
    flex-grow: 1;
}

.cfw-alert-content p {
    margin: 0;
}

.cfw-alert-close {
    background: none;
    border: none;
    color: #ffffff;
    font-size: 20px;
    cursor: pointer;
    padding: 0;
    margin-left: 12px;
    opacity: 0.7;
    transition: opacity 0.2s;
}

.cfw-alert-close:hover {
    opacity: 1;
}

.cb-alert {
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: 0.25rem;
}

.cb-alert-danger {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}

#wp-admin-bar-cfw-alerts .ab-icon:before {
    content: "\f227";
    top: 2px;
}

#wp-admin-bar-cfw-alerts .cfw-alert-badge {
    background: #d63638;
    color: #fff;
    border-radius: 10px;
    padding: 2px 6px;
    font-size: 11px;
    font-weight: 600;
    margin-left: 5px;
    display: inline-block;
    line-height: 1.4;
}

#wp-admin-bar-cfw-alerts .ab-submenu {
    min-width: 300px;
}

#wp-admin-bar-cfw-alerts .ab-submenu .ab-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
}

#wp-admin-bar-cfw-alerts .ab-submenu .cfw-alert-type-name {
    flex: 1;
}

#wp-admin-bar-cfw-alerts .ab-submenu .cfw-alert-type-count {
    background: #d63638;
    color: #fff;
    border-radius: 10px;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    margin-left: 10px;
}

#wp-admin-bar-cfw-alerts .ab-submenu .cfw-no-alerts {
    color: #72aee6;
    font-style: italic;
    padding: 10px 12px;
}

#wp-admin-bar-cfw-alerts .ab-submenu .cfw-view-all {
    border-top: 1px solid #464b50;
    background: #32373c;
}

#wp-admin-bar-cfw-alerts .ab-submenu .cfw-view-all:hover {
    background: #2271b1;
}

/* --- Login Page Styles --- */
body.login {
    background: linear-gradient(120deg, #fdfbfb 0%, #d2d2e6 100%);
    color: #3c4755;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    backdrop-filter: blur(100px);
}

#login h1 a,
.login h1 a {
    height: 50px;
    width: 250px;
    background-size: contain;
    background-repeat: no-repeat;
    padding-bottom: 10px;
}

.login form {
    border-radius: 10px;
    margin-top: 20px;
    padding: 26px 24px 34px;
    font-weight: 400;
    overflow: hidden;
    color: #3c4755;
    border: none;
    background: #fbfbff;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(10px);
}

.login form label,
.login #nav,
.login #backtoblog {
    font-size: 1.1rem;
}

.login form .forgetmenot {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-end;
}

#user_login,
#user_pass,
.login form > p > input {
    background: #ffffff;
    border: 1px solid #ddd;
    color: #333;
    border-radius: 10px;
    padding: 10px;
    margin-bottom: 10px;
}

.wp-core-ui .button-primary {
    background: #47c0a5;
    border: none;
    color: #fff;
    padding: 10px 20px;
    border-radius: 10px;
    transition: background-color 0.3s ease, transform 0.3s ease;
}

.wp-core-ui .button-primary:hover {
    background: #602da5;
}

.wp-login-lost-password,
#backtoblog > a {
    color: #202531 !important;
    text-decoration: underline;
}

#login-message {
    color: #202531;
}

@media screen and (max-width: 480px) {
    #login h1 a,
    .login h1 a {
        background-size: contain;
        height: 40px;
        width: 200px;
    }

    .login form {
        padding: 20px;
    }

    #user_login, #user_pass, .login form > p > input {
        padding: 8px;
    }

    .login button.button-primary {
        padding: 8px 16px;
    }
}

/* --- Password Reset Form --- */
.cfw-password-reset-form {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
}

.cfw-password-reset-form h2 {
    text-align: center;
    margin-bottom: 20px;
}

.cfw-password-reset-form form p {
    margin-bottom: 15px;
}

.cfw-password-reset-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
}

.cfw-password-reset-form input[type="password"] {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
}

.cfw-password-reset-form .button {
    display: block;
    width: 100%;
    padding: 10px;
    background-color: #007cba;
    color: #fff;
    border: none;
    cursor: pointer;
}

.cfw-password-reset-form .button:hover {
    background-color: #005a94;
}

.cfw-password-reset-form .error {
    color: #d9534f;
    margin-bottom: 15px;
}

.cfw-password-reset-form .success {
    color: #5cb85c;
    margin-bottom: 15px;
}

/* --- WP Admin Bar Customization --- */
#wpadminbar {
    background: #383d4f;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 9999;
}

#wp-admin-bar-wp-logo > a > span.ab-icon,
#wpadminbar #wp-admin-bar-wp-logo > .ab-item .ab-icon {
    content: url("../images/commercebuild_logo.svg");
    top: 2px;
    width: 20px;
    height: 20px;
}

#wpadminbar #wp-admin-bar-my-account.with-avatar > a img,
#wp-admin-bar-user-info .avatar {
    border-radius: 50%;
}

#wpadminbar #wp-admin-bar-my-account.with-avatar > a img {
    width: 24px;
    height: 24px;
}

/* Admin Bar Hovers */
#wpadminbar .quicklinks .ab-sub-wrapper .menupop.hover > a,
#wpadminbar .quicklinks .menupop ul li a:hover,
#wpadminbar .quicklinks .menupop.hover ul li a:hover,
#wpadminbar li.hover .ab-item:before,
#wpadminbar li:hover .ab-item:before {
    color: var(--common-mint);
    background-color: var(--common-dark-gray-medium);
}

#wpadminbar li:hover #adminbarsearch:before {
    color: var(--common-orange);
    background-color: transparent;
}

#wpadminbar .ab-top-menu > li.hover > .ab-item,
#wpadminbar:not(.mobile) .ab-top-menu > li:hover > .ab-item {
    background: #2c3338;
    color: #ffffff;
}

/* --- Address Book & Management --- */
.cfw-address-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 10px 0;
    border-bottom: 1px solid #eee;
}

.cfw-address-title {
    margin: 0;
    background-color: #f1f1f1;
    padding: 0 10px;
    border: 1px solid transparent;
    border-radius: 5px;
}

.cfw-address-actions {
    display: flex;
    gap: 10px;
    margin: 5px 0;
}

.cfw-icon-button {
    background: none;
    border: none;
    padding: 2px 8px;
    cursor: pointer;
    border-radius: 4px;
}

.cfw-icon-button:hover {
    background-color: #f0f0f0;
}

.cfw-icon-button i {
    font-size: 16px;
}

#cfw-cab-add-address-billing i,
#cfw-cab-add-address-shipping i {
    color: #28a745;
}

button[name^="save_addresses"] i {
    color: #007bff;
}

button[name^="remove_address"] i {
    color: #dc3545;
}

.cfw-address-management {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin: 0 auto;
    padding: 5px;
}

.cfw-cab-address {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 3px;
    padding: 10px;
    flex: 1 1 calc(50% - 20px);
    min-width: 280px;
}

.cfw-cab-address .form-control {
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    background-color: #fff;
    border-radius: 4px;
}

.cfw-cab-address .form-control:focus {
    border-color: var(--common-input-active, #66afe9);
    outline: none;
    box-shadow: 0 0 5px rgba(102, 175, 233, 0.6);
}

/* Read-only/locked field styling */
input.cfw-field-locked,
textarea.cfw-field-locked,
select.cfw-field-locked {
    background-color: #f0f0f0 !important;
    color: #666 !important;
    cursor: not-allowed !important;
    opacity: 0.8;
    border-color: #ccc !important;
}

select.cfw-field-locked {
    pointer-events: none;
}

/* Ensure SelectWoo/Select2 stays locked even if initialized after JS */
select.cfw-field-locked + .select2-container,
.cfw-field-locked.select2-container {
    pointer-events: none !important;
    background-color: #f0f0f0 !important;
    cursor: not-allowed !important;
    opacity: 0.8;
}

select.cfw-field-locked + .select2-container .select2-selection,
.cfw-field-locked.select2-container .select2-selection {
    background-color: #f0f0f0 !important;
    cursor: not-allowed !important;
}

.cfw-cab-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 15px;
}

.cfw-cab-button {
    padding: 10px 20px;
    border: none;
    background-color: #f0f0f0;
    color: #333;
    cursor: pointer;
    margin-right: 10px;
    border-radius: 4px;
}

.cfw-cab-button.loading {
    opacity: 0.7;
    cursor: not-allowed;
}

.cfw-cab-button-add {
    background-color: #4caf50;
    color: #fff;
}

.cfw-cab-button-remove {
    background-color: #f44336;
    color: #fff;
}

.cfw-cab-button.success {
    background-color: #28a745 !important;
    color: #fff !important;
}

/* Responsive Address Book */
@media (max-width: 767px) {
    .cfw-cab-address {
        flex: 1 1 100%;
    }
}

@media (max-width: 600px) {
    .cfw-cab-address {
        padding: 15px;
    }

    .cfw-cab-buttons {
        flex-direction: column;
        align-items: stretch;
    }

    .cfw-cab-button {
        margin-right: 0;
        margin-bottom: 10px;
    }
}

/* --- Modals (General) --- */
.cfw-modal, .cb-modal {
    display: none;
    position: fixed;
    z-index: 9995;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    overflow: auto;
}

.cb-modal {
    background-color: rgba(15, 23, 42, 0.45);
}

.cb-modal-backdrop {
    position: absolute;
    inset: 0;
    background: transparent;
}

:root {
    --cfw-admin-bar-offset: 0px;
    --cfw-portal-modal-gap: 24px;
}

body.admin-bar {
    --cfw-admin-bar-offset: 32px;
}

@media (max-width: 782px) {
    body.admin-bar {
        --cfw-admin-bar-offset: 46px;
    }
}

.cfw-portal-modal {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center;
    padding: var(--cfw-admin-bar-offset) var(--cfw-portal-modal-gap) var(--cfw-portal-modal-gap);
    background-color: rgba(15, 23, 42, 0.45);
}

.cfw-portal-modal .cfw-portal-modal-content {
    margin: 0;
    width: min(96vw, 1400px);
    height: calc(100vh - var(--cfw-admin-bar-offset) - (var(--cfw-portal-modal-gap) * 2));
    max-height: calc(100vh - var(--cfw-admin-bar-offset) - (var(--cfw-portal-modal-gap) * 2));
    border-radius: 0 0 12px 12px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18),
        0 -6px 16px rgba(15, 23, 42, 0.14);
}

@media (max-width: 782px) {
    .cfw-portal-modal {
        padding: var(--cfw-admin-bar-offset) 12px 12px;
    }
}

.cb-modal.show {
    display: block;
    opacity: 1;
    visibility: visible;
}

.cfw-modal-content {
    background-color: #fefefe;
    margin: 5% auto;
    padding: 20px;
    border: 1px solid #888;
    border-radius: 5px;
    width: 90%;
    max-width: 900px;
    height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    opacity: 0;
    transition: opacity 0.3s ease-in;
}

.cfw-modal:not(.loading) .cfw-modal-content {
    opacity: 1;
}

.cfw-modal-header, .cb-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}

.cfw-modal-body, .cb-modal-body {
    flex-grow: 1;
    overflow: auto;
    display: flex;
    flex-direction: column;
}

.cfw-modal-close, .cb-btn-close:not(.cb-btn) {
    border: none;
    cursor: pointer;
    background: transparent;
}

.cfw-modal-close {
    width: 2rem;
    aspect-ratio: 1/1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: oklch(57.7% 0.245 27.325);
    color: #ffffff;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.cfw-modal-close:hover {
    background-color: oklch(50.5% 0.213 27.518);
}

/* Portal Button Styles */
.cb-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 6px;
    border: 1px solid var(--cfw-portal-border, #d6dee8);
    background: var(--cfw-portal-surface, #ffffff);
    color: var(--cfw-portal-text, #1f2933);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    transition: all 0.2s ease;
}

.cb-btn:hover {
    border-color: var(--cfw-portal-accent, #2563eb);
    color: var(--cfw-portal-text, #1f2933);
    background: var(--cfw-portal-surface-muted, #f3f6fb);
}

.cb-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.cb-btn-primary {
    background: var(--cfw-portal-accent, #2563eb);
    border-color: var(--cfw-portal-accent, #2563eb);
    color: #ffffff;
    box-shadow: 0 8px 16px var(--cfw-portal-accent-soft, rgba(37, 99, 235, 0.16));
}

.cb-btn-primary:hover {
    background: var(--cfw-portal-accent-strong, #1d4ed8);
    border-color: var(--cfw-portal-accent-strong, #1d4ed8);
    color: #ffffff;
}

.cb-btn-primary .dashicons,
.cb-btn-primary:hover .dashicons,
.cb-btn-primary:focus .dashicons {
    color: #ffffff;
}

.cb-btn-secondary {
    background: var(--cfw-portal-surface, #ffffff);
    border-color: var(--cfw-portal-border, #d6dee8);
    color: var(--cfw-portal-text, #1f2933);
}

.cb-btn-secondary:hover {
    background: var(--cfw-portal-surface-muted, #f3f6fb);
    border-color: var(--cfw-portal-accent, #2563eb);
}

.cb-btn-danger-outline {
    background: var(--cfw-portal-surface, #ffffff);
    border-color: #f3b4b4;
    color: #b91c1c;
}

.cb-btn-danger-outline:hover {
    background: rgba(239, 68, 68, 0.08);
    border-color: #ef4444;
    color: #b91c1c;
}

.cb-btn-danger-outline .dashicons {
    color: currentColor;
}

.cb-btn-sm {
    padding: 5px 10px;
    font-size: 12px;
}

.cb-btn-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.cb-btn-close:not(.cb-btn-danger-outline) {
    border: 1px solid var(--cfw-portal-border, #d6dee8);
    color: var(--cfw-portal-text, #1f2933);
}

.cb-btn-close:not(.cb-btn-danger-outline):hover {
    background: var(--cfw-portal-surface-muted, #f3f6fb);
    border-color: var(--cfw-portal-accent, #2563eb);
}

.cb-btn.cb-btn-close {
    width: auto;
    height: auto;
    border-radius: 6px;
    padding: 5px 10px;
}

/* --- Specific Modals --- */
/* User Switching Modal */
.cfw-user-switch-modal, #arcust-switching-modal {
    display: none;
    position: fixed;
    z-index: 10;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(5px);
    color: #333333;
}

.cfw-user-switch-modal-content {
    background-color: #fefefe;
    margin: 5% auto;
    padding: 20px;
    border: 1px solid #888;
    border-radius: 5px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    width: 90%;
    max-width: 600px;
    animation: fadeIn 0.3s ease-out;
}

.cfw-user-switch-modal-header {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 20px;
    gap: 10px;
}

.cfw-user-switch-close {
    color: #aaa;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    margin-left: auto;
}

/* PDF Modal */
.cb-modal-content {
    position: relative;
    background-color: #fff;
    margin: 0;
    padding: 0;
    border-radius: 12px;
    border: 1px solid var(--cfw-portal-border, #d6dee8);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
}

.cb-modal-dialog {
    position: relative;
    width: auto;
    margin: 1.75rem auto;
    max-width: 90%;
    transform: translateY(-50px);
    transition: transform 0.3s ease;
}

.cb-modal.show .cb-modal-dialog {
    transform: translateY(0);
}

#cb-pdf-modal .cb-pdf-modal-dialog {
    max-width: 94vw;
}

#cb-pdf-modal .cb-pdf-modal-content {
    height: 90vh;
    display: flex;
    flex-direction: column;
}

#cb-pdf-modal .cb-pdf-modal-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--cfw-portal-border, #d6dee8);
    background: var(--cfw-portal-surface-muted, #f3f6fb);
}

#cb-pdf-modal .cb-modal-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

#cb-pdf-modal .cb-pdf-title-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

#cb-pdf-modal .cb-pdf-title-group h5 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--cfw-portal-text, #1f2933);
}

#cb-pdf-modal .cb-pdf-page-indicator {
    font-size: 0.85rem;
    color: var(--cfw-portal-text-muted, #5b6472);
}

#cb-pdf-modal .cb-pdf-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 16px;
    border-bottom: 1px solid var(--cfw-portal-border, #d6dee8);
    background: var(--cfw-portal-surface, #ffffff);
}

#cb-pdf-modal .cb-pdf-toolbar-group {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

#cb-pdf-modal .cb-pdf-page-label,
#cb-pdf-modal .cb-pdf-zoom-label {
    font-size: 0.85rem;
    color: var(--cfw-portal-text-muted, #5b6472);
    min-width: 88px;
    text-align: center;
}

#cb-pdf-modal .cb-pdf-modal-body {
    flex: 1;
    overflow: hidden;
    background: var(--cfw-portal-surface-muted, #f3f6fb);
}

#cb-pdf-modal #cb-pdf-container {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
}

#cb-pdf-modal .cb-pdf-loading {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: rgba(243, 246, 251, 0.92);
    z-index: 2;
}

#cb-pdf-modal .cb-pdf-pages {
    flex: 1;
    overflow: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: center;
}

#cb-pdf-modal .cb-pdf-page {
    background: #ffffff;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid var(--cfw-portal-border, #d6dee8);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.12);
}

#cb-pdf-modal .cb-pdf-page canvas {
    display: block;
    max-width: 100%;
    height: auto;
}

/* --- Loaders & Spinners --- */
.cfw-modal-loader,
.cfw-loading-spinner,
.sync-spinner {
    width: 50px;
    height: 50px;
    border: 5px solid;
    border-radius: 50%;
    animation: cfw-spin 1s linear infinite;
}

.cfw-dashicon-spin {
    display: inline-block;
    animation: cfw-spin 1s linear infinite;
}

.cb-dt-center,
th.cb-dt-center,
td.cb-dt-center {
    text-align: center;
}

.cb-dt-right,
th.cb-dt-right,
td.cb-dt-right {
    text-align: right;
}

.cb-dt-nowrap,
th.cb-dt-nowrap,
td.cb-dt-nowrap {
    white-space: nowrap;
}

.cb-dt-center .dashicons,
.cb-dt-right .dashicons {
    vertical-align: middle;
}

.cb-pdf-icon.dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
    line-height: 1;
    vertical-align: middle;
    cursor: pointer;
}

.cb-badge .dashicons {
    margin-right: 6px;
}

.cb-datatable-container table.dataTable th,
.cb-datatable-container table.dataTable td {
    vertical-align: middle;
}

.cb-datatable-container .dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
    line-height: 1;
    vertical-align: middle;
    color: #475569;
    transition: transform 0.15s ease, color 0.15s ease, opacity 0.15s ease;
}

.cb-datatable-container .cb-pdf-icon:hover,
.cb-datatable-container .btn:hover .dashicons,
.cb-datatable-container button:hover .dashicons {
    transform: scale(1.15);
    color: var(--cfw-portal-accent-strong, #1d4ed8);
}

.cfw-loading-progress-bar {
    --uib-size: 80px;
    --uib-speed: 1.55s;
    --uib-color: var(--common-dark-gray);
    --uib-line-weight: 5px;
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    align-items: center;
    justify-content: center;
    height: var(--uib-line-weight);
    width: var(--uib-size);
    border-radius: calc(var(--uib-line-weight) / 2);
    overflow: hidden;
    background-color: rgba(0, 0, 0, 0.05); /* Track color */
}

.cfw-loading-progress-bar::after {
    content: '';
    height: 100%;
    width: 100%;
    border-radius: calc(var(--uib-line-weight) / 2);
    animation: cfw-loading-progress-bar-animation var(--uib-speed) ease-in-out infinite;
    transform: translateX(-90%);
    background-color: var(--common-dark-gray);
}

@keyframes cfw-skeleton-shimmer {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(100%);
    }
}

.cfw-price-skeleton {
    display: inline-block;
    min-width: 60px;
    height: 1em;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

.cfw-skeleton-shimmer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
    animation: cfw-skeleton-shimmer 1.5s ease-in-out infinite;
}

.cfw-loading-price {
    opacity: 0.7;
}

body.cfw-dynamic-pricing-pending.single-product .summary .price {
    visibility: hidden;
}

body.cfw-dynamic-pricing-pending.single-product .summary .price.cfw-loading-price,
body.cfw-dynamic-pricing-initialized.single-product .summary .price {
    visibility: visible;
}

.cfw-price-uom {
    font-size: 0.85em;
    color: var(--common-dark-gray-light);
    margin-left: 4px;
}

.cfw-inventory-skeleton {
    display: inline-block;
    min-width: 80px;
    height: 1em;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

.cfw-msrp-skeleton {
    display: inline-block;
    min-width: 60px;
    height: 1em;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

.cfw-quantity-breaks-skeleton {
    display: inline-block;
    min-width: 100px;
    height: 1em;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

.cfw-loading-inventory {
    opacity: 0.7;
}

.cfw-modal-loader {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-color: var(--common-off-white);
    border-top-color: var(--common-purple);
    border-width: 3px;
    z-index: 1000;
}

.cfw-loading-spinner {
    border-color: var(--common-light-gray);
    border-top-color: var(--common-purple);
}

.sync-spinner {
    border-color: #f3f3f3;
    border-top-color: #3498db;
}

.cb-spinner-border {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    border: 0.25em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: cfw-spin 0.75s linear infinite;
}

.cfw-switch-loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    z-index: 99999;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    backdrop-filter: blur(5px);
}

.cfw-loading-container {
    margin-bottom: 20px;
}

.cfw-switch-status-text {
    font-size: 18px;
    font-weight: 600;
    color: var(--common-dark-gray);
    font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* --- Notification Bars --- */
.cfw-switch-notification {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, #4caf50 0%, #45a049 100%);
    color: #ffffff;
    padding: 16px 20px;
    z-index: 999999;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    animation: cfw-slideDown 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    cursor: pointer;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}

.cfw-switch-notification:hover {
    background: linear-gradient(135deg, #45a049 0%, #3d8b40 100%);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.cfw-switch-notification.cfw-error {
    background: linear-gradient(135deg, #f44336 0%, #d32f2f 100%);
}

.cfw-notification-dismissing {
    animation: cfw-slideUp 0.3s ease-out forwards;
}

.cfw-notification-close {
    background: transparent;
    border: none;
    color: #ffffff;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.cfw-notification-close:hover {
    opacity: 1;
}

/* --- Tables (Transactions & Invoices) --- */
.cfw-transaction-table-container,
.cfw-invoice-container {
    font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

#cfw-transaction-table,
#cfw-transaction-details-table,
.responsive-table,
.cfw-invoice-items {
    width: 100%;
    border-collapse: collapse;
}

#cfw-transaction-table th,
#cfw-transaction-details-table th,
.responsive-table th,
.cfw-invoice-items thead tr {
    background-color: #f8f8f8;
    font-weight: 600;
    color: #333;
    padding: 12px;
    text-align: left;
}

.cfw-invoice-items tbody tr {
    border-bottom: 1px solid #e0e0e0;
}

.cfw-invoice-items tbody tr td {
    padding: 10px;
}

/* --- Invoice Styling --- */
.cfw-invoice-container {
    width: 100%;
    max-width: 95%;
    margin: 0 auto;
    background-color: #fff;
}

.cfw-invoice-header {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #e0e0e0;
    padding-bottom: 20px;
    margin-bottom: 20px;
}

.cfw-invoice-meta {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.cfw-invoice-summary {
    margin-left: auto;
    width: 300px;
}

.cfw-summary-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 5px;
}

.cfw-summary-item.cfw-total {
    font-weight: bold;
    font-size: 18px;
    border-top: 2px solid #e0e0e0;
    padding-top: 5px;
    margin-top: 5px;
}

@media print {
    body * {
        visibility: hidden;
    }

    #cfw-invoice-content, #cfw-invoice-content * {
        visibility: visible;
    }

    #cfw-invoice-content {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
    }

    .cfw-modal-header, .cfw-modal-actions {
        display: none;
    }

    .cfw-invoice-container {
        border: none;
    }
}

/* --- Pills --- */
.pill, .pill-large {
    font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    font-size: 0.8em;
    font-weight: 600;
    border: none;
    color: #32335d;
    padding: 1px 10px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.pill {
    border-radius: 32px;
}

.pill-large {
    border-radius: 5px;
}

/* Pill Colors */
.pill-gray {
    background-color: #e7eaf0;
    color: #32335d;
}

.pill-blue {
    background-color: #c4effe;
    color: #32335d;
}

.pill-green {
    background-color: #d5fbcf;
    color: #1c5550;
}

.pill-red {
    background-color: var(--wc-red);
    color: #ffffff;
}

.pill-purple {
    background-color: var(--purple-medium);
    color: #ffffff;
}

/* --- Select2 Customization (Warehouse) --- */
.cfw-warehouse-select {
    width: 100% !important;
    min-height: 40px;
}

.cfw-warehouse-select + .select2-container--default .select2-selection--single {
    height: 40px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

.cfw-warehouse-select + .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 38px;
    padding-left: 12px;
    color: #333;
}

.cfw-warehouse-select + .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 38px;
    right: 8px;
}

.cfw-warehouse-select + .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--common-teal);
    box-shadow: 0 0 0 2px rgba(71, 192, 165, 0.2);
}
