.rhythm-planet-panel-layer {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    pointer-events: auto;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 260;
}

#rhythm svg.rhythm #current-info {
    isolation: isolate;
    pointer-events: none;
}

#rhythm svg.rhythm #current-info foreignObject {
    width: 100%;
    height: 100%;
    overflow: visible;
}

#rhythm .current-info-html-overlay {
    position: absolute;
    inset: 0;
    overflow: visible;
    pointer-events: none;
    z-index: 4;
}

#rhythm .current-info-html-overlay.is-visible {
    pointer-events: none;
}

#rhythm svg.rhythm #current-info-text {
    position: relative;
    width: 2000px;
    height: 2000px;
    overflow: visible;
    pointer-events: none;
}

#rhythm .current-info-html-overlay #current-info-text {
    position: absolute;
    left: 50%;
    top: 0;
    width: 1000px;
    height: auto;
    overflow: visible;
    pointer-events: none;
    transform: translateX(-50%) scale(var(--current-info-scale, 1));
    transform-origin: top center;
}

#rhythm svg.rhythm #current-info-text .current-info-inner {
    position: absolute;
    left: 500px;
    top: 500px;
    width: 1000px;
    max-width: 1000px;
    margin: 0;
    text-align: center;
    color: rgba(255, 255, 255, 0.94);
    font-family: Fieldwork, sans-serif;
    opacity: 0;
    pointer-events: none;
    transition: opacity 1s ease;
    box-sizing: border-box;
}

#rhythm .current-info-html-overlay #current-info-text .current-info-inner {
    position: relative;
    width: 1000px;
    max-width: 1000px;
    margin: 0;
    text-align: center;
    color: rgba(255, 255, 255, 0.94);
    font-family: Fieldwork, sans-serif;
    opacity: 0;
    pointer-events: none;
    transition: opacity 1s ease;
    box-sizing: border-box;
}

#rhythm svg.rhythm #current-info.is-visible #current-info-text .current-info-inner,
#rhythm .current-info-html-overlay.is-visible #current-info-text .current-info-inner {
    opacity: 1;
    pointer-events: none;
}

#rhythm svg.rhythm #current-info-text .current-info-inner.is-interpretation .current-info-header,
#rhythm .current-info-html-overlay #current-info-text .current-info-inner.is-interpretation .current-info-header {
    text-align: center;
}

#rhythm svg.rhythm #current-info-text .current-info-header,
#rhythm svg.rhythm #current-info-text .current-info-footer,
#rhythm .current-info-html-overlay #current-info-text .current-info-header,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

#rhythm svg.rhythm #current-info-text .current-info-header,
#rhythm .current-info-html-overlay #current-info-text .current-info-header {
    max-width: 800px;
}

#rhythm svg.rhythm #current-info-text .current-info-footer,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer {
    max-width: 800px;
}

#rhythm svg.rhythm #current-info-text .current-info-body,
#rhythm .current-info-html-overlay #current-info-text .current-info-body {
    width: 100%;
    max-width: 1000px;
    margin: 50px auto 0;
}

#rhythm svg.rhythm #current-info-text .current-info-body + .current-info-footer,
#rhythm .current-info-html-overlay #current-info-text .current-info-body + .current-info-footer {
    margin-top: 18px;
}

#rhythm svg.rhythm #current-info-text .current-info-body p,
#rhythm .current-info-html-overlay #current-info-text .current-info-body p {
    margin-left: auto;
    margin-right: auto;
}

#rhythm svg.rhythm #current-info-text .current-info-header,
#rhythm .current-info-html-overlay #current-info-text .current-info-header {
    gap: 14px;
}

#rhythm svg.rhythm #current-info-text .current-info-body,
#rhythm .current-info-html-overlay #current-info-text .current-info-body {
    gap: 14px;
}

#rhythm svg.rhythm #current-info-text .current-info-footer,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer {
    gap: 10px;
}

#rhythm svg.rhythm #current-info-text .current-info-header,
#rhythm svg.rhythm #current-info-text .current-info-body,
#rhythm svg.rhythm #current-info-text .current-info-footer,
#rhythm .current-info-html-overlay #current-info-text .current-info-header,
#rhythm .current-info-html-overlay #current-info-text .current-info-body,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer {
    display: block;
}

#rhythm svg.rhythm #current-info-text .current-info-header > * + *,
#rhythm svg.rhythm #current-info-text .current-info-body > * + *,
#rhythm svg.rhythm #current-info-text .current-info-footer > * + *,
#rhythm .current-info-html-overlay #current-info-text .current-info-header > * + *,
#rhythm .current-info-html-overlay #current-info-text .current-info-body > * + *,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer > * + * {
    margin-top: 14px;
}

#rhythm svg.rhythm #current-info-text .current-info-title,
#rhythm .current-info-html-overlay #current-info-text .current-info-title {
    font-size: 60px;
    line-height: 1;
    margin: 0;
    padding: 0;
    font-family: inherit;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
}

#rhythm svg.rhythm #current-info-text .current-info-subtitle,
#rhythm .current-info-html-overlay #current-info-text .current-info-subtitle {
    font-size: 40px;
    line-height: 1.1;
    margin: 0;
    padding: 0;
    color: rgba(255, 255, 255, 0.72);
}

#rhythm svg.rhythm #current-info-text .current-info-tabs,
#rhythm .current-info-html-overlay #current-info-text .current-info-tabs {
    display: flex;
    gap: 30px;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 20px;
    pointer-events: auto;
}

#rhythm svg.rhythm #current-info-text .current-info-tab,
#rhythm .current-info-html-overlay #current-info-text .current-info-tab {
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, 0.5);
    padding: 0;
    font-size: 30px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-weight: 800;
    transition: color 0.2s ease, opacity 0.2s ease;
    pointer-events: auto;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

#rhythm svg.rhythm #current-info-text .current-info-tabs,
#rhythm .current-info-html-overlay #current-info-text .current-info-tabs,
#rhythm svg.rhythm #current-info-text .current-info-header button,
#rhythm .current-info-html-overlay #current-info-text .current-info-header button,
#rhythm svg.rhythm #current-info-text .current-info-body button,
#rhythm .current-info-html-overlay #current-info-text .current-info-body button,
#rhythm svg.rhythm #current-info-text .current-info-footer button,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer button,
#rhythm svg.rhythm #current-info-text .current-info-close,
#rhythm .current-info-html-overlay #current-info-text .current-info-close,
#rhythm svg.rhythm #current-info-text [role="button"],
#rhythm .current-info-html-overlay #current-info-text [role="button"],
#rhythm svg.rhythm #current-info-text a,
#rhythm .current-info-html-overlay #current-info-text a {
    pointer-events: auto;
}

#rhythm svg.rhythm #current-info-text .current-info-tab.is-active,
#rhythm svg.rhythm #current-info-text .current-info-tab:hover,
#rhythm svg.rhythm #current-info-text .current-info-tab:focus-visible,
#rhythm .current-info-html-overlay #current-info-text .current-info-tab.is-active,
#rhythm .current-info-html-overlay #current-info-text .current-info-tab:hover,
#rhythm .current-info-html-overlay #current-info-text .current-info-tab:focus-visible {
    color: #fff;
}

#rhythm svg.rhythm #current-info-text .current-info-icon,
#rhythm .current-info-html-overlay #current-info-text .current-info-icon {
    width: auto;
    margin: 20px auto;
    pointer-events: none;
}

