/* =========================================================
   Sacrée Paris — Theme CSS
   Port of the Lovable styles.css to plain CSS for WordPress
   ========================================================= */

/* ---------- DESIGN TOKENS ---------- */
:root {
    --radius: 0;

    /* Sacrée Paris palette (OKLCH from Lovable spec) */
    --background:        oklch(1 0 0);              /* #FFFFFF */
    --foreground:        oklch(0.24 0.18 268);       /* indigo Klein */
    --ink:               oklch(0.24 0.18 268);
    --cream:             oklch(0.97 0.012 80);
    --beige:             oklch(0.74 0.055 78);

    --primary:           oklch(0.24 0.18 268);
    --primary-foreground:oklch(1 0 0);

    --secondary:         oklch(0.74 0.055 78);
    --secondary-foreground: oklch(0.24 0.18 268);

    --muted:             oklch(0.97 0.012 80);
    --muted-foreground:  oklch(0.45 0.04 268);

    --accent:            oklch(0.74 0.055 78);
    --accent-foreground: oklch(0.24 0.18 268);

    --border:            oklch(0.9 0.01 80);
    --input:             oklch(0.9 0.01 80);
    --ring:              oklch(0.24 0.18 268);

    --font-sans:   "Jost", "Avenir", system-ui, sans-serif;
    --font-serif:  "Avenir Next Cyr", "Avenir Next", "Avenir", "Cormorant Garamond", serif;
    --font-display:"Avenir Next Cyr", "Avenir Next", "Avenir", "Cormorant Garamond", serif;

    /* Container widths */
    --container-sm:   1100px;
    --container-md:   1200px;
    --container-lg:   1400px;
    --container-xl:   1600px;

    /* Easing */
    --ease-out: cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ---------- RESET / BASE ---------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    background-color: var(--background);
    color: var(--foreground);
    font-family: var(--font-sans);
    font-weight: 300;
    font-feature-settings: "ss01", "kern";
    -webkit-font-smoothing: antialiased;
    letter-spacing: 0.01em;
    line-height: 1.5;
}

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

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

h1, h2, h3, h4, h5 {
    font-family: var(--font-display);
    font-weight: 400;
    letter-spacing: -0.01em;
    line-height: 1.05;
    margin: 0;
}

p { margin: 0; }
ul { margin: 0; padding: 0; list-style: none; }

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

/* GeneratePress site wrapper override */
.site-content { padding: 0 !important; }
.inside-article { padding: 0 !important; }
.site-content .container { max-width: none !important; padding: 0 !important; }
.entry-content { margin: 0 !important; }
#page { background: var(--background); }

/* ---------- CUSTOM UTILITY CLASSES (from Lovable) ---------- */
.font-serif   { font-family: var(--font-serif); }
.font-sans    { font-family: var(--font-sans); }
.font-display { font-family: var(--font-display); }

.italic { font-style: italic; }

.eyebrow {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.32em;
    text-transform: uppercase;
}

.display {
    font-family: var(--font-display);
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.02em;
}

.rule { height: 1px; background: var(--ink); opacity: 0.2; }

/* ---------- BUTTONS ---------- */
.btn-primary,
.btn-outline,
.btn-ghost-light {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 1.05rem 2.25rem;
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    transition: all 0.5s var(--ease-out);
    border: 1px solid var(--ink);
    cursor: pointer;
    will-change: transform;
    text-align: center;
    line-height: 1;
}

.btn-primary {
    background: var(--ink);
    color: #fff;
}
.btn-primary:hover {
    background: transparent;
    color: var(--ink);
    transform: translateY(-2px);
}

.btn-outline {
    background: transparent;
    color: var(--ink);
}
.btn-outline:hover {
    background: var(--ink);
    color: #fff;
    transform: translateY(-2px);
}

.btn-ghost-light {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.6);
}
.btn-ghost-light:hover {
    background: #fff;
    color: var(--ink);
    border-color: #fff;
    transform: translateY(-2px);
}
.btn-ghost-light--inverted {
    background: #fff;
    color: var(--ink);
    border-color: #fff;
}
.btn-ghost-light--inverted:hover {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.6);
}

/* Small variant for nav reservation button */
.btn-primary--sm { padding: 0.75rem 1.5rem; }

/* ---------- NAV LINK ---------- */
.nav-link {
    position: relative;
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink);
    transition: opacity 0.3s ease;
    padding-bottom: 4px;
}
.nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 100%;
    height: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.5s var(--ease-out);
}
.nav-link:hover::after,
.nav-link.active::after {
    transform: scaleX(1);
    transform-origin: left;
}

