/*
Theme Name: LAFORGE THEME
Text Domain: lafoorgetheme
Version: 1.0
Tested up to: 6.3
Requires PHP: 7.4
Description: Ce thème a été spcécialement créer pour le site web laforgetattoo.fr.
Tags: classic theme, piercing, tattoo
Author: Dimitri JAUNATRE
Author URI: https://dimitri-jaunatre.fr
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

/* Personal CSS to fix WP */

/* Line clamp utilities */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}


/*! tailwindcss v4.1.7 | MIT License | https://tailwindcss.com */
@layer properties {
    @supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))) {

        *,
        :before,
        :after,
        ::backdrop {
            --tw-translate-x: 0;
            --tw-translate-y: 0;
            --tw-translate-z: 0;
            --tw-rotate-x: initial;
            --tw-rotate-y: initial;
            --tw-rotate-z: initial;
            --tw-skew-x: initial;
            --tw-skew-y: initial;
            --tw-space-y-reverse: 0;
            --tw-space-x-reverse: 0;
            --tw-border-style: solid;
            --tw-font-weight: initial;
            --tw-shadow: 0 0 #0000;
            --tw-shadow-color: initial;
            --tw-shadow-alpha: 100%;
            --tw-inset-shadow: 0 0 #0000;
            --tw-inset-shadow-color: initial;
            --tw-inset-shadow-alpha: 100%;
            --tw-ring-color: initial;
            --tw-ring-shadow: 0 0 #0000;
            --tw-inset-ring-color: initial;
            --tw-inset-ring-shadow: 0 0 #0000;
            --tw-ring-inset: initial;
            --tw-ring-offset-width: 0px;
            --tw-ring-offset-color: #fff;
            --tw-ring-offset-shadow: 0 0 #0000;
            --tw-duration: initial;
            --tw-ease: initial;
            --tw-scale-x: 1;
            --tw-scale-y: 1;
            --tw-scale-z: 1
        }
    }
}

@layer theme {

    :root,
    :host {
        --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
        --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
        --color-red-500: oklch(63.7% .237 25.331);
        --color-blue-500: oklch(62.3% .214 259.815);
        --color-blue-600: oklch(54.6% .245 262.881);
        --color-blue-700: oklch(48.8% .243 264.376);
        --color-gray-500: oklch(55.1% .027 264.364);
        --color-black: #000;
        --color-white: #fff;
        --spacing: .25rem;
        --container-2xl: 42rem;
        --container-6xl: 72rem;
        --text-xs: .75rem;
        --text-xs--line-height: calc(1/.75);
        --text-sm: .875rem;
        --text-sm--line-height: calc(1.25/.875);
        --text-base: 1rem;
        --text-base--line-height: 1.5;
        --text-lg: 1.125rem;
        --text-lg--line-height: calc(1.75/1.125);
        --text-xl: 1.25rem;
        --text-xl--line-height: calc(1.75/1.25);
        --text-2xl: 1.5rem;
        --text-2xl--line-height: calc(2/1.5);
        --text-3xl: 1.875rem;
        --text-3xl--line-height: 1.2;
        --text-4xl: 2.25rem;
        --text-4xl--line-height: calc(2.5/2.25);
        --text-5xl: 3rem;
        --text-5xl--line-height: 1;
        --font-weight-normal: 400;
        --font-weight-medium: 500;
        --font-weight-bold: 700;
        --font-weight-extrabold: 800;
        --radius-md: .375rem;
        --radius-3xl: 1.5rem;
        --ease-in-out: cubic-bezier(.4, 0, .2, 1);
        --default-transition-duration: .15s;
        --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
        --default-font-family: var(--font-sans);
        --default-mono-font-family: var(--font-mono);
        --color-twine-50: #f8f4ee;
        --color-twine-100: #eadcd0;
        --color-twine-200: #d4c2a8;
        --color-twine-300: #cead8c;
        --color-twine-400: #c4955f;
        --color-twine-500: #af8250;
        --color-twine-600: #9a7143;
        --color-twine-700: #875f36;
        --color-twine-900: #5d4527;
        --color-abey-300: #a7a8aa;
        --color-abey-400: #8e8f93;
        --color-abey-500: #76777b;
        --color-abey-600: #58595c;
        --color-abey-800: #4e4f53;
        --color-abey-900: #313234;
        --font-asap: "Asap", sans-serif;
        --font-nunito: "Nunito", sans-serif
    }
}

