@font-face {
    font-family: "Waldenburg";
    src: url("../fonts/WaldenburgNormal.woff2") format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Waldenburg";
    src: url("../fonts/WaldenburgHF.woff2") format("woff2");
    font-weight: 500 900;
    font-style: normal;
    font-display: swap;
}

:root {
    --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --font-heading: "Waldenburg", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --bg: #ffffff;
    --sidebar: #fafafa;
    --surface: #ffffff;
    --surface-soft: #ffffff;
    --surface-muted: #ffffff;
    --surface-raised: #ffffff;
    --ink: #171717;
    --text: #3f4048;
    --muted: #7b7d86;
    --muted-soft: #a0a2aa;
    --line: #e8e8eb;
    --line-strong: #d9d9df;
    --black: #111111;
    --green: #29c98b;
    --green-soft: #ffffff;
    --amber: #e2a20f;
    --amber-soft: #ffffff;
    --red: #ef4444;
    --red-soft: #ffffff;
    --blue: #5a78e6;
    --blue-soft: #ffffff;
    --purple: #7a5ce6;
    --purple-soft: #ffffff;
    --logo-cyan: #08cdda;
    --logo-blue: #1977f3;
    --logo-purple: #6e43f4;
    --logo-magenta: #f23be7;
    --sidebar-width: 296px;
    --topbar-height: 58px;
    --radius-card: 8px;
    --radius-control: 8px;
    --shadow-hairline: 0 0 0 1px rgba(17, 17, 17, 0.03);
    --shadow-sm: 0 1px 2px rgba(17, 17, 17, 0.05), 0 1px 1px rgba(17, 17, 17, 0.03);
    --shadow-md: 0 8px 28px rgba(17, 17, 17, 0.08);
    --safe-area-top: env(safe-area-inset-top, 0px);
    --safe-area-right: env(safe-area-inset-right, 0px);
    --safe-area-bottom: env(safe-area-inset-bottom, 0px);
    --safe-area-left: env(safe-area-inset-left, 0px);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    min-height: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
}

body {
    margin: 0;
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    touch-action: manipulation;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
    text-rendering: optimizeLegibility;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
select,
textarea {
    font: inherit;
}

button {
    appearance: none;
}

code {
    display: inline-flex;
    max-width: 100%;
    overflow-x: auto;
    padding: 0.25rem 0.42rem;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--surface-muted);
    color: var(--ink);
    font-size: 0.78rem;
}

::selection {
    background: rgba(17, 17, 17, 0.12);
}

.icon {
    width: 1.12rem;
    height: 1.12rem;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.75;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.app-shell {
    min-height: 100vh;
    background: var(--bg);
}

.app-nav {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 210;
    width: var(--sidebar-width);
    background: var(--sidebar);
    border-right: 1px solid var(--line);
}

.app-nav-inner {
    height: 100%;
    padding: calc(18px + var(--safe-area-top)) 14px calc(12px + var(--safe-area-bottom));
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.app-sidebar-head {
    min-height: 40px;
    display: flex;
    align-items: center;
}

.app-brand {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
}

.app-brand-logo {
    display: block;
    width: 112px;
    height: auto;
    max-height: 28px;
    object-fit: contain;
    object-position: left center;
}

.auth-brand-logo {
    display: block;
    width: 112px;
    height: auto;
    max-height: 28px;
    object-fit: contain;
    object-position: left center;
}

.auth-brand-icon {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.auth-brand-icon img {
    width: 23px;
    height: 23px;
    object-fit: contain;
}

.app-brand-mark,
.auth-brand-mark {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    color: #fff;
    background: var(--black);
    font-size: 0.75rem;
    font-weight: 800;
}

.app-brand-name {
    font-family: var(--font-heading);
    color: var(--ink);
    font-size: 1.22rem;
    font-weight: 800;
    letter-spacing: 0;
}

.workspace-switcher {
    width: 100%;
    min-height: 44px;
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr) 16px;
    align-items: center;
    gap: 9px;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 9px;
    background: #fff;
    color: var(--ink);
    cursor: default;
    box-shadow: var(--shadow-sm);
}

.workspace-mark {
    width: 23px;
    height: 23px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: var(--surface-muted);
}

.workspace-mark img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}

.workspace-name {
    min-width: 0;
    overflow: hidden;
    color: var(--ink);
    font-size: 0.92rem;
    font-weight: 600;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.workspace-chevrons {
    position: relative;
    width: 12px;
    height: 16px;
    color: var(--muted);
}

.workspace-chevrons::before,
.workspace-chevrons::after {
    content: "";
    position: absolute;
    left: 3px;
    width: 7px;
    height: 7px;
    border-top: 1.6px solid currentColor;
    border-left: 1.6px solid currentColor;
}

.workspace-chevrons::before {
    top: 2px;
    transform: rotate(45deg);
}

.workspace-chevrons::after {
    bottom: 2px;
    transform: rotate(225deg);
}

.app-nav-menu {
    min-height: 0;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 24px;
    overflow-y: auto;
    padding: 1px 0 10px;
    scrollbar-width: thin;
}

.app-nav-links,
.app-nav-section {
    display: grid;
}

.app-nav-links {
    gap: 17px;
}

.app-nav-section {
    gap: 3px;
}

.app-nav-label {
    margin: 0 0 6px;
    padding: 0 8px;
    color: var(--muted);
    font-size: 0.79rem;
    font-weight: 500;
}

.app-nav-link {
    position: relative;
    min-height: 38px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 10px;
    border: 1px solid transparent;
    border-radius: 9px;
    color: #656772;
    font-size: 0.93rem;
    font-weight: 600;
    line-height: 1;
    transition: background-color 0.14s ease, border-color 0.14s ease, color 0.14s ease;
}

.app-nav-link:hover {
    color: var(--ink);
    background: #f0f0f2;
}

.app-nav-link.is-active {
    color: #ffffff;
    background: #000000;
}

.app-nav-footer {
    display: grid;
    gap: 10px;
    margin-top: auto;
}

.invite-card {
    display: grid;
    gap: 5px;
    padding: 15px 16px 14px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.invite-card strong {
    color: var(--ink);
    font-size: 0.9rem;
    font-weight: 700;
}

.invite-card span:not(.invite-icon) {
    color: var(--muted);
    font-size: 0.8rem;
    line-height: 1.35;
}

.invite-icon {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    margin-bottom: 4px;
    border-radius: 999px;
    background: var(--surface-soft);
    color: #777984;
}

.app-nav-footer-link {
    margin-top: 1px;
}

.app-topbar {
    position: fixed;
    top: 0;
    right: 0;
    left: var(--sidebar-width);
    z-index: 180;
    height: calc(var(--topbar-height) + var(--safe-area-top));
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: var(--safe-area-top) calc(14px + var(--safe-area-right)) 0 calc(20px + var(--safe-area-left));
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(16px);
}

.app-topbar-left,
.app-topbar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.app-topbar-title {
    font-family: var(--font-heading);
    min-width: 0;
    overflow: hidden;
    color: var(--ink);
    font-size: 0.95rem;
    font-weight: 600;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-nav-toggle {
    width: 34px;
    height: 34px;
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--ink);
    cursor: pointer;
    box-shadow: var(--shadow-sm);
}

.app-nav-toggle span {
    width: 14px;
    height: 1.5px;
    border-radius: 999px;
    background: currentColor;
}

.topbar-pill,
.topbar-icon-button {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    color: var(--ink);
    box-shadow: var(--shadow-sm);
}

.topbar-pill {
    padding: 0 13px;
    font-size: 0.84rem;
    font-weight: 600;
}

.topbar-pill .icon {
    width: 1rem;
    height: 1rem;
}

.topbar-icon-button {
    position: relative;
    width: 36px;
    padding: 0;
}

.topbar-icon-button .icon {
    width: 1.05rem;
    height: 1.05rem;
}

.topbar-pill:hover,
.topbar-icon-button:hover {
    background: var(--surface-muted);
    border-color: var(--line-strong);
}

button.topbar-pill {
    cursor: pointer;
}

.topbar-pill.is-active {
    border-color: var(--ink);
    background: var(--ink);
    color: #fff;
}

.topbar-refresh-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.topbar-refresh-actions .inline-form {
    display: inline-flex;
}

.topbar-action-button {
    border-color: #111;
    background: #111;
    color: #fff;
    font: inherit;
    cursor: pointer;
    font-size: 0.84rem;
    font-weight: 600;
}

.topbar-action-button:hover,
.topbar-action-button:focus-visible {
    border-color: #000;
    background: #000;
    color: #fff;
}

.topbar-action-button:disabled {
    opacity: 0.58;
    cursor: wait;
}

.topbar-return-button {
    border-color: #111;
    background: #111;
    color: #fff;
    font: inherit;
    cursor: pointer;
}

.topbar-return-button:hover,
.topbar-return-button:focus-visible {
    border-color: #000;
    background: #000;
    color: #fff;
}

.refresh-job-status.topbar-refresh-status {
    max-width: 190px;
    min-height: 36px;
    padding: 0.38rem 0.58rem;
    border-radius: 999px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.refresh-job-status.topbar-refresh-status .refresh-job-copy {
    display: flex;
    align-items: center;
    min-width: 0;
}

.refresh-job-status.topbar-refresh-status .refresh-job-copy strong {
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.78rem;
    font-weight: 700;
}

.refresh-job-status.topbar-refresh-status .refresh-job-copy small {
    display: none;
}

.refresh-job-status.is-hiding {
    opacity: 0;
    transform: translateY(-4px);
    pointer-events: none;
}

.topbar-icon-button.has-dot::after {
    content: "";
    position: absolute;
    top: 7px;
    right: 8px;
    width: 7px;
    height: 7px;
    border: 2px solid #fff;
    border-radius: 999px;
    background: #0b80ff;
}

.app-user-menu {
    width: 37px;
    height: 37px;
    display: grid;
    place-items: center;
    border: 3px solid #e6e7eb;
    border-radius: 999px;
    background: #72a94b;
    color: #fff;
    font-size: 0.86rem;
    font-weight: 800;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.app-logout-button {
    cursor: pointer;
}

.inline-form {
    display: inline-flex;
}

.app-main {
    min-height: 100vh;
    margin-left: var(--sidebar-width);
}

.ask-chat-panel {
    position: fixed;
    top: calc(var(--topbar-height) + var(--safe-area-top));
    right: 0;
    bottom: var(--safe-area-bottom);
    z-index: 205;
    width: min(430px, calc(100vw - 24px));
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    border-left: 1px solid var(--line);
    background: #fff;
    box-shadow: -18px 0 42px rgba(17, 17, 17, 0.08);
    transform: translateX(100%);
    transition: transform 0.22s ease;
    pointer-events: none;
}

.ask-chat-panel.is-open {
    transform: translateX(0);
    pointer-events: auto;
}

.ask-chat-head {
    min-width: 0;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 1rem;
    border-bottom: 1px solid var(--line);
}

.ask-chat-head > div {
    min-width: 0;
    display: grid;
    gap: 0.18rem;
}

.ask-chat-head h2 {
    margin: 0;
    color: var(--ink);
    font-size: 1.08rem;
    line-height: 1.1;
}

.ask-chat-head span {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 600;
}

.ask-chat-head-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex: 0 0 auto;
}

.ask-chat-clear {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    padding: 0 0.64rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
    color: var(--text);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    font-size: 0.78rem;
    font-weight: 650;
    white-space: nowrap;
}

.ask-chat-clear:hover {
    background: var(--surface-muted);
    border-color: var(--line-strong);
}

.ask-chat-clear .icon {
    width: 0.95rem;
    height: 0.95rem;
}

.ask-chat-close {
    flex: 0 0 auto;
    cursor: pointer;
}

.ask-chat-messages {
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    padding: 1rem;
    overflow-y: auto;
    background: #fff;
}

.ask-chat-empty {
    margin: auto;
    display: grid;
    justify-items: center;
    gap: 0.35rem;
    color: var(--muted);
    text-align: center;
}

.ask-chat-empty strong {
    color: var(--ink);
    font-size: 0.98rem;
}

.ask-chat-empty span {
    font-size: 0.84rem;
}

.ask-suggestions {
    width: min(100%, 330px);
    display: grid;
    gap: 0.5rem;
    margin-top: 0.78rem;
}

.ask-suggestions button {
    width: 100%;
    min-height: 38px;
    padding: 0.58rem 0.68rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
    color: var(--ink);
    box-shadow: var(--shadow-hairline);
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1.25;
    text-align: left;
}

.ask-suggestions button:hover {
    border-color: var(--line-strong);
    background: var(--surface-muted);
}

.ask-message {
    display: flex;
    width: 100%;
}

.ask-message-user {
    justify-content: flex-end;
}

.ask-message-assistant {
    justify-content: flex-start;
}

.ask-message-bubble {
    max-width: min(88%, 330px);
    padding: 0.72rem 0.8rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--text);
    box-shadow: var(--shadow-hairline);
    font-size: 0.86rem;
    line-height: 1.5;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.ask-message-assistant .ask-message-bubble {
    max-width: min(94%, 382px);
}

.ask-message-bubble p,
.ask-message-bubble ul,
.ask-message-bubble ol,
.ask-message-bubble h4 {
    margin: 0;
}

.ask-message-bubble p + p,
.ask-message-bubble p + ul,
.ask-message-bubble p + ol,
.ask-message-bubble ul + p,
.ask-message-bubble ol + p,
.ask-message-bubble h4 + p,
.ask-message-bubble h4 + ul,
.ask-message-bubble h4 + ol {
    margin-top: 0.48rem;
}

.ask-message-bubble ul,
.ask-message-bubble ol {
    display: grid;
    gap: 0.28rem;
    padding-left: 1.1rem;
}

.ask-message-bubble h4 {
    color: var(--ink);
    font-family: var(--font-sans);
    font-size: 0.88rem;
    line-height: 1.35;
}

.ask-message-bubble code {
    display: inline;
    padding: 0.08rem 0.26rem;
    font-size: 0.78rem;
}

.ask-message-rich + .ask-chart,
.ask-chart + .ask-chart {
    margin-top: 0.72rem;
}

.ask-chart {
    width: 100%;
    display: grid;
    gap: 0.55rem;
    padding: 0.68rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
    color: var(--text);
    white-space: normal;
}

.ask-chart-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.55rem;
}

.ask-chart-header strong {
    min-width: 0;
    color: var(--ink);
    font-size: 0.83rem;
    line-height: 1.25;
}

.ask-chart-header span {
    flex: 0 0 auto;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
}

.ask-chart svg {
    width: 100%;
    height: auto;
    display: block;
    overflow: visible;
}

.ask-chart-grid {
    stroke: var(--line);
    stroke-width: 1;
}

.ask-chart-axis {
    stroke: var(--line-strong);
    stroke-width: 1;
}

.ask-chart-axis-text {
    fill: var(--muted);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 650;
}

.ask-chart-total {
    fill: var(--ink);
    font-family: var(--font-sans);
    font-size: 18px;
    font-weight: 800;
}

.ask-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.38rem 0.62rem;
    color: var(--text);
    font-size: 0.72rem;
    font-weight: 650;
    line-height: 1.25;
}

.ask-chart-legend span {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.ask-chart-legend i {
    width: 0.52rem;
    height: 0.52rem;
    flex: 0 0 auto;
    border-radius: 999px;
}

.ask-chart-pie-layout {
    display: grid;
    grid-template-columns: 132px minmax(0, 1fr);
    gap: 0.55rem;
    align-items: center;
}

.ask-chart-pie-legend {
    display: grid;
    gap: 0.38rem;
}

.ask-chart-pie-legend span {
    justify-content: flex-start;
}

.ask-chart-pie-legend b {
    margin-left: auto;
    color: var(--ink);
    font-size: 0.72rem;
}

.ask-message-user .ask-message-bubble {
    border-color: var(--ink);
    background: var(--ink);
    color: #fff;
}

.ask-message.is-pending .ask-message-bubble {
    color: var(--muted);
}

.ask-message-error .ask-message-bubble {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #a91d1d;
}

.ask-chat-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: 0.56rem;
    align-items: end;
    padding: 0.82rem;
    border-top: 1px solid var(--line);
    background: #fff;
}

.ask-chat-form textarea {
    min-height: 42px;
    max-height: 132px;
    resize: none;
    overflow-y: auto;
    font-size: 0.88rem;
}

.ask-chat-send {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid var(--ink);
    border-radius: var(--radius-control);
    background: var(--ink);
    color: #fff;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
}

.ask-chat-send:disabled {
    opacity: 0.56;
    cursor: wait;
}

.page-content {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: calc(132px + var(--safe-area-top)) clamp(56px, 5vw, 96px) calc(96px + var(--safe-area-bottom));
    display: grid;
    gap: 42px;
}

.async-page-progress {
    position: fixed;
    z-index: 220;
    top: 0;
    left: var(--sidebar-width);
    right: 0;
    height: 3px;
    background: var(--logo-blue);
    box-shadow: 0 0 16px rgba(31, 122, 236, 0.32);
    opacity: 0;
    transform: scaleX(0.12);
    transform-origin: left center;
    transition: opacity 0.16s ease, transform 0.42s ease;
}

.is-page-loading .async-page-progress {
    opacity: 1;
    transform: scaleX(0.78);
}

.async-content-layer {
    position: fixed;
    z-index: 70;
    top: 0;
    right: 0;
    bottom: 0;
    left: var(--sidebar-width);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    padding-top: var(--topbar-height);
    background: rgba(255, 255, 255, 0.72);
    color: var(--ink);
    opacity: 0;
    pointer-events: none;
    backdrop-filter: blur(6px);
    transition: opacity 0.16s ease;
}

.is-page-loading .async-content-layer {
    opacity: 1;
    pointer-events: auto;
}

.async-content-layer strong {
    font-size: 0.96rem;
    font-weight: 800;
}

.page-content.is-loading {
    cursor: progress;
}

.dashboard-widget {
    display: contents;
}

.dashboard-widget > .async-widget-loading,
.dashboard-widget > .async-widget-error {
    min-height: 180px;
}

.async-page-layer {
    min-height: calc(100vh - 230px);
    display: grid;
    place-items: center;
    position: relative;
}

.async-page-loader-card {
    width: min(420px, 100%);
    min-height: 220px;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 0.7rem;
    padding: 2rem;
    border: none;
    border-radius: var(--radius-card);
    background: var(--surface);
    box-shadow: none;
    text-align: center;
}

.async-page-loader-card h3 {
    margin: 0;
    color: var(--ink);
    font-size: 1.3rem;
}

.async-page-loader-card p:not(.eyebrow) {
    max-width: 280px;
    margin: 0;
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.6;
}

.async-page-spinner {
    width: 34px;
    height: 34px;
    border: 3px solid rgba(31, 122, 236, 0.18);
    border-top-color: #1f7aec;
    border-right-color: #27ad7b;
    border-radius: 50%;
    animation: ensyra-spin 0.8s linear infinite;
}

.async-widget-loading,
.async-widget-error {
    min-height: 92px;
    display: grid;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 700;
}

.async-widget-loading::before {
    content: "";
    width: 28px;
    height: 28px;
    border: 3px solid rgba(31, 122, 236, 0.18);
    border-top-color: #1f7aec;
    border-right-color: #27ad7b;
    border-radius: 50%;
    animation: ensyra-spin 0.8s linear infinite;
}

@keyframes ensyra-spin {
    to {
        transform: rotate(360deg);
    }
}

.topbar {
    margin-bottom: 1rem;
}

.topbar-frame,
.page-header,
.card-header,
.section-toolbar,
.form-panel-head,
.profit-detail-head,
.prediction-card-head,
.prediction-footer,
.insight-card-head,
.insight-action {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.topbar-actions,
.page-actions,
.row-actions,
.form-actions,
.hero-actions,
.filter-bar {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.refresh-job-status {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    max-width: min(100%, 360px);
    gap: 0.5rem;
    padding: 0.42rem 0.62rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.25;
    transition: opacity 0.18s ease, transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.refresh-job-status[hidden] {
    display: none;
}

.refresh-job-dot {
    width: 9px;
    height: 9px;
    flex: 0 0 auto;
    border-radius: 50%;
    background: #1f7aec;
    box-shadow: 0 0 0 4px rgba(31, 122, 236, 0.12);
}

.refresh-job-status.is-running .refresh-job-dot,
.refresh-job-status.is-queued .refresh-job-dot {
    animation: ensyra-pulse 1.1s ease-in-out infinite;
}

.refresh-job-status.is-finished {
    color: #157457;
    border-color: rgba(21, 116, 87, 0.22);
    background: rgba(39, 173, 123, 0.08);
}

.refresh-job-status.is-finished .refresh-job-dot {
    background: #27ad7b;
    box-shadow: 0 0 0 4px rgba(39, 173, 123, 0.13);
}

.refresh-job-status.is-failed {
    color: #c52222;
    border-color: #ffd7d7;
    background: var(--red-soft);
}

.refresh-job-status.is-failed .refresh-job-dot {
    background: #d92d20;
    box-shadow: 0 0 0 4px rgba(217, 45, 32, 0.12);
}

.refresh-job-copy {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
}

.refresh-job-copy strong,
.refresh-job-copy small {
    overflow-wrap: anywhere;
}

.refresh-job-copy strong {
    color: var(--ink);
    font-size: 0.74rem;
    font-weight: 800;
}

.refresh-job-copy small {
    color: inherit;
    font-size: 0.69rem;
    font-weight: 650;
}

@keyframes ensyra-pulse {
    0%,
    100% {
        opacity: 0.6;
        transform: scale(0.92);
    }

    50% {
        opacity: 1;
        transform: scale(1);
    }
}

.page-header {
    /*max-width: 860px;*/
    margin-bottom: 2px;
}

.connectors-page-header {
    width: 100%;
    max-width: none;
}

.connectors-page-header .page-actions {
    margin-left: auto;
}

.page-header-accent {
    position: relative;
    max-width: 1040px;
    padding-left: 22px;
}

.page-header-accent::before {
    content: "";
    position: absolute;
    top: 4px;
    bottom: 4px;
    left: 0;
    width: 4px;
    border-radius: 999px;
    background: var(--logo-purple);
}

.page-header-accent::after {
    display: none;
}

.customer-page-header::before {
    background: var(--logo-cyan);
}

.insights-page-header::before {
    background: var(--logo-magenta);
}

.segments-page-header::before {
    background: var(--logo-blue);
}

.form-page-header,
.form-canvas {
    width: 100%;
    /*max-width: 940px;*/
}

.eyebrow {
    margin: 0 0 7px;
    color: var(--muted);
    font-size: 0.84rem;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
}

.topbar-title,
.page-header h2,
.hero-copy h2,
.auth-copy h2,
.auth-showcase h1,
.empty-state h2,
.dashboard-title {
    font-family: var(--font-heading);
    margin: 0;
    color: var(--ink);
    font-size: clamp(1.72rem, 2.2vw, 2.12rem);
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.16;
}

.dashboard-title {
    margin-bottom: 0.38rem;
}

.dashboard-subtitle,
.page-header p,
.hero-copy p,
.section-subtitle,
.form-section-note,
.field-note,
.empty-state p,
.quick-action span,
.chart-label span,
.metric-inline span,
.selector-card p,
.auth-copy p,
.auth-showcase p,
.side-card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.9rem;
    line-height: 1.62;
}

.dashboard-subtitle strong {
    color: var(--text);
    font-weight: 600;
}

.page-explainer {
    width: 100%;
    /*max-width: 1040px;*/
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
    gap: 1.2rem;
    align-items: start;
    margin: 0.5rem 0 1.35rem;
    padding: 1.08rem 1.18rem;
    border: 1px solid var(--line);
    border-left: 4px solid var(--ink);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.page-explainer-main {
    display: grid;
    gap: 0.62rem;
}

.page-explainer h3 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.08rem;
    font-weight: 760;
    line-height: 1.25;
}

.page-explainer p,
.page-explainer li,
.page-explainer dd {
    margin: 0;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.55;
}

.page-explainer-bullets {
    display: grid;
    gap: 0.42rem;
    margin: 0;
    padding-left: 1.08rem;
}

.page-explainer-metrics {
    display: grid;
    gap: 0.72rem;
    margin: 0;
    padding: 0;
}

.page-explainer-metrics > div {
    display: grid;
    gap: 0.18rem;
    padding-bottom: 0.72rem;
    border-bottom: 1px solid var(--line);
}

.page-explainer-metrics > div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.page-explainer dt {
    color: var(--ink);
    font-size: 0.78rem;
    font-weight: 800;
}

.page-explainer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.08rem;
}

.page-explainer-variant-commerce {
    border-left-color: var(--logo-cyan);
}

.page-explainer-variant-decision {
    border-left-color: var(--logo-blue);
}

.page-explainer-variant-results {
    border-left-color: var(--logo-purple);
}

.page-explainer-variant-data {
    border-left-color: var(--logo-magenta);
}

.page-explainer-variant-technical {
    border-left-color: var(--logo-purple);
}

.kpi-help {
    display: block;
    margin-top: 0.24rem;
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.35;
}

.dashboard-header {
    max-width: 900px;
    margin-bottom: 2px;
}

.home-dashboard {
    gap: 32px;
}

.home-hero {
    display: grid;
    gap: 26px;
    max-width: 940px;
}

.release-pill {
    width: fit-content;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 4px 10px 4px 6px;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    background: #fff;
    color: var(--ink);
    box-shadow: var(--shadow-hairline);
    font-size: 0.88rem;
    font-weight: 650;
}

.release-pill span {
    min-height: 30px;
    display: inline-flex;
    align-items: center;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--black);
    color: #fff;
}

.release-pill i {
    color: var(--muted);
    font-style: normal;
    font-size: 1.35rem;
    line-height: 1;
}

.home-workspace {
    margin: 0 0 6px;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 650;
}

.home-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(220px, 1fr));
    gap: 0.72rem;
}

