/* ============================================================
   SHINY IN YOUR CAREER — Feuille de style
   Palette : rose poudré, crème ivoire, anthracite, doré
   ============================================================ */

:root{
  --rose:        #d99ca0;
  --rose-deep:   #c97f84;
  --rose-soft:   #f3d9d8;
  --cream:       #fcf4ee;
  --cream-2:     #f7e9e2;
  --ink:         #2b2422;
  --ink-soft:    #5e524e;
  --gold:        #c2a05f;
  --gold-light:  #d8be8a;
  --white:       #ffffff;

  --shadow:      0 18px 45px rgba(122, 74, 74, .14);
  --shadow-sm:   0 8px 22px rgba(122, 74, 74, .10);
  --radius:      22px;
  --radius-sm:   14px;
  --maxw:        1140px;

  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Poppins', system-ui, sans-serif;
  --script:'Great Vibes', cursive;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

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

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

h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.2; }

/* ===== Boutons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 30px; border-radius:50px;
  font-family:var(--sans); font-weight:500; font-size:.95rem;
  letter-spacing:.3px; cursor:pointer; border:none;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}
.btn-rose{
  background:linear-gradient(135deg, var(--rose), var(--rose-deep));
  color:#fff; box-shadow:0 10px 24px rgba(201,127,132,.4);
}
.btn-rose:hover{ transform:translateY(-3px); box-shadow:0 16px 32px rgba(201,127,132,.5); }
.btn-outline{
  background:transparent; color:var(--ink);
  border:1.5px solid var(--rose);
}
.btn-outline:hover{ background:var(--rose); color:#fff; transform:translateY(-3px); }
.btn-nav{ padding:10px 24px; background:var(--ink); color:#fff; }
.btn-nav:hover{ background:var(--rose-deep); }
.btn-block{ width:100%; }

/* ===== Header ===== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(252,244,238,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(201,127,132,.18);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.logo{ display:flex; flex-direction:column; line-height:1; }
.logo-script{ font-family:var(--script); font-size:2rem; color:var(--rose-deep); }
.logo-sub{
  font-family:var(--sans); font-size:.62rem; letter-spacing:3px;
  text-transform:uppercase; color:var(--ink-soft); margin-top:-2px; margin-left:3px;
}
.nav-links{ list-style:none; display:flex; align-items:center; gap:34px; }
.nav-links a{ font-size:.92rem; font-weight:400; transition:color .2s; }
.nav-links a:not(.btn):hover{ color:var(--rose-deep); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ width:26px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }

/* ===== Hero ===== */
.hero{
  position:relative; overflow:hidden;
  background:linear-gradient(160deg, var(--rose-soft) 0%, var(--cream) 55%);
  padding:90px 0 100px;
}
.hero-blob{ position:absolute; border-radius:50%; filter:blur(8px); opacity:.5; z-index:0; }
.hero-blob-1{ width:420px; height:420px; background:radial-gradient(circle, var(--rose) 0%, transparent 70%); top:-140px; right:-80px; }
.hero-blob-2{ width:360px; height:360px; background:radial-gradient(circle, var(--gold-light) 0%, transparent 70%); bottom:-160px; left:-100px; opacity:.35; }

.hero-inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.3fr .9fr; gap:50px; align-items:center; }
.hero-eyebrow{
  font-family:var(--script); font-size:1.9rem; color:var(--rose-deep); margin-bottom:6px;
}
.hero-title{ display:flex; flex-direction:column; margin-bottom:18px; }
.hero-script{ font-family:var(--script); font-size:5rem; color:var(--ink); line-height:.9; }
.hero-line{
  font-family:var(--serif); font-size:2.1rem; letter-spacing:6px;
  text-transform:uppercase; color:var(--rose-deep); margin-top:4px;
}
.hero-subtitle{ font-size:1.05rem; font-weight:500; color:var(--ink); margin-bottom:10px; }
.hero-tagline{ font-style:italic; color:var(--ink-soft); margin-bottom:30px; font-family:var(--serif); font-size:1.15rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }

.hero-badge{
  justify-self:center;
  width:300px; height:300px; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  box-shadow:var(--shadow), inset 0 0 0 5px rgba(194,160,95,.45);
  position:relative; overflow:hidden;
}
.hero-logo-img{
  width:100%; height:100%; object-fit:cover; border-radius:50%;
}
/* Texte de secours : masqué tant que le vrai logo s'affiche */
.hero-badge-script, .hero-badge-word{ display:none; }
.hero-badge--fallback{
  background:radial-gradient(circle at 35% 30%, #4b4441, #211d1c 75%);
}
.hero-badge--fallback::before{
  content:""; position:absolute; inset:24px; border:1px solid rgba(194,160,95,.45); border-radius:50%;
}
.hero-badge--fallback .hero-badge-script{ display:block; font-family:var(--script); font-size:3.4rem; color:var(--gold-light); }
.hero-badge--fallback .hero-badge-word{ display:block; font-family:var(--serif); letter-spacing:5px; text-transform:uppercase; font-size:1rem; color:#e9dcc4; }

/* ===== Ruban offre ===== */
.ribbon{
  background:linear-gradient(135deg, var(--rose), var(--rose-deep));
  color:#fff; text-align:center; padding:16px 24px;
}
.ribbon p{ font-size:.95rem; letter-spacing:.5px; font-weight:400; }

/* ===== Sections génériques ===== */
.section{ padding:90px 0; }
.section-soft{ background:linear-gradient(180deg, var(--cream-2), var(--cream)); }
.section-head{ text-align:center; margin-bottom:55px; }
.section-script{ font-family:var(--script); font-size:2rem; color:var(--rose-deep); display:block; }
.section-head h2{ font-size:2.3rem; color:var(--ink); margin-top:4px; }

.lead{ font-size:1.18rem; color:var(--ink); margin-bottom:18px; }
.lead-center{ text-align:center; max-width:680px; margin:0 auto 45px; }
.section p{ color:var(--ink-soft); }
.section .lead{ color:var(--ink); }

/* ===== À propos ===== */
.apropos-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:55px; align-items:center; }
.value-list{ list-style:none; display:flex; flex-direction:column; gap:18px; }
.value-list li{
  display:flex; align-items:center; gap:20px;
  background:#fff; padding:22px 26px; border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm); border-left:4px solid var(--rose);
}
.value-num{ font-family:var(--serif); font-size:2.6rem; color:var(--rose-deep); font-weight:700; min-width:54px; }
.value-label{ font-size:.95rem; color:var(--ink-soft); }

/* ===== Services ===== */
.services{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.service-card{
  background:#fff; border-radius:var(--radius); padding:40px 32px;
  box-shadow:var(--shadow-sm); text-align:center;
  transition:transform .3s ease, box-shadow .3s ease;
  border-top:4px solid transparent;
}
.service-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-top-color:var(--rose); }
.service-card-feature{
  background:linear-gradient(170deg, #fff, var(--rose-soft));
  border-top-color:var(--gold);
}
.service-icon{
  width:70px; height:70px; margin:0 auto 22px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; border-radius:50%;
  background:linear-gradient(135deg, var(--rose-soft), var(--cream-2));
  color:var(--rose-deep);
}
.service-card h3{ font-size:1.5rem; margin-bottom:16px; color:var(--ink); }
.service-card p{ font-size:.96rem; margin-bottom:12px; }
.service-punch{ font-family:var(--serif); font-style:italic; color:var(--rose-deep); font-size:1.05rem; margin-top:8px; }

/* ===== Méthode / étapes ===== */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-bottom:60px; }
.step{
  background:#fff; border-radius:var(--radius); padding:36px 30px;
  box-shadow:var(--shadow-sm); position:relative;
}
.step-num{
  font-family:var(--serif); font-size:2.4rem; font-weight:700;
  color:var(--rose); display:block; margin-bottom:12px;
}
.step h3{ font-size:1.25rem; margin-bottom:10px; color:var(--ink); }
.step p{ font-size:.95rem; }

.quote{
  max-width:720px; margin:0 auto; text-align:center;
  font-family:var(--serif); font-size:1.8rem; font-style:italic; color:var(--ink);
  padding:40px 20px;
}
.quote cite{ display:block; font-size:1rem; font-style:normal; color:var(--rose-deep); margin-top:16px; font-family:var(--sans); }

/* ===== Contact ===== */
.section-contact{ background:linear-gradient(160deg, var(--rose-soft), var(--cream)); }
.contact-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:50px; }
.contact-info{ display:flex; flex-direction:column; gap:26px; }
.contact-item{ display:flex; flex-direction:column; gap:4px; }
.contact-label{ font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--rose-deep); }
.contact-item a{ font-size:1.05rem; color:var(--ink); transition:color .2s; word-break:break-word; }
.contact-item a:hover{ color:var(--rose-deep); }
.contact-brand{ margin-top:14px; padding-top:24px; border-top:1px solid rgba(201,127,132,.25); }
.contact-brand .logo-script{ font-size:2.2rem; }
.contact-brand .hero-tagline{ font-size:.95rem; margin-top:6px; }

.contact-form{ background:#fff; padding:38px; border-radius:var(--radius); box-shadow:var(--shadow); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:.85rem; font-weight:500; margin-bottom:7px; color:var(--ink); }
.field input, .field textarea, .field select{
  width:100%; padding:13px 16px; border:1.5px solid var(--cream-2);
  border-radius:var(--radius-sm); font-family:var(--sans); font-size:.95rem;
  background:var(--cream); color:var(--ink); transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(217,156,160,.25); background:#fff;
}
.field textarea{ resize:vertical; }
.form-note{ margin-top:14px; font-size:.9rem; min-height:1.2em; }
.form-note.ok{ color:#2e7d4f; }
.form-note.err{ color:#c0392b; }

/* ===== Footer ===== */
.site-footer{ background:var(--ink); color:#e9dcd6; padding:26px 0; }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; font-size:.85rem; }
.to-top{ color:var(--gold-light); transition:color .2s; }
.to-top:hover{ color:#fff; }

/* ===== Animations d'apparition ===== */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.reveal.visible{ opacity:1; transform:none; }

/* ===== Responsive ===== */
@media (max-width:900px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; }
  .hero-actions{ justify-content:center; }
  .hero-title{ align-items:center; }
  .hero-badge{ order:-1; width:220px; height:220px; }
  .apropos-grid{ grid-template-columns:1fr; gap:36px; }
  .services{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
}

@media (max-width:760px){
  .nav-toggle{ display:flex; }
  .nav-links{
    position:absolute; top:74px; left:0; right:0;
    flex-direction:column; gap:0; background:var(--cream);
    box-shadow:var(--shadow); max-height:0; overflow:hidden;
    transition:max-height .35s ease; padding:0 24px;
  }
  .nav-links.open{ max-height:340px; padding:14px 24px 22px; }
  .nav-links li{ width:100%; }
  .nav-links a{ display:block; padding:12px 0; }
  .nav-links .btn-nav{ margin-top:8px; text-align:center; }
  .hero-script{ font-size:3.6rem; }
  .hero-line{ font-size:1.5rem; letter-spacing:4px; }
  .section{ padding:64px 0; }
  .section-head h2{ font-size:1.9rem; }
  .quote{ font-size:1.4rem; }
}