@layer base {

    *,
    :after,
    :before,
    ::backdrop {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    ::file-selector-button {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    html,
    :host {
        -webkit-text-size-adjust: 100%;
        -moz-tab-size: 4;
        tab-size: 4;
        line-height: 1.5;
        font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
        font-feature-settings: var(--default-font-feature-settings, normal);
        font-variation-settings: var(--default-font-variation-settings, normal);
        -webkit-tap-highlight-color: transparent
    }

    hr {
        height: 0;
        color: inherit;
        border-top-width: 1px
    }

    abbr:where([title]) {
        -webkit-text-decoration: underline dotted;
        text-decoration: underline dotted
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-size: inherit;
        font-weight: inherit
    }

    a {
        color: inherit;
        -webkit-text-decoration: inherit;
        text-decoration: inherit
    }

    b,
    strong {
        font-weight: bolder
    }

    code,
    kbd,
    samp,
    pre {
        font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
        font-feature-settings: var(--default-mono-font-feature-settings, normal);
        font-variation-settings: var(--default-mono-font-variation-settings, normal);
        font-size: 1em
    }

    small {
        font-size: 80%
    }

    sub,
    sup {
        vertical-align: baseline;
        font-size: 75%;
        line-height: 0;
        position: relative
    }

    sub {
        bottom: -.25em
    }

    sup {
        top: -.5em
    }

    table {
        text-indent: 0;
        border-color: inherit;
        border-collapse: collapse
    }

    :-moz-focusring {
        outline: auto
    }

    progress {
        vertical-align: baseline
    }

    summary {
        display: list-item
    }

    ol,
    ul,
    menu {
        list-style: none
    }

    img,
    svg,
    video,
    canvas,
    audio,
    iframe,
    embed,
    object {
        display: block
    }

    img,
    video {
        max-width: 100%;
        height: auto
    }

    button,
    input,
    select,
    optgroup,
    textarea {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    ::file-selector-button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    :where(select:is([multiple], [size])) optgroup {
        font-weight: bolder
    }

    :where(select:is([multiple], [size])) optgroup option {
        padding-inline-start: 20px
    }

    ::file-selector-button {
        margin-inline-end: 4px
    }

    ::placeholder {
        opacity: 1
    }

    @supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px) {
        ::placeholder {
            color: currentColor
        }

        @supports (color:color-mix(in lab, red, red)) {
            ::placeholder {
                color: color-mix(in oklab, currentcolor 50%, transparent)
            }
        }
    }

    textarea {
        resize: vertical
    }

    ::-webkit-search-decoration {
        -webkit-appearance: none
    }

    ::-webkit-date-and-time-value {
        min-height: 1lh;
        text-align: inherit
    }

    ::-webkit-datetime-edit {
        display: inline-flex
    }

    ::-webkit-datetime-edit-fields-wrapper {
        padding: 0
    }

    ::-webkit-datetime-edit {
        padding-block: 0
    }

    ::-webkit-datetime-edit-year-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-month-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-day-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-hour-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-minute-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-second-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-millisecond-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-meridiem-field {
        padding-block: 0
    }

    :-moz-ui-invalid {
        box-shadow: none
    }

    button,
    input:where([type=button], [type=reset], [type=submit]) {
        -webkit-appearance: button;
        -moz-appearance: button;
        appearance: button
    }

    ::file-selector-button {
        -webkit-appearance: button;
        -moz-appearance: button;
        appearance: button
    }

    ::-webkit-inner-spin-button {
        height: auto
    }

    ::-webkit-outer-spin-button {
        height: auto
    }

    [hidden]:where(:not([hidden=until-found])) {
        display: none !important
    }
}

@layer components;

@layer utilities {
    .invisible {
        visibility: hidden
    }

    .visible {
        visibility: visible
    }

    .absolute {
        position: absolute
    }

    .fixed {
        position: fixed
    }

    .relative {
        position: relative
    }

    .inset-0 {
        inset: calc(var(--spacing)*0)
    }

    .top-0 {
        top: calc(var(--spacing)*0)
    }

    .top-1\/2 {
        top: 50%
    }

    .right-6 {
        right: calc(var(--spacing)*6)
    }

    .bottom-6 {
        bottom: calc(var(--spacing)*6)
    }

    .left-1\/2 {
        left: 50%
    }

    .z-10 {
        z-index: 10
    }

    .z-20 {
        z-index: 20
    }

    .z-30 {
        z-index: 30
    }

    .z-50 {
        z-index: 50
    }

    .col-span-1 {
        grid-column: span 1/span 1
    }

    .container {
        width: 100%
    }

    @media (min-width:40rem) {
        .container {
            max-width: 40rem
        }
    }

    @media (min-width:48rem) {
        .container {
            max-width: 48rem
        }
    }

    @media (min-width:64rem) {
        .container {
            max-width: 64rem
        }
    }

    @media (min-width:80rem) {
        .container {
            max-width: 80rem
        }
    }

    @media (min-width:96rem) {
        .container {
            max-width: 96rem
        }
    }

    .m-auto {
        margin: auto
    }

    .mt-auto {
        margin-top: auto
    }

    .mx-auto {
        margin-inline: auto
    }

    .mt-1 {
        margin-top: calc(var(--spacing)*1)
    }

    .mt-2 {
        margin-top: calc(var(--spacing)*2)
    }

    .mt-4 {
        margin-top: calc(var(--spacing)*4)
    }

    .mt-\[80vh\] {
        margin-top: 80vh
    }

    .mr-2 {
        margin-right: calc(var(--spacing)*2)
    }

    .mb-0 {
        margin-bottom: calc(var(--spacing)*0)
    }

    .mb-2 {
        margin-bottom: calc(var(--spacing)*2)
    }

    .mb-3 {
        margin-bottom: calc(var(--spacing)*3)
    }

    .mb-4 {
        margin-bottom: calc(var(--spacing)*4)
    }

    .mb-8 {
        margin-bottom: calc(var(--spacing)*8)
    }

    .mb-12 {
        margin-bottom: calc(var(--spacing)*12)
    }

    .block {
        display: block
    }

    .flex {
        display: flex
    }

    .grid {
        display: grid
    }

    .hidden {
        display: none
    }

    .h-4 {
        height: calc(var(--spacing)*4)
    }

    .h-6 {
        height: calc(var(--spacing)*6)
    }

    .h-32 {
        height: calc(var(--spacing)*32)
    }

    .h-36 {
        height: calc(var(--spacing)*36)
    }

    .h-40 {
        height: calc(var(--spacing)*40)
    }

    .h-48 {
        height: calc(var(--spacing)*48)
    }

    .h-52 {
        height: calc(var(--spacing)*52)
    }

    .h-64 {
        height: calc(var(--spacing)*64)
    }

    .h-70 {
        height: calc(var(--spacing)*70)
    }

    .h-80 {
        height: calc(var(--spacing)*80)
    }

    .h-96 {
        height: calc(var(--spacing)*96)
    }

    .h-\[80\%\] {
        height: 80%
    }

    .h-auto {
        height: auto
    }

    .h-fit {
        height: fit-content
    }

    .h-full {
        height: 100%
    }

    .h-screen {
        height: 100vh
    }

    .w-4 {
        width: calc(var(--spacing)*4)
    }

    .w-6 {
        width: calc(var(--spacing)*6)
    }

    .w-7 {
        width: calc(var(--spacing)*7)
    }

    .w-8 {
        width: calc(var(--spacing)*8)
    }

    .w-\[90\%\] {
        width: 90%
    }

    .w-3\/4 {
        width: 75%
    }

    .w-fit {
        width: fit-content
    }

    .w-full {
        width: 100%
    }

    .w-screen {
        width: 100vw
    }

    .max-w-2xl {
        max-width: var(--container-2xl)
    }

    .max-w-6xl {
        max-width: var(--container-6xl)
    }

    .max-w-full {
        max-width: 100%
    }

    .flex-1 {
        flex: 1
    }

    .flex-grow {
        flex-grow: 1
    }

    .-translate-x-1\/2 {
        --tw-translate-x: -50%;
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

    .-translate-x-full {
        --tw-translate-x: -100%;
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

    .-translate-y-1\/2 {
        --tw-translate-y: -50%;
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

    .-translate-y-full {
        --tw-translate-y: -100%;
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

    .translate-y-0 {
        --tw-translate-y: calc(var(--spacing)*0);
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

    .transform {
        transform: var(--tw-rotate-x, )var(--tw-rotate-y, )var(--tw-rotate-z, )var(--tw-skew-x, )var(--tw-skew-y, )
    }

    .resize {
        resize: both
    }

    .resize-none {
        resize: none
    }

    .appearance-none {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none
    }

    .grid-cols-1 {
        grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
    }

    .grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .grid-rows-none {
        grid-template-rows: none
    }

    .flex-col {
        flex-direction: column
    }

    .flex-col-reverse {
        flex-direction: column-reverse
    }

    .flex-wrap {
        flex-wrap: wrap
    }

    .items-center {
        align-items: center
    }

    .items-start {
        align-items: flex-start
    }

    .justify-between {
        justify-content: space-between
    }

    .justify-center {
        justify-content: center
    }

    .justify-end {
        justify-content: flex-end
    }

    .gap-2 {
        gap: calc(var(--spacing)*2)
    }

    .gap-3 {
        gap: calc(var(--spacing)*3)
    }

    .gap-4 {
        gap: calc(var(--spacing)*4)
    }

    .gap-6 {
        gap: calc(var(--spacing)*6)
    }

    .gap-8 {
        gap: calc(var(--spacing)*8)
    }

    .gap-10 {
        gap: calc(var(--spacing)*10)
    }

    :where(.space-y-6>:not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));
        margin-block-end: calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))
    }

    :where(.space-x-3>:not(:last-child)) {
        --tw-space-x-reverse: 0;
        margin-inline-start: calc(calc(var(--spacing)*3)*var(--tw-space-x-reverse));
        margin-inline-end: calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-x-reverse)))
    }

    :where(.space-x-6>:not(:last-child)) {
        --tw-space-x-reverse: 0;
        margin-inline-start: calc(calc(var(--spacing)*6)*var(--tw-space-x-reverse));
        margin-inline-end: calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-x-reverse)))
    }

    .overflow-hidden {
        overflow: hidden
    }

    .rounded {
        border-radius: .25rem
    }

    .rounded-3xl {
        border-radius: var(--radius-3xl)
    }

    .rounded-full {
        border-radius: 3.40282e38px
    }

    .rounded-md {
        border-radius: var(--radius-md)
    }

    .rounded-t-3xl {
        border-top-left-radius: var(--radius-3xl);
        border-top-right-radius: var(--radius-3xl)
    }

    .border,
    .border-1 {
        border-style: var(--tw-border-style);
        border-width: 1px
    }

    .border-2 {
        border-style: var(--tw-border-style);
        border-width: 2px
    }

    .border-b {
        border-bottom-style: var(--tw-border-style);
        border-bottom-width: 1px
    }

    .border-dashed {
        --tw-border-style: dashed;
        border-style: dashed
    }

    .border-solid {
        --tw-border-style: solid;
        border-style: solid
    }

    .border-abey-300 {
        border-color: var(--color-abey-300)
    }

    .border-black {
        border-color: var(--color-black)
    }

    .border-red-500 {
        border-color: var(--color-red-500)
    }

    .border-twine-50 {
        border-color: var(--color-twine-50)
    }

    .border-twine-500 {
        border-color: var(--color-twine-500)
    }

    .bg-abey-400 {
        background-color: var(--color-abey-400)
    }

    .bg-abey-500 {
        background-color: var(--color-abey-500)
    }

    .bg-blue-600 {
        background-color: var(--color-blue-600)
    }

    .bg-twine-50 {
        background-color: var(--color-twine-50)
    }

    .bg-twine-300 {
        background-color: var(--color-twine-300)
    }

    .bg-twine-500 {
        background-color: var(--color-twine-500)
    }

    .bg-white {
        background-color: var(--color-white)
    }

    .bg-green-50 {
        background-color: rgb(240 253 244)
    }

    .bg-red-50 {
        background-color: rgb(254 242 242)
    }

    .border-green-200 {
        border-color: rgb(187 247 208)
    }

    .border-red-200 {
        border-color: rgb(254 202 202)
    }

    .text-green-800 {
        color: rgb(22 101 52)
    }

    .text-green-700 {
        color: rgb(21 128 61)
    }

    .text-green-400 {
        color: rgb(74 222 128)
    }

    .text-red-800 {
        color: rgb(153 27 27)
    }

    .text-red-700 {
        color: rgb(185 28 28)
    }

    .text-red-400 {
        color: rgb(248 113 113)
    }

    /* ===================================
       STYLES POUR LES PAGES LEGALES
       =================================== */

    .legal-content h1 {
        font-size: 1.875rem;
        line-height: 2.25rem;
        font-weight: 700;
        color: var(--color-abey-900);
        margin-top: 2rem;
        margin-bottom: 1rem;
        padding-bottom: 0.5rem;
        border-bottom: 2px solid var(--color-abey-200);
    }

    .legal-content h2 {
        font-size: 1.25rem;
        line-height: 1.75rem;
        font-weight: 600;
        color: var(--color-abey-900);
        margin-top: 2rem;
        margin-bottom: 1rem;
        padding-bottom: 0.5rem;
        border-bottom: 1px solid var(--color-abey-200);
    }

    .legal-content h3 {
        font-size: 1.125rem;
        line-height: 1.75rem;
        font-weight: 500;
        color: var(--color-abey-900);
        margin-top: 1.5rem;
        margin-bottom: 0.75rem;
    }

    .legal-content h4 {
        font-size: 1rem;
        line-height: 1.5rem;
        font-weight: 500;
        color: var(--color-abey-900);
        margin-top: 1rem;
        margin-bottom: 0.5rem;
    }

    .legal-content p {
        margin-bottom: 1rem;
        color: var(--color-abey-800);
        line-height: 1.625;
    }

    .legal-content ul,
    .legal-content ol {
        margin-bottom: 1rem;
        margin-left: 1.5rem;
        color: var(--color-abey-800);
    }

    .legal-content ul {
        list-style-type: disc;
    }

    .legal-content ol {
        list-style-type: decimal;
    }

    .legal-content li {
        margin-bottom: 0.5rem;
    }

    .legal-content strong {
        font-weight: 600;
        color: var(--color-abey-900);
    }

    .legal-content a {
        color: var(--color-twine-600);
        text-decoration: underline;
        transition: color 0.2s ease-in-out;
    }

    .legal-content a:hover {
        color: var(--color-twine-700);
    }

    .legal-content blockquote {
        border-left: 4px solid var(--color-twine-500);
        padding-left: 1rem;
        font-style: italic;
        color: var(--color-abey-700);
        margin: 1rem 0;
    }

    .legal-content table {
        width: 100%;
        border-collapse: collapse;
        border: 1px solid var(--color-abey-200);
        margin: 1.5rem 0;
    }

    .legal-content th,
    .legal-content td {
        border: 1px solid var(--color-abey-200);
        padding: 0.75rem 1rem;
        text-align: left;
    }

    .legal-content th {
        background-color: var(--color-abey-50);
        font-weight: 600;
        color: var(--color-abey-900);
    }

    .legal-content .wp-block-separator {
        border-top: 1px solid var(--color-abey-200);
        margin: 2rem 0;
    }

    /* ===================================
       STYLES POUR LE CONTENU PRINCIPAL
       =================================== */

    main ul:not(.pagination ul),
    main ol:not(.pagination ol) {
        margin-left: 1.5rem;
        color: var(--color-abey-800);
    }

    main ul:not(.pagination ul) {
        list-style-type: disc;
    }

    main ol:not(.pagination ol) {
        list-style-type: decimal;
    }

    main li:not(.pagination li) {
        line-height: 1.6;
    }

    .object-cover {
        object-fit: cover
    }

    .object-\[75\%\] {
        object-position: 75%
    }

    .p-3 {
        padding: calc(var(--spacing)*3)
    }

    .p-4 {
        padding: calc(var(--spacing)*4)
    }

    .p-6 {
        padding: calc(var(--spacing)*6)
    }

    .p-8 {
        padding: calc(var(--spacing)*8)
    }

    .px-3 {
        padding-inline: calc(var(--spacing)*3)
    }

    .px-4 {
        padding-inline: calc(var(--spacing)*4)
    }

    .px-6 {
        padding-inline: calc(var(--spacing)*6)
    }

    .px-16 {
        padding-inline: calc(var(--spacing)*16)
    }

    .py-2 {
        padding-block: calc(var(--spacing)*2)
    }

    .py-3 {
        padding-block: calc(var(--spacing)*3)
    }

    .py-4 {
        padding-block: calc(var(--spacing)*4)
    }

    .py-6 {
        padding-block: calc(var(--spacing)*6)
    }

    .py-8 {
        padding-block: calc(var(--spacing)*8)
    }

    .py-24 {
        padding-block: calc(var(--spacing)*24)
    }

    .pt-4 {
        padding-top: calc(var(--spacing)*4)
    }

    .pt-8 {
        padding-top: calc(var(--spacing)*8)
    }

    .pt-16 {
        padding-top: calc(var(--spacing)*16)
    }

    .pt-52 {
        padding-top: calc(var(--spacing)*52)
    }

    .pb-4 {
        padding-bottom: calc(var(--spacing)*4)
    }

    .pb-16 {
        padding-bottom: calc(var(--spacing)*16)
    }

    .pb-32 {
        padding-bottom: calc(var(--spacing)*32)
    }

    .text-center {
        text-align: center
    }

    .font-asap {
        font-family: var(--font-asap)
    }

    .font-nunito {
        font-family: var(--font-nunito)
    }

    .text-2xl {
        font-size: var(--text-2xl);
        line-height: var(--tw-leading, var(--text-2xl--line-height))
    }

    .text-3xl {
        font-size: var(--text-3xl);
        line-height: var(--tw-leading, var(--text-3xl--line-height))
    }

    .text-lg {
        font-size: var(--text-lg);
        line-height: var(--tw-leading, var(--text-lg--line-height))
    }

    .text-sm {
        font-size: var(--text-sm);
        line-height: var(--tw-leading, var(--text-sm--line-height))
    }

    .text-xl {
        font-size: var(--text-xl);
        line-height: var(--tw-leading, var(--text-xl--line-height))
    }

    .text-xs {
        font-size: var(--text-xs);
        line-height: var(--tw-leading, var(--text-xs--line-height))
    }

    .font-bold {
        --tw-font-weight: var(--font-weight-bold);
        font-weight: var(--font-weight-bold)
    }

    .font-extrabold {
        --tw-font-weight: var(--font-weight-extrabold);
        font-weight: var(--font-weight-extrabold)
    }

    .font-medium {
        --tw-font-weight: var(--font-weight-medium);
        font-weight: var(--font-weight-medium)
    }

    .font-normal {
        --tw-font-weight: var(--font-weight-normal);
        font-weight: var(--font-weight-normal)
    }

    .text-balance {
        text-wrap: balance
    }

    .text-abey-500 {
        color: var(--color-abey-500)
    }

    .text-abey-600 {
        color: var(--color-abey-600)
    }

    .text-abey-900 {
        color: var(--color-abey-900)
    }

    .text-blue-600 {
        color: var(--color-blue-600)
    }

    .text-gray-500 {
        color: var(--color-gray-500)
    }

    .text-twine-50 {
        color: var(--color-twine-50)
    }

    .text-white {
        color: var(--color-white)
    }

    .italic {
        font-style: italic
    }

    .opacity-0 {
        opacity: 0
    }

    .opacity-80 {
        opacity: .8
    }

    .opacity-95 {
        opacity: .95
    }

    .opacity-100 {
        opacity: 1
    }

    .shadow-lg {
        --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .shadow-sm {
        --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .transition-colors {
        transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration))
    }

    /* Classes ajoutées pour archive-realisations.php */

    .aspect-square {
        aspect-ratio: 1 / 1
    }

    .object-\\[75\\%\\] {
        object-position: 75%
    }

    .object-center {
        object-position: center
    }

    .bg-abey-200 {
        background-color: var(--color-abey-200)
    }

    .bg-abey-400 {
        background-color: var(--color-abey-400)
    }

    .bg-abey-900 {
        background-color: var(--color-abey-900)
    }

    .bg-gray-100 {
        background-color: var(--color-gray-100)
    }

    .bg-twine-400 {
        background-color: var(--color-twine-400)
    }

    .border-abey-300 {
        border-color: var(--color-abey-300)
    }


    .duration-500 {
        transition-duration: 500ms
    }

    .flex-wrap {
        flex-wrap: wrap
    }

    .font-semibold {
        --tw-font-weight: var(--font-weight-semibold);
        font-weight: var(--font-weight-semibold)
    }

    .gap-1 {
        gap: calc(var(--spacing)*1)
    }

    .gap-2 {
        gap: calc(var(--spacing)*2)
    }

    .gap-4 {
        gap: calc(var(--spacing)*4)
    }

    .gap-6 {
        gap: calc(var(--spacing)*6)
    }

    .grid-cols-1 {
        grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
    }

    .realisation-card.group:hover .group-hover\:scale-105,
    .portfolio .group:hover .group-hover\:scale-105 {
        transform: scale(1.05)
    }

    .group:hover .group-hover\:text-twine-600 {
        color: var(--color-twine-600)
    }

    .h-2 {
        height: calc(var(--spacing)*2)
    }

    .h-12 {
        height: calc(var(--spacing)*12)
    }

    .h-24 {
        height: calc(var(--spacing)*24)
    }

    .hover\:bg-abey-300:hover {
        background-color: var(--color-abey-300)
    }

    .hover\:bg-twine-600:hover {
        background-color: var(--color-twine-600)
    }

    .hover\:border-twine-500:hover {
        border-color: var(--color-twine-500)
    }

    .hover\:shadow-lg:hover {
        --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .hover\:text-white:hover {
        color: var(--color-white)
    }

    .hover\:bg-twine-500:hover {
        background-color: var(--color-twine-500);
    }

    .hover\:border-twine-500:hover {
        border-color: var(--color-twine-500);
    }

    .items-end {
        align-items: flex-end
    }


    .max-w-md {
        max-width: 28rem
    }

    .max-w-2xl {
        max-width: 42rem
    }

    .max-w-4xl {
        max-width: 56rem
    }

    .max-w-6xl {
        max-width: 72rem
    }

    .mb-6 {
        margin-bottom: calc(var(--spacing)*6)
    }

    .mt-12 {
        margin-top: calc(var(--spacing)*12)
    }

    .object-cover {
        object-fit: cover
    }

    .overflow-hidden {
        overflow: hidden
    }

    .p-4 {
        padding: calc(var(--spacing)*4)
    }

    .px-2 {
        padding-left: calc(var(--spacing)*2);
        padding-right: calc(var(--spacing)*2)
    }

    .px-6 {
        padding-left: calc(var(--spacing)*6);
        padding-right: calc(var(--spacing)*6)
    }

    .px-8 {
        padding-left: calc(var(--spacing)*8);
        padding-right: calc(var(--spacing)*8)
    }

    .py-1 {
        padding-top: calc(var(--spacing)*1);
        padding-bottom: calc(var(--spacing)*1)
    }

    .py-8 {
        padding-top: calc(var(--spacing)*8);
        padding-bottom: calc(var(--spacing)*8)
    }

    .py-12 {
        padding-top: calc(var(--spacing)*12);
        padding-bottom: calc(var(--spacing)*12)
    }

    .py-16 {
        padding-top: calc(var(--spacing)*16);
        padding-bottom: calc(var(--spacing)*16)
    }

    .pt-32 {
        padding-top: calc(var(--spacing)*32);
    }

    .pb-24 {
        padding-bottom: calc(var(--spacing)*24);
    }

    .rounded {
        border-radius: calc(var(--radius)*1)
    }

    .rounded-full {
        border-radius: 9999px
    }

    .rounded-lg {
        border-radius: calc(var(--radius)*2)
    }

    .rounded-xl {
        border-radius: calc(var(--radius)*3)
    }


    .space-x-2 > :not([hidden]) ~ :not([hidden]) {
        margin-left: calc(var(--spacing)*2)
    }

    .space-y-1 > :not([hidden]) ~ :not([hidden]) {
        margin-top: calc(var(--spacing)*1)
    }

    .sticky {
        position: sticky
    }


    .text-2xl {
        font-size: var(--text-2xl);
        line-height: var(--tw-leading, var(--text-2xl--line-height))
    }

    .text-4xl {
        font-size: var(--text-4xl);
        line-height: var(--tw-leading, var(--text-4xl--line-height))
    }

    .text-abey-400 {
        color: var(--color-abey-400)
    }

    .text-abey-700 {
        color: var(--color-abey-700)
    }

    .text-abey-800 {
        color: var(--color-abey-800)
    }

    .text-center {
        text-align: center
    }

    .text-twine-100 {
        color: var(--color-twine-100)
    }

    .top-0 {
        top: 0
    }

    .transition-all {
        transition-property: all;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration))
    }


    .w-2 {
        width: calc(var(--spacing)*2)
    }

    .w-12 {
        width: calc(var(--spacing)*12)
    }

    .w-24 {
        width: calc(var(--spacing)*24)
    }


    .z-40 {
        z-index: 40
    }

    /* Media queries pour les classes responsive - Version forcée */
    @media (min-width: 640px) {
        .sm\:grid-cols-2 {
            grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        }

        .sm\:flex-row {
            flex-direction: row;
        }

        .sm\:flex-wrap {
            flex-wrap: wrap;
        }

        .sm\:gap-6 {
            gap: calc(var(--spacing)*6);
        }

        .sm\:h-full {
            height: 100%;
        }

        .sm\:h-screen {
            height: 100vh;
        }

        .sm\:px-6 {
            padding-left: calc(var(--spacing)*6);
            padding-right: calc(var(--spacing)*6);
        }

        .sm\:py-2 {
            padding-top: calc(var(--spacing)*2);
            padding-bottom: calc(var(--spacing)*2);
        }

        .sm\:text-2xl {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }

        .sm\:text-5xl {
            font-size: var(--text-5xl);
            line-height: var(--tw-leading, var(--text-5xl--line-height));
        }

        .sm\:text-base {
            font-size: var(--text-base);
            line-height: var(--text-base--line-height);
        }

        .sm\:w-auto {
            width: auto;
        }
    }

    @media (min-width: 768px) {
        .md\:grid-cols-4 {
            grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        }

        .md\:py-20 {
            padding-top: 5rem;
            padding-bottom: 5rem;
        }

        .md\:text-3xl {
            font-size: 1.875rem;
            line-height: 2.25rem;
        }

        .md\:text-5xl {
            font-size: 3rem;
            line-height: 1;
        }

        .md\:flex {
            display: flex;
        }

        .md\:flex-nowrap {
            flex-wrap: nowrap;
        }

        .md\:flex-row {
            flex-direction: row;
        }

        .md\:gap-6 {
            gap: calc(var(--spacing)*6);
        }

        .md\:gap-8 {
            gap: calc(var(--spacing)*8);
        }

        .md\:hidden {
            display: none;
        }

        .md\:mb-12 {
            margin-bottom: calc(var(--spacing)*12);
        }

        .md\:mb-6 {
            margin-bottom: calc(var(--spacing)*6);
        }

        .md\:pt-32 {
            padding-top: calc(var(--spacing)*32);
        }

        .md\:px-0 {
            padding-left: 0;
            padding-right: 0;
        }

        .md\:text-base {
            font-size: var(--text-base);
            line-height: var(--text-base--line-height);
        }

        .md\:w-auto {
            width: auto;
        }

        .md\:pt-40 {
            padding-top: calc(var(--spacing)*40);
        }
    }

    @media (min-width: 1024px) {
        .lg\:grid-cols-3 {
            grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        }

        .lg\:gap-16 {
            gap: calc(var(--spacing)*16);
        }

        .lg\:grid-cols-4 {
            grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .lg\:w-auto {
            width: auto;
        }
    }

    @media (min-width: 1280px) {
        .xl\:grid-cols-4 {
            grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        }
    }

    /* Classes utilitaires pour focus */
    .focus\:outline-none:focus {
        outline: 2px solid transparent;
        outline-offset: 2px
    }

    .focus\:ring-2:focus {
        --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .focus\:ring-twine-500:focus {
        --tw-ring-color: var(--color-twine-500)
    }

    /* Classes supplémentaires pour l'effet hover archive-realisations */
    .absolute {
        position: absolute;
    }

    .inset-0 {
        inset: 0;
    }

    .relative {
        position: relative;
    }

    .bg-opacity-0 {
        background-color: rgb(0 0 0 / 0);
    }

    .bg-opacity-20 {
        background-color: rgb(255 255 255 / 0.2);
    }

    .realisation-card.group:hover .group-hover\:bg-opacity-60 {
        background-color: rgb(0 0 0 / 0.6);
    }

    .realisation-card.group:hover .group-hover\:opacity-100 {
        opacity: 1;
    }


    .justify-end {
        justify-content: flex-end;
    }

    .backdrop-blur-sm {
        backdrop-filter: blur(4px);
    }

    .inline-block {
        display: inline-block;
    }

    .text-lg {
        font-size: 1.125rem;
        line-height: 1.75rem;
    }

    .opacity-90 {
        opacity: 0.9;
    }

    .mb-1 {
        margin-bottom: 0.25rem;
    }

    .rounded-3xl {
        border-radius: 1.5rem;
    }

    /* Fix pour hero-header - pas de comportement de lien */
    .hero-header img {
        cursor: default;
        pointer-events: auto;
    }

    .hero-header {
        cursor: default;
    }


    /* Classes de grille manquantes pour la homepage */
    .grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .grid-rows-none {
        grid-template-rows: none;
    }

    .grid-rows-3 {
        grid-template-rows: repeat(3, minmax(0, 1fr));
    }

    .col-span-1 {
        grid-column: span 1 / span 1;
    }

    .col-span-2 {
        grid-column: span 2 / span 2;
    }

    .row-span-1 {
        grid-row: span 1 / span 1;
    }

    .row-span-2 {
        grid-row: span 2 / span 2;
    }

    .row-span-auto {
        grid-row: auto;
    }

    .col-start-4 {
        grid-column-start: 4;
    }

    .row-start-2 {
        grid-row-start: 2;
    }

    .h-auto {
        height: auto;
    }

    .h-\[800px\] {
        height: 800px;
    }

    /* Ajout des media queries responsive manquantes */
    @media (min-width: 640px) {
        .sm\:grid-rows-3 {
            grid-template-rows: repeat(3, minmax(0, 1fr));
        }

        .sm\:row-span-1 {
            grid-row: span 1 / span 1;
        }

        .sm\:row-span-2 {
            grid-row: span 2 / span 2;
        }

        .sm\:col-span-2 {
            grid-column: span 2 / span 2;
        }

        .sm\:row-start-2 {
            grid-row-start: 2;
        }

        .sm\:col-start-4 {
            grid-column-start: 4;
        }
    }

    @media (min-width: 768px) {
        .md\:h-\[800px\] {
            height: 800px;
        }
    }

    .transition-opacity {
        transition-property: opacity;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration))
    }

    .transition-transform {
        transition-property: transform, translate, scale, rotate;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration))
    }

    .duration-200 {
        --tw-duration: .2s;
        transition-duration: .2s
    }

    .duration-300 {
        --tw-duration: .3s;
        transition-duration: .3s
    }

    .ease-in-out {
        --tw-ease: var(--ease-in-out);
        transition-timing-function: var(--ease-in-out)
    }

    @media (hover:hover) {
        .group-hover\:scale-110:is(:where(.group):hover *) {
            --tw-scale-x: 110%;
            --tw-scale-y: 110%;
            --tw-scale-z: 110%;
            scale: var(--tw-scale-x)var(--tw-scale-y)
        }

        .hover\:border-1:hover {
            border-style: var(--tw-border-style);
            border-width: 1px
        }

        .hover\:border-solid:hover {
            --tw-border-style: solid;
            border-style: solid
        }

        .hover\:border-abey-900:hover {
            border-color: var(--color-abey-900)
        }

        .hover\:bg-abey-600:hover {
            background-color: var(--color-abey-600)
        }

        .hover\:bg-blue-700:hover {
            background-color: var(--color-blue-700)
        }

        .hover\:bg-transparent:hover {
            background-color: #0000
        }

        .hover\:bg-twine-50:hover {
            background-color: var(--color-twine-50)
        }

        .hover\:bg-twine-100:hover {
            background-color: var(--color-twine-100)
        }

        .hover\:bg-twine-700:hover {
            background-color: var(--color-twine-700)
        }

        .hover\:text-abey-900:hover {
            color: var(--color-abey-900)
        }
    }

    .focus\:border-blue-500:focus {
        border-color: var(--color-blue-500)
    }

    .focus\:ring-2:focus {
        --tw-ring-shadow: var(--tw-ring-inset, )0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color, currentcolor);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .focus\:ring-blue-500:focus {
        --tw-ring-color: var(--color-blue-500)
    }

    .focus\:outline-none:focus {
        --tw-outline-style: none;
        outline-style: none
    }

    @media (min-width:40rem) {
        .sm\:col-span-2 {
            grid-column: span 2/span 2
        }

        .sm\:col-start-4 {
            grid-column-start: 4
        }

        .sm\:row-span-1 {
            grid-row: span 1/span 1
        }

        .sm\:row-span-2 {
            grid-row: span 2/span 2
        }

        .sm\:row-start-2 {
            grid-row-start: 2
        }

        .sm\:mt-\[100vh\] {
            margin-top: 100vh
        }

        .sm\:block {
            display: block
        }

        .sm\:h-full {
            height: 100%
        }

        .sm\:h-screen {
            height: 100vh
        }

        .sm\:w-8 {
            width: calc(var(--spacing)*8)
        }

        .sm\:w-\[60\%\] {
            width: 60%
        }

        .sm\:w-\[calc\(50\%-0\.75rem\)\] {
            width: calc(50% - .75rem)
        }

        .sm\:grid-rows-3 {
            grid-template-rows: repeat(3, minmax(0, 1fr))
        }

        .sm\:flex-row {
            flex-direction: row
        }

        .sm\:flex-wrap {
            flex-wrap: wrap
        }

        .sm\:gap-4 {
            gap: calc(var(--spacing)*4)
        }

        .sm\:gap-6 {
            gap: calc(var(--spacing)*6)
        }

        .sm\:px-6 {
            padding-inline: calc(var(--spacing)*6)
        }

        .sm\:py-2 {
            padding-block: calc(var(--spacing)*2)
        }

        .sm\:text-2xl {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height))
        }

        .sm\:text-5xl {
            font-size: var(--text-5xl);
            line-height: var(--tw-leading, var(--text-5xl--line-height))
        }

        .sm\:text-base {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height))
        }
    }

    @media (min-width:48rem) {
        .md\:mb-6 {
            margin-bottom: calc(var(--spacing)*6)
        }

        .md\:mb-12 {
            margin-bottom: calc(var(--spacing)*12)
        }

        .md\:flex {
            display: flex
        }

        .md\:hidden {
            display: none
        }

        .md\:h-\[800px\] {
            height: 800px
        }

        .md\:w-1\/2 {
            width: 50%
        }

        .md\:w-auto {
            width: auto
        }

        .md\:max-w-1\/2 {
            max-width: 50%
        }

        .md\:flex-row {
            flex-direction: row
        }

        .md\:flex-nowrap {
            flex-wrap: nowrap
        }

        .md\:gap-6 {
            gap: calc(var(--spacing)*6)
        }

        .md\:gap-8 {
            gap: calc(var(--spacing)*8)
        }

        .md\:px-0 {
            padding-inline: calc(var(--spacing)*0)
        }

        .md\:py-16 {
            padding-block: calc(var(--spacing)*16)
        }

        .md\:pt-16 {
            padding-top: calc(var(--spacing)*16)
        }

        .md\:pt-32 {
            padding-top: calc(var(--spacing)*32)
        }

        .md\:pb-8 {
            padding-bottom: calc(var(--spacing)*8)
        }

        .md\:text-4xl {
            font-size: var(--text-4xl);
            line-height: var(--tw-leading, var(--text-4xl--line-height))
        }

        .md\:text-base {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height))
        }

        .md\:text-sm {
            font-size: var(--text-sm);
            line-height: var(--tw-leading, var(--text-sm--line-height))
        }

        .md\:sticky {
            position: sticky
        }

        .md\:top-0 {
            top: 0
        }
    }

    @media (min-width:64rem) {
        .lg\:w-auto {
            width: auto
        }

        .lg\:h-full {
            height: 100%
        }

        .lg\:h-64 {
            height: calc(var(--spacing)*64)
        }

        .lg\:min-h-\[400px\] {
            min-height: 400px
        }

        .lg\:grid-cols-2 {
            grid-template-columns: repeat(2, minmax(0, 1fr))
        }

        .lg\:grid-cols-4 {
            grid-template-columns: repeat(4, minmax(0, 1fr))
        }

        .lg\:flex-col {
            flex-direction: column
        }

        .lg\:flex-row {
            flex-direction: row
        }

        .lg\:items-start {
            align-items: flex-start
        }

        .lg\:gap-3 {
            gap: calc(var(--spacing)*3)
        }

        .lg\:gap-16 {
            gap: calc(var(--spacing)*16)
        }
    }
}

