:root {
    color-scheme: light;

    --bg: #F6F8FB;
    --bg-soft: #EEF3FA;
    --surface: rgba(255, 255, 255, 0.96);
    --surface-solid: #ffffff;
    --surface2: rgba(248, 250, 252, 0.98);
    --surface2-solid: #F8FAFC;
    --surface3: rgba(237, 242, 249, 0.98);
    --surface3-solid: #EDF2F9;
    --surface-elevated: #ffffff;
    --header-bg: rgba(255, 255, 255, 0.94);
    --modal-overlay-bg: rgba(2, 6, 23, 0.56);
    --border: rgba(20, 33, 65, 0.08);
    --border-strong: rgba(20, 33, 65, 0.16);

    --primary: #0065FF;
    --accent: #0065FF;
    --accent2: #014EDC;
    --accent-light: #6EA8FF;
    --accent-dark: #0049B8;
    --accent-contrast: #ffffff;
    --accent-glow: rgba(0, 101, 255, 0.1);
    --brand: #1B82B0;
    --brand-soft: rgba(27, 130, 176, 0.12);
    --highlight: #FCD02B;

    --text: #142141;
    --text2: #44516A;
    --text3: #68758D;
    --muted: #99A4B7;

    --success: #22c55e;
    --warning: #f59e0b;
    --danger: #ef4444;
    --info: #38bdf8;

    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 14px 32px rgba(20, 33, 65, 0.08);
    --shadow-lg: 0 24px 60px rgba(20, 33, 65, 0.12);
    --shadow-xl: 0 32px 80px rgba(20, 33, 65, 0.16);
    --shadow-hover: 0 18px 36px rgba(20, 33, 65, 0.1);

    --q1: var(--success);
    --q2: var(--warning);
    --q3: #fb7185;
    --q4: var(--danger);

    --font-display: 'Poppins', 'Outfit', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-logo: 'Syne', sans-serif;
    --font-syne: var(--font-display);
    --font-mono: 'DM Mono', monospace;
    --font-body: 'Outfit', 'Poppins', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

    --radius-xs: 6px;
    --radius-sm: 8px;
    --radius: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --control-h: 36px;
    --control-h-sm: 32px;
    --focus-ring: 0 0 0 3px rgba(0, 101, 255, 0.24);
    --z-header: 100;
    --z-dropdown: 300;
    --z-modal: 9999;
}

body.dark-mode {
    color-scheme: dark;

    --bg: #080A0F;
    --bg-soft: #0D1117;
    --surface: #111318;
    --surface-solid: #111318;
    --surface2: #151922;
    --surface2-solid: #151922;
    --surface3: #1B1F2A;
    --surface3-solid: #1B1F2A;
    --surface-elevated: #1B1F2A;
    --header-bg: rgba(17, 19, 24, 0.94);
    --modal-overlay-bg: rgba(0, 0, 0, 0.62);
    --border: rgba(255, 255, 255, 0.08);
    --border-strong: rgba(255, 255, 255, 0.12);

    --text: #F8FAFC;
    --text2: #AAB2C0;
    --text3: #6B7280;
    --muted: #4B5563;

    --accent-glow: rgba(0, 101, 255, 0.15);

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
    --shadow-md: 0 12px 30px rgba(0, 0, 0, 0.5);
    --shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.6);
    --shadow-xl: 0 32px 80px rgba(0, 0, 0, 0.64);
    --shadow-hover: 0 18px 36px rgba(0, 0, 10, 0.4);
}

body.dark-mode.true-darkness-mode {
    color-scheme: dark;

    --bg: #000000;
    --bg-soft: #000000;
    --surface: #050505;
    --surface-solid: #050505;
    --surface2: #080808;
    --surface2-solid: #080808;
    --surface3: #0D0D0D;
    --surface3-solid: #0D0D0D;
    --surface-elevated: #0A0A0A;
    --header-bg: rgba(5, 5, 5, 0.96);
    --modal-overlay-bg: rgba(0, 0, 0, 0.68);
    --border: rgba(255, 255, 255, 0.08);
    --border-strong: rgba(255, 255, 255, 0.14);

    --text: #F9FAFB;
    --text2: #C7CDD7;
    --text3: #8C95A3;
    --muted: #626B78;

    --accent-glow: rgba(0, 101, 255, 0.22);

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.72);
    --shadow-md: 0 14px 34px rgba(0, 0, 0, 0.74);
    --shadow-lg: 0 28px 68px rgba(0, 0, 0, 0.78);
    --shadow-xl: 0 36px 90px rgba(0, 0, 0, 0.82);
    --shadow-hover: 0 18px 38px rgba(0, 0, 0, 0.78);
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
}

html.dark-mode {
    color-scheme: dark;
}

html {
    overflow: hidden;
}

body {
    background:
        radial-gradient(circle at top left, rgba(0, 101, 255, 0.1), transparent 30vw),
        linear-gradient(180deg, var(--bg-soft) 0%, var(--bg) 48%);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.5;
    min-height: 100vh;
    overflow: hidden;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

body.true-darkness-mode {
    background: #000000;
}

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

button {
    color: inherit;
}

button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
a:focus-visible {
    outline: none;
    box-shadow: none;
}

input:focus,
input:focus-visible,
select:focus,
select:focus-visible,
textarea:focus,
textarea:focus-visible,
.multi-select-trigger:focus,
.settings-select:focus {
    border-color: var(--border) !important;
    outline: none !important;
    box-shadow: none !important;
}

::selection {
    background: rgba(0, 101, 255, 0.28);
    color: var(--text);
}

/* Ocultar barra de rolagem visualmente em todo o app (mantendo o scroll nativo ativo) */

* {
    scrollbar-width: none !important; /* Firefox */
    -ms-overflow-style: none !important; /* IE e Edge legacy */
}

::-webkit-scrollbar,
*::-webkit-scrollbar {
    display: none !important; /* Chrome, Safari, Edge e Opera */
    width: 0 !important;
    height: 0 !important;
}

.icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    
    vertical-align: middle;
}

#loader {
    --primary: var(--global-accent, #0065FF);
    --accent: var(--global-accent, #0065FF);
    --accent2: var(--global-accent2, #0056D9);
    --accent-light: var(--global-accent-light, #4D93FF);
    --accent-dark: var(--global-accent-dark, #0047B3);
    --accent-glow: var(--global-accent-glow, rgba(0, 101, 255, 0.15));
    position: fixed;
    inset: 0;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--bg-soft) 82%, transparent), var(--bg)),
        var(--bg);
    display: grid;
    place-items: center;
    z-index: 9999;
    overflow: hidden;
    padding: 28px;
    transition: opacity 0.6s ease;
}

#loader.hidden {
    opacity: 0;
    pointer-events: none;
}

.loader-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(color-mix(in srgb, var(--border) 55%, transparent) 1px, transparent 1px),
        linear-gradient(90deg, color-mix(in srgb, var(--border) 55%, transparent) 1px, transparent 1px);
    background-size: 58px 58px;
    mask-image: radial-gradient(circle at center, black 0%, transparent 72%);
    opacity: 0.42;
}

.loader-orbit {
    position: absolute;
    border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
    border-radius: 999px;
    filter: blur(0.1px);
}

.loader-orbit-one {
    width: 520px;
    height: 520px;
    left: 8vw;
    top: 12vh;
    animation: loaderDrift 16s ease-in-out infinite;
}

.loader-orbit-two {
    width: 360px;
    height: 360px;
    right: 9vw;
    bottom: 12vh;
    animation: loaderDrift 18s ease-in-out infinite reverse;
}

.loader-shell {
    position: relative;
    display: grid;
    grid-template-columns: minmax(280px, 430px) minmax(320px, 460px);
    gap: 18px;
    width: min(940px, 100%);
}

.loader-panel,
.loader-preview {
    background: color-mix(in srgb, var(--surface-solid) 86%, transparent);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(18px);
}

.loader-panel {
    min-height: 340px;
    padding: 28px;
}

.loader-brand-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 28px;
}

.loader-logo {
    display: flex;
    align-items: center;
    margin-bottom: 6px;
}

.loader-logo img {
    height: clamp(38px, 6vw, 52px);
    width: auto;
    display: block;
}

.loader-logo span {
    color: var(--text3);
}

.loader-kicker {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text3);
    opacity: 0.82;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.loader-percent {
    color: var(--accent);
    font-family: var(--font-mono);
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

.loader-headline {
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(22px, 3vw, 32px);
    font-weight: 800;
    line-height: 1.08;
    max-width: 360px;
}

.loader-status {
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 12px;
    margin-top: 14px;
    min-height: 18px;
}

.loader-bar-wrap {
    width: 100%;
    height: 8px;
    background: var(--surface3-solid);
    border-radius: 99px;
    overflow: hidden;
    margin-top: 28px;
}

.loader-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--accent), var(--brand));
    border-radius: 99px;
    width: 0%;
    transition: width 0.4s ease;
}

.loader-steps {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
}

.loader-steps span {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    padding: 7px 9px;
    text-transform: uppercase;
}

.loader-steps span.active {
    border-color: color-mix(in srgb, var(--accent) 48%, var(--border));
    color: var(--accent);
}

.loader-steps span.done {
    background: color-mix(in srgb, var(--accent) 13%, var(--surface2));
    color: var(--text);
}

.loader-preview {
    display: grid;
    gap: 14px;
    min-height: 340px;
    padding: 18px;
}

.loader-preview-top,
.loader-preview-grid span,
.loader-preview-chart,
.loader-preview-lines span {
    background: linear-gradient(90deg, var(--surface2-solid), var(--surface3-solid), var(--surface2-solid));
    background-size: 220% 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    animation: loaderShimmer 1.8s linear infinite;
}

.loader-preview-top {
    height: 42px;
}

.loader-preview-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, 1fr);
}

.loader-preview-grid span {
    height: 76px;
}

.loader-preview-chart {
    align-items: end;
    display: flex;
    gap: 10px;
    height: 112px;
    padding: 14px;
}

.loader-preview-chart i {
    background: color-mix(in srgb, var(--accent) 42%, var(--surface3-solid));
    border-radius: 6px 6px 2px 2px;
    flex: 1;
}

.loader-preview-chart i:nth-child(1) { height: 34%; }

.loader-preview-chart i:nth-child(2) { height: 62%; }

.loader-preview-chart i:nth-child(3) { height: 46%; }

.loader-preview-chart i:nth-child(4) { height: 78%; }

.loader-preview-chart i:nth-child(5) { height: 55%; }

.loader-preview-lines {
    display: grid;
    gap: 8px;
}

.loader-preview-lines span {
    height: 18px;
}

@keyframes loaderShimmer {
    from { background-position: 100% 0; }
    to { background-position: -100% 0; }
}

@keyframes loaderDrift {
    0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
    50% { transform: translate3d(18px, -14px, 0) scale(1.04); }
}

@media (max-width: 820px) {
    #loader {
        padding: 18px;
    }

    .loader-shell {
        grid-template-columns: 1fr;
        width: 100%;
        max-width: 460px;
        min-width: 0;
    }

    .loader-preview {
        display: none;
    }

    .loader-panel {
        width: 100%;
        min-width: 0;
        min-height: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .loader-orbit,
    .loader-preview-top,
    .loader-preview-grid span,
    .loader-preview-chart,
    .loader-preview-lines span {
        animation: none;
    }
}

.loader-message-repo {
    margin-top: 24px;
}

.loader-message {
    display: none;
    position: relative;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    overflow: hidden;
    border: 2px solid transparent;
    border-radius: var(--radius-lg);
    background-clip: padding-box;
    animation: loaderMessagePop 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.loader-message.active {
    display: flex;
}

.loader-message-body {
    min-width: 0;
    position: relative;
    z-index: 1;
}

.loader-message-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 3px 10px;
    border-radius: 99px;
    color: #fff;
    margin-bottom: 6px;
}

.loader-message-name {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 800;
    line-height: 1.2;
}

.loader-message-role {
    font-family: var(--font-mono);
    font-size: 11px;
    margin-top: 3px;
    font-weight: 600;
}

@keyframes loaderMessagePop {
    from { opacity: 0; transform: scale(0.85) translateY(16px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes floatUp {
    0%   { transform: translateY(0) scale(1); opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 0.6; }
    100% { transform: translateY(-180px) scale(0.6); opacity: 0; }
}

.loader-message[data-msg="health"] {
    min-height: 138px;
    background-color: #000000;
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 0 36px -14px rgba(0, 0, 0, 0.5);
}

.loader-message[data-msg="health"]::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, #333333, #555555, #222222, #777777, #333333);
    background-size: 420% 420%;
    z-index: -1;
    animation: loaderMessageBorder 6s ease-in-out infinite;
}

.loader-message[data-msg="health"]::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 15% 25%, rgba(255, 255, 255, 0.2) 0 1px, transparent 2px),
        radial-gradient(circle at 65% 15%, rgba(255, 255, 255, 0.1) 0 1px, transparent 2px),
        radial-gradient(circle at 45% 75%, rgba(255, 255, 255, 0.15) 0 1px, transparent 2px),
        linear-gradient(110deg, transparent 0 40%, rgba(255, 255, 255, 0.05) 50%, transparent 60%);
    opacity: 0.5;
    pointer-events: none;
    animation: healthSheen 6s ease-in-out infinite;
}

.loader-message[data-msg="health"] .loader-message-badge {
    background: rgba(30, 30, 30, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: #f8fafc;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.4);
}

.loader-message[data-msg="health"] .loader-message-body {
    flex: 1;
    max-width: none;
    padding-right: 38px;
}

.loader-message[data-msg="health"] .loader-message-name {
    color: #f8fafc;
    font-size: 21px;
    text-shadow: 0 2px 8px rgba(2, 44, 34, 0.8);
}

.loader-message[data-msg="health"] .loader-message-role {
    color: #cbd5e1;
    max-width: 310px;
    line-height: 1.35;
}

.loader-message[data-msg="health"] .loader-message-icon {
    display: grid;
    place-items: center;
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    border-radius: 16px;
    background: rgba(30, 30, 30, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 12px 28px rgba(0, 0, 0, 0.3);
    animation: healthIconFloat 3s ease-in-out infinite;
}

.loader-health-core {
    font-size: 24px;
    line-height: 1;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.3));
}

.loader-health-scene {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.health-fruit {
    position: absolute;
    right: 25px;
    bottom: -20px;
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.25), transparent 20%),
        linear-gradient(135deg, #ef4444 0%, #991b1b 60%, #450a0a 100%);
    box-shadow: inset -15px -15px 25px rgba(0, 0, 0, 0.4), 0 0 35px rgba(239, 68, 68, 0.2);
    transform: rotate(-15deg);
}

.health-fruit::before {
    content: '';
    position: absolute;
    top: -12px;
    left: 40px;
    width: 6px;
    height: 18px;
    background: #78350f;
    border-radius: 4px;
    transform: rotate(20deg);
}

.health-fruit::after {
    content: '';
    position: absolute;
    top: -5px;
    left: 46px;
    width: 25px;
    height: 15px;
    background: #22c55e;
    border-radius: 15px 0 15px 0;
    transform: rotate(-10deg);
    box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.3);
}

.health-leaf {
    position: absolute;
    background: linear-gradient(135deg, #4ade80, #16a34a);
    border-radius: 12px 0 12px 0;
    box-shadow: 0 4px 12px rgba(22, 163, 74, 0.4);
    opacity: 0.8;
    animation: healthLeafFloat 4s ease-in-out infinite;
}

.leaf-a { left: 15%; top: 25%; width: 20px; height: 12px; animation-duration: 4.5s; transform: rotate(15deg); }

.leaf-b { left: 45%; top: 60%; width: 14px; height: 8px; animation-duration: 3.8s; animation-delay: 1.2s; transform: rotate(-45deg); }

.leaf-c { right: 35%; top: 15%; width: 24px; height: 14px; animation-duration: 5s; animation-delay: 0.6s; transform: rotate(70deg); }

.health-sparkle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: #ffffff;
    border-radius: 50%;
    box-shadow: 0 0 15px 4px rgba(255, 255, 255, 0.6);
    animation: healthSparkle 3s ease-in-out infinite;
}

.sparkle-a { right: 85px; top: 40px; animation-delay: 0.5s; }

.sparkle-b { right: 15px; top: 30px; animation-delay: 1.8s; }

@keyframes healthIconFloat {
    0%, 100% { transform: translateY(0) scale(1); }
    50%      { transform: translateY(-6px) scale(1.05); }
}

@keyframes healthLeafFloat {
    0%, 100% { transform: translateY(0) rotate(0deg) scale(1); }
    50%      { transform: translateY(-12px) rotate(15deg) scale(1.1); }
}

@keyframes healthSparkle {
    0%, 100% { opacity: 0.2; transform: scale(0.6); }
    50%      { opacity: 1; transform: scale(1.5); }
}

@keyframes healthSheen {
    0%, 100% { transform: translateX(-15%); opacity: 0.3; }
    50%      { transform: translateX(15%); opacity: 0.6; }
}

@media (max-width: 520px) {
    #loader {
        padding: 14px;
    }

    .loader-shell {
        width: 100%;
        max-width: 360px;
        justify-self: start;
    }

    .loader-panel {
        max-width: 100%;
        padding: 22px;
    }

    .loader-message {
        gap: 12px;
        padding: 16px 14px;
    }

    .loader-steps {
        gap: 7px;
    }

    .loader-steps span {
        font-size: 9px;
        padding: 7px 8px;
    }

    .loader-message[data-msg="health"] {
        min-height: 140px;
    }

    .loader-message[data-msg="health"] .loader-message-icon {
        display: none;
    }

    .loader-message[data-msg="health"] .loader-message-body {
        max-width: none;
        padding-right: 34px;
    }

    .loader-message[data-msg="health"] .loader-message-badge {
        max-width: 178px;
        font-size: 8px;
        white-space: normal;
    }

    .loader-message[data-msg="health"] .loader-message-name {
        font-size: 21px;
    }

    .loader-message[data-msg="health"] .loader-message-role {
        max-width: 210px;
        font-size: 10px;
    }

    .health-fruit {
        right: -10px;
        bottom: -15px;
        width: 70px;
        height: 70px;
    }
    
    .health-fruit::before {
        left: 32px;
        top: -10px;
        width: 5px;
        height: 14px;
    }
    
    .health-fruit::after {
        left: 36px;
        top: -4px;
        width: 20px;
        height: 12px;
    }
}

.loader-message[data-msg="birthday"] {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--accent) 14%, var(--surface2)) 0%,
        color-mix(in srgb, var(--warning) 10%, var(--surface2)) 50%,
        color-mix(in srgb, var(--success) 8%, var(--surface2)) 100%
    );
    border-color: transparent;
}

.loader-message[data-msg="birthday"]::before {
    content: '';
    position: absolute;
    inset: -2px;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--accent), var(--warning), var(--success), var(--accent));
    background-size: 400% 400%;
    z-index: -1;
    animation: loaderMessageBorder 4s ease-in-out infinite;
}

.loader-message[data-msg="birthday"] .loader-message-badge {
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--warning)));
    box-shadow: 0 2px 8px color-mix(in srgb, var(--accent) 30%, transparent);
}

.loader-message[data-msg="birthday"] .loader-message-name {
    color: #0f172a;
    text-shadow: 0 1px 0 rgba(255,255,255,0.3);
}

.loader-message[data-msg="birthday"] .loader-message-role {
    color: #334155;
}

.loader-message[data-msg="birthday"] .loader-message-icon {
    font-size: 38px;
    line-height: 1;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 2px 8px color-mix(in srgb, var(--warning) 30%, transparent));
    animation: loaderIconBounce 1.5s ease-in-out infinite;
}

@keyframes loaderIconBounce {
    0%, 100% { transform: translateY(0) scale(1); }
    40%      { transform: translateY(-6px) scale(1.08); }
    60%      { transform: translateY(-2px) scale(1.04); }
}

.loader-message[data-msg="birthday"] .loader-message-confetti {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.loader-message[data-msg="birthday"] .loader-message-confetti i {
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 2px;
    opacity: 0;
    animation: confettiFall 3s ease-in-out infinite;
}

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(1)  { left: 5%;  top: -8%;  background: #ef4444; animation-delay: 0.0s; animation-duration: 2.8s; width: 5px; height: 5px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(2)  { left: 15%; top: -12%; background: #f59e0b; animation-delay: 0.3s; animation-duration: 3.2s; width: 6px; height: 4px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(3)  { left: 28%; top: -6%;  background: #22c55e; animation-delay: 0.6s; animation-duration: 2.6s; width: 4px; height: 6px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(4)  { left: 40%; top: -10%; background: #3b82f6; animation-delay: 0.9s; animation-duration: 3.4s; width: 7px; height: 5px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(5)  { left: 52%; top: -7%;  background: #a855f7; animation-delay: 1.2s; animation-duration: 2.9s; width: 5px; height: 5px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(6)  { left: 62%; top: -14%; background: #ec4899; animation-delay: 0.4s; animation-duration: 3.6s; width: 6px; height: 3px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(7)  { left: 72%; top: -9%;  background: #f59e0b; animation-delay: 0.7s; animation-duration: 2.7s; width: 4px; height: 7px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(8)  { left: 82%; top: -11%; background: #22c55e; animation-delay: 1.0s; animation-duration: 3.1s; width: 5px; height: 5px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(9)  { left: 92%; top: -5%;  background: #3b82f6; animation-delay: 1.4s; animation-duration: 2.5s; width: 6px; height: 4px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(10) { left: 48%; top: -16%; background: #ef4444; animation-delay: 0.1s; animation-duration: 3.8s; width: 5px; height: 5px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(11) { left: 8%;  top: -15%; background: #22c55e; animation-delay: 0.5s; animation-duration: 3.3s; width: 4px; height: 4px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(12) { left: 35%; top: -17%; background: #a855f7; animation-delay: 0.8s; animation-duration: 2.4s; width: 6px; height: 6px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(13) { left: 55%; top: -4%;  background: #f59e0b; animation-delay: 1.1s; animation-duration: 3.5s; width: 5px; height: 3px; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(14) { left: 75%; top: -13%; background: #ef4444; animation-delay: 0.2s; animation-duration: 2.2s; width: 4px; height: 6px; border-radius: 50%; }

.loader-message[data-msg="birthday"] .loader-message-confetti i:nth-child(15) { left: 88%; top: -18%; background: #3b82f6; animation-delay: 1.3s; animation-duration: 3.9s; width: 5px; height: 5px; }

@keyframes confettiFall {
    0%   { opacity: 0; transform: translateY(0) rotate(0deg) scale(1); }
    10%  { opacity: 1; }
    80%  { opacity: 0.8; }
    100% { opacity: 0; transform: translateY(160px) rotate(360deg) scale(0.3); }
}

@keyframes loaderMessageBorder {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

@media (prefers-reduced-motion: reduce) {
    .loader-message,
    .loader-message-icon,
    .loader-message-confetti i,
    .curiosity-star,
    .curiosity-satellite,
    .curiosity-signal,
    .loader-curiosity-core {
        animation: none !important;
    }
    .loader-message::before {
        animation: none !important;
    }
}

.loader-message::before {
    content: '';
    position: absolute;
    inset: -2px;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg,
        var(--accent), var(--warning), var(--success), var(--accent)
    );
    background-size: 400% 400%;
    z-index: -1;
    animation: loaderMessageBorder 4s ease-in-out infinite;
}

.loader-message::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--radius-lg);
    background: radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
        color-mix(in srgb, var(--accent) 6%, transparent) 0%,
        transparent 70%
    );
    pointer-events: none;
    z-index: 0;
}

