/* ─── Dashboard layout (pistachio light theme) ─── */
.dash-body {
    display: grid;
    grid-template-columns: 272px 1fr;
    min-height: 100vh;
    background: var(--bg);
}

.sidebar {
    background: var(--bg-soft);
    border-right: 1px solid var(--line);
    padding: 24px 16px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: sticky;
    top: 0;
    height: 100vh;
}
.sidebar .logo { padding: 0 8px; }

.side-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.side-nav__link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 12px;
    font-size: 14px;
    color: var(--ink-soft);
    font-weight: 600;
    transition: all 0.15s;
}
.side-nav__link:hover { background: var(--bg-pistachio); color: var(--pistachio-dark); }
.side-nav__link.is-active { background: var(--ink); color: var(--pistachio-bright); }
.side-nav__link span:first-child { font-size: 16px; }

.side-account {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: var(--shadow-sm);
}
.side-account__avatar {
    width: 38px; height: 38px;
    background: var(--grad-pist);
    color: #fff;
    font-weight: 800;
    border-radius: 50%;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}
.side-account__name { font-size: 13px; font-weight: 700; color: var(--ink); }
.side-account__plan { font-size: 11px; color: var(--ink-mute); }

/* Main */
.main { padding: 28px 36px 64px; display: flex; flex-direction: column; gap: 22px; }

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
    margin-bottom: 8px;
}
.topbar__crumbs { font-size: 12px; color: var(--ink-mute); margin-bottom: 6px; letter-spacing: 0.04em; text-transform: uppercase; font-weight: 600; }
.topbar__title { font-family: var(--font-display); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink); }
.topbar__actions { display: flex; gap: 10px; }
.topbar__actions .btn { padding: 11px 20px; font-size: 13px; }

/* KPIs */
.kpis { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.kpi {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 20px;
    transition: transform 0.2s, box-shadow 0.2s;
    position: relative;
    overflow: hidden;
}
.kpi:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.kpi:nth-child(1)::before { background: var(--pistachio); }
.kpi:nth-child(2)::before { background: var(--coral); }
.kpi:nth-child(3)::before { background: var(--honey); }
.kpi:nth-child(4)::before { background: var(--plum); }
.kpi:nth-child(5)::before { background: var(--pistachio-deep); }
.kpi::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 4px; height: 100%;
    background: var(--pistachio);
}
.kpi__label { font-size: 11px; color: var(--ink-mute); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 700; }
.kpi__value { font-family: var(--font-display); font-size: 30px; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 6px; color: var(--ink); }
.kpi__delta { font-size: 12px; font-weight: 700; }
.kpi__delta--up { color: var(--pistachio-deep); }
.kpi__delta--down { color: var(--coral); }
.kpi__delta--ok { color: var(--pistachio-deep); }

/* Two-col grid */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }

.panel {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 24px;
    box-shadow: var(--shadow-sm);
}
.panel__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.panel__head h2 { font-family: var(--font-display); font-size: 18px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); }
.panel__head .muted { color: var(--ink-mute); font-size: 13px; }

.badge-live {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--pistachio-dark);
    background: var(--bg-mint);
    padding: 5px 11px;
    border-radius: 999px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.mini-select {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 7px 12px;
    color: var(--ink);
    font-family: inherit;
    font-size: 12px;
    font-weight: 600;
}

/* Swarm rows */
.swarm { display: flex; flex-direction: column; gap: 10px; }
.swarm-row {
    display: grid;
    grid-template-columns: 50px 130px 1fr 100px 60px;
    gap: 12px;
    align-items: center;
    padding: 12px 14px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: 12px;
    font-size: 13px;
    transition: transform 0.15s;
}
.swarm-row:hover { transform: translateX(3px); border-color: var(--pistachio); }
.swarm-id { color: var(--pistachio-dark); font-weight: 800; font-size: 11px; background: var(--bg-pistachio); padding: 3px 7px; border-radius: 5px; text-align: center; letter-spacing: 0.04em; }
.swarm-task { color: var(--ink-soft); font-size: 12px; }
.swarm-progress {
    height: 6px;
    background: var(--bg-pistachio);
    border-radius: 3px;
    overflow: hidden;
}
.swarm-progress span {
    display: block;
    height: 100%;
    background: var(--grad-pist);
    border-radius: 3px;
    transition: width 0.6s;
}
.swarm-eta { font-size: 11px; color: var(--ink-mute); text-align: right; font-weight: 700; }

