/* ───────────────────────────────────────────────
   Ápice Hub — Design System v2
   Sidebar escura premium + conteúdo claro
─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --bg: #F3F5F9;
  --surface: #FFFFFF;
  --surface-2: #F8FAFC;
  --border: #E5E9F0;
  --text: #0F1726;
  --muted: #64748B;
  --muted-2: #94A3B8;

  --sidebar: #0B0F1A;
  --sidebar-hover: #151C2C;
  --sidebar-text: #8B93A7;
  --sidebar-active: #FFFFFF;

  --gold: #C8A84B;
  --gold-soft: #F6EFDC;
  --primary: #0F1726;

  --green: #16A34A; --green-soft: #E8F7EE;
  --red: #DC2626;   --red-soft: #FDECEC;
  --blue: #2563EB;  --blue-soft: #EAF1FE;
  --purple: #7C3AED;--purple-soft: #F3EDFD;
  --orange: #EA8A0A;--orange-soft: #FDF3E3;

  --radius: 14px;
  --radius-sm: 10px;
  --shadow: 0 1px 3px rgba(15,23,38,.06), 0 4px 16px rgba(15,23,38,.05);
  --shadow-lg: 0 8px 32px rgba(15,23,38,.14);
}

* { margin:0; padding:0; box-sizing:border-box; }
html, body { height:100%; }
body {
  font-family:'Inter',-apple-system,sans-serif;
  background:var(--bg); color:var(--text);
  font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
input, select, textarea { font-family:inherit; font-size:14px; }

/* ─── Layout ─── */
.app { display:flex; height:100vh; overflow:hidden; }
.main { flex:1; display:flex; flex-direction:column; min-width:0; }
.content { flex:1; overflow-y:auto; padding:32px 40px; }
.content.flush { padding:0; overflow:hidden; display:flex; }

/* ─── Sidebar ─── */
.sidebar {
  width:248px; min-width:248px; background:var(--sidebar);
  display:flex; flex-direction:column; padding:20px 14px;
  height:100vh;
}
.sb-logo {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px 24px; color:#fff;
  font-weight:800; font-size:18px; letter-spacing:-.3px;
}
.sb-logo .dot { width:10px; height:10px; border-radius:50%; background:var(--gold); box-shadow:0 0 12px rgba(200,168,75,.6); }
.sb-logo small { color:var(--sidebar-text); font-weight:500; font-size:11px; display:block; margin-top:1px; }

