@layer theme {
    :root {
        --color-neutral-50: oklch(0.985 0 0);
        --color-neutral-100: oklch(0.97 0 0);
        --color-neutral-200: oklch(0.922 0 0);
        --color-neutral-300: oklch(0.87 0 0);
        --color-neutral-400: oklch(0.708 0 0);
        --color-neutral-500: oklch(0.556 0 0);
        --color-neutral-600: oklch(0.439 0 0);
        --color-neutral-700: oklch(0.371 0 0);
        --color-neutral-800: oklch(0.269 0 0);
        --color-neutral-900: oklch(0.205 0 0);
        --color-neutral-950: oklch(0.145 0 0);
        --color-brand-orange: #d19718;
        --color-brand-blue: #3e00ff;
        --color-brand-lightblue: #6cd8df;
        --color-brand-green: #6cf400;
        --color-brand-50: #f7ff22;
        --color-error-text: #B3423D;
        --color-error-bg: #401a18;
        --color-black: #000;
        --color-white: #fff;
        --spacing:0.25rem;
        --radius-3xl: 1.5rem;
        --text-xs: 0.75rem;
        --text-sm: 0.875rem;
        --text-base: 1rem;
        --text-base--line-height: calc(1.5 / 1);
        --text-lg: 1.125rem;
        --text-lg--line-height: calc(1.75 / 1.125);
        --text-xl: 1.25rem;
        --text-2xl: 1.5rem;
        --text-3xl: 1.875rem;
        


        --font-title: "fashion-fetish", "sans-serif";
        --font-body: "just-sans", "sans-serif";
        --font-weight-thin: 100;
        --font-weight-light: 300;
        --font-weight-normal: 400;
        --font-weight-medium: 500;
        --font-weight-extrabold: 800;

        --tracking-tighter: -0.05em;
        --tracking-tight: -0.025em;
        --tracking-normal: 0em;
        --tracking-wide: 0.025em;
        --tracking-wider: 0.05em;
        --tracking-widest: 0.1em;
    }
}

/* ************************************************************************************************************************ *
 * Suppression des stytle de base 
 * ************************************************************************************************************************ */
@layer base {
    *,
    ::after,
    ::before,
    ::backdrop,
    ::file-selector-button {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
      border: 0 solid;
    }
    html,
    :host {
      line-height: 1.5;
      -webkit-text-size-adjust: 100%;
      tab-size: 4;
      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;
    }
    body {
      line-height: inherit;
    }
    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 {
      font-size: 75%;
      line-height: 0;
      position: relative;
      vertical-align: baseline;
    }
    sub {
      bottom: -0.25em;
    }
    sup {
      top: -0.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;
      vertical-align: middle;
    }
    img,
    video {
      max-width: 100%;
      height: auto;
    }
    button,
    input,
    select,
    optgroup,
    textarea,
    ::file-selector-button {
      font: inherit;
      font-feature-settings: inherit;
      font-variation-settings: inherit;
      letter-spacing: inherit;
      color: inherit;
      border-radius: 0;
      background-color: transparent;
      opacity: 1;
    }
    :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;
      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,
    ::-webkit-datetime-edit-year-field,
    ::-webkit-datetime-edit-month-field,
    ::-webkit-datetime-edit-day-field,
    ::-webkit-datetime-edit-hour-field,
    ::-webkit-datetime-edit-minute-field,
    ::-webkit-datetime-edit-second-field,
    ::-webkit-datetime-edit-millisecond-field,
    ::-webkit-datetime-edit-meridiem-field {
      padding-block: 0;
    }
    :-moz-ui-invalid {
      box-shadow: none;
    }
    button,
    input:where([type=button], [type=reset], [type=submit]),
    ::file-selector-button {
      appearance: button;
    }
    ::-webkit-inner-spin-button,
    ::-webkit-outer-spin-button {
      height: auto;
    }
    [hidden]:where(:not([hidden=until-found])) {
      display: none !important;
    }
}


/* ************************************************************************************************************************ *
 * font
 * ************************************************************************************************************************ */
 
 @font-face {
    font-family: 'fashion-fetish';
    font-style: normal;
    font-weight: 800;
    src: url('../fonts/fashionFetish/Fashion-Fetish-Heavy.woff') format('woff'), /* Modern Browsers */
    url('../fonts/fashionFetish/Fashion-Fetish-Heavy.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/fashionFetish/Fashion-Fetish-Heavy.ttf') format('truetype'); /* Safari, Android, iOS */
}
@font-face {
    font-family: 'just-sans';
    font-style: normal;
    font-weight: 100;
    src: url('../fonts/justSans/JUST-Sans-ExLight.woff') format('woff'), /* Modern Browsers */
    url('../fonts/justSans/JUST-Sans-ExLight.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/justSans/JUST-Sans-ExLight.otf') format('truetype'); /* Safari, Android, iOS */
}
    
font-face {
    font-family: 'just-sans';
    font-style: normal;
    font-weight: 300;
    src: url('../fonts/justSans/JUST-Sans-Light.woff') format('woff'), /* Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Light.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Light.otf') format('truetype'); /* Safari, Android, iOS */
}
@font-face {
    font-family: 'just-sans';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/justSans/JUST-Sans-Regular.woff') format('woff'), /* Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Regular.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Regular.otf') format('truetype'); /* Safari, Android, iOS */
}
  