/* ---------- HEADER ---------- */
.sp-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    padding: 1.5rem 0;
    background: transparent;
    transition: all 0.7s var(--ease-out);
}
.sp-header--scrolled {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 1rem 0;
    border-bottom: 1px solid var(--border);
}
.sp-header__inner {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}
.sp-logo {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1;
    color: var(--ink);
}
.sp-logo__img {
    display: block;
    height: 48px;
    width: auto;
    max-width: 180px;
    transition: height 0.5s var(--ease-out), filter 0.5s var(--ease-out);
}
/* When header is scrolled (white background), logo can stay as-is.
   If your logo file is light-colored and disappears against white,
   un-comment this block to invert it when scrolled: */
/*
.sp-header--scrolled .sp-logo__img {
    filter: brightness(0) saturate(100%) invert(11%) sepia(80%) saturate(5000%) hue-rotate(245deg);
}
*/
.sp-header--scrolled .sp-logo__img {
    height: 40px;
}
/* Fallback text logo styles (kept in case logo image fails to load) */
.sp-logo__name {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--primary);
}
.sp-logo__sub {
    margin-top: 0.25rem;
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: oklch(0.24 0.18 268 / 0.7);
}
.sp-nav {
    display: none;
    align-items: center;
    gap: 3rem;
}
.sp-header__cta { display: none; }
.sp-burger {
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}
.sp-burger span {
    display: block;
    width: 24px;
    height: 1px;
    background: var(--ink);
    transition: transform 0.3s, opacity 0.3s;
}
.sp-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sp-burger.is-open span:nth-child(2) { opacity: 0; }
.sp-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.sp-mobile-nav {
    display: none;
    background: var(--background);
    border-top: 1px solid var(--border);
    animation: fadeIn 0.6s ease-out both;
}
.sp-mobile-nav.is-open { display: block; }
.sp-mobile-nav__inner {
    padding: 2rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

@media (min-width: 1024px) {
    .sp-header__inner { padding: 0 3rem; }
    .sp-nav { display: flex; }
    .sp-header__cta { display: inline-flex; }
    .sp-burger { display: none; }
    .sp-logo__img { height: 56px; }
}

/* ---------- FOOTER ---------- */
.sp-footer {
    position: relative;
    color: var(--primary-foreground);
    overflow: hidden;
}
.sp-footer__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0.9;
}
.sp-footer__overlay {
    position: absolute;
    inset: 0;
    background: oklch(0.24 0.18 268 / 0.7);
}
.sp-footer__inner {
    position: relative;
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 5rem 1.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}
.sp-footer__brand-name {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 3rem;
    line-height: 1;
}
.sp-footer__brand-sub { margin-top: 0.5rem; opacity: 0.7; }
.sp-footer__brand-desc {
    margin-top: 2rem;
    max-width: 24rem;
    font-weight: 300;
    line-height: 1.6;
    opacity: 0.8;
}
.sp-footer__col-title {
    margin-bottom: 1.5rem;
    opacity: 0.7;
}
.sp-footer__list { display: flex; flex-direction: column; gap: 0.75rem; font-weight: 300; }
.sp-footer__list a:hover { opacity: 0.6; transition: opacity 0.3s; }
.sp-footer__list--info { opacity: 0.9; }
.sp-footer__list--info li.pt-spacer { padding-top: 1rem; }
.sp-footer__list--info li.dim { opacity: 0.7; }
.sp-footer__socials {
    margin-top: 1.25rem;
    display: flex;
    gap: 0.75rem;
}
.sp-footer__social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 9999px;
    color: #fff;
    transition: all 0.5s var(--ease-out);
}
.sp-footer__social:hover {
    background: #fff;
    color: var(--primary);
    border-color: #fff;
}
.sp-footer__social svg { width: 16px; height: 16px; }
.sp-footer__bottom {
    position: relative;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}
.sp-footer__bottom-inner {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.75rem;
    opacity: 0.6;
}

@media (min-width: 768px) {
    .sp-footer__inner {
        grid-template-columns: 5fr 3fr 4fr;
        padding: 7rem 3rem;
    }
    .sp-footer__brand-name { font-size: 3.75rem; }
    .sp-footer__bottom-inner { flex-direction: row; padding: 1.5rem 3rem; }
}