#rhythm svg.rhythm #current-info-text .current-info-icon svg,
#rhythm svg.rhythm #current-info-text .current-info-icon img,
#rhythm svg.rhythm #current-info-text .current-info-icon .current-info-icon-svg,
#rhythm svg.rhythm #current-info-text .current-info-icon .rhythm-planet-panel__icon-svg,
#rhythm .current-info-html-overlay #current-info-text .current-info-icon svg,
#rhythm .current-info-html-overlay #current-info-text .current-info-icon img,
#rhythm .current-info-html-overlay #current-info-text .current-info-icon .current-info-icon-svg,
#rhythm .current-info-html-overlay #current-info-text .current-info-icon .rhythm-planet-panel__icon-svg {
    width: 120px !important;
    height: 120px !important;
    display: block;
    margin: 0 auto;
}

#rhythm svg.rhythm #current-info-text .current-info-footer:empty,
#rhythm svg.rhythm #current-info-text .current-info-body:empty,
#rhythm .current-info-html-overlay #current-info-text .current-info-footer:empty,
#rhythm .current-info-html-overlay #current-info-text .current-info-body:empty {
    display: none;
}

#trop #current-info-text p,
#true #current-info-text p,
#rhythm .current-info-html-overlay #current-info-text p {
    margin: 0;
    font-size: 30px;
    line-height: 1.5;
    color: rgba(233, 233, 237, 0.92);
}

#rhythm svg.rhythm #current-info-text strong,
#rhythm .current-info-html-overlay #current-info-text strong {
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-weight: 700;
    color: #fff;
}

#rhythm svg.rhythm #current-info-hit {
    fill: rgba(255, 255, 255, 0.001);
    opacity: 0;
    pointer-events: none;
}

#rhythm svg.rhythm #current-info.is-button-visible #current-info-hit {
    pointer-events: all;
    cursor: pointer;
}

#rhythm svg.rhythm #current-info.is-button-visible #current-info-hit:hover {
    opacity: 0.04;
}

.rhythm-planet-panel {
    position: relative;
    width: min(90vw, 680px);
    max-width: 90vw;
    min-height: min(620px, 80vh);
    max-height: 80vh;
    overflow: hidden;
    padding: 32px 32px 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    pointer-events: auto;
    text-align: center;
    font-family: Fieldwork, sans-serif;
    color: #fff;
    border-radius: 12px;
    background: #2a2a2d;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
}

.rhythm-planet-panel__close {
    position: absolute;
    top: 12px;
    right: 12px;
    display: block;
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, 0.72);
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 4px;
    z-index: 3;
}

.rhythm-planet-panel__close:hover,
.rhythm-planet-panel__close:focus-visible {
    color: #fff;
}

.rhythm-planet-panel__title {
    position: relative;
    z-index: 2;
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-size: clamp(24px, 2.2vw, 34px);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    line-height: 1.1;
    margin-top: 0;
}

.rhythm-planet-panel__subtitle {
    position: relative;
    z-index: 2;
    font-family: Fieldwork, sans-serif;
    font-size: clamp(14px, 1.4vw, 18px);
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.72);
    width: 100%;
    max-width: none;
    margin-top: -4px;
}

.rhythm-planet-panel__tabs {
    position: relative;
    z-index: 2;
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 24px;
}

.rhythm-planet-panel__tab {
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, 0.5);
    padding: 0;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-weight: 800;
    transition: color 0.2s ease, opacity 0.2s ease;
}

.rhythm-planet-panel__tab.is-active {
    color: #fff;
}

.iam-essence-text p {
    font-size: 48px !important;
    padding: 40px 0px !important;
}

.iam-essence-jewel p {
    font-size: 60px !important;
}

.rhythm-planet-panel__body {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: none;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 20px;
    padding: 8px 0 0;
    align-self: stretch;
}

.rhythm-planet-panel__section {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    font-size: clamp(15px, 1.18vw, 18px);
    line-height: 1.62;
    opacity: 0.97;
}

.rhythm-planet-panel__section--narrow {
    max-width: none;
}

.rhythm-planet-panel__section--wide {
    max-width: none;
}

.rhythm-planet-panel__section--bottom {
    max-width: none;
}

.rhythm-planet-panel__section-title {
    display: none;
}

.rhythm-planet-panel__section p {
    margin: 0;
}

.rhythm-planet-panel__section p + p {
    margin-top: 10px;
}

.rhythm-planet-panel__list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.rhythm-planet-panel__list-title {
    display: block;
    margin-bottom: 6px;
    font-family: Fieldwork-HumBold, Fieldwork, sans-serif;
    font-size: 30px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.5);
}

.rhythm-planet-panel__list li + li {
    margin-top: 4px;
}

.rhythm-planet-panel__traits-inline {
    margin: 0;
}

.rhythm-planet-panel__aspect-orb {
    color: rgba(255, 255, 255, 0.66);
}

.rhythm-planet-panel__aspect--compact {
    margin-bottom: 20px;
}

.rhythm-planet-panel__aspect-type {
    font-size: 18px;
    line-height: 1.05;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    text-align: center;
    color: rgba(255, 255, 255, 0.46);
}

.rhythm-planet-panel__aspect-line {
    margin-top: 40px !important;
    font-size: 26px;
    line-height: 1.1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    color: rgba(255, 255, 255, 1);
    font-size: 40px !important;
    font-weight: 700;
}

.rhythm-planet-panel__aspect-note {
    margin-top: -44px !important;
    font-size: 30px !important;
    line-height: 1.2;
    letter-spacing: 0.02em;
    text-transform: none;
    text-align: center;
    color: rgba(255, 255, 255, 0.4) !important;
}

.trait-divider {
    opacity: 0.45;
    padding: 0 0.45em;
}

.rhythm-planet-panel__icon {
    position: relative;
    opacity: 1;
    width: auto;
    min-height: 0;
    pointer-events: none;
    z-index: 2;
    margin: 0 auto 6px;
}

.rhythm-planet-panel__icon-svg {
    width: clamp(48px, 6vw, 68px) !important;
    height: clamp(48px, 6vw, 68px) !important;
    display: block;
    margin: 0 auto;
    overflow: visible;
    transform: rotate(90deg);
    transform-origin: center center;
    opacity: 1;
    pointer-events: none;
}

#trop-house-btns [id^="btn-"],
#true-house-btns [id^="btn-"] {
    pointer-events: all;
    cursor: pointer;
}

#rhythm #true-in,
#rhythm #trop-in {
    transition: opacity 2s ease;
}

#true-in #main .rhythm, #trop-in #main .rhythm {
    width: 90%;
}

#true-in #main .rhythm #houses, #trop-in #main .rhythm  #houses {
    transform-origin: center;
}

#rhythm .rhythm-compare-inner-hidden {
    opacity: 0;
    pointer-events: none;
}

#trop-house-btns [id^="btn-"]:hover,
#true-house-btns [id^="btn-"]:hover {
    opacity: 0.92;
}

#trop-house-btns,
#true-house-btns {
    pointer-events: all;
}

#rhythm #houses > g:first-child,
#rhythm #houses > circle,
#rhythm #houses #num,
#rhythm #houses #num * {
    pointer-events: none;
}

body.rhythm-planet-panel-open {
    overflow: hidden;
}

:root {
    --iam-ui-offset: clamp(16px, 2.2vw, 24px);
    --iam-ui-gap: 12px;
    --iam-ui-hamburger-z: 110;
}

.iam-local-controls,
.iam-local-header {
    position: fixed;
    top: var(--iam-ui-offset);
    left: var(--iam-ui-offset);
    right: auto;
    z-index: 90;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--iam-ui-gap);
    max-width: min(calc(100vw - 128px), 980px);
}

.iam-local-controls__bar {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 0 0 auto;
    align-self: flex-start;
}

.iam-local-controls__logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(108px, 12vw, 156px);
    pointer-events: auto;
}

.iam-local-controls__logo img {
    display: block;
    width: 100%;
    height: auto;
}

