  /* Modal Ficha PDF */
  #ficha-modal {
    display: none; position: fixed; inset: 0; z-index: 9999;
    background: rgba(15, 23, 42, 0.55); align-items: center; justify-content: center;
  }
  #ficha-modal.visible { display: flex; }
  #ficha-modal .fm-card {
    background: #fff; border-radius: 10px; box-shadow: 0 10px 40px rgba(0,0,0,.25);
    width: 440px; max-width: calc(100% - 32px); padding: 22px 22px 18px;
    font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  }
  #ficha-modal .fm-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 14px;
  }
  #ficha-modal .fm-title {
    font-size: 15px; font-weight: 700; color: #1f2937; margin: 0;
  }
  #ficha-modal .fm-close {
    background: none; border: 0; font-size: 22px; line-height: 1; color: #6b7280;
    cursor: pointer; padding: 0 4px;
  }
  #ficha-modal .fm-label {
    display: block; font-size: 11px; font-weight: 600; color: #6b7280;
    text-transform: uppercase; letter-spacing: .04em; margin-bottom: 6px;
  }
  #ficha-modal .fm-input {
    width: 100%; padding: 9px 11px; font-size: 13px;
    border: 1px solid #d1d5db; border-radius: 6px; outline: none;
    font-family: "JetBrains Mono", "SF Mono", monospace;
  }
  #ficha-modal .fm-input:focus { border-color: #1f4e79; box-shadow: 0 0 0 3px rgba(31,78,121,.12); }
  #ficha-modal .fm-help {
    font-size: 11px; color: #6b7280; margin-top: 6px;
  }
  #ficha-modal .fm-actions {
    display: flex; gap: 8px; margin-top: 16px;
  }
  #ficha-modal .fm-btn {
    flex: 1; padding: 9px 14px; font-size: 13px; font-weight: 600;
    border: 0; border-radius: 6px; cursor: pointer;
    transition: background 0.15s;
  }
  #ficha-modal .fm-btn--secondary { background: #e5e7eb; color: #1f2937; }
  #ficha-modal .fm-btn--secondary:hover { background: #d1d5db; }
  #ficha-modal .fm-btn--primary   { background: #c0392b; color: #fff; }
  #ficha-modal .fm-btn--primary:hover:not(:disabled) { background: #a82d20; }
  #ficha-modal .fm-btn--primary:disabled { background: #d99c92; cursor: not-allowed; }
  #ficha-modal .fm-result {
    margin-top: 12px; padding: 10px 12px;
    background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 6px;
    font-size: 12px; line-height: 1.5; color: #1f2937;
  }
  #ficha-modal .fm-result.is-error { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
  #ficha-modal .fm-result.is-success { background: #ecfdf3; border-color: #c5e9d2; color: #166534; }
  #ficha-modal .fm-result .fm-cbml { font-family: "JetBrains Mono", monospace; font-weight: 700; }
  #ficha-modal .fm-loading { color: #6b7280; font-style: italic; font-size: 12px; margin-top: 10px; }

  /* Modal Ficha de Prefactibilidad */
  #prefact-modal {
    display: none; position: fixed; inset: 0; z-index: 9999;
    background: rgba(15, 23, 42, 0.55); align-items: flex-start; justify-content: center;
    padding: 28px 16px; overflow-y: auto;
  }
  #prefact-modal.visible { display: flex; }
  /* Modo panel lateral: el modal queda como drawer derecho fijo, con el mismo
     look del #tools-drawer (sombra suave, sin backdrop, alineado al borde).
     Cuando este panel está abierto, el #tools-drawer se oculta y el mapa se
     contrae para hacer espacio (igual que con el tools-drawer). */
  #prefact-modal.as-panel {
    background: transparent;
    inset: auto;
    top: 0; right: 0; bottom: 0;
    width: var(--prefact-panel-w);
    max-width: 92vw;
    padding: 0; overflow: hidden;
    align-items: stretch; justify-content: flex-start;
    pointer-events: none;                /* el card captura; lo demás pasa al mapa */
  }
  #prefact-modal.as-panel .pf-card {
    pointer-events: auto;
    width: 100%; max-width: none;
    height: 100%; overflow-y: auto;
    border-radius: 0;
    box-shadow: -2px 0 12px rgba(0,0,0,0.06);   /* mismo que tools-drawer */
    padding: 14px 16px 72px;
    background: var(--color-bg, #fff);
  }
  /* Coordinación con el resto de paneles cuando la ficha está abierta */
  body.pf-panel-open #tools-drawer { transform: translateX(100%); }
  body.pf-panel-open #map         { right: var(--prefact-panel-w); }
  body.pf-panel-open #ia-panel    { right: calc(var(--prefact-panel-w) + var(--space-3)); }
  body.pf-panel-open .ia-fab      { right: calc(var(--prefact-panel-w) + var(--space-3)); }
  body.pf-panel-open #pf-octavio  { right: var(--prefact-panel-w); }
