/* =====================================================
   PayoApps Dashboard — Crimson Neon Design System
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
    /* ===== Surface ===== */
    --bg-base: #08070a;
    --bg-primary: #0b0a0e;
    --bg-secondary: rgba(20, 16, 22, 0.55);
    --bg-card: rgba(18, 14, 20, 0.62);
    --bg-card-hover: rgba(28, 20, 28, 0.85);
    --bg-input: rgba(255, 255, 255, 0.025);
    --bg-input-focus: rgba(255, 60, 80, 0.06);
    --bg-sidebar: rgba(10, 8, 12, 0.85);
    --bg-elevated: rgba(24, 18, 26, 0.9);

    /* ===== Borders ===== */
    --border: rgba(255, 255, 255, 0.07);
    --border-hover: rgba(255, 80, 100, 0.25);
    --border-focus: rgba(255, 70, 90, 0.55);
    --border-subtle: rgba(255, 255, 255, 0.035);
    --border-crimson: rgba(255, 50, 70, 0.35);

    /* ===== Text ===== */
    --text-primary: #f4f4f5;
    --text-secondary: #a8a3ad;
    --text-muted: #6e6873;
    --text-white: #ffffff;

    /* ===== Brand: Crimson Neon ===== */
    --accent: #ff2d4f;          /* primary crimson */
    --accent-hover: #ff5773;
    --accent-deep: #d11237;
    --accent-glow: rgba(255, 45, 79, 0.45);
    --accent-dim: rgba(255, 45, 79, 0.12);
    --accent-soft: rgba(255, 45, 79, 0.06);
    --accent-grad: linear-gradient(135deg, #ff2d4f 0%, #ff5773 50%, #ff2d4f 100%);
    --accent-grad-soft: linear-gradient(135deg, rgba(255,45,79,0.18) 0%, rgba(255,87,115,0.05) 100%);

    /* ===== Semantic ===== */
    --success: #10b981;
    --success-bg: rgba(16, 185, 129, 0.1);
    --error: #ef4444;
    --error-bg: rgba(239, 68, 68, 0.1);
    --warning: #f59e0b;
    --warning-bg: rgba(245, 158, 11, 0.1);
    --info: #38bdf8;
    --info-bg: rgba(56, 189, 248, 0.1);

    /* ===== Layout ===== */
    --sidebar-width: 280px;
    --topbar-height: 60px;
    --radius-sm: 8px;
    --radius: 14px;
    --radius-lg: 22px;
    --radius-xl: 32px;

    /* ===== Shadows ===== */
    --shadow-sm: 0 4px 14px rgba(0, 0, 0, 0.35);
    --shadow: 0 14px 36px rgba(0, 0, 0, 0.55);
    --shadow-lg: 0 28px 60px rgba(0, 0, 0, 0.85);
    --shadow-crimson: 0 14px 40px rgba(255, 45, 79, 0.18);
    --shadow-crimson-lg: 0 22px 60px rgba(255, 45, 79, 0.32);
    --glow-crimson: 0 0 24px rgba(255, 45, 79, 0.5);

    --transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

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

body {
    font-family: 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100vh;
    overscroll-behavior: none;
    background-image:
        radial-gradient(ellipse 80% 60% at 18% 0%, rgba(255, 45, 79, 0.10) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 95% 100%, rgba(140, 20, 60, 0.08) 0%, transparent 55%);
    background-attachment: fixed;
}

h1, h2, h3, h4, .card-title, .topbar-title {
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--text-white);
}

a { color: var(--text-secondary); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--accent); }

code, pre, .mono { font-family: 'JetBrains Mono', monospace; font-size: 0.92em; }

/* ===== Selection ===== */
::selection { background: var(--accent-dim); color: var(--text-white); }

/* ===== Scrollbar ===== */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(255,45,79,0.25), rgba(255,45,79,0.08));
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, var(--accent), var(--accent-deep));
}

/* ===== App Layout ===== */
.app-layout { display: flex; min-height: 100vh; }

/* ===== Sidebar ===== */
.sidebar {
    width: var(--sidebar-width);
    background: var(--bg-sidebar);
    border-right: 1px solid var(--border);
    height: 100vh;
    position: fixed;
    top: 0; left: 0; z-index: 100;
    display: flex; flex-direction: column;
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
}
.sidebar::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 200px;
    background: radial-gradient(ellipse at top left, rgba(255,45,79,0.10), transparent 70%);
    pointer-events: none;
}

.sidebar-header {
    padding: 16px 24px;
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
    z-index: 1;
}
.sidebar-header .brand {
    display: flex;
    align-items: center;
    gap: 12px;
}
.sidebar-header .brand-mark {
    width: 38px; height: 38px;
    border-radius: 11px;
    background: var(--accent-grad);
    display: flex; align-items: center; justify-content: center;
    color: white; font-weight: 900; font-size: 18px;
    box-shadow: var(--shadow-crimson), inset 0 1px 0 rgba(255,255,255,0.25);
    letter-spacing: -0.04em;
    position: relative;
    overflow: hidden;
}
.sidebar-header .brand-mark::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,0.2) 50%, transparent 60%);
    animation: brandShine 4s ease-in-out infinite;
}
@keyframes brandShine { 0%,100% { transform: translateX(-100%); } 50% { transform: translateX(100%); } }
.sidebar-header .brand-name {
    font-size: 18px;
    font-weight: 800;
    color: var(--text-white);
    letter-spacing: -0.02em;
}
.sidebar-header .brand-name span { color: var(--accent); }
.sidebar-header .sub {
    font-size: 11px; color: var(--text-muted);
    font-weight: 600; margin-top: 8px; margin-left: 50px;
    letter-spacing: 0.12em; text-transform: uppercase;
}

.sidebar-nav {
    flex: 1; padding: 18px 14px; overflow-y: auto;
    position: relative; z-index: 1;
}
.sidebar-section { margin-bottom: 24px; }
.sidebar-section-title {
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.14em; color: var(--text-muted);
    padding: 0 14px 10px;
}