.home-feature-card {
    --accent: var(--logo-cyan);
    --accent-soft: #fff;
    position: relative;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 16px;
    align-items: center;
    gap: 0.78rem;
    min-height: 94px;
    padding: 0.9rem 0.95rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--ink);
    box-shadow: var(--shadow-hairline);
    text-align: left;
    text-decoration: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease, transform 0.15s ease;
}

.home-feature-card::before {
    content: "";
    position: absolute;
    inset: 0.7rem auto 0.7rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--accent);
    opacity: 0;
    transition: opacity 0.15s ease;
}

.home-feature-card:hover {
    border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
    box-shadow: 0 10px 24px rgba(17, 17, 17, 0.055);
    transform: translateY(-2px);
}

.home-feature-card:hover::before,
.home-feature-card:focus-visible::before {
    opacity: 1;
}

.home-feature-card:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 20%, transparent);
    outline-offset: 2px;
}

.home-feature-icon {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--accent);
}

.home-feature-icon .icon {
    width: 1.12rem;
    height: 1.12rem;
    stroke-width: 1.85;
}

.home-feature-content {
    min-width: 0;
    display: grid;
    gap: 0.22rem;
}

.home-feature-card strong {
    font-family: var(--font-heading);
    color: var(--ink);
    font-size: 0.98rem;
    font-weight: 750;
    line-height: 1.18;
}

.home-feature-card small {
    max-width: 100%;
    display: flex;
    align-items: baseline;
    gap: 0.42rem;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
    min-width: 0;
}

.home-feature-card small span:last-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.home-feature-metric {
    flex: 0 0 auto;
    color: var(--ink);
    font-weight: 800;
}

.home-feature-cue {
    position: relative;
    width: 14px;
    height: 14px;
    color: var(--muted-soft);
    opacity: 0.76;
}

.home-feature-cue::before {
    content: "";
    position: absolute;
    inset: 3px 4px 3px 2px;
    border-top: 1.7px solid currentColor;
    border-right: 1.7px solid currentColor;
    transform: rotate(45deg);
}

.theme-mint {
    --accent: var(--logo-cyan);
    --accent-soft: #fff;
}

.theme-violet {
    --accent: var(--logo-purple);
    --accent-soft: #fff;
}

.theme-amber {
    --accent: var(--logo-purple);
    --accent-soft: #fff;
}

.theme-coral {
    --accent: var(--logo-magenta);
    --accent-soft: #fff;
}

.theme-blue {
    --accent: var(--logo-blue);
    --accent-soft: #fff;
}

.theme-green {
    --accent: var(--logo-cyan);
    --accent-soft: #fff;
}

.dashboard-experiment-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.dashboard-experiment-grid .content-card {
    padding: 1rem;
}

.dashboard-experiment-grid .experiment-trend-card {
    gap: 0.72rem;
}

.dashboard-experiment-grid .section-toolbar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.68rem;
    margin-bottom: 0;
}

.dashboard-experiment-grid .section-toolbar h3 {
    margin: 0 0 0.16rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.98rem;
    font-weight: 750;
    line-height: 1.18;
}

.dashboard-experiment-grid .section-subtitle {
    font-size: 0.76rem;
    line-height: 1.45;
}

.dashboard-experiment-grid .eyebrow {
    margin-bottom: 0.28rem;
    font-size: 0.72rem;
}

.dashboard-experiment-grid .experiment-trend-legend {
    gap: 0.42rem 0.62rem;
    font-size: 0.68rem;
}

.dashboard-experiment-grid .experiment-trend-summary {
    gap: 0.5rem;
}

.dashboard-experiment-grid .experiment-trend-summary > div {
    padding: 0.62rem 0.68rem;
    border-radius: 8px;
}

.dashboard-experiment-grid .experiment-trend-summary span,
.dashboard-experiment-grid .experiment-trend-summary em {
    font-size: 0.66rem;
}

.dashboard-experiment-grid .experiment-trend-summary strong {
    font-size: 0.88rem;
}

.dashboard-experiment-grid .experiment-line {
    stroke-width: 2.2;
}

.dashboard-experiment-grid .experiment-line-point {
    stroke-width: 1.5;
}

.dashboard-experiment-grid .experiment-trend-axis-labels {
    gap: 0.45rem;
    font-size: 0.66rem;
}

.home-lower-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.62fr);
    gap: clamp(2rem, 5vw, 5.5rem);
    align-items: start;
}

.home-library,
.home-action-stack {
    display: grid;
    align-content: start;
}

.home-library {
    gap: 1.2rem;
}

.home-lower-grid > .home-library:only-child {
    grid-column: 1 / -1;
}

.home-library .button {
    justify-self: start;
}

.home-library h3,
.home-action-stack h3 {
    font-family: var(--font-heading);
    margin: 0;
    color: var(--ink);
    font-size: 1.22rem;
    font-weight: 750;
    line-height: 1.2;
}

.library-list {
    display: grid;
    gap: 0.98rem;
}

.library-row {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    gap: 0.74rem;
    max-width: 780px;
}

.library-row strong {
    display: block;
    overflow: hidden;
    color: var(--ink);
    font-size: 0.92rem;
    font-weight: 750;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.library-row small {
    display: block;
    overflow: hidden;
    margin-top: 0.18rem;
    color: var(--muted);
    font-size: 0.82rem;
    line-height: 1.38;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.library-avatar {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border: 2px solid #fff;
    border-radius: 999px;
    color: #fff;
    font-size: 0.82rem;
    font-weight: 850;
    box-shadow: var(--shadow-sm);
}

.library-avatar.theme-1 { background: var(--logo-cyan); }
.library-avatar.theme-2 { background: var(--logo-blue); }
.library-avatar.theme-3 { background: var(--logo-purple); }
.library-avatar.theme-4 { background: var(--logo-magenta); }
.library-avatar.theme-5 { background: var(--logo-cyan); }

.home-action-stack {
    gap: 1.15rem;
}

.home-action-card {
    display: grid;
    grid-template-columns: 148px minmax(0, 1fr);
    align-items: center;
    gap: 1.15rem;
    color: var(--ink);
}

.home-action-card > span:last-child {
    min-width: 0;
}

.home-action-card strong {
    display: block;
    color: var(--ink);
    font-size: 0.96rem;
    font-weight: 750;
    line-height: 1.25;
}

.home-action-card small {
    display: block;
    margin-top: 0.26rem;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.42;
}

.home-action-visual {
    position: relative;
    min-height: 104px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: var(--surface-soft);
}

.home-action-visual span,
.home-action-visual i {
    position: absolute;
    display: block;
    border-radius: 11px;
    background: var(--accent);
    box-shadow: var(--shadow-sm);
}

.home-action-visual span {
    width: 42px;
    height: 42px;
}

.home-action-visual i {
    width: 36px;
    height: 36px;
    margin: 18px 0 0 34px;
    transform: rotate(13deg);
    background: var(--accent-2);
}

.home-action-card:hover .home-action-visual {
    box-shadow: var(--shadow-sm);
}

.home-action-card.theme-coral {
    --accent: #f2524f;
    --accent-2: #ff7f32;
}

.home-action-card.theme-green {
    --accent: #27c98f;
    --accent-2: #2fb6d4;
}

.home-action-card.theme-blue {
    --accent: #5f7ce8;
    --accent-2: #27c7a2;
}

.dashboard-header-compact {
    margin-top: 0.2rem;
    padding-top: 0.35rem;
}

.flash-stack {
    display: grid;
    gap: 0.55rem;
}

.flash,
.alert {
    padding: 0.84rem 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-sm);
    color: var(--text);
    font-size: 0.86rem;
}

.flash-success {
    background: var(--green-soft);
    border-color: #d8f3e8;
    color: #137e57;
}

.flash-error,
.alert-error {
    background: var(--red-soft);
    border-color: #ffd7d7;
    color: #c52222;
}

.flash-info {
    background: var(--blue-soft);
    border-color: #dfe6ff;
    color: #3657c8;
}

.alert-info {
    background: var(--blue-soft);
    border-color: #dfe6ff;
    color: #3657c8;
}

.hero-panel,
.content-card,
.auth-card,
.auth-showcase-panel,
.selector-card,
.integration-card,
.decision-card,
.insight-card,
.prediction-card,
.profit-metric,
.profit-analysis-grid > div,
.metric-inline,
.chart-label,
.quick-action,
.meta-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-hairline);
}

.content-card {
    padding: 2rem;
}

.docs-origin {
    display: grid;
    gap: 0.82rem;
    max-width: 1040px;
    margin-bottom: 1.35rem;
    padding: 2.15rem;
}

.listing-shell,
.form-canvas {
    padding: 2rem;
}

.content-card-feature {
    display: grid;
    align-self: start;
    align-content: start;
    gap: 1.85rem;
}

.content-card-side {
    align-self: start;
    display: grid;
    gap: 1.75rem;
}

.docs-layout {
    display: grid;
    grid-template-columns: minmax(220px, 0.26fr) minmax(0, 1fr);
    gap: 1.35rem;
    align-items: start;
}

.docs-toc {
    position: sticky;
    top: 1rem;
    display: grid;
    gap: 0.85rem;
    padding: 1.25rem;
}

.docs-toc h3,
.docs-section h3,
.docs-intro h3 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1rem;
}

.docs-toc nav,
.docs-content,
.docs-section,
.docs-intro {
    display: grid;
    gap: 1rem;
}

.docs-intro > div {
    display: grid;
    justify-items: start;
    gap: 0.85rem;
}

.docs-intro .pill {
    margin-bottom: 0.15rem;
}

.docs-intro h3 {
    max-width: 760px;
    font-size: 1.22rem;
    line-height: 1.22;
}

.docs-toc a {
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.35;
    text-decoration: none;
}

.docs-toc a:hover {
    color: var(--ink);
}

.docs-section p,
.docs-intro p,
.docs-origin p {
    margin: 0;
    color: var(--muted);
    line-height: 1.65;
}

.docs-origin p {
    max-width: 860px;
}

.docs-origin .docs-origin-lead {
    max-width: 820px;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.34rem;
    line-height: 1.28;
}

.docs-intro p {
    max-width: 780px;
    line-height: 1.75;
}

.docs-section ul {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding-left: 1.15rem;
    color: var(--muted);
    line-height: 1.55;
}

.docs-boundaries {
    border-color: #f5e0a8;
    background: #fff;
}

.docs-term-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
}

.docs-term-grid > div {
    display: grid;
    gap: 0.35rem;
    padding: 0.85rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.developers-page-header {
    background: #fff;
    border-color: var(--line);
    color: var(--ink);
}

.developers-page-header::before,
.developers-page-header::after {
    opacity: 0.06;
}

.developers-page-header h2,
.developers-page-header p,
.developers-page-header .eyebrow {
    color: var(--ink);
}

.developers-page-header p:not(.eyebrow) {
    color: var(--muted);
}

.developers-endpoint-card {
    display: grid;
    gap: 0.45rem;
    min-width: min(100%, 320px);
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.developers-endpoint-card span {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 760;
}

.developers-endpoint-card code {
    color: var(--ink);
    overflow-wrap: anywhere;
}

.developer-quickstart-grid,
.developer-key-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.15rem;
}

.developer-card,
.developer-created-key {
    display: grid;
    gap: 1.15rem;
}

.developer-card h3,
.developer-created-key h3,
.developers-redoc-head h3 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.05rem;
}

.developer-card p,
.developer-created-key p {
    margin: 0;
    color: var(--muted);
    line-height: 1.65;
}

.developer-created-key {
    border-color: var(--line);
    background: var(--surface-raised);
}

.developer-created-key h3,
.developer-created-key p,
.developer-created-key .eyebrow {
    color: var(--ink);
}

.developer-created-key p {
    color: var(--muted);
}

.developer-key-form {
    align-content: start;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.developer-key-form textarea {
    min-height: 92px;
}

.checkbox-field {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.45;
    cursor: pointer;
}

.checkbox-field input {
    width: auto;
    min-height: 0;
    margin-top: 0.2rem;
    flex: 0 0 auto;
}

.developer-key-table {
    margin-top: 1.15rem;
}

.developer-key-table code {
    color: var(--ink);
    overflow-wrap: anywhere;
}

.developers-redoc-shell {
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.developers-redoc-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.2rem 1.35rem;
    border-bottom: 1px solid var(--line);
    background: var(--surface-raised);
}

.developers-redoc-head h3,
.developers-redoc-head .eyebrow {
    color: var(--ink);
}

.developers-redoc {
    min-height: 82vh;
    background: #fff;
    color: var(--text);
}

.developers-redoc-loading {
    display: grid;
    min-height: 360px;
    place-items: center;
    color: var(--muted);
    font-size: 0.92rem;
}

.developers-redoc [role='search'] input {
    border-color: var(--line);
    background: #fff;
    color: var(--ink);
    box-shadow: none;
}

.developers-redoc * {
    border-color: var(--line) !important;
}

.developers-redoc svg line,
.developers-redoc svg polyline,
.developers-redoc svg path[stroke] {
    stroke: var(--line-strong) !important;
}

.developers-redoc button svg path[stroke],
.developers-redoc [role='button'] svg path[stroke] {
    stroke: currentColor !important;
}

.developers-redoc button,
.developers-redoc [role='button'] {
    color: var(--text) !important;
}

.developers-redoc [role='tab'] {
    border-color: var(--line) !important;
    background: #fff !important;
    color: var(--text) !important;
}

.developers-redoc [role='tab'][aria-selected='true'],
.developers-redoc button[aria-selected='true'],
.developers-redoc button[aria-pressed='true'] {
    border-color: var(--ink) !important;
    background: var(--ink) !important;
    color: #fff !important;
}

.developers-redoc [role='tab'][aria-selected='true'] *,
.developers-redoc button[aria-selected='true'] *,
.developers-redoc button[aria-pressed='true'] * {
    color: #fff !important;
}

.developers-redoc pre,
.developers-redoc pre code {
    border-color: #252833 !important;
    background: #0b0c0f !important;
    color: #f4f5f7 !important;
}

.developers-redoc pre {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02) !important;
}

