/* Font Declarations - Consolidated */
@font-face {
  font-display: swap;
  font-family: NB International Pro;
  font-style: normal;
  font-weight: 300;
  src: local('NBInternationalPro-Light'),
  url('../fonts/NBInternationalPro-Light.woff2') format('woff2'),
  url('../fonts/NBInternationalPro-Light.woff') format('woff'),
  url('../fonts/NBInternationalPro-Light.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: NB International Pro;
  font-style: normal;
  font-weight: 400;
  src: local('NBInternationalPro-Regular'),
  url('../fonts/NBInternationalPro-Regular.woff2') format('woff2'),
  url('../fonts/NBInternationalPro-Regular.woff') format('woff'),
  url('../fonts/NBInternationalPro-Regular.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: NB International Pro;
  font-style: normal;
  font-weight: 500;
  src: local('NBInternationalPro-Medium'),
  url('../fonts/NBInternationalPro-Medium.woff2') format('woff2'),
  url('../fonts/NBInternationalPro-Medium.woff') format('woff'),
  url('../fonts/NBInternationalPro-Medium.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: NB International Pro;
  font-style: normal;
  font-weight: 700;
  src: local('NBInternationalPro-Medium'),
  url('../fonts/NBInternationalPro-Medium.woff2') format('woff2'),
  url('../fonts/NBInternationalPro-Medium.woff') format('woff'),
  url('../fonts/NBInternationalPro-Medium.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: DIN Pro;
  font-style: normal;
  font-weight: 300;
  src: local('DINPro-Light'),
  url('../fonts/DINPro-Light.woff2') format('woff2'),
  url('../fonts/DINPro-Light.woff') format('woff'),
  url('../fonts/DINPro-Light.otf') format('opentype')
}

@font-face {
  font-family: DIN Pro;
  font-style: normal;
  font-weight: 400;
  src: local('DINPro'),
  url('../fonts/DINPro.woff2') format('woff2'),
  url('../fonts/DINPro.woff') format('woff'),
  url('../fonts/DINPro.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: DIN Pro;
  font-style: normal;
  font-weight: 500;
  src: local('DINPro-Medium'),
  url('../fonts/DINPro-Medium.woff2') format('woff2'),
  url('../fonts/DINPro-Medium.woff') format('woff'),
  url('../fonts/DINPro-Medium.otf') format('opentype')
}

@font-face {
  font-display: swap;
  font-family: DIN Pro;
  font-style: normal;
  font-weight: 600;
  src: local('DINPro-Medium'),
  url('../fonts/DINPro-Medium.woff2') format('woff2'),
  url('../fonts/DINPro-Medium.woff') format('woff'),
  url('../fonts/DINPro-Medium.otf') format('opentype')
}

/* Root Variables - Consolidated */
:root {
    /* Layout */
    --sidebar-width: 260px;
    --sidebar-mini-width: 80px;
    --content-padding: 30px 15px;

    /* Brand Colors */
    --veryfi-green: #00aa00;
    --veryfi-purple: #8b229d;
    --veryfi-nav-bg: #171C3A;
    --veryfi-navy-light: #70748f;
    --veryfi-navy-medium: #45495F;
    --veryfi-navy: #171c3a;
    --veryfi-sky-dark: #4553BA;
    --veryfi-ivory-dark: #9B9C98;
    --veryfi-magenta: #E73C4E;
    --veryfi-gold: #B8860B;
    --veryfi-aqua-light: #1BA39C;
    --veryfi-forest: #173835;
    
    /* UI Colors */
    --uikit-bg-color: #e9ece4;
    --uikit-text-color: #45495f;
    --uikit-subtle-background: #E9ECE4;
    --uikit-text-secondary-color: #171c3a;
    --uikit-highlight-color: #00fa6c;
    --uikit-primary-color: #00aa00;
    --uikit-border-color: #70748f;
    --uikit-inactive-color: #70748f;
    --uikit-link-color: #5b6bd2;
    --uikit-red-color: #e73c4e;
    --uikit-disable-color: #9b9c98;
    --uikit-chart-color1: #00aa00;
    --uikit-chart-color2: #0b847c;
    --uikit-dark-forest: #173835;
    --uikit-gold-border: #b8860b;
    --uikit-navy-light: #70748f;

    /* Gradients */
    --uikit-company-color: linear-gradient(298.79deg, #2d9cd2 -23.47%, #00fa6c 92.01%, #2db5d2 214.83%);
    --uikit-company-color-inverted: linear-gradient(307.48deg, #2db5d2 -211.07%, #00fa6c -6.04%, #2db5d2 212.05%);
    
    /* Code */
    --code-bg: #171C3A;
    --code-color: #E6E1DC;

    /* Add more semantic variables */
    --spacing-base: 1rem;
    --border-radius-base: 4px;
    --transition-speed: 0.2s;
    --shadow-default: 0 2px 5px 0 rgba(0, 0, 0, 0.26);

    --default-box-shadow: 1px 1px 5px 0 #171c3a22;
    --default-radius: 20px;
    --din-pro: "DIN Pro";
    --nb-international: "NB International Pro";
}

.transparent {
    opacity: 0 !important;
}

#main-container {
    transition: all ease 0.25s;
    opacity: 1;
}

/* Only show invalid states after form validation has been attempted */
.was-validated input:invalid, .is-invalid, .btn.is-invalid, .btn.btn-primary.is-invalid {
    border-color: var(--veryfi-magenta) !important;
}

.was-validated .form-control:invalid {
    padding-right: .75rem;
}

.was-validated .form-control:valid, .was-validated button:valid {
    border-color: var(--veryfi-green) !important;
}

.dropdown-item {
    cursor: pointer;
}

/* Readonly field styling */
.form-control-readonly,
input[readonly].form-control,
.form-control-readonly:focus,
input[readonly].form-control:focus {
    background-color: var(--veryfi-navy-medium) !important;
    color: white !important;
    border: 1px solid var(--veryfi-navy-medium) !important;
    border-radius: 9999px !important;
    opacity: 1 !important;
}

/* Universal Input with Pill Prefix Styling */
.input-with-pill-prefix {
    position: relative !important;
    display: block !important;
}

.pill-prefix-input {
    padding-left: 1rem !important; /* Make space for the prefix */
    border-radius: 9999px !important;
}

.pill-prefix {
    position: absolute !important;
    top: 0px !important;
    left: 0px !important;
    bottom: 0px !important;
    border-radius: 9999px 0 0 9999px !important;
    background-color: var(--veryfi-navy-medium) !important;
    color: var(--uikit-bg-color) !important;
    border: none !important;
    padding: 0.25rem .75rem !important;
    font-size: 0.8rem !important;
    font-weight: 500 !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    min-width: fit-content !important;
    white-space: nowrap !important;
    pointer-events: none !important; /* Prevent interaction since it's just a label */
}

/* Auto-adjust input padding based on prefix width */
.input-with-pill-prefix .pill-prefix-input {
    padding-left: 4.5rem !important; /* Default padding that should work for most prefixes */
}

/* Custom dropdown button valid states */
.was-validated .btn.is-valid, 
.was-validated .btn:valid {
    border-color: var(--veryfi-green) !important;
}

.form-control.is-invalid, .was-validated .form-control:invalid,
.form-control.is-valid, .was-validated .form-control:valid {
    background-image: none !important;
}

.text-warning {
    color: var(--veryfi-gold) !important;
}

.form-required {
    color: var(--veryfi-magenta) !important;
}

hr {
    border-color: var(--veryfi-navy-light);
}


/* Base Typography */
body, p, a, td, .btn-simple {
    font-family: DIN Pro, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: NB International Pro, sans-serif;
    color: var(--uikit-text-secondary-color);
}

a {
    color: var(--veryfi-sky-dark);
    text-decoration: none !important;
}

.btn-brand.show {
    color: var(--veryfi-green) !important;
}

.btn:active, .btn:focus-visible, .btn.show {
    background-color: inherit !important;
}

:focus-visible {
    box-shadow: none !important;
}

.sidebar a:hover, a.btn:hover {
    text-decoration: none !important;
}

a:hover {
    color: var(--veryfi-sky-dark);
    text-decoration: underline !important;
    text-underline-offset: 5px;
}

.navbar-nav a:hover {
    text-decoration: none !important;
}

.brand-color {
    color: var(--veryfi-green) !important;
}

.btn {
    transition: none !important;
    text-transform: uppercase;
    border-radius: 9999px;
}

.btn-icon-right {
    padding-left: 1rem;
}

.btn.btn-brand {
    background: var(--veryfi-green);
    color: white;
    border: 1px solid var(--veryfi-green);
    font-size: 1rem !important;
    text-transform: uppercase !important;
}

.alert {
    background-color: white;
    border-radius: var(--default-radius);
}

.alert.alert-success {
    background-color: var(--veryfi-green) !important;
    border: 1px solid var(--veryfi-green) !important;
    color: white !important;
    border-radius: var(--default-radius) !important;
    padding: 0.5rem 1rem !important;
}

.callout {
    color: var(--veryfi-navy);
    background-color: #FFFFFF99;
    border: 1px solid white;
    padding: 0.75rem 1rem !important;
}

.callout > i {
    font-size: 1.5rem;
    margin-right: 1rem;
}

.callout.callout-warning > i {
    color: var(--veryfi-gold);
}

.callout.callout-warning > .btn {
    background: var(--veryfi-gold);
    border-color: var(--veryfi-gold);
    color: white;
}

.callout.callout-success > i {
    color: var(--veryfi-green);
}

.callout.callout-success > .btn {
    background: var(--veryfi-green) !important;
    color: white !important;
}


.callout.callout-success > .btn:active {
    border-color: var(--veryfi-green) !important;
}

.callout.callout-success > .btn:hover
{
    background: transparent !important;
}

[data-notify="container"] button.close {
    color: white !important;
}

.alert.alert-light {
    color: var(--veryfi-navy) !important;
    background: #FFFFFF99;
    border: 1px solid white;
}

.btn.btn-success {
    color: white !important;
    border: 1px solid var(--veryfi-green);
    background: var(--veryfi-green);
}

.btn.btn-success:hover, .btn.btn-success:active {
    color: var(--veryfi-green) !important;
    background: transparent;
}

/* Placeholder styles for cross-browser compatibility */
input::placeholder {
    color: var(--veryfi-navy-light) !important;
}

input::-webkit-input-placeholder {
    color: var(--veryfi-navy-light) !important;
}

input::-moz-placeholder {
    color: var(--veryfi-navy-light) !important;
    opacity: 1;
}

input:-ms-input-placeholder {
    color: var(--veryfi-navy-light) !important;
}

input:-moz-placeholder {
    color: var(--veryfi-navy-light) !important;
    opacity: 1;
}

.btn-close {
    opacity: 1 !important;
    color: var(--veryfi-navy) !important;
}

.btn-close:focus {
    outline: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
}

.bold {
    font-weight: 600;
}

select.form-select {
    border: 1px solid var(--veryfi-navy);
}

.btn.btn-primary.dropdown-toggle, select {
    background: transparent !important;
    border: 1px solid var(--veryfi-navy);
    color: var(--veryfi-navy) !important;
}

.btn.btn-primary.dropdown-toggle:hover, 
.btn.btn-primary.dropdown-toggle:active, 
.btn.btn-primary.dropdown-toggle.show {
    background: transparent !important;
    background-color: transparent !important;
    border: 1px solid var(--veryfi-green) !important;
    color: var(--veryfi-navy) !important;
}

.btn.btn-brand:hover {
    background: transparent;
    color: var(--veryfi-green);
}

.btn.btn-primary {
    border-radius: 9999px !important;
    background-color: var(--veryfi-navy) !important;
    border: 1px solid var(--veryfi-navy) !important;
    color: white !important;
    transition: none !important;
}

.btn.btn-primary:hover {
    background-color: transparent !important;
    color: var(--veryfi-navy) !important;
    border: 1px solid var(--uikit-text-secondary-color) !important;
}

.btn.btn-secondary {
    border-radius: 9999px !important;
    border: 1px solid var(--veryfi-navy) !important;
    background: transparent !important;
    color: var(--veryfi-navy) !important;
}

.btn.btn-secondary:hover {
    background: var(--veryfi-navy) !important;
    color: white !important;
}

.btn.btn-tertiary {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--veryfi-navy);
    border-radius: 0;
}

.btn.btn-tertiary:hover {
    border: none;
    border-bottom: 2px solid var(--veryfi-navy);
}

/* Layout Core */
html {
    overflow: hidden;
    height: 100%;
}

html.scrollable {
    overflow: auto;
}

body {
    height: 100%;
    background-color: var(--uikit-subtle-background);
    margin: 0;
}

.wrapper {
    position: relative;
    top: 0;
    height: 100vh;
}

/* Sidebar */
.sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: var(--sidebar-width);
    display: block;
    z-index: 1;
    color: #ffffff;
    background-color: var(--veryfi-nav-bg);
}

.sidebar-wrapper {
    position: relative;
    height: calc(100vh - 75px);
    overflow: auto;
    width: var(--sidebar-width);
    z-index: 4;
    padding-bottom: 30px;
}

.sidebar .sidebar-wrapper ul.nav > li > div > ul > li > a > p {
    margin-left: 40px;
}

#left-main-nav-bottom-section li > div > ul > li > a > p {
    margin-left: 15px;
}

/* Navigation */
.nav li {
    width: 100%;
}

.nav li > a {
    border-radius: 4px;
    color: #FFFFFF;
    padding: 5px 10px !important;
    display: flex;
    align-items: center;
    text-decoration: none;
    margin: 3px 8px 3px 8px !important;
    opacity: 1;
}

.nav li > a:hover {
    background-color: #353a52;
}

.nav li > a i {
    width: 24px;
    text-align: center;
    font-size: 18px;
    margin-right: 15px;
}

.nav li > a p, .nav li > a p span {
    margin: 0;
    line-height: 30px;
    font-size: 12px;
    text-transform: uppercase !important;
    white-space: nowrap;
}

/* Nested Navigation */
.sidebar ul.nav [data-toggle="collapse"] ~ div > ul > li > a {
    padding-left: 18px;
}

.sidebar ul.nav [data-toggle="collapse"] ~ div > ul.nav > li > div > ul.nav > li > a {
    padding-left: 32px;
}

.sidebar ul.nav [data-toggle="collapse"] ~ div > ul.nav > li > div > ul.nav > li > div > ul.nav > li > a {
    padding-left: 48px;
}

.veryfi-leftnav-selected > p{
    color: var(--uikit-highlight-color);
}

/* Main Panel */
.main-panel {
    background: rgba(203, 203, 210, .15);
    position: relative;
    float: right;
    width: calc(100% - var(--sidebar-width));
    min-height: 100%;
}

.main-panel > .content {
    padding: var(--content-padding);
    min-height: calc(100% - 123px);
    margin-top: 65px;
    height: calc(100vh - 70px);
    overflow-y: auto;
}

/* Navbar */
#veryfi-navbar {
    position: fixed;
    top: 0;
    right: 0;
    left: var(--sidebar-width);
    z-index: 1030;
    background: #fff;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    transition: all 0.3s;
    padding: 10px 15px;
    height: 65px;
}

.navbar-nav {
    display: flex;
    align-items: center;
}

/* Sidebar Mini State */
.sidebar-mini .sidebar {
    width: var(--sidebar-mini-width);
}

.sidebar-mini .sidebar .sidebar-wrapper {
    width: var(--sidebar-mini-width);
}

.sidebar-mini #veryfi-navbar {
    left: var(--sidebar-mini-width);
}

.sidebar-mini .main-panel {
    width: calc(100% - var(--sidebar-mini-width));
}

.sidebar-mini .sidebar .nav li > a {
    margin: 5px 10px;
}

.sidebar-mini .sidebar .nav li > a p {
    display: none;
}

.sidebar-mini .logo-container img {
    max-width: 40px;
}

.sidebar-mini .sidebar .collapse .nav {
    width: auto;
    min-width: 140px;
}

body.sidebar-mini .sidebar .sidebar-wrapper ul.nav > li > div > ul > li > a > p {
    color: var(--uikit-border-color);
    margin-left: 0;
    display: block;
}

body.sidebar-mini .sidebar .sidebar-wrapper ul.nav > li > div > ul > li > .veryfi-leftnav-selected > p {
    color: var(--uikit-highlight-color);
}

/* -------------- CARDS -------------- */
.card {
    transition: none !important;
    transform: none !important;
    box-shadow: none !important;
    container-type: inline-size;
    border-radius: var(--default-radius);
}

#insighsContent {
    font-family: var(--nb-international);
}

