/* ============================================================
   dashboard.css — Layout do app (sidebar, topbar, grid de cards
   do dashboard, gráficos, agenda do dia).
   ============================================================ */

/* ---------- Shell do app ---------- */
.app { display:flex; min-height:100vh; }

/* ---------- Sidebar ---------- */
.sidebar {
  width: var(--sidebar-w);
  background: var(--ink2);
  color: rgba(255,255,255,0.85);
  display:flex; flex-direction:column;
  position:fixed; inset:0 auto 0 0; z-index:50;
  transition: width 0.3s var(--ease), transform 0.3s var(--ease);
  border-right:1px solid rgba(201,169,110,0.1);
}
.sidebar-head {
  display:flex; align-items:center; gap:12px; padding:20px 22px;
  height:72px; border-bottom:1px solid rgba(255,255,255,0.06);
}
.sidebar-logo { height:40px; width:auto; filter:brightness(0) invert(1); opacity:0.92; transition:opacity 0.2s; }
.sidebar-collapse-btn {
  margin-left:auto; background:rgba(255,255,255,0.05); border:none; color:rgba(255,255,255,0.6);
  width:30px; height:30px; border-radius:7px; display:flex; align-items:center; justify-content:center; transition:0.2s;
}
.sidebar-collapse-btn:hover { background:rgba(201,169,110,0.15); color:var(--gold); }
.sidebar-nav { flex:1; overflow-y:auto; padding:14px 12px; display:flex; flex-direction:column; gap:2px; }
.nav-section-label { font-size:10px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:rgba(255,255,255,0.3); padding:14px 14px 6px; }
.nav-item {
  display:flex; align-items:center; gap:13px; padding:11px 14px;
  border-radius:9px; color:rgba(255,255,255,0.6); font-size:14px; font-weight:500;
  transition: background 0.18s, color 0.18s; white-space:nowrap;
}
.nav-item svg { width:19px; height:19px; flex-shrink:0; }
.nav-item span { transition: opacity 0.2s; }
.nav-item:hover { background:rgba(255,255,255,0.05); color:#fff; }
.nav-item.active { background: linear-gradient(135deg, var(--violet), var(--violet-mid)); color:#fff; box-shadow:0 4px 16px rgba(61,18,96,0.4); }
.nav-item.active svg { color: var(--gold); }
.nav-item.logout { color: rgba(255,255,255,0.45); margin-top:auto; }
.nav-item.logout:hover { background: var(--red-bg); color: #ff8b82; }
.sidebar-foot { padding:14px; border-top:1px solid rgba(255,255,255,0.06); }

/* Estado colapsado */
.app.collapsed .sidebar { width: var(--sidebar-w-collapsed); }
.app.collapsed .nav-item span,
.app.collapsed .nav-section-label,
.app.collapsed .sidebar-logo { opacity:0; pointer-events:none; }
.app.collapsed .sidebar-head { justify-content:center; }
.app.collapsed .nav-item { justify-content:center; padding:11px; }

/* ---------- Área principal ---------- */
.main {
  flex:1; margin-left: var(--sidebar-w);
  transition: margin-left 0.3s var(--ease);
  display:flex; flex-direction:column; min-width:0;
}
.app.collapsed .main { margin-left: var(--sidebar-w-collapsed); }

/* ---------- Topbar ---------- */
.topbar {
  height:72px; background: var(--surface); border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:16px; padding:0 28px;
  position:sticky; top:0; z-index:40;
}
.topbar-menu-btn { display:none; background:none; border:none; color:var(--text); padding:6px; }
.topbar h1 { font-size:20px; font-weight:600; }
.topbar .crumb { font-size:12.5px; color:var(--text-faint); }
.topbar-search {
  margin-left:auto; position:relative; max-width:300px; width:100%;
}
.topbar-search input {
  width:100%; background:var(--surface-2); border:1px solid var(--border);
  border-radius:40px; padding:9px 16px 9px 38px; font-size:13.5px; color:var(--text);
}
.topbar-search input:focus { outline:none; border-color:var(--violet); }
.topbar-search svg { position:absolute; left:13px; top:50%; transform:translateY(-50%); width:16px; height:16px; color:var(--text-faint); }
.topbar-actions { display:flex; align-items:center; gap:10px; }
.icon-btn { background:var(--surface-2); border:1px solid var(--border); width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--text-soft); transition:0.2s; position:relative; }
.icon-btn:hover { border-color:var(--violet); color:var(--violet); }
.icon-btn .dot { position:absolute; top:8px; right:9px; width:7px; height:7px; background:var(--gold); border-radius:50%; }
.avatar { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--violet),var(--violet-mid)); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; }

