/* =====================================================
   ESTILO compartilhado — Sistema Mohit
   Cores temáveis: hoje valores da Mohit; na Etapa 6 virão
   da tabela `clinicas`. Nunca chumbe cor fora deste :root.
   ===================================================== */
:root{
  --primaria:#A8744F;
  --primaria-clara:#C79A78;
  --secundaria:#6E7C5B;
  --escura:#2B2622;
  --clara:#F3EDE4;
  --clara-2:#EAE0D2;
  --branco:#FCFAF6;
  --linha:#DDD1BF;
  --erro:#7C3A3A;
  --texto-suave:#8a8074;
  --fonte:system-ui, 'Segoe UI', -apple-system, sans-serif;
  --sombra:0 1px 3px rgba(43,38,34,.06),0 8px 24px rgba(43,38,34,.06);
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:var(--fonte);
  background:var(--clara);
  color:var(--escura);
  line-height:1.5;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
/* Esconde a tela enquanto checa a sessão, pra não "piscar" conteúdo protegido. */
body[data-estado="carregando"]{visibility:hidden}

a{color:inherit;text-decoration:none}

/* ---------- Casca do app: sidebar + área principal ---------- */
.layout{display:flex;min-height:100vh}
.mandala{
  width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:radial-gradient(circle,var(--primaria) 30%,var(--escura) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;
}
.mandala img{width:100%;height:100%;object-fit:cover}

.sidebar{
  width:230px;background:var(--escura);color:var(--clara);flex-shrink:0;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
  padding:24px 0;z-index:50;
}
.sidebar .brand{display:flex;align-items:center;gap:12px;padding:0 22px 22px}
.sidebar .brand-name{font-weight:600;font-size:16px;line-height:1.1;color:var(--clara)}
.sidebar .brand-sub{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--primaria-clara)}
.sb-nav{display:flex;flex-direction:column;flex:1}
.sb-section{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,237,228,.35);padding:16px 24px 6px}
.sb-item{
  display:flex;align-items:center;gap:11px;padding:11px 24px;font-size:14px;
  color:rgba(243,237,228,.72);border-left:3px solid transparent;cursor:pointer;transition:.15s;
}
.sb-item:hover{background:rgba(255,255,255,.05);color:#fff}
.sb-item.active{background:rgba(168,116,79,.18);color:#fff;border-left-color:var(--primaria)}
.sb-icon{width:18px;text-align:center;font-size:15px;opacity:.9}
.sb-sair{
  margin:8px 16px 0;padding:10px;border:1px solid rgba(243,237,228,.25);
  background:transparent;color:var(--clara);border-radius:10px;font-size:13px;
  font-weight:600;cursor:pointer;font-family:inherit;transition:.15s;
}
.sb-sair:hover{background:rgba(255,255,255,.08)}

.main-area{flex:1;min-width:0;overflow-x:hidden}

/* Barra mobile (aparece só no celular) */
.topbar-mobile{display:none}
.sb-backdrop{display:none}
@media(max-width:768px){
  .sidebar{
    position:fixed;left:0;top:0;transform:translateX(-100%);
    transition:transform .2s ease;box-shadow:0 18px 50px rgba(0,0,0,.4);
  }
  .sidebar.aberta{transform:translateX(0)}
  .topbar-mobile{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:12px 16px;background:var(--branco);border-bottom:1px solid var(--linha);
    position:sticky;top:0;z-index:40;
  }
  .topbar-mobile .titulo{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}
  .menu-btn{background:transparent;border:none;font-size:22px;color:var(--escura);cursor:pointer;line-height:1;padding:4px}
  .sb-backdrop.aberta{display:block;position:fixed;inset:0;background:rgba(43,38,34,.45);z-index:45}
}

/* ---------- Botões ---------- */
.btn{
  background:var(--primaria);color:#fff;border:none;border-radius:10px;
  padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;
  font-family:inherit;
}
.btn:hover{background:var(--escura)}
.btn:disabled{opacity:.6;cursor:default}
.btn-ghost{background:transparent;color:var(--primaria);border:1px solid var(--primaria)}
.btn-ghost:hover{background:var(--primaria);color:#fff}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-perigo{background:var(--erro)}
.btn-perigo:hover{background:var(--escura)}
.btn-sair{
  background:transparent;color:var(--primaria);border:1px solid var(--primaria);
  border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;
  transition:.15s;font-family:inherit;flex-shrink:0;
}
.btn-sair:hover{background:var(--primaria);color:#fff}

/* ---------- Layout de página ---------- */
.conteudo{max-width:880px;margin:0 auto;padding:32px 24px}
.page-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-title{font-size:24px;font-weight:600}
.page-sub{color:var(--texto-suave);font-size:14px;margin-top:2px}

/* ---------- Cards ---------- */
.card{
  background:var(--branco);border:1px solid var(--linha);
  border-radius:16px;padding:22px;box-shadow:var(--sombra);margin-bottom:20px;
}
.card h2{font-size:16px;font-weight:600;margin-bottom:4px}
.card .card-sub{font-size:13px;color:var(--texto-suave);margin-bottom:16px}

/* ---------- Formulários ---------- */
label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.campo{margin-bottom:14px}
input,textarea,select{
  width:100%;padding:10px 12px;font-size:14px;font-family:inherit;
  border:1px solid var(--linha);border-radius:10px;background:var(--branco);
  color:var(--escura);transition:border-color .15s;
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primaria)}
textarea{resize:vertical}

.erro{
  display:none;background:#F0E1E1;color:var(--erro);
  font-size:13px;padding:10px 12px;border-radius:10px;margin-bottom:14px;
}
.erro.visivel{display:block}

/* ---------- Busca ---------- */
.busca{max-width:320px;margin-bottom:18px}

/* ---------- Tabela ---------- */
.rolavel{overflow-x:auto}
/* Colunas secundárias: somem no celular pra caber sem rolagem lateral. */
@media(max-width:640px){ .col-sec{display:none} }
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;
   color:var(--texto-suave);padding:10px 12px;border-bottom:2px solid var(--clara-2)}
td{padding:13px 12px;border-bottom:1px solid var(--clara-2)}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--clara)}
.cli-cell{display:flex;align-items:center;gap:10px}
.avatar{
  width:34px;height:34px;border-radius:50%;background:var(--clara-2);
  display:flex;align-items:center;justify-content:center;font-weight:700;
  font-size:13px;color:var(--primaria);flex-shrink:0;
}
.col-acao{text-align:right;white-space:nowrap}