@font-face {
    font-family: 'just-sans';
    font-style: normal;
    font-weight: 500;
    src: url('../fonts/justSans/JUST-Sans-Medium.woff') format('woff'), /* Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Medium.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/justSans/JUST-Sans-Medium.otf') format('truetype'); /* Safari, Android, iOS */
}


/* ************************************************************************************************************************ *
 * Custom Style : base
 * ************************************************************************************************************************ */
body {
    margin: 0;
    display: flex;
    min-height: 100dvh;
    flex-direction: column;
    overflow-x: hidden;
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: var(--font-weight-thin);
    background: 
    linear-gradient(150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat,
    linear-gradient(-150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat,
    linear-gradient(150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat,
    linear-gradient(-150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat,
    linear-gradient(150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat,
    linear-gradient(-150deg, var(--color-neutral-800), var(--color-neutral-900) 20%, var(--color-black), var(--color-neutral-900) 80%, var(--color-neutral-800)) no-repeat;
    background-size: 100% 2000px, 100% 2000px, 100% 2000px, 100% 2000px, 100% 2000px, 100% 2000px; 
    background-position: right top, right 2000px, right 4000px, right 6000px, right 8000px, right 10000px;
}

h1, h2, h3, h4 {
    font-family: var(--font-title);
    --tw-font-weight: var(--font-weight-extrabold);
    font-weight: var(--font-weight-extrabold);
    margin:0
  }
h1 {
    font-size: var(--text-2xl);
    line-height: calc(var(--spacing) * 10);
    @media (width >= 80rem) {
        font-size: var(--text-3xl);
        line-height: calc(var(--spacing) * 12);
    }
}
h2 {
    font-size: var(--text-xl);
    line-height: calc(var(--spacing) * 9);
    @media (width >= 80rem) {
        font-size: var(--text-2xl);
        line-height: calc(var(--spacing) * 10);
    }
}
h3 {
    font-size: var(--text-lg);
    line-height: calc(var(--spacing) * 8);
    @media (width >= 80rem) {
      font-size: var(--text-xl);
      line-height: calc(var(--spacing) * 9);
    }
}
a {
    width: max-content;
    --tw-font-weight: 100;
    font-weight: 100;
    color: var(--color-brand-50);
    text-decoration-line: underline;
    text-underline-offset: 4px;
    letter-spacing: var(--tracking-wider);
    &:hover {
        color: var(--color-brand-50);
        opacity: 80%;
    }
  }
  a a:focus {
    --tw-outline-style: none;
    outline-style: none;
  }
  a:focus-visible {
    outline-style: none;
    color: var(--color-brand-lightblue);
  }

  /* buton */
.button, button {
    display: flex;
    cursor: pointer;
    align-items: center;
    border-radius: calc(infinity * 1px);
    border: 1px solid var(--color-white);
    text-align: center;
    font-weight: var(--font-weight-medium);
    text-decoration-line: none;
    height: calc(var(--spacing) * 12);
    padding-inline: calc(var(--spacing) * 7);
    &:focus, &:focus-visible {
        outline: none;
        border: 1px solid var(--color-brand-lightblue) !important;
        background: transparent !important;
        color:var(--color-white) !important;
    }
}
a.button {
    text-decoration: none;
}
.button:focus, button:focus {
    outline-style: none;
}
.button.primary, button.primary {
    background: var(--color-brand-50);
    color: var(--color-black);

}
/* ************************************************************************************************************************ *
 * Custom Style : Layout
 * ************************************************************************************************************************ */
main {
    flex: 1;
    margin-bottom: calc(var(--spacing) * 8);
}

section, .section {
    margin-inline: auto;
    box-sizing: border-box;
    max-width: 120rem;
    padding-inline: calc(var(--spacing) * 6);
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 10);
    }
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 10);
    }
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 18);
    }
    @media (width >= 96rem) {
      padding-inline: calc(var(--spacing) * 24);
    }
}
header {
    position: sticky;
    top: 0;
    z-index: 50;
    width: 100%;
    background-color: transparent;
    display: flex;
    height: calc(var(--spacing) * 20);
    align-items: center;
    @media (width >= 96rem) {
      height: calc(var(--spacing) * 28);
    }
    transition: background-color 0.3s ease;
}
header.scrolled {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
    border-color: color-mix(in oklab, var(--color-brand-50) 15%, transparent);
    background-color: var(--color-black);
}
header > div {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
}
header > div img {
    height: calc(var(--spacing) * 12);
    @media (width >= 96rem) {
      height: calc(var(--spacing) * 14);
    }
}

#kc-content-wrapper {
    position: relative;
    padding-block: calc(var(--spacing)* 5);

    @media (width >= 40rem) {
        padding-inline: calc(var(--spacing)* 12);
        padding-block: calc(var(--spacing)* 8);
        background-color: color-mix(in oklab, var(--color-neutral-800) 60%, transparent);
        border-radius: var(--radius-3xl);
        max-width: calc(var(--spacing)*150);
        
        padding-inline: calc(var(--spacing)* 20);
        padding-block: calc(var(--spacing)* 10);
        margin:calc(var(--spacing)* 10) auto 0;
    }
}