#insightsContent .card-title, .card-subtitle {
    font-family: var(--din-pro);
    font-size: 14px !important;
    font-weight: 600;
    margin-bottom: 0 !important;
    color: var(--veryfi-navy);
    text-align: center;
}

#insightsContent .stat-value, .stat-value.primary {
    font-size: 1.5rem !important;
    font-family: var(--nb-international);
    text-align: center;
}

#insightsContent .stat {
    font-size: 14px !important;
    font-family: var(--din-pro);
}

#insightsContent .card-body {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.card-body {
    color: var(--veryfi-navy);
}

.card-header {
    background: transparent;
    border-bottom: none;
}

.card:hover {
    transition: none !important;
    transform: none !important;
    box-shadow: none !important;
}

.card-body .card.border-success {
    border-color: var(--uikit-primary-color) !important;
}

.card-body .card.border-danger {
    border-color: var(--uikit-red-color) !important;
}

.card-body .card.border-success, .card-body .card.border-danger {
    padding: 0.8rem !important;
    background: transparent !important;
    border-radius: var(--default-radius) !important;
    padding-bottom: 0 !important;
}

.card-body .card.border-success .card-body, .card-body .card.border-danger .card-body {
    padding: 1rem 0.5rem !important;
    padding-bottom: 0 !important;
}

