body {
    min-height: max(884px, 100dvh);
}

.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
}

.paw-watermark {
    mask-image: url('https://fonts.gstatic.com/s/i/short-term/release/materialsymbolsoutlined/pets/default/48px.svg');
    mask-repeat: no-repeat;
    mask-size: contain;
    -webkit-mask-image: url('https://fonts.gstatic.com/s/i/short-term/release/materialsymbolsoutlined/pets/default/48px.svg');
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    background-color: #24657e;
}

.bg-paw-pattern {
    background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 10c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-5 2c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm10 0c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-5 4c-3.3 0-6 2.7-6 6s2.7 6 6 6 6-2.7 6-6-2.7-6-6-6z' fill='%2324657e' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E");
}

.flash {
    padding: 1rem 1.25rem;
    border-radius: 0.75rem;
    margin-bottom: 1.5rem;
    font-weight: 500;
}
.flash.success { background: #dcfce7; color: #166534; border-left: 4px solid #16a34a; }
.flash.error   { background: #ffdad6; color: #93000a; border-left: 4px solid #ba1a1a; }
.flash.info    { background: #bde9ff; color: #004d64; border-left: 4px solid #24657e; }

.field-error {
    color: #ba1a1a;
    font-size: 0.75rem;
    margin-top: 0.25rem;
}
