/*
Theme Name: lpo-child
Theme URI: 
Author: Ben Newman
Author URI: 
Description: 
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 5.7
Version: 
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Template: twentytwentyfive
Text Domain: lpo-child
Tags: 
*/

:root {
    --theme-rom-blue: #002B7F;
    --theme-rom-yellow: #FCD116;
    --theme-rom-red: #CE1126;
    --theme-dl-secondary-color: rgba(0, 43, 127, 0.04);
}

.paw-background {
    position: relative;
    z-index: 0;
    overflow: hidden;
}

.paw-background::after {
    content: "";
    position: absolute;
    inset: 0 0 0 auto;
    width: 8em;
    background-color: rgba(255,255,255,.05);
    mask-image: url("assets/images/dog-paw.svg");
    mask-position: bottom right;
    mask-repeat: no-repeat;
    mask-size: 100%;
    mask-mode: alpha;
    pointer-events: none;
    z-index: -1;
    transform: rotateZ(-40deg);
}

mark {
    background: none;
    display: inline;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M1 16 Q3 9 8 5 Q12 2.8 20 3 Q70 1.8 100 2 Q170 1.5 190 2.5 Q195 3 197 4.5 Q200 7 199 13 Q197 16.5 193 17.5 Q160 19.5 100 18.8 Q40 19.2 10 17.8 Q4 17 2 16.5 Z' fill='rgba(252,209,22,0.85)' /%3E%3C/svg%3E");
    background-position: center bottom;
    background-repeat: repeat-x;
    background-size: 100% 95%;
    padding: 0.1em 0.3em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.is-style-underline-accent-blue {
    text-decoration: none;
    display: inline;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M1 17 Q3 10 7 5 L10 4.5 Q50 3.2 100 2.8 Q150 2.2 190 1.5 Q194 1.2 196 0.5 L198 1 Q199 3 200 6 L200 15 Q198 16.5 195 17.2 Q150 18.5 100 18 Q50 17.8 10 17.5 Z' fill='rgba(0,43,127,0.3)' /%3E%3C/svg%3E");
    background-position: center bottom;
    background-repeat: repeat-x;
    background-size: 100% 85%;
    padding: 0.1em 0.3em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.is-style-underline-accent-yellow {
    text-decoration: none;
    display: inline;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M2 14 Q4 8 9 4 Q12 2.5 20 2.8 Q80 1.5 100 1.8 Q160 1.2 192 2 Q196 2.2 198 3.5 L199 5 Q200 8 199 14 Q197 17 193 17.8 Q150 19 100 18.5 Q50 19.2 12 18 Q5 17.5 3 16 Z' fill='rgba(252,209,22,0.4)' /%3E%3C/svg%3E");
    background-position: center bottom;
    background-repeat: repeat-x;
    background-size: 100% 90%;
    padding: 0.1em 0.3em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.is-style-underline-accent-red {
    text-decoration: none;
    display: inline;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 20' preserveAspectRatio='none'%3E%3Cpath d='M0 15 Q2 12 5 8 Q8 4 14 3 Q50 1.8 100 2.5 Q150 1.5 185 2.2 Q190 2 194 3.5 Q198 5 200 10 L200 12 Q198 15 194 16.5 Q188 18.5 180 18 Q140 19.5 100 18.8 Q60 19.5 20 18.2 Q8 17.5 4 16.5 Q1 15.5 0 15 Z' fill='rgba(206,17,38,0.25)' /%3E%3C/svg%3E");
    background-position: center bottom;
    background-repeat: repeat-x;
    background-size: 100% 85%;
    padding: 0.1em 0.3em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

/*
 Helpers
 */

.translate-up-sm {
    transform: translateY(-3rem);
}

.translate-up-md {
    transform: translateY(-6rem);
}

.translate-up-lg {
    transform: translateY(-9rem);
}

.mobile-only-separator {
    display: flex;
    gap: 1em;
    justify-content: center;
    border: none;
}

.mobile-only-separator::before {
    content: "";
    width: 1em;
    height: 1em;
    background-color: rgb(143 143 143 / 0.56);
    mask-image: url("assets/images/dog-paw.svg");
    mask-position: bottom right;
    mask-repeat: no-repeat;
    mask-size: 100%;
    mask-mode: alpha;
    rotate: -10deg;
    display: inline-block;
    transform: translateY(.2em);
}

.mobile-only-separator::after {
    content: "";
    width: 1em;
    height: 1em;
    background-color: rgb(143 143 143 / 0.56);
    mask-image: url("assets/images/dog-paw.svg");
    mask-position: bottom right;
    mask-repeat: no-repeat;
    mask-size: 100%;
    mask-mode: alpha;
    rotate: 10deg;
    display: inline-block;
}

@media (min-width: 480px) {
    .mobile-only-separator {
        display: none;
    }
}

/* ==========================================================================
   Description list — rendered as a table
   Used by the Pods "Traits Animal" template on single animal pages.
   ========================================================================== */

dl {
    display: grid;
    grid-template-columns: max-content 1fr;
    margin: 1em 0;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}

dl dt,
dl dd {
    margin: 0;
    padding: 0.6em 1em;
}

dl dt {
    font-weight: 700;
    background: var(--theme-dl-secondary-color);
}

dl dd {
    border-bottom: 1px solid var(--theme-dl-secondary-color);
}

dl > :nth-last-child(-n+2) {
    border-bottom: 0;
}

/* ==========================================================================
   Icon helpers
   Add the icon to the left of the element's text.
   ========================================================================== */

.has-heart-icon:not(:has(.wp-block-button__link))::before,
.has-heart-icon .wp-block-button__link::before {
    content: "";
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 0.5em;
    vertical-align: -0.15em;
    background-color: var(--theme-rom-red);
    mask-image: url("assets/images/heart.svg");
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    transform-origin: center;
}

@keyframes heart-pulse {
    0%   { transform: scale(1);   opacity: 1; }
    100% { transform: scale(2.5); opacity: 0; }
}

.has-heart-icon:not(:has(.wp-block-button__link)):hover::before,
.has-heart-icon:not(:has(.wp-block-button__link)):focus-visible::before,
.has-heart-icon .wp-block-button__link:hover::before,
.has-heart-icon .wp-block-button__link:focus-visible::before {
    animation: heart-pulse 1100ms ease-out infinite;
}

@media (prefers-reduced-motion: reduce) {
    .has-heart-icon:not(:has(.wp-block-button__link)):hover::before,
    .has-heart-icon:not(:has(.wp-block-button__link)):focus-visible::before,
    .has-heart-icon .wp-block-button__link:hover::before,
    .has-heart-icon .wp-block-button__link:focus-visible::before {
        animation: none;
    }
}

/* ==========================================================================
   Animal card
   ========================================================================== */

.animal-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    margin: 10px;
}

.animal-card--urgent .animal-card__image-block::before {
    content: "Urgent";
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 1;
    background: var(--theme-rom-red);
    color: #FFF;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.2em 0.6em;
    border-radius: 6px;
}

.animal-card__image-block {
    position: relative;
}


.animal-card__image-block .wp-block-read-more {
    position: absolute;
    right: -10px;
    bottom: 10px;
}

.animal-card__image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background-color: #f0f2f5;
    border-radius: 8px;
}

.animal-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 400ms ease-in-out;
}

.animal-card:hover .animal-card__image img {
    transform: scale(110%);
}

.animal-card__body {
    margin-block-start: 0;
    padding: .5em;
}

.animal-card__footer {
    margin-top: auto;
}

.animal-card .wp-block-post-title {
    font-size: 1.1em;
}

.animal-card .wp-block-read-more {
    display: block;
    background: var(--theme-rom-blue);
    color: #FFF;
    text-align: center;
    padding: 0 1em;
    line-height: 2.5em;
    text-decoration: none;
    transition: background-color 100ms ease-in-out;
    border-radius: 8px;
}

.animal-card .wp-block-read-more:hover {
    background: hsl(from var(--theme-rom-blue) h s calc(l - 8));
}

.animal-card .wp-block-read-more::after {
    content: " \2192";
    display: inline-block;
    margin-left: 0.4em;
    transition: transform 200ms ease-out;
}

.animal-card .wp-block-read-more:hover::after,
.animal-card .wp-block-read-more:focus-visible::after {
    transform: translateX(4px);
}

/* ==========================================================================
   Scroll-triggered fade-in
   Apply via the block editor: Advanced > Additional CSS class(es).
   The `js-fade-ready` class is added to <html> by assets/js/theme.js, which
   gates the hidden initial state — so the editor (no JS run) shows content
   normally instead of being stuck at opacity:0.
   The `is-visible` class is added per-element by the same script when it
   enters the viewport.
   ========================================================================== */

@media (prefers-reduced-motion: no-preference) {
    .js-fade-ready .fade-in-on-scroll,
    .js-fade-ready .fade-in-up-on-scroll,
    .js-fade-ready .fade-in-down-on-scroll,
    .js-fade-ready .fade-in-left-on-scroll,
    .js-fade-ready .fade-in-right-on-scroll {
        opacity: 0;
        transition: opacity 1000ms ease-out, transform 1000ms ease-out;
        will-change: opacity, transform;
    }

    .js-fade-ready .fade-in-up-on-scroll    { transform: translateY(24px); }
    .js-fade-ready .fade-in-down-on-scroll  { transform: translateY(-24px); }
    .js-fade-ready .fade-in-left-on-scroll  { transform: translateX(-24px); }
    .js-fade-ready .fade-in-right-on-scroll { transform: translateX(24px); }

    .js-fade-ready .fade-in-on-scroll.is-visible,
    .js-fade-ready .fade-in-up-on-scroll.is-visible,
    .js-fade-ready .fade-in-down-on-scroll.is-visible,
    .js-fade-ready .fade-in-left-on-scroll.is-visible,
    .js-fade-ready .fade-in-right-on-scroll.is-visible {
        opacity: 1;
        transform: none;
    }

    .js-fade-ready .fade-in-delay-1 { transition-delay: 150ms; }
    .js-fade-ready .fade-in-delay-2 { transition-delay: 300ms; }
    .js-fade-ready .fade-in-delay-3 { transition-delay: 450ms; }
    .js-fade-ready .fade-in-delay-4 { transition-delay: 600ms; }
    .js-fade-ready .fade-in-delay-5 { transition-delay: 750ms; }
    .js-fade-ready .fade-in-delay-6 { transition-delay: 1000ms; }
}

/* ==========================================================================
   Contact Form 7
   ========================================================================== */

.wpcf7 {
    --cf7-accent: #002B7F;
    --cf7-accent-hover: #001f5c;
    --cf7-accent-soft: rgba(0, 43, 127, 0.08);
    --cf7-accent-ring: rgba(0, 43, 127, 0.18);
    --cf7-border: #d4d7dd;
    --cf7-border-strong: #9aa0ab;
    --cf7-text: #1a1d22;
    --cf7-muted: #5a6472;
    --cf7-bg: #ffffff;
    --cf7-bg-subtle: #f7f8fa;
    --cf7-error: #ce1126;
    --cf7-error-soft: rgba(206, 17, 38, 0.08);
    --cf7-success: #1f7a3a;
    --cf7-success-soft: rgba(31, 122, 58, 0.08);
    --cf7-radius: 8px;
    --cf7-radius-sm: 4px;
    --cf7-gap: 1.25rem;

    color: var(--cf7-text);
}

.wpcf7-form p {
    margin: 0 0 var(--cf7-gap);
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.wpcf7-form p:last-of-type {
    margin-bottom: 0;
}

.wpcf7-form label {
    font-weight: 600;
    color: var(--cf7-text);
    display: block;
}

/* ---- Text-like inputs, textareas, selects ---- */
.wpcf7-form-control.wpcf7-text,
.wpcf7-form-control.wpcf7-email,
.wpcf7-form-control.wpcf7-tel,
.wpcf7-form-control.wpcf7-url,
.wpcf7-form-control.wpcf7-number,
.wpcf7-form-control.wpcf7-date,
.wpcf7-form-control.wpcf7-textarea,
.wpcf7-form-control.wpcf7-select {
    width: 100%;
    box-sizing: border-box;
    padding: 0.625rem 0.875rem;
    font: inherit;
    color: var(--cf7-text);
    background-color: var(--cf7-bg);
    border: 1px solid var(--cf7-border);
    border-radius: var(--cf7-radius);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
    -webkit-appearance: none;
    appearance: none;
}

.wpcf7-form-control.wpcf7-textarea {
    min-height: 7.5rem;
    resize: vertical;
    line-height: 1.5;
}

.wpcf7-form-control.wpcf7-select {
    padding-right: 2.5rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%235a6472' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.875rem center;
    background-size: 12px 8px;
    cursor: pointer;
}

.wpcf7-form-control.wpcf7-select[multiple] {
    background-image: none;
    padding-right: 0.875rem;
    min-height: 8rem;
}

.wpcf7-form-control::placeholder {
    color: var(--cf7-muted);
    opacity: 1;
}

.wpcf7-form-control:hover:not(:focus):not([disabled]):not([readonly]) {
    border-color: var(--cf7-border-strong);
}

.wpcf7-form-control:focus,
.wpcf7-form-control:focus-visible {
    outline: none;
    border-color: var(--cf7-accent);
    box-shadow: 0 0 0 3px var(--cf7-accent-ring);
}

.wpcf7-form-control[disabled],
.wpcf7-form-control[readonly] {
    background-color: var(--cf7-bg-subtle);
    color: var(--cf7-muted);
    cursor: not-allowed;
}

/* ---- Fieldsets ---- */
.wpcf7-form fieldset {
    border: 1px solid var(--cf7-border);
    border-radius: var(--cf7-radius);
    padding: 1.25rem 1.5rem 1.5rem;
    margin: 0.75rem 0 1.5rem;
    background-color: var(--cf7-bg-subtle);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.wpcf7-form fieldset:last-child {
    margin-bottom: 0;
}

.wpcf7-form fieldset > legend,
.wpcf7-form legend {
    padding: 0 0.5rem;
    margin-bottom: 0.25rem;
    font-weight: 600;
    color: var(--cf7-text);
}

/* ---- Radio / checkbox groups ---- */
.wpcf7-form-control.wpcf7-checkbox,
.wpcf7-form-control.wpcf7-radio,
.wpcf7-form-control.wpcf7-acceptance {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0;
    border: 0;
}

.wpcf7-form-control.wpcf7-checkbox.wpcf7-list-inline,
.wpcf7-form-control.wpcf7-radio.wpcf7-list-inline,
.wpcf7-list-item-wrap-inline {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
}

.wpcf7-list-item {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin: 0;
    padding: 0;
}

.wpcf7-list-item > label {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-weight: 400;
    cursor: pointer;
    line-height: 1.4;
}

.wpcf7-list-item-label {
    user-select: none;
}

/* Custom-styled native radio & checkbox */
.wpcf7-form input[type="radio"],
.wpcf7-form input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 1.125rem;
    height: 1.125rem;
    margin: 0.125rem 0 0 0;
    flex-shrink: 0;
    border: 1.5px solid var(--cf7-border-strong);
    background-color: var(--cf7-bg);
    cursor: pointer;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
    display: inline-grid;
    place-content: center;
}

.wpcf7-form input[type="radio"] {
    border-radius: 50%;
}

.wpcf7-form input[type="checkbox"] {
    border-radius: var(--cf7-radius-sm);
}

.wpcf7-form input[type="radio"]::before {
    content: "";
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background-color: var(--cf7-bg);
    transform: scale(0);
    transition: transform 0.12s ease;
}

.wpcf7-form input[type="checkbox"]::before {
    content: "";
    width: 0.625rem;
    height: 0.625rem;
    background-color: var(--cf7-bg);
    clip-path: polygon(14% 44%, 0 65%, 40% 100%, 100% 20%, 85% 5%, 38% 70%);
    transform: scale(0);
    transition: transform 0.12s ease;
}

.wpcf7-form input[type="radio"]:checked,
.wpcf7-form input[type="checkbox"]:checked {
    border-color: var(--cf7-accent);
    background-color: var(--cf7-accent);
}

.wpcf7-form input[type="radio"]:checked::before,
.wpcf7-form input[type="checkbox"]:checked::before {
    transform: scale(1);
}

.wpcf7-form input[type="radio"]:hover:not(:disabled),
.wpcf7-form input[type="checkbox"]:hover:not(:disabled) {
    border-color: var(--cf7-accent);
}

.wpcf7-form input[type="radio"]:focus-visible,
.wpcf7-form input[type="checkbox"]:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--cf7-accent-ring);
}