/* ---------- Conteúdo da página ---------- */
.page { padding:28px; flex:1; animation: fadeUp 0.4s var(--ease); }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:24px; flex-wrap:wrap; }
.page-head h2 { font-size:24px; font-weight:600; }
.page-head p { font-size:13.5px; color:var(--text-faint); margin-top:2px; }

/* ---------- Dashboard: cards KPI ---------- */
.kpi-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:16px; margin-bottom:24px; }
.kpi {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:20px; position:relative; overflow:hidden; transition: transform 0.25s, box-shadow 0.25s;
}
.kpi::before { content:''; position:absolute; top:0; left:0; bottom:0; width:3px; background:var(--gold); transform:scaleY(0); transform-origin:bottom; transition:transform 0.3s; }
.kpi:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.kpi:hover::before { transform:scaleY(1); }
.kpi-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.kpi-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; }
.kpi-icon svg { width:20px; height:20px; }
.kpi-icon.v1 { background:rgba(92,32,144,0.12); color:var(--violet-mid); }
.kpi-icon.v2 { background:var(--gold-light); color:#8a6d2f; }
.kpi-icon.v3 { background:var(--green-bg); color:var(--green); }
.kpi-icon.v4 { background:var(--blue-bg); color:var(--blue); }
.kpi-icon.v5 { background:var(--red-bg); color:var(--red); }
.kpi-icon.v6 { background:var(--amber-bg); color:var(--amber); }
.kpi-label { font-size:12px; color:var(--text-faint); font-weight:600; letter-spacing:0.02em; }
.kpi-value { font-size:28px; font-weight:700; font-family:'Barlow',sans-serif; line-height:1.1; margin-top:2px; }
.kpi-trend { font-size:11.5px; font-weight:600; margin-top:6px; display:inline-flex; align-items:center; gap:4px; }
.kpi-trend.up { color:var(--green); } .kpi-trend.down { color:var(--red); }

/* ---------- Dashboard: grid de painéis ---------- */
.dash-grid { display:grid; grid-template-columns:1.6fr 1fr; gap:16px; margin-bottom:16px; }
.dash-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.chart-box { position:relative; height:300px; padding:8px 4px; }
.chart-box canvas { max-height:100%; }

/* Lista de agenda do dia */
.agenda-mini { display:flex; flex-direction:column; }
.agenda-mini-item { display:flex; align-items:center; gap:14px; padding:14px 22px; border-bottom:1px solid var(--border); transition:background 0.15s; }
.agenda-mini-item:hover { background:var(--surface-2); }
.agenda-mini-item:last-child { border-bottom:none; }
.agenda-time { font-family:'Barlow',sans-serif; font-weight:700; font-size:15px; color:var(--violet-mid); width:54px; flex-shrink:0; }
.agenda-info { flex:1; min-width:0; }
.agenda-info .name { font-size:14px; font-weight:600; }
.agenda-info .meta { font-size:12px; color:var(--text-faint); }

/* Lista de últimos pacientes */
.mini-list { display:flex; flex-direction:column; }
.mini-list-item { display:flex; align-items:center; gap:12px; padding:13px 22px; border-bottom:1px solid var(--border); }
.mini-list-item:last-child { border-bottom:none; }
.mini-avatar { width:36px; height:36px; border-radius:50%; background:var(--surface-2); border:1px solid var(--border-2); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; color:var(--violet-mid); flex-shrink:0; }
.mini-list-item .name { font-size:13.5px; font-weight:600; }
.mini-list-item .meta { font-size:11.5px; color:var(--text-faint); }

@media (max-width:1200px){ .kpi-grid { grid-template-columns:repeat(3,1fr); } .dash-grid { grid-template-columns:1fr; } }
@media (max-width:900px){
  .sidebar { transform:translateX(-100%); width:var(--sidebar-w); }
  .app.mobile-open .sidebar { transform:translateX(0); box-shadow:var(--shadow-lg); }
  .main { margin-left:0 !important; }
  .topbar-menu-btn { display:flex; }
  .topbar-search { max-width:none; }
  .kpi-grid { grid-template-columns:1fr 1fr; }
  .dash-grid-2 { grid-template-columns:1fr; }
  .page { padding:18px; }
}
@media (max-width:560px){ .kpi-grid { grid-template-columns:1fr; } .topbar h1 { font-size:17px; } }