.developers-redoc .pretty-json-container,
.developers-redoc .react-json-view {
    border: 1px solid #252833 !important;
    border-radius: 8px !important;
    background: #0b0c0f !important;
    color: #f4f5f7 !important;
}

.developers-redoc .pretty-json-container *,
.developers-redoc .react-json-view *,
.developers-redoc .pretty-json-container [style*='color'],
.developers-redoc .react-json-view [style*='color'] {
    color: #e5e7eb !important;
}

.developers-redoc .pretty-json-container .object-key,
.developers-redoc .react-json-view .object-key {
    color: #8bd5ff !important;
}

.developers-redoc .pretty-json-container .string-value,
.developers-redoc .react-json-view .string-value {
    color: #b7f7c1 !important;
}

.developers-redoc .pretty-json-container .integer-value,
.developers-redoc .pretty-json-container .float-value,
.developers-redoc .react-json-view .integer-value,
.developers-redoc .react-json-view .float-value {
    color: #ffd479 !important;
}

.developers-redoc .pretty-json-container .boolean-value,
.developers-redoc .pretty-json-container .null-value,
.developers-redoc .react-json-view .boolean-value,
.developers-redoc .react-json-view .null-value {
    color: #ff9ac8 !important;
}

.developers-redoc .pretty-json-container .variable-row,
.developers-redoc .pretty-json-container .brace-row,
.developers-redoc .react-json-view .variable-row,
.developers-redoc .react-json-view .brace-row {
    background: transparent !important;
}

.developers-redoc .redoc-json {
    overflow: auto !important;
    border: 1px solid #252833 !important;
    border-radius: 8px !important;
    background: #0b0c0f !important;
    color: #f4f5f7 !important;
}

.developers-redoc .redoc-json code {
    display: block !important;
    border: 0 !important;
    background: transparent !important;
    color: #f4f5f7 !important;
}

.developers-redoc .redoc-json .token,
.developers-redoc .redoc-json .property,
.developers-redoc .redoc-json .collapser,
.developers-redoc .redoc-json .ellipsis,
.developers-redoc .redoc-json a {
    color: #e5e7eb !important;
}

.developers-redoc .redoc-json .token.punctuation {
    color: #d7d7df !important;
}

.developers-redoc .redoc-json .property.token.string {
    color: #8bd5ff !important;
}

.developers-redoc .redoc-json .token.string {
    color: #b7f7c1 !important;
}

.developers-redoc .redoc-json .token.number {
    color: #ffd479 !important;
}

.developers-redoc .redoc-json .token.boolean,
.developers-redoc .redoc-json .token.keyword {
    color: #ff9ac8 !important;
}

.developers-redoc .redoc-json .hoverable {
    background: transparent !important;
}

@media (max-width: 900px) {
    .developer-quickstart-grid,
    .developer-key-actions {
        grid-template-columns: 1fr;
    }

    .developers-redoc-head {
        align-items: flex-start;
        flex-direction: column;
    }
}

.docs-term-grid strong {
    color: var(--ink);
    font-size: 0.88rem;
}

.docs-term-grid span {
    color: var(--muted);
    font-size: 0.8rem;
    line-height: 1.5;
}

.card-header h3,
.form-panel-head h3,
.selector-card h3,
.empty-state h3,
.side-card h3,
.integration-ident strong,
.quick-action strong {
    font-family: var(--font-heading);
    margin: 0 0 0.24rem;
    color: var(--ink);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0;
}

.card-header p:not(.eyebrow),
.form-panel-head p:not(.eyebrow) {
    margin: 0;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.6;
}

.card-header-tight {
    align-items: center;
}

.section-toolbar {
    margin-bottom: 1.75rem;
}

.section-divider,
.section-divider-top {
    border-top: 1px solid var(--line);
}

.section-divider {
    height: 1px;
    background: var(--line);
    border: 0;
}

.section-divider-top {
    margin-top: 1.35rem;
    padding-top: 1.45rem;
}

.connector-oauth-panel {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.connector-oauth-panel h3 {
    margin: 0 0 0.24rem;
    color: var(--ink);
    font-size: 1rem;
}

.connector-oauth-panel p {
    margin: 0;
}

.oauth-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.danger-zone {
    border-color: #ffd7d7;
    background: #fff;
}

.danger-zone .form-panel-head h3 {
    color: #9f1d1d;
}

.hero-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.8fr);
    overflow: hidden;
}

.hero-copy {
    padding: 1.45rem;
    background: var(--surface-muted);
    border-right: 1px solid var(--line);
}

.hero-copy h2 {
    margin-bottom: 0.55rem;
}

.hero-side {
    display: grid;
    align-content: start;
    gap: 0.75rem;
    padding: 1.2rem;
}

.hero-kpi {
    display: grid;
    gap: 0.18rem;
    padding: 0.86rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface-muted);
}

.hero-kpi span,
.hero-kpi small {
    color: var(--muted);
    font-size: 0.76rem;
}

.hero-kpi strong {
    color: var(--ink);
    font-size: 0.95rem;
    font-weight: 700;
}

.stats-grid,
.selector-grid,
.meta-grid {
    display: grid;
    gap: 1.45rem;
}

.stats-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.85rem;
}

.stats-grid-four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.stat-card {
    position: relative;
    display: grid;
    align-content: start;
    gap: 0.34rem;
    min-height: 112px;
    padding: 1rem;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.stat-card::before {
    content: "";
    position: absolute;
    inset: 0.72rem auto 0.72rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--line-strong);
    opacity: 0;
}

.stat-card span,
.stat-card small {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
}

.stat-card strong {
    color: var(--ink);
    font-size: clamp(1.14rem, 1.45vw, 1.48rem);
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.12;
    overflow-wrap: anywhere;
}

.stat-card-white {
    background: #fff;
}

.stat-card-white::before {
    display: none;
}

.stat-card-color {
    border-color: var(--line);
    background: #fff;
}

.stat-card-color::before {
    display: block;
    background: var(--accent);
    opacity: 0.86;
}

.stat-card-color::after {
    display: none;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 400px);
    gap: 1.75rem;
}

.smart-dashboard {
    display: grid;
    gap: 1.9rem;
}

.decision-stream,
.segment-list,
.channel-mix-list,
.freshness-list,
.quick-actions-stack,
.insight-list,
.stack-form,
.form-grid,
.side-card {
    display: grid;
    gap: 1.15rem;
}

.content-card-side > .side-card {
    padding-top: 1.55rem;
    border-top: 1px solid var(--line);
}

.content-card-side > .side-card-first {
    padding-top: 0;
    border-top: 0;
}

.code-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.code-list code {
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--surface-soft);
    color: var(--ink);
    padding: 7px 9px;
    font-size: 12px;
    line-height: 1.2;
}

.code-block {
    display: block;
    width: 100%;
    max-height: 520px;
    overflow: auto;
    margin: 0;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
    color: var(--ink);
    font-size: 0.78rem;
    line-height: 1.55;
    white-space: pre;
}

.code-block code {
    display: block;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font-size: inherit;
    line-height: inherit;
}

.commercial-report-shell {
    display: grid;
    gap: 2rem;
}

.commercial-report-brief {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
    gap: 1.2rem;
    align-items: stretch;
    padding: 1.35rem 1.45rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.commercial-report-brief::before {
    content: "";
    position: absolute;
    inset: 1rem auto 1rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--ink);
}

.commercial-report-brief h3,
.commercial-section-head h3 {
    margin: 0;
    color: var(--ink);
    font-size: 1.18rem;
    font-weight: 750;
    line-height: 1.22;
}

.commercial-report-brief p,
.commercial-section-head > p,
.commercial-finding p,
.commercial-exec-card p,
.commercial-action-item p,
.commercial-risk-list p {
    margin: 0;
    color: var(--muted);
    line-height: 1.62;
}

.commercial-report-stamp {
    display: grid;
    align-content: center;
    gap: 0.26rem;
    padding: 0.92rem 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.commercial-report-stamp span,
.commercial-report-stamp small,
.commercial-metric-card span,
.commercial-metric-card small,
.commercial-card-meta span {
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.35;
}

.commercial-report-stamp strong {
    color: var(--ink);
    font-size: 1.2rem;
    font-weight: 800;
}

.commercial-metric-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.72rem;
}

.commercial-metric-card {
    position: relative;
    display: grid;
    align-content: start;
    gap: 0.32rem;
    min-height: 104px;
    padding: 0.92rem 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.commercial-metric-card::before {
    content: "";
    position: absolute;
    inset: 0.72rem auto 0.72rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--line-strong);
    opacity: 0;
}

.commercial-metric-card strong {
    color: var(--ink);
    font-size: 1.3rem;
    font-weight: 800;
    line-height: 1.08;
}

.commercial-metric-card.is-profit {
    border-color: var(--line);
    background: #fff;
}

.commercial-metric-card.is-profit::before {
    background: var(--logo-cyan);
    opacity: 0.86;
}

.commercial-metric-card.is-risk {
    border-color: var(--line);
    background: #fff;
}

.commercial-metric-card.is-risk::before {
    background: var(--logo-magenta);
    opacity: 0.78;
}

.commercial-section {
    display: grid;
    gap: 1rem;
    padding-top: 1.45rem;
    border-top: 1px solid var(--line);
}

.commercial-section-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 470px);
    gap: 1.25rem;
    align-items: start;
}

.commercial-section-head.compact {
    grid-template-columns: 1fr;
    gap: 0.55rem;
}

.commercial-executive-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.85rem;
}

.commercial-exec-card {
    grid-column: span 2;
}

.commercial-exec-card:nth-child(4),
.commercial-exec-card:nth-child(5) {
    grid-column: span 3;
}

.commercial-two-column {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 1.55rem;
    align-items: start;
}

.commercial-finding-list,
.commercial-action-list,
.commercial-risk-list {
    display: grid;
    gap: 0.85rem;
}

.commercial-exec-card,
.commercial-finding,
.commercial-action-item,
.commercial-risk-list p {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: var(--shadow-hairline);
}

.commercial-exec-card,
.commercial-finding {
    position: relative;
    display: grid;
    gap: 0.58rem;
    padding: 1rem;
}

.commercial-exec-card::before,
.commercial-finding::before,
.commercial-action-item::before,
.commercial-risk-list p::before {
    content: "";
    position: absolute;
    inset: 0.8rem auto 0.8rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--line-strong);
}

.commercial-exec-card.is-success,
.commercial-finding.is-success,
.commercial-action-item.is-success {
    border-color: rgba(41, 201, 139, 0.2);
    background: #fff;
}

.commercial-exec-card.is-success::before,
.commercial-finding.is-success::before,
.commercial-action-item.is-success::before {
    background: var(--green);
}

.commercial-exec-card.is-warning,
.commercial-finding.is-warning,
.commercial-action-item.is-warning {
    border-color: rgba(239, 68, 68, 0.18);
    background: #fff;
}

.commercial-exec-card.is-warning::before,
.commercial-finding.is-warning::before,
.commercial-action-item.is-warning::before {
    background: var(--red);
}

.commercial-exec-card.is-neutral,
.commercial-finding.is-neutral,
.commercial-action-item.is-neutral {
    border-color: color-mix(in srgb, var(--blue) 18%, var(--line));
}

.commercial-exec-card.is-neutral::before,
.commercial-finding.is-neutral::before,
.commercial-action-item.is-neutral::before {
    background: var(--blue);
}

.commercial-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.commercial-card-meta em {
    color: var(--ink);
    font-style: normal;
    font-size: 0.82rem;
    font-weight: 800;
    white-space: nowrap;
}

.commercial-exec-card strong,
.commercial-finding strong,
.commercial-action-item strong {
    display: block;
    color: var(--ink);
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.32;
}

.commercial-action-item {
    position: relative;
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 0.9rem;
    padding: 1rem;
}

.commercial-action-item > span {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--ink);
    color: var(--surface);
    font-weight: 800;
}

.commercial-action-item p {
    margin-top: 0.32rem;
}

.commercial-risk-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.commercial-risk-list p {
    position: relative;
    padding: 0.92rem 1rem;
    border-color: rgba(226, 162, 15, 0.2);
    background: #fff;
}

.commercial-risk-list p::before {
    background: var(--amber);
}

.decision-card {
    display: flex;
    gap: 1.18rem;
    padding: 1.35rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.decision-card:hover,
.quick-action:hover,
.integration-card:hover,
.insight-card:hover,
.prediction-card:hover {
    border-color: var(--line-strong);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}

.decision-avatar,
.customer-avatar {
    width: 36px;
    height: 36px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--black);
    color: #fff;
    font-size: 0.76rem;
    font-weight: 750;
}

.customer-avatar {
    width: 30px;
    height: 30px;
    font-size: 0.68rem;
}

.decision-body {
    flex: 1;
    min-width: 0;
}

.decision-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.95rem;
}

.decision-layer-card {
    align-items: flex-start;
}

.decision-layer-card .decision-avatar {
    width: 44px;
    height: 44px;
    font-size: 0.82rem;
}

.profit-value {
    color: var(--ink);
}

.profit-value.is-negative {
    color: #c52222;
}

.confidence-value.is-high {
    color: #13835a;
}

.confidence-value.is-low {
    color: #b45309;
}

.roi-window-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.28rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
}

.roi-window-tabs a {
    min-width: 48px;
    padding: 0.48rem 0.72rem;
    border-radius: 6px;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
    text-align: center;
}

.roi-window-tabs a.is-active {
    background: var(--black);
    color: #fff;
}

.roi-incrementality-async-shell,
.roi-incrementality-async-shell .dashboard-widget {
    display: grid;
    gap: 2rem;
    width: 100%;
}

.roi-incrementality-async-shell .dashboard-widget > .page-header,
.roi-incrementality-async-shell .dashboard-widget > .roi-kpi-grid {
    margin: 0;
}

.kpi-header.roi-kpi-grid {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1.5rem;
}

.roi-warning-card {
    border-color: color-mix(in srgb, var(--amber) 34%, var(--line));
    background: #fff;
}

.roi-warning-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.roi-warning-list span {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0.38rem 0.62rem;
    border: 1px solid color-mix(in srgb, var(--amber) 32%, var(--line));
    border-radius: 999px;
    background: #fff;
    color: #7a4d00;
    font-size: 0.78rem;
    font-weight: 700;
}

.roi-main-grid {
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.55fr);
}

.roi-context-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.roi-debug-details {
    margin-top: 1rem;
    color: var(--muted);
    font-size: 0.82rem;
}

.roi-debug-details summary {
    cursor: pointer;
    color: var(--ink);
    font-weight: 700;
}

.roi-debug-details ul {
    display: grid;
    gap: 0.4rem;
    margin: 0.75rem 0 0;
    padding-left: 1.1rem;
}

.decision-inspector-list {
    display: grid;
    gap: 0.75rem;
}

.decision-inspector-item {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.decision-inspector-item summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 1rem;
    cursor: pointer;
}

.decision-inspector-item summary span:first-child {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.decision-inspector-item summary strong,
.decision-inspector-item summary em {
    overflow-wrap: anywhere;
}

.decision-inspector-item summary em,
.decision-alternatives em {
    color: var(--muted);
    font-size: 0.76rem;
    font-style: normal;
}

.decision-inspector-body {
    display: grid;
    gap: 1rem;
    padding: 0 1rem 1rem;
}

.decision-detail-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.bandit-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.bandit-metrics span {
    display: inline-flex;
    gap: 0.35rem;
    align-items: center;
    min-height: 25px;
    padding: 0.22rem 0.55rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 650;
}

.context-kpi-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: -0.35rem;
}

.context-kpi-item,
.context-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 25px;
    padding: 0.24rem 0.6rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1;
}

.context-kpi-item {
    gap: 0.42rem;
    border-radius: 8px;
    background: #fff;
}

.context-kpi-item strong {
    color: var(--ink);
    font-size: 0.82rem;
}

.discovery-opportunity-list .context-kpi-item {
    align-items: flex-start;
    flex: 1 1 240px;
    flex-direction: column;
    gap: 0.35rem;
    line-height: 1.35;
}

.discovery-opportunity-list .context-kpi-item small {
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 650;
}

.hypothesis-badge {
    display: inline-flex;
    width: fit-content;
    min-height: 22px;
    align-items: center;
    padding: 0.18rem 0.5rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--muted);
    font-size: 0.68rem;
    font-style: normal;
    font-weight: 760;
    line-height: 1;
}

.context-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin: -0.25rem 0 0.9rem;
}

.context-badge.is-positive,
.context-kpi-item.is-positive {
    background: var(--green-soft);
    border-color: #d8f3e8;
    color: #13835a;
}

.context-badge.is-warning,
.context-kpi-item.is-warning {
    background: var(--amber-soft);
    border-color: #f5e0a8;
    color: #9b6b00;
}

.context-badge.is-info,
.context-kpi-item.is-info {
    background: var(--blue-soft);
    border-color: #dde5ff;
    color: #395bd1;
}

.decision-context-block {
    display: grid;
    gap: 0.85rem;
}

.decision-context-section {
    display: grid;
    gap: 0.75rem;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.decision-context-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.decision-context-head h4 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.9rem;
}

.context-note {
    margin: 0;
    padding: 0.62rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--muted);
    background: var(--surface-muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.context-note.is-info {
    border-color: #dde5ff;
    color: #395bd1;
    background: var(--blue-soft);
}

.context-metric-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.55rem;
}

.context-metric-grid > div {
    display: grid;
    gap: 0.28rem;
    padding: 0.68rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.context-metric-grid span,
.context-key-stack span {
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.35;
}

.context-metric-grid strong,
.context-key-stack strong {
    color: var(--ink);
    font-size: 0.84rem;
    font-weight: 730;
    overflow-wrap: anywhere;
}

.context-metric-grid strong.is-positive {
    color: #13835a;
}

.context-metric-grid strong.is-warning {
    color: #9b6b00;
}

.context-key-stack,
.context-explanation-list {
    display: grid;
    gap: 0.35rem;
}

.context-explanation-list {
    margin: 0;
    padding-left: 1.05rem;
    color: var(--muted);
    font-size: 0.8rem;
    line-height: 1.5;
}

.context-learning-table .data-table td:first-child strong {
    display: inline-block;
    max-width: 22rem;
    overflow-wrap: anywhere;
}

.decision-explain,
.decision-explanation-block,
.decision-alternatives {
    display: grid;
    gap: 0.55rem;
}

.decision-explain h4,
.decision-explanation-head h4,
.decision-alternatives h4 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.9rem;
}

.decision-explain p,
.decision-explanation-block p,
.decision-alternatives p {
    margin: 0;
}

.decision-explanation-block {
    gap: 0.85rem;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.decision-explanation-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
}

.decision-explanation-head > div {
    display: grid;
    gap: 0.35rem;
    min-width: 0;
}

.decision-explanation-head p,
.decision-explanation-section p,
.decision-why-not p,
.decision-explanation-limits {
    color: var(--text);
    font-size: 0.82rem;
    line-height: 1.55;
}

.decision-explanation-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.55rem;
}