/* -------------- END CARDS -------------- */

/* -------------- CSTEP 2 SPECIFIC -------------- */

.border-primary {
    border: 1px solid var(--veryfi-green) !important;
}

.ui-sortable .card.mb-3 {
    background: white;
    box-shadow: var(--default-box-shadow) !important;
    border: 1px solid white;
}

.ui-sortable .ui-sortable-placeholder.card {
    background: transparent !important;
    border: 1px dashed var(--uikit-primary-color) !important;
    border-radius: var(--default-radius) !important;
}

.ui-sortable .card-body > div {
    align-items: center !important;
}

.border-primary .drag-handle .bi {
    color: var(--uikit-text-secondary-color) !important;
}

.drag-handle {
    color: var(--uikit-text-color) !important;
}

.drag-handle:hover {
    background: none !important;
}

/* -------------- END CSTEP 2 -------------- */

.card-animate {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    box-shadow: none;
}

.card-animate:hover {
    transform: translateY(-2px);
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15);
}

.card-body {
    padding: 1.5rem;
}

.card-title {
    font-weight: 600;
    font-size: 1.75rem;
}

/* Buttons */
.btn-primary {
    color: #fff;
    border-radius: 4px;
}

.btn-primary:hover {
    border-color: var(--uikit-border-color);
    color: var(--uikit-text-color);
    background-color: transparent;
}