/* nav-item (itens "soltos" tipo Conexão & Bot / Gestão SaaS) */
.nav-item {
    display: flex; align-items: center; gap: 13px;
    padding: 11px 14px; border-radius: 11px;
    color: var(--text-secondary); font-size: 14.5px; font-weight: 500;
    cursor: pointer; transition: var(--transition);
    margin-bottom: 3px;
    position: relative;
    overflow: hidden;
}
.nav-item::before {
    content: ''; position: absolute; left: 0; top: 50%;
    width: 3px; height: 0; transform: translateY(-50%);
    background: var(--accent); border-radius: 0 3px 3px 0;
    transition: height 0.3s ease;
    box-shadow: 0 0 12px var(--accent-glow);
}
.nav-item:hover {
    background: var(--bg-input);
    color: var(--text-white);
    padding-left: 18px;
}
.nav-item:hover::before { height: 18px; }
.nav-item.active {
    background: linear-gradient(90deg, rgba(255,45,79,0.12), rgba(255,45,79,0.02));
    color: var(--text-white); font-weight: 600;
    border: 1px solid var(--accent-dim);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.nav-item.active::before { height: 24px; }
.nav-item .icon { display: flex; color: var(--text-muted); transition: color 0.18s; }
.nav-item .icon i { width: 17px; height: 17px; }
.nav-item:hover .icon { color: var(--accent); }
.nav-item.active .icon { color: var(--accent); filter: drop-shadow(0 0 6px var(--accent-glow)); }
.nav-item .nav-badge {
    margin-left: auto;
    font-size: 10px; font-weight: 700;
    padding: 2px 7px; border-radius: 99px;
    background: var(--accent-grad); color: white;
    letter-spacing: 0.04em; text-transform: uppercase;
}
.nav-item .nav-badge.beta { background: rgba(56,189,248,0.18); color: #7dd3fc; }
.nav-item .nav-badge.new { box-shadow: 0 0 12px var(--accent-glow); }

/* ===== Main Content ===== */
.main-content {
    margin-left: var(--sidebar-width);
    flex: 1;
    min-height: 100vh;
    display: flex; flex-direction: column;
}

.topbar {
    height: var(--topbar-height);
    background: rgba(11, 10, 14, 0.55);
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 24px; position: sticky; top: 0; z-index: 50;
}
.topbar-title {
    font-size: 19px; font-weight: 700; letter-spacing: -0.02em;
    display: flex; align-items: center; gap: 12px;
}
.topbar-title::before {
    content: ''; width: 6px; height: 22px; border-radius: 3px;
    background: var(--accent-grad);
    box-shadow: 0 0 14px var(--accent-glow);
}
.topbar-actions { display: flex; align-items: center; gap: 14px; }

.page-content {
    padding: 12px 32px 60px;
    max-width: 1480px; flex: 1; width: 100%; margin: 0 auto;
}

/* ===== Page Header ===== */
.page-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 36px; gap: 24px; flex-wrap: wrap; }
.page-header h1 { font-size: 32px; font-weight: 800; letter-spacing: -0.025em; margin-bottom: 6px; }
.page-header .page-sub { color: var(--text-secondary); font-size: 15px; max-width: 640px; }
.page-header .page-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ===== Cards ===== */
.card {
    background: var(--bg-card);
    backdrop-filter: blur(28px);
    -webkit-backdrop-filter: blur(28px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 28px;
    box-shadow: var(--shadow);
    margin-bottom: 28px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent-dim), transparent);
}
.card:hover {
    border-color: var(--border-hover);
    box-shadow: var(--shadow-lg), 0 0 0 1px var(--accent-dim);
}
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 22px; gap: 16px; flex-wrap: wrap; }
.card-title { font-size: 18px; color: var(--text-white); font-weight: 700; letter-spacing: -0.015em; }
.card-subtitle { font-size: 13px; color: var(--text-muted); margin-top: 4px; }

/* ===== Stats Grid ===== */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    margin-bottom: 32px;
}
.stat-card {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px 26px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
    cursor: default;
}
.stat-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity: 0; transition: opacity 0.4s;
}
.stat-card::after {
    content: ''; position: absolute; right: -40px; top: -40px;
    width: 140px; height: 140px;
    background: radial-gradient(circle, var(--accent-soft) 0%, transparent 70%);
    opacity: 0; transition: opacity 0.4s;
}
.stat-card:hover {
    transform: translateY(-4px);
    border-color: var(--border-hover);
    box-shadow: var(--shadow-lg);
}
.stat-card:hover::before, .stat-card:hover::after { opacity: 1; }

.stat-card-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.stat-card-label { font-size: 13px; color: var(--text-secondary); font-weight: 600; letter-spacing: 0.02em; }
.stat-card-icon {
    width: 38px; height: 38px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    background: var(--accent-soft);
    border: 1px solid var(--accent-dim);
    color: var(--accent);
    flex-shrink: 0;
}
.stat-card-value {
    font-size: 30px; color: var(--text-white);
    font-weight: 800; line-height: 1.1;
    letter-spacing: -0.03em;
    font-variant-numeric: tabular-nums;
}
.stat-card-delta {
    margin-top: 10px; display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 600;
}
.stat-card-delta.up { color: var(--success); }
.stat-card-delta.down { color: var(--error); }

/* Legacy stat-icon support */
.stat-icon {
    width: 52px; height: 52px; border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; flex-shrink: 0;
    background: var(--accent-soft);
    border: 1px solid var(--accent-dim);
    color: var(--accent);
    box-shadow: inset 0 0 14px var(--accent-soft);
}
.stat-info h3 { font-size: 28px; color: var(--text-white); font-weight: 800; line-height: 1.1; margin-bottom: 4px; letter-spacing: -0.025em; font-variant-numeric: tabular-nums; }
.stat-info p { font-size: 13px; color: var(--text-secondary); font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em; }

/* ===== Forms ===== */
.form-group { margin-bottom: 22px; }
.form-label {
    display: block; font-size: 13px; font-weight: 600;
    color: var(--text-primary); margin-bottom: 8px;
    letter-spacing: 0.01em;
}
.form-label .req { color: var(--accent); margin-left: 2px; }
.form-help { font-size: 12px; color: var(--text-muted); margin-top: 6px; }

.form-input, .form-select, .form-textarea {
    width: 100%; padding: 13px 16px;
    background: var(--bg-input);
    border: 1px solid var(--border); border-radius: var(--radius);
    color: var(--text-white); font-family: inherit; font-size: 14.5px;
    transition: var(--transition); outline: none;
}
.form-input::placeholder, .form-textarea::placeholder { color: var(--text-muted); }
.form-input:hover, .form-select:hover, .form-textarea:hover { border-color: rgba(255,255,255,0.14); }
.form-input:focus, .form-select:focus, .form-textarea:focus {
    border-color: var(--accent);
    background: var(--bg-input-focus);
    box-shadow: 0 0 0 4px var(--accent-dim);
}
.form-textarea { resize: vertical; min-height: 100px; }

select.form-input, .form-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 16px;
    padding-right: 40px;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
select.form-input:focus, .form-select:focus {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ff2d4f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}

/* Fix dropdown options visibility */
option {
    background-color: #120e14;
    color: #ffffff;
}

/* Custom Checkbox */
input[type="checkbox"]:not(.switch input) {
    appearance: none;
    -webkit-appearance: none;
    width: 20px; height: 20px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 6px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    position: relative;
    top: 4px; /* alinhamento sutil com texto */
}
input[type="checkbox"]:not(.switch input):hover {
    border-color: rgba(255,255,255,0.2);
}
input[type="checkbox"]:not(.switch input):checked {
    background: var(--accent);
    border-color: var(--accent);
}
input[type="checkbox"]:not(.switch input):checked::after {
    content: '';
    position: absolute;
    width: 5px; height: 10px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-top: -2px;
}

.search-bar-container { position: relative; width: 100%; max-width: 360px; }
.search-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); font-size: 16px; color: var(--text-muted); pointer-events: none; }
.search-input { padding-left: 44px; border-radius: 99px; }

/* Switch */
.switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.switch input { display: none; }
.switch .slider {
    position: absolute; cursor: pointer; inset: 0;
    background: rgba(255,255,255,0.08);
    border-radius: 24px;
    transition: 0.3s;
    border: 1px solid var(--border);
}
.switch .slider::before {
    content: ''; position: absolute; height: 16px; width: 16px;
    left: 3px; top: 50%; transform: translateY(-50%);
    background: white; border-radius: 50%;
    transition: 0.3s;
}
.switch input:checked + .slider {
    background: var(--accent-grad);
    border-color: var(--accent);
    box-shadow: 0 0 12px var(--accent-glow);
}
.switch input:checked + .slider::before { left: 23px; }

/* ===== Buttons ===== */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 22px; border: 1px solid transparent; border-radius: 11px;
    font-family: inherit; font-size: 14px; font-weight: 600; cursor: pointer;
    transition: var(--transition); outline: none;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
}
.btn:active { transform: scale(0.97); }

.btn-primary {
    background: var(--accent-grad);
    color: white;
    border-color: transparent;
    box-shadow: var(--shadow-crimson);
}
.btn-primary::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%);
    transform: translateX(-100%);
    transition: transform 0.6s;
}
.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-crimson-lg);
}
.btn-primary:hover::after { transform: translateX(100%); }

.btn-secondary {
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    color: var(--text-white);
}
.btn-secondary:hover {
    border-color: var(--accent-dim);
    background: rgba(255,255,255,0.08);
    color: var(--accent);
}

.btn-ghost {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid transparent;
}
.btn-ghost:hover { background: rgba(255,255,255,0.05); color: var(--text-white); }