.decision-explanation-section {
    display: grid;
    align-content: start;
    gap: 0.32rem;
    padding: 0.68rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-explanation-section span,
.decision-why-not h5,
.decision-evidence h5,
.decision-explanation-snippet span {
    margin: 0;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 750;
    line-height: 1.35;
}

.decision-why-not,
.decision-evidence {
    display: grid;
    gap: 0.55rem;
}

.decision-why-not ul {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.decision-why-not li {
    display: grid;
    gap: 0.35rem;
    padding: 0.65rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.decision-why-not li > div {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.45rem;
}

.decision-why-not strong {
    color: var(--ink);
    font-size: 0.82rem;
}

.decision-why-not span,
.decision-why-not em {
    color: var(--muted);
    font-size: 0.74rem;
    font-style: normal;
}

.decision-evidence-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.decision-evidence-chips .context-badge {
    gap: 0.25rem;
    line-height: 1.25;
}

.decision-explanation-limits {
    padding-top: 0.65rem;
    border-top: 1px solid var(--line);
    color: var(--muted);
}

.decision-alternatives ul {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.decision-alternatives li {
    display: grid;
    gap: 0.75rem;
    padding: 0.55rem 0.65rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.decision-alternatives li > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.decision-alternatives li p {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.decision-customer {
    display: grid;
    gap: 0.16rem;
    min-width: min(100%, 260px);
    margin-right: 0.25rem;
}

.decision-customer strong {
    overflow-wrap: anywhere;
}

.decision-customer span {
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.decision-head-badges {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.decision-head strong,
.decision-action strong,
.segment-item strong,
.freshness-item strong,
.profit-profile-link strong,
.customer-cell strong {
    font-family: var(--font-heading);
    color: var(--ink);
    font-size: 0.88rem;
    font-weight: 700;
}

.decision-time {
    margin-left: auto;
    color: var(--muted);
    font-size: 0.74rem;
}

.decision-why {
    display: flex;
    align-items: flex-start;
    gap: 0.78rem;
    margin-bottom: 0.95rem;
    padding: 0.92rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
}

.decision-why > span {
    flex: 0 0 auto;
    margin-top: 0.05rem;
    color: var(--muted);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.decision-signals,
.decision-action,
.insight-segment-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.decision-signals span,
.decision-status,
.decision-confidence,
.decision-cost,
.insight-segment-tags span,
.insight-action span,
.pill,
.role-badge,
.status-badge,
.tier-badge,
.insight-score,
.prediction-card-head em {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 25px;
    padding: 0.22rem 0.55rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 650;
    line-height: 1;
    letter-spacing: 0;
    text-transform: none;
}

.decision-status.is-sent,
.decision-status.is-positive,
.status-active,
.insight-score.is-positive {
    background: var(--green-soft);
    border-color: #d8f3e8;
    color: #13835a;
}

.decision-status.is-suppressed,
.decision-status.is-warning,
.status-inactive,
.insight-score.is-warning,
.tier-gold {
    background: var(--amber-soft);
    border-color: #f5e0a8;
    color: #9b6b00;
}

.decision-channel,
.pill,
.role-admin {
    background: var(--purple-soft);
    border-color: #e5ddff;
    color: #5e44c7;
}

.decision-arrow {
    color: var(--muted);
    font-size: 0.9rem;
    font-weight: 700;
}

.decision-cost {
    background: var(--blue-soft);
    border-color: #dde5ff;
    color: #395bd1;
}

.decision-explanation-snippet {
    display: grid;
    gap: 0.35rem;
    margin-top: 0.8rem;
    padding: 0.78rem 0.85rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-explanation-snippet p {
    margin: 0;
    color: var(--text);
    font-size: 0.82rem;
    line-height: 1.5;
}

.decision-explanation-snippet em {
    color: var(--muted);
    font-size: 0.7rem;
    font-style: normal;
    font-weight: 750;
}

.decision-campaign {
    position: relative;
    display: grid;
    gap: 0.72rem;
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.decision-approval-panel {
    gap: 1rem;
    margin-top: 0;
    padding: 1.15rem 1.25rem;
    background: var(--surface-raised);
}

.decision-approval-panel::before {
    background: var(--purple);
}

.decision-approval-panel .segment-list {
    gap: 0;
}

.decision-approval-item {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.95rem;
    padding: 1.05rem 0;
    border-top: 1px solid var(--line);
}

.decision-approval-item:first-child {
    border-top: 0;
    padding-top: 0.2rem;
}

.decision-approval-check {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 0.15rem;
}

.decision-approval-content {
    min-width: 0;
    display: grid;
    gap: 0.42rem;
}

.decision-approval-title {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.decision-approval-title strong {
    min-width: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.92rem;
    font-weight: 760;
    overflow-wrap: anywhere;
}

.decision-approval-title span,
.decision-approval-meta span {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 24px;
    padding: 0.18rem 0.48rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 680;
    line-height: 1;
}

.decision-approval-meta {
    min-width: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.decision-approval-meta span {
    max-width: 240px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.decision-approval-content small {
    max-width: 76ch;
    color: var(--text);
    font-size: 0.8rem;
    line-height: 1.42;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.decision-approval-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.decision-campaign::before {
    content: "";
    position: absolute;
    inset: 0.8rem auto 0.8rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--purple);
}

.decision-campaign-head {
    display: flex;
    justify-content: space-between;
    gap: 0.85rem;
    align-items: center;
}

.decision-campaign-head span,
.decision-campaign-grid span {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 750;
    line-height: 1.35;
}

.decision-campaign-head em {
    color: var(--purple);
    font-size: 0.7rem;
    font-style: normal;
    font-weight: 800;
}

.decision-campaign > strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.3;
}

.decision-campaign p {
    margin: 0;
    color: var(--text);
    font-size: 0.84rem;
    line-height: 1.58;
}

.decision-campaign-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.decision-campaign-grid > div {
    display: grid;
    align-content: start;
    gap: 0.35rem;
    min-width: 0;
    padding: 0.75rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-campaign-grid p,
.decision-campaign-foot {
    color: var(--muted);
    font-size: 0.78rem;
}

.decision-campaign-foot {
    padding-top: 0.7rem;
    border-top: 1px solid var(--line);
}

.decision-outcome,
.queue-impact {
    color: #13835a;
    font-size: 0.78rem;
    font-weight: 650;
}

.decision-cost-note,
.row-note,
.inline-note {
    color: var(--muted);
    font-size: 0.75rem;
    line-height: 1.45;
}

.segment-item,
.freshness-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.85rem;
    padding-bottom: 1.12rem;
    border-bottom: 1px solid var(--line);
}

.segment-item:last-child,
.freshness-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.segment-item span,
.freshness-item span {
    display: block;
    margin-top: 0.3rem;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.segment-item em,
.freshness-item em {
    color: var(--ink);
    font-style: normal;
    font-size: 0.9rem;
    font-weight: 750;
    text-align: right;
}

.channel-mix-item {
    display: grid;
    grid-template-columns: 94px 1fr 38px;
    align-items: center;
    gap: 0.65rem;
}

.dashboard-action-list .channel-mix-item,
.dashboard-tier-list .channel-mix-item {
    grid-template-columns: minmax(0, 1fr) minmax(64px, 0.65fr) 38px;
}

.channel-label {
    min-width: 0;
    overflow: hidden;
    color: var(--text);
    font-size: 0.8rem;
    font-weight: 500;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.channel-bar,
.score-bar {
    overflow: hidden;
    border-radius: 999px;
    background: #ececef;
}

.channel-bar {
    height: 6px;
}

.channel-bar span,
.score-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--purple);
}

.channel-mix-item strong {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 650;
    text-align: right;
}

.run-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.latest-run-panel {
    display: grid;
    gap: 1rem;
    padding: 1.15rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.latest-run-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.4rem;
}

.latest-run-head h3 {
    margin: 0.12rem 0 0.35rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.22rem;
}

.latest-run-head p:not(.eyebrow) {
    max-width: 46rem;
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.latest-run-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

.run-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 2.25rem;
    padding: 0 0.72rem;
    border-radius: 8px;
    border: 1px solid var(--line);
    color: var(--muted);
    background: #fff;
    font-size: 0.82rem;
    font-weight: 760;
}

.run-status-pill.is-success {
    border-color: rgba(24, 149, 105, 0.2);
    color: #13795a;
    background: #e9f8f0;
}

.run-status-pill.is-error {
    border-color: rgba(194, 32, 32, 0.22);
    color: #b91c1c;
    background: #fff0f0;
}

.latest-run-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr minmax(180px, 1.35fr);
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.latest-run-metrics > div {
    display: grid;
    gap: 0.35rem;
    padding: 0.9rem 1rem;
    border-right: 1px solid var(--line);
}

.latest-run-metrics > div:last-child {
    border-right: 0;
}

.latest-run-metrics span,
.latest-run-meta {
    color: var(--muted);
    font-size: 0.77rem;
    line-height: 1.35;
}

.latest-run-metrics strong {
    color: var(--ink);
    font-size: 1.05rem;
    font-weight: 780;
    overflow-wrap: anywhere;
}

.latest-run-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 1.1rem;
}

.run-summary > div,
.insight-explainer > div,
.insight-card-side > div,
.prediction-metrics > div {
    display: grid;
    gap: 0.4rem;
    padding: 0.9rem 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
}

.run-summary span,
.freshness-item span,
.profit-metric span,
.profit-analysis-grid span,
.prediction-card span,
.insight-explainer span,
.insight-card-side span {
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.35;
}

.run-summary strong,
.freshness-item strong,
.profit-metric strong,
.profit-analysis-grid strong,
.prediction-metrics strong,
.metric-inline strong,
.chart-label strong,
.insight-card-side strong {
    color: var(--ink);
    font-size: 0.9rem;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.quick-action {
    position: relative;
    display: grid;
    gap: 0.32rem;
    padding: 0.95rem 2.2rem 0.95rem 1rem;
    background: #fff;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.quick-action::after {
    content: "";
    position: absolute;
    top: 1.12rem;
    right: 1rem;
    width: 9px;
    height: 9px;
    border-top: 1.7px solid var(--muted-soft);
    border-right: 1.7px solid var(--muted-soft);
    transform: rotate(45deg);
}

.selector-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.selector-card {
    padding: 1.5rem;
}

.connector-flow-shell,
.connector-map-shell {
    display: grid;
    gap: 1.45rem;
}

.connector-flow-shell .section-toolbar,
.connector-map-shell .section-toolbar {
    margin-bottom: 0;
}

.connector-flow {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 72px minmax(0, 1fr) 72px minmax(0, 1fr);
    align-items: stretch;
    gap: 0.7rem;
}

.connector-flow-node {
    min-width: 0;
    min-height: 178px;
    display: grid;
    align-content: start;
    gap: 0.72rem;
    padding: 1.12rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface);
    box-shadow: var(--shadow-hairline);
}

.connector-flow-node.flow-input {
    border-color: rgba(90, 120, 230, 0.24);
    background: var(--blue-soft);
}

.connector-flow-node.flow-engine {
    border-color: rgba(122, 92, 230, 0.22);
    background: var(--purple-soft);
}

.connector-flow-node.flow-output {
    border-color: rgba(41, 201, 139, 0.28);
    background: var(--green-soft);
}

.connector-flow-kicker {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.connector-flow-node strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.08rem;
    font-weight: 760;
    letter-spacing: 0;
}

.connector-flow-node p {
    margin: 0;
    color: var(--text);
    font-size: 0.82rem;
    line-height: 1.52;
}

.connector-flow-node em {
    align-self: end;
    color: var(--muted);
    font-size: 0.74rem;
    font-style: normal;
    font-weight: 700;
}

.connector-flow-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.connector-flow-pills span {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    max-width: 100%;
    padding: 0.28rem 0.52rem;
    border: 1px solid rgba(17, 17, 17, 0.08);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.7);
    color: var(--ink);
    font-size: 0.72rem;
    font-weight: 760;
    overflow-wrap: anywhere;
}

.connector-flow-pills span.is-muted {
    color: var(--muted);
    background: rgba(255, 255, 255, 0.42);
}

.connector-flow-rail {
    position: relative;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.connector-flow-rail::before {
    content: "";
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: var(--line-strong);
    opacity: 0.36;
}

.connector-flow-rail::after {
    content: "";
    position: absolute;
    right: 0.18rem;
    width: 10px;
    height: 10px;
    border-top: 2px solid rgba(17, 17, 17, 0.45);
    border-right: 2px solid rgba(17, 17, 17, 0.45);
    transform: rotate(45deg);
}

.connector-lane-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
}

.connector-lane {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: 1rem;
}

.connector-lane-head {
    min-height: 58px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--line);
}

.connector-lane-head h3 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 740;
    letter-spacing: 0;
}

.connector-lane-head span {
    min-width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 800;
}

.connector-lane-input .connector-lane-head span {
    background: var(--blue-soft);
    color: #3657c8;
}

.connector-lane-output .connector-lane-head span {
    background: var(--green-soft);
    color: #157457;
}

.connector-lane-cards {
    grid-template-columns: 1fr;
}

.connector-role-card {
    --connector-accent: #3656e7;
    --connector-accent-fill: #0aa8dc;
    --connector-accent-soft: var(--blue-soft);
    --connector-accent-border: #dfe6ff;
}

.connector-role-card.is-output {
    --connector-accent: #157457;
    --connector-accent-fill: #157457;
    --connector-accent-soft: var(--green-soft);
    --connector-accent-border: #d8f3e8;
}

.connector-type-klaviyo {
    --connector-accent: #5e44c7;
    --connector-accent-fill: #5e44c7;
    --connector-accent-soft: var(--purple-soft);
    --connector-accent-border: #e5ddff;
}

.connector-role-card.is-input .integration-icon {
    background: var(--connector-accent-soft);
    color: var(--connector-accent);
}

.connector-role-card.is-output .integration-icon {
    background: var(--connector-accent-soft);
    color: var(--connector-accent);
}

.connector-type-klaviyo .integration-icon {
    border-color: var(--connector-accent-border);
}

.integration-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.35rem;
}

.integration-card {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    padding: 1.42rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.integration-card-head,
.integration-ident,
.integration-meta,
.customer-cell,
.score-bar-wrap {
    display: flex;
    align-items: center;
    gap: 0.7rem;
}

.integration-card-head,
.integration-meta {
    justify-content: space-between;
}

.integration-ident {
    min-width: 0;
}

.integration-ident span,
.integration-copy,
.integration-meta span {
    color: var(--muted);
    font-size: 0.78rem;
}

.integration-icon {
    width: 36px;
    height: 36px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border: 1px solid transparent;
    border-radius: 9px;
    background: var(--surface-soft);
    color: var(--ink);
    font-size: 0.92rem;
    font-weight: 800;
}

.integration-copy {
    margin: 0;
    line-height: 1.52;
}

.connector-capability-panel,
.connector-telemetry {
    display: grid;
    gap: 0.72rem;
    padding: 0.82rem;
    border: 1px solid #ededf1;
    border-radius: 8px;
    background: #fafafb;
}

.connector-panel-head,
.connector-resource-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
}

.connector-panel-head span,
.connector-resource-row span,
.connector-telemetry-error {
    color: var(--muted);
    font-size: 0.74rem;
}

.connector-panel-head strong {
    color: var(--ink);
    font-size: 0.78rem;
    font-weight: 760;
    white-space: nowrap;
}

.connector-capability-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.connector-capability-pill {
    display: inline-flex;
    align-items: center;
    min-height: 23px;
    max-width: 100%;
    padding: 0.22rem 0.48rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--ink);
    background: var(--surface);
    font-size: 0.72rem;
    font-weight: 650;
    overflow-wrap: anywhere;
}

.connector-capability-pill.input {
    border-color: var(--connector-accent-border);
    background: var(--connector-accent-soft);
}

.connector-capability-pill.output {
    border-color: var(--connector-accent-border);
    background: var(--connector-accent-soft);
}

.connector-capability-pill.muted {
    color: var(--muted);
    background: transparent;
}

.code-sample {
    max-width: 100%;
    margin: 0;
    padding: 1rem;
    overflow: auto;
    border: 1px solid #252833;
    border-radius: var(--radius-control);
    background: #0b0c0f;
    color: #f4f5f7;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
    font-size: 0.82rem;
    line-height: 1.5;
}

.code-sample code {
    display: block;
    padding: 0;
    border: 0;
    background: transparent;
    white-space: pre;
}

.code-sample-json {
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
}

.code-token-key {
    color: #8bd5ff;
}

.code-token-string {
    color: #b7f7c1;
}

.code-token-number {
    color: #ffd479;
}

.code-token-boolean {
    color: #ff9ac8;
}

.code-token-null {
    color: #a3a8b6;
}

.code-token-punctuation {
    color: #d7d7df;
}

.connector-line-chart {
    display: grid;
    gap: 0.3rem;
}

.connector-line-chart svg {
    display: block;
    width: 100%;
    height: auto;
    overflow: visible;
}

.connector-line-grid {
    stroke: rgba(17, 24, 39, 0.055);
    stroke-width: 1;
}

.connector-line-path {
    fill: none;
    stroke: var(--connector-accent);
    stroke-width: 2.1;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.connector-line-area {
    opacity: 1;
}

.connector-line-point {
    fill: #fff;
    stroke: var(--connector-accent);
    stroke-width: 1.65;
}

.connector-line-labels {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.25rem;
}

.connector-line-labels small {
    color: var(--muted);
    font-size: 0.64rem;
    text-align: center;
    white-space: nowrap;
}

.connector-resource-row {
    flex-wrap: wrap;
    justify-content: flex-start;
}

.connector-telemetry-error {
    margin: 0;
    line-height: 1.45;
}

.capability-editor-shell {
    margin-top: -24px;
}

.account-output-shell {
    margin-top: 0;
    margin-bottom: 1.25rem;
}

.output-cost-shell .capability-editor-card {
    align-content: start;
}

.output-cost-shell .capability-editor-card.is-enabled {
    box-shadow: inset 0 0 0 1px rgba(5, 150, 105, 0.08);
}

.channel-testing-panel {
    display: grid;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.capability-readonly,
.capability-editor-form {
    display: grid;
    gap: 1rem;
}

.capability-readonly {
    padding: 0.95rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.capability-editor-section {
    display: grid;
    gap: 0.75rem;
}

.capability-editor-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.capability-editor-section-head span {
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 760;
}

.capability-readonly > span {
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 700;
}

.capability-editor-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.capability-editor-card {
    display: grid;
    gap: 0.92rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.capability-editor-card.is-enabled {
    border-color: rgba(5, 150, 105, 0.32);
    background: rgba(5, 150, 105, 0.05);
}

.capability-editor-head,
.capability-toggle,
.capability-consent,
.capability-meta-row {
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.capability-editor-head {
    justify-content: space-between;
}

.capability-toggle,
.capability-consent {
    min-width: 0;
    cursor: pointer;
}

.capability-toggle input,
.capability-consent input {
    width: auto;
    min-height: 0;
    flex: 0 0 auto;
}

.capability-toggle span {
    color: var(--ink);
    font-size: 0.9rem;
    font-weight: 760;
}

.capability-editor-head strong {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 760;
    white-space: nowrap;
}

.capability-editor-card p,
.capability-consent span {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.5;
}

.capability-meta-row {
    flex-wrap: wrap;
}

.capability-meta-row span {
    padding: 0.23rem 0.45rem;
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.capability-card-fields {
    gap: 0.72rem;
}

.form-grid.two-cols {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.form-grid.three-cols {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.form-field {
    display: grid;
    gap: 0.42rem;
}

.form-field > span,
.form-section-title {
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 650;
}

input,
select,
textarea {
    width: 100%;
    min-height: 42px;
    padding: 0.63rem 0.78rem;
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-control);
    outline: none;
    background: #fff;
    color: var(--ink);
    box-shadow: var(--shadow-hairline);
    transition: border-color 0.14s ease, box-shadow 0.14s ease, background-color 0.14s ease;
}

input[type="checkbox"],
input[type="radio"] {
    width: 18px;
    height: 18px;
    min-height: 18px;
    flex: 0 0 auto;
    padding: 0;
    border-radius: 4px;
    box-shadow: none;
    accent-color: var(--black);
    cursor: pointer;
}

input[type="radio"] {
    border-radius: 999px;
}

input::placeholder,
textarea::placeholder {
    color: var(--muted-soft);
}

input:focus,
select:focus,
textarea:focus {
    border-color: #b9bbc4;
    box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.06);
}

textarea {
    min-height: 128px;
    resize: vertical;
}

.field-note,
.field-error {
    font-size: 0.76rem;
}

.field-error {
    color: var(--red);
}

.password-input {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.55rem;
    align-items: center;
}

.button {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.42rem;
    padding: 0 0.95rem;
    border: 1px solid transparent;
    border-radius: var(--radius-control);
    background: var(--black);
    color: #fff;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    font-size: 0.86rem;
    font-weight: 650;
    line-height: 1;
    white-space: nowrap;
    transition: transform 0.12s ease, box-shadow 0.14s ease, background-color 0.14s ease, border-color 0.14s ease;
}

.button.is-small {
    min-height: 36px;
    padding-inline: 0.78rem;
    font-size: 0.8rem;
}

.button:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.button:disabled,
.button:disabled:hover {
    border-color: var(--line);
    background: var(--surface-muted);
    color: var(--muted);
    box-shadow: none;
    cursor: not-allowed;
    transform: none;
}

.button-solid {
    background: var(--black);
}

.button-secondary {
    background: #fff;
    color: var(--ink);
    border-color: var(--line);
}

.button-ghost {
    background: var(--surface-muted);
    color: var(--text);
    border-color: var(--line);
}

.button-danger {
    background: var(--red-soft);
    color: #c52222;
    border-color: #ffd7d7;
}

.button-danger-solid {
    background: #c52222;
    color: #fff;
    border-color: #c52222;
}

.button-danger-solid:hover,
.button-danger-solid:focus-visible {
    background: #a91d1d;
    border-color: #a91d1d;
    color: #fff;
}

.button-small {
    min-height: 34px;
    padding: 0 0.7rem;
    font-size: 0.78rem;
}

.meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.meta-card {
    padding: 1rem;
    background: var(--surface-muted);
}

.meta-card span {
    display: block;
    margin-bottom: 0.18rem;
    color: var(--muted);
    font-size: 0.74rem;
}

.meta-card strong {
    color: var(--ink);
    font-size: 0.86rem;
}

.role-super_admin,
.tier-platinum {
    background: var(--black);
    border-color: var(--black);
    color: #fff;
}

.role-user,
.tier-silver,
.tier-watch {
    background: var(--surface-muted);
    color: var(--text);
}

.empty-state {
    display: grid;
    gap: 0.42rem;
    padding: 1rem;
}

.empty-state.compact {
    padding: 0.7rem 0;
}

.table-shell {
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
}

.table-wrap {
    overflow-x: auto;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.86rem;
}

.data-table th,
.data-table td {
    padding: 1rem 1.1rem;
    text-align: left;
    vertical-align: middle;
    border-bottom: 1px solid var(--line);
}

.data-table th {
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.data-table tbody tr:last-child td {
    border-bottom: 0;
}

.data-table tbody tr:hover {
    background: var(--surface-raised);
}

.profit-profile-layout {
    display: grid;
    grid-template-columns: minmax(480px, 0.36fr) minmax(0, 1fr);
    gap: 1.35rem;
}

.segment-builder-shell {
    display: grid;
    gap: 1.1rem;
}

.segment-management-card,
.segment-suggestions-card {
    display: grid;
    gap: 1rem;
}

.segment-card-list,
.segment-suggestion-list {
    display: grid;
    gap: 0.9rem;
}

.segment-card,
.segment-suggestion-card {
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.segment-card-head,
.segment-suggestion-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.segment-card h4,
.segment-suggestion-card h4 {
    margin: 0;
    color: var(--ink);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.24;
}

.segment-card p,
.segment-suggestion-card p {
    margin: 0.28rem 0 0;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.48;
}

.status-pill {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.32rem 0.62rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 780;
    white-space: nowrap;
}

.status-pill.is-ready {
    border-color: rgba(41, 201, 139, 0.28);
    background: rgba(41, 201, 139, 0.1);
    color: #147b51;
}

.status-pill.is-running {
    border-color: rgba(25, 119, 243, 0.24);
    background: rgba(25, 119, 243, 0.08);
    color: var(--blue);
}

.status-pill.is-failed {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #9f1d1d;
}

.segment-card-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.7rem;
}

.segment-card-metrics > div {
    display: grid;
    gap: 0.2rem;
    min-height: 70px;
    padding: 0.72rem 0.78rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.segment-card-metrics span,
.segment-preview-card dt {
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.3;
}

.segment-card-metrics strong,
.segment-preview-card dd {
    color: var(--ink);
    font-size: 0.9rem;
    font-weight: 780;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.segment-next-action {
    display: grid;
    gap: 0.25rem;
    padding: 0.8rem 0.85rem;
    border: 1px solid rgba(25, 119, 243, 0.18);
    border-radius: 8px;
    background: #fff;
}

.segment-next-action.compact {
    background: var(--surface-muted);
}

.segment-next-action span {
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 760;
}

.segment-next-action strong {
    color: var(--ink);
    font-size: 0.95rem;
    font-weight: 820;
}

.segment-next-action p {
    margin: 0;
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.45;
}

.segment-card-actions {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.segment-edit-form {
    display: grid;
    gap: 0.7rem;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.segment-edit-form[hidden],
.segment-card-status[hidden],
.segment-empty-state[hidden] {
    display: none;
}

.segment-edit-form label {
    display: grid;
    gap: 0.32rem;
    color: var(--ink);
    font-size: 0.8rem;
    font-weight: 750;
}

.segment-edit-form input,
.segment-edit-form textarea {
    width: 100%;
    padding: 0.72rem 0.78rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
    color: var(--ink);
    font: inherit;
}

.segment-builder-form {
    display: grid;
    gap: 0.75rem;
}

.segment-input-label {
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 750;
}

.segment-builder-form textarea {
    width: 100%;
    min-height: 124px;
    resize: vertical;
    padding: 0.9rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
    color: var(--ink);
    line-height: 1.5;
    outline: none;
    transition: border-color 0.14s ease, box-shadow 0.14s ease;
}

.segment-builder-form textarea:focus {
    border-color: var(--ink);
    box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08);
}

.segment-actions,
.segment-export-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.segment-job-status {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
    padding: 0.82rem 0.9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface-muted);
}

.segment-card-status {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
    padding: 0.78rem 0.86rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.segment-job-status[hidden],
.segment-error[hidden],
.segment-stats[hidden],
.segment-result-grid[hidden] {
    display: none;
}

.segment-job-status strong,
.segment-job-status span,
.segment-card-status strong,
.segment-card-status span {
    display: block;
}

.segment-job-status strong,
.segment-card-status strong {
    color: var(--ink);
    font-size: 0.88rem;
    font-weight: 780;
}

.segment-job-status span,
.segment-card-status span {
    color: var(--muted);
    font-size: 0.82rem;
}

.segment-waiting-icon {
    position: relative;
    width: 20px;
    height: 20px;
    border: 2px solid var(--line-strong);
    border-top-color: var(--ink);
    border-radius: 50%;
    animation: ensyra-spin 0.8s linear infinite;
}

.segment-job-status.is-finished .segment-waiting-icon,
.segment-card-status.is-finished .segment-waiting-icon {
    border-color: var(--green);
    background: var(--green);
    animation: none;
}

.segment-job-status.is-finished .segment-waiting-icon::after,
.segment-card-status.is-finished .segment-waiting-icon::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 6px;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.segment-job-status.is-failed .segment-waiting-icon,
.segment-card-status.is-failed .segment-waiting-icon {
    border-color: var(--red);
    animation: none;
}

.segment-error {
    padding: 0.82rem 0.9rem;
    border: 1px solid #ffd7d7;
    border-radius: var(--radius-card);
    background: var(--red-soft);
    color: #9f1d1d;
    font-size: 0.86rem;
    font-weight: 650;
}

.segment-result-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.1rem;
}

.segment-result-grid .content-card:nth-child(3),
.segment-result-grid .content-card:nth-child(4) {
    grid-column: 1 / -1;
}

.segment-result-grid .segment-list {
    display: grid;
    gap: 0.48rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.segment-result-grid .segment-list li {
    padding: 0.62rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
    color: var(--text);
    font-size: 0.84rem;
    line-height: 1.42;
    overflow-wrap: anywhere;
}

.segment-result-grid .segment-warning-list li {
    border-color: rgba(226, 162, 15, 0.32);
    background: rgba(226, 162, 15, 0.08);
}

.segment-result-grid .segment-unsupported-list li {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #9f1d1d;
}

.segment-preview-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
}

.segment-preview-card {
    display: grid;
    gap: 0.62rem;
    padding: 0.78rem 0.86rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

.segment-preview-card > strong {
    color: var(--ink);
    font-size: 0.86rem;
    font-weight: 800;
}

.segment-preview-card dl {
    display: grid;
    grid-template-columns: minmax(110px, 0.42fr) minmax(0, 1fr);
    gap: 0.34rem 0.62rem;
    margin: 0;
}

.segment-preview-card dd {
    margin: 0;
}

.segment-sql-details {
    display: grid;
    gap: 0.75rem;
}

.segment-sql-details summary {
    cursor: pointer;
    color: var(--ink);
    font-weight: 780;
}

.segment-sql-details pre {
    max-height: 320px;
    margin: 0.85rem 0 0;
    overflow: auto;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #f7f7f8;
    color: var(--ink);
    font-size: 0.78rem;
    line-height: 1.45;
    white-space: pre-wrap;
}

@keyframes ensyra-spin {
    to {
        transform: rotate(360deg);
    }
}

.profit-profile-table th:nth-child(1),
.profit-profile-table td:nth-child(1) {
    width: 58%;
}

.profit-profile-table th:nth-child(2),
.profit-profile-table td:nth-child(2) {
    width: 116px;
}

.profit-profile-table th:nth-child(3),
.profit-profile-table td:nth-child(3) {
    width: 108px;
}

.profit-profile-table tr.is-active {
    background: var(--surface-muted);
}

.profit-profile-link {
    display: grid;
    gap: 0.24rem;
}

.profit-profile-link span {
    color: var(--muted);
    font-size: 0.74rem;
}

.profit-profile-persona {
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: 0.64rem;
}

.profit-profile-persona > span:last-child {
    min-width: 0;
    display: grid;
    gap: 0.2rem;
}

.profit-profile-persona .library-avatar {
    width: 34px;
    height: 34px;
    color: #fff;
    font-size: 0.74rem;
}

.profit-profile-persona strong {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.profit-profile-persona > span:last-child > span {
    overflow: hidden;
    color: var(--muted);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.identity-profile-layout {
    display: grid;
    grid-template-columns: minmax(390px, 0.35fr) minmax(0, 1fr);
    align-items: start;
    gap: 1.35rem;
}

.identity-profile-grid {
    display: grid;
    gap: 0.72rem;
}

.identity-profile-card {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    padding: 0.88rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface);
    color: inherit;
    text-decoration: none;
    box-shadow: var(--shadow-hairline);
}

.identity-profile-card:hover,
.identity-profile-card.is-active {
    border-color: color-mix(in srgb, var(--blue) 34%, var(--line));
    background: var(--surface-raised);
}

.identity-profile-card .library-avatar {
    width: 38px;
    height: 38px;
    color: #fff;
    font-size: 0.72rem;
}

.identity-profile-card > span:not(.library-avatar) {
    min-width: 0;
    display: grid;
    gap: 0.2rem;
}

.identity-profile-card strong,
.identity-profile-card em {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.identity-profile-card strong {
    color: var(--ink);
    font-size: 0.88rem;
}

.identity-profile-card em,
.identity-profile-card small {
    color: var(--muted);
    font-size: 0.74rem;
    font-style: normal;
    line-height: 1.4;
}

.identity-profile-card small {
    justify-self: end;
    white-space: nowrap;
}

.identity-profile-modal-layer {
    position: fixed;
    inset: 0;
    z-index: 520;
    display: none;
    align-items: center;
    justify-content: center;
    padding: calc(1.2rem + var(--safe-area-top)) calc(1rem + var(--safe-area-right)) calc(1.2rem + var(--safe-area-bottom)) calc(1rem + var(--safe-area-left));
}

.identity-profile-modal-layer.is-open {
    display: flex;
}

.identity-profile-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.46);
    backdrop-filter: blur(4px);
}

.identity-profile-modal {
    position: relative;
    z-index: 1;
    width: min(100%, 1040px);
    max-height: min(860px, 100%);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--surface);
    box-shadow: 0 22px 70px rgba(17, 17, 17, 0.22);
}

.identity-profile-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.35rem;
    border-bottom: 1px solid var(--line);
    background: var(--surface);
}

.identity-profile-modal-head h3 {
    margin: 0 0 0.2rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.12rem;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.identity-profile-modal-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    flex: 0 0 auto;
}

.modal-close-button {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
    color: var(--ink);
    font-size: 1.22rem;
    line-height: 1;
    text-decoration: none;
}

.modal-close-button:hover,
.modal-close-button:focus-visible {
    border-color: var(--line-strong);
    background: var(--surface-raised);
}

.identity-profile-modal-body {
    min-height: 0;
    overflow: auto;
    padding: 1.25rem 1.35rem 1.35rem;
}

.identity-attribute-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.84rem;
    margin-top: 1rem;
}

.identity-attribute-grid > div {
    min-width: 0;
    display: grid;
    gap: 0.36rem;
    padding: 0.92rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface-muted);
}

.identity-attribute-grid span {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
}

.identity-attribute-grid strong {
    overflow-wrap: anywhere;
    color: var(--ink);
    font-size: 0.88rem;
    line-height: 1.35;
}

.profit-metric-grid,
.prediction-grid,
.profit-analysis-grid,
.insight-explainer,
.insight-card-side,
.prediction-metrics,
.chart-labels {
    display: grid;
    gap: 1rem;
}

.profit-metric-grid,
.prediction-grid,
.insight-explainer {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profit-metric {
    display: grid;
    gap: 0.38rem;
    padding: 0.95rem 1rem;
}

.metric-color {
    position: relative;
    overflow: hidden;
    border-color: var(--line);
    background: #fff;
}

.metric-color::before {
    content: "";
    position: absolute;
    inset: 0.72rem auto 0.72rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--accent);
    opacity: 0.86;
}

.profit-metric strong {
    font-size: 1.08rem;
}

.profit-analysis-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    margin-top: 1.05rem;
}

.profit-analysis-grid > div {
    position: relative;
    display: grid;
    gap: 0.38rem;
    padding: 0.92rem 1rem;
    background: #fff;
}

.profit-analysis-grid > div:nth-child(6n + 1) {
    background: #fff;
}

.profit-analysis-grid > div:nth-child(6n + 2) {
    background: #fff;
}

.profit-analysis-grid > div:nth-child(6n + 3) {
    background: #fff;
}

.prediction-card {
    display: grid;
    gap: 1.05rem;
    padding: 1.15rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.prediction-card-color {
    position: relative;
    overflow: hidden;
    border-color: color-mix(in srgb, var(--accent) 18%, var(--line));
}

.prediction-card-color::before {
    content: "";
    position: absolute;
    inset: 0.9rem auto 0.9rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--accent);
}

.prediction-card-color .prediction-card-head em {
    background: #fff;
    border-color: var(--line);
    color: var(--accent);
}

.prediction-card-head > div {
    display: grid;
    gap: 0.28rem;
}

.prediction-card-head strong {
    color: var(--ink);
}

.prediction-card-head em {
    flex: 0 0 auto;
    background: var(--surface-muted);
    color: var(--ink);
    font-style: normal;
}

.prediction-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.prediction-metrics strong.is-positive {
    color: #13835a;
}

.prediction-metrics strong.is-negative {
    color: #c52222;
}

.prediction-footer {
    padding-top: 0.95rem;
    border-top: 1px solid var(--line);
}

.profit-table-note {
    margin-top: 0.2rem;
}

.insight-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 258px;
    gap: 1.25rem;
    padding: 1.2rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.insight-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.15rem;
}

.discovery-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.insight-summary-card {
    position: relative;
    min-height: 112px;
    display: grid;
    align-content: start;
    gap: 0.32rem;
    overflow: hidden;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.insight-summary-card::before {
    content: "";
    position: absolute;
    inset: 0.72rem auto 0.72rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--accent);
    opacity: 0.86;
}

.insight-summary-card span,
.insight-summary-card small {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
}

.insight-summary-card strong {
    color: var(--ink);
    font-size: 1.28rem;
    font-weight: 780;
    line-height: 1.08;
}

.insight-card-color {
    position: relative;
    overflow: hidden;
    border-color: var(--line);
    background: #fff;
}

.insight-card-color::before {
    content: "";
    position: absolute;
    inset: 0.9rem auto 0.9rem 0;
    width: 2px;
    border-radius: 999px;
    background: var(--accent);
}

.insight-orb {
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line));
    border-radius: 8px;
    background: color-mix(in srgb, var(--accent-soft) 68%, #fff);
    color: var(--accent);
    box-shadow: none;
    font-size: 0.82rem;
    font-weight: 850;
}

.insight-card-head > div {
    min-width: 0;
}

.insight-card-head h3 {
    font-family: var(--font-heading);
    margin: 0.08rem 0 0.25rem;
    color: var(--ink);
    font-size: 1rem;
}

.insight-card-head p:not(.eyebrow) {
    margin: 0;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.5;
}

.insight-segment-tags {
    margin-top: 1rem;
}

.insight-curation-note {
    margin: 0.75rem 0 0;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.insight-explainer {
    margin-top: 1rem;
}

.insight-explainer strong {
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 550;
    line-height: 1.42;
}

.insight-card-side {
    grid-template-columns: 1fr;
}

.insight-action {
    grid-column: 1 / -1;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid var(--line);
}

.insight-action strong {
    color: var(--ink);
    font-size: 0.88rem;
}

.discovery-evidence {
    margin-top: 1rem;
    border-top: 1px solid var(--line);
    padding-top: 0.9rem;
}

.discovery-evidence summary {
    cursor: pointer;
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 740;
}

.discovery-evidence-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 0.8rem;
}

.discovery-evidence-grid > div {
    display: grid;
    gap: 0.2rem;
    padding: 0.75rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.discovery-evidence-grid span,
.discovery-source-list {
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.45;
}

.discovery-evidence-grid strong {
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1.4;
}

.discovery-source-list {
    margin: 0.8rem 0 0;
}

.metric-inline {
    display: grid;
    gap: 0.28rem;
    padding: 0.9rem 1rem;
    background: #fff;
}

.chart-card {
    display: grid;
    gap: 1rem;
}

.trend-chart {
    width: min(100%, 1000px);
    height: auto;
    display: block;
    justify-self: center;
    margin-right: auto;
    margin-left: auto;
}

.trend-chart line,
.trend-chart path,
.trend-chart circle,
.connector-line-chart svg line,
.connector-line-chart svg path,
.connector-line-chart svg polyline {
    vector-effect: non-scaling-stroke;
}

.chart-axis {
    stroke: var(--line);
    stroke-width: 1;
}

.chart-grid-line {
    stroke: #f1f1f3;
    stroke-width: 1;
}

.chart-x-line {
    stroke: #ededf0;
    stroke-width: 1;
}

.chart-x-label {
    fill: var(--muted);
    font-size: 11px;
    text-anchor: middle;
}

.chart-line {
    stroke: var(--black);
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.chart-point {
    fill: var(--black);
    stroke: #fff;
    stroke-width: 2;
    transition: r 0.15s ease, fill 0.15s ease;
}

.chart-hit-area {
    fill: transparent;
    cursor: crosshair;
}

.chart-hover-line,
.chart-tooltip {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease;
}

.chart-hover-line {
    stroke: var(--black);
    stroke-width: 1;
    stroke-dasharray: 3 4;
}

.chart-tooltip rect {
    fill: #fff;
    stroke: var(--line);
    filter: drop-shadow(0 8px 18px rgba(17, 17, 17, 0.1));
}

.chart-tooltip-label {
    fill: var(--muted);
    font-size: 11px;
}

.chart-tooltip-value {
    fill: var(--ink);
    font-size: 14px;
    font-weight: 800;
}

.chart-hover-target:hover .chart-hover-line,
.chart-hover-target:focus .chart-hover-line,
.chart-hover-target:hover .chart-tooltip,
.chart-hover-target:focus .chart-tooltip {
    opacity: 1;
}

.chart-hover-target:hover .chart-point,
.chart-hover-target:focus .chart-point {
    r: 6;
    fill: var(--logo-purple);
}

.chart-labels {
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    gap: 0.5rem;
}

.chart-label {
    display: grid;
    padding: 0.85rem 0.95rem;
    background: #fff;
}

.chart-label strong {
    display: block;
    margin-top: 0.12rem;
}

.discovery-activity-card {
    display: grid;
    gap: 1rem;
}

.discovery-activity-toolbar {
    align-items: center;
    margin-bottom: 0.25rem;
}

.discovery-activity-legend {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 650;
}

.discovery-activity-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.discovery-activity-legend i {
    display: inline-block;
    width: 18px;
    height: 8px;
    border-radius: 999px;
}

.discovery-activity-legend .legend-bar {
    background: var(--logo-cyan);
}

.discovery-activity-legend .legend-line {
    height: 2px;
    background: rgba(63, 64, 72, 0.62);
}

.latest-run-metrics.discovery-activity-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.discovery-activity-chart {
    gap: 0.85rem;
}

.discovery-activity-x-grid line {
    stroke: rgba(16, 24, 40, 0.055);
    stroke-width: 1;
}

.discovery-activity-x-grid text {
    fill: var(--muted);
    font-size: 12px;
    font-weight: 650;
    text-anchor: middle;
}

.discovery-activity-bar.has-failure {
    fill: var(--logo-magenta);
    opacity: 1;
}

.discovery-activity-bar,
.discovery-activity-point {
    transition: opacity 0.14s ease;
}

.discovery-activity-bar {
    fill: var(--logo-cyan);
}

.discovery-activity-line {
    stroke: rgba(63, 64, 72, 0.72);
    stroke-width: 1.55;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.discovery-activity-point {
    fill: var(--surface);
    stroke: rgba(63, 64, 72, 0.76);
    stroke-width: 1.45;
}

.discovery-activity-hover-line {
    stroke: rgba(63, 64, 72, 0.42);
    stroke-width: 1;
    stroke-dasharray: 3 5;
}

.discovery-activity-hover-line,
.discovery-activity-bar-focus,
.discovery-activity-point-focus,
.discovery-activity-tooltip {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.14s ease;
}

.discovery-activity-bar-focus {
    fill: rgba(36, 142, 142, 0.08);
    stroke: rgba(36, 142, 142, 0.34);
    stroke-width: 1;
}

.discovery-activity-point-focus {
    fill: var(--surface);
    stroke: rgba(63, 64, 72, 0.76);
    stroke-width: 1.55;
}

.discovery-activity-tooltip rect {
    fill: #fff;
    stroke: rgba(16, 24, 40, 0.11);
    stroke-width: 1;
    filter: drop-shadow(0 8px 18px rgba(16, 24, 40, 0.1));
}

.discovery-activity-tooltip text {
    fill: var(--text);
    font-size: 12px;
    font-weight: 650;
}

.discovery-activity-tooltip .tooltip-title {
    fill: var(--ink);
    font-size: 13px;
    font-weight: 820;
}

.discovery-activity-hitbox {
    fill: transparent;
    cursor: crosshair;
    outline: none;
}

.discovery-activity-hover-slice:hover .discovery-activity-hover-line,
.discovery-activity-hover-slice:hover .discovery-activity-bar-focus,
.discovery-activity-hover-slice:hover .discovery-activity-point-focus,
.discovery-activity-hover-slice:hover .discovery-activity-tooltip,
.discovery-activity-hover-slice:focus-within .discovery-activity-hover-line,
.discovery-activity-hover-slice:focus-within .discovery-activity-bar-focus,
.discovery-activity-hover-slice:focus-within .discovery-activity-point-focus,
.discovery-activity-hover-slice:focus-within .discovery-activity-tooltip {
    opacity: 1;
}

.discovery-activity-hitbox:focus-visible {
    stroke: rgba(63, 64, 72, 0.46);
    stroke-width: 1;
}

.segment-activity-card {
    display: grid;
    gap: 1rem;
}

.segment-activity-legend .legend-updates {
    background: var(--logo-cyan);
}

.segment-activity-legend .legend-actual {
    height: 2px;
    background: var(--logo-blue);
}

.segment-activity-legend .legend-forecast {
    height: 2px;
    background: var(--logo-purple);
}

.segment-activity-chart .discovery-activity-bar {
    fill: var(--logo-cyan);
}

.segment-activity-chart .discovery-activity-bar.has-failure {
    fill: var(--logo-magenta);
}

.segment-activity-line-actual {
    stroke: var(--logo-blue);
    stroke-width: 2.2;
}

.segment-activity-line-forecast {
    stroke: var(--logo-purple);
    stroke-width: 2;
    stroke-dasharray: 7 7;
}

.segment-activity-point-actual {
    stroke: var(--logo-blue);
}

.segment-activity-point-forecast {
    stroke: var(--logo-purple);
}

.segment-activity-chart .discovery-activity-point-focus {
    stroke: var(--logo-purple);
}

.score-bar {
    width: 64px;
    height: 5px;
}

.score-bar-wrap strong {
    color: var(--ink);
    font-size: 0.78rem;
    font-weight: 650;
}

.decision-page-header {
    --accent: var(--purple);
    --accent-2: var(--blue);
    --accent-soft: var(--purple-soft);
}

.decision-layer-async-shell,
.decision-reviews-async-shell,
.decision-report-async-shell,
.decision-layer-async-shell .dashboard-widget,
.decision-reviews-async-shell .dashboard-widget,
.decision-report-async-shell .dashboard-widget {
    display: grid;
    gap: 1.65rem;
    width: 100%;
}

.decision-layer-async-shell .dashboard-widget > .page-header,
.decision-reviews-async-shell .dashboard-widget > .page-header,
.decision-report-async-shell .dashboard-widget > .page-header,
.decision-layer-async-shell .dashboard-widget > .context-kpi-row,
.decision-reviews-async-shell .dashboard-widget > .context-kpi-row,
.decision-report-async-shell .dashboard-widget > .insight-summary-grid {
    margin: 0;
}

.decision-layer-async-shell .dashboard-widget > .kpi-header,
.decision-reviews-async-shell .dashboard-widget > .kpi-header {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.35rem;
}

.decision-layer-async-shell .dashboard-widget > .explainability-kpi-row {
    gap: 0.85rem;
    align-items: flex-start;
}

.decision-layer-async-shell .dashboard-widget > .explainability-kpi-row .context-kpi-item {
    min-height: 34px;
    padding: 0.38rem 0.75rem;
}

.decision-layer-async-shell .dashboard-widget > .discovery-opportunities-card {
    padding: 2.15rem;
}

.decision-layer-async-shell .dashboard-widget > .discovery-opportunities-card .section-toolbar {
    margin-bottom: 1.9rem;
}

.decision-layer-async-shell .dashboard-widget > .discovery-opportunities-card .discovery-opportunity-list {
    margin: 0;
    gap: 1rem;
}

.decision-layer-async-shell .dashboard-widget > .discovery-opportunities-card .discovery-opportunity-list .context-kpi-item {
    padding: 0.95rem 1rem;
}

.decision-report-async-shell .dashboard-widget > .content-card,
.decision-report-async-shell .dashboard-widget > .dashboard-grid {
    margin-top: 0;
}

.decision-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 0.9fr);
    gap: 1.15rem;
}

.decision-score-card,
.decision-quality-card,
.dashboard-decision-panel {
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.decision-score-card {
    display: grid;
    grid-template-columns: 158px minmax(0, 1fr);
    align-items: center;
    gap: 1.35rem;
    padding: 1.35rem;
}

.decision-score-ring {
    --score: 0%;
    width: 142px;
    height: 142px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    border: 10px solid var(--logo-purple);
    background: #fff;
}

.decision-score-ring strong,
.decision-score-ring span {
    grid-area: 1 / 1;
    text-align: center;
}

.decision-score-ring strong {
    margin-top: -0.75rem;
    color: var(--ink);
    font-size: 1.15rem;
    font-weight: 800;
}

.decision-score-ring span {
    width: 82px;
    margin-top: 2.3rem;
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 650;
    line-height: 1.2;
}

.decision-score-card h3 {
    margin: 0.05rem 0 0.45rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.25rem;
}

.decision-score-card p:not(.eyebrow),
.decision-quality-card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.5;
}

.decision-stat-grid,
.decision-quality-grid,
.decision-dashboard-grid {
    display: grid;
    gap: 1.15rem;
}

.decision-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.decision-quality-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.decision-dashboard-grid {
    grid-template-columns: 1.1fr repeat(3, minmax(0, 0.8fr));
    margin-top: 1.2rem;
}

.decision-quality-card {
    display: grid;
    align-content: start;
    gap: 0.7rem;
    min-width: 0;
    padding: 1.15rem;
}

.decision-quality-card-large {
    border-color: color-mix(in srgb, var(--purple) 16%, var(--line));
    background: #fff;
}

.decision-quality-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
}

.decision-quality-head strong {
    min-width: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.9rem;
    font-weight: 750;
}

.decision-quality-head span {
    flex: 0 0 auto;
    color: var(--purple);
    font-size: 0.78rem;
    font-weight: 800;
}

.decision-quality-bar {
    overflow: hidden;
    height: 7px;
    border-radius: 999px;
    background: #ececef;
}

.decision-quality-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--logo-purple);
}

.decision-main-grid {
    align-items: start;
}

.decision-main-grid .content-card-side {
    padding: 1.65rem;
}

.decision-main-grid .content-card-side .side-card {
    gap: 1rem;
}

.decision-settings-form {
    gap: 0.9rem;
}

.decision-settings-form > div {
    display: grid;
    gap: 0.5rem;
}

.decision-settings-form .checkbox-row {
    min-width: 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.62rem;
    min-height: 40px;
    padding: 0.52rem 0.62rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--text);
    cursor: pointer;
}

.decision-settings-form .checkbox-row input {
    margin: 0;
}

.decision-settings-form .checkbox-row span {
    min-width: 0;
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1.3;
}

.decision-settings-form input[readonly] {
    background: var(--surface-muted);
    color: var(--text);
}

.decision-layer-card .decision-status.is-muted,
.insight-score.is-muted {
    background: var(--surface-muted);
    border-color: var(--line);
    color: var(--muted);
}

.decision-compact-list {
    display: grid;
    gap: 0.9rem;
    margin-top: 1rem;
}

.page-header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.decision-review-summary-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
}

.decision-review-summary-actions {
    display: grid;
    justify-items: end;
    gap: 0.25rem;
    min-width: 220px;
}

.decision-review-summary-actions strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.35rem;
}

.decision-review-summary-actions span {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 700;
}

.decision-actions-list,
.decision-review-list {
    display: grid;
    gap: 1rem;
}

.decision-recommendation-card {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 0.95rem;
    padding: 1.05rem;
}

.decision-recommendation-card .decision-action {
    align-items: center;
    gap: 0.55rem;
    margin: 0.7rem 0;
}

.decision-recommendation-card .decision-action > span:first-child {
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 750;
}

.decision-card-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
    gap: 0.55rem;
}

.decision-card-metrics > div {
    display: grid;
    gap: 0.24rem;
    padding: 0.65rem 0.72rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-card-metrics span {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 750;
}

.decision-card-metrics strong {
    color: var(--ink);
    font-size: 0.86rem;
    overflow-wrap: anywhere;
}

.decision-results-kpis {
    margin: 0 0 1.25rem;
}

.decision-results-kpis .context-kpi-item {
    min-height: 38px;
    padding: 0.45rem 0.75rem;
}

.decision-learning-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.decision-learning-grid > article {
    display: grid;
    align-content: start;
    gap: 0.8rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-learning-grid h4 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 0.95rem;
}

.decision-review-form {
    display: grid;
    gap: 1.2rem;
}

.decision-review-card {
    grid-template-columns: 22px minmax(0, 1fr) auto;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.decision-review-card.is-readonly {
    grid-template-columns: minmax(0, 1fr);
}

.decision-review-payload {
    margin-top: 0.5rem;
}

.decision-review-payload p {
    margin: 0;
    color: var(--text);
    font-size: 0.82rem;
    line-height: 1.5;
}

.decision-review-details {
    margin-top: 0.3rem;
}

.decision-review-details summary {
    cursor: pointer;
    color: var(--ink);
    font-size: 0.8rem;
    font-weight: 750;
}

.decision-review-details .decision-card-metrics {
    margin-top: 0.65rem;
}

.decision-review-bulk {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-raised);
}

.decision-review-bulk .form-field {
    min-width: min(100%, 360px);
}

.settings-autopilot-form {
    gap: 1.15rem;
}

.settings-autopilot-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.7rem;
}

.settings-autopilot-split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.settings-autopilot-split > div {
    display: grid;
    gap: 0.65rem;
}

.settings-channel-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
    gap: 0.55rem;
}

.decision-channel-insight {
    gap: 1rem;
}

.decision-channel-insight-head {
    display: grid;
    gap: 0.75rem;
}

.decision-channel-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.decision-channel-filter button {
    min-height: 32px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--muted);
    cursor: pointer;
    font: inherit;
    font-size: 0.76rem;
    font-weight: 750;
    padding: 0.35rem 0.7rem;
}

.decision-channel-filter button.is-active {
    border-color: var(--ink);
    background: var(--ink);
    color: #fff;
}

.decision-channel-table {
    display: grid;
    gap: 0.55rem;
}

.decision-channel-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.2rem 0.8rem;
    padding: 0.75rem 0;
    border-top: 1px solid var(--line);
}

.decision-channel-row span {
    min-width: 0;
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 750;
}

.decision-channel-row strong {
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 800;
}

.decision-channel-row em {
    grid-column: 1 / -1;
    color: var(--muted);
    font-size: 0.73rem;
    font-style: normal;
}

.decision-channel-row.is-hidden,
.decision-winner-list .segment-item.is-hidden {
    display: none;
}

.experiment-trend-card {
    display: grid;
    gap: 1rem;
}

.experiment-trend-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    align-items: center;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 750;
}