.btn-primary.btn-fill {
    background: none;
    border: 1px solid var(--uikit-text-secondary-color);
    color: var(--uikit-text-color) !important;
    font-size: 14px !important;
    font-weight: 600;
}

.btn-primary.btn-fill:hover {
    background: #fff;
}

/* Forms */
.form-control {
    color: var(--uikit-text-secondary-color);
}

select {
    appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, black 50%),
        linear-gradient(135deg, black 50%, transparent 50%);
    background-position:
        calc(100% - 12px) calc(1em + 2px),
        calc(100% - 7px) calc(1em + 2px);
    background-size: 5px 5px;
    background-repeat: no-repeat;
    padding-right: calc(5px * 2 + 12px);
}

/* Dropdowns */
.dropdown-menu {
    border-radius: 6px;
    padding: 0;
    box-shadow: var(--default-box-shadow);
}

.dropdown-menu li a {
    color: #333333;
    padding: 8px 20px;
    display: block;
    text-decoration: none;
}

.dropdown-menu li a:hover {
    background-color: var(--veryfi-navy);
    color: white !important;
}

.text-muted {
    color: var(--veryfi-ivory-dark) !important;
}

/* Code Blocks */
pre code {
    font-family: 'Inconsolata', monospace;
    font-size: 15px;
}

pre {
    border: 0;
    background: var(--code-bg);
    color: var(--code-color);
    white-space: pre-wrap;
    word-wrap: break-word;
}

.tab-code {
    padding: 8px;
    background: var(--code-bg);
    color: var(--code-color);
}

/* Document Meta */
.document-meta table {
    border-collapse: collapse;
    border-radius: 5px;
    border-style: hidden;
    box-shadow: 0 0 0 1px #c0c0c0;
}

.document-meta td {
    font-size: small;
    font-weight: normal;
    padding: 3px;
    border-bottom: solid #c0c0c0 1px;
}

/* Utility Classes */
.avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
}