.btn-success { background: var(--success-bg); border: 1px solid rgba(16,185,129,0.4); color: #34d399; }
.btn-success:hover { background: rgba(16, 185, 129, 0.2); }

.btn-danger { background: var(--error-bg); border: 1px solid rgba(239,68,68,0.4); color: #fca5a5; }
.btn-danger:hover { background: rgba(239, 68, 68, 0.22); border-color: rgba(239,68,68,0.6); color: white; }

.btn-sm { padding: 8px 14px; font-size: 13px; border-radius: 9px; }
.btn-xs { padding: 6px 11px; font-size: 12px; border-radius: 8px; }
.btn-lg { padding: 15px 30px; font-size: 16px; border-radius: 14px; }

.btn-icon {
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border); border-radius: 10px;
    width: 36px; height: 36px;
    cursor: pointer; transition: var(--transition);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--text-secondary);
    padding: 0;
}
.btn-icon:hover { color: var(--accent); background: var(--accent-soft); border-color: var(--accent-dim); transform: translateY(-2px); }

.expand-btn {
    background: transparent; border: 1px solid var(--border); color: var(--text-secondary); cursor: pointer;
    font-size: 13px; padding: 6px 10px; border-radius: 8px; transition: 0.18s; font-family: 'JetBrains Mono', monospace;
}
.expand-btn:hover { background: var(--bg-input-focus); color: var(--accent); border-color: var(--accent-dim); }

/* ===== Tables ===== */
.table-container {
    overflow-x: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
table { width: 100%; border-collapse: collapse; }
th {
    text-align: left; padding: 16px 22px;
    background: rgba(0,0,0,0.35);
    font-size: 11.5px; font-weight: 700;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border);
    letter-spacing: 0.12em; text-transform: uppercase;
}
td { padding: 18px 22px; border-bottom: 1px solid var(--border); font-size: 14.5px; color: var(--text-primary); font-weight: 400; vertical-align: middle; }
tr { transition: background var(--transition); background: transparent; }
tr:hover { background: rgba(255,45,79,0.04); }
tr:last-child td { border-bottom: none; }
tr.hidden-row { display: none; }

/* ===== Badges ===== */
.badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px;
    border-radius: 99px; font-size: 12px; font-weight: 600;
    border: 1px solid rgba(255,255,255,0.05);
    letter-spacing: 0.02em;
}
.badge-success { background: var(--success-bg); color: #34d399; border-color: rgba(52, 211, 153, 0.25); }
.badge-error { background: var(--error-bg); color: #f87171; border-color: rgba(248, 113, 113, 0.25); }
.badge-warning { background: var(--warning-bg); color: #fbbf24; border-color: rgba(251, 191, 36, 0.25); }
.badge-info { background: var(--info-bg); color: #7dd3fc; border-color: rgba(125, 211, 252, 0.25); }
.badge-neutral { background: rgba(255,255,255,0.05); color: var(--text-secondary); border-color: var(--border); }
.badge-accent { background: var(--accent-soft); color: var(--accent-hover); border-color: var(--accent-dim); }
.badge-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; box-shadow: 0 0 8px currentColor; }

/* ===== Modal ===== */
.modal-overlay {
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, 0.78);
    backdrop-filter: blur(14px);
    z-index: 1000;
    display: flex; align-items: flex-start; justify-content: center;
    padding: 5vh 24px 24px;
    overflow-y: auto;
    animation: overlayIn 0.25s ease;
}
@keyframes overlayIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
    background: rgba(15, 12, 17, 0.96);
    border: 1px solid var(--border-hover);
    backdrop-filter: blur(30px);
    border-radius: var(--radius-xl);
    padding: 36px;
    width: 100%; max-width: 540px;
    margin-bottom: 5vh;
    box-shadow: 0 50px 100px rgba(0, 0, 0, 0.9), 0 0 0 1px var(--accent-dim), inset 0 1px 0 rgba(255,255,255,0.06);
    animation: modalIn 0.45s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
}
.modal::before {
    content: ''; position: absolute;
    top: 0; left: 50%; transform: translateX(-50%);
    width: 60%; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    box-shadow: 0 0 20px var(--accent-glow);
}
@keyframes modalIn {
    from { opacity: 0; transform: scale(0.96) translateY(20px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}
.modal.modal-lg { max-width: 820px; }
.modal.modal-xl { max-width: 1080px; }
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; gap: 16px; }
.modal-title { font-size: 22px; font-weight: 700; color: var(--text-white); letter-spacing: -0.02em; }
.modal-close {
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border); color: var(--text-muted); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; transition: 0.25s;
    width: 36px; height: 36px; border-radius: 50%;
    flex-shrink: 0;
}
.modal-close:hover { color: var(--accent); background: var(--accent-soft); border-color: var(--accent-dim); transform: rotate(90deg); }
.modal-footer {
    display: flex; justify-content: flex-end; gap: 12px;
    margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--border);
}

/* ===== Toasts ===== */
.toast-container { position: fixed; bottom: 32px; right: 32px; z-index: 9999; display: flex; flex-direction: column; gap: 12px; }
.toast {
    background: rgba(15, 12, 17, 0.96);
    color: var(--text-white);
    border: 1px solid var(--border-hover);
    border-radius: var(--radius);
    padding: 14px 20px; min-width: 300px; font-size: 14px; font-weight: 500;
    display: flex; align-items: center; gap: 14px;
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(20px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}
.toast::before {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
    background: var(--accent);
    box-shadow: 0 0 10px var(--accent-glow);
}
.toast.error::before { background: var(--error); box-shadow: 0 0 10px rgba(239,68,68,0.5); }
.toast.success::before { background: var(--success); box-shadow: 0 0 10px rgba(16,185,129,0.5); }
.toast.warning::before { background: var(--warning); }

/* Sale toast (real-time) */
.toast.sale-toast {
    background: linear-gradient(135deg, rgba(15,12,17,0.96), rgba(40,8,18,0.92));
    border: 1px solid var(--accent-dim);
    box-shadow: 0 14px 40px rgba(255, 45, 79, 0.22);
}
.toast.sale-toast::before { background: var(--accent-grad); }
.sale-icon {
    width: 32px; height: 32px;
    background: var(--accent-grad); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: white; font-size: 15px; font-weight: bold;
    box-shadow: 0 0 16px var(--accent-glow);
    flex-shrink: 0;
}

/* ===== Discord Preview ===== */
.discord-preview-container {
    background: rgba(0,0,0,0.45);
    border-radius: var(--radius);
    padding: 22px; margin-top: 16px;
    border: 1px solid var(--border);
    color: #dbdee1; font-size: 14.5px;
    box-shadow: inset 0 4px 20px rgba(0,0,0,0.3);
}
.message-preview {
    border-left: 4px solid var(--accent);
    padding: 22px;
    background: rgba(255,255,255,0.02);
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}
.message-preview-title { font-weight: 700; margin-bottom: 12px; font-size: 16px; color: white; }
.message-preview-desc { font-size: 14.5px; color: var(--text-secondary); white-space: pre-wrap; line-height: 1.6; }
.message-preview-footer { font-size: 13px; color: var(--text-muted); margin-top: 18px; border-top: 1px solid var(--border); padding-top: 14px; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }

.empty-state {
    text-align: center; padding: 80px 20px;
    color: var(--text-muted); font-size: 15px;
    background: var(--bg-card);
    border: 1px dashed var(--border);
    border-radius: var(--radius-lg);
}
.empty-state .icon {
    width: 64px; height: 64px; margin: 0 auto 22px;
    border-radius: 18px;
    background: var(--accent-soft);
    border: 1px solid var(--accent-dim);
    display: flex; align-items: center; justify-content: center;
    color: var(--accent);
}
.empty-state h3 { font-size: 18px; color: var(--text-white); margin-bottom: 8px; }

/* ===== Transcript Chat ===== */
.chat-container {
    display: flex; flex-direction: column; gap: 18px;
    padding: 24px; background: rgba(0,0,0,0.4);
    border-radius: var(--radius-lg); border: 1px solid var(--border);
    max-height: 520px; overflow-y: auto;
}
.chat-message { display: flex; flex-direction: column; max-width: 78%; }
.chat-message.client { align-self: flex-start; }
.chat-message.staff { align-self: flex-end; align-items: flex-end; }
.chat-message.bot { align-self: flex-start; opacity: 0.85; }
.chat-bubble {
    padding: 14px 18px; border-radius: 18px;
    font-size: 14.5px; color: #fff; word-break: break-word;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}
.chat-message.client .chat-bubble { background: #1d1820; border-bottom-left-radius: 6px; border: 1px solid var(--border); }
.chat-message.staff .chat-bubble {
    background: var(--accent-grad);
    border-bottom-right-radius: 6px;
    box-shadow: var(--shadow-crimson);
}
.chat-message.bot .chat-bubble { background: #1a1418; border: 1px dashed var(--accent-dim); }
.chat-meta { font-size: 12px; color: var(--text-muted); margin-top: 6px; font-weight: 500; }

/* ===== Bento Grid ===== */
.bento-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 160px;
    gap: 20px;
    margin-bottom: 32px;
}
@media (max-width: 1024px) { .bento-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .bento-grid { grid-template-columns: 1fr; } }

.bento-col-1 { grid-column: span 1; }
.bento-col-2 { grid-column: span 2; }
.bento-col-3 { grid-column: span 3; }
.bento-col-4 { grid-column: span 4; }
.bento-row-1 { grid-row: span 1; }
.bento-row-2 { grid-row: span 2; }
.bento-row-3 { grid-row: span 3; }

.bento-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 26px;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(24px);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s, border-color 0.4s;
    display: flex; flex-direction: column;
}
.bento-card:hover {
    transform: translateY(-4px);
    border-color: var(--border-hover);
    box-shadow: var(--shadow-lg);
}
.bento-card::before {
    content: '';
    position: absolute; inset: 0;
    opacity: 0;
    transition: opacity 0.3s ease;
    background: radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), var(--accent-soft), transparent 40%);
    pointer-events: none; z-index: 0;
}
.bento-card:hover::before { opacity: 1; }
.bento-content { position: relative; z-index: 1; height: 100%; display: flex; flex-direction: column; }
.bento-aurora { background: linear-gradient(135deg, rgba(255,45,79,0.12) 0%, rgba(255,45,79,0.02) 100%); }
.bento-card h3 { font-size: 18px; font-weight: 700; color: white; margin-bottom: 6px; letter-spacing: -0.02em; }
.bento-card p { color: var(--text-secondary); font-size: 14px; font-weight: 400; line-height: 1.5; }

