.ars-form {
  --ars-form-border: #d8dde2;
  --ars-form-soft: #eef6f5;
  --ars-form-accent: #00969b;
  --ars-form-action: #941430;
  max-width: 760px;
  margin-inline: auto;
}
.ars-form__header { margin-bottom: 1.5rem; }
.ars-form__eyebrow { margin: 0 0 .45rem; color: #941430; font-size: .78rem; font-weight: 800; letter-spacing: .08em; }
.ars-form__intro { max-width: 65ch; font-size: 1.08rem; }
.ars-form__body { padding: clamp(1rem, 4vw, 2rem); border: 1px solid var(--ars-form-border); border-top: 5px solid var(--ars-form-accent); border-radius: 4px; background: #fff; box-shadow: 0 8px 26px rgb(32 37 43 / 8%); }
.ars-form__grid { display: grid; gap: 1.15rem; }
.ars-form__field { min-width: 0; }
.ars-form__note { grid-column: 1 / -1; padding-top: .35rem; border-top: 4px solid #ff8f1f; }
.ars-form__note:first-child { padding-top: 0; }
.ars-form__note h3 { margin: 0 0 .35rem; color: #20252b; font-size: clamp(1.18rem, 2vw, 1.45rem); line-height: 1.2; }
.ars-form__note p { margin: 0; color: #53606a; font-size: .96rem; line-height: 1.55; }
.ars-form__field label:not(.ars-form__check) { display: block; margin-bottom: .35rem; font-weight: 750; }
.ars-form__field input:not([type="checkbox"]), .ars-form__field textarea, .ars-form__field select { width: 100%; min-height: 48px; padding: .7rem .8rem; border: 1px solid #7b858d; border-radius: 2px; color: #20252b; background: #fff; font: inherit; }
.ars-form__field textarea { min-height: 10rem; resize: vertical; }
.ars-form__field :is(input, textarea, select):focus-visible { outline: 3px solid #ffbf47; outline-offset: 2px; border-color: #20252b; }
.ars-form__signature { display: grid; gap: .65rem; }
.ars-form__signature-canvas { width: 100%; min-height: 11rem; border: 1px solid #7b858d; border-radius: 2px; background: linear-gradient(to bottom, #fff 0%, #fff 72%, #eef6f5 72%, #eef6f5 100%); touch-action: none; cursor: crosshair; }
.ars-form__signature-canvas:focus-visible { outline: 3px solid #ffbf47; outline-offset: 2px; border-color: #20252b; }
.ars-form__signature-clear { justify-self: start; min-height: 42px; padding: .55rem .85rem; border: 2px solid #7b858d; border-radius: 2px; color: #20252b; background: #fff; font: inherit; font-weight: 750; cursor: pointer; }
.ars-form__signature-clear:hover { border-color: #20252b; }
.ars-form__signature-clear:focus-visible { outline: 3px solid #ffbf47; outline-offset: 2px; }
.ars-form__check { display: flex; gap: .75rem; align-items: flex-start; padding: 1rem; border-radius: 3px; background: var(--ars-form-soft); }
.ars-form__check input { width: 1.35rem; height: 1.35rem; margin-top: .1rem; flex: 0 0 auto; }
.ars-form__description { margin: .4rem 0 0; color: #53606a; font-size: .88rem; line-height: 1.45; }
.ars-form__error { margin: .4rem 0 0; color: #9b1c31; font-size: .94rem; font-weight: 700; line-height: 1.4; }
.ars-form__field.has-error :is(input, textarea, select) { border: 2px solid #9b1c31; }
.ars-form__errors, .ars-form__success { margin-bottom: 1.25rem; padding: 1rem 1.25rem; border-left: 5px solid #9b1c31; background: #fff1f2; }
.ars-form__success { border-color: #287c4b; background: #edf8f1; }
.ars-form__errors :is(h2, h3), .ars-form__success :is(h2, h3) { margin: 0 0 .55rem; font-size: 1.2rem; }
.ars-form__errors ul { margin: 0; padding-left: 1.25rem; }
.ars-form__errors li + li { margin-top: .3rem; }
.ars-form__required { margin-top: 1.2rem; color: #53606a; font-size: .9rem; }
.ars-form__submit { min-height: 48px; padding: .75rem 1.2rem; border: 2px solid var(--ars-form-action); border-radius: 2px; color: #fff; background: var(--ars-form-action); font: inherit; font-weight: 800; cursor: pointer; }
.ars-form__submit:hover { background: #6f0e23; border-color: #6f0e23; }
.ars-form__submit:focus-visible { outline: 3px solid #ffbf47; outline-offset: 3px; }
.ars-form__honeypot { position: absolute !important; width: 1px !important; height: 1px !important; overflow: hidden !important; clip: rect(1px, 1px, 1px, 1px) !important; white-space: nowrap !important; }
@media (min-width: 700px) { .ars-form__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .ars-form__field--wide { grid-column: 1 / -1; } }
@media (prefers-reduced-motion: reduce) { .ars-form *, .ars-form *::before, .ars-form *::after { scroll-behavior: auto !important; transition: none !important; } }
