/*
Theme Name:  Guirec Hypnose
Theme URI:   https://guirec-hypnose.fr
Author:      Guirec
Description: Thème sur mesure — hypnothérapeute, mobile-first, SEO optimisé
Version:     1.0
Text Domain: guirec-hypnose
*/

/* ============================================================
   TOKENS & VARIABLES
   ============================================================ */
:root {

  /* Palette */
  --purple-dark: #4A2070;
  --purple-mid: #7B4FA6;
  --purple-light: #A97FCC;
  --purple-pale: #F0E8F8;
  --purple-bg: #FAF6FE;
  --purple-bg-light: #fcfaff;
  --pink-pale: #EFA5D9;
  --pink-dark: #D14B8F;
  --pink: #b345a5;
  --white: #FFFFFF;
  --black: #000000;
  --grey22: #222222;
  --grey44: #444444;
  --grey66: #666666;
  --text-dark: #3c2451;
  --text-mid: #4A3560;
  --text-mid-soft: #6B557E;
  --text-soft: #8E7AAA;
  --border: #E2D6F0;
  --grad-hero: linear-gradient(to top, rgb(79, 54, 145), rgb(179, 69, 165) 100%);
  --grad-btn: linear-gradient(135deg, #7B4FA6 0%, #5A2D8A 100%);
  --gradient: linear-gradient(to right, rgb(79, 54, 145), rgb(179, 69, 165) 100%);

  /* Typographie */
  --f-display: 'Fraunces', Georgia, serif;
  --f-body: 'Outfit', system-ui, -apple-system, Arial, sans-serif;

  /* Tailles de texte — échelle modérée */
  --t-xs: 0.75rem;
  /*  12px */
  --t-sm: 0.875rem;
  /*  14px */
  --t-base: 1rem;
  /*  16px */
  --t-md: 1.125rem;
  /*  18px */
  --t-lg: 1.375rem;
  /*  22px */
  --t-xl: 1.75rem;
  /*  28px */
  --t-2xl: 2.25rem;
  /*  36px */
  --t-3xl: 3rem;
  /*  48px */

  /* Espacements */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;

  /* Layout */
  --max-w: 1580px;
  --max-w-text: 680px;
  --header-h-mobile: 74px;
  --header-h: 110px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* Transitions */
  --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --dur: 180ms;

  /* Swiper */
  --swiper-pagination-color: #7B4FA6;
}

/* ============================================================
   RESET MINIMAL
   ============================================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  scroll-padding-top: 94px;
  /* compense le header sticky */
  -webkit-text-size-adjust: 100%;
  overflow-x: clip;

}

@media (min-width: 768px) {
  html {
    font-size: 15px;
  }
}



a[href^="tel"],
a[href^="sms"] {
  text-decoration: none;
}

/*
  FONTS AUTO-HÉBERGÉES — zéro dépendance Google
  ─────────────────────────────────────────────

/* ── Fraunces variable — titres, graisses 300–700 ── */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 400 500 600 700;
  font-display: swap;
  src: url('../fonts/fraunces-latin-variable.woff2') format('woff2');
  unicode-range: U+0020-007E, U+00A0-00FF, U+0152-0153,
    U+02BC, U+02C6, U+2013-2014, U+2018-2019,
    U+201C-201D, U+20AC, U+2122;
}

/* ── Outfit variable — corps de texte, graisses 300–700 ── */
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300 400 500 600;
  font-display: swap;
  src: url('../fonts/outfit-latin-variable.woff2') format('woff2');
  unicode-range: U+0020-007E, U+00A0-00FF, U+0152-0153,
    U+02BC, U+02C6, U+2013-2014, U+2018-2019,
    U+201C-201D, U+20AC, U+2122;
}

body {
  font-family: var(--f-body);
  font-size: var(--t-base);
  font-weight: 300;
  line-height: 1.65;
  background: var(--white);
  color: var(--text-dark);
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  max-width: 100%;
  overflow-x: clip;
}

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

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

