/* Modal de confirmación (compartido entre temas) */
.modal { position: fixed; inset: 0; display: none; place-items: center; z-index: 2000; }
.modal[aria-hidden="false"] { display: grid; }
.modal-overlay { position:absolute; inset:0; background: var(--color-overlay); backdrop-filter: blur(2px); }
.modal-panel { position:relative; z-index:1; width: min(720px, 94%); background: var(--modal-bg); border-radius: 12px; padding: 1.25rem; box-shadow: 0 18px 40px rgba(0,0,0,0.35); border: 1px solid var(--color-border); }
.modal-panel { max-height: 84vh; overflow: auto; }
.modal-panel h3 { margin: 0 0 0.75rem 0; font-size: 1.25rem; color: var(--modal-title-color, var(--color-accent)); text-align:center; }
.modal-body { color: var(--modal-text-color, var(--color-text-dark)); font-size: 1rem; line-height:1.5; margin-bottom: 1rem; }
.modal-body p { margin: 0.35rem 0; }
.modal-actions { display:flex; gap:0.75rem; justify-content:center; }
.modal-actions .btn-confirm, .modal-actions .btn-cancel { padding: 0.7rem 1.1rem; border-radius: 8px; font-weight:600; cursor:pointer; }
.modal-actions .btn-confirm { background: var(--modal-confirm-bg, var(--color-accent)); color: var(--modal-confirm-color, var(--color-primary)); border: none; box-shadow: var(--modal-confirm-shadow, 0 8px 24px rgba(58,13,23,0.16)); }
.modal-actions .btn-confirm:active { transform: translateY(1px); }
.modal-actions .btn-cancel { background: transparent; border: 1px solid var(--modal-cancel-border, rgba(58,13,23,0.12)); color: var(--modal-cancel-color, var(--color-text-dark)); }

/* Accessibility focus visuals */
.modal-panel :focus { outline: 3px solid rgba(61,16,27,0.12); border-radius: 6px; }

/* Bloquear scroll del body mientras el modal está abierto */
body.modal-open { overflow: hidden; }