.truncated-label {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hidden-block {
    display: none;
}

.d-none-important {
    display: none !important;
}

.text-fit-overflow-ellipsis {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

/* Spacing Utilities */
.pt5 { padding-top: 5rem; }
.pt4 { padding-top: 4rem; }
.pt3 { padding-top: 3rem; }
.pt2 { padding-top: 2rem; }
.pt1 { padding-top: 1rem; }
.p1 { padding: 1rem; }
.p05 { padding: 0.5rem; }

.mt5 { margin-top: 5rem; }
.mt4 { margin-top: 4rem; }
.mt3 { margin-top: 3rem; }
.mt2 { margin-top: 2rem; }
.mt1 { margin-top: 1rem; }
.m1 { margin: 1rem; }

/* Status Indicators */
.is-error {
    color: var(--uikit-red-color);
    text-transform: uppercase;
}

/* Modals */
.ReactModal__Content--uikit-after-open {
    max-height: 60vh;
    max-width: 60vw;
    display: flex;
    flex-direction: column;
    background: var(--uikit-bg-color);
    overflow: hidden;
}

.ReactModal__Content--uikit-after-open .tooltip-content {
    max-height: 70%;
    overflow: auto;
    background: rgba(255, 255, 255, 0.6);
    border-radius: 4px;
    border: 1px solid white;
    padding: 12px;
}

/* Alerts */
.red-alert-card {
    background-color: var(--uikit-red-color);
    color: white;
}

.red-alert-card a {
    color: white;
    text-decoration: underline;
}

/* Advanced Filters */
.advanced-filters {
    display: flex;
    background-color: #f3f3f3;
    padding-right: 14px;
    width: 100%;
}

.advanced-filters-content {
    display: flex;
    width: 100%;
}

.advanced-filters-content .form-group {
    display: flex;
    flex-direction: column;
    height: 100%;
    margin-bottom: 0;
}

.advanced-filters-content .form-group label {
    margin-bottom: auto;
}

/* API Documentation */
.apidocs-box {
    border: solid 1px #6c757d;
    background-color: #6c757d;
    padding: 5px;
    border-radius: 5px;
    text-align: center;
    color: #ffffff;
}

/* Macro Container */
.macro-container-docs {
    border: solid 2px #6c757d;
    border-radius: 5px;
    padding: 3px;
    background-color: #6c757d;
    color: #fff;
    margin-left: 3px;
}

.macro-container-docs a {
    color: #fff;
}

.macro-container-docs a:hover {
    text-decoration: underline;
}

/* Collapsible Container */
.collapsible-container .collapsible-content {
    transition: max-height 0.2s cubic-bezier(0, 1, 0, 1);
    position: relative;
    overflow: hidden;
}

.collapsible-container:not(.expanded) .collapsible-content {
    max-height: 100px;
}

.collapsible-container:not(.expanded) .collapsible-content::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
}

/* Images */
.ios-framework-img {
    max-width: 628px;
    margin-top: 6px;
    border-radius: 4px;
}

.img-border {
    border: solid 1px var(--border-color);
}

/* Tooltips */
.tooltip-inner {
    border: solid 1px #ffffff;
}

/* SweetAlert Customization */
.swal-youtube-size {
    width: 850px;
}

.vertical-buttons {
    flex-direction: column;
}

.top-margin {
    margin-top: .5em;
}

.sidebar-mini .nav-item .nav-link p {
    display: none;
}

@media (max-width: 768px) {
    /* Group all mobile styles */
    .sidebar {
        width: 100%;
        position: relative;
    }
    .main-panel {
        width: 100%;
    }
    .navbar {
        position: relative;
    }
}


/* Animate carot */
.left-nav-section::after {
    transform: rotate(180deg);
}

.left-nav-section.collapsed::after {
    transform: rotate(0deg);
    transition: transform 0.2s ease-in-out;
}

/* Position of caret */
.left-nav-section::after {
    position: absolute;
    right: 10%;
}
  
/* Top Nav */
#navbar-help-button::before {
    content: "Get Help";
}
  
#navbar-help-button i:first-child {
    display: none;
}

#navbar-multipleprofiles {
    margin-top: 3px;
    margin-bottom: 3px;
    margin-right: 13px;
    font-size: 14px;
    padding: 5px 6px;
    border: solid 1px #00000033;
    border-radius: 10px;
}
#navbar-multipleprofiles .dropdown-toggle {
    background: none;
    color: #333333;
    cursor: pointer;
    text-decoration: none;
}
#navbar-multipleprofiles .dropdown-toggle .avatar {
    width: 38px;
    height: 38px;
    display: inline-block;
}
#multipleprofiles-selected {
    display: inline-block;
    position: relative;
    top: 2px;
    padding-left: 0;
    padding-right: 4px;
}
#multipleprofiles-selected.truncated-label {
    display: block;
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
#multipleprofiles-list {
    margin-top: 8px;
    max-height: 75vh;
    overflow-y: auto;
}
#multipleprofiles-list #btn-logout {
    color: #9a9a9a;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
}
.navbar-nav .dropdown-menu li a:hover {
    background-color: #f5f5f5 !important;
    color: var(--veryfi-navy) !important;
}
#multipleprofiles-list #btn-logout:hover {
    color: #447df7 !important;
}
#multipleprofiles-list #btn-logout [class^="fa"] {
    font-size: 19px;
    position: relative;
    line-height: 16px;
    top: 1px;
}
#multipleprofiles-list .divider {
    margin: 5px 0;
}
#multipleprofiles-list.dropdown-menu:before,
#multipleprofiles-list.dropdown-menu:after {
    left: auto !important;
    right: 22px !important;
}
#multipleprofiles-list > li {
    min-width: 184px;
}
#multipleprofiles-list > li > a {
    padding: 8px !important;
}
#multipleprofiles-list > li img {
    margin-top: 0px !important;
    padding: 2px;
}
#multipleprofiles-list .btn {
    margin: 0;
    height: 33px;
}
#multipleprofiles-list .truncated-label {
    display: block;
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Left Nav */
#left-main-nav {
    z-index: 1000;
    background-color: #171C3A;
    padding: 0;  
}

#left-main-nav li > a p span {
    text-transform: uppercase !important;
}

#left-main-nav-bottom-section {
    display: block; 
    margin-top: auto; 
    z-index: 1000; 
}