* {
    transition: all .3s ease-in-out
}

::selection {
    background-color: var(--color-twine-400);
    color: #fff
}

a:not([class*=bg]):hover {
    color: var(--color-twine-500);
    text-decoration: underline
}

@property --tw-translate-x {
    syntax: "*";
    inherits: false;
    initial-value: 0
}

@property --tw-translate-y {
    syntax: "*";
    inherits: false;
    initial-value: 0
}

@property --tw-translate-z {
    syntax: "*";
    inherits: false;
    initial-value: 0
}

@property --tw-rotate-x {
    syntax: "*";
    inherits: false
}

@property --tw-rotate-y {
    syntax: "*";
    inherits: false
}

@property --tw-rotate-z {
    syntax: "*";
    inherits: false
}

@property --tw-skew-x {
    syntax: "*";
    inherits: false
}

@property --tw-skew-y {
    syntax: "*";
    inherits: false
}

@property --tw-space-y-reverse {
    syntax: "*";
    inherits: false;
    initial-value: 0
}

@property --tw-space-x-reverse {
    syntax: "*";
    inherits: false;
    initial-value: 0
}

@property --tw-border-style {
    syntax: "*";
    inherits: false;
    initial-value: solid
}

@property --tw-font-weight {
    syntax: "*";
    inherits: false
}