.wpcf7-form input[type="radio"]:disabled,
.wpcf7-form input[type="checkbox"]:disabled {
    background-color: var(--cf7-bg-subtle);
    border-color: var(--cf7-border);
    cursor: not-allowed;
}

.wpcf7-form input[type="radio"]:disabled + .wpcf7-list-item-label,
.wpcf7-form input[type="checkbox"]:disabled + .wpcf7-list-item-label {
    color: var(--cf7-muted);
}

/* ---- File input ---- */
.wpcf7-form-control.wpcf7-file {
    width: 100%;
    box-sizing: border-box;
    padding: 0.5rem;
    font: inherit;
    background-color: var(--cf7-bg);
    border: 1px dashed var(--cf7-border-strong);
    border-radius: var(--cf7-radius);
    cursor: pointer;
}

.wpcf7-form-control.wpcf7-file::file-selector-button {
    margin-right: 0.75rem;
    padding: 0.375rem 0.75rem;
    font: inherit;
    color: var(--cf7-bg);
    background-color: var(--cf7-accent);
    border: 0;
    border-radius: var(--cf7-radius-sm);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.wpcf7-form-control.wpcf7-file:hover::file-selector-button {
    background-color: var(--cf7-accent-hover);
}

.wpcf7-form-control.wpcf7-file:focus-visible {
    outline: none;
    border-color: var(--cf7-accent);
    box-shadow: 0 0 0 3px var(--cf7-accent-ring);
}

/* ---- Range ---- */
.wpcf7-form-control.wpcf7-range {
    width: 100%;
    accent-color: var(--cf7-accent);
}

/* ---- Quiz ---- */
.wpcf7-form-control.wpcf7-quiz {
    width: 100%;
    box-sizing: border-box;
    padding: 0.625rem 0.875rem;
    font: inherit;
    border: 1px solid var(--cf7-border);
    border-radius: var(--cf7-radius);
}

.wpcf7-form-control.wpcf7-quiz:focus-visible {
    outline: none;
    border-color: var(--cf7-accent);
    box-shadow: 0 0 0 3px var(--cf7-accent-ring);
}

/* ---- Submit button ---- */
.wpcf7-form-control.wpcf7-submit {
    align-self: flex-start;
    padding: 0.75rem 1.5rem;
    font: inherit;
    font-weight: 600;
    color: #fff;
    background-color: var(--cf7-accent);
    border: 0;
    border-radius: var(--cf7-radius);
    cursor: pointer;
    transition: background-color 0.15s ease, transform 0.05s ease, box-shadow 0.15s ease;
}

.wpcf7-form-control.wpcf7-submit:hover:not(:disabled) {
    background-color: var(--cf7-accent-hover);
}

.wpcf7-form-control.wpcf7-submit:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--cf7-accent-ring);
}