.veryfi-leftnav-container {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

.left-nav-section-upwards {
    display: flex;
    flex-direction: row;
    gap: 5px;
    margin-left: 25px;
}

.sidebar-mini .left-nav-section-upwards {
    display: flex;
    flex-direction: column;
    margin-left: 0;
    position: absolute;
    left: 100%;
    top: 0;
    z-index: 100;
    min-width: 200px;
    background: white;
    border-radius: 4px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.left-nav-section-upwards li a {
    padding-bottom: 5px;
}

/* Carry overs */

.title {
    font-size: 22px;
    line-height: 30px;
    font-weight: 300;
    margin: 30px 0 15px;
}

.tab-action {
    color: var(--uikit-text-color);
    border-color: var(--uikit-border-color) !important;
    border-radius: 4px;
    background-color: transparent !important;
}

.fixed-table-toolbar .btn-secondary .bi {
    color: white !important;
}

/* Detail Modal */

.modal-dialog {
    max-width: 90%;
  }
  .modal-dialog-slideout {
    min-height: 100%;
    margin: 0 0 0 auto;
    background: #fff;
  }
  .modal.fade .modal-dialog.modal-dialog-slideout {
    -webkit-transform: translate(100%, 0)scale(1);
    transform: translate(100%, 0)scale(1);
  }
  .modal.fade.show .modal-dialog.modal-dialog-slideout {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    display: flex;
    align-items: stretch;
    -webkit-box-align: stretch;
    height: 100%;
  }
  .modal.fade.show .modal-dialog.modal-dialog-slideout .modal-body {
    overflow-y: auto;
    overflow-x: hidden;
  }
  .modal-dialog-slideout .modal-content {
    border: 0;
  }
  .modal-dialog-slideout .modal-header,
  .modal-dialog-slideout .modal-footer {
    height: 4rem;
    display: block;
  }

/* Extras */

.fac-pos {
    color: var(--veryfi-green);
}

.fac-neg {
    color: red;
}

.spinning {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.bootstrap-table .fixed-table-toolbar .bs-bars .bi-arrow-clockwise {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Prism code formatting */

pre {
    background: rgb(40, 44, 52) !important;
    border-radius: 6px;
    padding: 16px;
    margin: 0;
}
code {
    font-family: monospace;
    color: #E2E8F0;
    text-shadow: none !important;
    font-size: 13px !important;
}

.token.tag { color: rgb(224, 108, 117) !important; }
.token.punctuation { color: rgb(171, 178, 191) !important; }
.token.attr-name { color: #8FBCBB !important; }
.token.attr-value { color: rgb(152, 195, 121) !important; }
.token.string { color: #A3BE8C !important; }

.code2 {
    font-family: "Fira Code", Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace;
    border-radius: 4px;
    font-size: 1.2em;
    color: #333;
    border: dashed 1px #00000033;
    padding: 8px;
}

/* Add star to any label that's paired with a required input */
label.form-label:has(+ input[required])::after,
label.form-label:has(+ select[required])::after,
.form-required {
    content: "*";
    color: var(--veryfi-magenta);
    margin-left: 4px;
}

/* Breadcrumbs */

.text-muted {
    pointer-events: none;
    cursor: not-allowed;
    opacity: 0.6;
}
.text-muted a {
    color: #212529;
    opacity: 0.6;
    text-decoration: none !important;
}

.breadcrumb-item.active {
    font-weight: bold;
    color: var(--veryfi-nav-bg) !important; /* Bootstrap primary color */
}

.breadcrumb-item + .breadcrumb-item::before {
    color: #6c757d; /* Bootstrap secondary color for the separator */
}

/* Campaign Stats Cards */
.campaign-stat-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    transition: color 0.2s ease-in-out;
    color: var(--uikit-text-secondary-color);  /* Back to black */
}

.stat-card {
    opacity: 0;
    transform: translateY(20px);
}

.animate-in {
    animation: cardSlideIn 0.6s ease-out forwards;
}

@keyframes cardSlideIn {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    60% {
        opacity: 1;
        transform: translateY(-10px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.card {
    border: 1px solid white;
    background-color: #FFFFFF99;
}

.card-body {
    padding: 1.5rem;
}

.card-title {
    font-weight: 600;
    font-size: 1.35rem;
    color: var(--uikit-text-secondary-color);  /* Back to black */
}

/* Only show pointer cursor on cards with campaign links */
#statBestCampaign:hover,
#statLeastCampaign:hover {
    cursor: default !important;
}

/* Form Builder */
.dragging {
    opacity: 0.8;
    transform: scale(1.02);
    box-shadow: 0 0 10px rgba(0,0,0,0.2);
}
.drag-handle {
    cursor: move !important;
    padding: 5px;
}
.drag-handle:hover {
    background-color: rgba(0,0,0,0.05);
    border-radius: 4px;
}

/* Notify */
[data-notify="container"] button.close {
    background: transparent;
    border: none;
    color: #98a6ad;
    font-size: 1.25rem;
    line-height: 1;
    border-radius: 50%;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
}

[data-notify="container"] button.close:hover {
    color: #343a40;
    background-color: rgba(0, 0, 0, 0.05);
    transform: scale(1.1);
}

[data-notify="container"] button.close:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1);
}

/* Logo */

#veryfi-leftnav .logo-container {
    background: #fff;
    width: 100%;
    height: 64px;
    position: -webkit-sticky;
    position: -moz-sticky;
    position: -ms-sticky;
    position: -o-sticky;
    position: sticky;
    top: 0;
    padding-left: 32px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    vertical-align: middle;
    text-align: left;
    z-index: 99999;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: all 0.3s ease;
}

#veryfi-logo {
    max-height: 47px !important;
    max-width: 94px !important;
    padding: 5px !important;
    transition: all 0.3s ease;
}

.sidebar-mini #veryfi-leftnav .logo-container {
    padding-left: 5px;
    text-align: center;
    width: var(--sidebar-mini-width);
}

.sidebar-mini #veryfi-logo {
    max-width: 65px !important;
    max-height: 30px !important;
    padding: 0px !important;
}

/* Custom Veryfi Icons */
/* Reference: <i class="veryfi-embedded"></i> */
.veryfi-embedded {
    display: inline-block;
    width: 30px;
    height: 30px;
    background-image: url('/static/img/veryfi-custom-icons/Navigation-Icon_VeryfiEmbedded_White.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.veryfi-workflow-studio {
    display: inline-block;
    width: 30px;
    height: 30px;
    background-image: url('/static/img/veryfi-custom-icons/Navigation-Icon_VeryfiWorkflowStudio_White.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

/* Dropdown Menu Styling - Apply to all dropdowns */
.dropdown-menu {
    border-radius: 1rem !important;
    padding: 0.375rem !important;
    box-shadow: var(--default-box-shadow) !important;
    border: none !important;
    max-height: 500px !important;
    overflow: auto !important;
}

.dropdown-menu .dropdown-item {
    color: var(--uikit-text-color) !important;
    border-radius: 9999px !important;
    padding: 0.5rem 0.75rem !important;
    margin-bottom: 0.125rem !important;
    font-weight: normal !important;
    display: flex !important;
    align-items: center !important;
    text-decoration: none !important;
}

.dropdown-menu .dropdown-item i {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1.25rem !important;
    flex-shrink: 0 !important;
}

.dropdown-menu .dropdown-item span {
    cursor: pointer !important;
}

.dropdown-menu .dropdown-item:last-child {
    margin-bottom: 0 !important;
}

.dropdown-menu .dropdown-divider {
    margin: 0.75rem 0 !important;
}

.dropdown-menu .dropdown-divider + span {
    cursor: pointer !important;
    color: var(--uikit-inactive-color) !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
}


/* Embedded Form Dropdown Styling - Remove uppercase text */

.dropdown-toggle {
    text-transform: none !important;
    text-align: left !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

/* Override for navigation dropdowns to maintain uppercase */
#left-main-nav .dropdown-toggle {
    text-transform: uppercase !important;
    justify-content: left !important;
}

/* Override for navigation dropdowns to maintain uppercase */
#left-main-nav-bottom-section .dropdown-toggle {
    text-transform: uppercase !important;
    justify-content: left !important;
}

.was-validated .form-control:valid {
    padding-right: 0.75rem;
}

/* Universal Dropdown Styling - Remove uppercase text by default */
.dropdown-toggle,
.dropdown-toggle span,
.dropdown-menu .dropdown-item,
.dropdown-menu .dropdown-item span {
    text-transform: none !important;
    text-align: left !important;
}

.dropdown-menu .dropdown-item.active, .dropdown-item:active, .dropdown-item:hover {
    background-color: var(--uikit-text-secondary-color) !important;
    color: var(--uikit-bg-color) !important;
}

/* Dropdown items with custom checkboxes */
.dropdown-menu li {
    margin-bottom: 0.125rem !important;
}

.dropdown-menu li:last-child {
    margin-bottom: 0 !important;
}

.dropdown-menu li label {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 0.75rem !important;
    color: var(--uikit-text-color) !important;
    font-weight: normal !important;
    cursor: pointer !important;
    transition: background-color 0.2s ease !important;
    user-select: none !important;
    line-height: 1.5 !important;
}

.dropdown-menu li label * {
    cursor: pointer !important;
}

/* Dropdown items with checkboxes should have pointer cursor for entire area */
.dropdown-menu li:has(input[type="checkbox"]) {
    cursor: pointer !important;
}

.dropdown-menu li:has(input[type="checkbox"]) * {
    cursor: pointer !important;
}

.dropdown-menu li label:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
}

/* Active state for checked checkboxes using :has() selector */
.dropdown-menu li label:has(input[type="checkbox"]:checked) {
    background-color: var(--uikit-text-secondary-color) !important;
    color: var(--uikit-bg-color) !important;
}

/* Override checkbox colors when parent is active */
.dropdown-menu li label:has(input[type="checkbox"]:checked) input[type="checkbox"] {
    border-color: var(--uikit-bg-color) !important;
    background-color: var(--uikit-bg-color) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e") !important;
    background-size: 100% 100% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* Fallback for browsers that don't support :has() */
.dropdown-menu li.active label,
.dropdown-menu li label.active {
    background-color: var(--uikit-text-secondary-color) !important;
    color: var(--uikit-bg-color) !important;
}

.dropdown-menu li.active label input[type="checkbox"],
.dropdown-menu li label.active input[type="checkbox"] {
    border-color: var(--uikit-bg-color) !important;
    background-color: var(--uikit-bg-color) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e") !important;
    background-size: 100% 100% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.hidden {
    display: none !important;
}

.input-btn-container {
    display: flex;
    gap: 0.5rem;
}

.input-btn-container .btn {
    min-width: fit-content;
}

/* -------------- FLATPICKR -------------- */

.flatpickr-calendar select, .flatpickr-calendar input {
    font-family: var(--nb-international) !important;
    color: var(--veryfi-navy) !important;
}

.flatpickr-calendar input:focus, .flatpickr-calendar input:focus-visible {
    border: none !important;
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
    fill: var(--veryfi-green) !important;
}

.numInputWrapper:hover {
    background: transparent !important;
}

.flatpickr-weekday {
    color: var(--veryfi-navy-medium) !important;
    font-family: var(--nb-international) !important;
}

.flatpickr-day {
    font-family: var(--nb-international) !important;
    color: var(--veryfi-navy) !important;
}

.flatpickr-day:hover, .flatpickr-day.today:hover,
.flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover,
.flatpickr-day.prevMonthDay.today:hover, .flatpickr-day.nextMonthDay.today:hover {
    background: var(--veryfi-navy) !important;
    border-color: var(--veryfi-navy) !important;
    color: white !important;
}

.flatpickr-day.nextMonthDay.today, .flatpickr-day.prevMonthDay.today {
    border-color: var(--veryfi-navy-light) !important;
}

.flatpickr-day.today, .flatpickr-day.today {
    border-color: var(--veryfi-navy) !important;
}

.flatpickr-day.nextMonthDay, .flatpickr-day.prevMonthDay {
    color: var(--veryfi-navy-light) !important;
}

.flatpickr-day.selected {
    color: white !important;
    background: var(--veryfi-green) !important;
    border-color: var(--veryfi-green) !important;
}

.flatpickr-am-pm {
    color: var(--veryfi-navy) !important;
}

.flatpickr-calendar {
    border-radius: var(--default-radius);
    box-shadow: var(--default-box-shadow);
}

.flatpickr-calendar select {
    background-image: none !important;
}

.flatpickr-calendar select:focus {
    border: none !important;
}

.flatpickr-calendar input {
    border: none !important;
}

.flatpickr-next-month, .flatpickr-prev-month {
    display: flex;
}

.flatpickr-calendar.hasTime .flatpickr-time {
    border-top: 1px solid var(--veryfi-ivory-dark);
    margin-top: 0.5rem;
}



.flatpickr-wrapper {
    width: 100%;
    position: relative;
}

.flatpickr-wrapper input.flatpickr-input {
    background: transparent !important;
    color: var(--veryfi-navy) !important;
    padding-right: 2.5rem !important;
}

.was-validated .flatpickr-wrapper input.flatpickr-input.is-valid {
    border-color: var(--veryfi-green) !important;
}

.was-validated .flatpickr-wrapper input.flatpickr-input.is-invalid {
    border-color: var(--veryfi-magenta) !important;
}

.flatpickr-wrapper::after {
    content: '\f073';
    font-family: 'Font Awesome 6 Free', 'Font Awesome 5 Free', 'FontAwesome', sans-serif;
    font-weight: 400;
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--veryfi-navy);
    pointer-events: none;
    z-index: 1;
}

.flatpickr-wrapper input.flatpickr-input.active,
.flatpickr-wrapper input.flatpickr-input:hover,
.flatpickr-wrapper input.flatpickr-input:focus,
.flatpickr-wrapper input.flatpickr-input:focus-visible {
    background: transparent !important;
    color: var(--veryfi-navy) !important; 
    border-color: var(--veryfi-green) !important;
    padding-right: 2.5rem !important;
}

.flatpickr-innerContainer {
    margin-top: 0.25rem;
}



/* Flatpickr button container when moved inside calendar */
.flatpickr-button-container.flatpickr-buttons-integrated {
    position: relative !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    border-top: 1px solid var(--veryfi-ivory-dark) !important;
    padding: 0.75rem 1rem !important;
    background: transparent !important;
    display: flex !important;
    justify-content: flex-end !important;
    gap: 0.5rem !important;
}

/* -------------- END FLATPICKR -------------- */

.badge {
    border-radius: 9999px;
}

.badge.bg-primary {
    background-color: var(--veryfi-green) !important;
    color: white;
}

.badge.bg-secondary {
    background-color: var(--veryfi-navy-medium) !important;
    color: white;
}

.badge.badge-dark {
    background-color: var(--veryfi-forest) !important;
    color: #00FA6C !important;
}

/* Throbber animation with gradient shimmer effect */
@keyframes throbber-shimmer {
    0% {
        background-position: -200px 0;
    }
    100% {
        background-position: 0px 0;
    }
}

.throbber-transition {
    transition: all .25s ease-in-out;
    min-height: 1rem; /* Ensure consistent height during transition */
}

.throbber-transition > * {
    transition: opacity .25s ease-in-out;
}

.throbber {
    background-image: linear-gradient(
        90deg,
        var(--veryfi-navy-light) 10%,
        rgba(112, 116, 143, 0.6) 50%,
        var(--veryfi-navy-light) 90%
    ) !important;
    background-size: 200px 100% !important;
    animation: throbber-shimmer 1s infinite linear !important;
    min-height: 1.25rem !important;
    opacity: 0.4;
    color: transparent !important; /* Hide text content while throbber is active */
    border-radius: var(--default-radius);
    overflow: hidden;
}

/* When throbber class is removed, content appears with transition */
.throbber-transition:not(.throbber) {
    background: transparent !important;
    animation: none !important;
    opacity: 1;
    color: inherit !important;
    height: auto !important;
}

.throbber.throbber-full {
    width: 100%;
} 

.throbber.throbber-75 {
    width: 75%;
}

.throbber.throbber-half {
    width: 50%;
} 

.throbber.throbber-25 {
    width: 25%;
}

.throbber > * {
    opacity: 0 !important;
}

.bg-warning {
    background-color: var(--veryfi-gold) !important;
    color: white !important;
}

.bg-success {
    background-color: var(--veryfi-green) !important;
    color: white !important;
}

.swal2-close {
    text-align: end;
    right: 1rem !important;
    position: absolute;
    top: 1rem !important;
}

/* Left Nav Active Link Styling */
.sidebar .nav li.active > a {
    color: var(--uikit-highlight-color) !important;
    background: none !important;
}
.sidebar .nav li.active > i {
    color: var(--uikit-highlight-color) !important;
}