/* ===== Tabs ===== */
.tabs {
    display: flex; gap: 4px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 5px;
    margin-bottom: 24px;
    width: fit-content;
}
.tab {
    padding: 9px 18px;
    font-size: 13.5px; font-weight: 600;
    color: var(--text-secondary); cursor: pointer;
    border-radius: 8px;
    transition: var(--transition);
    background: transparent; border: none;
    font-family: inherit;
}
.tab:hover { color: var(--text-white); }
.tab.active {
    background: var(--accent-grad);
    color: white;
    box-shadow: var(--shadow-crimson);
}

/* ===== Date range picker (period chips) ===== */
.period-chips { display: inline-flex; gap: 4px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 99px; padding: 4px; }
.period-chip {
    padding: 7px 16px; font-size: 13px; font-weight: 600;
    border-radius: 99px; cursor: pointer;
    color: var(--text-secondary); transition: var(--transition);
    background: transparent; border: none; font-family: inherit;
}
.period-chip:hover { color: var(--text-white); }
.period-chip.active {
    background: var(--accent-grad);
    color: white;
    box-shadow: 0 4px 14px var(--accent-glow);
}

/* ===== Command Palette ===== */
.command-palette-overlay {
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(14px);
    z-index: 99999; display: flex; align-items: flex-start; justify-content: center;
    padding-top: 14vh;
}
.command-palette {
    width: 100%; max-width: 640px;
    background: rgba(15, 12, 17, 0.97);
    border: 1px solid var(--border-hover);
    border-radius: 18px;
    box-shadow: var(--shadow-lg), 0 0 0 1px var(--accent-dim);
    overflow: hidden;
    animation: cpIn 0.22s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes cpIn { from { opacity: 0; transform: scale(0.98) translateY(10px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.cp-search { display: flex; align-items: center; padding: 18px 22px; border-bottom: 1px solid var(--border); }
#cpInput {
    flex: 1; background: transparent; border: none;
    color: white; font-size: 17px; font-weight: 500;
    margin-left: 14px; outline: none; font-family: inherit;
}
#cpInput::placeholder { color: var(--text-muted); }
.cp-shortcut {
    font-size: 11px; background: rgba(255,255,255,0.05); padding: 4px 8px;
    border-radius: 6px; color: var(--text-muted); border: 1px solid var(--border);
    font-weight: 600; font-family: 'JetBrains Mono', monospace;
}
.cp-results { max-height: 360px; overflow-y: auto; padding: 10px; }
.cp-item {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 14px; border-radius: 10px; cursor: pointer;
    color: var(--text-secondary); transition: background 0.1s;
    font-size: 14.5px; font-weight: 500;
}
.cp-item:hover, .cp-item.active {
    background: var(--accent-soft);
    color: white;
}
.cp-item:hover .icon, .cp-item.active .icon { color: var(--accent); }
.cp-item .icon {
    width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.05); border-radius: 7px;
    color: var(--text-muted); transition: color 0.2s;
}

/* ===== Chart Container ===== */
.chart-container {
    width: 100%; height: 320px; position: relative; margin-top: 12px;
}

/* ===== Workspace selector / user profile (topbar) ===== */
.workspace-selector {
    background: var(--bg-card);
    color: var(--text-primary);
    border: 1px solid var(--border);
    padding: 8px 36px 8px 14px;
    border-radius: 11px;
    font-size: 13.5px;
    font-weight: 500;
    cursor: pointer;
    outline: none;
    transition: all var(--transition);
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23ff2d4f%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 9px;
    font-family: inherit;
}
.workspace-selector:hover { border-color: var(--accent-dim); }
.workspace-selector:focus { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-dim); }

.user-profile {
    display: flex; align-items: center; gap: 10px;
    padding: 5px 5px 5px 14px;
    border-radius: 99px;
    transition: background 0.2s;
    cursor: pointer;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-white);
}
.user-profile:hover { background: var(--accent-soft); border-color: var(--accent-dim); }
.user-avatar {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--accent-grad);
    border: 1px solid var(--border);
    object-fit: cover;
}
.user-name { font-size: 13px; font-weight: 600; color: var(--text-primary); }

/* ===== Order Bump / Upsell specific cards ===== */
.offer-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.offer-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--accent-grad);
    opacity: 0.7;
}
.offer-card:hover { border-color: var(--accent-dim); transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.offer-card .offer-tag {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 10.5px; font-weight: 700; letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 4px 10px; border-radius: 99px;
    background: var(--accent-soft); color: var(--accent);
    border: 1px solid var(--accent-dim);
    margin-bottom: 14px;
}
.offer-card .offer-title { font-size: 17px; font-weight: 700; color: var(--text-white); margin-bottom: 6px; }
.offer-card .offer-desc { font-size: 13.5px; color: var(--text-secondary); margin-bottom: 18px; line-height: 1.55; }
.offer-card .offer-meta {
    display: flex; gap: 18px; margin-bottom: 18px;
    padding: 14px; border-radius: 12px;
    background: rgba(0,0,0,0.3); border: 1px solid var(--border);
}
.offer-card .offer-meta .m { flex: 1; }
.offer-card .offer-meta .m .lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); margin-bottom: 4px; font-weight: 600; }
.offer-card .offer-meta .m .val { font-size: 15px; font-weight: 700; color: var(--text-white); font-variant-numeric: tabular-nums; }
.offer-card .offer-meta .m .val.crimson { color: var(--accent); }
.offer-card .offer-actions { display: flex; gap: 8px; }