.experiment-trend-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
}

.experiment-trend-legend i {
    display: inline-block;
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
}

.experiment-trend-legend b {
    display: inline-block;
    width: 1.25rem;
    height: 0;
    border-top: 2px dashed var(--muted);
}

.experiment-trend-legend .is-test,
.experiment-line-point.is-test {
    fill: #16895f;
    background: #16895f;
}

.experiment-trend-legend .is-control,
.experiment-line-point.is-control {
    fill: #5b6472;
    background: #5b6472;
}

.experiment-trend-legend .is-uplift {
    background: #1f7aec;
}

.experiment-trend-legend .is-net-profit {
    background: #a15c14;
}

.experiment-trend-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.experiment-trend-summary > div {
    display: grid;
    gap: 0.22rem;
    min-width: 0;
    padding: 0.9rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface-muted);
}

.experiment-trend-summary span,
.experiment-trend-summary em {
    overflow: hidden;
    color: var(--muted);
    font-size: 0.75rem;
    font-style: normal;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.experiment-trend-summary strong {
    color: var(--ink);
    font-size: 1.12rem;
    font-weight: 800;
    letter-spacing: 0;
}

.experiment-trend-chart {
    display: grid;
    gap: 0.45rem;
}

.experiment-trend-grid {
    stroke: var(--line);
    stroke-width: 1;
}

.experiment-trend-zero {
    stroke: var(--line-strong);
    stroke-dasharray: 5 7;
    stroke-width: 1.2;
}

.experiment-trend-boundary {
    stroke: var(--line-strong);
    stroke-dasharray: 4 7;
    stroke-width: 1.2;
}

.experiment-line {
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.experiment-line-test {
    stroke: #16895f;
}

.experiment-line-control {
    stroke: #5b6472;
}

.experiment-line-uplift {
    stroke: #1f7aec;
}

.experiment-line-net-profit {
    stroke: #a15c14;
}

.experiment-line-forecast {
    stroke-dasharray: 9 9;
    opacity: 0.78;
}

.experiment-line-point {
    stroke: #fff;
    stroke-width: 2;
}

.experiment-trend-axis-labels {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 0.75rem;
    color: var(--muted);
    font-size: 0.74rem;
}

.experiment-trend-axis-labels strong {
    color: var(--muted);
    font-weight: 750;
}

.experiment-trend-axis-labels span:last-child {
    text-align: right;
}

.auth-body {
    overflow-x: hidden;
    background: #fff;
}

.auth-login-is-loading {
    overflow: hidden;
}

.auth-login-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    padding: calc(1.25rem + var(--safe-area-top)) calc(1.25rem + var(--safe-area-right)) calc(1.25rem + var(--safe-area-bottom)) calc(1.25rem + var(--safe-area-left));
    background: rgba(255, 255, 255, 0.97);
    opacity: 0;
    pointer-events: all;
    transform: scale(0.985);
    transition: opacity 0.16s ease, transform 0.18s ease;
}

.auth-login-overlay.is-visible {
    opacity: 1;
    transform: scale(1);
}

.auth-login-loader {
    width: min(100%, 380px);
    display: grid;
    justify-items: center;
    gap: 1.05rem;
    text-align: center;
}

.auth-login-loader-stage {
    position: relative;
    width: 176px;
    height: 176px;
    display: grid;
    place-items: center;
}

.auth-login-loader-stage img,
.auth-login-logo-fallback {
    position: relative;
    z-index: 2;
    width: 74px;
    height: 74px;
    display: grid;
    place-items: center;
    padding: 11px;
    border: 1px solid var(--line);
    border-radius: 19px;
    background: #fff;
    box-shadow: var(--shadow-sm);
    animation: auth-loader-logo 1.9s ease-in-out infinite;
}

.auth-login-logo-fallback {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 2.4rem;
    font-weight: 800;
}

.auth-login-ring {
    position: absolute;
    inset: 27px;
    border: 2px solid transparent;
    border-radius: 999px;
    opacity: 0.74;
    animation: auth-loader-spin 2.6s linear infinite;
}

.auth-login-ring-one {
    border-top-color: var(--logo-cyan);
    border-right-color: var(--logo-blue);
}

.auth-login-ring-two {
    inset: 43px;
    border-bottom-color: var(--logo-purple);
    border-left-color: var(--logo-magenta);
    animation-duration: 3.2s;
    animation-direction: reverse;
}

.auth-login-ring-three {
    inset: 59px;
    border-top-color: var(--logo-magenta);
    border-right-color: var(--logo-cyan);
    opacity: 0.52;
    animation-duration: 2.1s;
}

.auth-login-loader-copy {
    display: grid;
    gap: 0.45rem;
}

.auth-login-loader-copy strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: clamp(1.45rem, 4vw, 2.05rem);
    font-weight: 800;
    line-height: 1.05;
}