#kc-page-title {
    color: var(--color-neutral-300);
    
}
#kc-info {
    margin-top: calc(var(--spacing) * 3);
    color: var(--color-neutral-300);
}
#kc-form-buttons {
    padding:0;
}
#kc-form-buttons input {
    width:max-content;
}
.alert-error, .alert-success, .alert-warning, .alert-info {
    background-color:transparent;
    margin-bottom: calc(var(--spacing)* 6);
    color: var(--color-neutral-200);
}
.alert-success {
    color: var(--color-brand-lightblue)
}
.alert-warning, .alert-error {
    color: var(--color-brand-orange)
}

/* ************************************************************************************************************************ *
 * Custom Style : form
 * ************************************************************************************************************************ */
 input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  -webkit-text-fill-color: white;
  transition: background-color 5000s ease-in-out 0s;
}

.form-field {
    display: flex;
    flex-direction: column;
    margin-bottom: calc(var(--spacing)* 4);
    padding-bottom: calc(var(--spacing) * 6);
}
.form-field label {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-light);
    padding-bottom: calc(var(--spacing) * 4);
    font-size: var(--text-base);
    line-height: var(--text-base--line-height);
    color: var(--color-neutral-300);
    margin-bottom:0px;
    @media (width >= 48rem) {
      font-size: var(--text-lg);
      line-height: var(--text-lg--line-height);
    }
}

.form-field .form-widget, .form-field input {
    appearance: none;
    font-weight: var(--font-weight-light);
    height:calc(var(--spacing) * 12);
    border-radius: 2rem;
    border-style: solid;
    border-width: 1px;
    border-color: color-mix(in oklab, var(--color-brand-50) 10%, transparent);
    background-color: var(--color-neutral-800);
    color: var(--color-white);
    &::placeholder {
        color: var(--color-neutral-400);
    }
    padding-inline: calc(var(--spacing) * 7);
    &:focus {
        border-color: color-mix(in oklab, var(--color-brand-50) 30%, transparent);
        outline-style: none;
    }
}
.form-field .form-widget {
    display:flex;
    justify-content: space-between;
}
.form-field .form-widget:has(input:focus) {
    border-color: color-mix(in oklab, var(--color-brand-50) 30%, transparent);
    outline-style: none;
}
.form-field .form-widget input {
    height:auto;
    border-radius: 0;
    border:0;
    background-color:transparent;
    padding-inline: 0;
    padding-bottom: 0;
}
.form-widget-button {
    border:0;
    padding:0;
    color: var(--color-neutral-300);
}

/* error */
.form-field:has(#input-error) {
    padding-bottom:0;
}
.form-field:has(#input-error) .form-widget, .form-field:has(#input-error) input  {
    border-color: var(--color-error-bg);
    background-color: var(--color-error-bg);
}
#input-error {
    color: var(--color-error-text);
    height: calc(var(--spacing) * 6);
}

/* ************************************************************************************************************************ *
 * Custom Style : login page
 * ************************************************************************************************************************ */
#kc-form-login .form-field:has(.form-options) {
    margin-top: calc(var(--spacing) * -9);
    @media (width >= 28rem) {
        float:right;
        margin-top:0;
    }
}
#kc-form-login .form-options {
    padding-top: calc(var(--spacing) * 2);
    text-align: right;
    font-size:var(--text-sm);
    @media (width >= 28rem) {
        font-size:var(--text-base);
    }
}
#kc-form-login .form-options a {
    color: var(--color-neutral-300)
}
#kc-social-providers {
    position:relative;
    margin-top: calc(var(--spacing) * 12);
    padding-bottom: calc(var(--spacing) * 12);
    margin-bottom: calc(var(--spacing) * 4);
}
#kc-social-providers hr {
    display:none;
}
#kc-social-providers h2 {
    font-family: var(--font-body);
    font-weight: var(--font-weight-light);
    font-size: var(--text-base);
    color: var(--color-neutral-600);
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    display: flex;
    align-items: center;
    &::after, &::before {
        content: "";
        flex: 1;
        height: 1px;
        background: var(--color-neutral-600);
        margin:0 calc(var(--spacing) * 2);
    }
}

#kc-social-providers #social-google {
    width:100%;
    /* border-color: var(--color-neutral-200); */
    color: var(--color-neutral-200);
    font-weight:var(--font-weight-light);
    justify-content: center;
    @media (width >= 64rem) {
        font-size:var(--text-base);
    }
}
#kc-social-providers #social-google i {
    padding-right: calc(var(--spacing) * 3);
}

/* ************************************************************************************************************************ *
 * Custom Style : reset password
 * ************************************************************************************************************************ */
#kc-reset-password-form a {
    display:block;
    margin-top:calc(var(--spacing) * 2);
    margin-bottom: calc(var(--spacing) * 12);
    font-size: var(--text-sm);
}
#kc-reset-password-form .form-field {
    margin-bottom:0;
}