/* ---------- CTA BAND ---------- */
.sp-ctaband {
    position: relative;
    overflow: hidden;
    color: var(--primary-foreground);
}
.sp-ctaband__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0.9;
}
.sp-ctaband__overlay {
    position: absolute;
    inset: 0;
    background: oklch(0.24 0.18 268 / 0.7);
}
.sp-ctaband__inner {
    position: relative;
    max-width: 56rem;
    margin: 0 auto;
    padding: 7rem 1.5rem;
    text-align: center;
}
.sp-ctaband__eyebrow { opacity: 0.7; margin-bottom: 2rem; }
.sp-ctaband__title {
    font-size: 3rem;
    line-height: 1;
}
.sp-ctaband__title em {
    font-style: italic;
    font-weight: 300;
    opacity: 0.9;
}
.sp-ctaband__lead {
    margin: 2rem auto 0;
    max-width: 36rem;
    font-weight: 300;
    line-height: 1.6;
    opacity: 0.85;
}
.sp-ctaband__buttons {
    margin-top: 3rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
}
.sp-ctaband__divider {
    background: var(--muted);
    height: 4rem;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sp-ctaband__divider span {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.875rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: oklch(0.24 0.18 268 / 0.4);
}
@media (min-width: 640px) {
    .sp-ctaband__buttons { flex-direction: row; }
}
@media (min-width: 768px) {
    .sp-ctaband__inner { padding: 10rem 1.5rem; }
    .sp-ctaband__title { font-size: 4.5rem; }
    .sp-ctaband__divider { height: 6rem; }
}

/* ---------- HERO (homepage) ---------- */
.sp-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}
.sp-hero__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    animation: slowZoom 8s ease-out both;
}
.sp-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.4), rgba(0,0,0,0.1) 50%, transparent);
}
.sp-hero__inner {
    position: relative;
    width: 100%;
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 5rem 1.5rem;
    color: #fff;
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: end;
}
.sp-hero__eyebrow { opacity: 0.8; }
.sp-hero__tagline {
    margin-top: 1.5rem;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.25rem;
    max-width: 28rem;
    opacity: 0.95;
}
.sp-hero__buttons {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
@media (min-width: 768px) {
    .sp-hero__inner {
        grid-template-columns: 7fr 5fr;
        padding: 7rem 3rem;
    }
    .sp-hero__tagline { font-size: 1.5rem; }
    .sp-hero__buttons { flex-direction: row; justify-content: flex-end; }
}

/* ---------- SUB-PAGE HERO (banner) ---------- */
.sp-banner {
    position: relative;
    height: 60vh;
    overflow: hidden;
}
.sp-banner--tall { height: 50vh; }
.sp-banner__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    filter: blur(8px);
    transform: scale(1.05);
}
.sp-banner__bg--med { filter: blur(12px); }
.sp-banner__overlay {
    position: absolute;
    inset: 0;
    background: oklch(0.24 0.18 268 / 0.3);
}
.sp-banner__overlay--light {
    background: oklch(0.24 0.18 268 / 0.2);
}
.sp-banner__inner {
    position: relative;
    z-index: 10;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0 1.5rem;
}
.sp-banner__eyebrow { color: rgba(255,255,255,0.8); }
.sp-banner__title {
    margin-top: 1.5rem;
    font-size: 3.75rem;
    color: #fff;
    filter: drop-shadow(0 4px 4px rgba(0,0,0,0.15));
}
.sp-banner__title em { font-style: italic; }
.sp-banner__lead {
    margin-top: 2rem;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.125rem;
    color: rgba(255,255,255,0.95);
    max-width: 42rem;
    filter: drop-shadow(0 2px 2px rgba(0,0,0,0.15));
}
@media (min-width: 768px) {
    .sp-banner { height: 75vh; }
    .sp-banner--tall { height: 70vh; }
    .sp-banner__title { font-size: 6rem; }
    .sp-banner__lead { font-size: 1.5rem; }
}

/* ---------- GENERIC SECTION ---------- */
.sp-section {
    padding: 7rem 0;
}
.sp-section--bg-muted { background: var(--muted); }
.sp-section--bg-primary { background: var(--primary); color: var(--primary-foreground); }
.sp-section--sm { padding: 5rem 0; }
.sp-section--lg { padding: 6rem 0; }
@media (min-width: 768px) {
    .sp-section { padding: 10rem 0; }
    .sp-section--sm { padding: 7rem 0; }
    .sp-section--lg { padding: 10rem 0; }
}

