/* ============================================
   ORIZEN GROUP — CALCULADORA TIRZEPATIDA v3
   ============================================ */

:root {
  --primary:       #1a56db;
  --primary-dark:  #1341a8;
  --primary-light: #e8f0fe;
  --success:       #10b981;
  --warning:       #f59e0b;
  --danger:        #ef4444;
  --purple:        #8b5cf6;
  --bg:            #f1f5f9;
  --surface:       #ffffff;
  --border:        #e2e8f0;
  --text-primary:  #0f172a;
  --text-secondary:#64748b;
  --text-muted:    #94a3b8;
  --radius:        12px;
  --radius-sm:     8px;
  --shadow:        0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --shadow-md:     0 4px 24px rgba(0,0,0,.10);
  --transition:    all 0.2s ease;
}

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

body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text-primary);
  min-height:100vh;
  font-size:14px;
  line-height:1.6;
}

/* ─── HEADER ─── */
.header {
  background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 60%,#1a56db 100%);
  padding:0 32px;
  box-shadow:0 2px 12px rgba(0,0,0,.18);
  position:sticky; top:0; z-index:100;
}
.header-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
}
.logo-area  { display:flex; align-items:center; gap:14px; }
.logo-icon  {
  width:44px; height:44px;
  background:linear-gradient(135deg,#1a56db,#06b6d4);
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:20px; color:#fff; box-shadow:0 2px 8px rgba(26,86,219,.4);
}
.logo-title { font-size:18px; font-weight:700; color:#fff; letter-spacing:-.3px; }
.logo-sub   { font-size:11px; color:rgba(255,255,255,.6); letter-spacing:.3px; }
.header-badge {
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2);
  color:#fff; padding:6px 14px; border-radius:20px;
  font-size:13px; font-weight:500; display:flex; align-items:center; gap:6px;
}

/* ─── MAIN ─── */
.main-container {
  max-width:1200px; margin:0 auto;
  padding:28px 24px 60px;
  display:flex; flex-direction:column; gap:20px;
}

/* ─── HERO ─── */
.hero {
  background:linear-gradient(135deg,#1a56db 0%,#0ea5e9 100%);
  border-radius:var(--radius); padding:32px 36px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  color:#fff; box-shadow:0 4px 20px rgba(26,86,219,.25);
}
.hero-text h1 { font-size:22px; font-weight:700; margin-bottom:8px; letter-spacing:-.3px; }
.hero-text p  { font-size:14px; opacity:.9; max-width:560px; line-height:1.7; }
.hero-icon    { font-size:64px; opacity:.2; flex-shrink:0; }

/* ─── CARD ─── */
.card {
  background:var(--surface); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:24px; border:1px solid var(--border);
}
.card-header {
  display:flex; align-items:center; gap:10px;
  margin-bottom:20px; padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.card-header.space-between { justify-content:space-between; }
.card-header i  { color:var(--primary); font-size:18px; }
.card-header h2 { font-size:16px; font-weight:600; }

/* ─── FORM ─── */
.form-group-cliente {
  margin-bottom: 20px;
}
.form-group-cliente label {
  font-size:12px; font-weight:700; color:var(--text-secondary);
  text-transform:uppercase; letter-spacing:.5px;
  display:block; margin-bottom:6px;
}
.form-group-cliente input {
  width: 100%;
  max-width: 420px;
  height:44px; padding:0 14px;
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:14px; font-family:'Inter',sans-serif;
  color:var(--text-primary); background:var(--bg);
  transition:var(--transition); outline:none;
}
.form-group-cliente input:focus {
  border-color:var(--primary); background:#fff;
  box-shadow:0 0 0 3px rgba(26,86,219,.10);
}

/* Cabeçalho das colunas de ampolas */
.ampolas-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  padding: 0 4px;
}
.ampolas-label {
  font-size:12px; font-weight:700; color:var(--text-secondary);
  text-transform:uppercase; letter-spacing:.5px;
}
.ampolas-colunas {
  display: flex;
  gap: 0;
  margin-right: 36px; /* espaço para o botão remover */
}
.ampolas-colunas span {
  font-size:11px; font-weight:700; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.4px;
  width: 220px;
}
.ampolas-colunas span:first-child { width: 240px; }

/* Linhas de ampola */
#linhas-ampolas { display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }

.ampola-linha {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  transition: var(--transition);
}
.ampola-linha:hover { border-color: #cbd5e1; }

.ampola-linha .form-group {
  margin:0; gap:0; flex:1;
}
.ampola-linha .form-group:first-child { flex: 1.2; }

.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label {
  font-size:12px; font-weight:700; color:var(--text-secondary);
  text-transform:uppercase; letter-spacing:.5px;
}
.form-group input,
.form-group select {
  height:42px; padding:0 14px;
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:14px; font-family:'Inter',sans-serif;
  color:var(--text-primary); background:#fff;
  transition:var(--transition); outline:none;
}
.form-group input:focus,
.form-group select:focus {
  border-color:var(--primary); background:#fff;
  box-shadow:0 0 0 3px rgba(26,86,219,.10);
}

/* Dentro das linhas, inputs sem borda própria (já tem a da linha) */
.ampola-linha select,
.ampola-linha input[type="number"] {
  border-color: transparent;
  background: transparent;
  padding: 0 8px;
}
.ampola-linha select:focus,
.ampola-linha input[type="number"]:focus {
  border-color: var(--primary);
  background: #fff;
}

/* Botão remover linha */
.btn-remove-linha {
  background: none; border:none; cursor:pointer;
  width:28px; height:28px; flex-shrink:0;
  border-radius:6px; color:var(--text-muted);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; transition:var(--transition);
}
.btn-remove-linha:hover { color:var(--danger); background:#fef2f2; }
.btn-remove-linha-placeholder { width:28px; flex-shrink:0; }

/* Botão adicionar linha */
.btn-add-linha {
  display: inline-flex; align-items:center; gap:7px;
  background: none; border: 1.5px dashed #93c5fd;
  color: var(--primary); border-radius: var(--radius-sm);
  padding: 8px 16px; font-size:13px; font-weight:600;
  font-family:'Inter',sans-serif; cursor:pointer;
  transition:var(--transition); margin-bottom:18px;
}
.btn-add-linha:hover { background:var(--primary-light); border-color:var(--primary); }

.form-actions { display:flex; gap:10px; flex-wrap:wrap; }

/* ─── PREVIEW ─── */
.preview-calculo {
  background:#f8fafc;
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:18px 20px;
  margin-bottom:20px;
}
.preview-header {
  display:flex; align-items:center; gap:8px;
  font-size:15px; font-weight:700; color:var(--text-primary);
  margin-bottom:4px;
}
.preview-header i { color:var(--primary); }
.preview-subtitle {
  font-size:12px; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.4px;
  margin-bottom:14px;
}

/* Dose utilizada no preview */
.pc-dose-usada {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--text-secondary);
  background: var(--primary-light);
  border: 1px solid #c7d7fa;
  border-radius: 6px;
  padding: 6px 12px;
  margin-bottom: 10px;
}
.pc-dose-usada i { color: var(--primary); }
.pc-dose-usada strong { color: var(--primary-dark); }

/* Grupos do preview */
.pc-grupos { display:flex; flex-direction:column; gap:8px; margin-bottom:10px; }
.pc-grupo {
  display:flex; align-items:center; gap:10px;
  background:#fff; border:1.5px solid var(--border);
  border-radius:var(--radius-sm); padding:10px 14px;
  transition: var(--transition);
}
.pc-grupo:hover { border-color: #93c5fd; }
.pc-g-count {
  font-size:22px; font-weight:800; color:var(--primary);
  min-width:36px; line-height:1;
}
.pc-g-desc { flex:1; font-size:13px; color:var(--text-primary); }
.pc-g-desc strong { color:var(--primary-dark); }
.pc-g-info {
  background:#eff6ff; color:#1d4ed8;
  padding:3px 10px; border-radius:12px;
  font-size:12px; font-weight:600; white-space:nowrap;
}

/* Rodapé informativo do preview */
.preview-regra {
  display:flex; align-items:center; gap:6px;
  font-size:12px; color:var(--text-muted);
  border-top:1px dashed var(--border);
  padding-top:10px; margin-top:2px;
}
.preview-regra i { color:var(--primary); }
.preview-regra strong { color:var(--text-secondary); }

/* ─── BOTÕES ─── */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600;
  font-family:'Inter',sans-serif;
  cursor:pointer; border:none;
  transition:var(--transition); white-space:nowrap;
}
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-dark); transform:translateY(-1px); box-shadow:0 4px 12px rgba(26,86,219,.3); }
.btn-outline { background:transparent; color:var(--primary); border:1.5px solid var(--primary); }
.btn-outline:hover { background:var(--primary-light); }
.btn-danger  { background:var(--danger); color:#fff; }
.btn-danger:hover { background:#dc2626; }
.btn-danger-outline { background:transparent; color:var(--danger); border:1.5px solid var(--danger); }
.btn-danger-outline:hover { background:#fef2f2; }

/* ─── SEARCH ─── */
.search-bar {
  display:flex; align-items:center; gap:10px;
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--radius-sm); padding:0 14px;
  margin-bottom:16px; transition:var(--transition);
}
.search-bar:focus-within { border-color:var(--primary); box-shadow:0 0 0 3px rgba(26,86,219,.08); }
.search-bar i { color:var(--text-muted); }
.search-bar input {
  flex:1; height:40px; border:none; background:transparent;
  font-size:14px; font-family:'Inter',sans-serif;
  color:var(--text-primary); outline:none;
}

/* ─── TABLE ─── */
.table-wrap { overflow-x:auto; border-radius:var(--radius-sm); border:1px solid var(--border); }
table { width:100%; border-collapse:collapse; font-size:13px; }
thead th {
  background:#f8fafc; color:var(--text-secondary);
  font-weight:700; font-size:11px;
  text-transform:uppercase; letter-spacing:.5px;
  padding:12px 16px; text-align:left;
  border-bottom:1px solid var(--border); white-space:nowrap;
}
tbody tr { border-bottom:1px solid #f1f5f9; transition:var(--transition); }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:#f8fafc; }
tbody td { padding:12px 16px; vertical-align:middle; }

/* Combinações inline na tabela */
.combinacoes-inline { display:flex; flex-direction:column; gap:5px; }
.combo-row {
  display:flex; align-items:center; gap:7px;
  font-size:12px; flex-wrap:wrap;
}
.combo-dose {
  background:var(--primary); color:#fff;
  padding:2px 9px; border-radius:12px;
  font-size:11px; font-weight:700; white-space:nowrap;
}
.combo-seta { color:var(--text-muted); font-size:11px; }
.combo-receitas {
  background:#d1fae5; color:#065f46;
  padding:2px 9px; border-radius:12px;
  font-size:11px; font-weight:700; white-space:nowrap;
}
.combo-dist { color:var(--text-muted); font-size:11px; }

.badge-dose {
  display:inline-flex; align-items:center;
  padding:4px 10px; border-radius:20px;
  font-size:12px; font-weight:600;
  background:var(--primary-light); color:var(--primary);
  white-space:nowrap;
}
.badge-receitas {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px;
  font-size:12px; font-weight:700;
  background:#d1fae5; color:#065f46;
}

.btn-icon {
  background:none; border:none; cursor:pointer;
  padding:6px 8px; border-radius:6px;
  color:var(--text-muted); transition:var(--transition); font-size:14px;
}
.btn-icon-primary:hover { color:var(--primary); background:var(--primary-light); }
.btn-icon-danger:hover  { color:var(--danger);  background:#fef2f2; }

/* Itens múltiplos na tabela */
.itens-wrap { display:flex; flex-direction:column; gap:10px; }
.item-linha { display:flex; flex-direction:column; gap:4px; }

/* Bloco de item no modal de detalhe */
.detalhe-item-bloco {
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 16px;
  background: #fafbfc;
}
.detalhe-item-titulo {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  font-size:14px; font-weight:700; color:var(--text-primary);
  margin-bottom:6px;
}
.detalhe-item-titulo i { color:var(--primary); }
.detalhe-regra {
  font-size:12px; color:var(--text-muted);
  background: var(--primary-light); border-radius: 6px;
  padding: 5px 10px; margin-bottom: 2px;
  display: inline-block;
}

/* Preview: bloco por ampola */
.preview-bloco {
  margin-bottom: 16px;
  background: #f8fafc;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
}
.preview-bloco:last-child { margin-bottom: 0; }
.preview-bloco-titulo {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  font-size:14px; font-weight:700; color:var(--text-primary);
  margin-bottom:12px; padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.preview-bloco-titulo i { color:var(--primary); }
.preview-bloco-badge {
  margin-left:auto;
  background:#d1fae5; color:#065f46;
  padding:3px 10px; border-radius:20px;
  font-size:12px; font-weight:700;
}

.empty-row td { padding:0; border:none; }
.empty-state { text-align:center; padding:48px 20px; color:var(--text-muted); }
.empty-state i { font-size:48px; margin-bottom:12px; display:block; opacity:.4; }
.empty-state p { font-size:14px; line-height:1.7; }

/* ─── TOTAIS ─── */
.totals-panel {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px,1fr));
  gap:16px;
}
.total-card {
  background:var(--surface); border-radius:var(--radius);
  padding:20px; display:flex; align-items:center; gap:16px;
  box-shadow:var(--shadow); border:1px solid var(--border);
  transition:var(--transition);
}
.total-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.total-icon {
  width:52px; height:52px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0;
}
.total-icon.blue   { background:#dbeafe; color:var(--primary); }
.total-icon.green  { background:#d1fae5; color:var(--success); }
.total-icon.purple { background:#ede9fe; color:var(--purple);  }
.total-info { display:flex; flex-direction:column; gap:2px; }
.total-label {
  font-size:12px; color:var(--text-secondary);
  font-weight:600; text-transform:uppercase; letter-spacing:.4px;
}
.total-value { font-size:28px; font-weight:800; color:var(--text-primary); line-height:1.1; letter-spacing:-.5px; }
.total-sub   { font-size:11px; color:var(--text-muted); }

/* ─── MODAL ─── */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.45); z-index:200;
  align-items:center; justify-content:center;
  backdrop-filter:blur(3px); padding:16px;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--surface); border-radius:var(--radius);
  width:100%; max-width:480px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
  animation:modalIn 0.2s ease;
  max-height:90vh; display:flex; flex-direction:column;
}
.modal-lg { max-width:720px; }
.modal-sm { max-width:380px; }
@keyframes modalIn {
  from { opacity:0; transform:scale(.95) translateY(-10px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.modal-header h3 {
  font-size:15px; font-weight:600;
  display:flex; align-items:center; gap:6px; color:var(--text-primary);
}
.modal-close {
  background:none; border:none; cursor:pointer;
  color:var(--text-muted); font-size:16px;
  padding:4px; border-radius:6px; transition:var(--transition);
}
.modal-close:hover { color:var(--text-primary); background:var(--bg); }
.modal-body {
  padding:22px; display:flex; flex-direction:column; gap:16px;
  overflow-y:auto;
}
.modal-body p { color:var(--text-secondary); font-size:14px; }
.modal-footer {
  display:flex; justify-content:flex-end; gap:10px;
  padding:16px 22px; border-top:1px solid var(--border); flex-shrink:0;
}

/* Detalhe do pedido */
.detalhe-info {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
  gap:10px;
  background:var(--primary-light); border:1px solid #c7d7fa;
  border-radius:var(--radius-sm); padding:14px 16px;
  font-size:13px;
}
.detalhe-info div { display:flex; align-items:center; gap:8px; color:var(--text-secondary); }
.detalhe-info i { color:var(--primary); }
.detalhe-info strong { color:var(--text-primary); }

.detalhe-sec-titulo {
  font-size:12px; font-weight:700; color:var(--text-secondary);
  text-transform:uppercase; letter-spacing:.5px;
  margin-top:4px; margin-bottom:0;
}
.detalhe-dose-bloco {
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px 16px;
  background:#fafbfc;
}
.detalhe-dose-titulo {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  margin-bottom:0;
}

/* ─── TOAST ─── */
.toast-container {
  position:fixed; bottom:24px; right:24px;
  display:flex; flex-direction:column; gap:10px; z-index:999;
}
.toast {
  display:flex; align-items:center; gap:10px;
  padding:12px 18px; border-radius:var(--radius-sm);
  color:#fff; font-size:13px; font-weight:500;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
  animation:toastIn 0.3s ease;
  min-width:260px; max-width:380px;
}
.toast.success { background:var(--success); }
.toast.error   { background:var(--danger);  }
.toast.info    { background:var(--primary); }
@keyframes toastIn  { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes toastOut { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(40px)} }

/* ─── RESPONSIVE ─── */
@media (max-width:768px) {
  .header { padding:0 16px; }
  .main-container { padding:16px 12px 40px; gap:14px; }
  .hero { flex-direction:column; padding:24px 20px; }
  .hero-icon { display:none; }
  .hero-text h1 { font-size:18px; }
  .form-grid { grid-template-columns:1fr; }
  .totals-panel { grid-template-columns:1fr 1fr; }
  .total-value { font-size:22px; }
  .card { padding:16px; }
  .card-header.space-between { flex-direction:column; align-items:flex-start; gap:10px; }
  .preview-cards { grid-template-columns:1fr; }
  .detalhe-info { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .totals-panel { grid-template-columns:1fr; }
  .header-badge { display:none; }
}