.loader-message-confetti {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.loader-message-confetti i {
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 2px;
    opacity: 0;
    animation: confettiFall 3s ease-in-out infinite;
}

.loader-message-confetti i:nth-child(1)  { left: 5%;  top: -8%;  background: #ef4444; animation-delay: 0.0s; animation-duration: 2.8s; width: 5px; height: 5px; border-radius: 50%; }

.loader-message-confetti i:nth-child(2)  { left: 15%; top: -12%; background: #f59e0b; animation-delay: 0.3s; animation-duration: 3.2s; width: 6px; height: 4px; }

.loader-message-confetti i:nth-child(3)  { left: 28%; top: -6%;  background: #22c55e; animation-delay: 0.6s; animation-duration: 2.6s; width: 4px; height: 6px; }

.loader-message-confetti i:nth-child(4)  { left: 40%; top: -10%; background: #3b82f6; animation-delay: 0.9s; animation-duration: 3.4s; width: 7px; height: 5px; border-radius: 50%; }

.loader-message-confetti i:nth-child(5)  { left: 52%; top: -7%;  background: #a855f7; animation-delay: 1.2s; animation-duration: 2.9s; width: 5px; height: 5px; }

.loader-message-confetti i:nth-child(6)  { left: 62%; top: -14%; background: #ec4899; animation-delay: 0.4s; animation-duration: 3.6s; width: 6px; height: 3px; }

.loader-message-confetti i:nth-child(7)  { left: 72%; top: -9%;  background: #f59e0b; animation-delay: 0.7s; animation-duration: 2.7s; width: 4px; height: 7px; border-radius: 50%; }

.loader-message-confetti i:nth-child(8)  { left: 82%; top: -11%; background: #22c55e; animation-delay: 1.0s; animation-duration: 3.1s; width: 5px; height: 5px; }

.loader-message-confetti i:nth-child(9)  { left: 92%; top: -5%;  background: #3b82f6; animation-delay: 1.4s; animation-duration: 2.5s; width: 6px; height: 4px; }

.loader-message-confetti i:nth-child(10) { left: 48%; top: -16%; background: #ef4444; animation-delay: 0.1s; animation-duration: 3.8s; width: 5px; height: 5px; border-radius: 50%; }

.loader-message-confetti i:nth-child(11) { left: 8%;  top: -15%; background: #22c55e; animation-delay: 0.5s; animation-duration: 3.3s; width: 4px; height: 4px; }

.loader-message-confetti i:nth-child(12) { left: 35%; top: -17%; background: #a855f7; animation-delay: 0.8s; animation-duration: 2.4s; width: 6px; height: 6px; border-radius: 50%; }

.loader-message-confetti i:nth-child(13) { left: 55%; top: -4%;  background: #f59e0b; animation-delay: 1.1s; animation-duration: 3.5s; width: 5px; height: 3px; }

.loader-message-confetti i:nth-child(14) { left: 75%; top: -13%; background: #ef4444; animation-delay: 0.2s; animation-duration: 2.2s; width: 4px; height: 6px; border-radius: 50%; }

.loader-message-confetti i:nth-child(15) { left: 88%; top: -18%; background: #3b82f6; animation-delay: 1.3s; animation-duration: 3.9s; width: 5px; height: 5px; }

@keyframes confettiFall {
    0%   { opacity: 0; transform: translateY(0) rotate(0deg) scale(1); }
    10%  { opacity: 1; }
    80%  { opacity: 0.8; }
    100% { opacity: 0; transform: translateY(160px) rotate(360deg) scale(0.3); }
}

.loader-message-icon {
    font-size: 38px;
    line-height: 1;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 2px 8px color-mix(in srgb, var(--warning) 30%, transparent));
    animation: loaderIconBounce 1.5s ease-in-out infinite;
}

@keyframes loaderIconBounce {
    0%, 100% { transform: translateY(0) scale(1); }
    40%      { transform: translateY(-6px) scale(1.08); }
    60%      { transform: translateY(-2px) scale(1.04); }
}

.loader-message-body {
    min-width: 0;
    position: relative;
    z-index: 1;
}

.loader-message-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 3px 10px;
    border-radius: 99px;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--warning)));
    color: #fff;
    margin-bottom: 6px;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--accent) 30%, transparent);
}

.loader-message-name {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 800;
    color: #0f172a;
    line-height: 1.15;
    text-shadow: 0 1px 0 rgba(255,255,255,0.3);
}

.loader-message-role {
    font-family: var(--font-mono);
    font-size: 11px;
    color: #334155;
    margin-top: 2px;
    font-weight: 600;
}

.loader-message[data-msg="scene"] {
    min-height: 138px;
    background: var(--loader-card-bg, linear-gradient(135deg, #4a4a47, #25272d, #565553));
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 0 36px -14px rgba(0, 0, 0, 0.5);
}

.loader-message[data-msg="scene"]::before {
    inset: -3px;
    background: var(--loader-card-border, linear-gradient(135deg, #77716a, #34363c, #73716d));
    background-size: 420% 420%;
    animation: loaderMessageBorder 6s ease-in-out infinite;
}

.loader-message[data-msg="scene"]::after {
    background:
        radial-gradient(circle at 15% 25%, rgba(255, 255, 255, 0.18) 0 1px, transparent 2px),
        radial-gradient(circle at 64% 17%, rgba(255, 255, 255, 0.11) 0 1px, transparent 2px),
        linear-gradient(110deg, transparent 0 40%, rgba(255, 255, 255, 0.05) 50%, transparent 60%);
    opacity: 0.58;
    animation: healthSheen 6s ease-in-out infinite;
}

.loader-message[data-msg="scene"] .loader-message-badge {
    background: color-mix(in srgb, var(--loader-card-accent, #60a5fa) 16%, rgba(16, 20, 28, 0.88));
    border: 1px solid color-mix(in srgb, var(--loader-card-accent, #60a5fa) 42%, rgba(255, 255, 255, 0.15));
    color: var(--loader-card-accent, #60a5fa);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.38);
}

.loader-message[data-msg="scene"] .loader-message-body {
    flex: 1;
    max-width: none;
    padding-right: 38px;
}

.loader-message[data-msg="scene"] .loader-message-name {
    color: #f8fafc;
    font-size: 21px;
    line-height: 1.08;
    text-shadow: 0 2px 8px rgba(2, 6, 23, 0.72);
}

.loader-message[data-msg="scene"] .loader-message-role {
    color: #d9e2ee;
    max-width: 310px;
    line-height: 1.35;
}

.loader-message[data-msg="scene"] .loader-message-icon {
    display: grid;
    place-items: center;
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    border-radius: 16px;
    background: rgba(22, 24, 28, 0.62);
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 12px 28px rgba(0, 0, 0, 0.3);
    filter: none;
    animation: healthIconFloat 3s ease-in-out infinite;
}

.loader-message[data-msg="scene"][data-motion="off"] .loader-message-icon {
    animation: none;
}

.loader-message[data-msg="scene"] .loader-health-scene {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.loader-message[data-msg="scene"] .health-leaf {
    background: linear-gradient(135deg, #5ee48f, #1fbf75);
}

.loader-message[data-msg="scene"][data-leaves="off"] .health-leaf,
.loader-message[data-msg="scene"][data-sparkles="off"] .health-sparkle {
    display: none;
}

.loader-message[data-msg="scene"] .sparkle-c {
    left: 42%;
    bottom: 30px;
    animation-delay: 1.1s;
}

.loader-bg-emoji {
    position: absolute;
    right: 22px;
    bottom: -22px;
    font-size: 92px;
    line-height: 1;
    opacity: 0.78;
    filter: drop-shadow(0 12px 28px rgba(0, 0, 0, 0.34));
    transform: rotate(-12deg);
}

.loader-bg-emoji-bulb,
.loader-bg-emoji-star,
.loader-bg-emoji-spark {
    right: 24px;
    bottom: 2px;
    font-size: 72px;
    opacity: 0.42;
}

.loader-bg-emoji-trophy,
.loader-bg-emoji-target {
    right: 18px;
    bottom: -8px;
    font-size: 82px;
}

.loader-bg-emoji-balloon {
    right: 22px;
    bottom: 4px;
    font-size: 80px;
    opacity: 0.64;
}

@keyframes loaderMessagePop {
    from {
        opacity: 0;
        transform: scale(0.85) translateY(16px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

@keyframes loaderMessageBorder {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

@media (prefers-reduced-motion: reduce) {
    .loader-message,
    .loader-message-icon,
    .loader-message-confetti i {
        animation: none;
    }
    .loader-message::before {
        animation: none;
    }
    .loader-message-confetti i {
        display: none;
    }
}

#app {
    display: none;
}

#app.visible {
    display: grid;
    animation: fadeIn 0.8s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.wellness-loading-card {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
    background: color-mix(in srgb, var(--surface-solid) 60%, transparent);
    border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
    border-radius: var(--radius-lg);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    width: 100%;
    min-height: 340px;
    animation: wellnessFadeIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    opacity: 0;
    transform: translateY(10px);
}

.wellness-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 9999;
    border-radius: 0;
    background: color-mix(in srgb, var(--bg) 85%, transparent);
}

.wellness-card-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 320px;
    gap: 16px;
}

.wellness-icon-container {
    position: relative;
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
}

.wellness-icon-bg {
    position: absolute;
    inset: -10px;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 25%, transparent) 0%, transparent 70%);
    border-radius: 50%;
    animation: wellnessPulse 3s ease-in-out infinite;
}

.wellness-icon-drop {
    color: var(--accent-light, #38bdf8);
    position: relative;
    z-index: 2;
    animation: wellnessFloat 3s ease-in-out infinite;
    filter: drop-shadow(0 4px 8px color-mix(in srgb, var(--accent) 40%, transparent));
}

.wellness-bubble {
    position: absolute;
    bottom: 0;
    background: var(--accent-light, #38bdf8);
    border-radius: 50%;
    opacity: 0;
}

.wellness-bubble-1 {
    width: 6px;
    height: 6px;
    left: 15%;
    animation: wellnessBubbleUp 2.5s ease-in infinite 0.2s;
}

.wellness-bubble-2 {
    width: 4px;
    height: 4px;
    right: 15%;
    animation: wellnessBubbleUp 2s ease-in infinite 1s;
}

.wellness-bubble-3 {
    width: 8px;
    height: 8px;
    left: 40%;
    animation: wellnessBubbleUp 3s ease-in infinite 0.7s;
}

.wellness-text-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.wellness-title {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text3);
}

.wellness-message {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 800;
    color: var(--text);
    line-height: 1.2;
}

.wellness-desc {
    font-size: 13px;
    color: var(--text2);
    line-height: 1.5;
}

.wellness-progress-container {
    width: 100%;
    height: 4px;
    background: var(--surface3-solid);
    border-radius: 99px;
    overflow: hidden;
    margin-top: 8px;
    position: relative;
}

.wellness-progress-bar {
    position: absolute;
    top: 0;
    left: -50%;
    height: 100%;
    width: 50%;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    animation: wellnessShimmer 2s linear infinite;
}

@keyframes wellnessFadeIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes wellnessPulse {
    0%, 100% { transform: scale(1); opacity: 0.8; }
    50% { transform: scale(1.4); opacity: 0.4; }
}

@keyframes wellnessFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@keyframes wellnessBubbleUp {
    0% { transform: translateY(10px) scale(0.5); opacity: 0; }
    20% { opacity: 0.6; }
    80% { opacity: 0.6; }
    100% { transform: translateY(-40px) scale(1.2); opacity: 0; }
}

@keyframes wellnessShimmer {
    0% { left: -50%; }
    100% { left: 100%; }
}

@media (max-width: 820px) {
    .wellness-loading-card {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .wellness-loading-card,
    .wellness-icon-bg,
    .wellness-icon-drop,
    .wellness-bubble,
    .wellness-progress-bar {
        animation: none !important;
        transform: none !important;
    }
    .wellness-loading-card {
        opacity: 1;
    }
}

.loader-panel {
    background: color-mix(in srgb, var(--surface-solid) 60%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--border) 60%, transparent) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    animation: wellnessFadeIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
    opacity: 0;
    transform: translateY(10px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.loader-percent {
    font-size: 28px !important;
    background: linear-gradient(135deg, var(--accent-light, #38bdf8), var(--accent, #0065FF));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}

.loader-headline {
    font-size: clamp(24px, 4vw, 36px) !important;
    background: linear-gradient(135deg, var(--text) 30%, var(--text2) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: -0.5px;
    margin-bottom: 4px;
}

.loader-status {
    font-size: 13px !important;
    opacity: 0.8;
}

.loader-bar-wrap {
    height: 6px !important;
    background: color-mix(in srgb, var(--border) 30%, transparent) !important;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
}

.loader-bar {
    background: linear-gradient(90deg, var(--accent), var(--accent-light, #38bdf8)) !important;
    box-shadow: 0 0 10px color-mix(in srgb, var(--accent) 50%, transparent);
}

.loader-steps span {
    background: color-mix(in srgb, var(--surface2) 40%, transparent) !important;
    border-color: color-mix(in srgb, var(--border) 40%, transparent) !important;
    backdrop-filter: blur(4px);
    transition: all 0.3s ease;
}

.loader-steps span.active {
    background: color-mix(in srgb, var(--accent) 15%, transparent) !important;
    border-color: color-mix(in srgb, var(--accent) 40%, transparent) !important;
    box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 20%, transparent);
    transform: translateY(-1px);
}

.loader-panel {
    background: color-mix(in srgb, var(--surface-solid) 70%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--border) 60%, transparent) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    display: flex;
    flex-direction: column;
    padding: 32px !important;
    animation: wellnessFadeIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.loader-brand-minimal {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: auto; 
}

.loader-brand-minimal img {
    height: 20px;
    opacity: 0.8;
}

.loader-kicker-minimal {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text3);
    letter-spacing: 1px;
    border-left: 1px solid var(--border);
    padding-left: 12px;
}

.loader-content-minimal {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1; 
    gap: 32px;
    margin-top: 24px;
    margin-bottom: 24px;
}

.circular-loader-container-minimal {
    width: 140px;
    height: 140px;
    position: relative;
}

.circular-progress-minimal {
    width: 100%;
    height: 100%;
}

.circular-progress-minimal svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.circular-bg-minimal {
    fill: none;
    stroke: color-mix(in srgb, var(--surface3-solid) 30%, transparent);
    stroke-width: 1.5; 
}

.circular-fill-minimal {
    fill: none;
    stroke: var(--accent-light, #38bdf8);
    stroke-width: 1.5; 
    stroke-linecap: round;
    stroke-dasharray: 301.59; 
    stroke-dashoffset: calc(301.59 - (301.59 * var(--progress, 0)) / 100);
    transition: stroke-dashoffset 0.3s ease-out;
}

.circular-content-minimal {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.loader-percent-minimal {
    font-family: var(--font-display);
    font-size: 32px !important;
    font-weight: 300 !important; 
    color: var(--text);
    letter-spacing: -1px;
}

.loader-text-container-minimal {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center;
}

.loader-headline-minimal {
    font-family: var(--font-display);
    font-size: 20px !important;
    font-weight: 600;
    color: var(--text);
    letter-spacing: -0.5px;
}

.loader-status-minimal {
    font-family: var(--font-mono);
    font-size: 11px !important;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ==========================================================================
   Novo Layout e Estrutura Principal - Locus Platform
   ========================================================================== */

/* Shell Principal */

#app {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    min-height: 100vh;
    background: var(--surface-solid);
    transition: grid-template-columns 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Sidebar Esquerda */

.app-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    background: var(--surface-solid);
    border-right: none;
    z-index: 100;
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: visible;
}

.sidebar-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 12px 14px 20px;
    box-sizing: border-box;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none; /* Hide scrollbar Firefox */
}

.sidebar-inner::-webkit-scrollbar {
    display: none; /* Hide scrollbar Chrome/Safari */
}

/* Perfil no Topo da Sidebar */

.sidebar-profile {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    cursor: pointer;
    background: transparent;
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    margin-bottom: 24px;
    user-select: none;
}

.sidebar-profile:hover {
    background: var(--surface2-solid);
}

.profile-avatar {
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent2), var(--accent));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 16px;
    font-family: var(--font-display);
    box-shadow: 0 2px 8px rgba(0, 101, 255, 0.25);
    flex-shrink: 0;
}

.status-badge {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--surface-solid);
    box-sizing: border-box;
}

/* Cores de status */

.status-badge.status-online { background-color: var(--success); }

.status-badge.status-ocupado { background-color: var(--danger); }

.status-badge.status-ausente { background-color: var(--warning); }

.status-badge.status-offline { background-color: var(--muted); }

.profile-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex-grow: 1;
}

.profile-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.profile-status-text {
    font-size: 11px;
    color: var(--text3);
    text-transform: capitalize;
    margin-top: 2px;
}

.profile-chevron {
    width: 16px;
    height: 16px;
    color: var(--text3);
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.sidebar-profile.active .profile-chevron {
    transform: rotate(180deg);
}

/* Dropdown de Perfil */

.profile-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    width: 100%;
    background: var(--surface-solid);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    padding: 8px;
    box-sizing: border-box;
    z-index: 200;
    animation: dropdownFadeIn 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes dropdownFadeIn {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.dropdown-header {
    font-size: 11px;
    font-weight: 600;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 6px 10px;
    user-select: none;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 10px;
    border: none;
    background: transparent;
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 13px;
    text-align: left;
    cursor: pointer;
    font-family: var(--font-body);
    transition: background-color 0.15s ease, color 0.15s ease;
    box-sizing: border-box;
}

.dropdown-item:hover:not(:disabled) {
    background: var(--surface2-solid);
    color: var(--text);
}

.dropdown-item:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.dropdown-item .icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.badge-disabled {
    font-size: 9px;
    background: var(--surface3-solid);
    color: var(--text3);
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: auto;
    font-weight: 600;
}

.dropdown-divider {
    height: 1px;
    background: var(--border);
    margin: 6px 0;
}

/* Status dots no menu */

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}

.status-dot.dot-online { background-color: var(--success); }

.status-dot.dot-ocupado { background-color: var(--danger); }

.status-dot.dot-ausente { background-color: var(--warning); }

.status-dot.dot-offline { background-color: var(--muted); }

/* Navegação Principal */

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 24px;
    flex-grow: 1;
}

.sidebar-section {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sidebar-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 12px;
    cursor: pointer;
    user-select: none;
    border-radius: var(--radius-sm);
}

.sidebar-section-header:hover {
    background: var(--surface2-solid);
}

.sidebar-section-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.chevron-icon {
    width: 14px;
    height: 14px;
    color: var(--text3);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-section.collapsed .chevron-icon {
    transform: rotate(-90deg);
}

.sidebar-section-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease;
    overflow: hidden;
}

.sidebar-section.collapsed .sidebar-section-content {
    max-height: 0 !important;
    opacity: 0;
    pointer-events: none;
}

/* Botões do Menu da Sidebar */

.nav-btn, a.nav-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border: none;
    background: transparent;
    border-radius: var(--radius);
    color: var(--text2);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    text-align: left;
    cursor: pointer;
    font-family: var(--font-body);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-sizing: border-box;
    user-select: none;
}

.nav-btn:hover, a.nav-btn:hover {
    background: var(--surface2-solid);
    color: var(--text);
}

.nav-btn.active, a.nav-btn.active {
    background: color-mix(in srgb, var(--primary) 8%, transparent);
    color: var(--primary);
    font-weight: 600;
}

.nav-btn.active:hover, a.nav-btn.active:hover {
    background: color-mix(in srgb, var(--primary) 12%, transparent);
}

.nav-btn .icon {
    width: 18px;
    height: 18px;
    color: currentColor;
    flex-shrink: 0;
}

/* Badges de notificação na sidebar */

.inbox-badge {
    background: var(--primary);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: auto;
    box-shadow: 0 2px 4px rgba(0, 101, 255, 0.2);
}

/* Rodapé da Sidebar */

.sidebar-footer {
    border-top: 1px solid var(--border);
    padding-top: 16px;
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--muted);
    letter-spacing: 0.2px;
    text-transform: uppercase;
}

.footer-powered {
    font-weight: 600;
}

.footer-studio {
    opacity: 0.8;
}

.sidebar-divider {
    border-top: 1px solid var(--border);
    margin: 8px 0 2px;
}

.footer-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.eventos-trigger-wrapper {
    position: relative;
}

.btn-eventos-trigger {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 7px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm, 6px);
    background: var(--surface);
    color: var(--muted);
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    cursor: pointer;
    transition: color 0.18s ease, border-color 0.18s ease, background 0.18s ease;
    line-height: 1;
    user-select: none;
    white-space: nowrap;
}

.btn-eventos-trigger .icon {
    width: 12px;
    height: 12px;
    color: currentColor;
}

.btn-eventos-trigger:hover {
    color: var(--text2);
    border-color: var(--accent);
    background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}

.btn-eventos-trigger:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.eventos-popover {
    position: absolute;
    bottom: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: var(--surface-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg, 0 8px 32px rgba(0,0,0,0.18));
    padding: 6px;
    display: none;
    z-index: 1000;
    animation: eventos-popover-in 0.15s ease-out;
}

@keyframes eventos-popover-in {
    from {
        opacity: 0;
        transform: translateY(6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.eventos-popover.open {
    display: block;
}

.eventos-popover-header {
    padding: 8px 10px 6px;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 4px;
}

.eventos-popover-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border: none;
    border-radius: var(--radius-sm, 6px);
    background: transparent;
    color: var(--text2);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    text-align: left;
    cursor: pointer;
    width: 100%;
    box-sizing: border-box;
    transition: background 0.15s ease, color 0.15s ease;
}

.eventos-popover-item .icon {
    width: 16px;
    height: 16px;
    color: currentColor;
    flex-shrink: 0;
}

.eventos-popover-item:hover {
    background: var(--surface2-solid);
    color: var(--text);
}

/* Conteúdo Principal */

.app-main {
    display: flex;
    flex-direction: column;
    min-width: 0;
    width: auto;
    flex-grow: 1;
    padding: 24px clamp(16px, 2.5vw, 32px) 40px;
    box-sizing: border-box;
    overflow-y: auto;
    height: calc(100vh - 12px);
    margin: 12px 0 0 0;
    border-radius: 16px 0 0 0;
    border-top: 1px solid var(--border);
    border-left: 1px solid var(--border);
    border-right: none;
    border-bottom: none;
    background-color: var(--surface-solid);

    /* Fundo quadriculado global */
    background-image: 
        linear-gradient(to right, var(--grid-color, rgba(0, 0, 0, 0.025)) 1px, transparent 1px),
        linear-gradient(to bottom, var(--grid-color, rgba(0, 0, 0, 0.025)) 1px, transparent 1px);
    background-size: 24px 24px;
    --grid-color: rgba(0, 0, 0, 0.025);
}

body.dark-mode .app-main {
    --grid-color: rgba(255, 255, 255, 0.015);
}

/* Cabeçalho da Área de Conteúdo */

.main-content-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 24px;
    flex-shrink: 0;
    min-height: 45px;
}

.header-date {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    color: var(--text3);
}

.header-logo {
    display: flex;
    align-items: center;
}

.header-logo img {
    height: 20px;
    width: auto;
    display: block;
}

/* Botão FAB do Assistente de IA */

.ai-fab {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent2), var(--accent));
    border: none;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 6px 20px rgba(0, 101, 255, 0.4), inset 0 1px 1px rgba(255, 255, 255, 0.25);
    z-index: 99;
    transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.25s ease;
}

.ai-fab svg {
    width: 26px;
    height: 26px;
    transition: transform 0.25s ease;
}

.ai-fab:hover {
    transform: scale(1.08) translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 101, 255, 0.5), inset 0 1px 1px rgba(255, 255, 255, 0.35);
}

.ai-fab:active {
    transform: scale(0.95);
}

/* Botão Voltar para a Workspace */

.btn-back-workspace {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    height: 32px;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text2);
    padding: 0 12px;
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.btn-back-workspace svg {
    width: 14px;
    height: 14px;
    transition: transform 0.2s ease;
}

.btn-back-workspace:hover {
    background: var(--surface3-solid);
    border-color: var(--accent);
    color: var(--text);
    transform: translateX(-2px);
}

.btn-back-workspace:hover svg {
    transform: translateX(-1px);
}

body.light-mode .btn-back-workspace {
    background: #ffffff;
}

body.light-mode .btn-back-workspace:hover {
    background: var(--surface2-solid);
}

/* Responsividade */

@media (max-width: 980px) {
    #app {
        grid-template-columns: 1fr;
    }
    
    .app-sidebar {
        position: fixed;
        left: -240px;
        top: 0;
        bottom: 0;
        width: 240px;
        height: 100vh;
        box-shadow: var(--shadow-xl);
    }
    
    body.sidebar-open .app-sidebar {
        left: 0;
    }
    
    .app-main {
        height: 100vh;
        padding-top: 80px;
        margin: 0;
        border-radius: 0;
        border: none;
        width: 100%;
    }
}

.filter-bar {
    display: flex;
    flex-wrap: wrap;
    overflow: visible;
    gap: 12px 14px;
    background: var(--surface);
    backdrop-filter: blur(14px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 26px;
    align-items: flex-end;
    box-shadow: var(--shadow-sm);
    position: relative;
    z-index: 20;
    transition: max-height 0.3s ease, opacity 0.25s ease, padding 0.3s ease, margin-bottom 0.3s ease;
    max-height: 500px;
}

body.filters-collapsed .filter-bar {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin-bottom: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

.filter-bar::-webkit-scrollbar {
    height: 8px;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
    min-width: 136px;
}

.filter-group-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.filter-group label {
    font-family: var(--font-display);
    font-size: 11px;
    font-weight: 600;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0;
}

.btn-acum {
    min-height: 18px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 8px;
    color: var(--text3);
    cursor: pointer;
    padding: 1px 6px;
    font-family: var(--font-mono);
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.btn-acum:hover {
    border-color: var(--text2);
    color: var(--text);
}

.btn-acum.active {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-contrast);
    font-weight: bold;
}

.filter-group select,
.filter-group input {
    min-height: var(--control-h);
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 13px;
    padding: 0 10px;
    border-radius: var(--radius-sm);
    outline: none;
    cursor: pointer;
    width: 100%;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

body.light-mode .filter-group select,
body.light-mode .filter-group input {
    background: #ffffff;
}

.filter-group select:hover,
.filter-group input:hover {
    background: var(--surface3-solid);
    border-color: var(--border-strong);
}

.filter-group select:focus,
.filter-group input:focus {
    border-color: var(--accent);
    box-shadow: var(--focus-ring);
}

#btn-rope {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: var(--control-h);
    width: 100%;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 0 12px;
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

#btn-rope:hover {
    background: var(--surface3-solid);
    border-color: var(--accent);
    transform: translateY(-1px);
}

#btn-rope svg {
    width: 13px;
    height: 13px;
    flex: 0 0 auto;
}

.multi-select-wrap {
    position: relative;
    width: 100%;
}

.multi-select-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: var(--control-h);
    width: 100%;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 13px;
    padding: 0 8px 0 10px;
    border-radius: var(--radius-sm);
    outline: none;
    cursor: pointer;
    gap: 4px;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.multi-select-trigger:hover {
    background: var(--surface3-solid);
    border-color: var(--border-strong);
}

.multi-select-wrap.open .multi-select-trigger,
.multi-select-trigger:focus {
    border-color: var(--accent);
    box-shadow: var(--focus-ring);
}

.multi-select-trigger.ms-active {
    border-color: var(--accent);
    background: var(--accent-glow);
}

.ms-label {
    flex: 1;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.ms-label.ms-has-selection {
    color: var(--accent);
    font-weight: 600;
}

.ms-chevron {
    width: 14px;
    height: 14px;
    flex: 0 0 auto;
    color: var(--text3);
    transition: transform 0.2s ease;
}

.multi-select-wrap.open .ms-chevron {
    transform: rotate(180deg);
}

.multi-select-dropdown {
    display: none;
    position: fixed;
    min-width: 200px;
    max-height: 280px;
    background: var(--surface-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-lg);
    z-index: 10000;
    overflow: hidden;
    animation: msSlideIn 0.15s ease;
}

@keyframes msSlideIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.ms-actions {
    display: flex;
    gap: 0;
    position: relative;
    padding: 0;
}

.ms-actions::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--border);
    transform: scaleY(0.5);
    transform-origin: bottom;
}

.ms-action {
    flex: 1;
    padding: 7px 10px;
    background: none;
    border: none;
    color: var(--accent);
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease;
    text-align: center;
}

.ms-action:hover {
    background: var(--accent-glow);
}

.ms-action + .ms-action {
    position: relative;
    border-left: none;
}

.ms-action + .ms-action::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--border);
    transform: scaleX(0.5);
    transform-origin: left;
}

.ms-options-list {
    overflow-y: auto;
    max-height: 220px;
    padding: 4px 0;
    scrollbar-width: thin;
}

.ms-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    margin: 3px 6px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-family: var(--font-body);
    color: var(--text);
    transition: background 0.12s ease, color 0.12s ease;
    user-select: none;
}

.ms-option:hover {
    background: var(--border);
}

.ms-option input[type="checkbox"] {
    display: none;
}

.ms-check {
    display: none;
}

.ms-option input:checked ~ .ms-check {
    background: var(--accent);
    border-color: var(--accent);
}

.ms-option input:checked ~ .ms-check::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 4.5px;
    width: 5px;
    height: 8px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.ms-option-label {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ms-option.checked {
    font-weight: 600;
    color: var(--accent);
    background: var(--accent-glow);
}

.ss-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    margin: 3px 6px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-family: var(--font-body);
    color: var(--text);
    transition: background 0.12s ease, color 0.12s ease;
    user-select: none;
}

.ss-option:hover {
    background: var(--border);
}

.ss-dot {
    display: none;
}

.ss-option.ss-active .ss-dot {
    border-color: var(--accent);
}

.ss-option.ss-active .ss-dot::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
}

.ss-option.ss-active {
    font-weight: 600;
    color: var(--accent);
    background: var(--accent-glow);
}

.ms-options-list .ss-option:first-child {
    margin-bottom: 6px;
    position: relative;
}

.ms-options-list .ss-option:first-child::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 4px;
    right: 4px;
    height: 1px;
    background: var(--border);
    transform: scaleY(0.5);
    transform-origin: bottom;
}

@media (max-width: 760px) {
    .filter-bar {
        border-radius: var(--radius);
        margin-inline: -4px;
        padding: 12px;
    }

    .filter-group {
        min-width: 148px;
    }

    .multi-select-dropdown {
        min-width: 160px;
    }
}

.page {
    display: none;
}

.page.active {
    display: block;
    animation: fadeIn 0.4s ease;
}

.page.is-page-loading,
.page.is-page-revealing,
.page.is-page-refreshing {
    border-radius: var(--radius-sm);
    overflow: hidden;
    position: relative;
}

.page.is-page-loading,
.page.is-page-revealing {
    min-height: clamp(360px, calc(100vh - 210px), 720px);
}

.page.is-page-loading > * {
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
}

.page.is-page-revealing > * {
    animation: pageContentReveal 0.42s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.page.is-page-loading::before,
.page.is-page-revealing::before {
    background: var(--bg);
    border: 1px solid color-mix(in srgb, var(--border) 58%, transparent);
    border-radius: inherit;
    content: '';
    inset: 0;
    opacity: 1;
    pointer-events: none;
    position: absolute;
    transition: opacity 0.38s ease, filter 0.38s ease;
    z-index: 20;
}

.page.is-page-loading::after,
.page.is-page-revealing::after {
    align-items: center;
    animation: pageLoadingPulse 1.2s ease-in-out infinite;
    color: var(--text2);
    content: attr(data-loading-message);
    display: inline-flex;
    font-family: var(--font-display);
    font-size: 14px;
    font-weight: 700;
    gap: 10px;
    left: 50%;
    letter-spacing: 0;
    line-height: 1.2;
    padding-top: 34px;
    position: absolute;
    text-align: center;
    top: 46%;
    transform: translate(-50%, -50%);
    transition: opacity 0.24s ease, transform 0.32s ease;
    white-space: nowrap;
    z-index: 21;
}

.page.is-page-revealing::before {
    filter: blur(6px);
    opacity: 0;
}

.page.is-page-revealing::after {
    animation: none;
    opacity: 0;
    transform: translate(-50%, calc(-50% - 6px));
}

.page.is-page-refreshing::before {
    animation: pageRefreshSweep 0.9s ease-in-out infinite;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    content: '';
    height: 2px;
    left: -35%;
    opacity: 0.72;
    pointer-events: none;
    position: absolute;
    right: auto;
    top: 0;
    width: 35%;
    z-index: 18;
}

.page.is-page-refreshing > * {
    transition: opacity 0.18s ease;
}

.page-error-state {
    align-content: center;
    background: #03050a;
    border: 1px solid color-mix(in srgb, var(--danger) 28%, var(--border));
    border-radius: var(--radius-sm);
    display: grid;
    justify-items: start;
    min-height: clamp(360px, calc(100vh - 210px), 720px);
    padding: clamp(22px, 4vw, 42px);
}

.page-error-kicker {
    color: var(--danger);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.7px;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.page-error-state h2 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(22px, 3vw, 34px);
    line-height: 1.08;
    margin: 0 0 10px;
}

.page-error-state p {
    color: var(--text2);
    margin: 0 0 18px;
    max-width: 560px;
}

@keyframes pageLoadingPulse {
    0%, 100% {
        opacity: 0.62;
    }

    50% {
        opacity: 1;
    }
}

@keyframes pageContentReveal {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

@keyframes pageRefreshSweep {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(385%);
    }
}

#filter-bar[hidden] {
    display: none !important;
}

.section-title {
    font-family: var(--font-display);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.7px;
    text-transform: uppercase;
    color: var(--text2);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.section-title::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-glow);
}

.converted-tag {
    font-size: 9px;
    background: var(--success);
    color: white;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 8px;
    font-weight: bold;
    display: inline-flex;
    align-items: center;
}

.commercial-tag-list {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-left: 2px;
}

.lead-modal-title + .commercial-tag-list {
    margin-left: 0;
    margin-top: 8px;
}

.commercial-tag-badge {
    align-items: center;
    border: 1px solid currentColor;
    border-radius: 4px;
    display: inline-flex;
    font-size: 9px;
    font-weight: 800;
    gap: 4px;
    height: 20px;
    letter-spacing: 0;
    line-height: 1;
    padding: 0 6px;
    text-transform: uppercase;
    white-space: nowrap;
}

.commercial-tag-badge svg {
    flex: 0 0 auto;
    height: 12px;
    width: 12px;
}

.commercial-tag-badge.hot {
    background: rgba(249, 115, 22, 0.12);
    border-color: rgba(249, 115, 22, 0.36);
    color: #fb923c;
}

.commercial-tag-badge.warm {
    background: rgba(245, 158, 11, 0.11);
    border-color: rgba(245, 158, 11, 0.34);
    color: #fbbf24;
}

.commercial-tag-badge.cold {
    background: rgba(56, 189, 248, 0.12);
    border-color: rgba(56, 189, 248, 0.34);
    color: #38bdf8;
}

.commercial-tag-kpi-band {
    display: grid;
    gap: clamp(8px, 1.2vw, 16px);
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

#aprovados-kpi-row,
#leads-kpi-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

#formalizados-kpi-row,
#perdidos-kpi-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.commercial-tag-kpi-card {
    min-height: 96px;
}

.commercial-tag-kpi-card .kpi-title {
    align-items: center;
    display: inline-flex;
    gap: 6px;
}

.commercial-tag-kpi-card .kpi-title svg {
    flex: 0 0 auto;
    height: 14px;
    width: 14px;
}

.commercial-tag-kpi-card.hot .kpi-title,
.commercial-tag-kpi-card.hot .commercial-tag-kpi-percent {
    color: #fb923c;
}

.commercial-tag-kpi-card.warm .kpi-title,
.commercial-tag-kpi-card.warm .commercial-tag-kpi-percent {
    color: #fbbf24;
}

.commercial-tag-kpi-card.cold .kpi-title,
.commercial-tag-kpi-card.cold .commercial-tag-kpi-percent {
    color: #38bdf8;
}

.commercial-tag-kpi-card.none .kpi-title,
.commercial-tag-kpi-card.none .commercial-tag-kpi-percent {
    color: var(--text3);
}

.commercial-tag-kpi-percent {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
}

.converted-row {
    background: rgba(34, 197, 94, 0.04) !important;
}

.converted-row:hover {
    background: rgba(34, 197, 94, 0.08) !important;
}

.pagination-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 0;
    margin-top: 8px;
    border-top: 1px solid var(--border);
}

.pagination-info {
    font-size: 13px;
    color: var(--text3);
}

.pagination-info strong {
    color: var(--text);
}

.pagination-btns {
    display: flex;
    gap: 8px;
}

.btn-pagination {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-pagination svg {
    width: 14px;
    height: 14px;
}

.btn-pagination:hover:not(:disabled) {
    background: var(--bg-soft);
    border-color: var(--accent);
    color: var(--accent);
}

.btn-pagination:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.funil-source {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    display: inline-flex;
    font-family: var(--font-mono);
    font-size: 10px;
    margin: -4px 0 18px;
    padding: 6px 10px;
}

.funil-source.is-live {
    background: color-mix(in srgb, var(--q1) 12%, transparent);
    border-color: color-mix(in srgb, var(--q1) 32%, var(--border));
    color: var(--q1);
}

.funil-source.is-local {
    background: color-mix(in srgb, var(--warning) 12%, transparent);
    border-color: color-mix(in srgb, var(--warning) 32%, var(--border));
    color: var(--warning);
}

.funil-warning {
    background: color-mix(in srgb, var(--danger) 9%, transparent);
    border: 1px solid color-mix(in srgb, var(--danger) 28%, var(--border));
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 12px;
    margin: -8px 0 18px;
    padding: 10px 12px;
}

.funil-filter-bar {
    align-items: end;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
    margin-bottom: 18px;
    padding: 12px;
}

.funil-filter-bar .funil-filter {
    flex: 1 1 120px;
    min-width: 0;
}

.funil-filter {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.funil-filter span {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.7px;
    text-transform: uppercase;
}

.funil-filter select {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    min-height: var(--control-h);
    outline: none;
    padding: 0 10px;
    width: 100%;
}

.funil-filter-clear {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    cursor: pointer;
    min-height: var(--control-h);
    padding: 0 12px;
}

.funil-filter-clear:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.fg-rope-group {
    min-width: 220px;
}

.fg-rope-controls {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: minmax(54px, 1fr) auto minmax(54px, 1fr) auto;
}

.fg-rope-controls span {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
}

.fg-rope-clear {
    min-height: var(--control-h);
    padding: 0 10px;
}

.fg-rope-clear.active {
    background: var(--accent-glow);
    border-color: var(--accent);
    color: var(--accent);
}

.funil-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(140px, 1fr));
    margin-bottom: 24px;
}

.funil-grid-small {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
}

.funil-grid-financial {
    grid-template-columns: repeat(4, minmax(160px, 1fr));
}

.funil-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    min-height: 108px;
    padding: 16px;
}

.funil-card-label {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.4px;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.funil-card-value {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.05;
}

.funil-card-hint {
    color: var(--text3);
    font-size: 11px;
    margin-top: 8px;
}

.funil-section {
    margin-bottom: 24px;
}

.funil-section-title {
    color: var(--text2);
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.6px;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.funil-loading {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    padding: 18px;
}

.funil-loss-section {
    margin-top: 4px;
}

.funil-loss-card {
    margin-bottom: 18px;
}

.funil-loss-summary {
    align-items: baseline;
    display: flex;
    gap: 10px;
    margin-bottom: 14px;
}

.funil-loss-summary span {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.funil-loss-summary strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 900;
}

.funil-loss-chart-scroll {
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 4px;
}

.funil-loss-chart {
    align-items: end;
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(var(--loss-day-count), minmax(36px, 1fr));
    min-height: 230px;
    min-width: min(100%, calc(var(--loss-day-count) * 44px));
}

.funil-loss-day {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-rows: 18px 1fr 18px;
    height: 230px;
    min-width: 36px;
}

.funil-loss-value {
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
}

.funil-loss-bar {
    align-self: end;
    background: linear-gradient(180deg, var(--q4), color-mix(in srgb, var(--q4) 70%, var(--accent)));
    border-radius: 5px 5px 2px 2px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
    height: var(--bar-height);
    min-height: 8px;
    width: 100%;
}

.funil-loss-label {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
}

.funil-loss-empty {
    align-items: center;
    background: var(--surface2);
    border: 1px dashed var(--border);
    border-radius: var(--radius-sm);
    color: var(--text3);
    display: flex;
    font-size: 12px;
    font-weight: 700;
    justify-content: center;
    min-height: 180px;
    padding: 18px;
    text-align: center;
}

.sales-funnel-filter {
    grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.sales-funnel-layout {
    align-items: stretch;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.75fr);
    margin-bottom: 24px;
}

.sales-funnel-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    padding: clamp(16px, 2vw, 24px);
}

.sales-funnel {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sales-funnel-stage {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(126px, 0.32fr) minmax(0, 1fr) minmax(54px, 0.12fr);
    width: 100%;
}

.sales-funnel-label span,
.sales-funnel-label small {
    display: block;
}

.sales-funnel-label span {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 13px;
    font-weight: 800;
}

.sales-funnel-label small {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 9px;
    margin-top: 2px;
}

.sales-funnel-bar {
    align-items: center;
    background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 86%, #38bdf8), color-mix(in srgb, var(--accent) 62%, var(--q1)));
    border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent);
    clip-path: polygon(0 0, 100% 0, 93% 100%, 7% 100%);
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: center;
    justify-self: center;
    min-height: 68px;
    padding: 10px clamp(18px, 4vw, 44px);
    text-align: center;
    width: var(--stage-width);
}

.sales-funnel-bar strong {
    font-family: var(--font-display);
    font-size: clamp(24px, 4vw, 44px);
    font-weight: 900;
    line-height: 1;
}

.sales-funnel-bar span {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    margin-top: 6px;
    opacity: 0.86;
}

.sales-funnel-share {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
    text-align: right;
}

.sales-funnel-side {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sales-funnel-side .funil-vendas-kpi:last-child {
    grid-column: 1 / -1;
}

.funil-vendas-kpi {
    border-radius: var(--radius-sm);
    min-height: 112px;
}

.conv-blocks {
    display: grid;
    gap: 18px;
}

.conv-supervisor-block {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.conv-table-wrap {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.conv-table {
    border-radius: 0;
}

.conv-table th:not(:first-child),
.conv-table td:not(:first-child) {
    text-align: center;
}

.conv-closer {
    min-width: 240px;
}

.conv-supervisor-row {
    background: color-mix(in srgb, var(--accent) 8%, var(--surface2-solid));
}

.conv-supervisor-row td {
    border-bottom: 1px solid var(--border-strong);
}

.conv-supervisor-row strong {
    color: var(--text);
    display: block;
    font-family: var(--font-display);
    font-size: 15px;
}

.conv-supervisor-row td:first-child small {
    color: var(--text3);
    display: block;
    font-family: var(--font-mono);
    font-size: 10px;
    margin-top: 2px;
}

.conv-cell span {
    color: var(--accent);
    display: block;
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 800;
}

.conv-cell small {
    color: var(--text3);
    display: block;
    font-family: var(--font-mono);
    font-size: 10px;
    margin-top: 2px;
}

.conv-cell.is-empty span {
    color: var(--text3);
}

.origem-kpi-row {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

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

.origem-table-wrap table {
    min-width: 900px;
}

.origem-name-cell {
    font-size: 11px;
    font-weight: 700;
}

.origem-strong-cell {
    font-size: 11px;
    font-weight: 800;
}

.origem-analysis-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 20px;
}

.origem-panel {
    min-width: 0;
}

.origem-compact-table {
    border: none;
    box-shadow: none;
    overflow-x: visible;
    padding: 0;
}

.origem-compact-table table {
    min-width: 0;
    table-layout: fixed;
    width: 100%;
}

.origem-compact-table th,
.origem-compact-table td {
    padding-left: 10px;
    padding-right: 10px;
}

.origem-share-cell {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(90px, 1fr) auto;
}

.origem-share-track {
    background: var(--surface3);
    border-radius: 4px;
    height: 6px;
    overflow: hidden;
}

.origem-share-bar {
    background: var(--accent);
    border-radius: 4px;
    height: 100%;
}

.origem-sim-title {
    margin-top: 12px;
}

.origem-tabs {
    margin-bottom: 14px;
}

.origem-sim-filter {
    margin-bottom: 14px;
    max-width: 360px;
}

.origem-simulation-table table {
    min-width: 620px;
}

.perdidos-kpi-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.perdidos-reason-row {
    align-items: stretch;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-bottom: 20px;
}

.perdidos-reason-select {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    display: grid;
    gap: 8px;
    padding: 14px;
}

.perdidos-reason-select span {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.perdidos-reason-select select {
    appearance: none;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    min-height: var(--control-h);
    outline: none;
    padding: 0 12px;
    width: 100%;
}

.perdidos-reason-kpi {
    margin: 0;
    min-height: 100%;
}

.perdidos-toolbar {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.timeline-dot.danger {
    background: var(--q4);
}

@media (max-width: 1100px) {
    .funil-grid {
        grid-template-columns: repeat(2, minmax(160px, 1fr));
    }

    .sales-funnel-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .funil-grid,
    .funil-grid-small,
    .sales-funnel-side,
    .origem-analysis-grid,
    #aprovados-kpi-row,
    #formalizados-kpi-row,
    #leads-kpi-row,
    #perdidos-kpi-row,
    .commercial-tag-kpi-band,
    .perdidos-kpi-row,
    .perdidos-reason-row {
        grid-template-columns: 1fr;
    }

    .sales-funnel-stage {
        grid-template-columns: 1fr;
    }

    .sales-funnel-label,
    .sales-funnel-share {
        text-align: center;
    }

    .sales-funnel-bar {
        width: 100%;
    }
}

.home-shell {
    display: grid;
    gap: 22px;
}

.home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
    gap: 20px;
    align-items: stretch;
    min-height: 250px;
    padding: clamp(26px, 4vw, 44px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 14%, transparent), transparent 34%),
        linear-gradient(135deg, var(--surface), var(--surface2));
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

.home-hero-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 760px;
}

.home-kicker,
.home-section-label,
.home-status-label,
.home-count {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent);
}

.home-hero h1 {
    margin: 10px 0 12px;
    max-width: 820px;
    font-family: var(--font-display);
    font-size: clamp(34px, 4.8vw, 64px);
    line-height: 0.98;
    letter-spacing: 0;
    color: var(--text);
    overflow-wrap: break-word;
}

.home-hero p {
    margin: 0;
    max-width: 640px;
    color: var(--text2);
    font-size: 16px;
    line-height: 1.65;
}

.home-status-card {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: color-mix(in srgb, var(--surface2) 86%, transparent);
    box-shadow: var(--shadow-sm);
}

.home-status-card {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 10px;
    padding: 22px;
    min-height: 190px;
}

.home-status-card strong {
    font-size: 20px;
    line-height: 1.25;
    color: var(--text);
    overflow-wrap: anywhere;
}

.home-status-card span:last-child {
    color: var(--text2);
    line-height: 1.5;
}

.home-section-header h2 {
    margin: 6px 0 6px;
    font-family: var(--font-display);
    font-size: 24px;
    line-height: 1.15;
    letter-spacing: 0;
}

.home-card-arrow svg,
.home-card-icon svg,
.home-folder-icon svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.home-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    padding-top: 6px;
}

.home-count {
    color: var(--text3);
}

.home-folders {
    display: grid;
    gap: 18px;
}

.home-folder {
    position: relative;
    display: grid;
    gap: 16px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface2) 78%, transparent), var(--surface));
    box-shadow: var(--shadow-sm);
}

.home-folder-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
}

.home-folder-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
    border-radius: var(--radius-xs);
    background: color-mix(in srgb, var(--accent) 9%, transparent);
    color: var(--accent);
}

.home-folder-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.home-folder-title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
}

.home-folder-description {
    color: var(--text2);
    font-size: 12px;
    line-height: 1.45;
}

.home-folder-count {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text2);
    display: inline-flex;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
    justify-content: center;
    min-width: 28px;
    padding: 5px 8px;
}

.home-folder-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(235px, 1fr));
    gap: 12px;
}

.home-folder-shortcuts {
    border-color: var(--border);
}

.home-folder-shortcuts .home-folder-icon,
.home-folder-shortcuts .home-card-icon {
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    background: color-mix(in srgb, var(--accent) 10%, transparent);
    color: var(--accent);
}

.home-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(245px, 1fr));
    gap: 14px;
}