@property --tw-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-shadow-color {
    syntax: "*";
    inherits: false
}

@property --tw-shadow-alpha {
    syntax: "<percentage>";
    inherits: false;
    initial-value: 100%
}

@property --tw-inset-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-inset-shadow-color {
    syntax: "*";
    inherits: false
}

@property --tw-inset-shadow-alpha {
    syntax: "<percentage>";
    inherits: false;
    initial-value: 100%
}

@property --tw-ring-color {
    syntax: "*";
    inherits: false
}

@property --tw-ring-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-inset-ring-color {
    syntax: "*";
    inherits: false
}

@property --tw-inset-ring-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-ring-inset {
    syntax: "*";
    inherits: false
}

@property --tw-ring-offset-width {
    syntax: "<length>";
    inherits: false;
    initial-value: 0
}

@property --tw-ring-offset-color {
    syntax: "*";
    inherits: false;
    initial-value: #fff
}

@property --tw-ring-offset-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-duration {
    syntax: "*";
    inherits: false
}

@property --tw-ease {
    syntax: "*";
    inherits: false
}

@property --tw-scale-x {
    syntax: "*";
    inherits: false;
    initial-value: 1
}

@property --tw-scale-y {
    syntax: "*";
    inherits: false;
    initial-value: 1
}

@property --tw-scale-z {
    syntax: "*";
    inherits: false;
    initial-value: 1
}