/* ===== Funnel Visualization ===== */
.funnel-stages {
    display: flex; flex-direction: column; gap: 4px;
    margin-top: 16px;
}
.funnel-stage {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 18px 22px;
    display: flex; align-items: center; justify-content: space-between;
    position: relative;
    overflow: hidden;
    transition: var(--transition);
}
.funnel-stage:hover { border-color: var(--accent-dim); }
.funnel-stage .stage-fill {
    position: absolute; left: 0; top: 0; bottom: 0;
    background: linear-gradient(90deg, var(--accent-soft), transparent);
    border-right: 2px solid var(--accent);
    z-index: 0;
    transition: width 0.8s ease-out;
}
.funnel-stage > * { position: relative; z-index: 1; }
.funnel-stage .stage-info { display: flex; align-items: center; gap: 14px; }
.funnel-stage .stage-num {
    width: 30px; height: 30px; border-radius: 9px;
    background: var(--accent-soft); color: var(--accent);
    border: 1px solid var(--accent-dim);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 13px;
    flex-shrink: 0;
}
.funnel-stage .stage-name { font-weight: 600; color: var(--text-white); font-size: 14.5px; }
.funnel-stage .stage-sub { font-size: 12.5px; color: var(--text-muted); margin-top: 2px; }
.funnel-stage .stage-count { font-weight: 800; font-size: 18px; color: var(--text-white); font-variant-numeric: tabular-nums; }
.funnel-stage .stage-rate { font-size: 12px; color: var(--text-muted); margin-top: 2px; text-align: right; }
.funnel-stage .stage-rate.up { color: var(--success); }

/* ===== Onboarding (driver.js) ===== */
.payo-driver-theme {
    background: rgba(15, 12, 17, 0.97) !important;
    border: 1px solid var(--accent-dim) !important;
    border-radius: 16px !important;
    box-shadow: var(--shadow-lg), 0 0 0 1px var(--accent-dim), 0 0 30px var(--accent-glow) !important;
    color: #e4e4e7 !important;
    font-family: 'Outfit', sans-serif !important;
    padding: 22px !important;
}
.payo-driver-theme .driver-popover-title {
    font-size: 19px !important; font-weight: 700 !important;
    color: #fff !important; margin-bottom: 8px !important;
}
.payo-driver-theme .driver-popover-description {
    font-size: 14px !important; color: #a1a1aa !important; line-height: 1.55 !important;
}
.payo-driver-theme .driver-popover-footer button {
    background: rgba(255,255,255,0.06) !important; color: white !important; border: none !important;
    border-radius: 8px !important; padding: 8px 16px !important; font-weight: 600 !important;
    text-shadow: none !important; transition: all 0.2s !important;
    font-family: 'Outfit', sans-serif !important;
}
.payo-driver-theme .driver-popover-footer button:hover { background: rgba(255,255,255,0.1) !important; }
.payo-driver-theme .driver-popover-footer .driver-popover-next-btn {
    background: var(--accent-grad) !important;
    box-shadow: var(--shadow-crimson) !important;
}

/* ===== Utility ===== */
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
.mb-2 { margin-bottom: 8px; }
.mb-4 { margin-bottom: 16px; }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }
.text-accent { color: var(--accent); }
.text-success { color: var(--success); }
.text-error { color: var(--error); }
.font-bold { font-weight: 700; }
.font-mono { font-family: 'JetBrains Mono', monospace; }
.text-sm { font-size: 13px; }
.text-xs { font-size: 11.5px; }
.w-full { width: 100%; }

/* ===== Responsive ===== */
@media (max-width: 1024px) {
    .sidebar { transform: translateX(-100%); transition: transform 0.3s; }
    .sidebar.open { transform: translateX(0); }
    .main-content { margin-left: 0; }
    .page-content { padding: 24px 20px 60px; }
    .topbar { padding: 0 20px; }
}
@media (max-width: 640px) {
    .stats-grid { grid-template-columns: 1fr; }
    .form-row, .form-row-3 { grid-template-columns: 1fr; }
}

/* ===== Loading ===== */
.spinner {
    width: 22px; height: 22px;
    border: 2.5px solid var(--accent-soft);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    display: inline-block;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-state { display: flex; align-items: center; justify-content: center; padding: 80px; gap: 14px; color: var(--text-muted); }

/* ===== Inline pill (small chip) ===== */
.pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 3px 9px; border-radius: 99px;
    font-size: 11.5px; font-weight: 600;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    color: var(--text-secondary);
}
.pill.crimson {
    background: var(--accent-soft); color: var(--accent); border-color: var(--accent-dim);
}

/* ===== KPI sparkline cell ===== */
.spark { display: inline-block; width: 70px; height: 22px; vertical-align: middle; }

/* =====================================================
   v2.0 — Layout estilo "print" (PayoApps Crimson)
   ===================================================== */

/* ===== Brand square grande (igual print) ===== */
.sidebar-brand-block {
    padding: 22px 24px 14px;
    display: flex; justify-content: flex-start; align-items: center;
    border-bottom: 1px solid var(--border-subtle);
    position: relative; z-index: 1;
}
.brand-square {
    width: 64px; height: 64px;
    border-radius: 16px;
    background: transparent;
    display: flex; align-items: center; justify-content: center;
    position: relative;
}
.brand-letter {
    position: relative; z-index: 1;
    font-size: 32px; font-weight: 900;
    color: var(--accent);
    letter-spacing: -0.04em;
    text-shadow: 0 0 24px var(--accent-glow), 0 0 8px var(--accent);
    font-family: 'Outfit', sans-serif;
    line-height: 1;
}

/* ===== Sidebar overrides (mais clean, igual print) ===== */
.sidebar { box-shadow: inset -1px 0 0 var(--border-subtle); }
.sidebar-nav { padding: 14px 14px 12px; }
.sidebar-section { margin-bottom: 18px; }
.sidebar-section-title {
    font-size: 10.5px; font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--text-muted);
    padding: 8px 14px 10px;
}

/* nav-item simples (para Geral/Conexão e Master) — reusa estilo existente */

/* ===== nav-group expansível ===== */
.nav-group { margin-bottom: 4px; }
.nav-group-toggle {
    width: 100%;
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px;
    border-radius: 11px;
    background: transparent; border: none;
    color: var(--text-secondary);
    font-family: inherit; font-size: 14.5px; font-weight: 500;
    cursor: pointer; transition: var(--transition);
    text-align: left;
}
.nav-group-toggle:hover { background: var(--bg-input); color: var(--text-white); }
.nav-group-toggle .icon { display: flex; color: var(--text-muted); transition: color 0.18s; }
.nav-group-toggle .icon i { width: 17px; height: 17px; }
.nav-group-toggle:hover .icon { color: var(--accent); }
.nav-group-toggle .caret {
    margin-left: auto;
    color: var(--text-muted);
    display: flex; align-items: center;
    transition: transform 0.25s;
}
.nav-group-toggle .caret i { width: 14px; height: 14px; }
.nav-group.open > .nav-group-toggle { color: var(--text-white); }
.nav-group.open > .nav-group-toggle .icon { color: var(--accent); }
.nav-group-toggle .nav-badge {
    margin-left: auto;
    font-size: 9.5px; font-weight: 800;
    padding: 2px 6px; border-radius: 99px;
    background: var(--accent-grad); color: white;
    letter-spacing: 0.04em; text-transform: uppercase;
    box-shadow: 0 0 10px var(--accent-glow);
}
.nav-group-toggle .nav-badge + .caret { margin-left: 8px; }