ul,
ol {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

/* ============================================================
   TYPOGRAPHIE GLOBALE
   ============================================================ */
h1,
h2,
h3,
h4,
h5 {
  font-family: var(--f-display);
  font-weight: 500;
  line-height: 1.2;
  color: var(--purple-dark);
  letter-spacing: -0.01em;
}

h1 {
  font-size: var(--t-2xl);
}

h2 {
  font-size: var(--t-xl);
}

h3 {
  font-size: var(--t-lg);
}

h4 {
  font-size: var(--t-md);
}

p {
  color: inherit;
}

strong {
  font-weight: 500;
  color: inherit;
}

/* ============================================================
   CONTENU PRINCIPAL
   ============================================================ */
.site-main {
  flex: 1;
  /* prend tout l'espace disponible */
  min-height: 60vh;
}

.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: 8%;
}

.container--text {
  max-width: var(--max-w-text);
}

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

.text-align-center {
  text-align: center;
}

/* ============================================================
   BOUTONS
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0;
  line-height: 1;
  font-weight: 400;
  padding: 0.8rem 1.6rem;
  border-radius: var(--radius-pill);
  font-family: var(--f-body);
  font-size: var(--t-base);
  transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
  border: 1px solid transparent;
}

.btn:hover {
  opacity: 0.9;
  transform: translateY(-2px);
}

/* CTA principal  */
.btn--cta-1 {
  background: var(--grad-btn);
  color: var(--white);
}

.btn--cta-1-light {
  background: var(--white);
  color: #6b3e98;
  border-color: #6b3e98;
}

/* CTA secondaire  */
.btn--cta-2 {
  background: var(--pink);
  color: var(--white);
}

.btn--cta-2-light {
  background: var(--white);
  color: var(--pink);
  border-color: var(--pink);
}

/* ombre  */
.btn.shadow {
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.2);
}

/* Secondaire — outline accent */
.btn--outline {
  background: transparent;
  color: var(--c-accent);
  border: 1.5px solid var(--c-accent);
}

.btn--outline:hover {
  background: var(--c-accent-lt);
}

/* Ghost blanc (sur fond coloré) */
.btn--ghost {
  background: rgba(255, 255, 255, 0.15);
  color: var(--c-white);
  border: 1.5px solid rgba(255, 255, 255, 0.4);
}

.btn--ghost:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* Taille large (hero) */
.btn--lg {
  padding: 1rem 1.5rem;
  font-size: var(--t-base);
}

/* Taille mini */
.btn--mini {
  padding: .5rem 1rem;
  font-size: var(--t-xs);
}

/* Taille full */
.btn--full {
  width: 100%;
  padding: 1rem;
  font-size: 1.05rem;
}

/* Btn classique */
.btn-classic {
  background: var(--purple-pale);
  color: var(--purple-mid);
}

/* Btn trasnparent */
.btn-trans {
  background: transparent;
  color: var(--purple-mid);
  padding: 0.7rem;
}

/* ============================================================
   RESPONSIVE — tablette et desktop
   ============================================================ */
@media (min-width: 768px) {

  h1 {
    font-size: var(--t-3xl);
  }

  h2 {
    font-size: var(--t-2xl);
  }
}

@media (min-width: 1024px) {
  :root {
    --header-h: 72px;
  }
}

/* ============================================================
   ACCESSIBILITÉ — focus visible
   ============================================================ */