.sb-client {
  margin:0 4px 18px; padding:12px 14px; border-radius:12px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.07);
}
.sb-client .cname { color:#fff; font-weight:600; font-size:13.5px; display:flex; align-items:center; gap:8px; }
.sb-client .cname .st { width:7px; height:7px; border-radius:50%; background:#22C55E; flex-shrink:0; }
.sb-client .crole { color:var(--sidebar-text); font-size:11.5px; margin-top:2px; }

.sb-section { color:#525B70; font-size:10.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:14px 12px 6px; }

.sb-nav { display:flex; flex-direction:column; gap:2px; flex:1; }
.sb-item {
  display:flex; align-items:center; gap:12px;
  padding:11px 12px; border-radius:10px;
  color:var(--sidebar-text); font-weight:500; font-size:14px;
  transition:all .15s; position:relative;
}
.sb-item:hover { background:var(--sidebar-hover); color:#D7DCE6; }
.sb-item.active { background:var(--sidebar-hover); color:#fff; font-weight:600; }
.sb-item.active::before {
  content:''; position:absolute; left:-14px; top:8px; bottom:8px;
  width:3px; border-radius:3px; background:var(--gold);
}
.sb-item svg { width:19px; height:19px; flex-shrink:0; }
.sb-item .bdg {
  margin-left:auto; background:var(--gold); color:#0B0F1A;
  font-size:11px; font-weight:700; padding:1px 7px; border-radius:20px;
}
.sb-foot { padding-top:12px; border-top:1px solid rgba(255,255,255,.07); }

/* ─── Topbar ─── */
.topbar {
  height:68px; min-height:68px; background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; padding:0 40px; gap:16px;
}
.topbar h1 { font-size:19px; font-weight:700; letter-spacing:-.3px; }
.topbar .sub { color:var(--muted); font-size:13px; }
.topbar .spacer { flex:1; }

/* ─── Cards ─── */
.card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow);
}
.card-pad { padding:24px; }
.card-title { font-size:15px; font-weight:700; margin-bottom:4px; }
.card-sub { color:var(--muted); font-size:13px; }

/* KPI */
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:18px; }
.kpi { padding:22px 24px; }
.kpi .k-icon {
  width:42px; height:42px; border-radius:11px; display:flex;
  align-items:center; justify-content:center; margin-bottom:14px;
}
.kpi .k-icon svg { width:21px; height:21px; }
.kpi .k-val { font-size:30px; font-weight:800; letter-spacing:-.8px; line-height:1.1; }
.kpi .k-label { color:var(--muted); font-size:13px; font-weight:500; margin-top:3px; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 18px; border-radius:10px; border:1px solid var(--border);
  background:var(--surface); color:var(--text);
  font-size:14px; font-weight:600; transition:all .15s; white-space:nowrap;
}
.btn:hover { background:var(--surface-2); border-color:#D3DAE4; }
.btn svg { width:16px; height:16px; }
.btn-primary { background:var(--primary); color:#fff; border-color:var(--primary); }
.btn-primary:hover { background:#1D2940; border-color:#1D2940; }
.btn-gold { background:var(--gold); color:#1A1407; border-color:var(--gold); }
.btn-gold:hover { background:#D4B65E; border-color:#D4B65E; }
.btn-danger { color:var(--red); }
.btn-danger:hover { background:var(--red-soft); border-color:#F5C8C8; }
.btn-sm { padding:7px 13px; font-size:13px; border-radius:8px; }
.btn-lg { padding:13px 24px; font-size:15px; border-radius:12px; }
.btn:disabled { opacity:.5; cursor:not-allowed; }

/* ─── Badges ─── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px; font-size:11.5px; font-weight:600;
}
.badge svg { width:11px; height:11px; }
.badge.meta { background:var(--blue-soft); color:var(--blue); }
.badge.organic { background:#EEF1F5; color:var(--muted); }
.badge.ai { background:var(--purple-soft); color:var(--purple); }
.badge.green { background:var(--green-soft); color:var(--green); }
.badge.red { background:var(--red-soft); color:var(--red); }
.badge.gold { background:var(--gold-soft); color:#8A6D1F; }
.badge.orange { background:var(--orange-soft); color:var(--orange); }
.badge.blue { background:var(--blue-soft); color:var(--blue); }
.badge.purple { background:var(--purple-soft); color:var(--purple); }
.badge.ig { background:linear-gradient(45deg,#F58529 0%,#DD2A7B 50%,#8134AF 100%); color:#fff; }

/* ─── Avatar ─── */
.avatar {
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:700; font-size:15px;
}
.avatar.sm { width:34px; height:34px; font-size:13px; }
.avatar.lg { width:56px; height:56px; font-size:20px; }

/* ─── Forms ─── */
.field { margin-bottom:18px; }
.field label { display:block; font-size:13px; font-weight:600; margin-bottom:7px; color:var(--text); }
.field .hint { font-size:12px; color:var(--muted-2); margin-top:5px; }
.input, .select, .textarea {
  width:100%; padding:11px 14px; border-radius:10px;
  border:1.5px solid var(--border); background:var(--surface);
  color:var(--text); outline:none; transition:border .15s;
}
.input:focus, .select:focus, .textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(200,168,75,.12); }
.textarea { resize:vertical; min-height:90px; line-height:1.55; }

/* Toggle */
.toggle {
  width:46px; height:26px; border-radius:20px; background:#CBD2DC;
  position:relative; cursor:pointer; transition:background .2s; flex-shrink:0; border:none;
}
.toggle::after {
  content:''; position:absolute; top:3px; left:3px; width:20px; height:20px;
  border-radius:50%; background:#fff; transition:left .2s; box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle.on { background:var(--green); }
.toggle.on::after { left:23px; }

/* ─── Tables ─── */
.table { width:100%; border-collapse:collapse; }
.table th {
  text-align:left; font-size:11.5px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--muted-2); padding:12px 16px;
  border-bottom:1px solid var(--border);
}
.table td { padding:14px 16px; border-bottom:1px solid var(--border); font-size:14px; }
.table tr:last-child td { border-bottom:none; }
.table tbody tr { transition:background .1s; }
.table tbody tr:hover { background:var(--surface-2); cursor:pointer; }

/* ─── Misc ─── */
.empty {
  text-align:center; padding:60px 20px; color:var(--muted);
}
.empty .e-icon { font-size:40px; margin-bottom:12px; opacity:.5; }
.empty h3 { font-size:16px; font-weight:700; color:var(--text); margin-bottom:6px; }
.empty p { font-size:13.5px; max-width:340px; margin:0 auto; }

.toast {
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(80px);
  background:var(--primary); color:#fff; padding:13px 24px; border-radius:12px;
  font-size:14px; font-weight:600; box-shadow:var(--shadow-lg);
  transition:transform .25s; z-index:999; display:flex; align-items:center; gap:10px;
}
.toast.show { transform:translateX(-50%) translateY(0); }
.toast.err { background:var(--red); }

.modal-bg {
  position:fixed; inset:0; background:rgba(11,15,26,.5); z-index:100;
  display:none; align-items:center; justify-content:center; backdrop-filter:blur(2px);
}
.modal-bg.open { display:flex; }
.modal {
  background:var(--surface); border-radius:18px; padding:28px;
  width:440px; max-width:92vw; max-height:88vh; overflow-y:auto; box-shadow:var(--shadow-lg);
}
.modal h3 { font-size:17px; font-weight:700; margin-bottom:18px; }

::-webkit-scrollbar { width:8px; height:8px; }
::-webkit-scrollbar-thumb { background:#CBD2DC; border-radius:8px; }
::-webkit-scrollbar-track { background:transparent; }

@media (max-width: 900px) {
  .sidebar { width:70px; min-width:70px; padding:16px 10px; }
  .sb-logo span, .sb-client, .sb-item span, .sb-section, .sb-item .bdg { display:none; }
  .sb-item { justify-content:center; }
  .content { padding:20px; }
  .topbar { padding:0 20px; }
}

/* ═══ MOBILE — sidebar vira barra inferior, conteúdo fluido ═══ */
@media (max-width: 820px) {
  .app { flex-direction: column; height: 100dvh; }

  /* sidebar → barra de navegação fixa embaixo */
  .sidebar {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
    width: 100%; height: 64px; min-height: 64px;
    flex-direction: row; align-items: stretch; padding: 0 4px;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .sb-logo, .sb-client, .sb-section { display: none; }
  .sb-nav { flex-direction: row; justify-content: space-around; align-items: stretch; gap: 0; flex: 1; }
  .sb-item {
    flex-direction: column; justify-content: center; gap: 3px;
    padding: 6px 8px; font-size: 9.5px; flex: 1; text-align: center; border-radius: 0;
  }
  .sb-item svg { width: 21px; height: 21px; }
  .sb-item.active::before { display: none; }
  .sb-item .bdg { position: absolute; top: 4px; right: 50%; margin-right: -22px; }
  .sb-item { position: relative; }
  .sb-foot { border: none; padding: 0; display: flex; }
  .sb-foot .sb-item { padding: 6px 10px; }

  /* conteúdo ocupa a tela, com folga pra barra */
  .main { padding-bottom: 64px; }
  .content { padding: 16px 14px; }
  .topbar { padding: 12px 14px; flex-wrap: wrap; gap: 10px; min-height: 0; }
  .topbar h1 { font-size: 17px; }

  /* kanban: colunas em largura de tela, swipe horizontal */
  .board-wrap { padding: 14px 12px !important; gap: 12px !important; }
  .kcol { width: 86vw !important; min-width: 86vw !important; }
  .crm-search { width: 100% !important; }

  /* grids viram coluna única */
  .row-2 { grid-template-columns: 1fr !important; }
  .cgrid { grid-template-columns: 1fr !important; }

  /* tabelas e cards respiram menos */
  .card { padding: 16px 14px; }
  .modal { width: 92vw; }
}
