/* =========================================================
   DA DARK / GLOW — Portfolio
   - Mobile-first + breakpoints clean
   - Navbar responsive (hamburger + desktop)
   - Sections fullscreen + séparateurs
   - Cards / projets / skills / langues / contact
   - Footer + Scroll-to-top
========================================================= */

/* -----------------------------
   Variables (palette imposée)
------------------------------ */
:root {
    --c-bg: #F2EAF7;
    --c-accent: #C59DD9;
    --c-primary: #7A3F91;
    --c-ink: #2B0D3E;

    /* Texte */
    --txt: rgba(242, 234, 247, .92);
    --txt-dim: rgba(242, 234, 247, .72);
    --txt-faint: rgba(242, 234, 247, .55);

    /* Glass */
    --glass: rgba(242, 234, 247, .06);
    --glass-2: rgba(242, 234, 247, .09);
    --stroke: rgba(197, 157, 217, .16);
    --stroke-2: rgba(197, 157, 217, .22);

    /* Ombres */
    --shadow-1: 0 18px 50px rgba(0, 0, 0, .55);
    --shadow-2: 0 22px 70px rgba(0, 0, 0, .65);

    /* Rayons */
    --radius-1: 14px;
    --radius-2: 22px;

    /* Layout */
    --container: 1040px;
    --nav-h: 100px;

    /* Gutter global */
    --gutter: clamp(18px, 4vw, 72px);

    /* Spaces */
    --space-1: clamp(.6rem, 1.2vw, .95rem);
    --space-2: clamp(1rem, 2.2vw, 1.5rem);
    --space-3: clamp(1.4rem, 3.2vw, 2.3rem);
    --space-4: clamp(2.1rem, 4.6vw, 3.4rem);

    /* Type scale */
    --fs-hero: clamp(2.6rem, 5.2vw, 4.6rem);
    --fs-h2: clamp(1.6rem, 2.7vw, 2.45rem);
    --fs-h3: clamp(1.15rem, 1.8vw, 1.5rem);
    --fs-base: clamp(1rem, 1.1vw, 1.08rem);

    --line: 1.55;

    /* Hero align */
    --hero-left-pad: clamp(10px, 2vw, 74px);

    /* Intro */
    --intro-dur: 7.2s;
    /* durée totale */
    --intro-end-delay: 1s;
    /* fade final */
    --intro-text-dur: calc(var(--intro-dur) - var(--intro-end-delay));
    --intro-skip-fade: 220ms;
}

/* -----------------------------
   Reset + base
------------------------------ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: auto;
}

body {
    margin: 0;
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    font-size: var(--fs-base);
    line-height: var(--line);
    color: var(--txt);
    background: #050208;
    overflow-x: hidden;
}

/* Fond glow global */
body::before {
    content: "";
    position: fixed;
    inset: -200px;
    pointer-events: none;
    z-index: -2;
    background:
        radial-gradient(900px 540px at 15% 18%, rgba(122, 63, 145, .40), transparent 60%),
        radial-gradient(900px 600px at 80% 30%, rgba(197, 157, 217, .20), transparent 62%),
        radial-gradient(1100px 720px at 50% 82%, rgba(43, 13, 62, .55), transparent 62%);
}

/* Vignette */
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: -1;
    background: radial-gradient(circle at 50% 40%, transparent 0%, rgba(0, 0, 0, .45) 65%, rgba(0, 0, 0, .70) 100%);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

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

a:hover {
    text-decoration: none;
}

/* Focus ring uniquement pour les contrôles (accessibilité OK) */
:where(a, button, input, textarea, select, summary, [role="button"], [role="link"]):focus-visible {
    outline: 3px solid rgba(197, 157, 217, .75);
    outline-offset: 3px;
}

/* Et on neutralise le focus ring sur le reste (titres, sections, wrappers…) */
:where(:not(a, button, input, textarea, select, summary, [role="button"], [role="link"])):focus-visible {
    outline: none;
}

