/* RouxLub · datasheet (ficha técnica) password-protected download — migrated component */
.roux-ficha-wrap { margin: 12px 0 24px; }
.roux-ficha-soon { margin: 12px 0 0; font-size: .92rem; color: #6b7280; font-style: italic; }

.roux-ficha-trigger {
  display: inline-block; padding: 14px 32px;
  background: #E33028; color: #fff;
  font-family: inherit; font-weight: 600; font-size: 1rem; letter-spacing: .02em;
  border: 0; border-radius: 6px; cursor: pointer;
  box-shadow: 0 2px 6px rgba(227, 48, 40, .25);
  transition: filter .15s ease, box-shadow .15s ease, transform .1s ease;
  text-decoration: none; line-height: 1.2;
}
.roux-ficha-trigger:hover { filter: brightness(.95); box-shadow: 0 4px 12px rgba(227, 48, 40, .32); color: #fff; }
.roux-ficha-trigger:active { transform: translateY(1px); }
.roux-ficha-trigger:focus-visible { outline: 3px solid rgba(227, 48, 40, .35); outline-offset: 2px; }

.roux-ficha-dlg {
  border: 0; border-radius: 12px; padding: 28px 26px; max-width: 420px; width: 90vw;
  font-family: inherit; color: #1a1a1a; background: #fff; box-shadow: 0 14px 50px rgba(0, 0, 0, .22);
}
.roux-ficha-dlg::backdrop { background: rgba(0, 0, 0, .55); }
.roux-ficha-dlg h3 { margin: 0 0 6px; font-size: 1.2rem; font-weight: 700; color: #1B3A6B; }
.roux-ficha-dlg p { margin: 0 0 18px; font-size: .95rem; color: #555; }
.roux-ficha-dlg label { display: block; font-size: .82rem; font-weight: 600; color: #444; margin-bottom: 4px; letter-spacing: .02em; }
.roux-ficha-dlg input[type="password"] {
  width: 100%; padding: 8px 0; border: 0; border-bottom: 2px solid #B9B9C5; border-radius: 0;
  background: transparent; font: inherit; font-size: 1rem; color: #1a1a1a; outline: none; box-sizing: border-box;
  transition: border-color .15s ease;
}
.roux-ficha-dlg input[type="password"]:focus { border-bottom-color: #E33028; }
.roux-ficha-err { color: #c0392b; font-size: .88rem; min-height: 1.3em; margin: 10px 0 6px; }
.roux-ficha-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 14px; }
.roux-ficha-cancel, .roux-ficha-ok {
  padding: 11px 22px; border: 0; border-radius: 6px; cursor: pointer; font: inherit;
  font-weight: 600; font-size: .95rem; letter-spacing: .02em; transition: filter .15s ease, background .15s ease;
}
.roux-ficha-cancel { background: #eef0f3; color: #333; }
.roux-ficha-cancel:hover { background: #e2e6ea; }
.roux-ficha-ok { background: #E33028; color: #fff; }
.roux-ficha-ok:hover { filter: brightness(.92); }

@media (max-width: 480px) {
  .roux-ficha-dlg { padding: 24px 20px; }
  .roux-ficha-actions { flex-direction: column-reverse; }
  .roux-ficha-cancel, .roux-ficha-ok { width: 100%; }
}