.home-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    min-height: 110px;
    padding: 20px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface-solid);
    color: var(--text);
    text-align: left;
    cursor: pointer;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.02), 0 8px 24px rgba(20, 33, 65, 0.02);
    transition: transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1), border-color 0.22s ease, background 0.22s ease, box-shadow 0.22s ease;
}

.home-card:hover {
    transform: translateY(-2.5px);
    border-color: var(--accent);
    background: var(--surface-solid);
    box-shadow: 0 4px 16px rgba(0, 101, 255, 0.08), 0 16px 36px rgba(0, 101, 255, 0.04);
}

.home-card:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
}

.home-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--border));
    border-radius: 10px;
    background: color-mix(in srgb, var(--accent) 6%, var(--surface-solid));
    color: var(--accent);
    flex-shrink: 0;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.home-card:hover .home-card-icon {
    transform: scale(1.05);
    background: color-mix(in srgb, var(--accent) 10%, var(--surface-solid));
}

.home-card-copy {
    min-width: 0;
}

.home-card-title,
.home-card-description {
    display: block;
}

.home-card-title {
    margin-bottom: 5px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--text);
}

.home-card-description {
    color: var(--text3);
    font-size: 12.5px;
    line-height: 1.5;
}

.home-empty-access {
    grid-column: 1 / -1;
    display: grid;
    gap: 8px;
    padding: 20px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    color: var(--text2);
    line-height: 1.5;
}

.home-empty-access strong {
    color: var(--text);
    font-size: 15px;
}

@media (max-width: 900px) {
    .home-hero {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .home-hero {
        padding: 22px;
        min-height: auto;
    }

    .home-hero h1 {
        font-size: clamp(28px, 9vw, 34px);
        line-height: 1.05;
    }

    .home-hero p {
        font-size: 15px;
    }

    .home-status-card {
        min-height: 160px;
        padding: 20px;
    }

    .home-section-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .home-grid,
    .home-folder-grid {
        grid-template-columns: 1fr;
    }

    .home-folder {
        padding: 16px;
    }

    .home-folder-header {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .home-folder-count {
        grid-column: 2;
        justify-self: start;
    }

    .home-card {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .home-card-arrow {
        grid-column: 2;
        justify-self: start;
        width: auto;
    }
}

/* Nova Home Portal */

.home-portal-container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 12px 0 0 0;
    box-sizing: border-box;
    width: 100%;
}

.home-portal-hero {
    text-align: left;
    max-width: 100%;
    width: 100%;
}

.home-portal-title {
    font-family: var(--font-display);
    font-size: clamp(20px, 2.6vw, 30px);
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 4px 0;
    color: var(--text);
    letter-spacing: -0.5px;
}

.home-portal-subtitle {
    font-family: var(--font-display);
    font-size: clamp(20px, 2.6vw, 30px);
    font-weight: 700;
    margin: 0;
    line-height: 1.25;
    letter-spacing: -0.5px;
    white-space: nowrap;
    display: inline-block;
    padding-bottom: 6px; /* Evita o corte da parte inferior de letras como 'j' e 'g' */

    /* Gradiente azul Locus/Ciano de alto contraste */
    background: linear-gradient(90deg, #00C6FF 0%, #0072FF 60%, #014EDC 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.myview-shell {
    display: grid;
    gap: 20px;
}

.myview-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
    gap: 20px;
    padding: clamp(24px, 4vw, 38px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 13%, transparent), transparent 34%),
        linear-gradient(135deg, var(--surface), var(--surface2));
    box-shadow: var(--shadow-md);
}

.myview-hero h1 {
    margin: 10px 0 12px;
    max-width: 840px;
    font-family: var(--font-display);
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1;
    letter-spacing: 0;
}

.myview-hero p {
    margin: 0;
    max-width: 680px;
    color: var(--text2);
    font-size: 15px;
    line-height: 1.65;
}

.myview-kicker {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent);
}

.myview-profile-card,
.myview-panel,
.myview-metric-card,
.myview-shortcut,
.myview-empty-state {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.myview-profile-card {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 8px;
    padding: 24px;
    min-height: 180px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 15%, var(--surface)), var(--surface));
    border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border));
    box-shadow: 0 8px 32px rgba(0,0,0,0.15), inset 0 1px 0 rgba(255,255,255,0.05);
    border-radius: var(--radius-lg);
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(10px);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.myview-profile-card::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 70%);
    opacity: 0.5;
    pointer-events: none;
}

.myview-profile-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.1);
}

.myview-profile-card span {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent);
    z-index: 1;
}

.myview-profile-card strong {
    color: var(--text);
    font-size: 32px;
    font-family: var(--font-display);
    line-height: 1.1;
    z-index: 1;
    background: linear-gradient(to right, var(--text), var(--text2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.myview-profile-card small {
    color: var(--text2);
    font-size: 13px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.myview-section-head,
.myview-panel-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
}

.myview-section-head h2,
.myview-panel-head h2 {
    margin: 5px 0 0;
    font-family: var(--font-display);
    font-size: 22px;
    letter-spacing: 0;
}

.myview-metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
}

.myview-metric-card {
    display: grid;
    gap: 8px;
    min-height: 136px;
    padding: 18px;
    border: 0;
    box-shadow: 0 8px 32px rgba(0,0,0,0.06), 0 2px 8px rgba(0,0,0,0.04);
}

body.dark-mode .myview-metric-card {
    box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.2);
}

body.true-darkness-mode .myview-metric-card {
    box-shadow: 0 8px 40px rgba(0,0,0,0.6), 0 2px 12px rgba(0,0,0,0.4);
}

.myview-shell .audit-kpi-card {
    border: 0;
}

.myview-shell .audit-kpi-card:hover {
    border-color: transparent;
}

.myview-adherence-card {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--adherence-color, var(--accent)) 14%, transparent), transparent 54%),
        linear-gradient(180deg, var(--surface2), var(--surface));
    box-shadow: var(--shadow-md);
}

.myview-metric-card.myview-adherence-card strong {
    color: var(--adherence-color, var(--accent));
}

.myview-metric-card.myview-adherence-card span {
    color: var(--text);
}

.myview-metric-card span,
.myview-metric-card small {
    color: var(--text2);
    line-height: 1.45;
}

.myview-metric-card strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1;
}

.myview-metric-card em {
    display: inline-flex;
    margin-right: 8px;
    padding: 3px 7px;
    border-radius: var(--radius-xs);
    background: color-mix(in srgb, var(--accent) 14%, transparent);
    color: var(--accent);
    font-style: normal;
    font-size: 11px;
    font-weight: 800;
}

.myview-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
    gap: 16px;
}

.myview-panel {
    display: grid;
    gap: 16px;
    padding: 18px;
}

.myview-panel-copy {
    margin: 6px 0 0;
    color: var(--text2);
    font-size: 13px;
    line-height: 1.5;
}

.myview-quality-adherence {
    margin-top: 4px;
}

.myview-adherence-list {
    display: grid;
    gap: 8px;
}

.myview-adherence-row {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(150px, 180px) minmax(260px, 420px);
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface2);
}

.myview-quality-adherence.has-audit-type-tab .myview-adherence-row {
    grid-template-columns: minmax(180px, 1fr) minmax(138px, 170px) minmax(138px, 170px) minmax(150px, 190px);
}

.myview-quality-adherence.has-sdr-monitoring .myview-adherence-row {
    grid-template-columns: minmax(180px, 1fr) minmax(138px, 170px) minmax(138px, 170px) minmax(150px, 190px);
}

.myview-quality-adherence.has-sdr-monitoring.has-audit-type-tab .myview-adherence-row {
    grid-template-columns: minmax(180px, 1fr) repeat(4, minmax(128px, 170px));
}

.myview-adherence-row strong {
    min-width: 0;
    overflow: hidden;
    color: var(--text);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.myview-adherence-row-head {
    background: transparent;
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.myview-adherence-inline {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    min-width: 0;
}

.myview-adherence-inline small {
    color: var(--text3);
    font-size: 11px;
    white-space: nowrap;
}

.myview-audit-tabs-wrap {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: space-between;
}

.myview-audit-tabs {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px;
}

.myview-audit-tabs button {
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-xs);
    color: var(--text2);
    cursor: pointer;
    font-size: 12px;
    font-weight: 800;
    min-height: 32px;
    padding: 0 10px;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.myview-audit-tabs button:hover,
.myview-audit-tabs button.active {
    background: color-mix(in srgb, var(--accent) 10%, var(--surface));
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    color: var(--accent);
}

.myview-audit-tab-summary {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    gap: 10px;
    min-height: 44px;
    padding: 8px 12px;
}

.myview-audit-tab-summary > span {
    color: var(--text2);
    font-size: 12px;
    font-weight: 800;
}

.myview-insight-list,
.myview-shortcuts {
    display: grid;
    gap: 10px;
}

.myview-insight-item {
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface2);
}

.myview-insight-item.severity-critical {
    border-color: rgba(239, 68, 68, 0.32);
    background: rgba(239, 68, 68, 0.08);
}

.myview-insight-item.severity-attention {
    border-color: rgba(251, 113, 133, 0.32);
    background: rgba(251, 113, 133, 0.08);
}

.myview-insight-item.severity-highlight {
    border-color: rgba(34, 197, 94, 0.32);
    background: rgba(34, 197, 94, 0.08);
}

.myview-insight-item strong {
    color: var(--text);
}

.myview-insight-item p,
.myview-insight-item span {
    display: block;
    margin: 6px 0 0;
    color: var(--text2);
    line-height: 1.5;
}

.myview-insight-item span {
    color: var(--text3);
    font-size: 12px;
}

.myview-shortcut {
    display: grid;
    gap: 5px;
    padding: 14px;
    color: var(--text);
    text-align: left;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.myview-shortcut:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    background: var(--surface2);
}

.myview-shortcut span,
.myview-empty {
    color: var(--text2);
    line-height: 1.45;
}

.myview-highlight-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 18px;
    color: var(--text2);
    line-height: 1.55;
}