.sr-only {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

body.is-locked {
    overflow: hidden;
}

/* -----------------------------
   Layout
------------------------------ */
.container {
    width: min(var(--container), calc(100% - (2 * var(--gutter))));
    margin-inline: auto;
}

.main {
    padding-top: var(--nav-h);
}

/* Sections FULLSCREEN */
.section {
    min-height: calc(100vh - var(--nav-h));
    padding: var(--space-4) 0;
    display: flex;
    align-items: center;
    position: relative;
    scroll-margin-top: var(--nav-h);
}

.section__inner {
    width: 100%;
}

.section::before {
    content: "";
    position: absolute;
    inset: -40px 0 -40px 0;
    pointer-events: none;
    z-index: -1;
    opacity: .55;
    background:
        radial-gradient(700px 420px at 18% 40%, rgba(122, 63, 145, .22), transparent 60%),
        radial-gradient(700px 420px at 82% 62%, rgba(197, 157, 217, .14), transparent 62%);
}

.section--center {
    align-items: center;
}

.section__head {
    text-align: center;
    margin: 0 auto var(--space-3);
    width: min(860px, 100%);
}

.section__title {
    font-size: var(--fs-h2);
    margin: 0 0 10px;
    letter-spacing: .01em;
    font-weight: 900;
    color: rgba(242, 234, 247, .95);
    text-shadow: 0 8px 30px rgba(122, 63, 145, .20);
}

.section__lead {
    margin: 0;
    color: var(--txt-dim);
}

/* séparateur en bas de chaque section */
.section::after {
    content: "";
    position: absolute;
    left: var(--gutter);
    right: var(--gutter);
    bottom: 0;
    height: 3px;
    background: linear-gradient(90deg,
            transparent,
            rgba(197, 157, 217, .55),
            rgba(122, 63, 145, .55),
            rgba(197, 157, 217, .55),
            transparent);
    opacity: .85;
    filter: blur(.15px);
    box-shadow: 0 0 18px rgba(122, 63, 145, .25);
    pointer-events: none;
}

.section:last-of-type::after {
    display: none;
}

/* -----------------------------
   Reveal on scroll
------------------------------ */
.reveal-el {
    opacity: 0;
    transform: translateY(18px);
    filter: blur(2px);
    transition:
        opacity 600ms ease,
        transform 650ms ease,
        filter 650ms ease;
    transition-delay: var(--reveal-delay, 0ms);
    will-change: transform, opacity, filter;
}

.reveal-el.is-visible {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

/* -----------------------------
   Navbar sticky (mobile-first)
------------------------------ */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
}

.skip-link {
    position: absolute;
    left: var(--gutter);
    top: 10px;
    transform: translateY(-140%);
    background: rgba(242, 234, 247, .92);
    color: #050208;
    padding: 10px 12px;
    border-radius: 12px;
    z-index: 9999;
    box-shadow: 0 14px 30px rgba(0, 0, 0, .45);
}

.skip-link:focus {
    transform: translateY(0);
}

.nav {
    height: var(--nav-h);
    background: rgba(0, 0, 0, .42);
    border-bottom: 1px solid rgba(197, 157, 217, .10);
    backdrop-filter: blur(12px);
}

.nav__inner {
    width: min(var(--container), calc(100% - (2 * var(--gutter))));
    margin-inline: auto;

    height: 100%;
    display: grid;
    grid-template-columns: auto 1fr auto;
    /* logo | mail | burger */
    align-items: center;
    gap: var(--space-1);
}

.nav__brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.nav__logo {
    filter: drop-shadow(0 10px 22px rgba(122, 63, 145, .25));
}

.nav__email {
    justify-self: start;
    font-size: .98rem;
    color: rgba(242, 234, 247, .82);
    opacity: .9;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 44vw;
}

.nav__email:hover {
    opacity: 1;
}

.nav__toggle {
    justify-self: end;
    border: 1px solid rgba(197, 157, 217, .18);
    background: rgba(242, 234, 247, .06);
    color: var(--txt);
    border-radius: 999px;
    padding: 10px 12px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 14px 30px rgba(0, 0, 0, .35);
}

.nav__toggle-icon {
    width: 18px;
    height: 12px;
    position: relative;
    display: inline-block;
}

.nav__toggle-icon::before,
.nav__toggle-icon::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: rgba(242, 234, 247, .92);
    border-radius: 2px;
}

.nav__toggle-icon::before {
    top: 0;
}

.nav__toggle-icon::after {
    bottom: 0;
}

.nav__panel {
    grid-column: 1 / -1;
    display: none;
}

.nav__panel.is-open {
    display: block;
}

.nav__list {
    list-style: none;
    margin: var(--space-1) 0 0;
    padding: 12px;
    /* ✅ plus opaque (demandé) */
    background: rgba(0, 0, 0, .78);
    border: 1px solid rgba(197, 157, 217, .16);
    border-radius: var(--radius-2);
    box-shadow: var(--shadow-1);
    display: grid;
    gap: 6px;
    backdrop-filter: blur(10px);
}

.nav__link {
    display: block;
    padding: 10px 12px;
    border-radius: 999px;
    color: rgba(242, 234, 247, .84);
    border: 1px solid transparent;
}

.nav__link:hover {
    background: rgba(242, 234, 247, .04);
    border-color: rgba(197, 157, 217, .12);
}

.nav__link.is-active {
    background: transparent;
    border-color: transparent;
    color: rgba(242, 234, 247, .95);
}

/* No-JS */
.no-js .nav__toggle {
    display: none;
}

.no-js .nav__panel {
    display: block;
}

.no-js .nav__list {
    margin: 0;
}

/* Navbar indicator (desktop only uses) */
.nav__indicator {
    display: none;
}

/* -----------------------------
   Intro overlay
------------------------------ */
.intro {
    position: fixed;
    inset: 0;
    background: #000;
    color: #fff;
    z-index: 100;
    display: grid;
    place-items: center;
    overflow: hidden;
    opacity: 1;
    visibility: visible;

    animation: introFade var(--intro-end-delay) ease forwards;
    animation-delay: var(--intro-text-dur);
    transition: opacity var(--intro-skip-fade) ease, visibility var(--intro-skip-fade) ease;
}

.intro__content {
    text-align: center;
    padding: var(--space-3);
    width: min(860px, 92vw);
    display: grid;
    place-items: center;
    gap: 12px;
}

.intro__line {
    font-weight: 900;
    letter-spacing: .05em;
    text-transform: uppercase;
    margin: 0;
}

.intro__line--portfolio {
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    opacity: 0;
    animation: introPortfolio var(--intro-text-dur) ease forwards;
}

.intro__line--name {
    font-size: clamp(1.7rem, 4.2vw, 3.1rem);
    opacity: 0;
    margin-top: 10px;
    animation: introNameOpacity var(--intro-text-dur) ease forwards;
}

.reveal {
    display: inline-block;
    overflow: hidden;
    border-radius: 10px;
}

.reveal__text {
    display: inline-block;
    padding: 6px 12px;
    clip-path: inset(0 100% 0 0);
    animation: introReveal var(--intro-text-dur) ease forwards;
}

.intro__skip {
    margin-top: var(--space-2);
    border: 1px solid rgba(255, 255, 255, .35);
    background: rgba(255, 255, 255, .08);
    color: #fff;
    padding: 10px 14px;
    border-radius: 999px;
    cursor: pointer;
    font-size: .95rem;
}

.intro__skip:hover {
    background: rgba(255, 255, 255, .12);
}