.auth-login-loader-copy span {
    color: var(--muted);
    font-size: 0.9rem;
    line-height: 1.55;
}

.auth-login-loader-steps {
    display: inline-flex;
    gap: 0.36rem;
}

.auth-login-loader-steps i {
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 999px;
    background: var(--logo-blue);
    animation: auth-loader-step 1.18s ease-in-out infinite;
}

.auth-login-loader-steps i:nth-child(2) {
    background: var(--logo-purple);
    animation-delay: 0.12s;
}

.auth-login-loader-steps i:nth-child(3) {
    background: var(--logo-magenta);
    animation-delay: 0.24s;
}

@keyframes auth-loader-spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes auth-loader-logo {
    0%,
    100% {
        transform: scale(0.99);
    }

    50% {
        transform: scale(1.025);
    }
}

@keyframes auth-loader-step {
    0%,
    100% {
        transform: translateY(0);
        opacity: 0.42;
    }

    50% {
        transform: translateY(-3px);
        opacity: 1;
    }
}

.auth-background,
.auth-spot {
    display: none;
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 456px;
    background: #fff;
}

.auth-showcase {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 3rem 4rem;
    border-right: 1px solid var(--line);
    background: var(--sidebar);
}

.auth-showcase-panel {
    max-width: 560px;
    padding: 0;
    border: 0;
    box-shadow: none;
    background: transparent;
}

.auth-showcase h1 {
    max-width: 15ch;
    margin-bottom: 0.82rem;
}

.auth-showcase-copy {
    display: grid;
    gap: 0.72rem;
}

.auth-showcase-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.showcase-metric {
    display: grid;
    gap: 0.18rem;
    padding: 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
}