/* Classes Tailwind manquantes pour le hero */
.grayscale {
    filter: grayscale(100%);
}

.bg-opacity-30 {
    background-color: rgb(0 0 0 / 0.3);
}

.rotate-180 {
    --tw-rotate-z: 180deg;
    transform: rotate(var(--tw-rotate-z));
}

/* Missing Tailwind classes for FAQ component */
.space-y-4 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(calc(var(--spacing)*4) * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(calc(var(--spacing)*4) * var(--tw-space-y-reverse));
}

.rounded-lg {
    border-radius: 0.5rem;
}

.border-gray-200 {
    border-color: rgb(229 231 235);
}

.text-gray-900 {
    color: rgb(17 24 39);
}

.text-gray-700 {
    color: rgb(55 65 81);
}

.hover\:bg-gray-50:hover {
    background-color: rgb(249 250 251);
}

.cursor-pointer {
    cursor: pointer;
}

.list-none {
    list-style-type: none;
}

.w-5 {
    width: calc(var(--spacing)*5);
}

.h-5 {
    height: calc(var(--spacing)*5);
}

.ml-4 {
    margin-left: calc(var(--spacing)*4);
}

.pt-0 {
    padding-top: calc(var(--spacing)*0);
}

.group-open\:rotate-180:is(:where(.group):is([open], [data-state="open"]) *) {
    --tw-rotate-z: 180deg;
    transform: rotate(var(--tw-rotate-z));
}