.nav-group-items {
    display: flex; flex-direction: column; gap: 2px;
    padding: 6px 0 6px 14px;
    margin: 4px 0 4px 18px;
    border-left: 1px dashed var(--border);
    overflow: hidden;
    max-height: 600px;
    transition: max-height 0.32s ease, opacity 0.25s ease, padding 0.25s ease, margin 0.25s ease;
    opacity: 1;
}
.nav-group-items.collapsed {
    max-height: 0;
    opacity: 0;
    padding-top: 0; padding-bottom: 0;
    margin-top: 0; margin-bottom: 0;
    border-left-color: transparent;
}

/* nav-subitem (sub-páginas dentro de Vendas/Marketing/Ticket/etc)
   — MESMO estilo do .nav-item: fundo gradient + barra retangular lateral */
.nav-subitem {
    padding: 9px 14px;
    border-radius: 10px;
    color: var(--text-secondary);
    font-size: 13.5px; font-weight: 500;
    cursor: pointer; transition: var(--transition);
    position: relative;
    overflow: hidden;
    margin-bottom: 2px;
}
.nav-subitem::before {
    content: ''; position: absolute; left: 0; top: 50%;
    width: 3px; height: 0; transform: translateY(-50%);
    background: var(--accent); border-radius: 0 3px 3px 0;
    transition: height 0.3s ease;
    box-shadow: 0 0 12px var(--accent-glow);
}
.nav-subitem:hover {
    background: var(--bg-input);
    color: var(--text-white);
    padding-left: 18px;
}
.nav-subitem:hover::before { height: 16px; }
.nav-subitem.active {
    background: linear-gradient(90deg, rgba(255,45,79,0.12), rgba(255,45,79,0.02));
    color: var(--text-white); font-weight: 600;
    border: 1px solid var(--accent-dim);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.nav-subitem.active::before { height: 22px; }

/* Sidebar collapsed (responsive) */
.app-layout.sidebar-collapsed .sidebar { transform: translateX(-100%); }
.app-layout.sidebar-collapsed .main-content { margin-left: 0; }

/* ===== Sidebar stamp (rodapé com versão) ===== */
.sidebar-stamp {
    padding: 14px 22px;
    border-top: 1px solid var(--border-subtle);
    color: var(--text-muted);
    font-size: 11.5px; font-weight: 600;
    display: flex; align-items: center; gap: 8px;
    letter-spacing: 0.04em;
    position: relative; z-index: 1;
}
.sidebar-stamp b { color: var(--text-secondary); font-weight: 700; }

/* ===== Topbar minimal (igual print) ===== */
.topbar-minimal {
    padding: 0 32px;
    height: 70px;
    background: transparent;
    border-bottom: 1px solid var(--border-subtle);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
.topbar-left { display: flex; align-items: center; gap: 18px; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.topbar-title-mini {
    font-size: 14.5px; font-weight: 600;
    color: var(--text-secondary);
}
.topbar-iconbtn {
    width: 38px; height: 38px;
    border-radius: 11px;
    background: rgba(255,255,255,0.025);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: var(--transition);
    position: relative;
    flex-shrink: 0;
}
.topbar-iconbtn:hover { color: var(--accent); border-color: var(--accent-dim); background: var(--accent-soft); }
.topbar-bell .bell-dot {
    position: absolute; top: 9px; right: 9px;
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 10px var(--accent), 0 0 0 2px rgba(11,10,14,0.95);
}

/* Achievement pill (1K igual print) */
.achievement-pill {
    display: inline-flex; align-items: center; gap: 7px;
    height: 38px;
    padding: 0 14px;
    border-radius: 11px;
    background: linear-gradient(135deg, rgba(255, 200, 55, 0.12), rgba(255, 150, 30, 0.04));
    border: 1px solid rgba(255, 200, 55, 0.32);
    color: #ffd24a;
    font-weight: 700; font-size: 13.5px;
    letter-spacing: 0.02em;
    cursor: pointer; transition: var(--transition);
    flex-shrink: 0;
}
.achievement-pill:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(255, 200, 55, 0.18); }
.achievement-pill i { filter: drop-shadow(0 0 6px rgba(255, 200, 55, 0.6)); }

/* Topbar avatar circular com iniciais */
.topbar-avatar {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: var(--accent-grad);
    border: 1px solid var(--accent-dim);
    color: white;
    font-weight: 800; font-size: 12.5px;
    letter-spacing: 0.04em;
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: var(--transition);
    box-shadow: 0 6px 18px var(--accent-glow);
    flex-shrink: 0;
    font-family: inherit;
}
.topbar-avatar:hover { transform: translateY(-1px) scale(1.04); box-shadow: 0 10px 24px var(--accent-glow); }
.topbar-avatar .user-initials { line-height: 1; }

/* ===== Period chips no header da página ===== */
.page-header-v2 {
    display: flex; justify-content: space-between; align-items: flex-end;
    margin-bottom: 16px; gap: 16px; flex-wrap: wrap;
}
.page-header-v2 h1 {
    font-size: 26px; font-weight: 800;
    letter-spacing: -0.025em; margin-bottom: 2px;
}
.page-header-v2 .page-sub { color: var(--text-muted); font-size: 14px; }
.page-period-row {
    display: inline-flex; gap: 6px;
    align-items: center;
    flex-wrap: wrap;
}
.page-period-row .chip {
    padding: 8px 16px;
    font-size: 13px; font-weight: 600;
    border-radius: 99px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-secondary);
    cursor: pointer; transition: var(--transition);
    font-family: inherit;
    display: inline-flex; align-items: center; gap: 6px;
}
.page-period-row .chip:hover { color: var(--text-white); border-color: var(--accent-dim); }
.page-period-row .chip.active {
    background: var(--accent);
    color: white;
    border-color: var(--accent);
    box-shadow: 0 6px 18px var(--accent-glow);
}
.page-period-row .chip i { width: 14px; height: 14px; }

/* ===== KPI Grid 4×2 (igual print) ===== */
.kpi-grid-8 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 24px;
}
@media (max-width: 1280px) { .kpi-grid-8 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .kpi-grid-8 { grid-template-columns: 1fr; } }

.kpi-card {
    background: var(--bg-card);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 16px 20px 18px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
    min-height: 100px;
    display: flex; flex-direction: column; justify-content: space-between;
}
.kpi-card::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent-dim), transparent);
    opacity: 0; transition: opacity 0.4s;
}
.kpi-card::after {
    content: ''; position: absolute;
    right: -50px; top: -50px;
    width: 160px; height: 160px;
    background: radial-gradient(circle, var(--accent-soft) 0%, transparent 65%);
    opacity: 0; transition: opacity 0.4s;
}
.kpi-card:hover {
    transform: translateY(-3px);
    border-color: var(--accent-dim);
}
.kpi-card:hover::before, .kpi-card:hover::after { opacity: 1; }