.myview-empty-state {
    padding: 22px;
    color: var(--text2);
}

.myview-empty-state strong {
    display: block;
    margin-bottom: 6px;
    color: var(--text);
    font-size: 16px;
}

@media (max-width: 900px) {
    .myview-hero,
    .myview-layout {
        grid-template-columns: 1fr;
    }

    .myview-adherence-row {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .myview-adherence-row-head {
        display: none;
    }

    .myview-adherence-inline {
        justify-content: flex-start;
    }
}

.settings-shell {
    display: flex;
    flex-direction: column;
    gap: 20px;
    
    /* Variáveis globais para cantos arredondados sutis nas configurações */
    --radius-lg: 12px;
    --radius: 8px;
    --radius-sm: 6px;
}

/* Novo Cabeçalho da Configuração */

.settings-header-new {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    width: 100%;
}

.settings-header-new h1 {
    font-family: var(--font-display);
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    color: var(--text);
    margin: 0;
}

/* Novas Abas */

.settings-tabs-new {
    display: flex;
    gap: 4px;
    background: var(--surface2-solid, #f1f5f9);
    padding: 4px;
    border-radius: 8px;
    width: fit-content;
    margin-bottom: 20px;
    border: 1px solid var(--border, #e2e8f0);
}

.settings-tab-new-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 6px;
    border: 1px solid transparent;
    background: transparent;
    color: var(--text3, #64748b);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.settings-tab-new-btn .icon {
    width: 14px;
    height: 14px;
}

.settings-tab-new-btn:hover {
    color: var(--text, #0f172a);
}

.settings-tab-new-btn.active {
    background: var(--surface, #ffffff);
    color: var(--text, #0f172a);
    border-color: var(--border-strong, #cbd5e1);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, 0.05));
    font-weight: 600;
}

/* Layout de Grid para os Cards Premium */

.settings-grid-layout {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
    width: 100%;
}

/* Card Premium do Novo Design */

.settings-premium-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: var(--shadow-sm);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    box-sizing: border-box;
    text-align: left;
}

.settings-premium-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    border-bottom: 1px solid var(--border);
    padding-bottom: 16px;
}

.card-simple-title h3 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--text);
}

/* Conteúdo e Grades Internas do Card */

.org-content-section-title {
    font-family: var(--font-display);
    font-size: 13px;
    font-weight: 600;
    color: var(--text3);
    margin: 0 0 16px 0;
}

/* Seletor de Tema Premium com Preview Mockups */

.theme-preview-selector {
    display: flex;
    gap: 20px;
    margin-top: 8px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.theme-preview-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: transform 0.2s ease;
    width: 130px;
}

.theme-preview-card:hover {
    transform: translateY(-2px);
}

.theme-preview-mockup {
    width: 100%;
    height: 80px;
    border-radius: 8px;
    border: 2px solid var(--border);
    position: relative;
    overflow: hidden;
    display: flex;
    transition: all 0.2s ease;
    box-sizing: border-box;
    margin-bottom: 10px;
}

.theme-preview-card.active .theme-preview-mockup {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent), 0 4px 12px rgba(0, 101, 255, 0.12);
}

/* Elementos do Mockup */

.mockup-sidebar {
    width: 30px;
    height: 100%;
    border-right: 1px solid var(--border);
    box-sizing: border-box;
}

.mockup-content {
    flex-grow: 1;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    box-sizing: border-box;
}

.mockup-line {
    height: 6px;
    border-radius: 3px;
    width: 80%;
}

.mockup-line.short {
    width: 50%;
}

/* Light Theme Preview */

.theme-light {
    background: #ffffff;
    border-color: #cbd5e1;
}

.theme-light .mockup-sidebar {
    background: #f8fafc;
    border-color: #e2e8f0;
}

.theme-light .mockup-line {
    background: #e2e8f0;
}

/* Dark Theme Preview */

.theme-dark {
    background: #0b0f19;
    border-color: #1f2937;
}

.theme-dark .mockup-sidebar {
    background: #111827;
    border-color: #1f2937;
}

.theme-dark .mockup-line {
    background: #374151;
}

/* Auto Theme Preview (Split) */

.theme-auto {
    background: #0b0f19;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-color: var(--border);
}

.theme-split-left {
    background: #ffffff;
    border-right: 1px solid #e2e8f0;
    position: relative;
    height: 100%;
}

.theme-split-left .mockup-sidebar {
    background: #f8fafc;
    border-color: #e2e8f0;
    width: 100%;
    height: 100%;
}

.theme-split-right {
    background: #0b0f19;
    height: 100%;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    box-sizing: border-box;
}

.theme-split-right .mockup-line {
    background: #374151;
}

/* Label & Radio */

.theme-preview-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text2);
    transition: color 0.2s ease;
}

.theme-preview-card.active .theme-preview-label {
    color: var(--accent);
    font-weight: 600;
}

.theme-radio-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid var(--border);
    display: inline-block;
    position: relative;
    box-sizing: border-box;
    background: var(--surface);
}

.theme-preview-card.active .theme-radio-dot {
    border-color: var(--accent);
    background: var(--accent);
}

.theme-preview-card.active .theme-radio-dot::after {
    content: '';
    position: absolute;
    left: 3px;
    top: 3px;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #ffffff;
}

/* True Darkness Premium */

.settings-true-darkness-premium {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 16px;
    border-top: 1px solid var(--border);
    gap: 16px;
}

.settings-true-darkness-premium.is-disabled {
    opacity: 0.5;
    pointer-events: none;
}

.darkness-desc-block {
    text-align: left;
}

.darkness-desc-block strong {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    display: block;
    margin-bottom: 2px;
}

.darkness-desc-block p {
    margin: 0;
    font-size: 11px;
    color: var(--text3);
    line-height: 1.4;
}

.settings-panel {
    display: grid;
    gap: 16px;
}

.settings-card {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: grid;
    gap: 18px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding: clamp(18px, 2.4vw, 24px);
}

.settings-card-stacked {
    align-items: start;
    grid-template-columns: auto minmax(0, 1fr);
}

.settings-card-stacked .settings-header-editor,
.settings-card-stacked .settings-sidebar-editor,
.settings-card-stacked .settings-density-editor,
.settings-card-stacked .settings-user-palette {
    grid-column: 1 / -1;
}

.settings-card-icon {
    align-items: center;
    background: var(--accent-glow);
    border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
    border-radius: var(--radius-sm);
    color: var(--accent);
    display: inline-flex;
    height: 48px;
    justify-content: center;
    width: 48px;
}

.settings-card-icon .icon {
    height: 22px;
    width: 22px;
}

.settings-card-kicker {
    color: var(--text3);
    display: block;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.7px;
    margin-bottom: 4px;
    text-transform: uppercase;
}

.settings-card h2 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 20px;
    line-height: 1.2;
    margin: 0 0 4px;
}

.settings-card p {
    color: var(--text2);
    font-size: 13px;
    margin: 0;
}

.settings-header-editor {
    display: grid;
    gap: 14px;
    width: 100%;
}

.settings-header-logo-segment {
    --logo-count: 3;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    display: grid;
    grid-template-columns: repeat(3, minmax(96px, 1fr));
    min-height: 42px;
    overflow: hidden;
    padding: 4px;
    position: relative;
    width: min(100%, 420px);
}

.settings-header-logo-segment > i {
    background: var(--accent);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    height: calc(100% - 8px);
    left: 4px;
    position: absolute;
    top: 4px;
    transform: translateX(calc(var(--logo-index) * 100%));
    transition: transform 0.24s cubic-bezier(0.4, 0, 0.2, 1);
    width: calc((100% - 8px) / 3);
}

.settings-header-logo-segment button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 999px;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    justify-content: center;
    min-height: 34px;
    padding: 0 10px;
    position: relative;
    transition: color 0.18s ease;
    z-index: 1;
}

.settings-header-logo-segment button.active {
    color: var(--accent-contrast);
}

.settings-sidebar-editor {
    width: 100%;
}

.settings-sidebar-segment {
    --sidebar-count: 4;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    display: grid;
    grid-template-columns: repeat(4, minmax(82px, 1fr));
    min-height: 42px;
    overflow: hidden;
    padding: 4px;
    position: relative;
    width: min(100%, 520px);
}

.settings-sidebar-segment > i {
    background: var(--accent);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    height: calc(100% - 8px);
    left: 4px;
    position: absolute;
    top: 4px;
    transform: translateX(calc(var(--sidebar-index) * 100%));
    transition: transform 0.24s cubic-bezier(0.4, 0, 0.2, 1);
    width: calc((100% - 8px) / var(--sidebar-count));
}

.settings-sidebar-segment button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 999px;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    font-weight: 700;
    gap: 6px;
    justify-content: center;
    min-height: 34px;
    padding: 0 10px;
    position: relative;
    transition: color 0.18s ease;
    z-index: 1;
}

.settings-sidebar-segment button .icon {
    width: 16px;
    height: 16px;
}

.settings-sidebar-segment button.active {
    color: var(--accent-contrast);
}

.settings-density-editor {
    width: 100%;
}

.settings-density-segment {
    --density-count: 3;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    display: grid;
    grid-template-columns: repeat(3, minmax(94px, 1fr));
    min-height: 42px;
    overflow: hidden;
    padding: 4px;
    position: relative;
    width: min(100%, 420px);
}

.settings-density-segment > i {
    background: var(--accent);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    height: calc(100% - 8px);
    left: 4px;
    position: absolute;
    top: 4px;
    transform: translateX(calc(var(--density-index) * 100%));
    transition: transform 0.24s cubic-bezier(0.4, 0, 0.2, 1);
    width: calc((100% - 8px) / var(--density-count));
}

.settings-density-segment button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 999px;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    font-weight: 700;
    gap: 6px;
    justify-content: center;
    min-height: 34px;
    padding: 0 10px;
    position: relative;
    transition: color 0.18s ease;
    z-index: 1;
}

.settings-density-segment button .icon {
    height: 16px;
    width: 16px;
}

.settings-density-segment button.active {
    color: var(--accent-contrast);
}

.settings-header-count {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text3);
    font-size: 12px;
}

.settings-header-count strong {
    color: var(--text);
    font-family: var(--font-mono);
}

.settings-header-button-list {
    display: grid;
    gap: 8px;
}

.settings-header-preview {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 56px;
    padding: 10px;
}

.settings-header-preview-button {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    cursor: grab;
    display: inline-flex;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, color 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
}

.settings-header-preview-button .icon {
    height: 16px;
    width: 16px;
}

.settings-header-preview-button span {
    font-size: 12px;
    font-weight: 800;
}

.settings-header-preview-button:hover,
.settings-header-preview-button.is-drop-target {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    color: var(--accent);
    transform: translateY(-1px);
}

.settings-header-preview-button.is-dragging {
    box-shadow: var(--shadow-md);
    cursor: grabbing;
    opacity: 0.56;
}

.settings-header-button-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-height: 48px;
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    background: var(--surface2);
}

.settings-header-button-row.is-disabled {
    opacity: 0.62;
}

.settings-header-button-name {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    color: var(--text);
    font-weight: 700;
}

.settings-header-button-name .icon {
    color: var(--text3);
    flex: 0 0 auto;
    height: 17px;
    width: 17px;
}

.settings-header-button-name span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.settings-header-button-name em {
    padding: 3px 7px;
    border-radius: var(--radius-xs);
    background: color-mix(in srgb, var(--accent) 14%, transparent);
    color: var(--accent);
    font-size: 10px;
    font-style: normal;
    text-transform: uppercase;
}

.settings-header-button-name .settings-header-badge-ai {
    background: color-mix(in srgb, #8ab4f8 16%, transparent);
    color: #8ab4f8;
}

.settings-user-palette {
    width: 100%;
}

.settings-user-palette-grid {
    grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));
    max-width: 420px;
}

.settings-user-color-preset.is-default {
    align-items: center;
    background:
        linear-gradient(135deg, var(--global-accent, var(--accent)) 0 50%, color-mix(in srgb, var(--global-accent, var(--accent)) 62%, #ffffff) 50% 100%);
    color: var(--accent-contrast);
    display: inline-flex;
    font-size: 10px;
    font-weight: 900;
    justify-content: center;
}

.settings-user-color-preset.is-default span {
    background: color-mix(in srgb, #000 26%, transparent);
    border-radius: 999px;
    padding: 2px 6px;
}

.settings-header-toggle-control {
    background: var(--surface3);
    border: 1px solid var(--border);
    border-radius: 999px;
    cursor: pointer;
    height: 28px;
    padding: 3px;
    position: relative;
    transition: background 0.18s ease, border-color 0.18s ease, opacity 0.18s ease;
    width: 50px;
}

.settings-header-toggle-control span {
    background: var(--surface-solid);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    display: block;
    height: 20px;
    transform: translateX(0);
    transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
    width: 20px;
}

.settings-header-toggle-control.active {
    background: var(--accent);
    border-color: var(--accent);
}

.settings-header-toggle-control.active span {
    transform: translateX(20px);
}

.settings-header-toggle-control:disabled {
    cursor: not-allowed;
    opacity: 0.52;
}

.settings-header-toggle-control.active:disabled {
    opacity: 0.86;
}

.settings-theme-control {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.settings-theme-current {
    color: var(--text2);
    font-size: 12px;
}

.settings-theme-current strong {
    color: var(--text);
}

.settings-switch {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text3);
    cursor: pointer;
    display: grid;
    gap: 4px;
    grid-template-columns: 28px 38px 28px;
    height: 38px;
    padding: 4px;
    position: relative;
}

.settings-switch span {
    align-items: center;
    display: inline-flex;
    height: 28px;
    justify-content: center;
    position: relative;
    z-index: 1;
}

.settings-switch i {
    background: var(--accent);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    height: 28px;
    left: 4px;
    position: absolute;
    top: 4px;
    transform: translateX(0);
    transition: transform 0.2s ease;
    width: 28px;
}

.settings-switch.active i {
    transform: translateX(70px);
}

.settings-users-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 14px;
    align-items: flex-end;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: 16px;
    margin-bottom: 0;
    max-height: none;
    overflow: visible;
}

.settings-search {
    align-items: center;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text3);
    display: flex;
    gap: 8px;
    min-height: var(--control-h);
    padding: 0 12px;
}

.settings-search input {
    background: transparent;
    border: 0;
    color: var(--text);
    min-width: 0;
    outline: 0;
    width: 100%;
}

.settings-field input,
.settings-field select {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    min-height: var(--control-h);
    outline: 0;
    padding: 0 12px;
    width: 100%;
}

.settings-users-summary {
    align-items: baseline;
    color: var(--text2);
    display: flex;
    gap: 6px;
    padding-inline: 2px;
}

.settings-users-summary strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 22px;
}

.settings-users-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

.settings-user-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.settings-user-card:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

.settings-user-card.is-inactive {
    opacity: 0.7;
}

.settings-user-head {
    align-items: center;
    display: flex;
    flex: 1;
    gap: 12px;
    min-width: 0;
}

.settings-user-avatar {
    align-items: center;
    background: var(--accent-glow);
    border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
    border-radius: 50%;
    color: var(--accent);
    display: inline-flex;
    flex-shrink: 0;
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 800;
    height: 38px;
    justify-content: center;
    width: 38px;
}

.settings-user-title {
    min-width: 0;
    flex: 1;
}

.settings-user-title h3 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
    line-height: 1.2;
    margin: 0 0 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.settings-user-title span {
    color: var(--text3);
    display: block;
    font-size: 11px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.settings-user-permission {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text2);
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.3px;
    padding: 3px 8px;
    text-transform: uppercase;
    white-space: nowrap;
}

.settings-status-badge {
    border: 1px solid currentColor;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
    padding: 5px 9px;
    white-space: nowrap;
}

.settings-status-badge.is-active {
    background: color-mix(in srgb, var(--success) 12%, transparent);
    color: var(--success);
}

.settings-status-badge.is-inactive {
    background: color-mix(in srgb, var(--danger) 10%, transparent);
    color: var(--danger);
}

.settings-user-grid {
    border-bottom: 1px solid var(--border);
    border-top: 1px solid var(--border);
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 14px 0;
}

.settings-user-field {
    min-width: 0;
}

.settings-user-field span {
    color: var(--text3);
    display: block;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
    text-transform: uppercase;
}

.settings-user-field strong {
    color: var(--text);
    display: block;
    font-size: 12px;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.settings-user-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.settings-user-actions .btn-ui {
    gap: 7px;
}

.settings-alert {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 13px;
    padding: 12px 14px;
}

.settings-alert-success {
    background: color-mix(in srgb, var(--success) 10%, transparent);
    border-color: color-mix(in srgb, var(--success) 30%, var(--border));
    color: var(--success);
}

.settings-alert-error {
    background: color-mix(in srgb, var(--danger) 9%, transparent);
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
    color: var(--danger);
}

.settings-alert-warning {
    background: color-mix(in srgb, var(--warning) 10%, transparent);
    border-color: color-mix(in srgb, var(--warning) 30%, var(--border));
    color: var(--warning);
}

.settings-loading {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    color: var(--text2);
    display: flex;
    gap: 10px;
    padding: 24px;
}

.settings-loading span {
    animation: settingsSpin 0.8s linear infinite;
    border: 2px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    height: 18px;
    width: 18px;
}

.settings-modal-head {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.settings-user-form {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.settings-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.settings-field span {
    color: var(--text3);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.settings-form-actions {
    grid-column: 1 / -1;
}

.settings-form-actions .btn-ui:disabled {
    cursor: wait;
    opacity: 0.72;
    transform: none;
}

@keyframes settingsSpin {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 980px) {
    .settings-users-toolbar {
        flex-direction: column;
    }

    .settings-search-group {
        min-width: 0;
        width: 100%;
    }

    .settings-new-user {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 720px) {
    .settings-card {
        align-items: flex-start;
        grid-template-columns: 1fr;
    }

    .settings-theme-control {
        align-items: flex-start;
        width: 100%;
    }

    .settings-header-button-row {
        grid-template-columns: 1fr;
    }

    .settings-header-logo-segment {
        width: 100%;
    }

    .settings-users-toolbar,
    .settings-user-form {
        grid-template-columns: 1fr;
    }

    .settings-user-head {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .settings-status-badge {
        grid-column: 1 / -1;
        justify-self: flex-start;
    }

    .settings-user-grid {
        grid-template-columns: 1fr;
    }

    .settings-users-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .settings-tabs {
        width: 100%;
    }

    .settings-tab {
        flex: 1;
        justify-content: center;
    }

    .settings-user-actions .btn-ui {
        width: 100%;
    }
}

.settings-theme-segment {
    --theme-count: 3;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    display: grid;
    grid-template-columns: repeat(3, minmax(86px, 1fr));
    min-height: 42px;
    overflow: hidden;
    padding: 4px;
    position: relative;
    width: min(100%, 360px);
}

.settings-theme-segment > i {
    background: var(--accent);
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    height: calc(100% - 8px);
    left: 4px;
    position: absolute;
    top: 4px;
    transform: translateX(calc(var(--theme-index) * 100%));
    transition: transform 0.24s cubic-bezier(0.4, 0, 0.2, 1);
    width: calc((100% - 8px) / 3);
}

.settings-theme-segment button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 999px;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    gap: 6px;
    justify-content: center;
    min-height: 34px;
    padding: 0 10px;
    position: relative;
    transition: color 0.18s ease;
    z-index: 1;
}

.settings-theme-segment button.active {
    color: var(--accent-contrast);
}

.settings-true-darkness {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
    max-width: 360px;
    padding: 12px 14px;
    width: min(100%, 360px);
}

.settings-true-darkness strong {
    color: var(--text);
    display: block;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 2px;
}

.settings-true-darkness p {
    color: var(--text2);
    font-size: 12px;
    line-height: 1.35;
}

.settings-true-darkness.is-disabled {
    opacity: 0.68;
}

.settings-true-darkness-switch input:disabled + .slider {
    cursor: not-allowed;
}

.settings-true-darkness-switch input:disabled + .slider:before {
    opacity: 0.7;
}

.settings-search-group {
    flex: 1;
    min-width: 220px;
}

.settings-users-toolbar .settings-new-user {
    gap: 8px;
    min-height: var(--control-h);
    white-space: nowrap;
}

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

.settings-user-avatar {
    height: 36px;
    width: 36px;
}

.settings-status-dot {
    border: 3px solid var(--surface);
    border-radius: 50%;
    box-shadow: 0 0 0 1px var(--border-strong);
    display: inline-flex;
    height: 13px;
    width: 13px;
}

.settings-status-dot.is-active {
    background: var(--success);
}

.settings-status-dot.is-inactive {
    background: var(--danger);
}

.settings-user-grid {
    border: 0;
    gap: 8px 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0;
}

.settings-user-field span {
    font-size: 8px;
    margin-bottom: 1px;
}

.settings-user-field strong {
    font-size: 11px;
    line-height: 1.25;
}

.settings-user-actions {
    align-content: center;
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
}

.settings-icon-action {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text3);
    cursor: pointer;
    display: inline-flex;
    height: 34px;
    justify-content: center;
    min-width: 34px;
    padding: 0;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
    width: 34px;
}

.settings-icon-action:hover {
    background: var(--surface3);
    border-color: var(--border-strong);
    color: var(--accent);
    transform: translateY(-1px);
}

.settings-icon-action.danger:hover {
    border-color: color-mix(in srgb, var(--danger) 45%, var(--border));
    color: var(--danger);
}

.settings-modal-overlay {
    display: flex !important;
    padding: 18px;
}

.settings-user-modal,
.settings-confirm-modal {
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--accent) 5%, var(--surface-elevated)) 0%, var(--surface-elevated) 42%) !important;
    position: relative;
}

.settings-modal-head {
    border-bottom: 1px solid var(--border);
    margin: -2px 0 18px;
    padding-bottom: 16px;
}

.settings-confirm-modal {
    text-align: center;
}

.settings-confirm-icon {
    align-items: center;
    background: var(--accent-glow);
    border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
    border-radius: 50%;
    color: var(--accent);
    display: inline-flex;
    height: 54px;
    justify-content: center;
    margin: 0 auto 16px;
    width: 54px;
}

.settings-confirm-icon.danger {
    background: color-mix(in srgb, var(--danger) 10%, transparent);
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
    color: var(--danger);
}

.btn-ui.danger.filled {
    background: var(--danger);
    border-color: var(--danger);
    color: #ffffff;
}

.settings-user-details {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.settings-detail-field {
    min-width: 0;
}

.settings-detail-label {
    color: var(--text3);
    display: block;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin-bottom: 3px;
    text-transform: uppercase;
}

.settings-detail-value {
    color: var(--text);
    display: block;
    font-size: 14px;
    font-weight: 600;
    overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
    .settings-user-card {
        flex-wrap: wrap;
    }

    .settings-user-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 980px) {
    .settings-users-toolbar {
        flex-direction: column;
    }

    .settings-search-group {
        min-width: 0;
        width: 100%;
    }

    .settings-new-user {
        width: 100%;
        justify-content: center;
    }

    .settings-users-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .settings-theme-segment {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        width: 100%;
    }

    .settings-theme-segment button span {
        display: none;
    }

    .settings-user-details {
        grid-template-columns: 1fr;
    }
}

.settings-permissions-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 14px;
    align-items: center;
    justify-content: space-between;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: 16px;
}

.settings-permissions-toolbar-info {
    align-items: baseline;
    color: var(--text2);
    display: flex;
    gap: 6px;
    font-size: 13px;
}

.settings-permissions-toolbar-info strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 22px;
}

.settings-permissions-toolbar .btn-ui {
    gap: 8px;
    min-height: var(--control-h);
    white-space: nowrap;
}

.settings-badge {
    align-items: center;
    background: var(--accent);
    border-radius: 999px;
    color: var(--accent-contrast);
    display: inline-flex;
    font-size: 10px;
    font-weight: 800;
    height: 20px;
    justify-content: center;
    min-width: 20px;
    padding: 0 5px;
}

.solicitacoes-panel {
    gap: 18px;
}

.solicitacoes-status-tabs {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    padding: 8px;
}

.solicitacoes-status-tabs button {
    align-items: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text2);
    cursor: pointer;
    display: flex;
    gap: 8px;
    justify-content: space-between;
    min-height: 40px;
    padding: 0 12px;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.solicitacoes-status-tabs button:hover,
.solicitacoes-status-tabs button.active {
    background: color-mix(in srgb, var(--accent) 10%, var(--surface2));
    border-color: color-mix(in srgb, var(--accent) 22%, var(--border));
    color: var(--accent);
}

.solicitacoes-status-tabs span {
    font-size: 12px;
    font-weight: 800;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.solicitacoes-status-tabs strong {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 11px;
    min-width: 24px;
    padding: 3px 7px;
    text-align: center;
}

.solicitacoes-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
}

.solicitacao-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: grid;
    gap: 12px;
    padding: 18px;
}

.solicitacao-card-head {
    align-items: flex-start;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.solicitacao-card h3 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 17px;
    line-height: 1.25;
    margin: 0;
}

.solicitacao-priority {
    border: 1px solid currentColor;
    border-radius: 999px;
    color: var(--text3);
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 900;
    padding: 5px 8px;
    text-transform: uppercase;
}

.solicitacao-priority.priority-alta {
    color: var(--warning);
}

.solicitacao-priority.priority-critica {
    color: var(--danger);
}

.solicitacao-priority.priority-baixa {
    color: var(--success);
}

.solicitacao-meta,
.solicitacao-origin,
.solicitacao-card-foot {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.solicitacao-meta span,
.solicitacao-origin span,
.solicitacao-card-foot span {
    color: var(--text3);
    font-size: 11px;
}

.solicitacao-meta span {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text2);
    font-weight: 700;
    padding: 4px 7px;
}

.solicitacao-card p {
    color: var(--text2);
    display: -webkit-box;
    font-size: 13px;
    line-height: 1.5;
    margin: 0;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
}

.solicitacao-last-response {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: grid;
    gap: 4px;
    padding: 10px;
}

.solicitacao-last-response strong {
    color: var(--text);
    font-size: 11px;
}

.solicitacao-last-response span {
    color: var(--text2);
    font-size: 12px;
    line-height: 1.4;
}

.solicitacao-card-foot {
    border-top: 1px solid var(--border);
    justify-content: space-between;
    padding-top: 12px;
}

.solicitacao-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.solicitacao-actions .btn-ui {
    gap: 7px;
}

.solicitacao-action-message {
    margin-top: 12px;
}

.solicitacao-action-message textarea {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font: inherit;
    line-height: 1.45;
    min-height: 110px;
    outline: 0;
    padding: 10px 12px;
    resize: vertical;
    width: 100%;
}

.solicitacao-detail-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.solicitacao-detail-text {
    border-top: 1px solid var(--border);
    margin-top: 14px;
    padding-top: 14px;
}

.solicitacao-detail-text h3 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 14px;
    margin: 0 0 8px;
}

.solicitacao-detail-text p {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
    margin: 0;
    white-space: pre-wrap;
}

.solicitacao-admin-history {
    display: grid;
    gap: 10px;
}

.solicitacao-admin-history-item {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
}

.solicitacao-admin-history-item div {
    display: flex;
    gap: 8px;
    justify-content: space-between;
}