.intro.intro--done {
    display: none;
}

.intro.intro--skip {
    animation: none !important;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

@keyframes introFade {
    to {
        opacity: 0;
        visibility: hidden;
    }
}

@keyframes introPortfolio {
    0% {
        opacity: 0;
        transform: translateY(10px)
    }

    12% {
        opacity: 1;
        transform: translateY(0)
    }

    32% {
        opacity: 1
    }

    42% {
        opacity: 0;
        transform: translateY(-6px)
    }

    100% {
        opacity: 0
    }
}

@keyframes introNameOpacity {

    0%,
    42% {
        opacity: 0;
        transform: translateY(10px)
    }

    52% {
        opacity: 1;
        transform: translateY(0)
    }

    80% {
        opacity: 1;
        transform: translateY(0)
    }

    100% {
        opacity: 0;
        transform: translateY(-6px)
    }
}

@keyframes introReveal {

    0%,
    48% {
        clip-path: inset(0 100% 0 0)
    }

    72% {
        clip-path: inset(0 0 0 0)
    }

    82% {
        clip-path: inset(0 0 0 0)
    }

    92% {
        clip-path: inset(0 100% 0 0)
    }

    100% {
        clip-path: inset(0 100% 0 0)
    }
}

/* -----------------------------
   HERO
------------------------------ */
.section--hero {
    align-items: center;
    padding-top: calc(var(--space-4) + 10px);
}

.hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    align-items: center;
    width: min(1480px, 100%);
    margin-inline: auto;
}

.hero__left {
    padding-left: var(--hero-left-pad);
    margin-right: auto;
}

.kicker {
    margin: 0 0 8px;
    color: #fff;
    font-weight: 800;
    letter-spacing: .08em;
    font-size: clamp(1rem, 1.2vw, 1.5rem);
}

.hero__title {
    font-size: var(--fs-hero);
    margin: 0 0 10px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: .01em;
}

.hero__title-strong {
    background: linear-gradient(90deg, rgba(242, 234, 247, .95), rgba(197, 157, 217, .95));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: 0 14px 60px rgba(122, 63, 145, .22);
}

.hero__title-plus {
    color: rgba(197, 157, 217, .95);
    text-shadow: 0 14px 60px rgba(122, 63, 145, .35);
}

.hero__subtitle {
    margin: 0 0 var(--space-1);
    color: var(--txt-dim);
    font-weight: 700;
    font-size: clamp(1.05rem, 1.2vw, 1.2rem);
}

.hero__bio {
    margin: 0 0 var(--space-2);
    color: var(--txt-faint);
    max-width: 62ch;
    font-size: clamp(1.02rem, 1.1vw, 1.15rem);
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-bottom: var(--space-3);
}

/* boutons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 12px 16px;
    border: 1px solid transparent;
    cursor: pointer;
    font-weight: 900;
}

.btn--primary {
    color: rgba(242, 234, 247, .95);
    border-color: rgba(197, 157, 217, .20);
    background: linear-gradient(90deg, rgba(122, 63, 145, .95), rgba(197, 157, 217, .85));
    box-shadow: 0 18px 44px rgba(122, 63, 145, .22);
    background-size: 200% 100%;
    background-position: 0% 50%;
}

.btn--primary:hover {
    filter: brightness(1.03);
    background-position: 100% 50%;
    box-shadow: 0 22px 60px rgba(122, 63, 145, .28);
}

.btn--outline {
    background: rgba(242, 234, 247, .06);
    border: 1px solid rgba(197, 157, 217, .22);
    color: rgba(242, 234, 247, .92);
}

.btn--outline:hover {
    background: rgba(122, 63, 145, .14);
    border-color: rgba(197, 157, 217, .30);
}

.btn--ghost {
    color: rgba(242, 234, 247, .92);
    border: 1px solid rgba(197, 157, 217, .20);
    background: rgba(242, 234, 247, .06);
}

.btn--ghost:hover {
    background: rgba(122, 63, 145, .14);
    border-color: rgba(197, 157, 217, .28);
}

.btn--sm {
    padding: 10px 14px;
    font-size: .95rem;
}

.social {
    display: flex;
    gap: 10px;
}

.icon-btn {
    width: 46px;
    height: 46px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(197, 157, 217, .18);
    background: rgba(242, 234, 247, .06);
    box-shadow: 0 16px 34px rgba(0, 0, 0, .35);
}

.icon-btn:hover {
    background: rgba(122, 63, 145, .16);
    border-color: rgba(197, 157, 217, .26);
    box-shadow: 0 18px 44px rgba(122, 63, 145, .18);
}

.icon {
    font-weight: 950;
    color: rgba(242, 234, 247, .92);
}

.icon--in {
    letter-spacing: -.02em;
}

/* visuel */
.hero__right {
    display: flex;
    justify-content: center;
}

.portrait {
    width: min(560px, 100%);
    position: relative;
    border-radius: 28px;
    background: rgba(242, 234, 247, .05);
    border: 1px solid rgba(197, 157, 217, .14);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .55);
    overflow: hidden;
}

.portrait::before {
    content: "";
    position: absolute;
    inset: -60px;
    background:
        radial-gradient(420px 320px at 20% 20%, rgba(122, 63, 145, .35), transparent 62%),
        radial-gradient(420px 320px at 80% 30%, rgba(197, 157, 217, .18), transparent 62%);
    pointer-events: none;
}

.portrait__img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    opacity: .96;
}

/* HERO STATS BAR */
.hero__bottom {
    width: min(1480px, 100%);
    margin-inline: auto;
    margin-top: clamp(28px, 4.2vw, 64px);
    margin-bottom: clamp(6px, 1.6vw, 18px);
}

