.hero-form-card,
.ocf-form-shell,
.ocf-contact-form,
.ocf-booking-form {
    width: 100%;
    border: var(--card-border-width) solid var(--card-border-color);
    border-radius: var(--card-radius);
    background: var(--ocf-bg);
    box-shadow: var(--card-shadow);
    padding: clamp(1rem, 3vw, 1.75rem);
}

.hero-form-card {
    display: grid;
    gap: 1rem;
    align-self: stretch;
}

.hero-form-title {
    color: var(--ocf-heading);
    font-size: var(--text-xl);
    font-weight: 700;
    line-height: 1.2;
}

.hero-form-card p {
    margin: 0;
    color: var(--ocf-body);
    font-size: var(--text-sm);
}

.ocf-contact-form h2,
.ocf-booking-form h2 {
    margin: 0;
    color: var(--ocf-heading);
    font-size: var(--text-xl);
}

.ocf-contact-form form,
.ocf-booking-form form,
.ocf-simple-form,
.hero-form-fields,
.ocf-form-grid {
    display: grid;
    gap: 0.875rem;
}

.ocf-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.875rem;
}

.ocf-field,
.ocf-form-field,
.bw-field-group {
    display: grid;
    gap: 0.35rem;
}

.ocf-field label,
.ocf-form-field label,
.bw-field-label {
    color: var(--ocf-label);
    font-size: var(--text-sm);
    font-weight: 600;
}

.ocf-field input,
.ocf-field textarea,
.ocf-field select,
.ocf-form-field input,
.ocf-form-field textarea,
.ocf-form-field select,
.bw-input,
.bw-textarea {
    width: 100%;
    border: 1px solid var(--ocf-border);
    border-radius: var(--radius-sm);
    background: var(--ocf-bg);
    color: var(--ocf-heading);
    padding: 0.75rem;
    line-height: 1.35;
    transition: border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease), background var(--duration) var(--ease);
}

.ocf-field input:focus,
.ocf-field textarea:focus,
.ocf-field select:focus,
.ocf-form-field input:focus,
.ocf-form-field textarea:focus,
.ocf-form-field select:focus,
.bw-input:focus,
.bw-textarea:focus {
    outline: 2px solid color-mix(in srgb, var(--ocf-accent) 24%, transparent);
    outline-offset: 1px;
    border-color: var(--ocf-accent);
}

.ocf-field textarea,
.ocf-form-field textarea,
.bw-textarea {
    min-height: 7rem;
    resize: vertical;
}

.form-submit-btn {
    display: inline-flex;
    width: 100%;
    min-height: 2.85rem;
    align-items: center;
    justify-content: center;
    border: var(--button-border-width) solid var(--button-border-color);
    border-radius: var(--button-radius);
    background: var(--ocf-accent);
    color: var(--ocf-heading-alt);
    padding: 0.75rem 1rem;
    font-weight: 700;
}

.form-submit-btn:hover:not(:disabled) {
    background: var(--ocf-accent-hover);
}

.form-submit-btn:disabled {
    cursor: not-allowed;
    opacity: 0.55;
}

.hero-svc-list {
    display: grid;
    gap: 0.5rem;
}

.hero-svc-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    border: 1px solid var(--ocf-border-light);
    background: var(--ocf-bg);
    color: var(--ocf-heading);
    padding: 0.75rem;
    text-align: left;
}

.hero-svc-row:hover,
.hero-svc-row.is-selected {
    border-color: var(--ocf-accent);
    background: var(--ocf-bg-alt);
}

.hero-svc-check {
    display: inline-grid;
    width: 1.2rem;
    height: 1.2rem;
    place-items: center;
    border: 1px solid var(--ocf-border);
    color: transparent;
    flex: 0 0 auto;
}

.hero-svc-row.is-selected .hero-svc-check {
    background: var(--ocf-accent);
    color: var(--ocf-heading-alt);
    border-color: var(--ocf-accent);
}

.hero-svc-check svg {
    width: 0.85rem;
    height: 0.85rem;
}

@media (max-width: 640px) {
    .ocf-form-row { grid-template-columns: 1fr; }
}