/* ===================================
   CLASSES MANQUANTES POUR ARTIST SPOTLIGHT
   =================================== */

/* Layout classes */
.max-w-7xl {
    max-width: 80rem;
}

.py-20 {
    padding-top: calc(var(--spacing)*20);
    padding-bottom: calc(var(--spacing)*20);
}

.py-28 {
    padding-top: calc(var(--spacing)*28);
    padding-bottom: calc(var(--spacing)*28);
}

/* XL Grid classes */
.xl\:col-span-1 {
    grid-column: span 1 / span 1;
}

.xl\:col-span-2 {
    grid-column: span 2 / span 2;
}

.xl\:col-span-3 {
    grid-column: span 3 / span 3;
}

.xl\:order-1 {
    order: 1;
}

.xl\:order-2 {
    order: 2;
}

@media (min-width: 1280px) {
    .xl\:col-span-1 {
        grid-column: span 1 / span 1;
    }

    .xl\:col-span-2 {
        grid-column: span 2 / span 2;
    }

    .xl\:col-span-3 {
        grid-column: span 3 / span 3;
    }

    .xl\:order-1 {
        order: 1;
    }

    .xl\:order-2 {
        order: 2;
    }
}

/* Effects and visual classes */
.blur-xl {
    filter: blur(24px);
}