.hero__bottom-left {
    width: 100%;
}

#accueil .stats {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: clamp(18px, 3vw, 44px);

    width: 100%;
    max-width: none;

    padding: clamp(14px, 2vw, 18px) clamp(16px, 2.4vw, 22px);
    border-radius: 18px;
    background: rgba(242, 234, 247, .06);
    border: 1px solid rgba(197, 157, 217, .14);
    box-shadow: 0 18px 50px rgba(0, 0, 0, .25);

    position: relative;
    overflow: hidden;
}

#accueil .stats::before {
    content: "";
    position: absolute;
    inset: -60px;
    background:
        radial-gradient(420px 220px at 18% 50%, rgba(122, 63, 145, .22), transparent 62%),
        radial-gradient(420px 220px at 85% 45%, rgba(197, 157, 217, .14), transparent 62%);
    pointer-events: none;
}

#accueil .stat {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    padding: 0;
    background: transparent;
    border: 0;
}

#accueil .stat+.stat {
    position: relative;
    padding-left: clamp(22px, 3.4vw, 52px);
}

#accueil .stat+.stat::before {
    content: "";
    position: absolute;
    left: clamp(11px, 1.7vw, 26px);
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: clamp(18px, 2.4vw, 28px);
    background: linear-gradient(to bottom, transparent, rgba(197, 157, 217, .28), transparent);
    opacity: .95;
}

#accueil .stat__num {
    font-size: clamp(2.6rem, 5.2vw, 5.6rem);
    line-height: 1;
    font-weight: 950;
    letter-spacing: .01em;
    color: #fff;
}

#accueil .stat__label {
    font-size: clamp(1.1rem, 1.3vw, 2.1rem);
    line-height: 1.18;
    font-weight: 800;
    color: #fff;
    max-width: 16ch;
}

/* -----------------------------
   Grilles / Cards (général)
------------------------------ */
.grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
}

.section__subtitle {
    font-size: var(--fs-h3);
    margin: 0 0 var(--space-1);
    color: rgba(242, 234, 247, .92);
    font-weight: 900;
}

.cards {
    display: grid;
    gap: 12px;
}

.card {
    background: rgba(242, 234, 247, .05);
    border: 1px solid rgba(197, 157, 217, .14);
    border-radius: var(--radius-2);
    padding: 16px 18px;
    box-shadow: 0 18px 50px rgba(0, 0, 0, .25);
}

.card__meta {
    font-size: .98rem;
    color: rgba(197, 157, 217, .88);
    font-weight: 900;
}

.card__title {
    font-weight: 950;
    margin-top: 8px;
    color: rgba(242, 234, 247, .95);
}

.card__place {
    margin-top: 6px;
    color: var(--txt-dim);
}

/* Qualités */
.qualities {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    width: min(1480px, 100%);
    margin-inline: auto;
}

.quality {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px 14px;
    align-items: center;
    background: rgba(242, 234, 247, .04);
    border: 1px solid rgba(197, 157, 217, .12);
    border-radius: var(--radius-2);
    padding: 16px 18px;
    box-shadow: 0 18px 60px rgba(0, 0, 0, .25);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.quality:hover {
    transform: translateY(-2px);
    border-color: rgba(197, 157, 217, .22);
    background: rgba(122, 63, 145, .10);
}

.quality__title {
    margin: 0 0 6px;
    font-size: var(--fs-h3);
    font-weight: 950;
    color: rgba(242, 234, 247, .95);
}

.quality__desc {
    margin: 0;
    color: var(--txt-dim);
}

.quality__arrow {
    color: rgba(197, 157, 217, .92);
    font-size: 1.3rem;
    transform: translateY(-2px);
}

/* Projets grid */
.projects {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    width: min(1480px, 100%);
    margin-inline: auto;
}

.project {
    background: rgba(242, 234, 247, .05);
    border: 1px solid rgba(197, 157, 217, .14);
    border-radius: var(--radius-2);
    overflow: hidden;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .40);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
    display: flex;
    flex-direction: column;
}

.project:hover {
    transform: translateY(-4px);
    box-shadow: 0 28px 95px rgba(0, 0, 0, .55);
    border-color: rgba(197, 157, 217, .24);
}

.project__img {
    width: 100%;
    object-fit: cover;
    filter: saturate(1.05) contrast(1.05);
}

.project__body {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: 100%;
}

.project__title {
    margin: 0 0 8px;
    font-size: var(--fs-h3);
    font-weight: 950;
    color: rgba(242, 234, 247, .95);
}

.project__desc {
    margin: 0;
    color: var(--txt-dim);
}

.project__actions {
    margin-top: auto;
    display: flex;
    justify-content: flex-end;
    padding-top: 10px;
}

.project__footer {
    margin-top: 14px;
    display: flex;
    justify-content: flex-end;
}

/* Skills */
.skills {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    width: min(1480px, 100%);
    margin-inline: auto;
}

.skill {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;

    min-height: 150px;
    padding: 18px 16px;

    background: rgba(242, 234, 247, .04);
    border: 1px solid rgba(197, 157, 217, .12);
    border-radius: var(--radius-2);
    box-shadow: 0 20px 70px rgba(0, 0, 0, .35);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.skill:hover,
.skill:focus-visible {
    transform: translateY(-3px);
    border-color: rgba(197, 157, 217, .22);
    background: rgba(122, 63, 145, .10);
}

.skill__top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.skill__logo {
    width: 60px;
    height: 60px;
    object-fit: contain;
    margin-bottom: 10px;
    filter: grayscale(1);
    opacity: .65;
    transition: filter 180ms ease, opacity 180ms ease;
}

.skill:hover .skill__logo,
.skill:focus-visible .skill__logo {
    filter: grayscale(0);
    opacity: 1;
}

.skill__name {
    margin: 0 0 8px;
    font-weight: 950;
    font-size: 1.05rem;
    color: rgba(242, 234, 247, .92);
}

.skill__percent {
    margin: 0;
    font-weight: 950;
    font-size: 1.2rem;
    color: rgba(197, 157, 217, .92);
}

/* -----------------------------
   Contact
------------------------------ */
.contact {
    align-items: start;
    width: min(1480px, 100%);
    margin-inline: auto;
}

.form {
    background: rgba(242, 234, 247, .05);
    border: 1px solid rgba(197, 157, 217, .14);
    border-radius: var(--radius-2);
    padding: 18px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .40);
}

