/* ====== Morganti Ju-Jitsu - estilos do front ====== */
.mjj-wrap { max-width: 980px; margin: 0 auto; font-size: 15px; }
.mjj-wrap * { box-sizing: border-box; }

.mjj-card {
	background: #fff; border: 1px solid #e3e3e3; border-radius: 10px;
	padding: 22px; margin-bottom: 20px; box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.mjj-card h3 { margin-top: 0; }
.mjj-center { text-align: center; }

/* Header */
.mjj-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }

/* Alertas */
.mjj-alert { padding: 12px 16px; border-radius: 8px; margin-bottom: 18px; font-weight: 500; }
.mjj-ok  { background: #e7f6ec; color: #1c6b38; border: 1px solid #b6e2c4; }
.mjj-erro{ background: #fdecec; color: #a12626; border: 1px solid #f3bcbc; }

/* Abas */
.mjj-tabs { display:flex; gap:6px; border-bottom:2px solid #eee; margin-bottom:18px; flex-wrap:wrap; }
.mjj-tab {
	background:none; border:none; padding:10px 16px; cursor:pointer;
	font-size:15px; font-weight:600; color:#777; border-bottom:3px solid transparent; margin-bottom:-2px;
}
.mjj-tab.active { color:#111; border-bottom-color:#c1121f; }
.mjj-tabcontent { display:none; }
.mjj-tabcontent.active { display:block; }

/* Formularios */
.mjj-wrap label { display:block; margin-bottom:14px; font-weight:600; font-size:14px; }
.mjj-wrap input[type=text], .mjj-wrap input[type=email], .mjj-wrap input[type=password],
.mjj-wrap input[type=date], .mjj-wrap select {
	display:block; width:100%; padding:9px 11px; margin-top:5px;
	border:1px solid #cfcfcf; border-radius:7px; font-size:15px; font-weight:400;
}
.mjj-grid { display:grid; grid-template-columns:1fr 1fr; gap:0 18px; }
.mjj-col2 { grid-column: 1 / -1; }
.mjj-inlinefield { display:inline-block; max-width:220px; }
.mjj-filterrow { display:flex; flex-wrap:wrap; gap:18px; align-items:flex-end; }

/* Botoes */
.mjj-btn {
	display:inline-block; background:#c1121f; color:#fff !important; border:none;
	padding:11px 20px; border-radius:7px; font-size:15px; font-weight:600;
	cursor:pointer; text-decoration:none; transition:background .15s;
}
.mjj-btn:hover { background:#9e0e18; }
.mjj-btn.mjj-ghost { background:#f0f0f0; color:#333 !important; }
.mjj-btn.mjj-ghost:hover { background:#e2e2e2; }
.mjj-btn.mjj-sm { padding:7px 14px; font-size:13px; }

.mjj-link { background:none; border:none; cursor:pointer; color:#0a5ad4; padding:0; font-size:13px; text-decoration:underline; }
.mjj-link.mjj-danger { color:#a12626; }
.mjj-inline { display:inline; }

/* Tabelas */
.mjj-tablewrap { overflow-x:auto; }
.mjj-table { width:100%; border-collapse:collapse; margin:6px 0 4px; font-size:14px; }
.mjj-table th, .mjj-table td { padding:9px 10px; border-bottom:1px solid #eee; text-align:left; }
.mjj-table thead th { background:#fafafa; font-size:12px; text-transform:uppercase; letter-spacing:.4px; color:#666; }
.mjj-table tfoot th { background:#fafafa; }
.mjj-actions { white-space:nowrap; }
.mjj-actions .mjj-inline { margin-left:8px; }
.mjj-row-inactive { opacity:.55; }

/* Pills / badges */
.mjj-pill { display:inline-block; padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600; }
.mjj-pill.ok { background:#e7f6ec; color:#1c6b38; }
.mjj-pill.no { background:#fdecec; color:#a12626; }

/* Faixas coloridas */
.mjj-belt { display:inline-block; padding:3px 10px; border-radius:5px; font-size:12px; font-weight:700; border:1px solid rgba(0,0,0,.15); }
.mjj-belt-branca   { background:#ffffff; color:#333; }
.mjj-belt-cinza    { background:#9aa0a6; color:#fff; }
.mjj-belt-amarela  { background:#ffe14d; color:#5c4b00; }
.mjj-belt-laranja  { background:#ff9c33; color:#5c2c00; }
.mjj-belt-vermelha { background:#e23b3b; color:#fff; }
.mjj-belt-azul     { background:#2f6fe0; color:#fff; }
.mjj-belt-verde    { background:#2faa55; color:#fff; }
.mjj-belt-roxa     { background:#7a3fb5; color:#fff; }
.mjj-belt-marrom   { background:#6b4226; color:#fff; }
.mjj-belt-preta    { background:#111; color:#fff; }
.mjj-belt-preta_dan{ background:#111; color:#ffd54a; border-color:#ffd54a; }

/* Caixa de totais do exame */
.mjj-totalbox {
	display:flex; flex-wrap:wrap; gap:18px; background:#f7f7f7; border:1px solid #e5e5e5;
	border-radius:8px; padding:14px 18px; margin:14px 0;
}
.mjj-totalbox strong { font-size:18px; color:#111; display:block; }

/* Estatisticas */
.mjj-stats { display:flex; flex-wrap:wrap; gap:14px; }
.mjj-stat { flex:1; min-width:140px; background:#f7f7f7; border-radius:8px; padding:16px; text-align:center; font-size:13px; color:#666; }
.mjj-stat span { display:block; font-size:24px; font-weight:700; color:#111; margin-bottom:4px; }

.mjj-muted { color:#888; }
.mjj-small { font-size:12px; }

/* Acoes / WhatsApp / PIX */
.mjj-actionsrow { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin:14px 0; }
.mjj-btn.mjj-wa { background:#25d366; color:#fff !important; }
.mjj-btn.mjj-wa:hover { background:#1da851; }
.mjj-inner { background:#fbfbfb; }

.mjj-pixbox { display:flex; flex-wrap:wrap; gap:20px; align-items:flex-start; background:#f7f7f7; border:1px solid #e5e5e5; border-radius:10px; padding:18px; margin-top:10px; }
.mjj-pix-left img { border:1px solid #ddd; border-radius:8px; background:#fff; padding:6px; }
.mjj-pix-right { flex:1; min-width:260px; }
.mjj-pix-code { width:100%; font-family:monospace; font-size:12px; padding:8px; border:1px solid #ccc; border-radius:6px; resize:vertical; word-break:break-all; }
.mjj-pix-right .mjj-btn { margin-top:8px; margin-right:8px; }

.mjj-emails { width:100%; max-width:520px; display:block; font-family:monospace; font-size:13px; padding:8px; border:1px solid #ccc; border-radius:6px; margin:4px 0 8px; }
.mjj-share { margin:12px 0; background:#f4f8ff; border:1px solid #cfe0ff; border-radius:10px; padding:14px; }
.mjj-share .mjj-btn { margin-right:8px; margin-bottom:6px; }
.mjj-share-steps { font-size:13px; color:#333; margin-bottom:10px; }
.mjj-share-step { display:inline-block; background:#fff; border:1px solid #d7e3f7; border-radius:20px; padding:3px 10px; margin:4px 6px 0 0; }
.mjj-copybig { font-size:17px; padding:14px 26px; background:#128c3f; box-shadow:0 2px 6px rgba(0,0,0,.15); }
.mjj-copybig:hover { background:#0f7a37; }
.mjj-share-open { margin-top:8px; }
.mjj-share .mjj-emails { background:#fff; margin-top:10px; }

/* Guia / dicas */
.mjj-guide { background:#f4f8ff; border-color:#cfe0ff; }
.mjj-steps-guide { margin:6px 0 12px; padding-left:20px; }
.mjj-steps-guide li { margin-bottom:8px; }
.mjj-tip { background:#fff7e0; border:1px solid #f2df9e; border-radius:8px; padding:10px 14px; font-size:14px; }
.mjj-next { background:#e7f6ec; border:1px solid #b6e2c4; border-radius:8px; padding:10px 14px; margin:12px 0; font-size:15px; }

/* <details> */
.mjj-details > summary { cursor:pointer; font-weight:700; font-size:16px; padding:6px 0; list-style:none; }
.mjj-details > summary::-webkit-details-marker { display:none; }
.mjj-details > summary::before { content:"▸ "; color:#c1121f; }
.mjj-details[open] > summary::before { content:"▾ "; }
.mjj-confirmbox { margin-top:14px; background:#fafafa; border:1px solid #eee; border-radius:8px; padding:12px 14px; }

/* Cartao de pedido em andamento */
.mjj-pedido { border:1px solid #e0e0e0; border-left:5px solid #c1121f; border-radius:10px; padding:16px; margin-bottom:18px; background:#fff; }
.mjj-pedido-head { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.mjj-pedido-foot { margin-top:12px; border-top:1px dashed #eee; padding-top:10px; }

/* Stepper */
.mjj-stepper { display:flex; gap:8px; margin:6px 0 6px; }
.mjj-step { flex:1; text-align:center; font-size:12px; color:#999; border-top:3px solid #e2e2e2; padding-top:8px; }
.mjj-step span { display:inline-flex; width:26px; height:26px; align-items:center; justify-content:center; border-radius:50%; background:#e2e2e2; color:#777; font-weight:700; margin-bottom:4px; }
.mjj-step.done { color:#1c6b38; border-top-color:#2faa55; }
.mjj-step.done span { background:#2faa55; color:#fff; }
.mjj-step.now { color:#c1121f; border-top-color:#c1121f; font-weight:700; }
.mjj-step.now span { background:#c1121f; color:#fff; }

@media print {
	.mjj-tab, .mjj-btn, .mjj-actionsrow, .mjj-header a, form.mjj-inline { display:none !important; }
	.mjj-tabcontent { display:block !important; }
}

@media (max-width:640px){ .mjj-grid { grid-template-columns:1fr; } }

/* ====== Estilos no admin ====== */
.mjj-admin-cards { display:flex; flex-wrap:wrap; gap:14px; margin-top:16px; }
.mjj-admin-card { background:#fff; border:1px solid #dcdcde; border-radius:8px; padding:18px 22px; min-width:160px; font-size:13px; color:#666; }
.mjj-admin-card span { display:block; font-size:26px; font-weight:700; color:#1d2327; margin-bottom:4px; }