/* ---------- Barra de progresso (pacotes) ---------- */
.prog{height:8px;background:var(--clara-2);border-radius:8px;overflow:hidden;width:140px}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--primaria-clara),var(--primaria));border-radius:8px}
.prog-text{font-size:12px;color:var(--texto-suave);margin-top:4px}

/* ---------- Tags de status ---------- */
.tag{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;white-space:nowrap;display:inline-block}
.tag-ok{background:#E6EBDD;color:var(--secundaria)}
.tag-alerta{background:#F4E9DC;color:var(--primaria)}
.tag-neutro{background:var(--clara-2);color:var(--texto-suave)}
.tag-urgente{background:#F0E1E1;color:var(--erro)}

/* ---------- Estado vazio ---------- */
.vazio{
  text-align:center;color:var(--texto-suave);font-size:14px;
  padding:28px 16px;
}

/* ---------- KPIs (dashboard) ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.kpi{background:var(--branco);border:1px solid var(--linha);border-radius:16px;padding:20px;box-shadow:var(--sombra)}
.kpi-label{font-size:12px;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.06em}
.kpi-value{font-size:30px;font-weight:700;margin-top:8px}
.kpi-sub{font-size:12px;margin-top:6px;color:var(--texto-suave)}
.kpi-sub.alerta{color:var(--primaria);font-weight:600}

/* ---------- Layout em duas colunas (agenda + calendário) ---------- */
.grid-agenda{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;align-items:start}
@media(max-width:860px){.grid-agenda{grid-template-columns:1fr}}

/* ---------- Seletor de dia ---------- */
.dia-nav{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.dia-nav .seta{
  background:var(--branco);border:1px solid var(--linha);border-radius:10px;
  width:34px;height:34px;font-size:16px;cursor:pointer;color:var(--texto-suave);
  display:flex;align-items:center;justify-content:center;transition:.15s;
}
.dia-nav .seta:hover{border-color:var(--primaria);color:var(--primaria)}
.dia-nav .rotulo{font-weight:600;font-size:15px;flex:1;text-transform:capitalize}
.dia-nav input[type="date"]{width:auto;padding:7px 10px}

/* ---------- Linha da agenda ---------- */
.agenda-row{
  display:flex;align-items:center;gap:14px;padding:12px 0;
  border-bottom:1px solid var(--clara-2);
}
.agenda-row:last-child{border-bottom:none}
.agenda-time{font-weight:700;font-size:14px;width:52px;color:var(--primaria);flex-shrink:0}
.agenda-info{flex:1;min-width:0}
.agenda-cli{font-weight:600;font-size:14px}
.agenda-serv{font-size:12.5px;color:var(--texto-suave)}
.agenda-extra{font-size:11.5px;color:var(--texto-suave);margin-top:1px}
.status-select{
  font-size:12px;font-weight:600;padding:6px 10px;border-radius:20px;width:auto;
  border:1px solid var(--linha);cursor:pointer;
}
.agenda-acoes{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ---------- Mini calendário ---------- */
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cal-head strong{font-size:14px;text-transform:capitalize}
.cal-nav{cursor:pointer;color:var(--texto-suave);font-size:18px;padding:0 6px;user-select:none}
.cal-nav:hover{color:var(--primaria)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.cal-dow{font-size:11px;color:var(--texto-suave);padding:4px 0;font-weight:600}
.cal-day{font-size:13px;padding:8px 0;border-radius:8px;cursor:pointer;position:relative}
.cal-day:hover{background:var(--clara-2)}
.cal-day.muted{color:#cfc4b4;cursor:default}
.cal-day.muted:hover{background:none}
.cal-day.sel{background:var(--clara-2);font-weight:700}
.cal-day.today{background:var(--primaria);color:#fff;font-weight:700}
.cal-day.has::after{
  content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--secundaria);
}
.cal-day.today.has::after{background:#fff}

/* ---------- Combobox com busca ---------- */
.combobox{position:relative}
.cb-input{width:100%}
.cb-lista{
  display:none;position:absolute;z-index:10;top:calc(100% + 4px);left:0;right:0;
  background:var(--branco);border:1px solid var(--linha);border-radius:10px;
  box-shadow:var(--sombra);max-height:200px;overflow-y:auto;
}
.cb-lista.aberta{display:block}
.cb-item{padding:9px 12px;font-size:14px;cursor:pointer}
.cb-item:hover,.cb-item.ativo{background:var(--clara-2)}
.cb-vazio{padding:9px 12px;font-size:13px;color:var(--texto-suave)}

/* ---------- Modal ---------- */
.modal-fundo{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(43,38,34,.45);align-items:center;justify-content:center;padding:20px;
}
.modal-fundo.aberto{display:flex}
.modal{
  width:100%;max-width:420px;background:var(--branco);border-radius:16px;
  padding:24px;box-shadow:var(--sombra);max-height:90vh;overflow-y:auto;
}
.modal h2{font-size:18px;font-weight:600;margin-bottom:16px}
.modal-acoes{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}
.modal-confirm{max-width:380px}
.dlg-msg{font-size:14px;color:var(--escura);margin-bottom:18px;white-space:pre-line}

/* ---------- Responsivo ---------- */
@media(max-width:640px){
  .topo{flex-wrap:wrap;gap:12px}
  .nav{order:3;width:100%}
  .conteudo{padding:24px 16px}
  .prog{width:100px}
}