.kpi-head {
    display: flex; justify-content: space-between; align-items: center;
    gap: 14px;
}
.kpi-label {
    font-size: 14px; font-weight: 600;
    color: var(--text-secondary);
    letter-spacing: 0.01em;
}
.kpi-ico {
    width: 32px; height: 32px;
    border-radius: 9px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    display: inline-flex; align-items: center; justify-content: center;
    transition: var(--transition);
    flex-shrink: 0;
}
.kpi-ico i { width: 16px; height: 16px; }
.kpi-card:hover .kpi-ico {
    background: var(--accent-soft);
    color: var(--accent);
    border-color: var(--accent-dim);
}
.kpi-value {
    font-size: 32px; font-weight: 800;
    color: var(--text-white);
    letter-spacing: -0.03em;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.kpi-value.crimson {
    background: var(--accent-grad);
    -webkit-background-clip: text; background-clip: text;
    color: transparent;
    text-shadow: none;
}
.kpi-trend {
    margin-top: 8px;
    font-size: 12px; font-weight: 600;
    color: var(--text-muted);
    display: inline-flex; align-items: center; gap: 5px;
}
.kpi-trend.up { color: var(--success); }
.kpi-trend.down { color: var(--error); }
.kpi-trend i { width: 13px; height: 13px; }

/* ===== Bottom row do dashboard: chart + donut ===== */
.dash-bottom {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 18px;
    margin-top: 4px;
}
@media (max-width: 1180px) { .dash-bottom { grid-template-columns: 1fr; } }

.panel-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 24px 26px;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    min-height: 440px;
    display: flex; flex-direction: column;
}
.panel-head {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 18px; gap: 14px;
}
.panel-title { font-size: 16px; font-weight: 700; color: var(--text-white); letter-spacing: -0.015em; }
.panel-sub { font-size: 12.5px; color: var(--text-muted); margin-top: 2px; }
.panel-body { flex: 1; position: relative; }

/* ===== Donut gauge (semi-circle, igual print) ===== */
.donut-wrap {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 16px 0 8px;
    text-align: center;
}
.donut-svg { width: 260px; height: 150px; max-width: 100%; }
.donut-track { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 18; stroke-linecap: round; }
.donut-fill {
    fill: none;
    stroke: url(#donutGradGreen);
    stroke-width: 18;
    stroke-linecap: round;
    transition: stroke-dashoffset 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}
.donut-center {
    margin-top: -50px; margin-bottom: 12px;
    display: flex; flex-direction: column; align-items: center;
}
.donut-percent {
    font-size: 40px; font-weight: 800;
    color: var(--text-white);
    letter-spacing: -0.03em; line-height: 1;
    font-variant-numeric: tabular-nums;
    display: inline-flex; align-items: baseline; gap: 4px;
}
.donut-percent .pct-sign { font-size: 18px; color: var(--text-secondary); font-weight: 700; }
.donut-label {
    margin-top: 6px;
    font-size: 13px; color: var(--text-muted); font-weight: 500;
}
.donut-legend {
    display: flex; justify-content: center; gap: 22px;
    margin-top: 18px; flex-wrap: wrap;
}
.donut-legend-item {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13px; color: var(--text-secondary); font-weight: 500;
}
.donut-legend-item.approved .dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: #84cc16;
    box-shadow: 0 0 10px rgba(132,204,22,0.5);
}
.donut-legend-item.pending .dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: #f59e0b;
    box-shadow: 0 0 8px rgba(245,158,11,0.5);
}
.donut-legend-item .dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: #84cc16;
    box-shadow: 0 0 10px rgba(132,204,22,0.5);
}
.donut-legend-item b { color: var(--text-white); font-weight: 800; margin-left: 4px; }

/* ===== Chart Y-axis labels (R$ 0k etc) ===== */

/* ===== Mensagens (Management UI) ===== */
.messages-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 32px;
    align-items: flex-start;
}
@media (max-width: 1024px) {
    .messages-layout { grid-template-columns: 1fr; }
}

.messages-sidebar {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.msg-cat-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 18px;
    border-radius: 12px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
    text-align: left;
    font-family: inherit;
}
.msg-cat-btn:hover {
    background: var(--bg-input);
    color: var(--text-white);
}
.msg-cat-btn.active {
    background: var(--accent-soft);
    color: var(--accent);
    border-color: var(--accent-dim);
}
.msg-cat-btn i {
    width: 18px;
    height: 18px;
    opacity: 0.7;
}

.messages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
    gap: 20px;
}
@media (max-width: 640px) {
    .messages-grid { grid-template-columns: 1fr; }
}

.msg-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 20px;
    transition: var(--transition);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.msg-card:hover {
    border-color: var(--accent-dim);
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}
.msg-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.msg-card-title {
    font-weight: 700;
    font-size: 15px;
    color: var(--text-white);
}
.msg-card-key {
    font-size: 11px;
    color: var(--text-muted);
    font-family: 'JetBrains Mono', monospace;
    margin-top: 2px;
}
.msg-preview-mini {
    background: #2b2d31;
    border-radius: 8px;
    padding: 12px;
    font-family: 'Outfit', sans-serif;
    border-left: 4px solid var(--accent);
}
.msg-preview-mini-title {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 4px;
    color: #fff;
}
.msg-preview-mini-desc {
    font-size: 12px;
    color: #dbdee1;
    line-height: 1.4;
}

/* =====================================================
   ===== RESPONSIVIDADE COMPLETA — App Dashboard ======
   ===================================================== */

/* Guard horizontal SEM quebrar scroll vertical.
   overflow-x: clip não cria contexto de scroll (diferente de hidden) */
html { overflow-x: clip; }
body { overflow-x: clip; }
/* Fallback pra navegadores muito antigos que não suportam `clip` */
@supports not (overflow: clip) {
    html, body { overflow-x: hidden; }
    html { overflow-y: auto; } /* força scroll vertical no html */
}
img, svg, video, canvas { max-width: 100%; height: auto; }

/* Hamburger (default escondido no desktop) */
.sidebar-hamburger {
    display: none;
    width: 40px; height: 40px;
    border-radius: 11px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    flex-shrink: 0;
}
.sidebar-hamburger:hover { color: var(--accent); border-color: var(--accent-dim); }