.iam-local-controls__toggle {
    appearance: none;
    border: 0;
    background: rgba(20, 20, 24, 0.82);
    color: #f4f4f4;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

.iam-local-controls__toggle svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.compass-local-header {
    pointer-events: none;
}

.compass-local-header .iam-local-controls__logo {
    pointer-events: auto;
}

#rhythm-local-controls #rhythm-topbar,
#rhythm-topbar {
    position: relative;
    z-index: 50;
    display: none;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    align-items: center;
    gap: 12px;
    flex-wrap: nowrap;
    justify-content: flex-start;
    flex: 0 0 auto;
    min-width: 0;
    align-self: flex-start;
    margin-top: -2px;
}

.rhythm-local-controls.is-open #rhythm-topbar {
    display: flex;
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

#blueprint-local-controls #blueprint-topbar,
#blueprint-topbar {
    position: relative;
    z-index: 50;
    display: none;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    align-items: center;
    gap: 12px;
    flex-wrap: nowrap;
    justify-content: flex-start;
    flex: 0 0 auto;
    min-width: 0;
    align-self: flex-start;
    margin-top: -2px;
}

.blueprint-local-controls.is-open #blueprint-topbar {
    display: flex;
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.rhythm-nav-group {
    position: relative;
    flex: 0 0 auto;
}

.blueprint-nav-group {
    position: relative;
    flex: 0 0 auto;
}

.rhythm-nav-btn {
    font-family: 'fieldwork', sans-serif;
    appearance: none;
    border: 0;
    background: rgba(20, 20, 24, 0.82);
    color: rgba(255, 255, 255, 0.82);
    padding: 11px 16px;
    font-size: 16px;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
    min-height: 38px;
    border-radius: 5px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

.blueprint-nav-btn {
    font-family: 'fieldwork', sans-serif;
    appearance: none;
    border: 0;
    background: rgba(20, 20, 24, 0.82);
    color: rgba(255, 255, 255, 0.82);
    padding: 11px 16px;
    font-size: 16px;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
    min-height: 38px;
    border-radius: 5px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

.rhythm-nav-btn:hover,
.rhythm-nav-btn.is-open,
.blueprint-nav-btn:hover,
.blueprint-nav-btn.is-open,
.iam-local-controls__toggle:hover,
.iam-local-controls.is-open .iam-local-controls__toggle {
    background: rgba(230, 230, 230, 0.16);
    color: #fff;
}

.rhythm-menu {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 180px;
    background: rgba(18, 18, 22, 0.96);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 10px 30px rgba(0,0,0,0.35);
    width: 320px;
    max-width: min(82vw, 320px);
    padding: 14px;
    border-radius: 5px;
}

.rhythm-menu.is-open {
    display: block;
}

.blueprint-menu {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 180px;
    background: rgba(18, 18, 22, 0.96);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 10px 30px rgba(0,0,0,0.35);
    width: 320px;
    max-width: min(82vw, 320px);
    padding: 14px;
    border-radius: 5px;
}

.blueprint-menu.is-open {
    display: block;
}

.rhythm-option {
    display: block;
    width: 100%;
    border: 0;
    background: transparent;
    color: rgba(255,255,255,0.78);
    text-align: left;
    padding: 12px 16px;
    font-size: 18px;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
    border-radius: 5px;
}

.rhythm-option:hover,
.rhythm-option.active {
    background: rgba(255,255,255,0.08);
    color: #fff;
}

#rhythm .rhythm-lilith-hit {
    fill: transparent;
}

#rhythm .iam-extra-body {
    pointer-events: auto;
}

#rhythm .iam-extra-body.is-hidden,
#rhythm .rhythm-lilith.is-hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

#rhythm .rhythm-lilith-symbol,
#rhythm .rhythm-lilith-center-symbol .rhythm-lilith-symbol {
    fill: none;
    stroke: rgba(242, 242, 242, 0.96);
    stroke-width: 3.4;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
}

#rhythm .rhythm-lilith-center-icon {
    width: 120px;
    height: 120px;
    display: block;
    margin: 0 auto;
}

.blueprint-option {
    display: block;
    width: 100%;
    border: 0;
    background: transparent;
    color: rgba(255,255,255,0.78);
    text-align: left;
    padding: 12px 16px;
    font-size: 18px;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
    border-radius: 5px;
}

.blueprint-option:hover,
.blueprint-option.active {
    background: rgba(255,255,255,0.08);
    color: #fff;
}

#rhythm {
    position: relative;
    width: 100%;
}

#rhythm.container {
    max-width: 1080px !important;
}

#rhythm #true,
#rhythm #trop,
#rhythm #true-in,
#rhythm #trop-in {
    display: none;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 2s ease;
}

#rhythm #true.is-active,
#rhythm #trop.is-active,
#rhythm #true-in.is-active,
#rhythm #trop-in.is-active {
    display: block;
    visibility: visible;
    opacity: 1;
    pointer-events: none;
}

#rhythm #true.is-fading-out,
#rhythm #trop.is-fading-out,
#rhythm #true-in.is-fading-out,
#rhythm #trop-in.is-fading-out {
    display: block;
    visibility: visible;
    opacity: 0;
    pointer-events: none;
}

#rhythm #true.is-hidden,
#rhythm #trop.is-hidden,
#rhythm #true-in.is-hidden,
#rhythm #trop-in.is-hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

#rhythm #true-in.is-active,
#rhythm #trop-in.is-active {
    z-index: 3;
}


#rhythm #flex-box {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100svh;
    
    box-sizing: border-box;
}

#rhythm #flex-main {
    width: min(calc(100svh), calc(100vw));
    margin: 0 auto;
}

#mobile_menu1 {
    top: 38px;
    background-color: #161616 !important;
    border-top: 3px solid #252525;
}
#mobile_menu1 .sub-menu {
    background-color: #161616 !important;
}

body.iam-besource-app-page #divi-menu,
body.iam-besource-pmpro-page #divi-menu {
    display: none !important;
}

body.page-id-21 #divi-menu .mobile_menu_bar:before,
body.parent-pageid-21 #divi-menu .mobile_menu_bar:before,
body.page-id-21 #divi-menu.et_pb_menu .mobile_menu_bar:before,
body.parent-pageid-21 #divi-menu.et_pb_menu .mobile_menu_bar:before,
body.page-id-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar:before,
body.parent-pageid-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar:before {
    color: #d8d8d8 !important;
}

body.page-id-21 #divi-menu .mobile_menu_bar:hover:before,
body.parent-pageid-21 #divi-menu .mobile_menu_bar:hover:before,
body.page-id-21 #divi-menu.et_pb_menu .mobile_menu_bar:hover:before,
body.parent-pageid-21 #divi-menu.et_pb_menu .mobile_menu_bar:hover:before,
body.page-id-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar:hover:before,
body.parent-pageid-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar:hover:before,
body.page-id-21 #divi-menu .mobile_menu_bar.et_pb_menu_toggle_open:before,
body.parent-pageid-21 #divi-menu .mobile_menu_bar.et_pb_menu_toggle_open:before,
body.page-id-21 #divi-menu.et_pb_menu .mobile_menu_bar.et_pb_menu_toggle_open:before,
body.parent-pageid-21 #divi-menu.et_pb_menu .mobile_menu_bar.et_pb_menu_toggle_open:before,
body.page-id-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar.et_pb_menu_toggle_open:before,
body.parent-pageid-21 #divi-menu.et_pb_fullwidth_menu .mobile_menu_bar.et_pb_menu_toggle_open:before {
    color: #ffffff !important;
}