.solicitacao-admin-history-item strong {
    color: var(--text);
    font-size: 12px;
}

.solicitacao-admin-history-item span,
.solicitacao-admin-history-item small {
    color: var(--text3);
    font-size: 11px;
}

.solicitacao-admin-history-item p {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.45;
    margin: 6px 0 0;
}

@media (max-width: 900px) {
    .solicitacoes-status-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .solicitacoes-status-tabs,
    .solicitacao-detail-grid {
        grid-template-columns: 1fr;
    }

    .solicitacoes-grid {
        grid-template-columns: 1fr;
    }
}

.permissions-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 24px;
    align-items: start;
}

@media (max-width: 900px) {
    .permissions-layout {
        grid-template-columns: 1fr;
    }
}

.permissions-sidebar {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    
}

.permissions-sidebar-title {
    color: var(--text3);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    margin: 0;
    padding: 0 8px;
}

.permissions-role-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.permissions-role-item {
    align-items: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text2);
    cursor: pointer;
    display: flex;
    gap: 12px;
    padding: 10px 12px;
    text-align: left;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.permissions-role-item:hover {
    background: var(--surface2);
    color: var(--text);
}

.permissions-role-item.active {
    background: var(--accent-glow);
    border-color: color-mix(in srgb, var(--accent) 30%, transparent);
    color: var(--accent);
}

.permissions-role-item .role-icon {
    display: inline-flex;
    opacity: 0.6;
    transition: opacity 0.2s, transform 0.2s;
}

.permissions-role-item:hover .role-icon,
.permissions-role-item.active .role-icon {
    opacity: 1;
}

.permissions-role-item.active .role-icon {
    transform: scale(1.1);
}

.permissions-role-item .role-icon svg {
    width: 18px;
    height: 18px;
}

.permissions-role-item .role-name {
    flex: 1;
    font-size: 14px;
    font-weight: 600;
}

.role-dirty-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--warning);
    box-shadow: 0 0 0 2px var(--surface);
}

.permissions-role-item.active .role-dirty-dot {
    box-shadow: 0 0 0 2px var(--accent-glow);
}

.permissions-content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.permissions-content-header {
    background: linear-gradient(135deg, var(--surface2) 0%, var(--surface) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: 24px;
}

.permissions-content-header h2 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 24px;
    margin: 0 0 8px;
}

.permissions-content-header h2 span {
    color: var(--accent);
}

.permissions-content-header p {
    color: var(--text2);
    font-size: 14px;
    margin: 0;
}

.permissions-groups-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.permission-group-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.permission-group-card:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-md);
}

.permission-group-card.is-fully-enabled {
    border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}

.permission-group-header {
    align-items: center;
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    padding: 14px 18px;
}

.permission-group-card.is-fully-enabled .permission-group-header {
    background: color-mix(in srgb, var(--accent) 8%, var(--surface2));
}

.permission-group-header h3 {
    color: var(--text);
    font-size: 14px;
    font-weight: 700;
    margin: 0;
}

.permission-group-card.is-fully-enabled .permission-group-header h3 {
    color: var(--accent);
}

.permission-group-count {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text2);
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
}

.permission-group-card.is-fully-enabled .permission-group-count {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-contrast);
}

.permission-group-items {
    display: flex;
    flex-direction: column;
    padding: 8px 0;
}

.permission-item {
    align-items: center;
    display: flex;
    justify-content: space-between;
    padding: 10px 18px;
    transition: background 0.15s ease;
}

.permission-item:hover {
    background: var(--surface2);
}

.permission-item-name {
    color: var(--text2);
    font-size: 13px;
    font-weight: 500;
    transition: color 0.15s ease;
}

.permission-item.is-enabled .permission-item-name {
    color: var(--text);
    font-weight: 600;
}

.premium-toggle {
    cursor: pointer;
    display: inline-flex;
    position: relative;
}

.premium-toggle input {
    display: none;
}

.premium-toggle-track {
    background: var(--surface3);
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    height: 22px;
    width: 40px;
    padding: 2px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.1);
}

body.dark-mode .premium-toggle-track {
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.3);
}

.premium-toggle.enabled .premium-toggle-track {
    background: var(--accent);
    border-color: var(--accent);
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.1), 0 0 8px color-mix(in srgb, var(--accent) 40%, transparent);
}

.premium-toggle-thumb {
    background: #ffffff;
    border-radius: 50%;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15), 0 1px 2px rgba(0,0,0,0.1);
    height: 16px;
    width: 16px;
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    position: absolute;
    top: 2px;
    left: 2px;
}

body.dark-mode .premium-toggle-thumb {
    background: var(--text);
    box-shadow: 0 1px 3px rgba(0,0,0,0.5);
}

.premium-toggle.enabled .premium-toggle-thumb {
    transform: translateX(18px);
    background: #ffffff;
}

.premium-toggle:hover .premium-toggle-track {
    border-color: var(--text3);
}

.premium-toggle.enabled:hover .premium-toggle-track {
    filter: brightness(1.1);
}

.settings-permissions-legend {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 16px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 12px;
    color: var(--text2);
    margin-top: 8px;
}

.permission-sub-items {
    padding-left: 24px;
    margin-top: 4px;
    border-left: 2px solid var(--border);
    margin-left: 18px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    opacity: 0.5;
    pointer-events: none;
    transition: all 0.2s ease;
    margin-bottom: 8px;
}

.permission-sub-items.is-parent-enabled {
    opacity: 1;
    pointer-events: auto;
}

.permission-sub-item {
    align-items: center;
    display: flex;
    justify-content: space-between;
    padding: 6px 14px;
    border-radius: var(--radius-sm);
    background: var(--surface2);
}

@media (max-width: 720px) {
    .settings-permissions-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .settings-permissions-toolbar .btn-ui {
        justify-content: center;
    }
}

.settings-control-row {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.settings-select {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 0.6rem 1rem;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    outline: none;
    transition: all 0.2s ease;
    width: 100%;
    max-width: 280px;
}

.settings-select:focus, .settings-select:hover {
    border-color: var(--accent);
}

.toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-switch .slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: var(--surface3);
    transition: .3s;
    border-radius: 24px;
}

.toggle-switch .slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: var(--text);
    transition: .3s;
    border-radius: 50%;
}

.toggle-switch input:checked + .slider {
    background-color: var(--accent);
}

.toggle-switch input:checked + .slider:before {
    transform: translateX(20px);
    background-color: #fff;
}

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

.settings-card .multi-select-wrap {
    min-width: 200px;
    max-width: 280px;
}

.settings-card .multi-select-trigger {
    padding: 0.5rem 0.8rem;
    font-size: 0.9rem;
    border-radius: 8px;
    min-height: 40px;
    background: var(--surface2);
}

.settings-goals-panel {
    gap: 18px;
}

.settings-goals-form {
    display: grid;
    gap: 18px;
}

.settings-goals-toolbar {
    align-items: end;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(160px, 1fr));
    padding: 16px;
}

.settings-goals-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.settings-goal-card,
.settings-goals-summary {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: 18px;
}

.settings-goal-card {
    display: grid;
    gap: 12px;
}

.settings-goal-card h2,
.settings-goals-summary-head h2 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 18px;
    letter-spacing: 0;
    margin: 0;
}

.settings-goal-card input {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 24px;
    font-weight: 800;
    min-height: 54px;
    outline: 0;
    padding: 0 12px;
    width: 100%;
}

.settings-goal-card input:focus,
.settings-goals-toolbar input:focus,
.settings-goals-toolbar select:focus {
    border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}

.settings-goals-summary {
    display: grid;
    gap: 16px;
}

.settings-goals-summary-head {
    align-items: center;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.settings-goal-fallback {
    background: color-mix(in srgb, var(--warning) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--warning) 34%, var(--border));
    border-radius: 999px;
    color: var(--warning);
    font-size: 10px;
    font-weight: 900;
    padding: 5px 9px;
    text-transform: uppercase;
    white-space: nowrap;
}

.settings-goals-summary-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.settings-goal-summary-card {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: grid;
    gap: 8px;
    min-height: 132px;
    padding: 14px;
}

.settings-goal-summary-card span {
    color: var(--text2);
    font-size: 12px;
    font-weight: 800;
}

.settings-goal-summary-card strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1;
}

.settings-goal-summary-card div {
    display: grid;
    gap: 3px;
}

.settings-goal-summary-card small {
    color: var(--text3);
    font-size: 11px;
}

.settings-goals-actions {
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 760px) {
    .settings-goals-toolbar {
        grid-template-columns: 1fr;
    }

    .settings-goals-summary-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .settings-goals-actions .btn-ui {
        justify-content: center;
        width: 100%;
    }
}

.feedback-header-button {
    align-items: center;
    background: var(--accent);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    color: var(--accent-contrast);
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    height: var(--control-h-sm);
    justify-content: center;
    letter-spacing: 0;
    min-width: 88px;
    padding: 0 14px;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
    white-space: nowrap;
}