/* Overlay quando sidebar abre no mobile */
.sidebar-backdrop {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(6px);
    z-index: 95;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.app-layout.sidebar-open .sidebar-backdrop {
    display: block;
    opacity: 1;
}

/* ===== Tablet (≤1024px) ===== */
@media (max-width: 1024px) {
    /* Sidebar: vira drawer */
    .sidebar {
        transform: translateX(-100%);
        transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 20px 0 60px rgba(0,0,0,0.6);
    }
    .app-layout.sidebar-open .sidebar {
        transform: translateX(0);
    }
    .app-layout.sidebar-collapsed .sidebar {
        transform: translateX(-100%);
    }
    .main-content { margin-left: 0 !important; }

    /* Topbar mostra hamburger, esconde o "collapse" original */
    .sidebar-hamburger { display: inline-flex; }
    #sidebarCollapse { display: none; }

    .topbar-minimal { padding: 0 20px; height: 64px; }
    .topbar-title-mini { font-size: 14px; }

    .page-content { padding: 24px 20px 60px; }

    /* Page header v2 stack */
    .page-header-v2 {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
    }
    .page-header-v2 h1 { font-size: 22px; }
    .page-period-row { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; padding-bottom: 4px; }
    .page-period-row::-webkit-scrollbar { height: 4px; }
    .page-period-row .chip { flex-shrink: 0; }

    /* Dashboard bottom */
    .dash-bottom { grid-template-columns: 1fr; }
    .panel-card { min-height: auto; padding: 22px 22px; }

    /* Tabela com scroll horizontal */
    .table-container { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    table { min-width: 640px; }
}

/* ===== Mobile (≤768px) ===== */
@media (max-width: 768px) {
    .page-content { padding: 20px 16px 60px; }

    /* Topbar: oculta workspace selector e achievement para liberar espaço */
    .workspace-selector { display: none; }
    .achievement-pill span { display: none; } /* só ícone */
    .achievement-pill { padding: 0 10px; }
    .topbar-bell { display: none; }
    .topbar-iconbtn#themeToggle { display: none; }

    .topbar-right { gap: 8px; }

    /* KPI grid: 2 colunas sempre */
    .kpi-grid-8 { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .kpi-card { padding: 18px 16px; min-height: 108px; }
    .kpi-label { font-size: 12.5px; }
    .kpi-value { font-size: 24px; }
    .kpi-ico { width: 28px; height: 28px; }
    .kpi-ico i { width: 14px; height: 14px; }

    /* Cards / Panels */
    .card { padding: 20px 18px; border-radius: 16px; }
    .card-header { flex-direction: column; align-items: flex-start; gap: 12px; }
    .panel-card { padding: 18px 16px; border-radius: 16px; }
    .panel-head { flex-direction: column; align-items: flex-start; gap: 12px; }
    .panel-title { font-size: 15px; }

    /* Modal: ocupa quase a tela */
    .modal {
        padding: 26px 22px;
        border-radius: 20px;
        max-height: calc(100dvh - 32px);
    }
    .modal-overlay { padding: 16px; }
    .modal-title { font-size: 18px; }
    .modal-header { margin-bottom: 22px; }
    .modal-footer { flex-direction: column-reverse; gap: 8px; padding-top: 20px; }
    .modal-footer .btn { width: 100%; }

    /* Form row sempre 1 coluna */
    .form-row, .form-row-3 { grid-template-columns: 1fr; gap: 14px; }

    /* Search bar full-width */
    .search-bar-container { max-width: 100% !important; }

    /* Bento grid (legacy) */
    .bento-grid { grid-template-columns: 1fr !important; grid-auto-rows: auto; gap: 14px; }
    .bento-col-1, .bento-col-2, .bento-col-3, .bento-col-4 { grid-column: span 1 !important; }
    .bento-row-1, .bento-row-2, .bento-row-3 { grid-row: span 1 !important; }
    .bento-card { padding: 22px; }

    /* Stats grid (legacy 280px min) */
    .stats-grid { grid-template-columns: 1fr; gap: 14px; }

    /* Tabs scroll horizontal se passar */
    .tabs { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; }
    .tab { flex-shrink: 0; }

    /* Tabela: cell padding menor */
    th { padding: 14px 16px; font-size: 11px; }
    td { padding: 14px 16px; font-size: 13.5px; }

    /* Toast container ajustado */
    .toast-container { bottom: 16px; right: 16px; left: 16px; }
    .toast { min-width: 0; width: 100%; }

    /* Command palette */
    .command-palette-overlay { padding: 16px; padding-top: 10vh; }
    .command-palette { max-width: 100%; }

    /* Offer cards */
    .offer-card { padding: 20px; }
    .offer-card .offer-meta { flex-direction: column; gap: 10px; padding: 12px; }

    /* Funnel stage */
    .funnel-stage { padding: 14px 16px; }
    .funnel-stage .stage-name { font-size: 13.5px; }
    .funnel-stage .stage-count { font-size: 16px; }

    /* Discord chat */
    .chat-message { max-width: 90%; }
    .chat-bubble { padding: 12px 16px; font-size: 13.5px; }

    /* Messages page sidebar (cat selector) */
    .messages-sidebar {
        position: relative;
        top: 0;
        flex-direction: row;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 6px;
    }
    .msg-cat-btn { flex-shrink: 0; padding: 10px 14px; font-size: 13px; }
}

/* ===== Mobile pequeno (≤480px) ===== */
@media (max-width: 480px) {
    .page-content { padding: 16px 14px 50px; }

    /* Topbar mais compacto */
    .topbar-minimal { padding: 0 14px; height: 60px; }
    .topbar-iconbtn { width: 36px; height: 36px; }
    .topbar-avatar { width: 36px; height: 36px; font-size: 11.5px; }
    .achievement-pill { height: 36px; }
    .topbar-title-mini { display: none; } /* só hamburger + brand */

    /* KPI: 1 coluna em telas muito pequenas */
    .kpi-grid-8 { grid-template-columns: 1fr; }
    .kpi-card { padding: 18px; }
    .kpi-value { font-size: 26px; }

    /* Page header */
    .page-header-v2 h1 { font-size: 20px; }
    .page-header-v2 .page-sub { font-size: 13px; }
    .page-period-row .chip { padding: 7px 12px; font-size: 12px; }

    /* Sidebar: largura adaptada */
    .sidebar { width: min(86vw, 320px); }

    /* Modal full-bleed */
    .modal {
        padding: 22px 18px;
        border-radius: 18px;
    }
    .modal-overlay { padding: 10px; }

    /* Forms */
    .form-input, .form-select, .form-textarea {
        padding: 12px 14px; font-size: 14px;
    }
    .btn { padding: 11px 18px; font-size: 13.5px; }
    .btn-lg { padding: 14px 22px; font-size: 14.5px; }

    /* Card title */
    .card-title { font-size: 16px; }

    /* Donut menor */
    .donut-svg { width: 220px; height: 130px; }
    .donut-percent { font-size: 34px; }
    .donut-legend { gap: 16px; }

    /* Tabela mais "fluida": deixa expandir em vez de scroll */
    table { font-size: 13px; }
    th { padding: 12px 14px; }
    td { padding: 12px 14px; }
}

/* ===== Mobile MUITO pequeno (≤360px) ===== */
@media (max-width: 360px) {
    .page-content { padding: 14px 12px 50px; }
    .kpi-card { padding: 16px; }
    .kpi-value { font-size: 22px; }
    .panel-card { padding: 16px 14px; }
    .page-header-v2 h1 { font-size: 18px; }
}

/* ===== Touch devices ===== */
@media (hover: none) {
    .kpi-card:hover, .panel-card:hover, .offer-card:hover, .card:hover, .bento-card:hover {
        transform: none;
    }
    /* Sub-itens não devem mover no hover em touch */
    .nav-item:hover, .nav-subitem:hover { padding-left: 14px; }
    .nav-item:hover::before, .nav-subitem:hover::before { height: 0; }
}

/* Animação suave do drawer */
@media (prefers-reduced-motion: reduce) {
    .sidebar, .sidebar-backdrop { transition: none !important; }
}

/* ===== Image Upload Zone ===== */
.img-upload-zone {
    border: 2px dashed var(--border);
    border-radius: var(--radius);
    padding: 24px;
    cursor: pointer;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-input);
}
.img-upload-zone:hover {
    border-color: var(--accent-dim);
    background: rgba(255, 45, 79, 0.03);
}
.img-upload-zone.dragover {
    border-color: var(--accent);
    background: rgba(255, 45, 79, 0.06);
    border-style: solid;
    box-shadow: 0 0 0 4px var(--accent-dim), inset 0 0 40px rgba(255, 45, 79, 0.04);
}
.img-upload-zone.has-image {
    border-style: solid;
    border-color: var(--border);
    padding: 0;
}
.img-upload-zone.has-image:hover {
    border-color: var(--accent-dim);
}
.img-upload-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    pointer-events: none;
}
.img-upload-icon {
    color: var(--text-muted);
    opacity: 0.5;
    transition: var(--transition);
}
.img-upload-zone:hover .img-upload-icon {
    color: var(--accent);
    opacity: 0.8;
    transform: scale(1.05);
}
.img-upload-text {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
}
.img-upload-hint {
    font-size: 11px;
    color: var(--text-muted);
}
.img-upload-preview {
    width: 100%;
    height: 100%;
    min-height: 120px;
    position: relative;
}
.img-upload-preview img {
    width: 100%;
    height: 100%;
    min-height: 120px;
    max-height: 200px;
    object-fit: cover;
    border-radius: calc(var(--radius) - 2px);
    display: block;
}
.img-upload-actions {
    position: absolute;
    top: 8px;
    right: 8px;
    display: flex;
    gap: 6px;
    opacity: 0;
    transition: opacity 0.2s;
}
.img-upload-zone:hover .img-upload-actions {
    opacity: 1;
}
.img-action-btn {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(8px);
    color: white;
}
.img-action-btn:hover {
    background: var(--accent);
    transform: scale(1.1);
}
.img-action-remove:hover {
    background: var(--error);
}
.img-upload-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 20px;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 500;
}
.img-upload-spinner {
    width: 28px;
    height: 28px;
    border: 3px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: imgSpin 0.7s linear infinite;
}
@keyframes imgSpin {
    to { transform: rotate(360deg); }
}