.form__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.form__field {
    display: grid;
    gap: 6px;
    margin-bottom: 12px;
}

.form label {
    font-weight: 900;
    color: rgba(242, 234, 247, .92);
}

.form input,
.form textarea {
    border-radius: 16px;
    border: 1px solid rgba(197, 157, 217, .14);
    padding: 12px 12px;
    background: rgba(0, 0, 0, .35);
    color: rgba(242, 234, 247, .92);
}

.form input:focus-visible,
.form textarea:focus-visible {
    border-color: rgba(197, 157, 217, .28);
}

.form__hint {
    margin: 0;
    font-size: .92rem;
    color: var(--txt-dim);
}

.hp-field {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.contact__info {
    display: grid;
    gap: 12px;
}

.info-card {
    background: rgba(242, 234, 247, .05);
    border: 1px solid rgba(197, 157, 217, .14);
    border-radius: var(--radius-2);
    padding: 18px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .40);
}

.info-row {
    display: flex;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(197, 157, 217, .10);
}

.info-row:last-child {
    border-bottom: 0;
}

.info-icon {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(122, 63, 145, .22);
    border: 1px solid rgba(197, 157, 217, .16);
    color: rgba(242, 234, 247, .92);
    box-shadow: 0 18px 44px rgba(0, 0, 0, .35);
    flex: 0 0 auto;
}

.info-text {
    display: grid;
    gap: 4px;
}

.info-label {
    font-weight: 950;
    color: rgba(242, 234, 247, .92);
}

.info-value {
    color: var(--txt-dim);
}

.info-value a {
    color: rgba(197, 157, 217, .92);
}

.info-value a:hover {
    text-decoration: underline;
}

/* Titres contact centrés + card coordonnée centrée */
#contact .section__subtitle {
    text-align: center;
    width: 100%;
}

#contact .contact__info {
    justify-items: center;
}

/* -----------------------------
   Project detail pages
------------------------------ */
.project-detail {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    width: min(1180px, 100%);
    margin-inline: auto;
}

.project-detail__media {
    border-radius: var(--radius-2);
    overflow: hidden;
    border: 1px solid rgba(197, 157, 217, .14);
    background: rgba(242, 234, 247, .04);
}

.project-detail__media img {
    width: 100%;
    height: auto;
    display: block;
}

.project-detail__content {
    background: rgba(242, 234, 247, .04);
    border: 1px solid rgba(197, 157, 217, .14);
    border-radius: var(--radius-2);
    padding: 18px;
}

.project-detail__list {
    margin: 10px 0 0;
    padding-left: 18px;
    color: var(--txt-dim);
}

/* -----------------------------
   Project page (WattWay / LearnFlow)
------------------------------ */
.project-page {
    width: min(1480px, 100%);
    margin-inline: auto;
}

.project-hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    align-items: center;
}

.project-hero__title {
    font-size: clamp(2.2rem, 4.4vw, 3.6rem);
    line-height: 1.05;
    margin: 0 0 10px;
    font-weight: 950;
    letter-spacing: .01em;
}

.project-hero__lead {
    margin: 0 0 var(--space-2);
    color: var(--txt-dim);
    max-width: 70ch;
}

.project-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 var(--space-2);
}

.badge {
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(197, 157, 217, .16);
    background: rgba(242, 234, 247, .06);
    color: rgba(242, 234, 247, .85);
    font-weight: 850;
    font-size: .95rem;
}

.prose {
    width: min(980px, 100%);
    margin-inline: auto;
    display: grid;
    gap: 14px;
}

.prose h2 {
    margin: 22px 0 8px;
    font-size: clamp(1.4rem, 2.4vw, 2rem);
    font-weight: 950;
    color: rgba(242, 234, 247, .95);
}

.prose p,
.prose li {
    color: rgba(242, 234, 247, .78);
    line-height: 1.65;
}

.callouts {
    width: min(1100px, 100%);
    margin: 14px auto 0;
    display: grid;
    gap: 12px;
}

.callout {
    border-radius: var(--radius-2);
    border: 1px solid rgba(197, 157, 217, .14);
    background: rgba(242, 234, 247, .05);
    padding: 16px 18px;
}

.callout__title {
    margin: 0 0 8px;
    font-weight: 950;
    color: rgba(242, 234, 247, .92);
}

.back-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-top: var(--space-2);
    flex-wrap: wrap;
}

/* -----------------------------
   LANGUES — passport badge + CECR
------------------------------ */
.langs {
    width: min(1480px, 100%);
    margin-inline: auto;
    margin-top: var(--space-4);
    display: grid;
    gap: var(--space-2);
}

.langs__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.langs__title {
    margin: 0;
    font-size: var(--fs-h3);
    font-weight: 950;
    color: rgba(242, 234, 247, .95);
}

.langs__sub {
    margin: 0;
    color: var(--txt-dim);
    font-weight: 700;
}

.langs__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.lang-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-2);
    border: 1px solid rgba(197, 157, 217, .14);
    background: rgba(242, 234, 247, .05);
    padding: 16px 16px 14px;
}

