@media (min-width: 768px) {
    html,
    body {
        height: 100%;
        margin: 0;
        overflow: hidden;
    }
}

.signin-desktop,
.signin-row {
    min-height: 100vh;
}

.signin-row {
    align-items: stretch;
}

/* COLONNA SINISTRA (FORM) */
.col-left .content-wrapper {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.login-signin-page .col-left {
    padding-top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-signin-page .col-left .content-wrapper {
    width: 100%;
    max-width: 440px;
    min-height: 100%;
    margin: 0 auto;
}

.login-signin-page .petbuy-login-form {
    width: 100%;
    max-width: none;
    margin: 0;
}

/* COLONNA DESTRA (GRAFICA) */
.signin-right {
    position: relative;
    background-color: #f87537;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    overflow: hidden;
    height: 100%;
}

.signin-content-wrapper {
    width: 100%;
    max-width: 650px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
    text-align: center;
    position: relative;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.signin-slider-wrapper {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}

.signin-slider {
    position: relative;
    overflow: hidden;
    border-radius: 1rem;
    min-height: 460px;
    margin: 0 auto;
}

.signin-card {
    position: absolute;
    inset: 0;
    padding: 2rem 2rem 2.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
    opacity: 0;
    pointer-events: none;
    transform: translateZ(0);
    transition: opacity 0.6s ease;
}

.signin-card.active {
    opacity: 1;
    pointer-events: auto;
    display: flex;
}

.signin-card:not(.active) {
    display: none;
}

.signin-card .intro-section {
    text-align: center;
}

.signin-card .intro-section p {
    font-size: 0.95rem;
    line-height: 1.5;
}

.signin-card .dog-wrapper {
    width: 100%;
    max-width: 360px;
}

.signin-card .register-btn {
    width: 100%;
    max-width: 320px;
    border-radius: 999px;
    font-weight: 600;
}

.signin-slider-controls {
    margin-top: 1.5rem;
    display: flex;
    justify-content: center;
    gap: 0.75rem;
}

.signin-slider-control {
    background: rgba(255, 255, 255, 0.25);
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 0.45rem 1.25rem;
    color: #fff;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.signin-slider-control.active {
    background: #fff;
    color: #f87537;
    border-color: #fff;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
}

.dog-wrapper {
    position: relative;
    max-width: 550px;
    width: 100%;
    margin: 1.5rem auto 0 auto;
}

.dog-img {
    width: 100%;
    height: auto;
    position: relative;
    z-index: 5;
}

/* ==========================================================
   ZAMPE ARANCIONI (STATICHE A SINISTRA DELLA COLONNA DESTRA)
   ========================================================== */
.paw-orange {
    position: absolute;
    pointer-events: none;
    z-index: 1;
    filter: invert(51%) sepia(63%) saturate(1764%) hue-rotate(350deg) brightness(101%) contrast(96%);
    opacity: 0.9;
}

/* sparse su tutta la colonna, lato sinistro */
.paw-left-big-orange {
    left: 4%;
    top: 8%;
    width: 22%;
}

.paw-left-mid-orange {
    left: 10%;
    top: 38%;
    width: 18%;
}

.paw-left-small-orange {
    left: 3%;
    top: 68%;
    width: 14%;
}

/* ==========================================================
   ZAMPE BIANCHE
   - gruppo A: vicine al cane (relative al dog-wrapper)
   - gruppo B: molto più sparse sul lato destro (relative alla colonna)
   ========================================================== */

/* generico bianco */
.paw-white {
    position: absolute;
    pointer-events: none;
    z-index: 4;
    will-change: transform;
}

/* --- GRUPPO A: intorno al cane (dog-wrapper) --- */
.paw-dog-1 {
    right: 0%;
    top: 8%;
    width: 14%;
}

.paw-dog-2 {
    right: -4%;
    top: 42%;
    width: 18%;
}

.paw-dog-3 {
    right: 6%;
    top: 74%;
    width: 13%;
}

/* --- GRUPPO B: sfondo lato destro colonna (signin-right) --- */
/* ancorate alla colonna, NON al dog-wrapper */
.paw-col-right-1 {
    right: 6%;
    top: 4%;
    width: 16%;
}

.paw-col-right-2 {
    right: -8%;
    top: 30%;
    width: 22%;
}

.paw-col-right-3 {
    right: 12%;
    top: 62%;
    width: 18%;
}

.paw-col-right-4 {
    right: -10%;
    top: 88%;
    width: 24%;
}

/* ANIMAZIONI morbide ma visibili */
@keyframes pawFloatA {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    50% {
        transform: translate(10px, -24px) rotate(2.5deg);
    }

    100% {
        transform: translate(0, 0) rotate(0deg);
    }
}

@keyframes pawFloatB {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    50% {
        transform: translate(-14px, -28px) rotate(-2deg);
    }

    100% {
        transform: translate(0, 0) rotate(0deg);
    }
}

@keyframes pawFloatC {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }

    50% {
        transform: translate(8px, -20px) rotate(1.5deg);
    }

    100% {
        transform: translate(0, 0) rotate(0deg);
    }
}

/* assegno animazioni diverse per creare effetto “casuale” */
.paw-dog-1 {
    animation: pawFloatA 7s ease-in-out infinite;
}

.paw-dog-2 {
    animation: pawFloatB 9s ease-in-out infinite;
}

.paw-dog-3 {
    animation: pawFloatC 6.5s ease-in-out infinite;
}

.paw-col-right-1 {
    animation: pawFloatA 8s ease-in-out infinite;
    animation-delay: -2s;
}

.paw-col-right-2 {
    animation: pawFloatB 10s ease-in-out infinite;
    animation-delay: -3s;
}

.paw-col-right-3 {
    animation: pawFloatC 7.5s ease-in-out infinite;
    animation-delay: -1s;
}

.paw-col-right-4 {
    animation: pawFloatA 11s ease-in-out infinite;
    animation-delay: -4s;
}

.field-status {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
    margin-top: 0.35rem;
    min-height: 1em;
    color: var(--petbuy-message-success-text, #1d7b42);
    visibility: hidden;
    transition: color 0.2s ease;
}

.field-status::before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.field-status.field-status-success {
    color: var(--petbuy-message-success-text, #1d7b42);
    visibility: visible;
}

.field-status.field-status-success::before {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--petbuy-message-success-text, #1d7b42);
}

.field-status.field-status-error {
    color: var(--petbuy-message-error-text, #d64550);
    visibility: visible;
}

.field-status.field-status-error::before {
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 10px solid currentColor;
    filter: drop-shadow(0 0 2px rgba(0,0,0,0.3));
}

.registration-flow-loading {
    min-height: 320px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.registration-flow-loading__spinner {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: 4px solid rgba(248, 117, 55, 0.18);
    border-top-color: #F87537;
    border-right-color: #F8BB39;
    box-shadow: 0 12px 24px rgba(248, 117, 55, 0.12);
    animation: registrationFlowLoaderSpin 0.85s linear infinite;
}

.registration-flow-error {
    min-height: 320px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    text-align: center;
}

.registration-flow-error p {
    max-width: 28rem;
    margin: 0;
}

.registration-flow-error__retry {
    min-width: 140px;
    height: 2.75rem;
    padding: 0 1.25rem;
    border: none;
    border-radius: 999px;
    background: #F87537;
    color: #FFFFFF;
    font-weight: 600;
}

.registration-field-control {
    position: relative;
}

.registration-field-control.has-tooltip input {
    padding-right: 3.15rem !important;
}

.registration-field-tooltip-trigger {
    position: absolute;
    top: 50%;
    right: 0.75rem;
    transform: translateY(-50%);
    width: 1.9rem;
    height: 1.9rem;
    border: 1px solid rgba(248, 117, 55, 0.24);
    border-radius: 999px;
    background: #FFFFFF;
    color: #F87537;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 8px 18px rgba(248, 117, 55, 0.12);
}

.registration-field-tooltip-trigger:focus-visible {
    outline: 2px solid #F87537;
    outline-offset: 2px;
}

@keyframes registrationFlowLoaderSpin {
    to {
        transform: rotate(360deg);
    }
}

.register-btn {
    background: #FFFFFF !important;
    color: #f87537 !important;
    width: 100%;
    height: 3.5rem;
    display: flex !important;
    justify-content: center;
    align-items: center;
    margin-top: 8rem;
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}

@media (max-width: 1024px) {
    .registration-signin-page,
    .registration-signin-page .signin-row {
        min-height: auto;
    }

    .registration-signin-page .signin-row {
        display: block;
        padding: 1.5rem !important;
    }

    .registration-signin-page .registration-signin-form-column {
        width: 100%;
        max-width: 100%;
        flex: 0 0 100%;
    }

    .registration-signin-page .col-left {
        padding-top: 0;
    }

    .registration-signin-page .col-left .content-wrapper {
        justify-content: center;
        align-items: center;
        min-height: auto;
    }

    .registration-signin-page .signin-right {
        display: none;
    }

    .registration-signin-page .ilform,
    .registration-signin-page #registration-flow-app {
        width: 100%;
        max-width: 520px;
        margin: 0 auto;
    }

    .registration-signin-page .registration-button-nav {
        width: auto;
        min-width: 132px;
        padding-inline: 1rem;
    }
}

@media (max-width: 600px) {
    .registration-signin-page .signin-row {
        padding: 1rem !important;
    }

    .registration-signin-page .col-left .content-wrapper {
        align-items: center;
    }

    .registration-signin-page .registration-step-nav {
        gap: 0.75rem;
    }

    .registration-signin-page .registration-button-nav {
        flex: 1 1 0;
        min-width: 0;
    }
}

.registration-signin-page .col-left .content-wrapper {
    align-items: center;
}

.registration-signin-page .ilform,
.registration-signin-page #registration-flow-app {
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
}

.registration-signin-page .registration-step-nav .registration-button-nav {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem;
    white-space: nowrap !important;
    min-height: 3.25rem;
    padding: 0 1.5rem;
}

.registration-signin-page .registration-step-nav .registration-button-spinner {
    margin-left: 0 !important;
}

.registration-signin-page .registration-step-nav .registration-button-nav.is-loading::after,
.registration-signin-page .registration-step-nav .registration-button-nav[aria-busy="true"]::after {
    content: none !important;
}