.showcase-metric span {
    color: var(--muted);
    font-size: 0.76rem;
}

.showcase-metric strong {
    color: var(--ink);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0;
}

.auth-card {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

.auth-card-inner {
    width: 100%;
    max-width: 380px;
}

.auth-brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 2rem;
}

.auth-brand h1 {
    font-family: var(--font-heading);
    margin: 0;
    color: var(--ink);
    font-size: 1.1rem;
}

.auth-copy {
    margin-bottom: 1rem;
}

.authenticator-qr-box {
    display: grid;
    place-items: center;
    margin: 0 0 1rem;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #fff;
}

.authenticator-qr-code {
    width: min(100%, 236px);
    height: auto;
}

.authenticator-setup-box {
    display: grid;
    gap: 0.52rem;
    margin: 0 0 1.1rem;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface-soft);
}

.authenticator-setup-box span {
    color: var(--muted);
    font-size: 0.76rem;
}

.authenticator-setup-box code {
    display: block;
    overflow-wrap: anywhere;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--ink);
    font-size: 1rem;
    line-height: 1.5;
    letter-spacing: 0;
}

.authenticator-setup-box a {
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 650;
}

.auth-meta,
.auth-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.8rem;
    margin-top: 0.55rem;
}

.auth-meta span,
.auth-links a {
    color: var(--muted);
    font-size: 0.8rem;
}

.auth-legal-links {
    margin-top: 0.25rem;
}

.legal-body {
    min-height: 100vh;
    overflow-x: hidden;
    background: #fff;
}

.legal-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: calc(0.9rem + var(--safe-area-top)) calc(1.5rem + var(--safe-area-right)) 0.9rem calc(1.5rem + var(--safe-area-left));
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.96);
}

.legal-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.62rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 800;
}

.legal-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.85rem;
    color: var(--muted);
    font-size: 0.84rem;
}

.legal-nav a[aria-current="page"],
.legal-nav a:hover,
.legal-footer a:hover,
.legal-section a:hover,
.legal-url-panel a:hover {
    color: var(--ink);
}

.legal-shell {
    width: min(calc(100% - 2rem), 980px);
    margin: 0 auto;
    padding: clamp(2rem, 5vw, 4rem) 0;
}

.legal-hero {
    display: grid;
    gap: 0.78rem;
    margin-bottom: 1.25rem;
}

.legal-hero h1 {
    max-width: 12ch;
    margin: 0;
    color: var(--ink);
    font-size: clamp(2.45rem, 7vw, 5.2rem);
    line-height: 0.95;
}

.legal-hero p {
    max-width: 760px;
    margin: 0;
    color: var(--text);
    font-size: 1.02rem;
    line-height: 1.65;
}

.legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.95rem;
    color: var(--muted);
    font-size: 0.84rem;
}

.legal-meta a,
.legal-section a,
.legal-url-panel a,
.legal-footer a {
    color: var(--ink);
    text-decoration: underline;
    text-decoration-color: var(--line-strong);
    text-underline-offset: 0.18em;
}

.legal-document {
    display: grid;
    gap: 1.3rem;
    padding: clamp(1.1rem, 3vw, 2rem);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--surface);
    box-shadow: var(--shadow-hairline);
}

.legal-url-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 0.75rem;
    padding: 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: var(--sidebar);
}

.legal-url-panel div,
.legal-status-panel div {
    display: grid;
    gap: 0.28rem;
    min-width: 0;
}

.legal-url-panel span,
.legal-status-panel span {
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 750;
    text-transform: uppercase;
}

.legal-url-panel a {
    overflow-wrap: anywhere;
    font-size: 0.86rem;
    line-height: 1.45;
}

.legal-section {
    display: grid;
    gap: 0.68rem;
    padding-top: 1.3rem;
    border-top: 1px solid var(--line);
}

.legal-status-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.75rem;
    padding: 0.95rem;
    border: 1px solid #dfe6ff;
    border-radius: var(--radius-card);
    background: var(--blue-soft);
}

.legal-status-panel strong {
    overflow-wrap: anywhere;
    color: var(--ink);
    font-size: 0.92rem;
}

.legal-status-panel p {
    grid-column: 1 / -1;
    margin: 0;
    color: var(--text);
    font-size: 0.9rem;
    line-height: 1.6;
}

.legal-url-panel + .legal-section,
.legal-section:first-child {
    padding-top: 0;
    border-top: 0;
}

.legal-section h2 {
    margin: 0;
    color: var(--ink);
    font-size: 1.18rem;
    line-height: 1.25;
}

.legal-section p,
.legal-section li {
    margin: 0;
    color: var(--text);
    font-size: 0.95rem;
    line-height: 1.72;
}

.legal-section ul {
    display: grid;
    gap: 0.54rem;
    margin: 0;
    padding-left: 1.2rem;
}

.legal-section strong {
    color: var(--ink);
    font-weight: 750;
}

.legal-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem 1rem;
    padding: 0 1.5rem calc(2rem + var(--safe-area-bottom));
    color: var(--muted);
    font-size: 0.82rem;
}

.link-button {
    appearance: none;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
    font: inherit;
    font-size: 0.8rem;
}

.link-button:hover {
    color: var(--ink);
}

.segments-page-header::before {
    background: var(--logo-blue);
}

.segment-builder-shell,
.segment-result-stack {
    display: grid;
    gap: 1.25rem;
}

.segment-builder-card {
    max-width: 1040px;
}

.segment-builder-form {
    display: grid;
    gap: 0.8rem;
}

.segment-builder-form label {
    color: var(--ink);
    font-size: 0.86rem;
    font-weight: 750;
}

.segment-builder-form textarea {
    width: 100%;
    min-height: 132px;
    resize: vertical;
    padding: 0.9rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    background: #fff;
    color: var(--ink);
    line-height: 1.5;
    box-shadow: var(--shadow-hairline);
}

.segment-builder-form textarea:focus {
    outline: 2px solid rgba(25, 119, 243, 0.16);
    border-color: rgba(25, 119, 243, 0.42);
}

.segment-loading {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    color: var(--muted);
    font-size: 0.84rem;
    font-weight: 650;
}

.segment-alert {
    margin-top: 1rem;
    padding: 0.82rem 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    font-size: 0.86rem;
    line-height: 1.45;
}

.segment-alert-error {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #a91d1d;
}

.segment-stats-grid {
    max-width: 1040px;
}

.segment-result-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.segment-panel {
    min-width: 0;
}

.segment-result-stack .segment-list {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.segment-result-stack .segment-list li {
    padding: 0.66rem 0.75rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
    color: var(--text);
    font-size: 0.84rem;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.segment-result-stack .segment-warning-list li {
    border-color: rgba(226, 162, 15, 0.3);
    background: rgba(226, 162, 15, 0.08);
    color: #775400;
}

.segment-result-stack .segment-unsupported-list {
    margin-top: 0.7rem;
}

.segment-result-stack .segment-unsupported-list li {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #9f1d1d;
}

.segment-sql-details summary {
    cursor: pointer;
    color: var(--ink);
    font-weight: 750;
}

.segment-sql-details pre {
    max-height: 360px;
    margin: 0.9rem 0 0;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    background: #f7f7f8;
}

.segment-sql-details code {
    display: block;
    padding: 1rem;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    white-space: pre;
}

.segment-actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.toast-stack {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 260;
    display: grid;
    gap: 0.5rem;
}

.toast {
    min-width: 220px;
    padding: 0.82rem 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-card);
    background: var(--black);
    color: #fff;
    box-shadow: var(--shadow-md);
    font-size: 0.84rem;
}

.toast-error {
    background: var(--red);
}

.toast-success {
    background: #13835a;
}

.confirm-modal-layer {
    position: fixed;
    inset: 0;
    z-index: 500;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.2rem;
}

.confirm-modal-layer.is-open {
    display: flex;
}

.confirm-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.42);
    backdrop-filter: blur(4px);
}

.confirm-modal {
    position: relative;
    z-index: 1;
    width: min(100%, 460px);
    display: grid;
    gap: 1.2rem;
    padding: 1.25rem;
    border: 1px solid #ffd7d7;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 22px 70px rgba(17, 17, 17, 0.22);
}

.confirm-modal-copy {
    display: grid;
    gap: 0.45rem;
}

.confirm-modal h3 {
    margin: 0;
    color: #9f1d1d;
    font-size: 1.16rem;
}

.confirm-modal-message {
    margin: 0;
    color: var(--text);
    font-size: 0.92rem;
    line-height: 1.55;
}

.confirm-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.is-invalid {
    border-color: rgba(239, 68, 68, 0.42);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.08);
}

@media (max-width: 1199px) {
    .home-feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-lower-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-experiment-grid {
        grid-template-columns: 1fr;
    }

    .home-action-stack {
        max-width: 780px;
    }

    .stats-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .stats-grid-four {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-grid {
        grid-template-columns: 1fr;
    }

    .decision-hero-grid,
    .decision-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .decision-layer-async-shell .dashboard-widget > .kpi-header,
    .decision-report-async-shell .dashboard-widget > .insight-summary-grid,
    .roi-incrementality-async-shell .dashboard-widget > .roi-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .commercial-two-column {
        grid-template-columns: 1fr;
    }

    .commercial-metric-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .commercial-executive-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .commercial-exec-card,
    .commercial-exec-card:nth-child(4),
    .commercial-exec-card:nth-child(5) {
        grid-column: auto;
    }

    .decision-quality-grid,
    .decision-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .latest-run-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .profit-profile-layout,
    .identity-profile-layout,
    .profit-analysis-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 991px) {
    .app-nav {
        transform: translateX(-100%);
        transition: transform 0.2s ease;
        box-shadow: var(--shadow-md);
    }

    .app-nav.is-open {
        transform: translateX(0);
    }

    .app-nav-toggle {
        display: inline-flex;
    }

    .app-topbar {
        left: 0;
    }

    .app-main {
        margin-left: 0;
    }

    .async-page-progress,
    .async-content-layer {
        left: 0;
    }

    .page-content {
        max-width: none;
        padding-top: calc(var(--topbar-height) + var(--safe-area-top) + 38px);
    }

    .stats-grid,
    .insight-summary-grid,
    .commercial-section-head,
    .selector-grid,
    .form-grid.two-cols,
    .form-grid.three-cols,
    .meta-grid {
        grid-template-columns: 1fr 1fr;
    }

    .auth-shell {
        grid-template-columns: 1fr;
    }

    .auth-showcase {
        display: none;
    }

    .topbar-frame,
    .page-header,
    .section-toolbar,
    .form-panel-head,
    .profit-detail-head,
    .card-header {
        flex-direction: column;
    }

    .card-header-tight {
        align-items: flex-start;
    }

    .profit-profile-layout,
    .identity-profile-layout,
    .segment-result-grid,
    .segment-card-metrics,
    .segment-preview-list,
    .prediction-grid,
    .docs-layout,
    .page-explainer,
    .insight-card,
    .insight-explainer,
    .commercial-report-brief,
    .commercial-section-head,
    .decision-score-card {
        grid-template-columns: 1fr;
    }

    .decision-score-ring {
        width: 132px;
        height: 132px;
    }

    .roi-main-grid,
    .roi-context-grid {
        grid-template-columns: 1fr;
    }

    .roi-window-tabs {
        width: 100%;
        justify-content: stretch;
    }

    .roi-window-tabs a {
        flex: 1 1 0;
    }

    .docs-toc {
        position: static;
    }

    .legal-topbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .legal-nav {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .legal-url-panel {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .auth-login-overlay {
        align-items: center;
        padding: calc(1rem + var(--safe-area-top)) calc(1rem + var(--safe-area-right)) calc(1rem + var(--safe-area-bottom)) calc(1rem + var(--safe-area-left));
    }

    .auth-login-loader {
        width: min(100%, 320px);
        gap: 0.9rem;
    }

    .auth-login-loader-stage {
        width: 148px;
        height: 148px;
    }

    .auth-login-loader-stage img,
    .auth-login-logo-fallback {
        width: 64px;
        height: 64px;
        padding: 10px;
        border-radius: 17px;
    }

    .auth-login-ring {
        inset: 21px;
    }

    .auth-login-ring-two {
        inset: 36px;
    }

    .auth-login-ring-three {
        inset: 51px;
    }

    .auth-login-loader-copy strong {
        font-size: 1.48rem;
    }

    .auth-login-loader-copy span {
        font-size: 0.86rem;
    }

    .app-topbar {
        gap: 0.6rem;
        padding-right: calc(10px + var(--safe-area-right));
        padding-left: calc(10px + var(--safe-area-left));
    }

    .app-topbar-left {
        flex: 1 1 auto;
    }

    .app-topbar-actions,
    .topbar-refresh-actions {
        gap: 6px;
    }

    .identity-profile-card {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .identity-profile-card small {
        grid-column: 2;
        justify-self: start;
    }

    .identity-profile-modal-layer {
        align-items: stretch;
        padding: calc(0.72rem + var(--safe-area-top)) calc(0.72rem + var(--safe-area-right)) calc(0.72rem + var(--safe-area-bottom)) calc(0.72rem + var(--safe-area-left));
    }

    .identity-profile-modal {
        max-height: none;
    }

    .identity-profile-modal-head {
        flex-direction: column;
        padding: 1rem;
    }

    .identity-profile-modal-actions {
        width: 100%;
        justify-content: space-between;
    }

    .identity-profile-modal-body {
        padding: 1rem;
    }

    .topbar-pill span {
        display: none;
    }

    .topbar-pill {
        width: 36px;
        padding: 0;
    }

    .app-topbar-actions > .topbar-icon-button:not(.app-logout-button),
    .topbar-icon-button.has-dot {
        display: none;
    }

    .page-content {
        padding-right: calc(1rem + var(--safe-area-right));
        padding-left: calc(1rem + var(--safe-area-left));
        padding-bottom: calc(1.4rem + var(--safe-area-bottom));
    }

    input,
    select,
    textarea {
        font-size: 16px;
    }

    .ask-chat-panel {
        width: 100vw;
    }

    .ask-chat-head,
    .ask-chat-messages {
        padding-right: 0.86rem;
        padding-left: 0.86rem;
    }

    .ask-chat-head {
        align-items: stretch;
        flex-direction: column;
    }

    .ask-chat-head-actions {
        justify-content: space-between;
    }

    .ask-message-bubble {
        max-width: 92%;
    }

    .page-header-accent {
        padding-left: 16px;
    }

    .page-header-accent::before {
        width: 4px;
    }

    .page-header-accent::after {
        display: none;
    }

    .home-dashboard {
        gap: 30px;
    }

    .home-hero {
        gap: 18px;
    }

    .release-pill {
        max-width: 100%;
        font-size: 0.8rem;
    }

    .home-feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.72rem;
    }

    .home-feature-card {
        grid-template-columns: 40px minmax(0, 1fr);
        min-height: 94px;
        padding: 0.82rem;
    }

    .home-feature-cue {
        display: none;
    }

    .home-feature-icon {
        width: 40px;
        height: 40px;
    }

    .home-lower-grid {
        gap: 2.1rem;
    }

    .library-row small {
        white-space: normal;
    }

    .home-action-card {
        grid-template-columns: 104px minmax(0, 1fr);
        gap: 0.9rem;
    }

    .home-action-visual {
        min-height: 82px;
        border-radius: 14px;
    }

    .latest-run-panel {
        padding: 1rem;
    }

    .latest-run-head,
    .latest-run-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .latest-run-metrics {
        grid-template-columns: 1fr;
    }

    .latest-run-metrics.discovery-activity-metrics {
        grid-template-columns: 1fr;
    }

    .latest-run-metrics > div {
        border-right: 0;
        border-bottom: 1px solid rgba(16, 24, 40, 0.08);
    }

    .latest-run-metrics > div:last-child {
        border-bottom: 0;
    }

    .hero-panel,
    .stats-grid,
    .stats-grid-four,
    .insight-summary-grid,
    .commercial-metric-strip,
    .commercial-executive-grid,
    .commercial-risk-list,
    .decision-campaign-grid,
    .selector-grid,
    .connector-flow,
    .connector-lane-grid,
    .form-grid.two-cols,
    .form-grid.three-cols,
    .meta-grid,
    .run-summary,
    .profit-metric-grid,
    .profit-analysis-grid,
    .prediction-metrics,
    .insight-card-side,
    .discovery-evidence-grid,
    .decision-quality-grid,
    .decision-stat-grid,
    .capability-editor-grid,
    .chart-labels,
    .experiment-trend-summary {
        grid-template-columns: 1fr;
    }

    .decision-layer-async-shell .dashboard-widget > .kpi-header,
    .decision-reviews-async-shell .dashboard-widget > .kpi-header,
    .decision-report-async-shell .dashboard-widget > .insight-summary-grid,
    .roi-incrementality-async-shell .dashboard-widget > .roi-kpi-grid {
        grid-template-columns: 1fr;
    }

    .hero-copy {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .connector-flow {
        gap: 0.55rem;
    }

    .connector-flow-node {
        min-height: 0;
    }

    .connector-flow-rail {
        min-height: 32px;
    }

    .connector-flow-rail::before {
        width: 2px;
        height: 100%;
        background: var(--line-strong);
    }

    .connector-flow-rail::after {
        right: auto;
        bottom: 0.18rem;
        transform: rotate(135deg);
    }

    .dashboard-action-list .channel-mix-item,
    .dashboard-tier-list .channel-mix-item {
        grid-template-columns: minmax(0, 1fr) 76px 34px;
    }

    .smart-dashboard .card-header .button {
        width: 100%;
    }

    .connector-oauth-panel,
    .oauth-actions {
        display: grid;
        justify-content: stretch;
    }

    .oauth-actions > * {
        width: 100%;
    }

    .content-card,
    .selector-card,
    .page-explainer,
    .hero-copy,
    .hero-side,
    .listing-shell,
    .form-canvas {
        padding: 1rem;
    }

    .decision-layer-card {
        display: grid;
        grid-template-columns: 44px minmax(0, 1fr);
        gap: 0.8rem;
        padding: 1rem;
    }

    .decision-layer-card .decision-head {
        display: grid;
        gap: 0.55rem;
        align-items: start;
    }

    .decision-layer-card .decision-time {
        margin-left: 0;
    }

    .decision-layer-card .decision-why {
        display: grid;
        gap: 0.62rem;
        padding: 0.8rem;
    }

    .decision-approval-item {
        grid-template-columns: 22px minmax(0, 1fr);
    }

    .decision-approval-actions {
        grid-column: 2;
        flex-wrap: wrap;
    }

    .page-header-actions,
    .decision-review-summary-card,
    .decision-review-bulk {
        display: grid;
        justify-items: stretch;
    }

    .decision-review-summary-actions {
        justify-items: start;
        min-width: 0;
    }

    .decision-learning-grid,
    .settings-autopilot-split {
        grid-template-columns: 1fr;
    }

    .decision-review-card {
        grid-template-columns: 22px minmax(0, 1fr);
    }

    .decision-review-card .decision-approval-actions {
        grid-column: 2;
    }

    .decision-approval-content small,
    .decision-approval-meta span {
        max-width: 100%;
    }

    .decision-campaign {
        padding: 0.85rem;
    }

    .decision-explanation-head,
    .decision-alternatives li > div {
        display: grid;
        align-items: start;
    }

    .topbar-actions,
    .filter-bar,
    .row-actions,
    .form-actions {
        width: 100%;
    }

    .filter-bar > *,
    .topbar-actions > *,
    .row-actions > *,
    .form-actions > * {
        width: 100%;
    }

    .app-topbar-actions {
        width: auto;
        flex: 0 0 auto;
    }

    .topbar-refresh-status {
        display: none;
    }

    .app-user-menu {
        display: none;
    }

    .data-table th,
    .data-table td {
        padding: 0.76rem 0.78rem;
    }
}

@media (max-width: 540px) {
    .auth-login-loader {
        width: min(100%, 286px);
    }

    .auth-login-loader-stage {
        width: 132px;
        height: 132px;
    }

    .auth-login-loader-stage img,
    .auth-login-logo-fallback {
        width: 58px;
        height: 58px;
        border-radius: 15px;
    }

    .auth-login-ring {
        inset: 18px;
    }

    .auth-login-ring-two {
        inset: 32px;
    }

    .auth-login-ring-three {
        inset: 46px;
    }

    .app-nav {
        width: min(86vw, var(--sidebar-width));
    }

    .ask-chart-pie-layout {
        grid-template-columns: 1fr;
    }

    a.topbar-pill:nth-of-type(1),
    a.topbar-pill:nth-of-type(2) {
        display: none;
    }

    .page-content {
        padding-top: calc(var(--topbar-height) + var(--safe-area-top) + 36px);
    }

    .home-feature-grid,
    .home-action-card {
        grid-template-columns: 1fr;
    }

    .home-feature-grid {
        gap: 0.62rem;
    }

    .home-feature-card {
        grid-template-columns: 40px minmax(0, 1fr);
        min-height: 76px;
        padding: 0.72rem 0.78rem;
    }

    .home-feature-card strong {
        font-size: 0.94rem;
    }

    .home-feature-card small {
        flex-wrap: wrap;
        gap: 0.2rem 0.42rem;
        font-size: 0.76rem;
    }

    .home-feature-card small span:last-child {
        white-space: normal;
    }

    .home-action-card {
        gap: 0.72rem;
    }

    .home-action-visual {
        width: 100%;
    }

    .button {
        width: 100%;
    }

    .password-input {
        grid-template-columns: 1fr;
    }
}

.decision-tab-nav .tab-pills {
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}

@media (max-width: 768px) {
  .decision-tab-nav .tab-pills .button {
    width:100%;
    text-align:center;
  }
}

.morning-dashboard {
    display: grid;
    gap: 0.9rem;
    width: 100%;
    max-width: 1480px;
    margin: 0 auto;
    color: var(--ink);
}

.dashboard-greeting-top {
    display: grid;
    gap: 0.1rem;
    width: 100%;
    max-width: 1480px;
    margin: 0 auto 1rem;
}

.dashboard-greeting-top .dashboard-title {
    margin-bottom: 0;
}

.dashboard-growth-heading {
    margin: 0 0 0.72rem;
}

.dashboard-growth-heading h2 {
    margin: 0;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: clamp(1.54rem, 2vw, 2rem);
    font-weight: 600;
    line-height: 1.2;
}

.morning-statusbar,
.morning-kpi-strip,
.morning-focus-panel,
.morning-journey-panel,
.morning-warning {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.morning-statusbar {
    min-height: 58px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.78rem 0.95rem;
}

.morning-brand,
.morning-status-meta,
.morning-kpi-label,
.morning-legend,
.morning-secondary-metric,
.morning-phase-footer,
.morning-quick-links {
    display: flex;
    align-items: center;
    gap: 0.58rem;
}

.morning-brand {
    min-width: 0;
    flex-wrap: wrap;
    color: var(--muted);
    font-size: 0.82rem;
}

.morning-brand strong {
    color: var(--ink);
    font-size: 0.86rem;
    font-weight: 800;
}

.morning-brand-mark {
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    border-radius: 7px;
    background: var(--black);
}

.morning-brand-mark img {
    width: 15px;
    height: 15px;
    object-fit: contain;
}

.morning-live {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    color: var(--muted);
    font-style: normal;
    font-size: 0.78rem;
}

.morning-live::before,
.morning-legend span::before,
.morning-phase-heading i::before {
    content: "";
    width: 6px;
    height: 6px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--amber);
}

.morning-live.is-healthy::before,
.morning-legend .is-healthy::before,
.morning-journey-card.is-healthy .morning-phase-heading i::before {
    background: var(--green);
}

.morning-live.is-critical::before,
.morning-legend .is-critical::before,
.morning-journey-card.is-critical .morning-phase-heading i::before {
    background: var(--red);
}

.morning-status-meta {
    justify-content: flex-end;
    flex-wrap: wrap;
    color: var(--muted);
    font-size: 0.78rem;
}

.morning-warning {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border-color: color-mix(in srgb, var(--amber) 32%, var(--line));
    color: #7a4d00;
    font-size: 0.84rem;
}

.morning-warning.is-muted {
    border-color: var(--line);
    color: var(--muted);
}

.morning-warning strong {
    color: var(--ink);
}

.morning-kpi-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    overflow: hidden;
}

.morning-kpi-card {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 0.32rem;
    min-height: 102px;
    padding: 1.12rem 1.45rem;
    border-right: 1px solid var(--line);
    color: var(--ink);
    text-decoration: none;
}

.morning-kpi-card:last-child {
    border-right: 0;
}

.morning-kpi-card:hover,
.morning-kpi-card:focus-visible {
    background: #fbfbfc;
}

.morning-kpi-label {
    color: var(--muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.morning-kpi-label i {
    width: 15px;
    height: 15px;
    display: inline-grid;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--muted);
    font-style: normal;
    font-size: 0.66rem;
    font-weight: 800;
}

.morning-kpi-card strong {
    display: flex;
    align-items: baseline;
    gap: 0.42rem;
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: clamp(1.72rem, 3vw, 2.46rem);
    font-weight: 500;
    line-height: 1.02;
}

.morning-kpi-card strong small {
    color: var(--muted);
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 600;
}

.morning-kpi-text-value {
    font-size: clamp(1.2rem, 2vw, 1.72rem);
}

.morning-kpi-caption {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
}

.morning-kpi-caption.is-up {
    color: #13835a;
}

.morning-kpi-caption.is-down {
    color: #b42318;
}

.morning-journey-panel {
    display: grid;
    overflow: hidden;
}

.morning-focus-panel {
    display: grid;
    overflow: hidden;
}

.morning-focus-panel .dashboard-next-step-grid {
    padding: 0 1.4rem 1.2rem;
}

.morning-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.22rem 1.4rem 0.9rem;
}

.morning-section-head h2 {
    margin: 0 0 0.16rem;
    color: var(--ink);
    font-size: 1.22rem;
    font-weight: 500;
    line-height: 1.16;
}

.morning-section-head p,
.morning-generated {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
}

.morning-legend {
    flex-wrap: wrap;
    justify-content: flex-end;
    color: var(--muted);
    font-size: 0.72rem;
}

.morning-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
}

.morning-flow {
    display: flex;
    gap: 0;
    align-items: center;
    min-height: 88px;
    padding: 0.82rem 1.4rem 1rem;
}

.morning-flow-segment {
    position: relative;
    flex: var(--volume) 1 0;
    min-width: 58px;
    height: 34px;
    background: var(--amber);
}

.morning-flow-segment:first-child {
    border-radius: 7px 0 0 7px;
}

.morning-flow-segment:last-child {
    border-radius: 0 7px 7px 0;
}

.morning-flow-segment.is-healthy {
    background: #48c39a;
}

.morning-flow-segment.is-critical {
    background: #f05c62;
}

.morning-flow-segment em {
    position: absolute;
    top: 50%;
    right: -22px;
    z-index: 2;
    min-width: 44px;
    padding: 0.22rem 0.4rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--ink);
    font-style: normal;
    font-size: 0.68rem;
    font-weight: 800;
    text-align: center;
    transform: translateY(-50%);
    box-shadow: var(--shadow-sm);
}

.morning-flow-segment:last-child em {
    right: 0.45rem;
}

.morning-journey-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    border-top: 1px solid var(--line);
}