.wpcf7-form-control.wpcf7-submit:active:not(:disabled) {
    transform: translateY(1px);
}

.wpcf7-form-control.wpcf7-submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ---- Spinner ---- */
.wpcf7-spinner {
    margin-left: 0.75rem;
    vertical-align: middle;
}

/* ---- Validation ---- */
.wpcf7-not-valid-tip {
    display: block;
    margin-top: 0.375rem;
    color: var(--cf7-error);
    font-size: 0.875rem;
    font-weight: 500;
}

.wpcf7-form-control.wpcf7-not-valid:not([type="radio"]):not([type="checkbox"]) {
    border-color: var(--cf7-error);
    background-color: var(--cf7-error-soft);
}

.wpcf7-form-control.wpcf7-not-valid:not([type="radio"]):not([type="checkbox"]):focus {
    box-shadow: 0 0 0 3px rgba(206, 17, 38, 0.18);
}

input[type="radio"].wpcf7-not-valid,
input[type="checkbox"].wpcf7-not-valid {
    border-color: var(--cf7-error);
}

/* ---- Response output (success / error banners) ---- */
.wpcf7-response-output {
    margin: 1rem 0 0;
    padding: 0.75rem 1rem;
    border-radius: var(--cf7-radius);
    border: 1px solid transparent;
    font-size: 0.9375rem;
    line-height: 1.5;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    color: var(--cf7-error);
    background-color: var(--cf7-error-soft);
    border-color: var(--cf7-error);
}

.wpcf7 form.sent .wpcf7-response-output {
    color: var(--cf7-success);
    background-color: var(--cf7-success-soft);
    border-color: var(--cf7-success);
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
    color: var(--cf7-error);
    background-color: var(--cf7-error-soft);
    border-color: var(--cf7-error);
}

/* Screen-reader-only live region CF7 renders at the top */
.screen-reader-response {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ---- Responsive ---- */
@media (max-width: 480px) {
    .wpcf7-form-control.wpcf7-submit {
        width: 100%;
        text-align: center;
    }
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
    .wpcf7-form-control,
    .wpcf7-form input[type="radio"],
    .wpcf7-form input[type="checkbox"],
    .wpcf7-form input[type="radio"]::before,
    .wpcf7-form input[type="checkbox"]::before,
    .wpcf7-form-control.wpcf7-submit {
        transition: none;
    }
}