body.page-id-21 #divi-menu .et_mobile_nav_menu,
body.parent-pageid-21 #divi-menu .et_mobile_nav_menu,
body.page-id-21 #divi-menu .mobile_nav,
body.parent-pageid-21 #divi-menu .mobile_nav {
    position: static;
}

body.page-id-21 #divi-menu .mobile_menu_bar,
body.parent-pageid-21 #divi-menu .mobile_menu_bar {
    position: fixed;
    top: var(--iam-ui-offset);
    right: var(--iam-ui-offset);
    z-index: var(--iam-ui-hamburger-z);
    padding: 0;
}

body.page-id-21 #divi-menu .et_mobile_menu,
body.parent-pageid-21 #divi-menu .et_mobile_menu {
    position: fixed;
    top: calc(var(--iam-ui-offset) + 34px);
    right: var(--iam-ui-offset);
    left: auto !important;
    width: min(300px, calc(100vw - (var(--iam-ui-offset) * 2)));
    max-height: calc(100vh - (var(--iam-ui-offset) + 56px));
    overflow-y: auto;
    z-index: calc(var(--iam-ui-hamburger-z) - 1);
}

body.page-id-21 #divi-menu .mobile_menu_bar:before,
body.parent-pageid-21 #divi-menu .mobile_menu_bar:before {
    display: block;
    line-height: 1;
}

@media (max-width: 900px) {
    .iam-local-controls,
    .iam-local-header {
        top: 12px;
        left: 12px;
        right: 12px;
        max-width: none;
    }

    .iam-local-controls {
        flex-direction: column;
        align-items: flex-start;
    }

    .iam-local-controls__bar {
        gap: 10px;
    }

    .iam-local-controls__logo {
        width: clamp(92px, 28vw, 128px);
    }

    #rhythm-topbar,
    #blueprint-topbar {
        gap: 8px;
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .rhythm-nav-btn,
    .blueprint-nav-btn {
        font-size: 13px;
        padding: 10px 14px;
        min-height: 34px;
    }

    .rhythm-nav-group,
    .blueprint-nav-group {
        flex: 0 0 auto;
    }

    .rhythm-menu,
    .blueprint-menu {
        width: min(86vw, 320px);
        max-width: min(86vw, 320px);
    }

    body.page-id-21 #divi-menu .mobile_menu_bar,
    body.parent-pageid-21 #divi-menu .mobile_menu_bar {
        top: 12px;
        right: 12px;
    }

    body.page-id-21 #divi-menu .et_mobile_menu,
    body.parent-pageid-21 #divi-menu .et_mobile_menu {
        top: 44px;
        right: 12px;
        width: min(300px, calc(100vw - 24px));
        max-height: calc(100vh - 56px);
    }

    #rhythm #flex-box {
        align-items: flex-start;
        padding: 74px 10px 12px;
    }

    #rhythm #flex-main {
        width: min(calc(100vw - 12px), calc(100svh - 86px));
        margin-top: 0;
    }

    .rhythm-planet-panel {
        width: min(90vw, 620px);
        max-width: 90vw;
        min-height: min(620px, 80vh);
        max-height: 80vh;
        padding: 28px 22px 24px;
        row-gap: 10px;
    }

    .rhythm-planet-panel__title {
        font-size: clamp(20px, 4.8vw, 28px);
    }

    .rhythm-planet-panel__tabs {
        gap: 14px;
        margin-bottom: 22px;
    }

    .rhythm-planet-panel__body {
        gap: 16px;
        padding-top: 6px;
    }

    .rhythm-planet-panel__section--narrow,
    .rhythm-planet-panel__section--wide,
    .rhythm-planet-panel__section--bottom {
        max-width: none;
    }

    .rhythm-planet-panel__icon-svg {
        width: clamp(44px, 8vw, 60px) !important;
        height: clamp(44px, 8vw, 60px) !important;
    }
}

.besource-login {
    min-height: 100vh;
    padding: clamp(32px, 6vw, 72px) 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #212121;
    color: #f0f0f0;
    font-family: "Fieldwork", sans-serif;
}

.besource-login__card {
    width: min(100%, 520px);
    padding: clamp(28px, 5vw, 48px);
    border-radius: 6px;
    background: #2a2a2a;
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.besource-login__brand {
    margin-bottom: 24px;
    text-align: center;
}

.besource-login__logo {
    display: block;
    width: min(220px, 56vw);
    margin: 0 auto 22px;
}

.besource-login--signin .besource-login__brand {
    margin-bottom: 18px;
}

.besource-login--signin .besource-login__logo {
    margin-bottom: 28px;
    animation: besourceLogoBreath 6s ease-in-out infinite alternate;
    transform-origin: center;
}

@keyframes besourceLogoBreath {
    0% {
        opacity: 0.82;
        transform: scale(1);
    }
    100% {
        opacity: 1;
        transform: scale(1.015);
    }
}

@media (prefers-reduced-motion: reduce) {
    .besource-login--signin .besource-login__logo {
        animation: none;
    }
}

.besource-login__eyebrow {
    margin-bottom: 12px;
    color: rgba(255, 255, 255, 0.54);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.26em;
    text-transform: uppercase;
}

.besource-login__title {
    margin: 0 0 12px;
    color: #ffffff;
    font-size: clamp(30px, 5vw, 42px);
    line-height: 0.98;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.besource-login__intro {
    margin: 0 auto;
    max-width: 28ch;
    color: rgba(255, 255, 255, 0.72);
    font-size: 18px;
    line-height: 1.55;
}

.besource-login__message {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 6px;
    font-size: 15px;
    line-height: 1.45;
}

.besource-login__message--error {
    background: rgba(133, 34, 34, 0.28);
    border: 1px solid rgba(255, 112, 112, 0.28);
    color: #ffe0e0;
}

.besource-login__message--success {
    background: rgba(63, 104, 75, 0.26);
    border: 1px solid rgba(147, 211, 166, 0.24);
    color: #e5ffe8;
}

.besource-login__form {
    display: grid;
    gap: 18px;
}

.besource-login__footer-links {
    display: flex;
    justify-content: center;
    margin-top: 6px;
}

.besource-login__field {
    display: grid;
    gap: 8px;
}

.besource-login__label {
    color: rgba(255, 255, 255, 0.8);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.besource-login__input {
    width: 100%;
    min-height: 56px;
    padding: 0 18px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    background: #2f2f2f;
    color: #f2f2f2;
    font-size: 18px;
    line-height: 1.2;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.besource-login__input:focus {
    outline: none;
    border-color: rgba(255, 255, 255, 0.28);
    background: #343434;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.08);
}

.besource-login input,
.besource-login__input,
.besource-login__input:focus,
.besource-login__input:active,
.besource-login__input:hover {
    color: #f2f2f2;
    caret-color: #ffffff;
}

.besource-login input::placeholder,
.besource-login__input::placeholder {
    color: rgba(255, 255, 255, 0.45);
}

.besource-login input:-webkit-autofill,
.besource-login input:-webkit-autofill:hover,
.besource-login input:-webkit-autofill:focus,
.besource-login input:-webkit-autofill:active,
.besource-login__input:-webkit-autofill,
.besource-login__input:-webkit-autofill:hover,
.besource-login__input:-webkit-autofill:focus,
.besource-login__input:-webkit-autofill:active {
    -webkit-text-fill-color: #f2f2f2 !important;
    caret-color: #ffffff;
    transition: background-color 9999s ease-in-out 0s;
    box-shadow: 0 0 0 1000px #2a2a2a inset;
}

.besource-login__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.besource-login__remember {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: rgba(255, 255, 255, 0.76);
    font-size: 15px;
}

.besource-login__remember input {
    width: 18px;
    height: 18px;
    margin: 0;
}

.besource-login__link {
    color: rgba(255, 255, 255, 0.8);
    font-size: 15px;
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.22);
    transition: color 0.2s ease, border-color 0.2s ease;
}

.besource-login__link:hover,
.besource-login__link:focus {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.56);
}

.besource-login__submit {
    min-height: 58px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    background: #2f2f2f;
    color: #e8e8e8;
    font-family: inherit;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.besource-login__submit:hover,
.besource-login__submit:focus {
    transform: translateY(-1px);
    background: #343434;
    border-color: rgba(255, 255, 255, 0.28);
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

@media (max-width: 640px) {
    .besource-login__card {
        padding: 26px 20px 24px;
        border-radius: 6px;
    }

    .besource-login__intro {
        font-size: 16px;
    }

    .besource-login__input {
        min-height: 52px;
        font-size: 17px;
    }

    .besource-login__meta {
        align-items: flex-start;
        flex-direction: column;
    }
}

.besource-account {
    min-height: 100vh;
    padding: clamp(24px, 4vw, 48px) 20px;
    background: #212121;
    color: #f0f0f0;
    font-family: "Fieldwork", sans-serif;
}

body.iam-besource-account-page,
body.iam-besource-account-page #main-content,
body.iam-besource-account-page #page-container {
    background: #212121;
}

body.iam-besource-pmpro-page,
body.iam-besource-pmpro-page #main-content,
body.iam-besource-pmpro-page #page-container {
    background: #212121;
}

body.iam-besource-account-page .entry-title {
    display: none;
}

body.iam-besource-pmpro-page .entry-title {
    display: none;
}

body.iam-besource-account-page #main-content > .container {
    width: 100%;
    max-width: none;
    padding-top: 0 !important;
}

body.iam-besource-pmpro-page #main-content > .container {
    width: 100%;
    max-width: none;
    padding-top: 0 !important;
}