/* Approve cards */
.approve {
    display: grid;
    grid-template-columns: 84px 1fr;
    gap: 16px;
    padding: 16px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: 14px;
    margin-bottom: 12px;
}
.approve:last-child { margin-bottom: 0; }
.approve__visual {
    width: 84px;
    height: 84px;
    border-radius: 12px;
    background-size: cover;
}
.approve__visual--post { background: var(--bg-pistachio); display: grid; place-items: center; font-size: 32px; }
.approve__visual--post::after { content: '📝'; }
.approve__visual--image {
    background:
        radial-gradient(circle at 25% 30%, var(--coral) 0%, transparent 55%),
        radial-gradient(circle at 75% 70%, var(--pistachio) 0%, transparent 55%),
        radial-gradient(circle at 50% 50%, var(--honey) 0%, transparent 60%),
        var(--ink);
}
.approve__visual--video {
    background: radial-gradient(circle at 30% 30%, rgba(255, 122, 89, 0.7), transparent), var(--ink);
    display: grid;
    place-items: center;
    font-size: 26px;
}
.approve__visual--video::after { content: '▶'; color: white; }

.approve__type { font-size: 11px; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; font-weight: 700; }
.approve__title { font-family: var(--font-display); font-size: 15px; font-weight: 600; line-height: 1.4; margin-bottom: 10px; color: var(--ink); }
.approve__meta { display: flex; gap: 12px; flex-wrap: wrap; font-size: 11px; color: var(--ink-soft); margin-bottom: 12px; }
.approve__meta b { color: var(--pistachio-deep); }
.approve__actions { display: flex; gap: 6px; flex-wrap: wrap; }

.btn-pill {
    padding: 7px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    border: 1.5px solid var(--line-mid);
    background: transparent;
    color: var(--ink);
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.btn-pill:hover { background: var(--bg); }
.btn-pill--ok { border-color: var(--pistachio-deep); color: var(--pistachio-dark); background: var(--bg-mint); }
.btn-pill--ok:hover { background: var(--pistachio); color: #fff; border-color: var(--pistachio); }
.btn-pill--no { border-color: var(--coral); color: var(--coral); }
.btn-pill--no:hover { background: var(--coral); color: #fff; }
.btn-pill--edit { border-color: var(--honey); color: #b88516; background: var(--honey-soft); }
.btn-pill--edit:hover { background: var(--honey); color: var(--ink); }

/* Chart */
.chart { position: relative; }
.chart__svg { width: 100%; height: 240px; }
.chart__legend {
    display: flex;
    gap: 20px;
    margin-top: 12px;
    font-size: 12px;
    color: var(--ink-soft);
    font-weight: 600;
}
.chart__legend i {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 3px;
    margin-right: 6px;
    vertical-align: middle;
}

/* Channels */
.channels { display: flex; flex-direction: column; gap: 12px; }
.ch {
    display: grid;
    grid-template-columns: 130px 90px 1fr;
    gap: 12px;
    align-items: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
}
.ch__num { color: var(--ink-mute); font-size: 12px; text-align: right; font-weight: 700; }
.ch__bar {
    height: 8px;
    background: var(--bg-pistachio);
    border-radius: 4px;
    overflow: hidden;
}
.ch__bar span { display: block; height: 100%; background: var(--grad-pist); border-radius: 4px; }

/* Activity */
.activity { display: flex; flex-direction: column; gap: 6px; }
.activity li {
    padding: 12px 14px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: 10px;
    font-size: 13px;
    color: var(--ink-soft);
    display: flex;
    gap: 12px;
    align-items: baseline;
}
.activity li b { color: var(--ink); font-weight: 700; }
.activity__time {
    font-size: 11px;
    color: var(--ink-mute);
    flex-shrink: 0;
    min-width: 42px;
    font-weight: 700;
}
.activity__agent {
    font-size: 11px;
    color: var(--pistachio-dark);
    font-weight: 800;
    background: var(--bg-pistachio);
    padding: 3px 8px;
    border-radius: 5px;
    flex-shrink: 0;
    letter-spacing: 0.04em;
}

.dash-foot {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    color: var(--ink-mute);
    font-size: 13px;
}
.dash-foot a { color: var(--pistachio-deep); font-weight: 700; }

/* Responsive dashboard */
@media (max-width: 1100px) {
    .dash-body { grid-template-columns: 1fr; }
    .sidebar { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; }
    .side-nav { flex-direction: row; flex-wrap: wrap; flex: 1; }
    .side-nav__link span:last-child { display: none; }
    .side-account { margin-left: auto; }
    .kpis { grid-template-columns: repeat(2, 1fr); }
    .grid-2 { grid-template-columns: 1fr; }
    .swarm-row { grid-template-columns: 50px 1fr 80px; }
    .swarm-row > :nth-child(2), .swarm-row > :nth-child(4) { display: none; }
    .main { padding: 16px; }
    .topbar { flex-direction: column; align-items: flex-start; }
}