.feedback-header-button:hover {
    background: color-mix(in srgb, var(--accent) 86%, #ffffff);
    border-color: color-mix(in srgb, var(--accent) 86%, #ffffff);
    color: var(--accent-contrast);
    transform: translateY(-1px);
}

.feedback-header-button:disabled,
.feedback-header-button[aria-disabled="true"],
.feedback-header-button.is-loading {
    cursor: not-allowed;
    opacity: 0.58;
    transform: none;
}

.feedback-header-button:disabled:hover,
.feedback-header-button[aria-disabled="true"]:hover,
.feedback-header-button.is-loading:hover {
    background: var(--accent);
    border-color: var(--accent);
}

.notifications-button {
    position: relative;
}

.notifications-button.has-unread {
    color: var(--accent);
}

.gemini-chat-button {
    border-color: color-mix(in srgb, #8ab4f8 48%, var(--border));
    color: #8ab4f8;
    position: relative;
}

.gemini-chat-button:hover,
.gemini-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #8ab4f8 12%, var(--surface2));
    border-color: color-mix(in srgb, #8ab4f8 64%, var(--border));
    color: #c4d7ff;
}

.openrouter-chat-button {
    border-color: color-mix(in srgb, #14b8a6 50%, var(--border));
    color: #2dd4bf;
    position: relative;
}

.openrouter-chat-button:hover,
.openrouter-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #14b8a6 12%, var(--surface2));
    border-color: color-mix(in srgb, #14b8a6 68%, var(--border));
    color: #99f6e4;
}

.cerebras-chat-button {
    border-color: color-mix(in srgb, #a855f7 50%, var(--border));
    color: #c084fc;
    position: relative;
}

.cerebras-chat-button:hover,
.cerebras-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #a855f7 12%, var(--surface2));
    border-color: color-mix(in srgb, #a855f7 68%, var(--border));
    color: #e9d5ff;
}

.cloudflare-chat-button {
    border-color: color-mix(in srgb, #f59e0b 50%, var(--border));
    color: #fbbf24;
    position: relative;
}

.cloudflare-chat-button:hover,
.cloudflare-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #f59e0b 12%, var(--surface2));
    border-color: color-mix(in srgb, #f59e0b 68%, var(--border));
    color: #fde68a;
}

.mistral-chat-button {
    border-color: color-mix(in srgb, #ff7a1a 50%, var(--border));
    color: #fb923c;
    position: relative;
}

.mistral-chat-button:hover,
.mistral-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #ff7a1a 12%, var(--surface2));
    border-color: color-mix(in srgb, #ff7a1a 68%, var(--border));
    color: #fed7aa;
}

.deepseek-chat-button {
    border-color: color-mix(in srgb, #38bdf8 50%, var(--border));
    color: #7dd3fc;
    position: relative;
}

.deepseek-chat-button:hover,
.deepseek-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #38bdf8 12%, var(--surface2));
    border-color: color-mix(in srgb, #38bdf8 68%, var(--border));
    color: #bae6fd;
}

.openai-chat-button {
    border-color: color-mix(in srgb, #10a37f 50%, var(--border));
    color: #5eead4;
    position: relative;
}

.openai-chat-button:hover,
.openai-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #10a37f 12%, var(--surface2));
    border-color: color-mix(in srgb, #10a37f 68%, var(--border));
    color: #a7f3d0;
}

.claude-chat-button {
    border-color: color-mix(in srgb, #d97706 50%, var(--border));
    color: #fbbf24;
    position: relative;
}

.claude-chat-button:hover,
.claude-chat-button[aria-expanded="true"] {
    background: color-mix(in srgb, #d97706 12%, var(--surface2));
    border-color: color-mix(in srgb, #d97706 68%, var(--border));
    color: #fde68a;
}

.assistant-chat-gemini {
    --assistant-accent: #8ab4f8;
    --assistant-soft: color-mix(in srgb, #8ab4f8 13%, transparent);
    --assistant-strong: #c4d7ff;
}

.assistant-chat-openrouter {
    --assistant-accent: #14b8a6;
    --assistant-soft: color-mix(in srgb, #14b8a6 13%, transparent);
    --assistant-strong: #99f6e4;
}

.assistant-chat-cerebras {
    --assistant-accent: #a855f7;
    --assistant-soft: color-mix(in srgb, #a855f7 13%, transparent);
    --assistant-strong: #e9d5ff;
}

.assistant-chat-cloudflare {
    --assistant-accent: #f59e0b;
    --assistant-soft: color-mix(in srgb, #f59e0b 13%, transparent);
    --assistant-strong: #fde68a;
}

.assistant-chat-mistral {
    --assistant-accent: #ff7a1a;
    --assistant-soft: color-mix(in srgb, #ff7a1a 13%, transparent);
    --assistant-strong: #fed7aa;
}

.assistant-chat-deepseek {
    --assistant-accent: #38bdf8;
    --assistant-soft: color-mix(in srgb, #38bdf8 13%, transparent);
    --assistant-strong: #bae6fd;
}

.assistant-chat-openai {
    --assistant-accent: #10a37f;
    --assistant-soft: color-mix(in srgb, #10a37f 13%, transparent);
    --assistant-strong: #a7f3d0;
}

.assistant-chat-claude {
    --assistant-accent: #d97706;
    --assistant-soft: color-mix(in srgb, #d97706 13%, transparent);
    --assistant-strong: #fde68a;
}

.assistant-chat-overlay {
    background: color-mix(in srgb, var(--modal-overlay-bg) 60%, transparent);
    backdrop-filter: blur(6px);
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: calc(var(--z-dropdown) - 1);
}

.assistant-chat-popover {
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 78%, transparent), color-mix(in srgb, var(--surface) 92%, transparent)),
        color-mix(in srgb, var(--surface-elevated) 88%, transparent);
    backdrop-filter: blur(18px) saturate(1.25);
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 26%, var(--border));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg), 0 18px 48px color-mix(in srgb, var(--assistant-accent) 10%, transparent);
    display: flex;
    flex-direction: column;
    max-height: min(560px, calc(100vh - 86px));
    overflow: hidden;
    position: fixed;
    right: clamp(16px, 2.4vw, 32px);
    top: 58px;
    width: min(430px, calc(100vw - 32px));
    z-index: var(--z-dropdown);
}

.assistant-chat-head {
    align-items: center;
    background: color-mix(in srgb, var(--assistant-accent) 8%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--assistant-accent) 22%, var(--border));
    display: grid;
    gap: 10px;
    grid-template-columns: 30px minmax(0, 1fr) auto;
    padding: 13px 14px;
}

.assistant-chat-title {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.assistant-chat-title strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.assistant-chat-title span {
    color: var(--assistant-accent);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    overflow: hidden;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.assistant-chat-mark {
    height: 28px;
    position: relative;
    width: 28px;
}

.assistant-chat-mark::before,
.assistant-chat-mark::after {
    background: color-mix(in srgb, var(--assistant-accent) 46%, var(--border));
    content: '';
    height: 1px;
    left: 9px;
    position: absolute;
    top: 13px;
    transform-origin: left center;
    width: 16px;
}

.assistant-chat-mark::before {
    transform: rotate(-28deg);
}

.assistant-chat-mark::after {
    transform: rotate(28deg);
}

.assistant-chat-mark span {
    background: var(--surface);
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 58%, var(--border));
    border-radius: 50%;
    display: block;
    height: 8px;
    position: absolute;
    width: 8px;
}

.assistant-chat-mark span:nth-child(1) {
    left: 0;
    top: 10px;
}

.assistant-chat-mark span:nth-child(2) {
    right: 0;
    top: 2px;
}

.assistant-chat-mark span:nth-child(3) {
    bottom: 2px;
    right: 0;
}

.assistant-chat-mark-svg::before,
.assistant-chat-mark-svg::after {
    display: none;
}

.assistant-chat-mark-svg {
    align-items: center;
    display: inline-flex;
    justify-content: center;
}

.assistant-chat-mark-svg svg {
    height: 22px;
    width: 22px;
}

.assistant-chat-actions {
    align-items: center;
    display: inline-flex;
    gap: 4px;
    margin-left: auto;
    min-width: max-content;
}

.assistant-chat-head button {
    align-items: center;
    background: color-mix(in srgb, var(--surface2) 46%, transparent);
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 14%, transparent);
    border-radius: 8px;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    height: 28px;
    justify-content: center;
    padding: 0;
    width: 28px;
}

.assistant-chat-head button:hover {
    background: color-mix(in srgb, var(--assistant-accent) 12%, var(--surface2));
    border-color: color-mix(in srgb, var(--assistant-accent) 34%, var(--border));
    color: var(--text);
}

.assistant-chat-messages {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 8px;
    min-height: 180px;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 12px;
}

.assistant-chat-message {
    align-items: flex-end;
    display: flex;
    gap: 6px;
    max-width: 89%;
    min-width: 0;
}

.assistant-chat-message span {
    background: color-mix(in srgb, var(--surface2) 88%, var(--assistant-accent));
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 14%, var(--border));
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 13px;
    line-height: 1.42;
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
    padding: 9px 10px;
    white-space: pre-wrap;
    word-break: normal;
}

.assistant-chat-message span p {
    margin: 0;
}

.assistant-chat-message span p + p,
.assistant-chat-message span p + .assistant-chat-table-wrap,
.assistant-chat-message span .assistant-chat-table-wrap + p {
    margin-top: 10px;
}

.assistant-chat-message strong {
    color: var(--text);
    font-weight: 800;
}

.assistant-chat-message em {
    color: var(--text);
    font-style: italic;
}

.assistant-chat-message code {
    background: color-mix(in srgb, var(--assistant-accent) 14%, var(--surface));
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 18%, var(--border));
    border-radius: 5px;
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 0.92em;
    padding: 1px 4px;
}

.assistant-chat-table-wrap {
    margin: 8px 0 2px;
    max-width: 100%;
    overflow-x: hidden;
}

.assistant-chat-table {
    border-collapse: collapse;
    font-size: 12px;
    table-layout: fixed;
    width: 100%;
    white-space: normal;
}

.assistant-chat-table th,
.assistant-chat-table td {
    border-bottom: 1px solid color-mix(in srgb, var(--assistant-accent) 16%, var(--border));
    max-width: 0;
    overflow-wrap: anywhere;
    padding: 5px 7px;
    text-align: left;
    word-break: normal;
}

.assistant-chat-table th {
    color: var(--text);
    font-weight: 800;
}

.assistant-chat-table td {
    color: var(--text2);
}

.assistant-chat-message.is-user {
    align-self: flex-end;
    justify-content: flex-end;
}

.assistant-chat-message.is-user .assistant-chat-copy {
    display: none;
}

.assistant-chat-message.is-user span {
    background: color-mix(in srgb, var(--assistant-accent) 13%, var(--surface2));
    border-color: color-mix(in srgb, var(--assistant-accent) 32%, var(--border));
    color: var(--text);
}

.assistant-chat-message.is-assistant {
    align-self: flex-start;
    max-width: 100%;
}

.assistant-chat-copy {
    align-items: center;
    background: color-mix(in srgb, var(--surface2) 72%, transparent);
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 16%, var(--border));
    border-radius: 8px;
    color: var(--text3);
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    height: 26px;
    justify-content: center;
    margin-bottom: 2px;
    opacity: 0;
    padding: 0;
    transition: opacity 0.16s ease, color 0.16s ease, border-color 0.16s ease;
    width: 26px;
}

.assistant-chat-message:hover .assistant-chat-copy,
.assistant-chat-copy:focus-visible,
.assistant-chat-copy.is-copied {
    opacity: 1;
}

.assistant-chat-copy:hover,
.assistant-chat-copy.is-copied {
    border-color: color-mix(in srgb, var(--assistant-accent) 36%, var(--border));
    color: var(--assistant-strong);
}

.assistant-chat-message.is-loading span {
    color: var(--text3);
}

.assistant-chat-form {
    align-items: center;
    border-top: 1px solid color-mix(in srgb, var(--assistant-accent) 20%, var(--border));
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) 38px;
    padding: 10px;
}

.assistant-chat-form textarea {
    background: color-mix(in srgb, var(--surface) 84%, transparent);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-family: inherit;
    font-size: 13px;
    line-height: 1.35;
    max-height: 96px;
    min-height: 46px;
    min-width: 0;
    outline: none;
    overflow-y: hidden;
    padding: 13px 11px;
    resize: none;
}

.assistant-chat-form textarea:focus {
    border-color: var(--border) !important;
    box-shadow: none !important;
}

.assistant-chat-send {
    align-items: center;
    background: color-mix(in srgb, var(--assistant-accent) 18%, var(--surface2));
    border: 1px solid color-mix(in srgb, var(--assistant-accent) 46%, var(--border));
    border-radius: var(--radius-sm);
    color: var(--assistant-strong);
    cursor: pointer;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    padding: 0;
    width: 38px;
}

.assistant-chat-send:disabled {
    cursor: wait;
    opacity: 0.62;
}

.notifications-badge {
    align-items: center;
    background: var(--danger);
    border: 2px solid var(--surface-solid);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 800;
    height: 17px;
    justify-content: center;
    line-height: 1;
    min-width: 17px;
    padding: 0 4px;
    position: absolute;
    right: -6px;
    top: -6px;
}

.notifications-badge[hidden] {
    display: none;
}

.notifications-popover {
    background: var(--surface-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    max-height: min(460px, calc(100vh - 86px));
    overflow: hidden;
    position: fixed;
    right: clamp(16px, 2.4vw, 32px);
    top: 58px;
    width: min(380px, calc(100vw - 32px));
    z-index: var(--z-dropdown);
}

.gemini-chat-popover {
    background: var(--surface-elevated);
    border: 1px solid color-mix(in srgb, #8ab4f8 24%, var(--border));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    max-height: min(560px, calc(100vh - 86px));
    overflow: hidden;
    position: fixed;
    right: clamp(16px, 2.4vw, 32px);
    top: 58px;
    width: min(420px, calc(100vw - 32px));
    z-index: var(--z-dropdown);
}

.gemini-chat-head {
    align-items: center;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    padding: 14px 16px;
}

.gemini-chat-head strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
}

.gemini-chat-head button {
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    height: 30px;
    justify-content: center;
    padding: 0;
    width: 30px;
}

.gemini-chat-head button:hover {
    color: var(--text);
}

.gemini-chat-messages {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 8px;
    min-height: 180px;
    overflow-y: auto;
    padding: 12px;
}

.gemini-chat-message {
    display: flex;
    max-width: 88%;
}

.gemini-chat-message span {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 13px;
    line-height: 1.42;
    padding: 9px 10px;
    white-space: pre-wrap;
}

.gemini-chat-message.is-user {
    align-self: flex-end;
    justify-content: flex-end;
}

.gemini-chat-message.is-user span {
    background: color-mix(in srgb, var(--accent) 14%, var(--surface2));
    border-color: color-mix(in srgb, var(--accent) 26%, var(--border));
    color: var(--text);
}

.gemini-chat-message.is-assistant {
    align-self: flex-start;
}

.gemini-chat-message.is-assistant span {
    background: var(--surface2);
}

.gemini-chat-message.is-loading span {
    color: var(--text3);
}

.gemini-chat-form {
    align-items: center;
    border-top: 1px solid var(--border);
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) 38px;
    padding: 10px;
}

.gemini-chat-form input {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 13px;
    height: 38px;
    min-width: 0;
    outline: none;
    padding: 0 11px;
}

.gemini-chat-form input:focus {
    border-color: color-mix(in srgb, #8ab4f8 58%, var(--border));
}

.gemini-chat-send {
    align-items: center;
    background: color-mix(in srgb, #8ab4f8 18%, var(--surface2));
    border: 1px solid color-mix(in srgb, #8ab4f8 42%, var(--border));
    border-radius: var(--radius-sm);
    color: #c4d7ff;
    cursor: pointer;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    padding: 0;
    width: 38px;
}

.gemini-chat-send:disabled {
    cursor: wait;
    opacity: 0.62;
}

.openrouter-chat-popover {
    background: var(--surface-elevated);
    border: 1px solid color-mix(in srgb, #14b8a6 26%, var(--border));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    max-height: min(548px, calc(100vh - 86px));
    overflow: hidden;
    position: fixed;
    right: clamp(16px, 2.4vw, 32px);
    top: 58px;
    width: min(430px, calc(100vw - 32px));
    z-index: var(--z-dropdown);
}

.openrouter-chat-head {
    align-items: center;
    border-bottom: 1px solid color-mix(in srgb, #14b8a6 22%, var(--border));
    display: grid;
    gap: 10px;
    grid-template-columns: 34px minmax(0, 1fr) 30px;
    padding: 13px 16px;
}

.openrouter-chat-head > div:not(.openrouter-chat-mark) {
    display: grid;
    gap: 2px;
}

.openrouter-chat-head strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
}

.openrouter-chat-head span {
    color: #2dd4bf;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.openrouter-chat-mark {
    height: 28px;
    position: relative;
    width: 28px;
}

.openrouter-chat-mark::before,
.openrouter-chat-mark::after {
    background: color-mix(in srgb, #14b8a6 46%, var(--border));
    content: '';
    height: 1px;
    left: 9px;
    position: absolute;
    top: 13px;
    transform-origin: left center;
    width: 16px;
}

.openrouter-chat-mark::before {
    transform: rotate(-28deg);
}

.openrouter-chat-mark::after {
    transform: rotate(28deg);
}

.openrouter-chat-mark span {
    background: var(--surface);
    border: 1px solid color-mix(in srgb, #14b8a6 58%, var(--border));
    border-radius: 50%;
    display: block;
    height: 8px;
    position: absolute;
    width: 8px;
}

.openrouter-chat-mark span:nth-child(1) {
    left: 0;
    top: 10px;
}

.openrouter-chat-mark span:nth-child(2) {
    right: 0;
    top: 2px;
}

.openrouter-chat-mark span:nth-child(3) {
    bottom: 2px;
    right: 0;
}

.openrouter-chat-head button {
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    height: 30px;
    justify-content: center;
    padding: 0;
    width: 30px;
}

.openrouter-chat-head button:hover {
    color: var(--text);
}

.openrouter-chat-messages {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 8px;
    min-height: 178px;
    overflow-y: auto;
    padding: 12px;
}

.openrouter-chat-message {
    display: flex;
    max-width: 89%;
}

.openrouter-chat-message span {
    background: color-mix(in srgb, var(--surface2) 90%, #14b8a6);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-size: 13px;
    line-height: 1.42;
    padding: 9px 10px;
    white-space: pre-wrap;
}

.openrouter-chat-message.is-user {
    align-self: flex-end;
    justify-content: flex-end;
}

.openrouter-chat-message.is-user span {
    background: color-mix(in srgb, #14b8a6 13%, var(--surface2));
    border-color: color-mix(in srgb, #14b8a6 32%, var(--border));
    color: var(--text);
}

.openrouter-chat-message.is-assistant {
    align-self: flex-start;
}

.openrouter-chat-message.is-loading span {
    color: var(--text3);
}

.openrouter-chat-form {
    align-items: center;
    border-top: 1px solid color-mix(in srgb, #14b8a6 20%, var(--border));
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) 38px;
    padding: 10px;
}

.openrouter-chat-form input {
    background: var(--surface);
    border: 1px solid color-mix(in srgb, #14b8a6 24%, var(--border));
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 13px;
    height: 38px;
    min-width: 0;
    outline: none;
    padding: 0 11px;
}

.openrouter-chat-form input:focus {
    border-color: color-mix(in srgb, #14b8a6 66%, var(--border));
}

.openrouter-chat-send {
    align-items: center;
    background: color-mix(in srgb, #14b8a6 18%, var(--surface2));
    border: 1px solid color-mix(in srgb, #14b8a6 48%, var(--border));
    border-radius: var(--radius-sm);
    color: #99f6e4;
    cursor: pointer;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    padding: 0;
    width: 38px;
}

.openrouter-chat-send:disabled {
    cursor: wait;
    opacity: 0.62;
}

.notifications-head {
    align-items: center;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    padding: 14px 16px;
}

.notifications-head strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
}

.notifications-head-actions {
    display: flex;
    gap: 12px;
}

.notifications-head button {
    background: transparent;
    border: 0;
    color: var(--accent);
    cursor: pointer;
    font-size: 12px;
    font-weight: 800;
}

.notifications-head button[data-notifications-clear-all] {
    color: var(--danger);
}

.notifications-list {
    max-height: 392px;
    overflow-y: auto;
    padding: 6px;
}

.notification-item {
    align-items: stretch;
    background: transparent;
    border: 0;
    border-radius: var(--radius-sm);
    color: var(--text2);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0;
    width: 100%;
}

.notification-item:hover {
    background: var(--surface2);
}

.notification-item.is-unread {
    background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.notification-item-body {
    align-items: flex-start;
    background: transparent;
    border: 0;
    color: var(--text2);
    cursor: pointer;
    display: grid;
    gap: 10px;
    grid-template-columns: 8px minmax(0, 1fr);
    padding: 10px;
    text-align: left;
    width: 100%;
}

.notification-item-body:hover {
    background: transparent;
}

.notification-delete-btn {
    align-self: start;
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--text3);
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    margin: 10px 8px 0 0;
    opacity: 0;
    padding: 2px;
    transition: opacity 0.15s ease, color 0.15s ease;
}

.notification-delete-btn svg {
    width: 14px;
    height: 14px;
}

.notification-item:hover .notification-delete-btn {
    opacity: 1;
}

.notification-delete-btn:hover {
    color: var(--danger);
}

.notification-dot {
    background: var(--border-strong);
    border-radius: 50%;
    height: 8px;
    margin-top: 6px;
    width: 8px;
}

.notification-item.is-unread .notification-dot {
    background: var(--accent);
}

.notification-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.notification-copy strong {
    color: var(--text);
    font-size: 13px;
    line-height: 1.25;
}

.notification-copy small {
    color: var(--text2);
    font-size: 12px;
    line-height: 1.35;
}

.notification-copy em {
    color: var(--text3);
    font-size: 10px;
    font-style: normal;
}

.notifications-empty {
    color: var(--text3);
    font-size: 13px;
    padding: 22px 14px;
    text-align: center;
}

.request-modal-overlay {
    align-items: center;
    display: flex;
    justify-content: center;
    padding: 24px;
}

.request-modal {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 38%),
        linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 92%, transparent), var(--surface-elevated)) !important;
    border-color: color-mix(in srgb, var(--accent) 14%, var(--border)) !important;
    max-width: min(820px, 92vw);
    overflow: hidden;
    padding: 0 !important;
    position: relative;
}

.request-modal::before {
    background: linear-gradient(90deg, var(--highlight), var(--accent), var(--brand));
    content: '';
    height: 3px;
    left: 0;
    opacity: 0.85;
    position: absolute;
    right: 0;
    top: 0;
}

.request-detail-modal {
    max-width: min(860px, 92vw);
}

.request-modal-head {
    align-items: flex-start;
    background: color-mix(in srgb, var(--surface2) 64%, transparent);
    border-bottom: 1px solid var(--border);
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin-bottom: 0;
    padding: 24px 24px 20px;
}

.request-modal-head .eyebrow {
    color: var(--accent);
}

.request-modal-head .modal-title {
    font-size: 24px;
    margin-bottom: 8px;
}

.request-modal-head .modal-desc {
    max-width: 660px;
}

.request-modal > .request-alert,
.request-modal > .request-form,
.request-modal > .request-detail-grid,
.request-modal > .request-detail-section,
.request-modal > .request-followup-form {
    margin-left: 24px;
    margin-right: 24px;
}

.request-modal > .request-alert {
    margin-top: 18px;
}

.request-form,
.request-followup-form {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.request-form {
    background: color-mix(in srgb, var(--surface) 72%, transparent);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 24px;
    margin-top: 18px;
    padding: 18px;
}

.request-followup-form {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-top: 16px;
    padding: 14px;
}

.request-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.request-field-wide,
.request-followup-form .request-field,
.request-followup-form .modal-actions {
    grid-column: 1 / -1;
}

.request-field span {
    color: var(--text3);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.request-field .multi-select-trigger {
    min-height: 44px;
    padding-inline: 12px;
}

.request-field input,
.request-field select,
.request-field textarea {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font: inherit;
    min-height: 44px;
    outline: 0;
    padding: 0 12px;
    width: 100%;
}

.request-field textarea {
    line-height: 1.45;
    min-height: 132px;
    padding: 12px;
    resize: vertical;
}

.request-field input:focus,
.request-field select:focus,
.request-field textarea:focus {
    border-color: var(--accent);
    box-shadow: var(--focus-ring);
}

.request-disclaimer {
    align-items: center;
    color: var(--text3);
    display: flex;
    font-size: 11px;
    gap: 6px;
    margin-top: 4px;
}

.request-disclaimer strong {
    color: var(--text2);
    font-weight: 600;
}

.request-disclaimer .icon {
    flex-shrink: 0;
    height: 14px;
    width: 14px;
}

.request-badge {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text2);
    font-size: 11px;
    font-weight: 800;
    padding: 5px 8px;
}

.request-form-actions {
    grid-column: 1 / -1;
    margin-top: 4px;
}

.request-alert {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    margin-bottom: 14px;
    padding: 12px 14px;
}

.request-alert-success {
    background: color-mix(in srgb, var(--success) 10%, transparent);
    border-color: color-mix(in srgb, var(--success) 30%, var(--border));
    color: var(--success);
}

.request-alert-error {
    background: color-mix(in srgb, var(--danger) 9%, transparent);
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
    color: var(--danger);
}

.request-detail-grid {
    align-items: center;
    color: var(--text3);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
    margin-top: 18px;
}

.request-badge.status-nova,
.request-badge.status-reaberta {
    color: var(--info);
}

.request-badge.status-em_analise {
    color: var(--warning);
}

.request-badge.status-resolvida {
    color: var(--success);
}

.request-badge.status-devolvida,
.request-badge.priority-critica {
    color: var(--danger);
}

.request-badge.priority-alta {
    color: var(--warning);
}

.request-detail-section {
    border-top: 1px solid var(--border);
    padding: 14px 0;
}

.request-detail-section h3 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 14px;
    margin: 0 0 8px;
}

.request-detail-section p {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
    margin: 0;
    white-space: pre-wrap;
}

.request-history {
    display: grid;
    gap: 10px;
}

.request-history-item {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
}

.request-history-item div {
    align-items: baseline;
    display: flex;
    gap: 8px;
    justify-content: space-between;
}

.request-history-item strong {
    color: var(--text);
    font-size: 12px;
}

.request-history-item span,
.request-history-item small,
.request-history-empty {
    color: var(--text3);
    font-size: 11px;
}

.request-history-item p {
    margin-top: 6px;
}

@media (max-width: 760px) {
    .request-modal-overlay {
        padding: 14px;
    }

    .request-modal-head {
        padding: 20px 18px 16px;
    }

    .request-modal > .request-alert,
    .request-modal > .request-form,
    .request-modal > .request-detail-grid,
    .request-modal > .request-detail-section,
    .request-modal > .request-followup-form {
        margin-left: 18px;
        margin-right: 18px;
    }

    .feedback-header-button {
        min-width: 78px;
        padding: 0 10px;
    }

    .request-form,
    .request-followup-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .feedback-header-button {
        font-size: 11px;
        min-width: 72px;
    }

    .header-right {
        gap: 6px;
    }

    .notifications-popover {
        top: 54px;
    }
}

.request-modal-stunning {
    background: var(--surface-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    display: flex;
    flex-direction: row;
    max-width: 900px;
    min-height: 480px;
    overflow: hidden;
    padding: 0 !important;
    position: relative;
    width: 100%;
}

.request-close-stunning {
    align-items: center;
    background: var(--surface-elevated);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text2);
    cursor: pointer;
    display: flex;
    height: 36px;
    justify-content: center;
    position: absolute;
    right: 20px;
    top: 20px;
    transition: background 0.2s, color 0.2s;
    width: 36px;
    z-index: 10;
}

.request-close-stunning:hover {
    background: var(--surface2);
    color: var(--text);
}

.request-close-stunning svg {
    height: 18px;
    width: 18px;
}

.request-stunning-hero {
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), color-mix(in srgb, var(--highlight) 8%, transparent));
    border-right: 1px solid var(--border);
    display: flex;
    flex: 0 0 320px;
    flex-direction: column;
    justify-content: center;
    padding: 40px;
    position: relative;
    overflow: hidden;
}

.request-hero-orb {
    background: var(--accent);
    border-radius: 50%;
    filter: blur(80px);
    height: 300px;
    left: -50px;
    opacity: 0.15;
    position: absolute;
    top: -50px;
    width: 300px;
    z-index: 0;
}

.request-hero-content {
    position: relative;
    z-index: 1;
}

.request-hero-badge {
    background: color-mix(in srgb, var(--accent) 15%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
    border-radius: var(--radius-sm);
    color: var(--accent);
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    margin-bottom: 16px;
    padding: 6px 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.request-stunning-hero h2 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 16px;
}

.request-stunning-hero p {
    color: var(--text2);
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 32px;
}

.request-hero-features {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.hero-feature {
    align-items: center;
    color: var(--text);
    display: flex;
    font-size: 13px;
    font-weight: 600;
    gap: 12px;
}

.hero-icon-box {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--accent);
    display: flex;
    height: 32px;
    justify-content: center;
    width: 32px;
}

.hero-icon-box svg {
    height: 16px;
    width: 16px;
}

.request-stunning-body {
    background: var(--surface);
    display: flex;
    flex: 1;
    flex-direction: column;
    justify-content: center;
    padding: 40px;
}

.request-stunning-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.request-form-row {
    display: grid;
    gap: 20px;
    grid-template-columns: 1fr 1fr;
}

.request-stunning-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.request-stunning-field span {
    color: var(--text);
    font-size: 13px;
    font-weight: 600;
}

.request-stunning-field input,
.request-stunning-field select,
.request-stunning-field textarea {
    background: var(--surface-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-family: inherit;
    font-size: 14px;
    padding: 12px 14px;
    transition: all 0.2s ease;
    width: 100%;
    outline: none;
}

.request-stunning-field select {
    appearance: none;
    background-image: url('data:image/svg+xml;utf8,<svg viewBox="0 0 24 24" fill="none" stroke="%238a8f98" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>');
    background-position: right 14px center;
    background-repeat: no-repeat;
    background-size: 16px;
    padding-right: 40px;
}

.request-stunning-field textarea {
    line-height: 1.5;
    resize: none;
}

.request-stunning-field input:focus,
.request-stunning-field select:focus,
.request-stunning-field textarea:focus {
    background: var(--surface2);
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);
}

.request-disclaimer-stunning {
    align-items: center;
    color: var(--text3);
    display: flex;
    font-size: 12px;
    gap: 8px;
    margin-top: 4px;
}

.request-disclaimer-stunning strong {
    color: var(--text);
    font-weight: 600;
}

.request-disclaimer-stunning .icon {
    flex-shrink: 0;
    height: 16px;
    width: 16px;
}

.request-stunning-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 12px;
}

.request-stunning-actions .btn-ui {
    font-size: 14px;
    padding: 0 20px;
    height: 44px;
}

@media (max-width: 760px) {
    .request-modal-stunning {
        flex-direction: column;
    }
    
    .request-stunning-hero {
        flex: none;
        padding: 30px 24px;
    }
    
    .request-stunning-body {
        padding: 24px;
    }
    
    .request-form-row {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* ==========================================================================
   Caixa de Entrada (Inbox) - Locus Platform
   ========================================================================== */

.inbox-shell {
    display: flex;
    flex-direction: column;
    gap: 24px;
    max-width: 1100px;
    margin: 0 auto;
    width: 100%;
}

.inbox-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border);
    padding-bottom: 20px;
}

.inbox-kicker {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--primary);
    letter-spacing: 1px;
}

.inbox-title {
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 700;
    color: var(--text);
    margin: 4px 0;
}

.inbox-subtitle {
    font-size: 14px;
    color: var(--text3);
    margin: 0;
}

.inbox-body {
    background: var(--surface-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.inbox-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: var(--surface2-solid);
    border-bottom: 1px solid var(--border);
}

.inbox-unread-count {
    font-size: 13px;
    font-weight: 600;
    color: var(--text2);
}

.inbox-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.btn-link-action {
    background: transparent;
    border: none;
    color: var(--primary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: var(--radius-xs);
    transition: background-color 0.15s ease, color 0.15s ease;
}

.btn-link-action:hover {
    background: color-mix(in srgb, var(--primary) 8%, transparent);
    color: var(--accent2);
}

.inbox-list {
    display: flex;
    flex-direction: column;
    min-height: 300px;
}

.inbox-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    transition: background-color 0.15s ease;
    position: relative;
}

.inbox-item:last-child {
    border-bottom: none;
}

.inbox-item:hover {
    background-color: var(--surface2-solid);
}

.inbox-item.is-unread {
    background-color: color-mix(in srgb, var(--primary) 2%, var(--surface-solid));
}

.inbox-item-indicator {
    padding-top: 4px;
}

.inbox-dot {
    display: block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: transparent;
    transition: background-color 0.2s ease;
}

.inbox-item.is-unread .inbox-dot {
    background-color: var(--primary);
    box-shadow: 0 0 8px var(--primary);
}

.inbox-item-content {
    flex-grow: 1;
    min-width: 0;
}

.inbox-item-meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
}

.inbox-item-title {
    font-size: 15px;
    color: var(--text);
    font-weight: 600;
}

.inbox-item-date {
    font-size: 12px;
    color: var(--text3);
    white-space: nowrap;
}

.inbox-item-message {
    font-size: 13px;
    color: var(--text2);
    margin: 6px 0 0 0;
    line-height: 1.5;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.inbox-item-actions {
    opacity: 0;
    transition: opacity 0.15s ease;
}

.inbox-item:hover .inbox-item-actions {
    opacity: 1;
}

.inbox-delete-btn {
    background: transparent;
    border: none;
    color: var(--text3);
    padding: 6px;
    border-radius: var(--radius-xs);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.inbox-delete-btn:hover {
    background: color-mix(in srgb, var(--danger) 8%, transparent);
    color: var(--danger);
}

.inbox-delete-btn svg {
    width: 16px;
    height: 16px;
}

.inbox-loading, .inbox-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 250px;
    font-size: 14px;
    color: var(--text3);
}

/* Seletor de Modelo no Chat IA */

.assistant-chat-model-selector-container {
    padding: 10px 16px;
    background: var(--surface2-solid);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 8px;
    box-sizing: border-box;
}

.assistant-model-select {
    width: 100%;
    height: 34px;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background-color: var(--surface-solid);
    color: var(--text);
    font-size: 13px;
    font-weight: 500;
    padding: 0 10px;
    font-family: var(--font-body);
    outline: none;
    cursor: pointer;
    transition: border-color 0.15s ease;
    box-sizing: border-box;
}

.assistant-model-select:focus {
    border-color: var(--primary);
}

.kpi-card,
.chart-wrap,
.sup-card,
.closer-card,
.top-item {
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.closer-card {
    border-radius: var(--radius-lg);
    padding: 20px;
    position: relative;
    overflow: hidden;
}

.kpi-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: clamp(8px, 1.2vw, 16px);
    margin-bottom: 24px;
}

#kpi-row,
#kpi-chamadas-row,
#kpi-daily-row,
#kpi-estorno-row,
#sdr-kpi-row {
    grid-template-columns: repeat(auto-fit, minmax(80px, 1fr)) !important;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
    overflow: visible;
}

#kpi-chamadas-row {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.kpi-card {
    min-width: 0;
    container-type: inline-size;
    border-radius: var(--radius-lg);
    padding: clamp(12px, 1.5vw, 20px);
    background: linear-gradient(180deg, var(--surface) 0%, var(--surface2) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    min-height: 105px;
    transition: all 0.2s ease;
    border: 1px solid var(--border);
}

.kpi-card:hover,
.closer-card:hover,
.sup-card:hover,
.top-item:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
    border-color: var(--border-strong);
}

.kpi-label {
    font-family: var(--font-display);
    font-size: clamp(10px, 8cqw, 12px);
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-height: 1.2em;
}

.kpi-value {
    font-family: var(--font-display);
    font-size: clamp(16px, 18cqw, 40px);
    font-weight: 800;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    max-width: 100%;
    margin-bottom: auto;
}

.kpi-value.is-currency {
    font-size: clamp(14px, 13cqw, 34px);
    letter-spacing: -0.05em;
}

.kpi-footer {
    margin-top: 8px;
    min-height: 20px;
    display: flex;
    align-items: center;
    width: 100%;
}

.kpi-trend {
    font-size: 11px;
    display: flex;
    align-items: center;
    gap: 4px;
    font-family: var(--font-mono);
}

.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(292px, 1fr));
    gap: 16px;
}

#closers-cards.cards-grid {
    grid-template-columns: repeat(2, 1fr) !important;
}

.closer-card {
    background: var(--surface);
}

.closer-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}

.closer-card::before {
    content: '';
    position: absolute;
    top: 14px;
    right: 14px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    opacity: 0.95;
}

.closer-card.q1::before {
    background: var(--q1);
}

.closer-card.q2::before {
    background: var(--q2);
}

.closer-card.q3::before {
    background: var(--q3);
}

.closer-card.q4::before {
    background: var(--q4);
}

.closer-name {
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 4px;
}

.closer-sub {
    font-size: 11px;
    color: var(--text3);
    margin-bottom: 14px;
    display: flex;
    gap: 8px;
}

.closer-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.metric-box {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px;
    text-align: center;
}

.metric-label {
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--text3);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.metric-val {
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
}

.metric-trend {
    font-size: 11px;
    display: flex;
    align-items: center;
    gap: 4px;
    justify-content: center;
}

.quartil-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 700;
    min-height: 20px;
    padding: 0 8px;
    border-radius: 99px;
    border: 1px solid transparent;
}

.quartil-badge.q1 {
    background: rgba(34, 197, 94, 0.14);
    border-color: rgba(34, 197, 94, 0.24);
    color: var(--q1);
}

.quartil-badge.q2 {
    background: rgba(245, 158, 11, 0.14);
    border-color: rgba(245, 158, 11, 0.24);
    color: var(--q2);
}

.quartil-badge.q3 {
    background: rgba(251, 113, 133, 0.14);
    border-color: rgba(251, 113, 133, 0.24);
    color: var(--q3);
}

.quartil-badge.q4 {
    background: rgba(239, 68, 68, 0.14);
    border-color: rgba(239, 68, 68, 0.24);
    color: var(--q4);
}

.person-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 18px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.person-card:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

.person-card.compact {
    padding: 14px;
    gap: 12px;
}

.person-main-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    padding: 12px 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.metric-main.small {
    font-size: 14px;
}

.subcards-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
}

.closer-detail-block {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 10px;
}

.closer-detail-title {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.closer-detail-title span {
    color: var(--text2);
    font-size: 11px;
    font-weight: 800;
}

.closer-detail-title small {
    color: var(--text3);
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    white-space: nowrap;
}

.track-mini-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.track-mini-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
    padding: 8px;
}

.track-mini-head,
.track-mini-line {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 6px;
    min-width: 0;
}

.track-mini-head span {
    color: var(--text);
    font-size: 10px;
    font-weight: 800;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.track-mini-head strong {
    font-family: var(--font-mono);
    font-size: 12px;
    white-space: nowrap;
}

.track-mini-line span {
    color: var(--text3);
    font-size: 9px;
    font-weight: 700;
    white-space: nowrap;
}

.track-mini-line strong {
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    white-space: nowrap;
}

.closer-detail-metrics {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.closer-detail-tile {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    min-width: 0;
    padding: 8px;
}

.closer-detail-tile span {
    color: var(--text3);
    display: block;
    font-size: 9px;
    font-weight: 700;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.closer-detail-tile strong {
    color: var(--text);
    display: block;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.closer-detail-tile.positive strong {
    color: var(--q1);
}

.closer-detail-tile.negative strong {
    color: var(--q4);
}

.subcard.compact {
    padding: 10px;
    background: var(--surface2-solid);
}

.subcard-meta {
    font-size: 9px;
    color: var(--text3);
    font-weight: 700;
}

.score-pill-value.small {
    font-size: 14px;
    margin-bottom: 4px;
}

.mini-metrics-row {
    display: flex;
    justify-content: space-between;
    margin-top: 8px;
    font-size: 9px;
    font-family: var(--font-mono);
    color: var(--text3);
}

.mini-metric-item span {
    font-weight: 700;
}

.subcard-footer {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px dashed var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 9px;
    color: var(--text3);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.person-card-header {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.person-card-clickable {
    cursor: pointer;
}

.person-card-name {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
}

.person-card-sub {
    color: var(--text3);
    font-size: 11px;
    margin-top: 3px;
}

.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.data-chip {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text2);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    padding: 3px 8px;
    text-transform: uppercase;
    white-space: nowrap;
}

.data-chip.muted {
    color: var(--text3);
}

.data-chip.period-chip {
    background: var(--accent-glow);
    border-color: color-mix(in srgb, var(--accent) 36%, transparent);
    color: var(--accent);
}

.score-pill {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    text-align: right;
}

.score-pill-value {
    color: var(--accent);
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
}

.score-pill-label {
    color: var(--text3);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    margin-top: 4px;
    text-transform: uppercase;
}

.person-section-grid {
    border-bottom: 1px solid var(--border);
    border-top: 1px solid var(--border);
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 12px 0;
}

.person-section-grid.plain {
    border: 0;
    padding: 0;
}

.person-stack {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.operational-stack {
    background: linear-gradient(180deg, var(--surface2-solid) 0%, var(--surface) 100%);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border));
    border-radius: var(--radius-sm);
    box-shadow: none;
    gap: 7px;
    margin: -6px 0;
    padding: 10px 12px;
}

.operational-stack .person-section-label {
    color: var(--accent);
}

.operational-main {
    align-items: baseline;
    display: flex;
    gap: 6px;
}

.operational-main strong {
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
}

.operational-main span {
    color: var(--text2);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.operational-sub {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

.operational-sub span {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
}

.person-section-label {
    color: var(--text3);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.6px;
    text-transform: uppercase;
}

.metric-line {
    align-items: center;
    display: flex;
    font-size: 12px;
    justify-content: space-between;
    gap: 12px;
}

.metric-line span:first-child {
    color: var(--text2);
}

.metric-line strong {
    color: var(--text);
    font-weight: 700;
}

.metric-line .positive {
    color: var(--q1);
}

.metric-main-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.metric-main {
    font-size: 18px;
    font-weight: 800;
}

.marker-bar {
    background: var(--surface3);
    border-radius: 2px;
    height: 4px;
    margin-top: 8px;
    position: relative;
    width: 100%;
}

.marker-dot {
    border: 2px solid var(--surface);
    border-radius: 50%;
    box-shadow: var(--shadow-sm);
    height: 10px;
    position: absolute;
    top: -3px;
    transform: translateX(-50%);
    width: 10px;
}

.subcard {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px;
}

.subcard-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}

.subcard-title {
    align-items: center;
    color: var(--text2);
    display: flex;
    font-size: 11px;
    font-weight: 700;
    gap: 5px;
}

.progress-track {
    background: var(--surface3);
    border-radius: 3px;
    height: 6px;
    overflow: hidden;
    position: relative;
    width: 100%;
}

.progress-fill {
    border-radius: 3px;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: width 0.5s ease;
}

.progress-caption {
    display: flex;
    justify-content: space-between;
    margin-top: 4px;
}

.progress-caption span {
    color: var(--text3);
    font-size: 9px;
}

.progress-caption strong {
    font-family: var(--font-mono);
    font-size: 10px;
}

.mini-metrics {
    display: flex;
    gap: 8px;
    justify-content: space-around;
    margin-top: 12px;
}

.mini-metric {
    flex: 1;
    text-align: center;
}

.mini-metric+.mini-metric {
    box-shadow: -1px 0 0 var(--border);
}

.mini-metric-label {
    color: var(--text3);
    font-size: 9px;
}

.mini-metric-value {
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 700;
}

.highlight-panel {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
}

.highlight-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.highlight-label {
    color: var(--text2);
    font-size: 11px;
    font-weight: 700;
}

.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.small-tag {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text2);
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    white-space: nowrap;
}

.card-copy-btn {
    background: var(--surface3);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    color: var(--text3);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    flex-shrink: 0;
    position: relative;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.card-copy-btn:hover {
    color: var(--accent);
    border-color: var(--accent);
    background: var(--accent)15;
}

.card-copy-btn.copied {
    color: var(--q1);
    border-color: var(--q1);
    background: var(--q1)15;
}

.card-copy-btn.failed {
    color: var(--q4);
    border-color: var(--q4);
    background: var(--q4)15;
}

.card-copy-btn.copying {
    color: var(--accent);
    border-color: var(--accent);
    background: var(--accent)12;
}

.card-copy-btn.copying svg,
.card-copy-btn.copied svg,
.card-copy-btn.failed svg {
    opacity: 0;
}

.card-copy-btn.copying::after,
.card-copy-btn.copied::after,
.card-copy-btn.failed::after {
    align-items: center;
    display: flex;
    inset: 0;
    justify-content: center;
    position: absolute;
}

.card-copy-btn.copying::after {
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 999px;
    content: "";
    height: 12px;
    inset: auto;
    width: 12px;
    animation: copy-spin 0.7s linear infinite;
}

.card-copy-btn.copied::after {
    content: "OK";
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 900;
}

.card-copy-btn.failed::after {
    content: "!";
    font-family: var(--font-mono);
    font-size: 15px;
    font-weight: 900;
}

.card-copy-btn.has-feedback::before {
    background: var(--text);
    border-radius: var(--radius-xs);
    bottom: calc(100% + 8px);
    box-shadow: var(--shadow-md);
    color: var(--surface);
    content: attr(data-copy-message);
    font-size: 10px;
    font-weight: 800;
    left: 50%;
    letter-spacing: 0.2px;
    line-height: 1;
    padding: 6px 8px;
    pointer-events: none;
    position: absolute;
    transform: translateX(-50%);
    white-space: nowrap;
    z-index: 10;
}

.copy-capture-card {
    box-sizing: border-box;
}

.copy-capture-card,
.copy-capture-card:hover {
    transform: none !important;
}

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

.copy-toolbar {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    margin-bottom: 4px;
}

@media (max-width: 640px) {

    .kpi-row,
    #kpi-row,
    #kpi-daily-row,
    #kpi-estorno-row,
    #sdr-kpi-row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-flow: row;
    }

    .kpi-card {
        padding: 15px;
    }

    .cards-grid,
    #closers-cards.cards-grid {
        grid-template-columns: 1fr !important;
    }

    .person-section-grid {
        grid-template-columns: 1fr;
    }

    .person-main-grid,
    .track-mini-grid,
    .closer-detail-metrics,
    .closer-detail-metrics.four {
        grid-template-columns: 1fr 1fr;
    }

    .person-card-header {
        flex-direction: column;
    }

    .score-pill {
        text-align: left;
        width: 100%;
    }
}

.table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    min-width: 720px;
}

thead tr {
    background: var(--surface2-solid);
}

thead th {
    text-align: left;
    padding: 12px 14px;
    font-family: var(--font-display);
    font-size: 11px;
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: 1;
}

tbody tr {
    border-bottom: 1px solid var(--border);
    transition: background 0.15s ease;
}

tbody tr:last-child {
    border-bottom: none;
}

tbody tr:hover {
    background: color-mix(in srgb, var(--surface3-solid) 68%, transparent);
}

tbody td {
    padding: 12px 14px;
    color: var(--text);
    vertical-align: middle;
    line-height: 1.45;
}

tbody td:first-child {
    font-weight: 700;
    color: var(--text);
}

td:is(:nth-child(n+4)),
th:is(:nth-child(n+4)) {
    font-variant-numeric: tabular-nums;
}

.lead-row {
    cursor: pointer;
}

.lead-cell-main {
    align-items: center;
    display: flex;
    gap: 8px;
}

.lead-avatar {
    align-items: center;
    background: var(--surface3);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--accent);
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 10px;
    font-weight: 800;
    height: 24px;
    justify-content: center;
    width: 24px;
}

.td-muted {
    color: var(--text2);
    font-size: 11px;
}

.td-compact {
    font-size: 12px;
}

.td-mono {
    font-family: var(--font-mono);
    font-size: 11px;
}

.td-positive {
    color: var(--q1);
    font-weight: 700;
}

.chart-wrap {
    border-radius: var(--radius-lg);
    padding: clamp(16px, 1.8vw, 22px);
    margin-bottom: 20px;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
}

.chart-title {
    font-family: var(--font-display);
    font-size: 14px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 14px;
    letter-spacing: 0;
}

.chart-container {
    position: relative;
    width: 100%;
    min-width: 0;
    min-height: 180px;
}

.chart-container canvas {
    display: block;
    width: 100% !important;
    height: 100% !important;
    max-width: 100%;
}

.chart-container[data-chart-state]::after {
    content: attr(data-chart-message);
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 16px 20px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.45;
    color: var(--text2);
    background: var(--surface-solid);
    box-shadow: inset 0 0 0 1px var(--border);
    border-radius: var(--radius, 12px);
    pointer-events: none;
    z-index: 2;
}

.chart-container[data-chart-state='loading']::after {
    content: 'Carregando gráfico…';
    color: var(--text3);
    font-weight: 500;
}

.chart-container[data-chart-state='empty']::after {
    content: attr(data-chart-message);
    color: var(--text3);
    font-weight: 500;
}

.chart-container[data-chart-state='error']::after {
    content: attr(data-chart-message);
    color: var(--danger);
    font-weight: 600;
}

.chart-container[data-chart-state='ok']::after,
.chart-container:not([data-chart-state])::after {
    display: none;
}

.chart-h-180 { min-height: 180px; height: 180px; }

.chart-h-220 { min-height: 220px; height: 220px; }

.chart-h-250 { min-height: 250px; height: 250px; }

.chart-h-260 { min-height: 260px; height: 260px; }

.chart-h-300 { min-height: 300px; height: 300px; }

.chart-h-350 { min-height: 350px; height: 350px; }

@media (max-width: 640px) {
    .chart-wrap {
        padding: 12px;
    }

    .chart-container {
        min-height: 160px;
    }

    .chart-h-180,
    .chart-h-220,
    .chart-h-250,
    .chart-h-260,
    .chart-h-300,
    .chart-h-350 {
        min-height: 160px;
        height: 200px;
    }
}

.kanban-board {
    margin-top: 4px;
}

.kanban-selection-toolbar {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin: -8px 0 20px;
    padding: 12px 16px;
}

.kanban-selection-summary {
    align-items: baseline;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    min-width: 0;
}

.kanban-selection-summary span {
    color: var(--text3);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.kanban-selection-summary strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 800;
}

.kanban-selection-summary small {
    color: var(--text2);
    font-size: 12px;
    font-weight: 700;
}

.kanban-selection-actions {
    display: flex;
    flex: 0 0 auto;
    gap: 8px;
}

.kanban-selection-actions .btn-ui.primary {
    gap: 8px;
}

.kanban-selection-actions .btn-ui:disabled {
    cursor: not-allowed;
    opacity: 0.48;
    transform: none;
}

.kanban-columns {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

.kanban-column {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    min-height: 200px;
    max-height: calc(100vh - 220px);
}

.kanban-column.is-selected-for-export {
    border-color: color-mix(in srgb, var(--accent) 54%, var(--border)) !important;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}

.kanban-column-header {
    padding: 14px 14px 12px;
    border-bottom: 1px solid var(--border);
    position: relative;
    flex-shrink: 0;
}

.kanban-column-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--kanban-color);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.kanban-step-select {
    align-items: center;
    cursor: pointer;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    position: absolute;
    right: 38px;
    top: 0;
    width: 32px;
    z-index: 1;
}

.kanban-step-select input {
    cursor: pointer;
    height: 100%;
    inset: 0;
    margin: 0;
    opacity: 0;
    position: absolute;
    width: 100%;
}

.kanban-step-select-box {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: transparent;
    display: flex;
    height: 24px;
    justify-content: center;
    transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease;
    width: 24px;
}

.kanban-step-select-box svg {
    height: 14px;
    width: 14px;
}

.kanban-step-select:hover .kanban-step-select-box {
    border-color: var(--border-strong);
}

.kanban-step-select input:checked + .kanban-step-select-box {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-contrast);
}

.kanban-step-name {
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 6px;
    line-height: 1.2;
}

.kanban-stats {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.kanban-count {
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 800;
    color: var(--text);
}

.kanban-pct {
    font-size: 11px;
    font-weight: 600;
    color: var(--text3);
}

.kanban-progress {
    height: 4px;
    background: var(--surface3);
    border-radius: 2px;
    overflow: hidden;
}

.kanban-progress-fill {
    height: 100%;
    background: var(--kanban-color);
    border-radius: 2px;
    transition: width 0.4s ease;
    min-width: 2px;
}

.kanban-column-body {
    flex: 1;
    overflow-y: auto;
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    scrollbar-width: thin;
}

.kanban-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    cursor: default;
    transition: box-shadow 0.18s ease, transform 0.18s ease;
}

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

.kanban-card-name {
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.kanban-card-phone {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text3);
    margin-bottom: 6px;
}

.kanban-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 2px;
}

.kanban-tag {
    font-size: 9px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 4px;
    background: var(--surface3);
    color: var(--text2);
    white-space: nowrap;
}

.kanban-tag-amount {
    background: color-mix(in srgb, var(--accent) 14%, var(--surface3));
    color: var(--accent);
}

.kanban-card-sup {
    font-size: 9px;
    color: var(--text3);
    font-weight: 500;
}

.kanban-empty {
    font-size: 11px;
    color: var(--text3);
    text-align: center;
    padding: 20px 8px;
    font-weight: 500;
}

.kanban-more {
    font-size: 10px;
    font-weight: 600;
    color: var(--text3);
    text-align: center;
    padding: 6px;
    border-top: 1px solid var(--border);
}

.empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--text3);
    font-size: 13px;
    font-weight: 500;
}

@media (max-width: 640px) {
    .kanban-selection-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .kanban-selection-actions {
        width: 100%;
    }

    .kanban-selection-actions .btn-ui {
        flex: 1;
        min-width: 0;
    }

    .kanban-columns {
        grid-template-columns: 1fr;
    }

    .kanban-column {
        max-height: 320px;
    }
}

.top-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.top-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 14px 16px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.top-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}

.top-item.rank-1,
.top-item.rank-2,
.top-item.rank-3 {
    background: linear-gradient(90deg, var(--accent-glow), var(--surface));
}

.top-item.worst-1,
.top-item.worst-2,
.top-item.worst-3 {
    background: linear-gradient(90deg, rgba(100, 116, 139, 0.08), transparent);
}

.top-rank {
    font-family: var(--font-display);
    font-size: 21px;
    font-weight: 800;
    color: var(--text3);
    min-width: 38px;
    text-align: center;
}

.top-rank.rank-1,
.top-rank.rank-2,
.top-rank.rank-3 {
    color: var(--accent);
}

.top-rank.worst-1,
.top-rank.worst-2,
.top-rank.worst-3 {
    color: var(--text2);
}

.top-info {
    flex: 1;
}

.top-name {
    font-family: var(--font-display);
    font-size: 14.5px;
    font-weight: 700;
}

.top-sup {
    font-size: 11px;
    color: var(--text3);
}

.top-metric {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--accent);
    font-weight: 500;
}

.top-trend {
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 2px;
    justify-content: flex-end;
}

.deficit-item {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.deficit-name {
    min-width: 240px;
    font-size: 12px;
    color: var(--text2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.deficit-bar-wrap {
    flex: 1;
    height: 8px;
    background: var(--surface3-solid);
    border-radius: 99px;
    overflow: hidden;
}

.deficit-bar {
    height: 100%;
    border-radius: 99px;
    background: linear-gradient(90deg, var(--accent), var(--brand));
    transition: width 1s ease;
}

.deficit-pct {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text3);
    min-width: 48px;
    text-align: right;
}

.evo-controls {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 16px;
    align-items: center;
}

.evo-select {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 13px;
    min-height: var(--control-h);
    padding: 0 12px;
    border-radius: var(--radius-sm);
    outline: none;
    cursor: pointer;
}

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

.sup-card {
    border-radius: var(--radius-lg);
    padding: 20px;
}

.sup-name {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 800;
    margin-bottom: 14px;
}

.sup-closers {
    font-size: 12px;
    color: var(--text3);
    margin-bottom: 12px;
}

.sup-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
}

.sup-metric {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px;
    text-align: center;
}

.sup-metric-label {
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sup-metric-val {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
}

.empty {
    text-align: center;
    padding: 52px 20px;
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 12px;
    background: var(--surface);
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-lg);
}

.empty svg {
    width: 40px;
    height: 40px;
    margin-bottom: 12px;
    stroke: var(--text3);
}

.two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: start;
}

.call-hours-wrap {
    margin-top: -4px;
}

.call-hours-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.call-hours-panel {
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    min-width: 0;
    padding: 14px;
}

.call-hours-head {
    align-items: baseline;
    border-bottom: 1px solid var(--border);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-bottom: 12px;
    padding-bottom: 10px;
}

.call-hours-head span {
    color: var(--text2);
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.call-hours-head strong {
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 900;
    white-space: nowrap;
}

.call-hours-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.call-hour-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 92px minmax(80px, 1fr) 44px;
    min-height: 22px;
}

.call-hour-label {
    color: var(--text3);
    font-size: 10px;
    font-weight: 800;
    white-space: nowrap;
}

.call-hour-track {
    background: var(--surface3);
    border-radius: 99px;
    height: 8px;
    overflow: hidden;
    position: relative;
}

.call-hour-track span {
    background: linear-gradient(90deg, var(--accent), var(--q1));
    border-radius: inherit;
    display: block;
    height: 100%;
    min-width: 0;
}

.call-hour-value {
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
    text-align: right;
}

.call-hour-row.is-peak .call-hour-label,
.call-hour-row.is-peak .call-hour-value {
    color: var(--accent);
}

.call-best-hours {
    border-top: 1px solid var(--border);
    margin-top: 16px;
    padding-top: 14px;
}

.call-best-hours-title {
    color: var(--text2);
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.call-best-hours-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.call-best-hour-card {
    align-items: center;
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: grid;
    gap: 10px;
    grid-template-columns: 28px minmax(0, 1fr) auto;
    min-width: 0;
    padding: 12px;
}

.call-best-rank {
    align-items: center;
    background: var(--accent-glow);
    border: 1px solid color-mix(in srgb, var(--accent) 34%, transparent);
    border-radius: var(--radius-xs);
    color: var(--accent);
    display: flex;
    font-family: var(--font-display);
    font-size: 13px;
    font-weight: 900;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.call-best-main {
    min-width: 0;
}

.call-best-main strong {
    color: var(--text);
    display: block;
    font-size: 12px;
    font-weight: 800;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.call-best-main span {
    color: var(--text3);
    display: block;
    font-size: 10px;
    font-weight: 700;
    margin-top: 3px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.call-best-rate {
    color: var(--q1);
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 900;
    white-space: nowrap;
}

@media (max-width: 900px) {
    .two-col,
    .call-hours-grid,
    .call-best-hours-list {
        grid-template-columns: 1fr;
    }
}

.inner-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.inner-tab {
    min-height: var(--control-h-sm);
    background: var(--surface2-solid);
    border: 1px solid var(--border);
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 11px;
    padding: 0 14px;
    border-radius: 99px;
    cursor: pointer;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.inner-tab.active,
.inner-tab:hover {
    background: var(--accent);
    color: var(--accent-contrast);
    border-color: var(--accent);
}

.sep {
    height: 1px;
    background: var(--border);
    margin: 28px 0;
}

optgroup {
    font-family: var(--font-display);
    color: var(--text3);
    font-weight: 700;
    background: var(--surface-solid);
}

option {
    font-family: var(--font-body);
    color: var(--text);
    font-weight: 400;
}

.att-score-bar {
    height: 6px;
    background: var(--surface3-solid);
    border-radius: 3px;
    overflow: hidden;
    margin-top: 6px;
}

.att-score-fill {
    height: 100%;
    border-radius: 3px;
    background: var(--accent);
}

.content-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 22px;
    margin-bottom: 24px;
    line-height: 1.6;
    box-shadow: var(--shadow-sm);
}

.split-panel {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

.split-col {
    flex: 1 1 300px;
    min-width: 0;
}

.panel-heading {
    margin: 0 0 10px;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 18px;
}

.panel-heading.accent {
    color: var(--accent);
}

.panel-heading.success {
    color: var(--q1);
}

.body-copy {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
}

.body-copy+.body-copy {
    margin-top: 8px;
}

.page-intro {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
    margin-top: -8px;
    margin-bottom: 24px;
}

.chart-note {
    color: var(--text3);
    font-size: 11px;
    line-height: 1.5;
    margin-top: -8px;
    margin-bottom: 16px;
    padding-inline: 2px;
}

.formula-box {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 12px;
    margin-top: 16px;
    padding: 14px;
}

.hint-copy {
    color: var(--text3);
    font-size: 11px;
    margin-top: 8px;
}

.example-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 12px;
}

.example-callout {
    border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
    background: var(--surface2);
    color: var(--text2);
    font-size: 12px;
    padding: 10px 12px;
    border-radius: var(--radius-sm);
}

.example-callout.success {
    border-color: rgba(34, 197, 94, 0.3);
    background: rgba(34, 197, 94, 0.08);
}

.example-callout.danger {
    border-color: rgba(239, 68, 68, 0.3);
    background: rgba(239, 68, 68, 0.08);
}

.mini-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 12px;
}

.mini-stat {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px;
    text-align: center;
}

.mini-stat.q1 {
    border-color: color-mix(in srgb, var(--q1) 45%, var(--border));
}

.mini-stat.q2 {
    border-color: color-mix(in srgb, var(--q2) 45%, var(--border));
}

.mini-stat.q3 {
    border-color: color-mix(in srgb, var(--q3) 45%, var(--border));
}

.mini-stat.q4 {
    border-color: color-mix(in srgb, var(--q4) 45%, var(--border));
}

.mini-stat-title {
    font-weight: 700;
}

.mini-stat.q1 .mini-stat-title {
    color: var(--q1);
}

.mini-stat.q2 .mini-stat-title {
    color: var(--q2);
}

.mini-stat.q3 .mini-stat-title {
    color: var(--q3);
}

.mini-stat.q4 .mini-stat-title {
    color: var(--q4);
}

.mini-stat-caption {
    color: var(--text3);
    font-size: 10px;
}

.section-title.compact {
    margin-bottom: 12px;
    color: var(--text2);
}

.section-title.offset {
    margin-top: 32px;
}

.section-title.offset-lg {
    margin-top: 40px;
}

.spaced-top {
    margin-top: 24px;
}

.spaced-bottom {
    margin-bottom: 32px;
}

.spaced-bottom-lg {
    margin-bottom: 40px;
}

.scroll-list {
    max-height: 240px;
    overflow-y: auto;
    padding-right: 4px;
}

.scroll-list-tall {
    max-height: 600px;
    overflow-y: auto;
    padding-right: 4px;
}

.table-scroll {
    max-height: 400px;
    overflow-y: auto;
}

.table-title-sticky {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    margin: 0;
    padding: 12px;
    position: sticky;
    top: 0;
    z-index: 2;
}

.inline-dashboard-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
}

.surface-cluster {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 32px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 16px;
}

.login-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin: 40px auto;
    max-width: 400px;
    padding: 32px;
    text-align: center;
}

.access-block {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    margin: 100px auto;
    max-width: 500px;
    padding: 40px;
    text-align: center;
}

.access-block-icon {
    align-items: center;
    background: var(--accent-glow);
    border-radius: 50%;
    color: var(--accent);
    display: flex;
    height: 64px;
    justify-content: center;
    margin: 0 auto 24px;
    width: 64px;
}

.access-block-icon svg {
    height: 32px;
    width: 32px;
}

.access-block-title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 22px;
    margin: 0 0 16px;
}

.access-block-copy {
    color: var(--text2);
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

.access-block--broken {
    animation: accessBlockShake 0.15s infinite;
    border-color: #ff4444;
    box-shadow: 0 0 20px rgba(255, 68, 68, 0.3), inset 0 0 20px rgba(255, 68, 68, 0.05);
    filter: hue-rotate(5deg);
    transform: rotate(-0.5deg);
}

.access-block--broken .access-block-icon {
    background: rgba(255, 68, 68, 0.15);
    color: #ff4444;
    animation: accessBlockPulse 0.8s ease-in-out infinite;
}

.access-block--broken .access-block-icon svg {
    transform: scaleX(-1);
}

.access-block--broken .access-block-title {
    animation: accessBlockGlitch 2s infinite;
    color: #ff4444;
    position: relative;
}

.access-block--broken .access-block-copy {
    color: #ff6666;
}

@keyframes accessBlockShake {
    0%, 100% { transform: rotate(-0.5deg) translateX(0); }
    25% { transform: rotate(0.5deg) translateX(2px); }
    50% { transform: rotate(-0.3deg) translateX(-1px); }
    75% { transform: rotate(0.3deg) translateX(1px); }
}

@keyframes accessBlockPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

@keyframes accessBlockGlitch {
    0%, 90%, 100% { opacity: 1; }
    92% { opacity: 0; }
    94% { opacity: 1; }
    96% { opacity: 0; }
    98% { opacity: 0.8; }
}

.lead-modal-head {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 24px;
}

.eyebrow {
    color: var(--text3);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 4px;
    text-transform: uppercase;
}

.lead-modal-title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 22px;
    line-height: 1.2;
    margin: 0;
}

.status-pill {
    border: 1px solid currentColor;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    padding: 6px 12px;
    white-space: nowrap;
}

.lead-detail-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.detail-card {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
}

.detail-title {
    align-items: center;
    color: var(--text3);
    display: flex;
    font-size: 10px;
    font-weight: 800;
    gap: 6px;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.detail-title svg {
    height: 14px;
    width: 14px;
}

.detail-stack {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.detail-line {
    color: var(--text2);
    font-size: 13px;
}

.detail-line strong {
    color: var(--text);
}

.detail-money {
    color: var(--q1);
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 800;
}

.lead-timeline {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-top: 24px;
    padding: 16px;
}

.timeline-track {
    display: flex;
    justify-content: space-between;
    padding: 0 10px;
    position: relative;
}

.timeline-line {
    background: var(--border);
    height: 2px;
    left: 20px;
    position: absolute;
    right: 20px;
    top: 12px;
    z-index: 1;
}

.timeline-point {
    position: relative;
    text-align: center;
    width: 86px;
    z-index: 2;
}

.timeline-dot {
    background: var(--accent);
    border: 4px solid var(--surface);
    border-radius: 50%;
    height: 24px;
    margin: 0 auto 8px;
    width: 24px;
}

.timeline-dot.success {
    background: var(--q1);
}

.timeline-label {
    color: var(--text3);
    font-size: 9px;
    text-transform: uppercase;
}

.timeline-date {
    color: var(--text);
    font-size: 11px;
    font-weight: 700;
}

.timeline-chip {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
    margin-top: 2px;
    padding: 4px 10px;
}

.lead-modal-footer {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    padding: 0 4px;
}

.lead-modal-owner {
    color: var(--text2);
    font-size: 12px;
}

.external-cta {
    align-items: center;
    background: var(--accent);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    color: var(--accent-contrast);
    display: flex;
    font-family: var(--font-display);
    font-weight: 800;
    justify-content: center;
    margin-top: 24px;
    min-height: 44px;
    text-decoration: none;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
    width: 100%;
}

.external-cta:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

@media (max-width: 640px) {
    .content-card {
        padding: 18px;
    }

    .mini-grid {
        grid-template-columns: 1fr;
    }

    .inline-dashboard-head {
        align-items: flex-start;
        flex-direction: column;
        gap: 8px;
    }

    .lead-modal-head,
    .lead-modal-footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .lead-detail-grid {
        grid-template-columns: 1fr;
    }
}

.audit-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: start;
}

.audit-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.audit-card:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-hover);
}

.audit-card.full {
    grid-column: 1 / -1;
}

.audit-card-title {
    font-family: var(--font-display);
    font-size: 14px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.audit-card-title .badge {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    color: var(--text3);
    background: var(--surface2);
    padding: 2px 8px;
    border-radius: 99px;
    margin-left: auto;
}

.audit-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.audit-kpi-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    box-shadow: var(--shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.audit-kpi-card:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

.audit-kpi-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-family: var(--font-display);
}

.audit-kpi-value {
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 800;
    color: var(--text);
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}

.audit-kpi-sub {
    font-size: 11px;
    color: var(--text3);
}

.audit-pct-badge {
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 700;
}

.audit-pct-badge.q1 {
    color: var(--q1);
}

.audit-pct-badge.q2 {
    color: var(--q2);
}

.audit-pct-badge.q3 {
    color: var(--q3);
}

.audit-pct-badge.q4 {
    color: var(--q4);
}

@media (max-width: 900px) {
    .audit-grid {
        grid-template-columns: 1fr;
    }

    .audit-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .audit-kpi-grid {
        grid-template-columns: 1fr;
    }
}

.mapeamento-hero {
    align-items: end;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.mapeamento-hero h1 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(30px, 4vw, 46px);
    line-height: 1;
    margin: 0 0 8px;
}

.mapeamento-subtitle {
    color: var(--text);
    font-size: 15px;
    font-weight: 700;
    margin: 0 0 6px;
}

.mapeamento-description {
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
    margin: 0;
    max-width: 780px;
}

.mapeamento-hero-meta {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 210px;
}

.mapeamento-hero-meta span {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    padding: 6px 9px;
    text-transform: uppercase;
}

.mapeamento-filter-bar {
    margin-bottom: 18px;
    max-height: none;
    overflow: visible;
    z-index: 15;
}

.mapeamento-filter-bar .filter-group {
    flex: 1 1 148px;
    min-width: 136px;
}

.mapeamento-filter-bar .filter-group:nth-child(6),
.mapeamento-filter-bar .filter-group:nth-child(8) {
    flex-basis: 190px;
}

.mapeamento-filter-bar .funil-filter-clear {
    align-self: flex-end;
    flex: 0 0 auto;
    min-height: var(--control-h);
    padding: 0 14px;
}

body.filters-collapsed .mapeamento-filter-bar {
    margin-bottom: 18px;
    max-height: none;
    opacity: 1;
    padding: 16px;
    pointer-events: auto;
}

.mapeamento-tabs {
    margin-bottom: 18px;
}

.mapeamento-kpis {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.mapeamento-kpis.compact {
    grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.mapeamento-grid-2 {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 22px;
}

.mapeamento-insight-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 22px;
}

.mapeamento-insight-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 106px;
    padding: 14px;
}

.mapeamento-insight-card strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
    line-height: 1.25;
}

.mapeamento-opportunity-strategy {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 22px;
}

.mapeamento-strategy-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 9px;
    min-height: 130px;
    padding: 14px;
}

.mapeamento-strategy-card strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 15px;
    line-height: 1.25;
}

.mapeamento-strategy-card span {
    color: var(--text2);
    font-size: 12px;
    line-height: 1.45;
}

.mapeamento-insight-card.positive {
    border-color: color-mix(in srgb, var(--q1) 32%, var(--border));
}

.mapeamento-insight-card.warning {
    border-color: color-mix(in srgb, var(--warning) 32%, var(--border));
}

.mapeamento-insight-card.danger {
    border-color: color-mix(in srgb, var(--danger) 32%, var(--border));
}

.mapeamento-badge {
    align-self: flex-start;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.4px;
    padding: 4px 8px;
    text-transform: uppercase;
}

.mapeamento-badge.positive {
    background: color-mix(in srgb, var(--q1) 12%, transparent);
    border-color: color-mix(in srgb, var(--q1) 32%, var(--border));
    color: var(--q1);
}

.mapeamento-badge.warning {
    background: color-mix(in srgb, var(--warning) 12%, transparent);
    border-color: color-mix(in srgb, var(--warning) 32%, var(--border));
    color: var(--warning);
}

.mapeamento-badge.danger {
    background: color-mix(in srgb, var(--danger) 12%, transparent);
    border-color: color-mix(in srgb, var(--danger) 32%, var(--border));
    color: var(--danger);
}

.mapeamento-badge.info {
    background: color-mix(in srgb, var(--info) 12%, transparent);
    border-color: color-mix(in srgb, var(--info) 32%, var(--border));
    color: var(--info);
}

.mapeamento-table table {
    min-width: 980px;
}

.mapeamento-loading {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text2);
    padding: 18px;
}

@media (max-width: 1180px) {
    .mapeamento-insight-grid,
    .mapeamento-opportunity-strategy {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .mapeamento-hero {
        align-items: flex-start;
        flex-direction: column;
    }

    .mapeamento-hero-meta {
        align-items: stretch;
        min-width: 0;
        width: 100%;
    }

    .mapeamento-grid-2,
    .mapeamento-insight-grid,
    .mapeamento-opportunity-strategy,
    .mapeamento-kpis.compact {
        grid-template-columns: 1fr;
    }
}

.attention-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.attention-hero .page-intro {
    margin-bottom: 0;
}

.attention-hero-note {
    max-width: 360px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    color: var(--text2);
    font-size: 12px;
    line-height: 1.5;
}

.attention-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(8px, 1.2vw, 16px);
    margin-bottom: 24px;
}

.attention-summary-card {
    position: relative;
    overflow: hidden;
    min-width: 0;
    container-type: inline-size;
    min-height: 105px;
    padding: clamp(12px, 1.5vw, 20px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, var(--surface) 0%, var(--surface2) 100%);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.attention-summary-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
    border-color: var(--border-strong);
}

.attention-summary-card span {
    display: block;
    color: var(--text3);
    font-family: var(--font-display);
    font-size: clamp(10px, 8cqw, 12px);
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-height: 1.2em;
}

.attention-summary-card strong {
    display: block;
    margin-bottom: auto;
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(16px, 18cqw, 40px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    overflow: hidden;
    max-width: 100%;
}

.attention-summary-card.summary-critical strong {
    color: var(--q4);
}

.attention-summary-card.summary-attention strong {
    color: var(--q3);
}

.attention-summary-card.summary-opportunity strong {
    color: var(--q2);
}

.attention-summary-card.summary-highlight strong {
    color: var(--q1);
}

.attention-layout,
.attention-insights-panel,
.attention-focus-panel {
    min-width: 0;
}

.attention-insights-panel,
.attention-focus-panel {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
    padding: 18px;
}

.attention-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.attention-panel-head span {
    color: var(--accent);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.attention-panel-head h3 {
    margin: 0;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 18px;
    letter-spacing: 0;
}

.insight-list {
    display: grid;
    gap: 10px;
}

.insight-list.is-collapsed .insight-card-extra {
    display: none;
}

.insight-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface2);
}

.insight-card.severity-critical {
    border-color: color-mix(in srgb, var(--q4) 36%, var(--border));
}

.insight-card.severity-attention {
    border-color: color-mix(in srgb, var(--q3) 32%, var(--border));
}

.insight-card.severity-highlight {
    border-color: color-mix(in srgb, var(--q1) 28%, var(--border));
}

.insight-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--accent);
}