.sp-container {
    max-width: var(--container-lg);
    margin: 0 auto;
    padding: 0 1.5rem;
}
.sp-container--sm { max-width: var(--container-sm); }
.sp-container--md { max-width: var(--container-md); }
.sp-container--xl { max-width: var(--container-xl); }
.sp-container--prose { max-width: 56rem; padding-left: 1.5rem; padding-right: 1.5rem; text-align: center; }
@media (min-width: 768px) {
    .sp-container { padding: 0 3rem; }
}

/* Heading helpers */
.sp-title--xl { font-size: 3rem; line-height: 0.95; }
.sp-title--lg { font-size: 2.25rem; line-height: 1.05; }
.sp-title--md { font-size: 1.875rem; line-height: 1.1; }
@media (min-width: 768px) {
    .sp-title--xl { font-size: 4.5rem; }
    .sp-title--lg { font-size: 3rem; }
    .sp-title--md { font-size: 2.5rem; }
}

/* ---------- INTRO (welcome) ---------- */
.sp-intro {
    text-align: center;
    padding: 7rem 1.5rem;
}
.sp-intro__inner { max-width: 64rem; margin: 0 auto; }
.sp-intro__lead {
    margin-top: 2.5rem;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1.4;
    color: var(--primary);
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
}
.sp-intro__buttons {
    margin-top: 4rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
}
@media (min-width: 640px) {
    .sp-intro__buttons { flex-direction: row; }
}
@media (min-width: 768px) {
    .sp-intro { padding: 10rem 1.5rem; }
    .sp-intro__lead { font-size: 1.875rem; }
}

/* ---------- TWO-COL CONTENT BLOCK ---------- */
.sp-two-col {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    align-items: center;
}
@media (min-width: 768px) {
    .sp-two-col {
        grid-template-columns: repeat(12, 1fr);
        gap: 4rem;
    }
    .sp-two-col__text { grid-column: 2 / span 5; }
    .sp-two-col__text--right { grid-column: 7 / span 5; }
    .sp-two-col__media { grid-column: 7 / span 5; }
    .sp-two-col__media--left { grid-column: 1 / span 6; }
    .sp-two-col__media--right { grid-column: 8 / span 5; }
}

.sp-prose {
    margin-top: 2rem;
    font-weight: 300;
    line-height: 1.8;
    color: oklch(0.24 0.18 268 / 0.85);
}
.sp-prose + .sp-prose { margin-top: 1.5rem; }

.sp-eyebrow-line { color: var(--muted-foreground); margin-bottom: 0.5rem; }

.sp-buttons {
    margin-top: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
@media (min-width: 640px) { .sp-buttons { flex-direction: row; } }

.sp-media-block {
    overflow: hidden;
}
.sp-media-block img {
    width: 100%;
    height: auto;
    transition: transform 1.4s var(--ease-out);
}
.sp-media-block--tall img { height: 60vh; object-fit: cover; }
.sp-media-block--xtall img { height: 70vh; object-fit: cover; }
.sp-media-block--portrait img { height: 80vh; object-fit: cover; }
.sp-media-block:hover img { transform: scale(1.04); }

/* ---------- TECHNOLOGIES GRID ---------- */
.sp-tech-header {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-bottom: 5rem;
}
.sp-tech-lead {
    font-weight: 300;
    line-height: 1.8;
    opacity: 0.85;
}
.sp-tech-grid {
    display: grid;
    grid-template-columns: 1fr;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}
.sp-tech-cell {
    padding: 2.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
    position: relative;
    transition: background-color 0.3s;
    display: flex;
    flex-direction: column;
}
.sp-tech-cell:hover { background: rgba(255, 255, 255, 0.05); }
.sp-tech-cell__num {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 3rem;
    opacity: 0.3;
}
.sp-tech-cell__name {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin-top: 2rem;
}
.sp-tech-cell__desc {
    margin-top: 1.5rem;
    font-weight: 300;
    line-height: 1.6;
    opacity: 0.8;
    font-size: 0.875rem;
}
.sp-tech-cell--end { justify-content: flex-end; }
.sp-tech-cell--end p {
    font-family: var(--font-serif);
    font-style: italic;
    opacity: 0.7;
}
.sp-tech-cell--end .btn-ghost-light { margin-top: 2rem; align-self: flex-start; }

@media (min-width: 768px) {
    .sp-tech-header {
        grid-template-columns: 4fr 8fr;
        gap: 2rem;
    }
    .sp-tech-header__lead-wrap {
        grid-column: 2;
        align-self: end;
    }
    .sp-tech-grid { grid-template-columns: 1fr 1fr; }
    .sp-tech-cell:nth-child(2n+1) { border-right: 1px solid rgba(255, 255, 255, 0.15); }
}
@media (min-width: 1024px) {
    .sp-tech-grid { grid-template-columns: 1fr 1fr 1fr; }
    .sp-tech-cell { padding: 3rem; }
    .sp-tech-cell:nth-child(2n+1) { border-right: none; }
    .sp-tech-cell:not(:nth-child(3n)) { border-right: 1px solid rgba(255, 255, 255, 0.15); }
}

/* ---------- INSTANT SUSPENDU SECTION ---------- */
.sp-suspendu {
    position: relative;
    min-height: 90vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}
.sp-suspendu__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
}
.sp-suspendu__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
}
.sp-suspendu__inner {
    position: relative;
    max-width: 48rem;
    margin: 0 auto;
    padding: 8rem 1.5rem;
    color: #fff;
    text-align: center;
}
.sp-suspendu__title { font-size: 3rem; }
.sp-suspendu__title em { font-style: italic; }
.sp-suspendu__lead {
    margin: 2.5rem auto 0;
    max-width: 36rem;
    font-weight: 300;
    line-height: 1.8;
    opacity: 0.9;
}
.sp-suspendu .btn-ghost-light { margin-top: 3rem; }
@media (min-width: 768px) {
    .sp-suspendu__title { font-size: 4.5rem; }
}