:focus-visible {
  outline: 2px solid var(--c-accent);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* ============================================================
   ANIMATION - on scroll
    (ajouter la classe .reveal via JS pour animer à l'apparition)
    (voir assets/js/main.js pour l'implémentation)
    (pas d'animation sur les préférences reduced motion)
    (utiliser avec parcimonie, principalement pour les éléments clés du hero)
   ============================================================ */

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

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

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.reveal.visible {
  opacity: 1;
  transform: none;
}

/* État initial — avant que .visible soit ajouté */
.reveal-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 600ms ease, transform 600ms ease;
}

.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 600ms ease 200ms, transform 600ms ease 200ms;
  /* délai 200ms */
}

/* État visible */
.reveal-up.visible,
.reveal-right.visible {
  opacity: 1;
  transform: translate(0);
}

/* ============================================================
   ANIMATION - Parallax
    (ajouter la classe .parallax via JS pour animer à l'apparition)
    (utiliser avec parcimonie, principalement pour les éléments clés du hero)
   ============================================================ */

.parallax {
  /*background-image: url('votre-image.jpg');*/
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  will-change: background-position;
  /* hint GPU */
}

/* ============================================================
   PERFORMANCE — réduction animations
   ============================================================ */
@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   GRID 12 COLONNES — système Bootstrap-like
   Usage : <div class="row"><div class="col-8">...</div><div class="col-4">...</div></div>
   ============================================================ */

.row {
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sp-6);
  row-gap: 2rem;
}

.row,
.grid {
  display: grid;
}

.row.valign-top {
  align-items: flex-start;
}

.row.valign-center {
  align-items: center;
}

.row.valign-bottom {
  align-items: flex-end;
}

/* ── Colonnes mobile (toujours actives) ─────────────────── */
.col-1 {
  grid-column: span 1;
}

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

.col-3 {
  grid-column: span 3;
}

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

.col-5 {
  grid-column: span 5;
}

.col-6 {
  grid-column: span 6;
}

.col-7 {
  grid-column: span 7;
}

.col-8 {
  grid-column: span 8;
}

.col-9 {
  grid-column: span 9;
}

.col-10 {
  grid-column: span 10;
}

.col-11 {
  grid-column: span 11;
}

.col-12 {
  grid-column: span 12;
}

/* ── Colonnes tablette (>= 640px) ───────────────────────── */
@media (min-width: 640px) {
  .col-sm-1 {
    grid-column: span 1;
  }

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

  .col-sm-3 {
    grid-column: span 3;
  }

  .col-sm-4 {
    grid-column: span 4;
  }

  .col-sm-5 {
    grid-column: span 5;
  }

  .col-sm-6 {
    grid-column: span 6;
  }

  .col-sm-7 {
    grid-column: span 7;
  }

  .col-sm-8 {
    grid-column: span 8;
  }

  .col-sm-9 {
    grid-column: span 9;
  }

  .col-sm-10 {
    grid-column: span 10;
  }

  .col-sm-11 {
    grid-column: span 11;
  }

  .col-sm-12 {
    grid-column: span 12;
  }
}

/* ── Colonnes desktop (>= 1024px) ───────────────────────── */
@media (min-width: 1024px) {
  .col-lg-1 {
    grid-column: span 1;
  }

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

  .col-lg-3 {
    grid-column: span 3;
  }

  .col-lg-4 {
    grid-column: span 4;
  }

  .col-lg-5 {
    grid-column: span 5;
  }

  .col-lg-6 {
    grid-column: span 6;
  }

  .col-lg-7 {
    grid-column: span 7;
  }

  .col-lg-8 {
    grid-column: span 8;
  }

  .col-lg-9 {
    grid-column: span 9;
  }

  .col-lg-10 {
    grid-column: span 10;
  }

  .col-lg-11 {
    grid-column: span 11;
  }

  .col-lg-12 {
    grid-column: span 12;
  }
}

/* ── Mobile : tout en pleine largeur par défaut ─────────── */
@media (max-width: 639px) {
  /*
  .col-1,
  .col-2,
  .col-3,
  .col-4,
  .col-5,
  .col-6,
  .col-7,
  .col-8,
  .col-9,
  .col-10,
  .col-11 {
    grid-column: span 12;
  }*/
}

/* ============================================================
   GAP SYSTEM — utilitaires responsive
   ============================================================ */

/* ── Gaps fixes (toutes tailles d'écran) ───────────────── */
.gap-0 {
  gap: 0;
}

.gap-1 {
  gap: var(--sp-1);
}

.gap-2 {
  gap: var(--sp-2);
}

.gap-3 {
  gap: var(--sp-3);
}

.gap-4 {
  gap: var(--sp-4);
}

.gap-6 {
  gap: var(--sp-6);
}

.gap-8 {
  gap: var(--sp-8);
}

.gap-10 {
  gap: var(--sp-10);
}

.gap-12 {
  gap: var(--sp-12);
}

.gap-16 {
  gap: var(--sp-16);
}

/* ── Gap colonne uniquement ─────────────────────────────── */
.col-gap-0 {
  column-gap: 0;
}

.col-gap-2 {
  column-gap: var(--sp-2);
}

.col-gap-4 {
  column-gap: var(--sp-4);
}

.col-gap-6 {
  column-gap: var(--sp-6);
}

.col-gap-8 {
  column-gap: var(--sp-8);
}

.col-gap-10 {
  column-gap: var(--sp-10);
}

.col-gap-16 {
  column-gap: var(--sp-16);
}

/* ── Gap ligne uniquement ───────────────────────────────── */
.row-gap-0 {
  row-gap: 0;
}

.row-gap-2 {
  row-gap: var(--sp-2);
}

.row-gap-4 {
  row-gap: var(--sp-4);
}

.row-gap-6 {
  row-gap: var(--sp-6);
}

.row-gap-8 {
  row-gap: var(--sp-8);
}

.row-gap-10 {
  row-gap: var(--sp-10);
}

.row-gap-16 {
  row-gap: var(--sp-16);
}

/* ── Tablette (>= 640px) ────────────────────────────────── */
@media (min-width: 640px) {
  .gap-sm-0 {
    gap: 0;
  }

  .gap-sm-2 {
    gap: var(--sp-2);
  }

  .gap-sm-4 {
    gap: var(--sp-4);
  }

  .gap-sm-6 {
    gap: var(--sp-6);
  }

  .gap-sm-8 {
    gap: var(--sp-8);
  }

  .gap-sm-10 {
    gap: var(--sp-10);
  }

  .gap-sm-16 {
    gap: var(--sp-16);
  }

  .col-gap-sm-0 {
    column-gap: 0;
  }

  .col-gap-sm-4 {
    column-gap: var(--sp-4);
  }

  .col-gap-sm-6 {
    column-gap: var(--sp-6);
  }

  .col-gap-sm-10 {
    column-gap: var(--sp-10);
  }

  .col-gap-sm-16 {
    column-gap: var(--sp-16);
  }

  .row-gap-sm-0 {
    row-gap: 0;
  }

  .row-gap-sm-4 {
    row-gap: var(--sp-4);
  }

  .row-gap-sm-6 {
    row-gap: var(--sp-6);
  }

  .row-gap-sm-10 {
    row-gap: var(--sp-10);
  }

  .row-gap-sm-16 {
    row-gap: var(--sp-16);
  }
}

/* ── Desktop (>= 1024px) ────────────────────────────────── */
@media (min-width: 1024px) {
  .gap-lg-0 {
    gap: 0;
  }

  .gap-lg-2 {
    gap: var(--sp-2);
  }

  .gap-lg-4 {
    gap: var(--sp-4);
  }

  .gap-lg-6 {
    gap: var(--sp-6);
  }

  .gap-lg-8 {
    gap: var(--sp-8);
  }

  .gap-lg-10 {
    gap: var(--sp-10);
  }

  .gap-lg-16 {
    gap: var(--sp-16);
  }

  .gap-lg-20 {
    gap: var(--sp-20);
  }

  .gap-lg-24 {
    gap: var(--sp-24);
  }

  .col-gap-lg-0 {
    column-gap: 0;
  }

  .col-gap-lg-4 {
    column-gap: var(--sp-4);
  }

  .col-gap-lg-6 {
    column-gap: var(--sp-6);
  }

  .col-gap-lg-10 {
    column-gap: var(--sp-10);
  }

  .col-gap-lg-16 {
    column-gap: var(--sp-16);
  }

  .row-gap-lg-0 {
    row-gap: 0;
  }

  .row-gap-lg-4 {
    row-gap: var(--sp-4);
  }

  .row-gap-lg-6 {
    row-gap: var(--sp-6);
  }

  .row-gap-lg-10 {
    row-gap: var(--sp-10);
  }

  .row-gap-lg-16 {
    row-gap: var(--sp-16);
  }
}

/* ── Col Image Full Height ────────────────────────────────── */

.col-image-full {
  align-self: stretch;
  overflow: hidden;
}

/* ── Visibilité responsive ──────────────────────────────── */

/* Par défaut — visible */
.col-visible {
  display: block;
}

.col-hidden {
  display: none;
}

/* Small — < 640px */
@media (max-width: 639px) {
  .col-sm-hidden {
    display: none;
  }

  .col-sm-visible {
    display: block;
  }
}

/* Medium — 640px → 1023px */
@media (min-width: 640px) and (max-width: 1023px) {
  .col-md-hidden {
    display: none;
  }

  .col-md-visible {
    display: block;
  }
}

/* Large — > 1024px */
@media (min-width: 1024px) {
  .col-lg-hidden {
    display: none;
  }

  .col-lg-visible {
    display: block;
  }
}