/* =========================================================
   MOBILE FIXES — Chatterie du Diamant Sauvage
   Correctifs globaux pour les modales chats + hommage Kiara
========================================================= */

@media (max-width: 900px) {
    .kiara-tribute {
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }

    .kiara-tribute__image {
        object-position: center center;
    }

    .kiara-tribute__gold {
        inset: 14px;
        min-height: calc(100dvh - 28px);
    }

    .kiara-tribute__close {
        top: calc(env(safe-area-inset-top, 0px) + 18px);
        right: 22px;
        width: 50px;
        height: 50px;
        font-size: 2.05rem;
        z-index: 40;
    }

    .kiara-tribute__content {
        width: 100%;
        min-height: 100dvh;
        box-sizing: border-box;
        padding:
            calc(env(safe-area-inset-top, 0px) + 96px)
            24px
            calc(env(safe-area-inset-bottom, 0px) + 54px);
        justify-content: flex-end;
    }

    .kiara-tribute__brand {
        top: calc(env(safe-area-inset-top, 0px) + 28px);
        left: 24px;
        right: 88px;
        align-items: center;
    }

    .kiara-tribute__logo-wrap {
        width: 50px;
        height: 50px;
        flex-basis: 50px;
        padding: 7px;
    }

    .kiara-tribute__brand-text {
        min-width: 0;
    }

    .kiara-tribute__brand-text strong {
        white-space: normal;
        font-size: clamp(0.86rem, 4.2vw, 1.1rem);
        line-height: 1.05;
        letter-spacing: 0.05em;
    }

    .kiara-tribute__brand-text span {
        margin-top: 4px;
        font-size: 0.52rem;
        line-height: 1.45;
        letter-spacing: 0.20em;
    }

    .kiara-tribute__kicker {
        margin-bottom: 8px;
        font-size: 0.62rem;
        line-height: 1.45;
        letter-spacing: 0.17em;
    }

    .kiara-tribute__content h1 {
        font-size: clamp(3.75rem, 18.5vw, 5.4rem);
        line-height: 0.86;
        letter-spacing: -0.04em;
    }

    .kiara-tribute__subtitle {
        max-width: 300px;
        font-size: clamp(1.9rem, 9.5vw, 2.7rem);
        line-height: 1.02;
    }

    .kiara-tribute__line {
        width: min(315px, 100%);
        margin: 18px 0 16px;
    }

    .kiara-tribute__text,
    .kiara-tribute__quote {
        max-width: 100%;
        font-size: 0.86rem;
        line-height: 1.62;
    }

    .kiara-tribute__quote {
        margin-top: 10px;
    }

    .kiara-tribute__dates {
        margin-top: 14px;
        gap: 10px;
        font-size: 0.68rem;
        letter-spacing: 0.08em;
    }

    .kiara-tribute__actions {
        margin-top: 18px;
        gap: 10px;
    }

    .kiara-tribute__enter {
        width: 100%;
        min-height: 56px;
        padding: 0 20px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 0.72rem;
        letter-spacing: 0.15em;
    }

    .kiara-tribute__remember {
        position: relative;
        z-index: 3;
        justify-content: center;
        font-size: 0.74rem;
    }

    .kiara-tribute__scroll {
        display: none;
    }
}

@media (max-width: 900px) and (max-height: 760px) {
    .kiara-tribute__content {
        padding:
            calc(env(safe-area-inset-top, 0px) + 86px)
            22px
            calc(env(safe-area-inset-bottom, 0px) + 34px);
    }

    .kiara-tribute__content h1 {
        font-size: clamp(3.25rem, 16vw, 4.55rem);
    }

    .kiara-tribute__subtitle {
        font-size: clamp(1.55rem, 8vw, 2.15rem);
        max-width: 270px;
    }

    .kiara-tribute__line {
        margin: 14px 0 12px;
    }

    .kiara-tribute__text,
    .kiara-tribute__quote {
        font-size: 0.79rem;
        line-height: 1.48;
    }

    .kiara-tribute__quote {
        margin-top: 8px;
    }

    .kiara-tribute__dates {
        margin-top: 10px;
        font-size: 0.62rem;
    }

    .kiara-tribute__actions {
        margin-top: 13px;
    }

    .kiara-tribute__enter {
        min-height: 50px;
    }
}

@media (max-width: 430px) {
    .kiara-tribute__gold {
        inset: 10px;
    }

    .kiara-tribute__brand {
        left: 18px;
        right: 78px;
    }

    .kiara-tribute__close {
        right: 18px;
    }

    .kiara-tribute__content {
        padding-left: 18px;
        padding-right: 18px;
    }
}