.severity-critical .insight-icon {
    color: var(--q4);
}

.severity-attention .insight-icon {
    color: var(--q3);
}

.severity-opportunity .insight-icon {
    color: var(--q2);
}

.severity-highlight .insight-icon {
    color: var(--q1);
}

.insight-icon svg,
.attention-primary-icon svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.insight-head {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 6px;
}

.insight-severity,
.insight-type,
.insight-scope {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 0 7px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text2);
    font-size: 10px;
    font-weight: 700;
}

.insight-severity {
    color: var(--text);
    background: var(--surface);
}

.insight-card h3 {
    margin: 0 0 6px;
    color: var(--text);
    font-size: 15px;
    line-height: 1.25;
}

.insight-card p {
    margin: 0;
    color: var(--text2);
    font-size: 13px;
    line-height: 1.55;
}

.insight-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.insight-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 28px;
    padding: 0 9px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
}

.insight-meta-item span {
    color: var(--text3);
    font-size: 10px;
}

.insight-meta-item strong {
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 11px;
}

.insight-action {
    margin-top: 12px;
    padding: 12px;
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
}

.insight-action span {
    display: block;
    margin-bottom: 4px;
    color: var(--accent);
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.insight-action strong {
    color: var(--text);
    font-size: 12px;
    line-height: 1.5;
}

.attention-more-btn {
    margin-top: 12px;
    min-height: 36px;
    padding: 0 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface2);
    color: var(--text);
    cursor: pointer;
    font-weight: 700;
}