/* ---------- SOINS GRID (homepage) ---------- */
.sp-soins-grid {
    display: grid;
    grid-template-columns: 1fr;
    column-gap: 1.5rem;
    row-gap: 4rem;
    margin-top: 4rem;
}
.sp-soin {
    display: block;
    color: var(--primary);
}
.sp-soin__media {
    overflow: hidden;
    aspect-ratio: 4 / 5;
}
.sp-soin__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--ease-out);
}
.sp-soin:hover .sp-soin__media img { transform: scale(1.05); }
.sp-soin__meta {
    margin-top: 1.5rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
}
.sp-soin__num { color: var(--muted-foreground); }
.sp-soin__name {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin-top: 0.75rem;
}
.sp-soin__arrow {
    font-family: var(--font-serif);
    font-style: italic;
    color: oklch(0.24 0.18 268 / 0.7);
    transition: transform 0.3s;
}
.sp-soin:hover .sp-soin__arrow { transform: translateX(8px); }
@media (min-width: 768px) { .sp-soins-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .sp-soins-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* ---------- REVIEWS ---------- */
.sp-reviews-head {
    text-align: center;
    margin-bottom: 5rem;
}
.sp-reviews-head__rating {
    margin-top: 2rem;
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    align-items: center;
}
.sp-reviews-head__score {
    font-family: var(--font-serif);
    font-size: 2.25rem;
    color: var(--primary);
}
.sp-reviews-head__stars {
    color: var(--secondary);
    letter-spacing: 0.1em;
}
.sp-reviews-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--border);
}
.sp-review {
    background: var(--background);
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
}
.sp-review__stars {
    color: var(--secondary);
    letter-spacing: 0.1em;
    font-size: 0.875rem;
}
.sp-review__text {
    margin-top: 2rem;
    flex: 1;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1.6;
    color: var(--primary);
}
.sp-review__author {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}
.sp-review__name {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--primary);
}
.sp-review__date {
    color: var(--muted-foreground);
    margin-top: 0.5rem;
}
@media (min-width: 768px) {
    .sp-reviews-grid { grid-template-columns: 1fr 1fr 1fr; }
    .sp-review { padding: 3rem; }
    .sp-review__text { font-size: 1.5rem; }
}

/* ---------- MAP / ADRESSE ---------- */
.sp-map-block {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}
.sp-map-block__map iframe {
    width: 100%;
    height: 60vh;
    border: 0;
    filter: grayscale(1);
}
@media (min-width: 768px) {
    .sp-map-block { grid-template-columns: 4fr 8fr; }
}