.opacity-30 {
    opacity: 0.3;
}

.opacity-50 {
    opacity: 0.5;
}

.group-hover\:opacity-50:is(:where(.group):hover *) {
    opacity: 0.5;
}

/* Typography classes */
.text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
}

.text-6xl {
    font-size: 3.75rem;
    line-height: 1;
}

.font-black {
    font-weight: 900;
}

.leading-tight {
    line-height: 1.25;
}

.tracking-wider {
    letter-spacing: 0.05em;
}

.uppercase {
    text-transform: uppercase;
}

/* Modern background and border classes */
.bg-white\/10 {
    background-color: rgb(255 255 255 / 0.1);
}

.border-white\/20 {
    border-color: rgb(255 255 255 / 0.2);
}

.ring-4 {
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

.ring-white\/20 {
    --tw-ring-color: rgb(255 255 255 / 0.2);
}

.rounded-2xl {
    border-radius: 1rem;
}

.shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

/* Text color variants */
.text-white\/80 {
    color: rgb(255 255 255 / 0.8);
}

.text-white\/90 {
    color: rgb(255 255 255 / 0.9);
}

/* Gradient text classes */
.bg-gradient-to-r {
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.from-white {
    --tw-gradient-from: #fff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-twine-200 {
    --tw-gradient-to: rgb(234 220 208 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #eadcd0 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-white {
    --tw-gradient-to: #fff var(--tw-gradient-to-position);
}

.bg-clip-text {
    background-clip: text;
    -webkit-background-clip: text;
}

.text-transparent {
    color: transparent;
}

/* Enhanced hover effects */
.hover\:shadow-2xl:hover {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

.hover\:-translate-y-1:hover {
    --tw-translate-y: -0.25rem;
    translate: var(--tw-translate-x) var(--tw-translate-y);
}

.group-hover\:scale-110:is(:where(.group):hover *) {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    scale: var(--tw-scale-x) var(--tw-scale-y);
}

/* Missing gradient backgrounds for buttons */
.from-pink-500 {
    --tw-gradient-from: #ec4899 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(236 72 153 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-purple-600 {
    --tw-gradient-to: #9333ea var(--tw-gradient-to-position);
}

.from-pink-600 {
    --tw-gradient-from: #db2777 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(219 39 119 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-purple-700 {
    --tw-gradient-to: #7c3aed var(--tw-gradient-to-position);
}

.hover\:from-pink-600:hover {
    --tw-gradient-from: #db2777 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(219 39 119 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:to-purple-700:hover {
    --tw-gradient-to: #7c3aed var(--tw-gradient-to-position);
}

/* Dark gradient background for section */
.bg-gradient-to-br {
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.from-abey-900 {
    --tw-gradient-from: var(--color-abey-900) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(49 50 52 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-abey-800 {
    --tw-gradient-to: rgb(78 79 83 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #4e4f53 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-twine-900 {
    --tw-gradient-to: #5d4527 var(--tw-gradient-to-position);
}

/* Twine and Abey color variants for gradients */
.from-twine-400 {
    --tw-gradient-from: var(--color-twine-400) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(196 149 95 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-twine-500 {
    --tw-gradient-to: var(--color-twine-500) var(--tw-gradient-to-position);
}

.to-abey-600 {
    --tw-gradient-to: var(--color-abey-600) var(--tw-gradient-to-position);
}

/* Additional missing colors */
.bg-twine-300 {
    background-color: var(--color-twine-300);
}

.bg-abey-300 {
    background-color: var(--color-abey-300);
}

/* Transition duration classes */
.duration-300 {
    --tw-duration: 0.3s;
    transition-duration: 0.3s;
}

.duration-500 {
    --tw-duration: 0.5s;
    transition-duration: 0.5s;
}

/* Missing responsive text sizes */
@media (min-width: 1024px) {
    .lg\:text-6xl {
        font-size: 3.75rem;
        line-height: 1;
    }
}

/* Classes supplémentaires pour le nouveau design artiste */
.shadow-3xl {
    --tw-shadow: 0 35px 60px -12px rgba(0, 0, 0, 0.25);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

.hover\:shadow-3xl:hover {
    --tw-shadow: 0 35px 60px -12px rgba(0, 0, 0, 0.25);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

.hover\:-translate-y-2:hover {
    --tw-translate-y: -0.5rem;
    translate: var(--tw-translate-x) var(--tw-translate-y);
}

.bg-gray-100 {
    background-color: #f3f4f6;
}

.bg-gray-200 {
    background-color: #e5e7eb;
}

.border-gray-200 {
    border-color: #e5e7eb;
}

.text-gray-600 {
    color: #4b5563;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.w-12 {
    width: 3rem;
}

.h-12 {
    height: 3rem;
}

.w-6 {
    width: 1.5rem;
}

.h-6 {
    height: 1.5rem;
}

.bg-abey-100 {
    background-color: #d1d2d4;
}

.text-abey-700 {
    color: #606266;
}

.text-abey-800 {
    color: #4a4d52;
}

.border-twine-200 {
    border-color: var(--color-twine-200);
}

@media (min-width: 1024px) {
    .lg\:flex-shrink-0 {
        flex-shrink: 0;
    }

    .lg\:w-80 {
        width: 20rem;
    }

    .lg\:h-96 {
        height: 24rem;
    }

    .lg\:flex-row {
        flex-direction: row;
    }

    .lg\:justify-between {
        justify-content: space-between;
    }

    .lg\:items-start {
        align-items: flex-start;
    }

    .lg\:text-3xl {
        font-size: 1.875rem;
        line-height: 2.25rem;
    }

    .lg\:p-8 {
        padding: 2rem;
    }

    .lg\:w-1\/2 {
        width: 50%;
    }
}

/* Classes additionnelles */
.h-full {
    height: 100%;
}

.min-h-96 {
    min-height: 24rem;
}

.lg\:h-full {
    height: 100%;
}

@media (min-width: 1024px) {
    .lg\:h-full {
        height: 100%;
    }

    .lg\:w-1\/2 {
        width: 50%;
    }
}