/* =========================
   MODALES CHATS — MOBILE
========================= */

@media (max-width: 760px) {
    body.modal-open {
        overflow: hidden;
        touch-action: none;
    }

    .cat-modal {
        position: fixed;
        inset: 0;
        padding: 0;
        align-items: stretch;
        justify-content: stretch;
    }

    .cat-modal-panel {
        width: 100vw;
        max-width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        border-radius: 0;
        overflow: hidden;
        border-left: 0;
        border-right: 0;
    }

    .cat-modal-close {
        position: fixed;
        top: calc(env(safe-area-inset-top, 0px) + 14px);
        right: 14px;
        width: 48px;
        height: 48px;
        z-index: 9999999;
        background: rgba(17, 16, 11, 0.94);
        border-color: rgba(224, 201, 130, .38);
        box-shadow: 0 16px 40px rgba(0, 0, 0, .26);
    }

    .cat-modal-content {
        height: 100dvh;
        min-height: 100dvh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
        grid-template-columns: 1fr;
        gap: 16px;
        padding:
            calc(env(safe-area-inset-top, 0px) + 76px)
            16px
            calc(env(safe-area-inset-bottom, 0px) + 30px);
    }

    .cat-modal-content.is-active {
        display: block;
    }

    .cat-modal-gallery {
        display: block;
        margin-bottom: 18px;
    }

    .cat-modal-main-image {
        height: min(48vh, 360px);
        min-height: 265px;
        border-radius: 24px;
    }

    .cat-modal-thumbs {
        margin-top: 10px;
        display: flex;
        overflow-x: auto;
        padding: 8px;
        gap: 8px;
    }

    .cat-modal-thumbs button {
        flex: 0 0 62px;
        width: 62px;
        height: 62px;
        border-radius: 13px;
    }

    .cat-modal-info {
        height: auto;
        overflow: visible;
        padding: 0 0 24px;
    }

    .cat-modal-info .cat-status {
        margin-bottom: 14px;
    }

    .cat-modal-info h3 {
        padding-right: 58px;
        margin-bottom: 14px;
        font-size: clamp(32px, 10vw, 48px);
        line-height: .95;
        letter-spacing: -1.7px;
    }

    .cat-modal-info > p {
        font-size: 14.8px;
        line-height: 1.7;
    }

    .cat-modal-price {
        margin-top: 18px;
        padding: 18px;
        border-radius: 22px;
    }

    .cat-modal-grid,
    .cat-modal-family,
    .cat-modal-health,
    .cat-modal-parents-showcase {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .cat-modal-grid div,
    .cat-modal-family div,
    .cat-modal-health div {
        padding: 16px;
        border-radius: 20px;
    }

    .cat-modal-health {
        margin: 18px 0;
    }

    .cat-modal-pedigree {
        margin-top: 18px;
        padding: 18px;
        border-radius: 24px;
    }

    .cat-modal-pedigree-head h4 {
        font-size: 26px;
    }

    .cat-modal-parents-showcase figure,
    .cat-parent-placeholder {
        height: 210px;
    }

    .cat-pedigree-link,
    .cat-modal-info .btn {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 430px) {
    .cat-modal-content {
        padding-left: 12px;
        padding-right: 12px;
    }

    .cat-modal-main-image {
        height: min(43vh, 310px);
        min-height: 235px;
    }

    .cat-modal-info h3 {
        font-size: clamp(30px, 10.5vw, 42px);
    }

    .cat-modal-grid div,
    .cat-modal-family div,
    .cat-modal-health div {
        padding: 15px;
        border-radius: 18px;
    }
}


/* =========================================================
   KIARA HOMMAGE — MOBILE PREMIUM FINAL
   À coller tout en bas de public/css/mobile-fixes.css
========================================================= */

@media (max-width: 900px) {
    .kiara-tribute {
        overflow: hidden;
        background: #030201;
    }

    body.kiara-tribute-open {
        overflow: hidden;
        height: 100dvh;
    }

    .kiara-tribute__slideshow,
    .kiara-tribute__shade,
    .kiara-tribute__gold {
        pointer-events: none;
    }

    .kiara-tribute__image {
        object-fit: cover;
        object-position: center center;
        filter: brightness(.86) contrast(1.04) saturate(1.05);
    }

    .kiara-tribute__shade {
        background:
            linear-gradient(
                180deg,
                rgba(0, 0, 0, .34) 0%,
                rgba(0, 0, 0, .28) 24%,
                rgba(0, 0, 0, .62) 56%,
                rgba(0, 0, 0, .88) 100%
            ),
            linear-gradient(
                90deg,
                rgba(0, 0, 0, .50) 0%,
                rgba(0, 0, 0, .18) 52%,
                rgba(0, 0, 0, .46) 100%
            );
    }

    .kiara-tribute__gold {
        inset: 12px;
        min-height: auto;
        border-color: rgba(232, 190, 83, .34);
        box-shadow:
            inset 0 0 48px rgba(232, 190, 83, .035),
            0 0 48px rgba(0, 0, 0, .38);
    }

    .kiara-tribute__gold::before {
        left: -90px;
        top: 90px;
        width: 280px;
        height: 280px;
        opacity: .10;
        background-size: 34px 34px, 58px 58px;
    }

    .kiara-tribute__gold::after {
        opacity: .055;
    }

    .kiara-tribute__close {
        position: fixed;
        top: calc(env(safe-area-inset-top, 0px) + 18px);
        right: 20px;
        width: 46px;
        height: 46px;
        z-index: 50;
        border-color: rgba(232, 190, 83, .58);
        background: rgba(6, 5, 3, .72);
        color: #f4d27a;
        font-size: 1.95rem;
        box-shadow: 0 14px 34px rgba(0, 0, 0, .28);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
    }

    .kiara-tribute__content {
        width: 100%;
        max-width: 100%;
        min-height: 100dvh;
        padding:
            calc(env(safe-area-inset-top, 0px) + 90px)
            22px
            calc(env(safe-area-inset-bottom, 0px) + 34px);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        transform: none;
    }

    .kiara-tribute__brand {
        position: fixed;
        top: calc(env(safe-area-inset-top, 0px) + 18px);
        left: 20px;
        right: 78px;
        z-index: 45;
        display: flex;
        align-items: center;
        gap: 10px;
        margin: 0;
        min-width: 0;
    }

    .kiara-tribute__logo-wrap {
        width: 46px;
        height: 46px;
        flex: 0 0 46px;
        padding: 6px;
        border-color: rgba(232, 190, 83, .48);
        background: rgba(0, 0, 0, .30);
    }

    .kiara-tribute__brand-text {
        min-width: 0;
        max-width: 100%;
    }

    .kiara-tribute__brand-text strong {
        white-space: normal;
        color: #e8be53;
        font-size: clamp(.78rem, 3.8vw, .98rem);
        line-height: 1.08;
        letter-spacing: .055em;
    }

    .kiara-tribute__brand-text span {
        display: none;
    }

    .kiara-tribute__kicker {
        margin: 0 0 8px;
        color: #f1d483;
        font-size: .58rem;
        line-height: 1.45;
        letter-spacing: .17em;
    }

    .kiara-tribute__content h1 {
        margin: 0;
        font-size: clamp(3.15rem, 15vw, 4.75rem);
        line-height: .86;
        letter-spacing: -.045em;
        text-shadow:
            0 0 26px rgba(255, 247, 223, .12),
            0 10px 34px rgba(0, 0, 0, .72);
    }

    .kiara-tribute__subtitle {
        max-width: 270px;
        margin-top: 8px;
        font-size: clamp(1.45rem, 7.6vw, 2.15rem);
        line-height: 1.05;
    }

    .kiara-tribute__line {
        width: min(280px, 100%);
        margin: 14px 0 13px;
        gap: 10px;
    }

    .kiara-tribute__text,
    .kiara-tribute__quote {
        max-width: 100%;
        font-size: .80rem;
        line-height: 1.55;
        text-shadow: 0 2px 12px rgba(0, 0, 0, .78);
    }

    .kiara-tribute__quote {
        margin-top: 8px;
        color: rgba(255, 248, 232, .72);
    }

    .kiara-tribute__dates {
        margin-top: 12px;
        gap: 8px;
        font-size: .62rem;
        line-height: 1.5;
        letter-spacing: .075em;
    }

    .kiara-tribute__dates i {
        font-size: .72rem;
    }

    .kiara-tribute__actions {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 15px;
    }

    .kiara-tribute__enter {
        width: 100%;
        min-width: 0;
        min-height: 50px;
        padding: 0 18px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        font-size: .66rem;
        line-height: 1.25;
        letter-spacing: .135em;
        text-align: center;
        white-space: normal;
    }

    .kiara-tribute__enter span {
        margin-left: 10px;
    }

    .kiara-tribute__remember {
        position: relative;
        z-index: 3;
        width: fit-content;
        max-width: 100%;
        margin: 0 auto;
        padding: 7px 12px;
        justify-content: center;
        border-radius: 999px;
        color: rgba(255, 248, 232, .68);
        background: rgba(0, 0, 0, .22);
        font-size: .69rem;
        line-height: 1.2;
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
    }

    .kiara-tribute__remember input {
        width: 14px;
        height: 14px;
        flex: 0 0 auto;
    }

    .kiara-tribute__scroll {
        display: none;
    }
}

/* Téléphones bas type iPhone SE / petits Android */
@media (max-width: 900px) and (max-height: 740px) {
    .kiara-tribute__content {
        padding:
            calc(env(safe-area-inset-top, 0px) + 76px)
            20px
            calc(env(safe-area-inset-bottom, 0px) + 24px);
    }

    .kiara-tribute__logo-wrap {
        width: 42px;
        height: 42px;
        flex-basis: 42px;
    }

    .kiara-tribute__brand-text strong {
        font-size: .76rem;
    }

    .kiara-tribute__kicker {
        margin-bottom: 6px;
        font-size: .52rem;
    }

    .kiara-tribute__content h1 {
        font-size: clamp(2.75rem, 13.5vw, 4rem);
    }

    .kiara-tribute__subtitle {
        max-width: 240px;
        font-size: clamp(1.25rem, 6.8vw, 1.8rem);
    }

    .kiara-tribute__line {
        margin: 10px 0 9px;
    }

    .kiara-tribute__text,
    .kiara-tribute__quote {
        font-size: .72rem;
        line-height: 1.42;
    }

    .kiara-tribute__quote {
        margin-top: 6px;
    }

    .kiara-tribute__dates {
        margin-top: 8px;
        font-size: .55rem;
    }

    .kiara-tribute__actions {
        margin-top: 10px;
        gap: 7px;
    }

    .kiara-tribute__enter {
        min-height: 44px;
        font-size: .58rem;
    }

    .kiara-tribute__remember {
        padding: 5px 10px;
        font-size: .62rem;
    }
}

/* Petits écrans étroits */
@media (max-width: 430px) {
    .kiara-tribute__gold {
        inset: 10px;
    }

    .kiara-tribute__close {
        right: 18px;
        width: 44px;
        height: 44px;
    }

    .kiara-tribute__brand {
        left: 18px;
        right: 72px;
    }

    .kiara-tribute__content {
        padding-left: 18px;
        padding-right: 18px;
    }

    .kiara-tribute__content h1 {
        font-size: clamp(2.95rem, 14.8vw, 4.35rem);
    }

    .kiara-tribute__subtitle {
        max-width: 250px;
    }
}

/* Très petits écrans */
@media (max-width: 360px) {
    .kiara-tribute__content {
        padding-left: 16px;
        padding-right: 16px;
    }

    .kiara-tribute__content h1 {
        font-size: 2.72rem;
        letter-spacing: -.035em;
    }

    .kiara-tribute__subtitle {
        font-size: 1.28rem;
    }

    .kiara-tribute__text,
    .kiara-tribute__quote {
        font-size: .69rem;
    }

    .kiara-tribute__dates {
        font-size: .52rem;
    }
}

/* =========================================================
   KIARA HOMMAGE — CADRAGE PHOTOS MOBILE
   Corrige uniquement les images sur téléphone
========================================================= */

@media (max-width: 900px) {
    .kiara-tribute__slideshow {
        position: absolute;
        inset: 0 0 auto 0;
        height: 58vh;
        background:
            radial-gradient(circle at 50% 30%, rgba(232, 190, 83, .08), transparent 42%),
            #030201;
        overflow: hidden;
    }

    .kiara-tribute__image {
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: contain;
        object-position: center center;
        padding: 14px 14px 0;
        filter: brightness(.94) contrast(1.04) saturate(1.04);
        transform: scale(1.01);
    }

    .kiara-tribute__image.is-active {
        transform: scale(1);
    }

    .kiara-tribute__shade {
        background:
            linear-gradient(
                180deg,
                rgba(0, 0, 0, .10) 0%,
                rgba(0, 0, 0, .18) 30%,
                rgba(0, 0, 0, .66) 58%,
                rgba(0, 0, 0, .93) 100%
            );
    }

    .kiara-tribute__content {
        position: relative;
        z-index: 8;
    }
}

@media (max-width: 430px) {
    .kiara-tribute__slideshow {
        height: 55vh;
    }

    .kiara-tribute__image {
        padding: 12px 12px 0;
    }
}