body.iam-besource-account-page #content-area {
    width: 100%;
    max-width: none;
    padding: 0;
}

body.iam-besource-pmpro-page #content-area {
    width: 100%;
    max-width: none;
    padding: 0;
}

body.iam-besource-account-page #left-area {
    float: none;
    width: 100%;
    margin: 0;
    padding: 0;
}

body.iam-besource-pmpro-page #left-area {
    float: none;
    width: 100%;
    margin: 0;
    padding: 0;
}

body.iam-besource-account-page #sidebar,
body.iam-besource-account-page .et_right_sidebar #sidebar,
body.iam-besource-account-page .et_left_sidebar #sidebar {
    display: none;
}

body.iam-besource-pmpro-page #sidebar,
body.iam-besource-pmpro-page .et_right_sidebar #sidebar,
body.iam-besource-pmpro-page .et_left_sidebar #sidebar {
    display: none;
}

body.iam-besource-account-page .et_right_sidebar #left-area,
body.iam-besource-account-page .et_left_sidebar #left-area {
    float: none;
    width: 100%;
    padding: 0;
}

body.iam-besource-pmpro-page .et_right_sidebar #left-area,
body.iam-besource-pmpro-page .et_left_sidebar #left-area {
    float: none;
    width: 100%;
    padding: 0;
}

body.iam-besource-account-page #left-area .post-meta,
body.iam-besource-account-page #left-area .entry-featured-image-url,
body.iam-besource-account-page #left-area .et_post_meta_wrapper {
    display: none;
}

body.iam-besource-pmpro-page #left-area .post-meta,
body.iam-besource-pmpro-page #left-area .entry-featured-image-url,
body.iam-besource-pmpro-page #left-area .et_post_meta_wrapper {
    display: none;
}

body.iam-besource-account-page #left-area .entry-content {
    padding-top: 0;
}

body.iam-besource-pmpro-page #left-area .entry-content {
    padding-top: 0;
    background: transparent !important;
    box-shadow: none !important;
}

body.iam-besource-account-page #left-area .entry-content > .besource-account {
    margin: 0;
}

body.iam-besource-pmpro-page .et_pb_section,
body.iam-besource-pmpro-page .et_pb_row,
body.iam-besource-pmpro-page .et_pb_column,
body.iam-besource-pmpro-page .entry-content,
body.iam-besource-pmpro-page article,
body.iam-besource-pmpro-page .post,
body.iam-besource-pmpro-page .page,
body.iam-besource-pmpro-page .et_pb_post,
body.iam-besource-pmpro-page .pmpro,
body.iam-besource-pmpro-page .pmpro_member_profile_edit_wrap,
body.iam-besource-pmpro-page .pmpro_section,
body.iam-besource-pmpro-page .pmpro_section_content,
body.iam-besource-pmpro-page .pmpro_form {
    background: transparent !important;
    box-shadow: none !important;
}

.besource-pmpro {
    min-height: 100vh;
    padding: clamp(24px, 4vw, 48px) 20px;
    background: transparent;
    color: #f0f0f0;
    font-family: "Fieldwork", sans-serif;
}

.besource-pmpro__shell {
    width: min(100%, 1040px);
    margin: 0 auto;
}

.besource-pmpro .pmpro,
.besource-pmpro .pmpro_account,
.besource-pmpro .pmpro_checkout,
.besource-pmpro .pmpro_form,
.besource-pmpro [class*="pmpro_"] {
    color: #f0f0f0;
    font-family: "Fieldwork", sans-serif;
}