/* ---------- ACCORDION ---------- */
.sp-accordion {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.sp-accordion__item {
    border: 1px solid oklch(0.9 0.01 80 / 0.6);
    background: oklch(1 0 0 / 0.4);
    padding: 0 1.5rem;
    transition: border-color 0.3s, background-color 0.3s;
}
.sp-accordion__item:hover { border-color: oklch(0.24 0.18 268 / 0.4); }
.sp-accordion__item.is-open {
    border-color: oklch(0.24 0.18 268 / 0.5);
    background: oklch(0.97 0.012 80 / 0.3);
}
.sp-accordion__trigger {
    width: 100%;
    background: none;
    border: none;
    padding: 2rem 0;
    cursor: pointer;
    text-align: left;
    display: flex;
    align-items: baseline;
    gap: 1.5rem;
    color: inherit;
    font-family: inherit;
}
/* Defeat GeneratePress default button hover (which adds dark bg) */
.sp-accordion__trigger,
.sp-accordion__trigger:hover,
.sp-accordion__trigger:focus,
.sp-accordion__trigger:active {
    background-color: transparent !important;
    color: inherit !important;
    box-shadow: none !important;
    text-decoration: none;
}
.sp-accordion__num {
    color: var(--muted-foreground);
    flex-shrink: 0;
}
.sp-accordion__body { flex: 1; }
.sp-accordion__title {
    font-family: var(--font-display);
    font-weight: 400;
    line-height: 1.1;
    color: var(--primary);
    font-size: 1.5rem;
    letter-spacing: -0.02em;
}
.sp-accordion__desc {
    display: none;
    margin-top: 0.75rem;
    font-weight: 300;
    font-size: 0.875rem;
    color: oklch(0.24 0.18 268 / 0.6);
    max-width: 42rem;
}
.sp-accordion__chevron {
    margin-left: 1rem;
    flex-shrink: 0;
    font-family: var(--font-serif);
    font-size: 1.5rem;
    color: oklch(0.24 0.18 268 / 0.6);
    transition: transform 0.5s;
}
.sp-accordion__item.is-open .sp-accordion__chevron { transform: rotate(180deg); }
.sp-accordion__content {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.5s var(--ease-out);
}
.sp-accordion__item.is-open .sp-accordion__content { max-height: 4000px; }
.sp-accordion__content-inner {
    padding-bottom: 0.5rem;
}
.sp-accordion__desc-mobile {
    margin-bottom: 1.5rem;
    font-weight: 300;
    font-size: 0.875rem;
    color: oklch(0.24 0.18 268 / 0.7);
}
.sp-accordion__list {
    border-top: 1px solid oklch(0.9 0.01 80 / 0.6);
}
.sp-accordion__row {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 1rem;
    padding: 1.5rem 0;
    border-bottom: 1px solid oklch(0.9 0.01 80 / 0.6);
    align-items: baseline;
}
.sp-accordion__row-name {
    grid-column: span 12;
}
.sp-accordion__row-title {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--primary);
}
.sp-accordion__row-duration {
    color: var(--muted-foreground);
    margin-top: 0.5rem;
    font-size: 0.625rem;
    font-family: var(--font-sans);
    letter-spacing: 0.32em;
    text-transform: uppercase;
}
.sp-accordion__row-desc {
    grid-column: span 12;
    font-weight: 300;
    font-size: 0.875rem;
    color: oklch(0.24 0.18 268 / 0.7);
    line-height: 1.6;
}
.sp-accordion__row-price {
    grid-column: span 6;
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--primary);
}
.sp-accordion__row-cta {
    grid-column: span 6;
    text-align: right;
}
.sp-accordion__row-cta a {
    font-family: var(--font-sans);
    font-size: 0.625rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--primary);
    border-bottom: 1px solid oklch(0.24 0.18 268 / 0.3);
    padding-bottom: 0.25rem;
    transition: border-color 0.3s;
}
.sp-accordion__row-cta a:hover { border-color: var(--primary); }
@media (min-width: 768px) {
    .sp-accordion__item { padding: 0 2.5rem; }
    .sp-accordion__trigger { gap: 2.5rem; }
    .sp-accordion__title { font-size: 2.25rem; }
    .sp-accordion__desc { display: block; }
    .sp-accordion__desc-mobile { display: none; }
    .sp-accordion__chevron { font-size: 1.875rem; }
    .sp-accordion__row-name { grid-column: span 5; }
    .sp-accordion__row-desc { grid-column: span 4; }
    .sp-accordion__row-price { grid-column: span 1; }
    .sp-accordion__row-cta { grid-column: span 2; }
}