.lang-card::before {
    content: "";
    position: absolute;
    inset: -70px;
    background:
        radial-gradient(420px 240px at 12% 25%, rgba(122, 63, 145, .22), transparent 62%),
        radial-gradient(360px 220px at 85% 20%, rgba(197, 157, 217, .14), transparent 62%);
    pointer-events: none;
}

.lang-card__top {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.lang-badge {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(197, 157, 217, .18);
    background: rgba(0, 0, 0, .28);
}

.lang-flag {
    width: 28px;
    height: 28px;
    object-fit: cover;
    border-radius: 7px;
    display: block;
}

.lang-meta {
    display: grid;
    gap: 4px;
}

.lang-name {
    font-weight: 950;
    color: rgba(242, 234, 247, .95);
    font-size: 1.05rem;
}

.lang-level {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.lang-level__tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 5px 10px;
    border-radius: 999px;
    font-weight: 950;
    border: 1px solid rgba(197, 157, 217, .22);
    background: rgba(122, 63, 145, .18);
    color: rgba(242, 234, 247, .92);
}

.lang-level__label {
    color: rgba(242, 234, 247, .75);
    font-weight: 750;
}

.cef {
    position: relative;
    display: grid;
    gap: 8px;
    margin-top: 10px;
}

.cef__scale {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    align-items: center;
}

.cef__dot {
    height: 10px;
    border-radius: 999px;
    border: 1px solid rgba(197, 157, 217, .18);
    background: rgba(242, 234, 247, .06);
}

.cef__labels {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    font-size: .78rem;
    color: rgba(242, 234, 247, .55);
    text-align: center;
    font-weight: 750;
}

.lang-note {
    position: relative;
    margin: 12px 0 0;
    color: rgba(242, 234, 247, .68);
    font-weight: 650;
    font-size: .95rem;
    line-height: 1.35;
}

/* Remplissage des paliers */
.lang-card.is-a2 .cef__dot:nth-child(-n+2),
.lang-card.is-b1 .cef__dot:nth-child(-n+3),
.lang-card.is-c1 .cef__dot:nth-child(-n+5) {
    background: linear-gradient(90deg, rgba(197, 157, 217, .80), rgba(122, 63, 145, .80));
    border-color: rgba(197, 157, 217, .35);
}

/* Palier actuel */
.lang-card.is-a2 .cef__dot:nth-child(2),
.lang-card.is-b1 .cef__dot:nth-child(3),
.lang-card.is-c1 .cef__dot:nth-child(5) {
    background: linear-gradient(90deg, rgba(242, 234, 247, .95), rgba(197, 157, 217, .95));
}

.langs-legend {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 8px;
    padding-top: 10px;
    border-top: 1px solid rgba(197, 157, 217, .10);
}

.legend-item {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(197, 157, 217, .12);
    background: rgba(242, 234, 247, .04);
    color: rgba(242, 234, 247, .72);
    font-weight: 700;
}

.legend-item b {
    color: rgba(242, 234, 247, .92);
    font-weight: 950;
}

/* -----------------------------
   Footer
------------------------------ */
.site-footer {
    position: relative;
    padding: 26px 0;
    margin-top: 18px;
    border-top: 1px solid rgba(197, 157, 217, .10);
    background: rgba(0, 0, 0, .35);
    backdrop-filter: blur(10px);
}

.site-footer::before {
    content: "";
    position: absolute;
    inset: -80px 0 auto 0;
    height: 160px;
    background:
        radial-gradient(520px 240px at 20% 40%, rgba(122, 63, 145, .18), transparent 62%),
        radial-gradient(520px 240px at 80% 40%, rgba(197, 157, 217, .12), transparent 62%);
    pointer-events: none;
}

.site-footer__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    position: relative;
}

.site-footer__copy {
    margin: 0;
    color: rgba(242, 234, 247, .68);
    font-weight: 650;
    font-size: .95rem;
}

.site-footer__links {
    display: flex;
    gap: 12px;
    align-items: center;
}

.site-footer__links a {
    padding: 8px 12px;
    border-radius: 999px;
    color: rgba(242, 234, 247, .78);
    border: 1px solid transparent;
    transition: background 200ms ease, border-color 200ms ease, transform 160ms ease;
}

.site-footer__links a:hover {
    background: rgba(242, 234, 247, .06);
    border-color: rgba(197, 157, 217, .14);
    transform: translateY(-1px);
}

/* -----------------------------
   Scroll to top
------------------------------ */
.to-top {
    position: fixed;
    right: clamp(16px, 2vw, 28px);
    bottom: clamp(16px, 2vw, 28px);
    width: 52px;
    height: 52px;
    border-radius: 999px;

    display: grid;
    place-items: center;

    background: rgba(242, 234, 247, .08);
    border: 1px solid rgba(197, 157, 217, .18);
    color: rgba(242, 234, 247, .92);

    cursor: pointer;
    z-index: 60;
    backdrop-filter: blur(10px);

    opacity: 0;
    transform: translateY(8px);
    pointer-events: none;

    transition: opacity 180ms ease, transform 180ms ease, background 200ms ease, border-color 200ms ease;
}

.to-top:hover {
    background: rgba(122, 63, 145, .16);
    border-color: rgba(197, 157, 217, .28);
    transform: translateY(6px);
}

.to-top.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.to-top i {
    font-size: 1.3rem;
    font-weight: 900;
    /* utile pour FA “Free” */
    line-height: 1;
    transform: translateY(-1px);
    display: block;
}

/* -----------------------------
   Micro-interactions (globaux)
------------------------------ */
.btn,
.icon-btn,
.nav__link {
    transition:
        transform 180ms ease,
        filter 180ms ease,
        box-shadow 220ms ease,
        background 220ms ease,
        border-color 220ms ease,
        color 220ms ease;
}

