@font-face {
    font-family: 'Product-Bold';
    src: url('../fonts/NBInternationalPro-Reg.woff2') format('woff2');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Product-Medium';
    src: url('../fonts/NBInternationalPro-Reg.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Product-Regular';
    src: url('../fonts/NBInternationalPro-Lig.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Recie';
    src: url('../fonts/RecifeDisplay-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

body:not(.logged-in) .z-10.absolute.pencil-edit.top-0.right-0.p-1.rounded-full.bg-blue-100.cursor-pointer {
    display: none !important;
}
.product-bold {
    font-family: 'Product-Bold', sans-serif;
}

.product-medium {
    font-family: 'Product-Medium', sans-serif;
}

.product-regular {
    font-family: 'Product-Regular', sans-serif;
}

.recie {
    font-family: 'Recie', sans-serif;
}

.text-8xl,.text-7xl,.text-6xl,.text-5xl,.text-4xl {
    font-family: 'Recie', sans-serif !important;
}

/* SQUIRCLE */

.button {
    --squircle-smooth: 0.9;
    --squircle-radius: 10px;
}

.img-radius {
    --squircle-smooth: 1;
    --squircle-radius: 20px;
}

.bloc-radius {
    --squircle-smooth: 1;
    --squircle-radius: 12px;
}

.fill-squircle {
    /*
    mask-image: paint(squircle);
    */
}

.outline-squircle-black {
    background: paint(squircle);
    --squircle-outline: 1px;
}

/* Chrome / Safari / Edge (Chromium) */
#guestPanel input[type="number"]::-webkit-inner-spin-button,
#guestPanel input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}

/* Tes presets de rayons */
.img-radius { --squircle-radius: 20px; }
.bloc-radius { --squircle-radius: 12px; }

/* ====== FILL (masque) ====== */
/* Par défaut (navigateurs sans CSS Paint) → simple arrondi */

.fill-squircle {
    /*
    border-radius: var(--squircle-radius, 16px);
    */
    border-radius: 0!important;
    overflow: hidden; /* utile pour les images/overlays */
}



/* ====== OUTLINE (contour + remplissage) ====== */
/* Fallback: on simule le contour avec un pseudo-élément et on applique juste une couleur de fond */
.outline-squircle-black {
    position: relative;
    border-radius: var(--squircle-radius, 12px);
    background: var(--squircle-fill); /* équiv. à ta var */
}
.outline-squircle-black::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    border: var(--squircle-outline, 1px) solid #000; /* contour */
}

/* Si paint() est supporté → on revient à ton rendu Houdini */
@supports (background: paint(squircle)) {
    .outline-squircle-black {
        background: paint(squircle);
    }
}


/* Firefox */
#guestPanel input[type="number"] {
    -moz-appearance: textfield;
}

.grey-input {
    background: #EBEDEB;
}
.bg-grey-input {
    background: #EBEDEB;
}

.grey-input:hover,
.grey-input:focus {
    background: #E2E2E2;
}

.with-blur-bg::after {
    content: "";
    background: var(--img);
    background-size: cover;
    position: absolute;
    inset: 0;
    filter: blur(9px) saturate(0.1) brightness(0.5);
    -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 45%, rgba(0, 0, 0, 1) 75%);
    z-index: 9;
    -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
}


.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }

.fade-edges::before {
    left: 0; background: linear-gradient(to right, rgba(255,255,255,1), rgba(255,255,255,0));
}
.fade-edges::after {
    right: 0; background: linear-gradient(to left, rgba(255,255,255,1), rgba(255,255,255,0));
}