/* ---------- FAQ (simpler accordion) ---------- */
.sp-faq {
    display: flex;
    flex-direction: column;
}
.sp-faq__item {
    border-bottom: 1px solid oklch(0.24 0.18 268 / 0.15);
}
.sp-faq__trigger {
    width: 100%;
    background: none;
    border: none;
    padding: 1.5rem 0;
    cursor: pointer;
    text-align: left;
    font-family: var(--font-serif);
    font-size: 1.25rem;
    color: var(--primary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}
/* Defeat GeneratePress default button hover */
.sp-faq__trigger,
.sp-faq__trigger:hover,
.sp-faq__trigger:focus,
.sp-faq__trigger:active {
    background-color: transparent !important;
    color: var(--primary) !important;
    box-shadow: none !important;
    text-decoration: none;
}
.sp-faq__trigger::after {
    content: "";
    display: inline-block;
    width: 9px;
    height: 9px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    border-top: 0;
    border-left: 0;
    transform: rotate(45deg);
    margin-top: -4px;
    transition: transform 0.4s var(--ease-out);
    flex-shrink: 0;
}
.sp-faq__item.is-open .sp-faq__trigger::after {
    transform: rotate(-135deg);
    margin-top: 4px;
}
.sp-faq__content {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.4s var(--ease-out);
}
.sp-faq__item.is-open .sp-faq__content { max-height: 600px; }
.sp-faq__content-inner {
    padding-bottom: 1.5rem;
    font-weight: 300;
    font-size: 1rem;
    line-height: 1.6;
    color: oklch(0.24 0.18 268 / 0.8);
}
@media (min-width: 768px) {
    .sp-faq__trigger { font-size: 1.5rem; }
}

/* ---------- PRESTATIONS HEAD ---------- */
.sp-presta-catalog-head {
    text-align: center;
    margin-bottom: 4rem;
}
.sp-presta-catalog-head__title {
    margin-top: 1.5rem;
    font-size: 2.25rem;
    color: var(--primary);
}
.sp-presta-catalog-head__lead {
    margin-top: 1.5rem;
    font-weight: 300;
    color: oklch(0.24 0.18 268 / 0.7);
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
}
@media (min-width: 768px) {
    .sp-presta-catalog-head__title { font-size: 3rem; }
}

/* ---------- ABONNEMENT FORMULES ---------- */
.sp-formules {
    display: flex;
    flex-direction: column;
    gap: 4rem;
    max-width: var(--container-md);
    margin: 0 auto;
    padding: 0 1.5rem;
}
.sp-formule {
    border: 1px solid oklch(0.9 0.01 80 / 0.6);
    background: oklch(1 0 0 / 0.4);
    padding: 2rem;
}
.sp-formule__head {
    display: flex;
    gap: 1.5rem;
    align-items: baseline;
    margin-bottom: 2.5rem;
}
.sp-formule__num {
    color: var(--muted-foreground);
    flex-shrink: 0;
}
.sp-formule__title {
    margin-top: 0.75rem;
    font-family: var(--font-display);
    font-size: 1.875rem;
    color: var(--primary);
}
.sp-formule__desc {
    margin-top: 1rem;
    font-weight: 300;
    color: oklch(0.24 0.18 268 / 0.7);
    max-width: 42rem;
}
.sp-formule__tiers {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.sp-tier {
    border: 1px solid oklch(0.9 0.01 80 / 0.6);
    padding: 2rem;
    text-align: center;
    transition: border-color 0.3s;
}
.sp-tier:hover { border-color: oklch(0.24 0.18 268 / 0.4); }
.sp-tier--highlight {
    border-color: var(--primary);
    background: var(--primary);
    color: var(--primary-foreground);
}
.sp-tier__rec {
    opacity: 0.8;
    margin-bottom: 1rem;
}
.sp-tier__duration {
    color: var(--muted-foreground);
}
.sp-tier--highlight .sp-tier__duration { color: rgba(255,255,255,0.85); }
.sp-tier__price {
    margin-top: 1.5rem;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.25rem;
}
.sp-tier__price-amount {
    font-family: var(--font-display);
    font-size: 3.75rem;
    line-height: 1;
}
.sp-tier__price-currency {
    font-family: var(--font-serif);
    font-size: 1.5rem;
}
.sp-tier__per {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: oklch(0.24 0.18 268 / 0.6);
}
.sp-tier--highlight .sp-tier__per { color: rgba(255,255,255,0.8); }
.sp-tier__note {
    margin-top: 1.5rem;
    color: var(--muted-foreground);
}
.sp-tier--highlight .sp-tier__note { color: rgba(255,255,255,0.8); }
.sp-tier__cta {
    margin-top: 2rem;
    display: inline-block;
    font-family: var(--font-sans);
    font-size: 0.625rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    border-bottom: 1px solid oklch(0.24 0.18 268 / 0.3);
    padding-bottom: 0.25rem;
    transition: border-color 0.3s;
    color: var(--primary);
}
.sp-tier__cta:hover { border-color: var(--primary); }
.sp-tier--highlight .sp-tier__cta {
    color: var(--primary-foreground);
    border-color: rgba(255,255,255,0.4);
}
.sp-tier--highlight .sp-tier__cta:hover { border-color: #fff; }

@media (min-width: 768px) {
    .sp-formule { padding: 3.5rem; }
    .sp-formule__head { gap: 2.5rem; }
    .sp-formule__title { font-size: 3rem; }
    .sp-formule__tiers { grid-template-columns: 1fr 1fr 1fr; }
    .sp-tier__price-amount { font-size: 4.5rem; }
}

/* Prestations incluses (3-card list) */
.sp-included {
    margin-top: 2.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.sp-included li {
    border: 1px solid oklch(0.9 0.01 80 / 0.6);
    padding: 2rem 1rem;
    text-align: center;
    background: oklch(1 0 0 / 0.4);
}
.sp-included__name {
    margin-top: 1rem;
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--primary);
}
@media (min-width: 640px) {
    .sp-included { grid-template-columns: 1fr 1fr 1fr; }
}

/* ---------- CARTE CADEAU ---------- */
.sp-giftcard {
    position: relative;
    overflow: hidden;
    background: oklch(0.97 0.012 80 / 0.3);
    padding: 6rem 0;
}
.sp-giftcard__inner {
    max-width: var(--container-md);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}
.sp-giftcard__image {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border: 1px solid oklch(0.9 0.01 80 / 0.6);
}
.sp-giftcard__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.sp-giftcard__title em {
    font-style: italic;
    font-weight: 300;
}
.sp-giftcard__lead {
    margin-top: 2rem;
    font-weight: 300;
    color: oklch(0.24 0.18 268 / 0.75);
    line-height: 1.6;
    max-width: 32rem;
}
.sp-giftcard__list {
    margin-top: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.sp-giftcard__list li {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    color: oklch(0.24 0.18 268 / 0.8);
    font-weight: 300;
}
.sp-giftcard__list .num {
    color: var(--muted-foreground);
    flex-shrink: 0;
}
.sp-giftcard__buttons {
    margin-top: 3rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
@media (min-width: 640px) {
    .sp-giftcard__buttons { flex-direction: row; }
}
@media (min-width: 1024px) {
    .sp-giftcard__inner {
        grid-template-columns: 1fr 1fr;
        gap: 5rem;
    }
    .sp-giftcard { padding: 9rem 0; }
}

/* ---------- CONTACT ---------- */
.sp-contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
}
.sp-contact-info {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-top: 2.5rem;
    font-weight: 300;
    color: oklch(0.24 0.18 268 / 0.85);
}
.sp-contact-info__group .eyebrow { color: var(--muted-foreground); margin-bottom: 0.75rem; }
.sp-contact-info__group p { line-height: 1.6; }
.sp-contact-info__group .dim { opacity: 0.6; }
.sp-contact-map iframe {
    width: 100%;
    height: 60vh;
    border: 0;
    filter: grayscale(1);
}
@media (min-width: 768px) {
    .sp-contact-grid {
        grid-template-columns: 5fr 7fr;
        gap: 4rem;
    }
    .sp-contact-map iframe {
        height: 100vh;
    }
}

/* ---------- HISTOIRE EXPERTISE LIST ---------- */
.sp-expertise-list {
    margin-top: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.sp-expertise-list li {
    display: flex;
    gap: 1rem;
    color: oklch(0.24 0.18 268 / 0.9);
    font-weight: 300;
}
.sp-expertise-list .num {
    font-family: var(--font-serif);
    font-style: italic;
    color: oklch(0.24 0.18 268 / 0.6);
}

/* ---------- ANIMATIONS ---------- */
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes slowZoom {
    from { transform: scale(1.08); }
    to   { transform: scale(1); }
}
.animate-fade-up { animation: fadeUp 1.2s var(--ease-out) both; }
.animate-fade-in { animation: fadeIn 1.6s ease-out both; }
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.25s; }
.delay-300 { animation-delay: 0.4s; }

/* Reveal-on-scroll */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 1.1s var(--ease-out),
                transform 1.1s var(--ease-out);
    will-change: opacity, transform;
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.25s; }

@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
    .animate-fade-up, .animate-fade-in { animation: none; }
    .sp-hero__bg { animation: none; }
}