.besource-pmpro .pmpro h1,
.besource-pmpro .pmpro h2,
.besource-pmpro .pmpro h3,
.besource-pmpro .pmpro h4,
.besource-pmpro .pmpro legend,
.besource-pmpro .pmpro .pmpro_card_title,
.besource-pmpro .pmpro .pmpro_section_title {
    color: #ffffff;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.besource-pmpro .pmpro p,
.besource-pmpro .pmpro li,
.besource-pmpro .pmpro label,
.besource-pmpro .pmpro td,
.besource-pmpro .pmpro th,
.besource-pmpro .pmpro span,
.besource-pmpro .pmpro small {
    color: rgba(255, 255, 255, 0.82);
}

.besource-pmpro .pmpro label {
    color: #e8e8e8;
}

.besource-pmpro .pmpro .lite,
.besource-pmpro .pmpro .description,
.besource-pmpro .pmpro .pmpro_form_hint,
.besource-pmpro .pmpro small {
    color: #b8b8b8;
}

.besource-pmpro .pmpro a {
    color: #d8d8d8;
}

.besource-pmpro .pmpro a:hover,
.besource-pmpro .pmpro a:focus {
    color: #ffffff;
}

.besource-pmpro .pmpro_section,
.besource-pmpro .pmpro_card,
.besource-pmpro .pmpro_checkout_gateway,
.besource-pmpro .pmpro_checkout,
.besource-pmpro .pmpro_checkout-fields,
.besource-pmpro .pmpro_confirmation,
.besource-pmpro .pmpro_form_fieldset,
.besource-pmpro .pmpro_message,
.besource-pmpro .pmpro_table,
.besource-pmpro .pmpro_invoice,
.besource-pmpro .pmpro_member_profile_edit_wrap,
.besource-pmpro .pmpro_form,
.besource-pmpro .pmpro_section_content,
.besource-pmpro .pmpro_levels .pmpro_level {
    background: #2a2a2a;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 6px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.besource-pmpro .pmpro_card,
.besource-pmpro .pmpro_checkout,
.besource-pmpro .pmpro_checkout-fields,
.besource-pmpro .pmpro_confirmation,
.besource-pmpro .pmpro_message,
.besource-pmpro .pmpro_form_fieldset,
.besource-pmpro .pmpro_checkout_gateway,
.besource-pmpro .pmpro_member_profile_edit_wrap,
.besource-pmpro .pmpro_form,
.besource-pmpro .pmpro_section_content,
.besource-pmpro .pmpro_levels .pmpro_level,
.besource-pmpro .pmpro_invoice {
    padding: 22px 20px;
}

.besource-pmpro .pmpro_section {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.besource-pmpro .pmpro_member_profile_edit_wrap .pmpro_form_fieldset,
.besource-pmpro .pmpro_checkout .pmpro_checkout-fields,
.besource-pmpro .pmpro_checkout .pmpro_checkout_gateway,
.besource-pmpro .pmpro_checkout,
.besource-pmpro .pmpro_form {
    padding: 32px 28px;
}

.besource-pmpro .pmpro_section + .pmpro_section {
    margin-top: 24px;
}

.besource-pmpro .pmpro_levels .pmpro_level + .pmpro_level,
.besource-pmpro .pmpro_checkout .pmpro_section + .pmpro_section,
.besource-pmpro .pmpro_confirmation > * + *,
.besource-pmpro .pmpro_invoice > * + * {
    margin-top: 24px;
}

.besource-pmpro .pmpro_levels,
.besource-pmpro .pmpro_checkout,
.besource-pmpro .pmpro_confirmation,
.besource-pmpro .pmpro_invoice {
    max-width: 1040px;
    margin-left: auto;
    margin-right: auto;
}

.besource-pmpro .pmpro_levels .pmpro_section,
.besource-pmpro .pmpro_checkout .pmpro_section {
    background: transparent;
    border: 0;
    box-shadow: none;
}

.besource-pmpro .pmpro_levels .pmpro_section_content,
.besource-pmpro .pmpro_checkout .pmpro_section_content {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}

body.iam-besource-pmpro-page,
body.iam-besource-pmpro-page #main-content,
body.iam-besource-pmpro-page #page-container,
body.iam-besource-pmpro-page .entry-content,
body.iam-besource-pmpro-page .post,
body.iam-besource-pmpro-page .page,
body.iam-besource-pmpro-page article {
    background: #212121 !important;
}

body.iam-besource-pmpro-page .pmpro,
body.iam-besource-pmpro-page .pmpro_form,
body.iam-besource-pmpro-page .pmpro_checkout,
body.iam-besource-pmpro-page .pmpro_section,
body.iam-besource-pmpro-page .pmpro_card,
body.iam-besource-pmpro-page .pmpro_checkout_gateway,
body.iam-besource-pmpro-page .pmpro_levels .pmpro_level,
body.iam-besource-pmpro-page .pmpro_invoice,
body.iam-besource-pmpro-page .pmpro_confirmation,
body.iam-besource-pmpro-page .pmpro_message,
body.iam-besource-pmpro-page .pmpro_card_content,
body.iam-besource-pmpro-page .pmpro_form_fieldset,
body.iam-besource-pmpro-page .pmpro_checkout_gateway-paypalstandard {
    color: #e8e8e8 !important;
}

body.iam-besource-pmpro-page .besource-levels__card,
body.iam-besource-pmpro-page .pmpro_levels .pmpro_level,
body.iam-besource-pmpro-page .pmpro_card,
body.iam-besource-pmpro-page .pmpro_checkout,
body.iam-besource-pmpro-page .pmpro_section.pmpro_checkout_gateway-paypalstandard,
body.iam-besource-pmpro-page .pmpro_invoice,
body.iam-besource-pmpro-page .pmpro_confirmation,
body.iam-besource-pmpro-page .pmpro_message {
    background: #2a2a2a !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 6px !important;
    box-shadow: none !important;
}

body.iam-besource-pmpro-page .pmpro_card,
body.iam-besource-pmpro-page .pmpro_levels .pmpro_level,
body.iam-besource-pmpro-page .pmpro_checkout,
body.iam-besource-pmpro-page .pmpro_section.pmpro_checkout_gateway-paypalstandard,
body.iam-besource-pmpro-page .pmpro_invoice,
body.iam-besource-pmpro-page .pmpro_confirmation {
    padding: 28px !important;
}

body.iam-besource-pmpro-page .pmpro_card_content,
body.iam-besource-pmpro-page .pmpro_form_fieldset,
body.iam-besource-pmpro-page .pmpro_section_content {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
}

body.iam-besource-pmpro-page .pmpro h2,
body.iam-besource-pmpro-page .pmpro h3,
body.iam-besource-pmpro-page .pmpro h4,
body.iam-besource-pmpro-page .pmpro_card_title,
body.iam-besource-pmpro-page .pmpro_form_heading,
body.iam-besource-pmpro-page .pmpro_checkout h2,
body.iam-besource-pmpro-page .pmpro_checkout h3,
body.iam-besource-pmpro-page .pmpro_checkout h4 {
    color: #ffffff !important;
}

body.iam-besource-pmpro-page .pmpro p,
body.iam-besource-pmpro-page .pmpro li,
body.iam-besource-pmpro-page .pmpro label,
body.iam-besource-pmpro-page .pmpro span,
body.iam-besource-pmpro-page .pmpro small,
body.iam-besource-pmpro-page .pmpro td,
body.iam-besource-pmpro-page .pmpro th {
    color: #e8e8e8 !important;
}

body.iam-besource-pmpro-page .pmpro_cols-2,
body.iam-besource-pmpro-page .pmpro_cols-3 {
    display: block !important;
}

body.iam-besource-pmpro-page .pmpro_cols-2 > *,
body.iam-besource-pmpro-page .pmpro_cols-3 > * {
    width: 100% !important;
}

body.iam-besource-pmpro-page .besource-checkout {
    display: grid;
    gap: 24px;
}

body.iam-besource-pmpro-page .besource-checkout__panel {
    display: grid;
    gap: 24px;
    background: #2a2a2a !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 6px !important;
    padding: 28px !important;
}

body.iam-besource-pmpro-page .besource-checkout__hero {
    margin-bottom: 0;
}

body.iam-besource-pmpro-page .besource-checkout__section,
body.iam-besource-pmpro-page .besource-checkout__fieldset {
    display: grid;
    gap: 16px;
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent !important;
    min-inline-size: 0;
}

body.iam-besource-pmpro-page .besource-checkout__section + .besource-checkout__fieldset,
body.iam-besource-pmpro-page .besource-checkout__fieldset + .besource-checkout__fieldset,
body.iam-besource-pmpro-page .besource-checkout__fieldset + .pmpro_form_submit {
    margin-top: 8px;
}

body.iam-besource-pmpro-page .besource-checkout__section-header,
body.iam-besource-pmpro-page .besource-checkout__section-body,
body.iam-besource-pmpro-page .besource-checkout__section-actions {
    min-inline-size: 0;
}

body.iam-besource-pmpro-page .besource-checkout__section-title {
    margin: 0;
    color: #ffffff !important;
    font-size: 22px !important;
    line-height: 1.06 !important;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

body.iam-besource-pmpro-page .besource-checkout__section-body {
    display: grid;
    gap: 16px;
}

body.iam-besource-pmpro-page .besource-checkout__section-body > p:first-child {
    margin-top: 0;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_fields,
body.iam-besource-pmpro-page .besource-checkout .pmpro_form_fields-inline {
    min-inline-size: 0;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_cols-2 {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 20px;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_cols-2 > * {
    width: auto !important;
    min-width: 0;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_field {
    min-width: 0;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_label {
    color: #e8e8e8 !important;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_input,
body.iam-besource-pmpro-page .besource-checkout .pmpro_form_input[type="text"],
body.iam-besource-pmpro-page .besource-checkout .pmpro_form_input[type="email"],
body.iam-besource-pmpro-page .besource-checkout .pmpro_form_input[type="password"],
body.iam-besource-pmpro-page .besource-checkout select.pmpro_form_input,
body.iam-besource-pmpro-page .besource-checkout textarea.pmpro_form_input {
    min-height: 48px;
    background: #2f2f2f !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: 5px !important;
    color: #f2f2f2 !important;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_message {
    margin: 0;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_submit {
    display: grid;
    gap: 14px;
    margin-top: 8px;
}

body.iam-besource-pmpro-page .besource-checkout .pmpro_form_submit #pmpro_submit_span {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

@media (max-width: 760px) {
    body.iam-besource-pmpro-page .besource-checkout__panel {
        padding: 24px 20px !important;
    }

    body.iam-besource-pmpro-page .besource-checkout .pmpro_cols-2 {
        grid-template-columns: 1fr;
    }
}

body.iam-besource-pmpro-page .pmpro input[type="text"],
body.iam-besource-pmpro-page .pmpro input[type="email"],
body.iam-besource-pmpro-page .pmpro input[type="password"],
body.iam-besource-pmpro-page .pmpro input[type="number"],
body.iam-besource-pmpro-page .pmpro input[type="tel"],
body.iam-besource-pmpro-page .pmpro input[type="url"],
body.iam-besource-pmpro-page .pmpro select,
body.iam-besource-pmpro-page .pmpro textarea {
    background: #2f2f2f !important;
    border: 1px solid rgba(255,255,255,0.16) !important;
    color: #e8e8e8 !important;
}

body.iam-besource-pmpro-page .pmpro .pmpro_btn,
body.iam-besource-pmpro-page .pmpro a.pmpro_btn,
body.iam-besource-pmpro-page .pmpro input[type="submit"],
body.iam-besource-pmpro-page .pmpro button,
body.iam-besource-pmpro-page .pmpro .pmpro_actionlinks a,
body.iam-besource-pmpro-page .pmpro .pmpro_card_actions a {
    background: #2f2f2f !important;
    color: #eaeaea !important;
    border: 1px solid rgba(255,255,255,0.16) !important;
}

body.iam-besource-pmpro-page .pmpro .pmpro_btn:hover,
body.iam-besource-pmpro-page .pmpro a.pmpro_btn:hover,
body.iam-besource-pmpro-page .pmpro input[type="submit"]:hover,
body.iam-besource-pmpro-page .pmpro button:hover,
body.iam-besource-pmpro-page .pmpro .pmpro_actionlinks a:hover,
body.iam-besource-pmpro-page .pmpro .pmpro_card_actions a:hover {
    background: #3a3a3a !important;
    color: #ffffff !important;
}

.besource-pmpro .pmpro_table {
    overflow: hidden;
}

.besource-pmpro .pmpro hr,
.besource-pmpro .pmpro .pmpro_spacer,
.besource-pmpro .pmpro .pmpro_card hr {
    border-color: rgba(255, 255, 255, 0.08);
}

.besource-pmpro .pmpro input[type="text"],
.besource-pmpro .pmpro input[type="email"],
.besource-pmpro .pmpro input[type="password"],
.besource-pmpro .pmpro input[type="number"],
.besource-pmpro .pmpro input[type="tel"],
.besource-pmpro .pmpro input[type="url"],
.besource-pmpro .pmpro select,
.besource-pmpro .pmpro textarea {
    background: #2f2f2f;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    color: #f2f2f2;
}

.besource-pmpro .pmpro input[type="text"]:focus,
.besource-pmpro .pmpro input[type="email"]:focus,
.besource-pmpro .pmpro input[type="password"]:focus,
.besource-pmpro .pmpro input[type="number"]:focus,
.besource-pmpro .pmpro input[type="tel"]:focus,
.besource-pmpro .pmpro input[type="url"]:focus,
.besource-pmpro .pmpro select:focus,
.besource-pmpro .pmpro textarea:focus {
    border-color: rgba(255, 255, 255, 0.28);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.06);
    outline: none;
}

.besource-pmpro .pmpro .pmpro_btn,
.besource-pmpro .pmpro a.pmpro_btn,
.besource-pmpro .pmpro input[type="submit"],
.besource-pmpro .pmpro button,
.besource-pmpro .pmpro .pmpro_actionlinks a,
.besource-pmpro .pmpro .pmpro_card_actions a {
    background: #2f2f2f;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    color: #e8e8e8;
    box-shadow: none;
    text-transform: uppercase;
    letter-spacing: 0.11em;
}

.besource-pmpro .pmpro .pmpro_btn:hover,
.besource-pmpro .pmpro .pmpro_btn:focus,
.besource-pmpro .pmpro a.pmpro_btn:hover,
.besource-pmpro .pmpro a.pmpro_btn:focus,
.besource-pmpro .pmpro input[type="submit"]:hover,
.besource-pmpro .pmpro input[type="submit"]:focus,
.besource-pmpro .pmpro button:hover,
.besource-pmpro .pmpro button:focus,
.besource-pmpro .pmpro .pmpro_actionlinks a:hover,
.besource-pmpro .pmpro .pmpro_actionlinks a:focus,
.besource-pmpro .pmpro .pmpro_card_actions a:hover,
.besource-pmpro .pmpro .pmpro_card_actions a:focus {
    background: #343434;
    border-color: rgba(255, 255, 255, 0.28);
    color: #ffffff;
}

.besource-pmpro .pmpro .pmpro_actionlinks,
.besource-pmpro .pmpro .pmpro_card_actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.besource-pmpro .pmpro .pmpro_card_action_separator {
    display: none;
}

.besource-pmpro .pmpro_table th,
.besource-pmpro .pmpro_table td {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.08);
}

.besource-pmpro-panel {
    padding: 36px 32px;
    background: #2a2a2a;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.besource-pmpro-panel--narrow {
    max-width: 900px;
    margin: 0 auto;
}

.besource-pmpro-panel__header {
    margin-bottom: 24px;
}

.besource-pmpro-form {
    display: grid;
    gap: 22px;
}

.besource-pmpro-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 20px;
}

.besource-pmpro-form__field {
    display: grid;
    gap: 8px;
}

.besource-pmpro-form__label {
    color: #e8e8e8;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.besource-pmpro-form__input {
    min-height: 48px;
    width: 100%;
    padding: 0 14px;
    background: #2f2f2f;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    color: #f2f2f2;
}

.besource-pmpro-form__input:focus {
    outline: none;
    border-color: rgba(255, 255, 255, 0.28);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.06);
}

.besource-pmpro input,
.besource-pmpro-form__input,
.besource-pmpro-form__input:focus,
.besource-pmpro-form__input:active,
.besource-pmpro-form__input:hover,
.iam-besource-pmpro-page input {
    color: #f2f2f2;
    caret-color: #ffffff;
}

.besource-pmpro input::placeholder,
.besource-pmpro-form__input::placeholder,
.iam-besource-pmpro-page input::placeholder {
    color: rgba(255, 255, 255, 0.45);
}

.besource-pmpro input:-webkit-autofill,
.besource-pmpro input:-webkit-autofill:hover,
.besource-pmpro input:-webkit-autofill:focus,
.besource-pmpro input:-webkit-autofill:active,
.besource-pmpro-form__input:-webkit-autofill,
.besource-pmpro-form__input:-webkit-autofill:hover,
.besource-pmpro-form__input:-webkit-autofill:focus,
.besource-pmpro-form__input:-webkit-autofill:active,
.iam-besource-pmpro-page input:-webkit-autofill,
.iam-besource-pmpro-page input:-webkit-autofill:hover,
.iam-besource-pmpro-page input:-webkit-autofill:focus,
.iam-besource-pmpro-page input:-webkit-autofill:active {
    -webkit-text-fill-color: #f2f2f2 !important;
    caret-color: #ffffff;
    transition: background-color 9999s ease-in-out 0s;
    box-shadow: 0 0 0 1000px #2a2a2a inset;
}

.besource-pmpro-form__hint {
    margin: -6px 0 0;
    color: #b8b8b8;
    font-size: 14px;
    line-height: 1.5;
}

.besource-pmpro-form__hooks {
    display: grid;
    gap: 18px;
}

.besource-levels__hero {
    margin-bottom: 24px;
}

.besource-levels__group + .besource-levels__group {
    margin-top: 28px;
}

.besource-levels__group-header {
    margin-bottom: 16px;
}

.besource-levels__group-title {
    margin: 0 0 6px;
    color: #ffffff;
    font-size: 22px;
    line-height: 1.05;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.besource-levels__group-note {
    margin: 0;
    color: rgba(255, 255, 255, 0.62);
    font-size: 15px;
    line-height: 1.5;
}

.besource-levels__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.besource-levels__card {
    display: grid;
    gap: 18px;
    padding: 24px 22px;
    min-height: 100%;
    background: #2a2a2a;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 5px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.besource-levels__card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
}

.besource-levels__card-title {
    margin: 0;
    color: #ffffff;
    font-size: 24px;
    line-height: 1.06;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.besource-levels__card-description {
    margin: 8px 0 0;
    color: rgba(255, 255, 255, 0.6);
    font-size: 15px;
    line-height: 1.55;
}

.besource-levels__card-body {
    display: grid;
    gap: 12px;
}

.besource-levels__price {
    color: rgba(255, 255, 255, 0.9);
    font-size: 18px;
    line-height: 1.5;
}

.besource-levels__price p,
.besource-levels__detail p {
    margin: 0;
}

.besource-levels__detail {
    color: rgba(255, 255, 255, 0.72);
    font-size: 15px;
    line-height: 1.55;
}

.besource-levels__card .besource-account__actions {
    margin-top: auto;
}

@media (max-width: 1080px) {
    .besource-levels__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .besource-pmpro-panel {
        padding: 24px 20px;
    }

    .besource-pmpro-form__grid {
        grid-template-columns: 1fr;
    }

    .besource-levels__grid {
        grid-template-columns: 1fr;
    }
}

.besource-account__shell {
    width: min(100%, 1180px);
    margin: 0 auto;
}

.besource-account__hero {
    margin-bottom: 22px;
    text-align: left;
}

.besource-account__eyebrow {
    margin-bottom: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.besource-account__title {
    margin: 0 0 8px;
    color: #ffffff;
    font-size: clamp(30px, 4vw, 42px);
    line-height: 0.96;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.besource-account__subtitle,
.besource-account__welcome {
    margin: 0;
    max-width: 42ch;
    color: rgba(255, 255, 255, 0.7);
    font-size: 17px;
    line-height: 1.5;
}

.besource-account__welcome {
    margin-top: 8px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.56);
}

.besource-account__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.besource-account__card {
    padding: 22px 20px;
    border-radius: 6px;
    background: #2a2a2a;
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.besource-account__card--wide {
    grid-column: span 2;
}

.besource-account__card-header {
    margin-bottom: 14px;
}

.besource-account__card-title {
    margin: 0 0 6px;
    color: #ffffff !important;
    font-size: 22px;
    line-height: 1.05;
    font-family: "Fieldwork-HumBold", "Fieldwork", sans-serif;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.besource-account__card-meta,
.besource-account__empty {
    color: rgba(255, 255, 255, 0.62);
    font-size: 15px;
    line-height: 1.5;
}

.besource-account__empty {
    margin: 0 0 16px;
}

.besource-account__membership-list .besource-account__membership {
    background:none !important;
}

.besource-account__membership-list {
    display: grid;
    gap: 18px;
}

.besource-account__membership {
    padding-top: 2px;
}

.besource-account__membership + .besource-account__membership {
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.besource-account__membership-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.besource-account__membership-title {
    margin: 0;
    color: #ffffff;
    font-size: 19px;
    line-height: 1.1;
    font-weight: 700;
}

.besource-account__status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 5px;
    background: #3a3a3a;
    color: #f2f2f2;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.besource-account__details {
    display: grid;
    gap: 12px;
    margin: 0 0 18px;
}

.besource-account__details--chart {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 18px;
}

.besource-account__detail {
    display: grid;
    gap: 4px;
}

.besource-account__detail dt {
    color: rgba(255, 255, 255, 0.46);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.besource-account__detail dd {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 15px;
    line-height: 1.5;
}

.besource-account__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.besource-account__chart-editor {
    margin-top: 6px;
}

.besource-account__chart-editor summary {
    list-style: none;
    cursor: pointer;
}

.besource-account__chart-editor summary::-webkit-details-marker {
    display: none;
}

.besource-account__chart-form {
    margin-top: 16px;
    padding-top: 18px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.besource-account__chart-resolved {
    color: rgba(255, 255, 255, 0.62);
    font-size: 13px;
    line-height: 1.4;
}

.besource-account__chart-submeta {
    margin-top: 4px;
}

.besource-account__chart-offset {
    display: none;
}

.besource-account__chart-location-field {
    position: relative;
}

.besource-account__chart-location-input-wrap {
    position: relative;
}

.iam-account-chart-results,
#autoComplete_results_list {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    width: 100%;
    margin: 0;
    padding: 8px 0;
    list-style: none;
    border-radius: 6px;
    background: #2f2f2f;
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
    max-height: 240px;
    overflow-y: auto;
    z-index: 9999;
    display: none;
}

.iam-account-chart-results:not(:empty),
#autoComplete_results_list:not(:empty) {
    display: block;
}

.iam-account-chart-results .autoComplete_result,
#autoComplete_results_list .autoComplete_result {
    padding: 10px 14px;
    color: #e8e8e8;
    cursor: pointer;
}

.iam-account-chart-results .autoComplete_result:hover,
.iam-account-chart-results .autoComplete_result:focus,
#autoComplete_results_list .autoComplete_result:hover,
#autoComplete_results_list .autoComplete_result:focus {
    background: #3a3a3a;
    color: #ffffff;
    outline: none;
}

.besource-account__chart-location-field .ui-state-error {
    color: #f0b3b3;
    font-size: 13px;
    line-height: 1.4;
}

.besource-account__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 5px;
    background: #2f2f2f;
    border: 1px solid rgba(255, 255, 255, 0.16);
    color: #e8e8e8;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-decoration: none;
    text-transform: uppercase;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.besource-account__action:hover,
.besource-account__action:focus {
    transform: translateY(-1px);
    background: #343434;
    border-color: rgba(255, 255, 255, 0.28);
    color: #ffffff;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.14);
}

.besource-account__action--primary {
    background: #2f2f2f;
    border-color: rgba(255, 255, 255, 0.16);
}

.besource-account a,
.besource-account button,
.besource-account .button {
    color: #e8e8e8 !important;
    border-color: rgba(255, 255, 255, 0.16) !important;
    background: #2f2f2f !important;
}

.besource-account a:hover,
.besource-account a:focus,
.besource-account button:hover,
.besource-account button:focus,
.besource-account .button:hover,
.besource-account .button:focus {
    color: #ffffff !important;
    background: #343434 !important;
    border-color: rgba(255, 255, 255, 0.28) !important;
}

.besource-account__actions--portal .besource-account__action--primary {
    min-width: 180px;
}

@media (max-width: 980px) {
    .besource-account__grid {
        grid-template-columns: 1fr;
    }

    .besource-account__card--wide {
        grid-column: auto;
    }

    .besource-account__details--chart {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .besource-account__card {
        padding: 20px 16px;
        border-radius: 6px;
    }

    .besource-account__membership-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .besource-account__action {
        width: 100%;
    }
}