.btn:hover,
.icon-btn:hover {
    transform: translateY(-2px);
}

/* -----------------------------
   Breakpoints (mobile-first)
------------------------------ */

/* 360px+ : petit confort */
@media (min-width:360px) {
    .nav__email {
        max-width: 52vw;
    }
}

/* 430px+ : forms 2 colonnes */
@media (min-width:430px) {
    .form__row {
        grid-template-columns: 1fr 1fr;
    }
}

/* 576px+ : skills 2 colonnes */
@media (min-width:576px) {
    .skills {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* 768px+ : hero 2 cols, résumé 2 cols, projets 2 cols, langues 2 cols, callouts 2 cols */
@media (min-width:768px) {
    .hero {
        grid-template-columns: 1.05fr .95fr;
    }

    .grid-2 {
        grid-template-columns: 1fr 1fr;
    }

    .projects {
        grid-template-columns: 1fr 1fr;
    }

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

    .callouts {
        grid-template-columns: 1fr 1fr;
    }

    /* stats alignées au texte hero */
    #accueil .stats {
        margin-left: var(--hero-left-pad);
        width: calc(100% - var(--hero-left-pad));
    }
}

/* 992px+ : desktop nav + skills 3 cols + project-hero 2 cols + project-detail 2 cols + container */
@media (min-width:992px) {
    :root {
        --container: 1120px;
    }

    .section {
        padding: calc(var(--space-4) + 10px) 0;
    }

    .nav__inner {
        grid-template-columns: auto auto 1fr;
    }

    /* logo | email | menu */
    .nav__toggle {
        display: none;
    }

    .nav__panel {
        display: block;
        grid-column: auto;
        justify-self: center;
    }

    .nav__list {
        margin: 0;
        padding: 6px;
        display: flex;
        gap: 10px;
        align-items: center;
        background: transparent;
        border: 0;
        box-shadow: none;
        backdrop-filter: none;
        position: relative;
        padding-bottom: 10px;
    }

    .nav__link {
        padding: 9px 12px;
        border-radius: 999px;
        background: transparent;
    }

    .nav__list li:last-child .nav__link {
        padding: 10px 16px;
        color: rgba(242, 234, 247, .95);
        border: 1px solid rgba(197, 157, 217, .20);
        background: linear-gradient(90deg, rgba(122, 63, 145, .95), rgba(197, 157, 217, .85));
        box-shadow: 0 18px 44px rgba(122, 63, 145, .22);
    }

    .nav__list li:last-child .nav__link:hover {
        filter: brightness(1.04);
    }

    .nav__list li:not(:last-child) .nav__link.is-active {
        background: transparent;
        border-color: transparent;
        box-shadow: none;
    }

    /* underline indicator si tu l’utilises en JS */
    .nav__indicator {
        display: block;
        position: absolute;
        left: 0;
        bottom: 4px;
        height: 2px;
        width: 0;
        border-radius: 999px;
        background: linear-gradient(90deg,
                rgba(197, 157, 217, .15),
                rgba(197, 157, 217, .95),
                rgba(197, 157, 217, .15));
        transform: translateX(0);
        transition:
            transform 260ms cubic-bezier(.2, .9, .2, 1),
            width 260ms cubic-bezier(.2, .9, .2, 1),
            opacity 180ms ease;
        opacity: .95;
        pointer-events: none;
        will-change: transform, width;
    }

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

    .project-hero {
        grid-template-columns: 1.05fr .95fr;
    }

    .project-detail {
        grid-template-columns: 1.2fr .8fr;
        align-items: start;
    }
}

/* 1200px+ */
@media (min-width:1200px) {
    :root {
        --container: 1180px;
    }
}

/* 1280px+ : skills 4 cols + langues 3 cols */
@media (min-width:1280px) {
    :root {
        --container: 1240px;
    }

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

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

/* 1440px+ */
@media (min-width:1440px) {
    :root {
        --container: 1280px;
    }
}

/* 1600px+ */
@media (min-width:1600px) {
    :root {
        --container: 1320px;
    }
}

/* Mobile étroit : stats en colonne */
@media (max-width:430px) {
    #accueil .stats {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    #accueil .stat {
        justify-content: flex-start;
    }

    #accueil .stat+.stat {
        padding-left: 0;
        padding-top: 14px;
    }

    #accueil .stat+.stat::before {
        display: none;
    }
}

/* -----------------------------
   Accessibilité : reduced motion
------------------------------ */
@media (prefers-reduced-motion:reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
        scroll-behavior: auto !important;
    }

    .intro {
        display: none !important;
    }

    .reveal-el {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }
}


/* =========================
   RESUME : gutters cohérents
========================= */
#resume .section__inner {
    /* même règle que .container / .nav__inner */
    width: min(var(--container), calc(100% - (2 * var(--gutter))));
    margin-inline: auto;
}

/* La grille prend 100% de ce wrapper (pas une largeur à part) */
#resume .grid-2 {
    width: 100%;
    margin: 0;
    min-width: 0;
    /* évite les débordements/décalages */
}


/* =========================================================
   SECTIONS : gutters cohérents partout
   (accueil, resume, qualite, projets, competences, contact)
========================================================= */

/* 1) Tous les contenus de section respectent les mêmes marges */
.section .section__inner {
    width: min(var(--container), calc(100% - (2 * var(--gutter))));
    margin-inline: auto;
}

/* 2) Les gros wrappers ne doivent jamais “dépasser” le wrapper */
.section .grid-2,
.section .hero,
.section .hero__bottom,
.section .qualities,
.section .projects,
.section .skills,
.section .langs,
.section .contact,
.section .project-page,
.section .project-detail,
.section .prose,
.section .callouts {
    width: 100%;
    margin-inline: 0;
    min-width: 0;
}