.attention-more-btn:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.attention-focus-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.attention-focus-list {
    display: grid;
    gap: 10px;
}

.attention-focus-item {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface2);
}

.attention-focus-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--surface);
    color: var(--text2);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
}

.attention-focus-main {
    min-width: 0;
}

.attention-focus-main strong,
.attention-focus-main span {
    display: block;
}

.attention-focus-main strong {
    color: var(--text);
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.attention-focus-main > span {
    color: var(--text3);
    font-size: 11px;
    margin-top: 2px;
}

.attention-focus-score {
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 800;
}

.focus-critical .attention-focus-score {
    color: var(--q4);
}

.focus-attention .attention-focus-score {
    color: var(--q3);
}

.attention-focus-bar {
    height: 5px;
    margin: 9px 0 8px;
    border-radius: 999px;
    background: var(--surface3);
    overflow: hidden;
}

.attention-focus-bar span {
    height: 100%;
    border-radius: inherit;
    background: var(--accent);
}

.focus-critical .attention-focus-bar span {
    background: var(--q4);
}

.focus-attention .attention-focus-bar span {
    background: var(--q3);
}

.attention-focus-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.attention-focus-metrics span {
    display: inline-flex;
    color: var(--text2);
    font-size: 10px;
}

.attention-empty {
    padding: 18px;
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    color: var(--text3);
    text-align: center;
}

@media (max-width: 980px) {
    .attention-hero,
    .attention-focus-grid {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

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

@media (max-width: 640px) {
    .attention-summary-grid {
        grid-template-columns: 1fr;
    }

    .insight-card,
    .attention-focus-item {
        grid-template-columns: 1fr;
    }

    .attention-focus-score {
        justify-self: start;
    }
}

.quartil-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    min-height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    margin-top: 6px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
}

.quartil-badge.q1,
.q1-badge {
    background: rgba(34, 197, 94, 0.15);
    color: var(--q1);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.quartil-badge.q2,
.q2-badge {
    background: rgba(245, 158, 11, 0.15);
    color: var(--q2);
    border: 1px solid rgba(245, 158, 11, 0.3);
}

.quartil-badge.q3,
.q3-badge {
    background: rgba(251, 113, 133, 0.15);
    color: var(--q3);
    border: 1px solid rgba(251, 113, 133, 0.3);
}

.quartil-badge.q4,
.q4-badge {
    background: rgba(239, 68, 68, 0.15);
    color: var(--q4);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.modal-overlay {
    align-items: center;
    background: var(--modal-overlay-bg, rgba(0, 0, 0, 0.62));
    backdrop-filter: blur(14px) saturate(0.92);
    -webkit-backdrop-filter: blur(14px) saturate(0.92);
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 24px;
    position: fixed;
    z-index: var(--z-modal) !important;
}

.modal-content {
    animation: modalPop 0.26s cubic-bezier(0.21, 1.02, 0.73, 1) both;
    background: var(--surface-elevated) !important;
    border: 1px solid var(--border);
    border-radius: var(--radius-xl) !important;
    box-shadow: var(--shadow-xl);
    color: var(--text);
    overflow: hidden;
    position: relative;
}

body.light-mode .modal-content {
    background: var(--surface-elevated) !important;
    box-shadow: var(--shadow-xl);
}

@keyframes modalPop {
    from {
        opacity: 0;
        transform: scale(0.96) translateY(14px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.modal-panel-sm {
    max-height: calc(100vh - 48px);
    max-width: 450px;
    overflow-y: auto;
    padding: 32px;
    width: min(90vw, 450px);
}

.modal-panel-md {
    max-height: calc(100vh - 48px);
    max-width: 600px;
    overflow-y: auto;
    padding: 24px;
    width: min(90vw, 600px);
}

.modal-panel-lg {
    max-height: 90vh;
    max-width: 800px;
    overflow-y: auto;
    padding: 24px;
    width: min(90vw, 800px);
}

.modal-panel-xl {
    max-height: 90vh;
    max-width: 900px;
    overflow-y: auto;
    padding: 24px;
    width: min(90vw, 900px);
}

.modal-title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 16px;
}

.modal-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 24px;
}

.modal-content > .icon-button,
.settings-modal-head .icon-button,
.request-modal-head .icon-button,
.kanban-export-close {
    align-items: center;
    background: var(--surface-elevated);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text2);
    cursor: pointer;
    display: inline-flex;
    height: 36px;
    justify-content: center;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
    width: 36px;
}

.modal-content > .icon-button:hover,
.settings-modal-head .icon-button:hover,
.request-modal-head .icon-button:hover,
.kanban-export-close:hover {
    background: var(--surface2);
    border-color: var(--border-strong);
    color: var(--text);
    transform: translateY(-1px);
}

.btn-ui {
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: inline-flex;
    font-weight: 700;
    gap: 8px;
    justify-content: center;
    min-height: var(--control-h);
    padding: 0 14px;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.btn-ui:hover {
    transform: translateY(-1px);
}

.btn-ui.secondary {
    background: var(--surface2);
    color: var(--text);
}

.btn-ui.ghost {
    background: transparent;
    color: var(--text2);
}

.btn-ui.danger {
    background: transparent;
    border-color: color-mix(in srgb, var(--q4) 60%, var(--border));
    color: var(--q4);
}

.btn-ui.danger.filled {
    background: var(--q4);
    border-color: var(--q4);
    color: #fff;
}

.btn-ui.outline {
    background: transparent;
    border-color: var(--border-strong);
    color: var(--text);
}

.btn-ui.outline:hover {
    background: var(--surface2);
    border-color: var(--accent);
    color: var(--accent);
}

.btn-ui.primary {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-contrast);
}

.request-modal {
    background: var(--surface-elevated) !important;
    border-color: var(--border) !important;
}

.request-modal::before {
    display: none;
}

.request-modal-head,
.settings-modal-head {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), color-mix(in srgb, var(--highlight) 7%, transparent));
    border-bottom: 1px solid var(--border);
}

.settings-user-modal,
.settings-confirm-modal {
    background: var(--surface-elevated) !important;
}

.settings-modal-head {
    margin: -24px -24px 22px;
    padding: 24px;
}

.modal-panel-sm .settings-modal-head {
    margin: -32px -32px 22px;
}

.rope-helper {
    color: var(--text2);
    font-size: 12px;
    margin-bottom: 32px;
}

.rope-control {
    align-items: center;
    display: flex;
    height: 40px;
    margin-bottom: 24px;
    position: relative;
}

.rope-track {
    background: var(--surface3);
    border-radius: 2px;
    height: 4px;
    position: absolute;
    width: 100%;
}

.rope-fill {
    background: var(--accent);
    border-radius: 3px;
    box-shadow: 0 0 8px var(--accent-glow);
    height: 6px;
    left: 0%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    z-index: 1;
}

.rope-range {
    -webkit-appearance: none;
    background: transparent;
    pointer-events: none;
    position: absolute;
    width: 100%;
}

.rope-range-min {
    z-index: 2;
}

.rope-range-max {
    z-index: 3;
}

.rope-labels {
    color: var(--text);
    display: flex;
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 700;
    justify-content: space-between;
    margin-bottom: 32px;
}

.export-reason-actions {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.export-reason-list {
    max-height: 320px;
    overflow-y: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px;
}

.export-reason-item {
    align-items: center;
    cursor: pointer;
    display: flex;
    gap: 10px;
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    transition: background 0.15s ease;
}

.export-reason-item:hover {
    background: var(--surface2);
}

.export-reason-item input[type="checkbox"] {
    accent-color: var(--accent);
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.export-reason-item span {
    color: var(--text);
    font-size: 14px;
}

.modal-desc {
    color: var(--text2);
    font-size: 14px;
    margin: 0 0 16px;
    line-height: 1.5;
}

.export-restriction {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: var(--radius-sm);
    color: var(--q4);
    font-size: 13px;
    line-height: 1.5;
    margin-bottom: 14px;
    padding: 10px 14px;
}

.export-summary {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 16px;
}

.export-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.export-summary-label {
    color: var(--text2);
    font-size: 14px;
}

.export-summary-value {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 800;
    color: var(--text);
}

.kanban-export-modal {
    display: grid;
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    height: min(86vh, 680px);
    max-height: calc(100vh - 32px);
    overflow: hidden;
    padding: 0;
    position: relative;
    width: min(94vw, 960px);
}

.kanban-export-close {
    height: 34px;
    position: absolute;
    right: 14px;
    top: 14px;
    width: 34px;
    z-index: 2;
}

.kanban-export-close svg {
    height: 17px;
    width: 17px;
}

.kanban-export-sidebar {
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), color-mix(in srgb, var(--highlight) 7%, transparent));
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 18px;
    min-width: 0;
    overflow: hidden;
    padding: 28px 22px;
}

.kanban-export-kicker {
    color: var(--text3);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.kanban-export-title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1;
    margin: -10px 0 0;
}

.kanban-export-step {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
    padding: 12px;
    word-break: break-word;
}

.kanban-export-metrics {
    display: grid;
    gap: 10px;
}

.kanban-export-metric,
.kanban-export-format {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px;
}

.kanban-export-metric span,
.kanban-export-format span {
    color: var(--text3);
    display: block;
    font-size: 10px;
    font-weight: 800;
    margin-bottom: 4px;
    text-transform: uppercase;
}

.kanban-export-metric strong,
.kanban-export-format strong {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 800;
}

.kanban-export-format {
    margin-top: auto;
}

.kanban-export-format strong {
    font-size: 14px;
}

.kanban-export-main {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    padding: 24px;
    padding-top: 62px;
}

.kanban-export-toolbar {
    align-items: center;
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
}

.kanban-export-search {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: flex;
    flex: 1;
    gap: 8px;
    min-height: 40px;
    min-width: 0;
    padding: 0 12px;
}

.kanban-export-search:focus-within {
    border-color: var(--border-strong);
    box-shadow: none;
}

.kanban-export-search svg {
    color: var(--text3);
    flex: 0 0 auto;
    height: 16px;
    width: 16px;
}

.kanban-export-search input {
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--text);
    flex: 1;
    font: inherit;
    min-width: 0;
    outline: 0 !important;
}

.kanban-export-search input::placeholder {
    color: var(--text3);
}

.kanban-export-search input:focus,
.kanban-export-search input:focus-visible {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
}

.kanban-export-actions {
    display: flex;
    flex: 0 0 auto;
    gap: 8px;
}

.kanban-export-columns {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
    overflow-y: auto;
    padding: 2px 4px 2px 0;
}

.kanban-export-group-title {
    align-items: center;
    color: var(--text2);
    display: flex;
    font-size: 11px;
    font-weight: 800;
    justify-content: space-between;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.kanban-export-group-title strong {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text3);
    font-size: 10px;
    padding: 2px 8px;
}

.kanban-export-options {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
}

.kanban-export-option {
    align-items: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: flex;
    gap: 10px;
    min-height: 58px;
    min-width: 0;
    padding: 10px;
    position: relative;
    transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.kanban-export-option:hover {
    background: var(--surface3);
    border-color: var(--border-strong);
}

.kanban-export-option:has(input:checked) {
    background: color-mix(in srgb, var(--accent) 9%, var(--surface));
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}

.kanban-export-option input {
    cursor: pointer;
    height: 100%;
    inset: 0;
    margin: 0;
    opacity: 0;
    position: absolute;
    width: 100%;
}

.kanban-export-option input:focus,
.kanban-export-option input:focus-visible {
    box-shadow: none !important;
    outline: 0 !important;
}

.kanban-export-check {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    color: transparent;
    display: flex;
    flex: 0 0 auto;
    height: 20px;
    justify-content: center;
    width: 20px;
}

.kanban-export-option:has(input:checked) .kanban-export-check {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-contrast);
}

.kanban-export-check svg {
    height: 13px;
    width: 13px;
}

.kanban-export-option-text {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.kanban-export-option-text strong,
.kanban-export-option-text small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.kanban-export-option-text strong {
    color: var(--text);
    font-size: 13px;
    font-weight: 800;
}

.kanban-export-option-text small {
    color: var(--text3);
    font-size: 11px;
}

.kanban-export-option.hidden {
    display: none;
}

.kanban-export-empty {
    align-items: center;
    background: var(--surface2);
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-sm);
    color: var(--text3);
    display: flex;
    font-size: 14px;
    justify-content: center;
    min-height: 180px;
    padding: 24px;
    text-align: center;
}

.kanban-export-empty.search-empty {
    min-height: 96px;
}

.kanban-export-footer {
    align-items: center;
    border-top: 1px solid var(--border);
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin: 18px -24px -24px;
    padding: 16px 24px;
}

.kanban-export-footer .btn-ui.primary {
    gap: 8px;
}

.kanban-export-footer .btn-ui:disabled {
    cursor: not-allowed;
    opacity: 0.48;
    transform: none;
}

@media (max-width: 760px) {
    .modal-overlay {
        padding: 14px;
    }

    .kanban-export-modal {
        grid-template-columns: 1fr;
        height: min(92vh, 760px);
        max-height: 92vh;
    }

    .kanban-export-sidebar {
        border-bottom: 1px solid var(--border);
        border-right: 0;
        gap: 12px;
        padding: 22px;
        padding-right: 58px;
    }

    .kanban-export-title {
        font-size: 24px;
    }

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

    .kanban-export-format {
        display: none;
    }

    .kanban-export-main {
        padding: 16px;
    }

    .kanban-export-toolbar,
    .kanban-export-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .kanban-export-actions,
    .kanban-export-footer .btn-ui {
        width: 100%;
    }

    .kanban-export-actions .btn-ui {
        flex: 1;
    }

    .kanban-export-options {
        grid-template-columns: 1fr;
    }

    .kanban-export-footer {
        margin: 16px -16px -16px;
        padding: 14px 16px;
    }
}

.top-item.rank-1,
.top-item.rank-2,
.top-item.rank-3,
.top-item.worst-1,
.top-item.worst-2,
.top-item.worst-3 {
    position: relative;
    overflow: hidden;
}

.top-item.rank-1 {
    background: var(--accent-glow);
    border: 1px solid var(--accent);
}

.top-item.rank-2 {
    background: rgba(100, 116, 139, 0.15);
    border: 1px solid #94a3b8;
}

.top-item.rank-3 {
    background: rgba(245, 158, 11, 0.15);
    border: 1px solid #f59e0b;
}

.top-item.worst-1 {
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid var(--q4);
    transform: scale(1.02);
}

.top-item.worst-2 {
    background: rgba(248, 113, 113, 0.1);
    border: 1px solid rgba(248, 113, 113, 0.5);
}

.top-item.worst-3 {
    background: rgba(252, 165, 165, 0.1);
    border: 1px solid rgba(252, 165, 165, 0.5);
}

#proj-landing-tbody b,
#proj-sup-tbody b {
    font-family: var(--font-mono);
    font-size: 1.1em;
}

#page-projecao .top-item {
    border-radius: var(--radius-lg);
    padding: 16px;
    background: var(--surface);
}

body.ui-density-compact .app-main {
    padding: 20px clamp(14px, 2vw, 26px) 30px;
}

body.ui-density-compact .kpi-row {
    gap: 10px;
    margin-bottom: 16px;
}

body.ui-density-compact .kpi-card,
body.ui-density-compact .chart-wrap,
body.ui-density-compact .closer-card,
body.ui-density-compact .sup-card,
body.ui-density-compact .settings-card {
    padding: 14px;
}

body.ui-density-compact .kpi-card {
    min-height: 92px;
}

body.ui-density-compact .cards-grid,
body.ui-density-compact .settings-shell,
body.ui-density-compact .settings-panel {
    gap: 12px;
}

body.ui-density-compact .section-title {
    margin-bottom: 10px;
}

body.ui-density-spacious .app-main {
    padding: 34px clamp(22px, 3vw, 44px) 52px;
}

body.ui-density-spacious .kpi-row {
    gap: 18px;
    margin-bottom: 30px;
}

body.ui-density-spacious .kpi-card,
body.ui-density-spacious .chart-wrap,
body.ui-density-spacious .closer-card,
body.ui-density-spacious .sup-card,
body.ui-density-spacious .settings-card {
    padding: 24px;
}

body.ui-density-spacious .kpi-card {
    min-height: 118px;
}

body.ui-density-spacious .cards-grid,
body.ui-density-spacious .settings-shell,
body.ui-density-spacious .settings-panel {
    gap: 22px;
}

body.ui-density-spacious .section-title {
    margin-bottom: 20px;
}

.tier-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 800;
    padding: 3px 10px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    min-width: 28px;
}

.tier-badge.tier-s {
    background: rgba(168, 85, 247, 0.15);
    color: #a855f7;
    border: 1px solid rgba(168, 85, 247, 0.35);
    text-shadow: 0 0 6px rgba(168, 85, 247, 0.3);
}

.tier-badge.tier-a {
    background: rgba(34, 197, 94, 0.15);
    color: var(--q1);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.tier-badge.tier-b {
    background: var(--accent-glow);
    color: var(--accent);
    border: 1px solid rgba(0, 101, 255, 0.28);
}

.tier-badge.tier-c {
    background: rgba(249, 115, 22, 0.15);
    color: var(--q3);
    border: 1px solid rgba(249, 115, 22, 0.3);
}

.tier-badge.tier-d {
    background: rgba(239, 68, 68, 0.15);
    color: var(--q4);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.efet-index-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 12px 16px;
    transition: box-shadow 0.2s, transform 0.2s;
}

.efet-index-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}

.efet-index-item.tier-s-aura {
    border-color: rgba(168, 85, 247, 0.35);
    background: rgba(168, 85, 247, 0.08);
}

.efet-index-item.tier-a-aura {
    border-color: rgba(34, 197, 94, 0.28);
    background: rgba(34, 197, 94, 0.08);
}

.efet-index-item.tier-b-aura {
    border-color: color-mix(in srgb, var(--accent) 24%, var(--border));
    background: var(--accent-glow);
}

.efet-explain-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    margin-bottom: 24px;
    line-height: 1.6;
}

.efet-tier-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    margin-top: 12px;
}

@media (max-width: 900px) {
    .efet-tier-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.efet-tier-card {
    background: var(--surface2);
    border: 1px solid var(--border);
    padding: 10px;
    border-radius: var(--radius-sm);
    text-align: center;
}

.efet-tier-card .tier-label {
    font-weight: 700;
    font-size: 13px;
}

.efet-tier-card .tier-range {
    font-size: 10px;
    color: var(--text3);
    margin-top: 2px;
}

.efet-score-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.efet-score-track {
    flex: 1;
    height: 5px;
    background: var(--surface3-solid);
    border-radius: 3px;
    overflow: hidden;
}

.efet-score-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.8s ease;
}

.efet-score-val {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text3);
    min-width: 48px;
    text-align: right;
}

.dispersao-summary {
  margin-bottom: 24px;
}

.dispersao-empty-summary {
  padding: 32px 24px;
  text-align: center;
  color: var(--text3);
  font-size: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.dispersao-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: clamp(8px, 1.2vw, 16px);
}

.dispersao-kpi-card {
  min-width: 0;
  container-type: inline-size;
  min-height: 105px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface2) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: clamp(12px, 1.5vw, 20px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.dispersao-kpi-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
  border-color: var(--border-strong);
}

.dispersao-kpi-label {
  font-family: var(--font-display);
  font-size: clamp(10px, 8cqw, 12px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text3);
  margin-bottom: 8px;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.2;
  min-height: 2.4em;
  max-width: 100%;
}

.dispersao-kpi-value {
  font-family: var(--font-display);
  font-size: clamp(16px, 18cqw, 40px);
  color: var(--text);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
  max-width: 100%;
  margin-bottom: auto;
}

.dispersao-kpi-value.accent { color: var(--accent); }

.dispersao-kpi-value.good { color: var(--q1); }

.dispersao-kpi-value.warn { color: var(--q3); }

.dispersao-kpi-value.danger { color: var(--q4); }

.dispersao-kpi-value-gmv {
  font-size: clamp(15px, calc(18cqw - 2px), 38px);
}

.dispersao-kpi-sub {
  min-height: 20px;
  margin-top: 8px;
  color: var(--text3);
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.2;
}

.dispersao-section {
  margin-bottom: 32px;
}

.dispersao-section-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--text);
  margin-bottom: 12px;
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.dispersao-section-title span {
  font-weight: 400;
  font-size: 12px;
  color: var(--text3);
}

.dispersao-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.dispersao-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 12px;
}

.dispersao-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--surface2);
  padding: 10px 12px;
  text-align: left;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text3);
  font-weight: 700;
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}

.dispersao-th-pos { width: 50px; text-align: center !important; }

.dispersao-th-closer { min-width: 140px; }

.dispersao-th-sup { min-width: 100px; }

.dispersao-th-value { min-width: 80px; text-align: right !important; }

.dispersao-th-vs {
  min-width: 110px;
  text-align: center !important;
  color: var(--accent) !important;
}

.dispersao-table tbody tr {
  transition: background-color 0.15s ease;
}

.dispersao-table tbody tr:hover {
  background: var(--surface2);
}

.dispersao-table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}

.dispersao-td-pos {
  text-align: center;
  font-weight: 700;
  font-family: var(--font-mono);
}

.dispersao-pos-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 24px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 800;
  background: var(--surface2);
  color: var(--text2);
}

.dispersao-pos-badge.pos-top-1 {
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  color: #000;
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.3);
}

.dispersao-pos-badge.pos-top-2 {
  background: linear-gradient(135deg, #94a3b8, #64748b);
  color: #fff;
  box-shadow: 0 2px 8px rgba(100, 116, 139, 0.3);
}

.dispersao-pos-badge.pos-top-3 {
  background: linear-gradient(135deg, #d97706, #b45309);
  color: #fff;
  box-shadow: 0 2px 8px rgba(180, 83, 9, 0.25);
}

.dispersao-td-closer {
  font-weight: 600;
  font-size: 13px;
}

.dispersao-td-sup {
  color: var(--text2);
  font-size: 11px;
}

.dispersao-td-value {
  text-align: right;
  font-family: var(--font-mono);
  font-size: 12px;
}

.dispersao-td-value strong {
  font-weight: 800;
}

.dispersao-td-gap {
  text-align: center;
  padding: 6px 8px !important;
  border-radius: 0;
  transition: background-color 0.2s ease;
}

.dispersao-td-self {
  color: var(--text3) !important;
  font-size: 11px;
}

.dispersao-gap-pp {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.3;
}

.dispersao-gap-rel {
  font-family: var(--font-mono);
  font-size: 9px;
  opacity: 0.7;
  line-height: 1.3;
}

.dispersao-single {
  padding: 24px;
  text-align: center;
  color: var(--text2);
  font-size: 13px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.dispersao-single strong {
  color: var(--accent);
}

@media (max-width: 768px) {
  .dispersao-kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .dispersao-kpi-value {
    font-size: 18px;
  }

  .dispersao-table {
    font-size: 11px;
  }

  .dispersao-th-vs,
  .dispersao-td-gap {
    min-width: 90px;
  }
}

body.privacy-mode-active .is-currency,
body.privacy-mode-active .privacy-sensitive,
body.privacy-mode-active .dispersao-kpi-value-gmv {
    filter: blur(6px);
    transition: filter 0.2s ease;
    cursor: pointer;
}

body.privacy-mode-active .is-currency:hover,
body.privacy-mode-active .privacy-sensitive:hover,
body.privacy-mode-active .dispersao-kpi-value-gmv:hover {
    filter: blur(0);
}

input:focus,
input:focus-visible,
select:focus,
select:focus-visible,
textarea:focus,
textarea:focus-visible,
.settings-select:focus,
.multi-select-trigger:focus,
.request-field input:focus,
.request-field select:focus,
.request-field textarea:focus,
.request-stunning-field input:focus,
.request-stunning-field select:focus,
.request-stunning-field textarea:focus {
    border-color: var(--border) !important;
    box-shadow: none !important;
    outline: none !important;
}
