/* ============================================
   MEDICACAO-MODAL.CSS — Modal de dose/frequência
   ============================================
   Modal compartilhado visualmente por:
     - TagInput  (#dose-modal)      — medicamentos na anamnese
     - MUCInput  (#muc-dose-modal)  — medicamentos de uso contínuo

   Antes cada um usava cor fixa (azul / verde). Agora ambos seguem
   o design system LabNote: acento único acompanha a paleta
   personalizada via --accent-primary e dark mode via os tokens
   --color-*. Estado selecionado = classe .is-selected (uma só).

   Estrutura:
     §1  Overlay + diálogo
     §2  Cabeçalho
     §3  Corpo + seções
     §4  Apresentações (chips)
     §5  Inputs / select
     §6  Frequência (chips)
     §7  Rodapé + botões
   ============================================ */

/* §1 — Overlay + diálogo ───────────────────────────────────────── */
.medmod-overlay {
    position: fixed; inset: 0; z-index: 10000;
    display: flex; align-items: center; justify-content: center;
    padding: 16px;
    background: rgba(15, 23, 42, 0.45);
}
.medmod-overlay.hidden { display: none; }

.medmod-dialog {
    --mm-accent:      var(--accent-primary, #18355C);
    --mm-accent-soft: var(--accent-muted, color-mix(in srgb, var(--accent-primary, #18355C) 12%, transparent));
    width: 100%; max-width: 460px; max-height: 90vh; overflow-y: auto;
    background: var(--color-bg-primary, #ffffff);
    border: 1px solid var(--color-border-primary, #e2e8f0);
    border-radius: 14px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
    animation: medmod-in 160ms cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes medmod-in {
    from { opacity: 0; transform: translateY(8px) scale(0.985); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* §2 — Cabeçalho ───────────────────────────────────────────────── */
.medmod-header {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px;
    background: color-mix(in srgb, var(--mm-accent) 6%, var(--color-bg-primary, #fff));
    border-bottom: 1px solid var(--color-border-primary, #e2e8f0);
}
.medmod-header-icon {
    width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; font-size: 1.15rem;
    background: var(--mm-accent-soft);
    border: 1px solid color-mix(in srgb, var(--mm-accent) 22%, transparent);
}
.medmod-header-text { flex: 1; min-width: 0; }
.medmod-header-name {
    font-size: 0.95rem; font-weight: 700; color: var(--color-text-primary, #0c1f3b);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.medmod-header-class { font-size: 0.76rem; color: var(--color-text-muted, #94a3b8); margin-top: 1px; }
.medmod-close {
    width: 32px; height: 32px; flex-shrink: 0; cursor: pointer; border: none;
    border-radius: 8px; background: transparent; color: var(--color-text-muted, #94a3b8);
    display: flex; align-items: center; justify-content: center;
    transition: background 0.15s, color 0.15s;
}
.medmod-close:hover {
    background: var(--color-bg-tertiary, #f1f5f9);
    color: var(--color-text-primary, #1e293b);
}

/* §3 — Corpo + seções ──────────────────────────────────────────── */
.medmod-body { padding: 16px; display: flex; flex-direction: column; gap: 16px; }
.medmod-section { display: flex; flex-direction: column; gap: 6px; }
.medmod-section.hidden { display: none; }
.medmod-label {
    font-size: 0.74rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.02em; color: var(--color-text-secondary, #475569);
}

/* §4 — Apresentações (chips) ───────────────────────────────────── */
.medmod-apr-box {
    max-height: 116px; overflow-y: auto; padding: 8px;
    border-radius: 8px; display: flex; flex-direction: column; gap: 2px;
    background: var(--color-bg-secondary, #f8fafc);
    border: 1px solid var(--color-border-primary, #e2e8f0);
}
.medmod-apr-row { display: flex; align-items: flex-start; gap: 8px; padding: 2px 0; }
.medmod-apr-forma {
    font-size: 0.72rem; font-weight: 600; color: var(--color-text-secondary, #475569);
    flex-shrink: 0; min-width: 104px; max-width: 140px; padding-top: 3px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.medmod-apr-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.medmod-apr-chip {
    font-size: 0.72rem; padding: 2px 9px; border-radius: 999px; cursor: pointer;
    background: var(--color-bg-primary, #fff); color: var(--mm-accent);
    border: 1px solid color-mix(in srgb, var(--mm-accent) 28%, transparent);
    transition: background 0.13s, border-color 0.13s, box-shadow 0.13s;
}
.medmod-apr-chip:hover { background: var(--mm-accent-soft); }
.medmod-apr-chip.is-selected {
    background: var(--mm-accent); color: #ffffff; font-weight: 600;
    border-color: var(--mm-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--mm-accent) 20%, transparent);
}
.medmod-apr-chip.forma-chip {
    font-style: italic; color: var(--color-text-muted, #94a3b8);
    background: var(--color-bg-tertiary, #f1f5f9);
    border-color: var(--color-border-primary, #e2e8f0);
}
.medmod-apr-chip.forma-chip.is-selected {
    background: var(--color-border-secondary, #cbd5e1);
    color: var(--color-text-primary, #1e293b);
    font-style: normal; box-shadow: none;
}

/* §5 — Inputs / select ─────────────────────────────────────────── */
.medmod-dose-row { display: flex; gap: 8px; }
.medmod-input, .medmod-select {
    padding: 8px 10px; font-size: 0.88rem;
    border: 1px solid var(--color-border-input, #d1d5db); border-radius: 8px;
    background: var(--color-bg-input, #fff); color: var(--color-text-primary, #1e293b);
    outline: none; transition: border-color 0.15s, box-shadow 0.15s;
}
.medmod-input { flex: 1; min-width: 0; }
.medmod-select { width: 92px; flex-shrink: 0; cursor: pointer; }
.medmod-input:focus, .medmod-select:focus {
    border-color: var(--mm-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--mm-accent) 16%, transparent);
}

/* §6 — Frequência (chips) ──────────────────────────────────────── */
.medmod-freq-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.medmod-freq-btn {
    font-size: 0.76rem; padding: 5px 11px; border-radius: 8px; cursor: pointer;
    background: var(--mm-accent-soft); color: var(--mm-accent);
    border: 1px solid color-mix(in srgb, var(--mm-accent) 22%, transparent);
    transition: background 0.13s, color 0.13s, border-color 0.13s;
}
.medmod-freq-btn:hover { background: color-mix(in srgb, var(--mm-accent) 16%, transparent); }
.medmod-freq-btn.is-selected {
    background: var(--mm-accent); color: #ffffff; font-weight: 600;
    border-color: var(--mm-accent);
}
.medmod-outro-row { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.medmod-outro-label {
    font-size: 0.74rem; color: var(--color-text-muted, #94a3b8); white-space: nowrap;
}

/* §7 — Rodapé + botões ─────────────────────────────────────────── */
.medmod-foot {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding: 12px 16px;
    background: var(--color-bg-secondary, #f8fafc);
    border-top: 1px solid var(--color-border-primary, #e2e8f0);
}
.medmod-foot-actions { display: flex; gap: 8px; }
.medmod-btn {
    font-size: 0.84rem; font-weight: 600; border-radius: 8px; cursor: pointer;
    border: 1px solid transparent; transition: background 0.15s, color 0.15s, filter 0.15s;
    display: inline-flex; align-items: center; gap: 5px;
}
.medmod-btn-ghost { background: transparent; color: var(--color-text-secondary, #475569); padding: 7px 12px; }
.medmod-btn-ghost:hover {
    background: var(--color-bg-tertiary, #f1f5f9); color: var(--color-text-primary, #1e293b);
}
.medmod-btn-soft { background: var(--mm-accent-soft); color: var(--mm-accent); padding: 7px 12px; }
.medmod-btn-soft:hover { filter: brightness(0.97); }
.medmod-btn-primary { background: var(--mm-accent); color: #ffffff; padding: 8px 18px; }
.medmod-btn-primary:hover { filter: brightness(1.08); }

@media (max-width: 480px) {
    .medmod-foot { flex-direction: column-reverse; align-items: stretch; }
    .medmod-foot-actions { justify-content: flex-end; }
}