/* 3) Sécurité anti overflow sur les enfants (très utile en CSS Grid/Flex) */
.section .grid-2>*,
.section .hero>*,
.section .projects>*,
.section .skills>*,
.section .langs__grid>*,
.section .contact>*,
.section .callouts>*,
.section .project-detail>* {
    min-width: 0;
}

/* =========================================================
   HAMBURGER MENU — fond + overlay (force l'opacité)
   (à mettre TOUT en bas du fichier)
========================================================= */

/* 1) Force le fond du menu UNIQUEMENT quand il est ouvert */
.nav__panel.is-open .nav__list {
    background: rgba(0, 0, 0, 0.88);
    border-color: rgba(197, 157, 217, 0.18);
    box-shadow: var(--shadow-1);
    backdrop-filter: blur(12px);
}

/* 2) (Optionnel mais recommandé) : voile derrière le menu */
@media (max-width: 991.98px) {
    .nav__panel.is-open {
        position: fixed;
        top: var(--nav-h);
        left: 0;
        right: 0;
        bottom: 0;
        padding: 0 var(--gutter) var(--gutter);
        z-index: 60;
    }

    .nav__panel.is-open::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.45);
        backdrop-filter: blur(6px);
    }

    .nav__panel.is-open .nav__list {
        position: relative;
        /* pour passer au-dessus du voile */
        margin-top: var(--space-2);
    }
}

/* =========================
   MOBILE (hamburger) : menu + opaque
   (à mettre tout en bas)
========================= */
@media (max-width: 991.98px) {
    .nav__panel.is-open .nav__list {
        background: rgba(0, 0, 0, 0.92) !important;
        /* + opaque */
        border-color: rgba(197, 157, 217, 0.22) !important;
        backdrop-filter: blur(12px);
    }
}


/* =========================================================
   NO SHADOW — enlever toutes les ombres derrière les blocs
   (à mettre TOUT en bas)
========================================================= */

/* Cards / blocs principaux */
.card,
.quality,
.project,
.skill,
.form,
.info-card,
.lang-card,
.callout,
.portrait,
.project-detail__media,
.project-detail__content,
#accueil .stats,
.icon-btn,
.btn,
.nav__toggle,
.nav__list {
    box-shadow: none !important;
}

/* Optionnel : si tu veux aussi enlever les "glow" de texte/éléments */
.section__title,
.hero__title-strong,
.hero__title-plus {
    text-shadow: none !important;
}



/* Force Material Symbols à s'afficher (même si d'autres styles écrasent) */
.material-symbols-rounded {
    font-family: "Material Symbols Rounded" !important;
    font-weight: 400;
    font-style: normal;
    font-size: 20px;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    text-transform: none;
    letter-spacing: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
}




.toast-stack {
    position: fixed;
    z-index: 9999;
    right: 16px;
    top: 16px;
    display: grid;
    gap: 10px;
    width: min(420px, calc(100vw - 32px));
    pointer-events: none;
}

.toast {
    pointer-events: auto;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    padding: 14px 14px;
    border-radius: 14px;
    box-shadow: 0 18px 50px rgba(0, 0, 0, .18);
    border: 1px solid rgba(0, 0, 0, .08);
    backdrop-filter: blur(8px);
    animation: toastIn .22s ease-out both;
}

.toast__title {
    font-weight: 800;
    letter-spacing: .02em;
    margin-bottom: 2px;
}

.toast__message {
    line-height: 1.35;
}

.toast__list {
    margin: 8px 0 0 18px;
    padding: 0;
    display: grid;
    gap: 4px;
}

.toast__close {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, .25);
    background: rgba(255, 255, 255, .12);
    color: inherit;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
}

.toast__close:hover {
    background: rgba(255, 255, 255, .18);
}

.toast--success {
    background: rgba(16, 185, 129, .92);
    color: #fff;
}

.toast--error {
    background: rgba(239, 68, 68, .92);
    color: #fff;
}

.toast.is-hiding {
    animation: toastOut .18s ease-in forwards;
}

@keyframes toastIn {
    from {
        transform: translateY(-8px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes toastOut {
    to {
        transform: translateY(-6px);
        opacity: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .toast {
        animation: none;
    }

    .toast.is-hiding {
        animation: none;
        opacity: 0;
    }
}

/* -----------------------------
   Contact form - privacy note
------------------------------ */
.form__privacy {
    margin-top: 12px;
    font-size: 0.85rem;
    /* petit */
    font-style: italic;
    /* italique */
    line-height: 1.35;
    opacity: 0.82;
    /* moins voyant */
    color: var(--txt-dim, rgba(242, 234, 247, .78));
    text-align: center;
}

/* Force les liens à passer en dessous */
.form__privacy a {
    display: inline-block;
    margin-top: 6px;
    /* espace entre texte et liens */
    font-style: normal;
    /* liens non-italiques (plus lisibles) */
    text-decoration: underline;
    text-underline-offset: 3px;
    opacity: 0.95;
}

/* Petit espacement entre les 2 liens */
.form__privacy a+a {
    margin-left: 10px;
}

/* Hover */
.form__privacy a:hover {
    opacity: 1;
}

/* Accessibilité : focus clavier */
.form__privacy a:focus-visible {
    outline: 2px solid rgba(242, 234, 247, .55);
    outline-offset: 3px;
    border-radius: 6px;
}

.form__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 10px;
}

/* Responsive : sur mobile, bouton plein largeur (optionnel mais souvent mieux) */
@media (max-width: 520px) {
    .form__actions {
        justify-content: stretch;
    }

    .form__actions .btn {
        width: 100%;
    }
}