.morning-journey-card {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: 0.78rem;
    min-height: 258px;
    padding: 1rem;
    border-right: 1px solid var(--line);
    color: var(--ink);
    text-decoration: none;
}

.morning-journey-card:last-child {
    border-right: 0;
}

.morning-journey-card:hover,
.morning-journey-card:focus-visible {
    background: #fbfbfc;
}

.morning-phase-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.morning-phase-title {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    min-width: 0;
}

.morning-product-icon {
    width: 22px;
    height: 22px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #fff;
    color: var(--ink);
}

.morning-product-icon svg {
    width: 14px;
    height: 14px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
}

.morning-phase-heading strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1;
}

.morning-phase-heading i {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    color: var(--muted);
    font-style: normal;
    font-size: 0.68rem;
}

.morning-phase-subtitle {
    margin-top: -0.5rem;
    color: var(--muted);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.morning-primary-metric {
    display: grid;
    gap: 0.2rem;
}

.morning-primary-metric > strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.78rem;
    font-weight: 500;
    line-height: 1;
    overflow-wrap: anywhere;
}

.morning-primary-metric small,
.morning-impact small,
.morning-secondary-metric span {
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.35;
}

.morning-primary-metric em {
    margin-left: 0.32rem;
    font-style: normal;
    font-weight: 750;
}

.morning-primary-metric em.is-up {
    color: #13835a;
}

.morning-primary-metric em.is-down {
    color: #b42318;
}

.morning-secondary-metric {
    justify-content: space-between;
    min-height: 24px;
    border-bottom: 1px solid var(--line);
    padding-bottom: 0.72rem;
}

.morning-secondary-metric strong {
    color: var(--ink);
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.morning-signal {
    display: grid;
    gap: 0.3rem;
    min-height: 54px;
}

.morning-signal em {
    color: var(--muted);
    font-style: normal;
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.morning-signal strong {
    color: var(--ink);
    font-size: 0.84rem;
    font-weight: 750;
    line-height: 1.35;
}

.morning-impact {
    display: grid;
    gap: 0.12rem;
}

.morning-impact strong {
    color: var(--ink);
    font-size: 0.98rem;
    font-weight: 850;
}

.morning-phase-footer {
    align-self: end;
    justify-content: space-between;
    gap: 0.46rem;
    padding-top: 0.7rem;
    border-top: 1px solid var(--line);
    color: var(--muted);
    font-size: 0.68rem;
}

.morning-quick-links {
    justify-content: center;
    flex-wrap: wrap;
    padding: 0.36rem 0;
}

.morning-quick-links a {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    padding: 0.36rem 0.65rem;
    border-radius: 7px;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 650;
    text-decoration: none;
}

.morning-quick-links a:hover,
.morning-quick-links a:focus-visible {
    background: #fff;
    color: var(--ink);
}

.morning-generated {
    text-align: center;
}

.dashboard-legacy-section {
    margin-top: 2.4rem;
}

.dashboard-legacy-full,
.dashboard-next-steps {
    display: grid;
    gap: 1rem;
}

.dashboard-next-steps {
    padding: 1.2rem;
}

.dashboard-next-step-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.7rem;
}

.dashboard-next-step {
    display: grid;
    align-content: start;
    gap: 0.24rem;
    min-height: 112px;
    padding: 0.9rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--ink);
    text-decoration: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.dashboard-next-step:hover,
.dashboard-next-step:focus-visible {
    border-color: var(--line-strong);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}

.dashboard-next-step span,
.dashboard-next-step small {
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.35;
}

.dashboard-next-step strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.34rem;
    font-weight: 500;
    line-height: 1.1;
}

.dashboard-side-full {
    display: grid;
    min-width: 0;
}

.dashboard-side-full .content-card-side {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.dashboard-side-full .content-card-side > .empty-state {
    grid-column: 1 / -1;
}

.dashboard-side-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start;
    gap: 1rem;
}

.dashboard-side-columns.has-products {
    grid-template-columns: minmax(0, 1.55fr) minmax(250px, 0.72fr) minmax(280px, 0.9fr);
}

.dashboard-side-column {
    display: grid;
    align-content: start;
    gap: 1rem;
    min-width: 0;
}

.dashboard-side-full .content-card-side .side-card {
    min-width: 0;
    align-self: start;
    align-content: start;
    gap: 0.86rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-hairline);
}

.dashboard-side-full .content-card-side > .side-card-first {
    grid-column: 1 / -1;
    padding: 1rem;
    border: 1px solid var(--line);
}

.dashboard-side-full .side-card h3 {
    font-size: 1rem;
    line-height: 1.2;
}

.dashboard-side-full .segment-list,
.dashboard-side-full .channel-mix-list,
.dashboard-side-full .freshness-list,
.dashboard-side-full .quick-actions-stack {
    gap: 0.66rem;
}

.dashboard-side-full .side-card-queues .segment-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dashboard-side-full .side-card-queues .segment-item,
.dashboard-side-full .side-card-products .segment-item,
.dashboard-side-full .side-card-freshness .freshness-item,
.dashboard-side-full .side-card-discovery .freshness-item {
    min-height: 76px;
    padding: 0.78rem;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-soft);
}

.product-opportunity-item.has-thumbnail {
    grid-template-columns: 44px minmax(0, 1fr) auto;
    align-items: center;
}

.product-opportunity-thumb {
    width: 44px;
    height: 44px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    object-fit: cover;
}

.dashboard-side-full .side-card-products .segment-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dashboard-side-full .channel-mix-item,
.dashboard-side-full .dashboard-action-list .channel-mix-item,
.dashboard-side-full .dashboard-tier-list .channel-mix-item {
    grid-template-columns: minmax(0, 1fr) minmax(72px, 0.54fr) 42px;
}

.dashboard-side-full .quick-action {
    min-height: 0;
    padding: 0.78rem;
}

.dashboard-side-full .quick-action span {
    font-size: 0.78rem;
}

@media (max-width: 1199px) {
    .morning-kpi-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .morning-kpi-card:nth-child(2n) {
        border-right: 0;
    }

    .morning-kpi-card:nth-child(-n + 2) {
        border-bottom: 1px solid var(--line);
    }

    .morning-journey-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .morning-journey-card {
        border-bottom: 1px solid var(--line);
    }

    .morning-journey-card:nth-child(2n) {
        border-right: 0;
    }

    .morning-journey-card:last-child {
        grid-column: 1 / -1;
        border-bottom: 0;
    }

    .dashboard-side-columns {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-side-column-main {
        grid-column: 1 / -1;
    }

    .dashboard-side-full .side-card-queues .segment-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .morning-statusbar,
    .morning-section-head,
    .morning-warning {
        align-items: flex-start;
        flex-direction: column;
    }

    .morning-status-meta,
    .morning-legend {
        justify-content: flex-start;
    }

    .morning-kpi-strip {
        grid-template-columns: 1fr;
    }

    .morning-kpi-card {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .morning-kpi-card:last-child {
        border-bottom: 0;
    }

    .morning-flow {
        overflow-x: auto;
    }

    .dashboard-next-step-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-side-columns,
    .dashboard-side-full .side-card-queues .segment-list,
    .dashboard-side-full .side-card-products .segment-list {
        grid-template-columns: 1fr;
    }

    .dashboard-side-column-main {
        grid-column: auto;
    }

    .segment-result-grid,
    .segment-card-metrics,
    .segment-preview-list {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .morning-statusbar,
    .morning-kpi-card,
    .morning-section-head,
    .morning-flow,
    .morning-journey-card {
        padding-right: 0.86rem;
        padding-left: 0.86rem;
    }

    .morning-journey-grid {
        grid-template-columns: 1fr;
    }

    .morning-journey-card,
    .morning-journey-card:nth-child(2n) {
        border-right: 0;
    }

    .morning-journey-card:last-child {
        grid-column: auto;
    }

    .morning-phase-footer {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .morning-kpi-card strong {
        font-size: 1.82rem;
    }
}

.system-log-filter label {
    display: grid;
    gap: 0.32rem;
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 700;
}

.system-log-filter select,
.system-log-filter input {
    min-height: 38px;
    max-width: 220px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--text);
    font: inherit;
    font-size: 0.86rem;
}

.system-log-filter input {
    padding: 0 0.78rem;
}

.system-log-kpi-grid,
.system-log-chart-grid,
.system-log-table-grid {
    display: grid;
    gap: 1rem;
    margin-bottom: 1rem;
}

.system-log-kpi-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.system-log-kpi-card {
    display: grid;
    gap: 0.42rem;
    padding: 1rem;
}

.system-log-kpi-card span,
.system-log-muted,
.system-log-file-meta {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.45;
}

.system-log-kpi-card strong {
    color: var(--ink);
    font-family: var(--font-heading);
    font-size: 1.45rem;
    font-weight: 700;
    letter-spacing: 0;
}

.system-log-chart-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.system-log-chart-card {
    min-width: 0;
    overflow: hidden;
}

.system-log-chart-card:first-child {
    grid-column: 1 / -1;
}

.system-log-run-chart {
    max-width: 100%;
    height: auto;
    min-height: 260px;
}

.system-log-run-chart line,
.system-log-run-chart polyline {
    vector-effect: non-scaling-stroke;
}

.system-log-line-runs,
.system-log-line-errors {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.system-log-line-runs {
    stroke: #1f7aec;
}

.system-log-line-errors {
    stroke: #d92d20;
}

.system-log-dot-runs {
    fill: #1f7aec;
}

.system-log-dot-errors {
    fill: #d92d20;
}

.system-log-chart-label {
    fill: var(--muted);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0;
}

.system-log-chart-legend text {
    fill: var(--muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0;
}

.system-log-bar-list {
    display: grid;
    gap: 0.86rem;
}

.system-log-bar-row {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(130px, 0.85fr) max-content;
    align-items: center;
    gap: 0.72rem;
    min-width: 0;
}

.system-log-bar-row > div:first-child {
    min-width: 0;
}

.system-log-bar-row > div:first-child strong {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.system-log-bar-row > strong {
    justify-self: end;
    min-width: 4.5rem;
    text-align: right;
    white-space: nowrap;
}

.system-log-bar-row strong {
    color: var(--ink);
    font-size: 0.86rem;
}

.system-log-bar-row span {
    display: block;
    color: var(--muted);
    font-size: 0.74rem;
    line-height: 1.4;
}

.system-log-bar-track {
    height: 10px;
    overflow: hidden;
    border-radius: 999px;
    background: #eef2f8;
}

.system-log-bar-fill {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #1f7aec;
}

.system-log-bar-fill.is-error {
    background: #d92d20;
}

.system-log-table-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
}

.system-log-status {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0.18rem 0.5rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 700;
}

.system-log-status.is-ok {
    border-color: rgba(39, 173, 123, 0.22);
    background: rgba(39, 173, 123, 0.08);
    color: #157457;
}

.system-log-status.is-error {
    border-color: #ffd7d7;
    background: var(--red-soft);
    color: #c52222;
}

.system-log-viewer-card {
    display: grid;
    gap: 1rem;
}

.system-log-file-meta {
    display: grid;
    justify-items: end;
    gap: 0.18rem;
}

.system-log-viewer {
    display: grid;
    max-height: 560px;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #101217;
    color: #e9edf5;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.78rem;
    line-height: 1.55;
}

.system-log-line {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 0.75rem;
    padding: 0.36rem 0.72rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.system-log-line:last-child {
    border-bottom: 0;
}

.system-log-line.is-error {
    background: rgba(217, 45, 32, 0.18);
}

.system-log-line-number {
    color: rgba(233, 237, 245, 0.5);
    text-align: right;
    user-select: none;
}

.system-log-line code {
    white-space: pre-wrap;
    word-break: break-word;
}

.system-log-empty {
    padding: 1rem;
    border: 1px dashed var(--line);
    border-radius: 8px;
    background: var(--surface-muted);
}

@media (max-width: 1320px) {
    .system-log-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .system-log-chart-grid,
    .system-log-table-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .system-log-filter {
        width: 100%;
    }

    .system-log-filter label,
    .system-log-filter select,
    .system-log-filter input,
    .system-log-filter button {
        width: 100%;
        max-width: none;
    }

    .system-log-kpi-grid {
        grid-template-columns: 1fr;
    }

    .system-log-bar-row {
        grid-template-columns: minmax(0, 1fr);
        gap: 0.48rem;
    }

    .system-log-bar-row > strong {
        justify-self: start;
        min-width: 0;
        text-align: left;
    }

    .system-log-file-meta {
        justify-items: start;
    }

    .system-log-line {
        grid-template-columns: 42px minmax(0, 1fr);
        gap: 0.52rem;
        padding-right: 0.52rem;
        padding-left: 0.52rem;
    }
}
