.fr-wrapper { max-width: 620px; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
.fr-form label { display: block; font-size: 14px; margin-bottom: 6px; }
.fr-field { margin-bottom: 14px; }
.fr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fr-field input, .fr-field select, .fr-field textarea { width: 100%; padding: 6px 10px; border: 1px solid #ccc; border-radius: 6px; }
.fr-field input, .fr-field select { height: 38px; }
.fr-field textarea { min-height: 80px; }
.fr-field.fr-full { grid-column: 1 / -1; }
.fr-add-btn { background: #000; color: #fff; border: 0; padding: 10px 14px; border-radius: 8px; cursor: pointer; }
.fr-add-btn:hover { opacity: 0.92; }
.fr-additional { margin-top: 12px; }
.fr-area-row { display: grid; grid-template-columns: 1fr 1fr auto; gap: 12px; align-items: end; margin-bottom: 10px; }
.fr-area-row .fr-field { margin-bottom: 0; }
.fr-area-row .fr-remove { height: 38px; min-width: 160px; padding: 0 16px; border: 1px solid #ccc; background: #fff; border-radius: 6px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; white-space: nowrap; font-weight: 600; }
.fr-result { margin-top: 14px; font-size: 16px; }
.fr-note { font-size: 12px; color: #666; }
.fr-request { margin-top: 22px; }
.fr-request-toggle, .fr-send-btn { background: #0a0a0a; color: #fff; border: 0; padding: 10px 14px; border-radius: 8px; cursor: pointer; }
.fr-request-toggle:hover, .fr-send-btn:hover { opacity: .92; }
.fr-dropzone { margin-top: 8px; border: 2px dashed #bbb; border-radius: 8px; padding: 16px; text-align: center; cursor: pointer; }
.fr-dropzone.fr-drag { border-color: #000; }
.fr-file-list { list-style: none; padding: 0; margin: 10px 0 0; }
.fr-file-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.fr-file-item .fr-file-remove { margin-left: auto; height: 30px; padding: 0 12px; border: 1px solid #ccc; background: #fff; border-radius: 6px; cursor: pointer; }
.fr-progress { width: 120px; height: 6px; background: #eee; border-radius: 4px; overflow: hidden; }
.fr-progress .fr-bar { width: 0%; height: 100%; background: #000; }
.fr-upload-note strong { font-weight: 700; }
.fr-consent-wrap { margin-top: 8px; }
.fr-consent-label { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 400; }
.fr-consent-label input { width: auto; height: auto; transform: none; margin: 0; vertical-align: middle; accent-color: #000; }
.fr-status { margin-top: 10px; }
.fr-status.ok { font-weight: 700; font-size: 16px; }
.fr-status.error { color: #b00020; }
@media (max-width: 620px) {
.fr-grid { grid-template-columns: 1fr; }
.fr-area-row { grid-template-columns: 1fr; }
.fr-area-row .fr-remove { width: 100%; }
}