/* ================================================
   Site Psychologue — Frontend Premium
   Palette : Beige chaud, Bleu profond, Ocre/Sienna
   Polices : Playfair Display + Lato (Google Fonts)
   ================================================ */
:root {
  --primary:   #fdfbf7;
  --secondary: #1a365d;
  --accent:    #b5836a;
  --text:      #2d3748;
  --text-muted:#718096;
  --border:    rgba(26,54,93,0.1);
  --surface:   #ffffff;
  --surface-2: #f7f5f0;
  --font-h:    'Playfair Display', Georgia, serif;
  --font-b:    'Lato', sans-serif;
  --radius:    16px;
  --shadow:    0 4px 24px rgba(26,54,93,0.07);
  --transition:220ms cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-b); background:var(--primary); color:var(--text); line-height:1.7; overflow-x:hidden; }
h1,h2,h3,h4,h5 { font-family:var(--font-h); color:var(--secondary); line-height:1.25; }
h1 { font-size:clamp(2rem,5vw,3.5rem); margin-bottom:1rem; }
h2 { font-size:clamp(1.5rem,3.5vw,2.5rem); margin-bottom:.75rem; }
h3 { font-size:1.25rem; margin-bottom:.5rem; }
p { margin-bottom:1rem; }
a { color:var(--accent); text-decoration:none; transition:color var(--transition); }
a:hover { color:var(--secondary); }
img { max-width:100%; height:auto; display:block; }
.container { width:min(90%, 1160px); margin-inline:auto; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:.5rem; padding:.75rem 1.75rem; border-radius:50px; font-family:var(--font-b); font-weight:700; font-size:.9rem; cursor:pointer; border:none; text-decoration:none; transition:all var(--transition); }
.btn-primary { background:var(--accent); color:#fff; box-shadow:0 4px 16px rgba(181,131,106,.3); }
.btn-primary:hover { background:var(--secondary); color:#fff; transform:translateY(-2px); box-shadow:0 6px 20px rgba(26,54,93,.25); }
.btn-secondary { background:transparent; color:var(--secondary); border:2px solid var(--secondary); }
.btn-secondary:hover { background:var(--secondary); color:#fff; }

/* ---- HEADER ---- */
.site-header { background:rgba(253,251,247,.92); backdrop-filter:blur(12px); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:100; transition:box-shadow var(--transition); }
.site-header.scrolled { box-shadow:0 2px 20px rgba(26,54,93,.08); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:72px; }
.site-logo { display:flex; align-items:center; gap:.75rem; text-decoration:none; flex-shrink:0; }
.site-logo img { height:52px; width:auto; object-fit:contain; }
.site-logo-text { font-family:var(--font-h); font-size:1.05rem; color:var(--secondary); line-height:1.2; font-weight:700; }
.site-logo-sub { font-size:.6rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--accent); }
.main-nav { display:flex; align-items:center; gap:2rem; list-style:none; }
.main-nav a { font-size:.88rem; font-weight:600; color:var(--text); letter-spacing:.02em; position:relative; }
.main-nav a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--accent); border-radius:2px; transition:width var(--transition); }
.main-nav a:hover::after { width:100%; }
.main-nav a:hover { color:var(--accent); }
.nav-cta { background:var(--accent); color:#fff !important; padding:.5rem 1.25rem; border-radius:50px; }
.nav-cta:hover { background:var(--secondary); }
.nav-cta::after { display:none !important; }
.menu-toggle { display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:.5rem; border-radius:8px; transition:background var(--transition); }
.menu-toggle:hover { background:var(--surface-2); }
.menu-toggle span { display:block; width:22px; height:2px; background:var(--secondary); border-radius:2px; transition:all var(--transition); }
.menu-toggle.is-open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.menu-toggle.is-open span:nth-child(2) { opacity:0; }
.menu-toggle.is-open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ---- HERO ---- */
.hero { display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.hero-sm { min-height:300px; }
.hero-md { min-height:500px; }
.hero-lg { min-height:680px; }
.hero-fs { min-height:100vh; }
.hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.hero-overlay { position:absolute; inset:0; background:rgba(0,0,0,.35); }
.hero-content { position:relative; z-index:1; padding:4rem 1.5rem; max-width:800px; }
.hero-content p { font-size:1.1rem; opacity:.9; max-width:600px; margin-inline:auto; margin-bottom:2rem; }

/* ---- SECTION ---- */
.section { padding:5rem 0; }
.section-alt { background:var(--surface-2); }
.section-label { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:var(--accent); margin-bottom:.75rem; }
.section-title { text-align:center; margin-bottom:.75rem; }
.section-sub { text-align:center; color:var(--text-muted); max-width:600px; margin:0 auto 3rem; font-size:1rem; }

/* ---- SERVICES GRID ---- */
.services-grid { display:grid; gap:1.5rem; }
.services-grid.cols-2 { grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.services-grid.cols-3 { grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.services-grid.cols-4 { grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.service-card { background:var(--surface); border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow); border:1px solid var(--border); transition:transform var(--transition),box-shadow var(--transition); overflow:hidden; }
.service-card:hover { transform:translateY(-6px); box-shadow:0 12px 40px rgba(26,54,93,.12); }
.service-card-img { height:160px; margin:-2rem -2rem 1.5rem; overflow:hidden; }
.service-card-img img { width:100%; height:100%; object-fit:cover; }
.service-card-stripe { height:5px; margin:-2rem -2rem 1.5rem; }
.service-card-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:1rem; font-size:1.4rem; }

/* ---- TEXT + IMAGE ---- */
.text-image { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.text-image.reverse { direction:rtl; }
.text-image.reverse > * { direction:ltr; }
.text-image-media { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/3; }
.text-image-media img { width:100%; height:100%; object-fit:cover; display:block; }
.text-image-placeholder { background:var(--surface-2); }

/* ---- KEY FIGURES ---- */
.key-figures { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1.5rem; }
.key-figure { text-align:center; padding:2rem 1rem; background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid var(--border); }
.key-figure-value { font-family:var(--font-h); font-size:3rem; font-weight:700; color:var(--accent); line-height:1; margin-bottom:.5rem; }
.key-figure-label { font-size:.82rem; color:var(--text-muted); font-weight:600; }

/* ---- REASSURANCE BAND ---- */
.reassurance { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem; }
.reassurance-item { display:flex; gap:1rem; align-items:flex-start; background:var(--surface); padding:1.5rem; border-radius:var(--radius); box-shadow:var(--shadow); }
.reassurance-icon { font-size:2rem; flex-shrink:0; }

/* ---- FAQ ---- */
.faq-list { max-width:720px; margin-inline:auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item:first-child { border-top:1px solid var(--border); }
.faq-btn { display:flex; justify-content:space-between; align-items:center; width:100%; padding:1.25rem 0; background:none; border:none; cursor:pointer; font-family:var(--font-h); font-size:1.05rem; font-weight:600; color:var(--secondary); text-align:left; gap:1rem; }
.faq-btn svg { flex-shrink:0; transition:transform var(--transition); }
.faq-btn.open svg { transform:rotate(45deg); }
.faq-answer { overflow:hidden; max-height:0; transition:max-height .4s ease; }
.faq-answer-inner { padding-bottom:1.25rem; color:var(--text-muted); line-height:1.8; }

/* ---- TESTIMONIALS ---- */
.testimonials-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.testimonial-card { background:var(--surface); border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow); border:1px solid var(--border); }
.testimonial-stars { color:#f59e0b; margin-bottom:.75rem; font-size:1rem; }
.testimonial-text { font-style:italic; color:var(--text-muted); margin-bottom:1.25rem; line-height:1.8; }
.testimonial-author { display:flex; align-items:center; gap:.75rem; }
.testimonial-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; border:2px solid var(--border); }
.testimonial-avatar-init { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--secondary)); display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:1rem; flex-shrink:0; }
.testimonial-name { font-weight:700; font-size:.88rem; }
.testimonial-title { font-size:.75rem; color:var(--text-muted); }

/* ---- CTA BANNER ---- */
.cta-banner { border-radius:var(--radius); padding:4rem 2rem; text-align:center; }
.cta-banner h2 { color:inherit; margin-bottom:.75rem; }
.cta-banner p { opacity:.85; margin-bottom:2rem; }

/* ---- TWO COLUMNS ---- */
.two-cols { display:grid; grid-template-columns:1fr 1fr; gap:3rem; }

/* ---- BLOG GRID ---- */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; }
.blog-card { background:var(--surface); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--border); transition:transform var(--transition); display:flex; flex-direction:column; }
.blog-card:hover { transform:translateY(-4px); }
.blog-card-img { height:200px; overflow:hidden; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.blog-card:hover .blog-card-img img { transform:scale(1.04); }
.blog-card-body { padding:1.5rem; flex:1; display:flex; flex-direction:column; }
.blog-card-date { font-size:.72rem; color:var(--text-muted); margin-bottom:.5rem; }
.blog-card h3 { margin-bottom:.75rem; font-size:1.1rem; line-height:1.35; }
.blog-card p { color:var(--text-muted); font-size:.88rem; flex:1; margin-bottom:1rem; }
.blog-read-more { color:var(--accent); font-weight:700; font-size:.85rem; display:inline-flex; align-items:center; gap:.3rem; }

/* ---- ARTICLE ---- */
.article-hero { background:var(--surface-2); padding:4rem 0 2rem; }
.article-meta { font-size:.8rem; color:var(--text-muted); margin-bottom:1rem; display:flex; gap:1rem; }
.article-img { width:100%; max-height:480px; object-fit:cover; border-radius:var(--radius); margin:2rem 0; }
.article-body { max-width:720px; margin-inline:auto; }
.article-body h2,.article-body h3 { margin:2rem 0 .75rem; }
.article-body p { margin-bottom:1.25rem; line-height:1.85; }
.article-body ul,.article-body ol { margin:1rem 0 1.25rem 1.5rem; }
.article-body li { margin-bottom:.4rem; }
.article-body blockquote { border-left:4px solid var(--accent); padding:1rem 1.5rem; margin:1.5rem 0; color:var(--text-muted); font-style:italic; background:var(--surface-2); border-radius:0 8px 8px 0; }

/* ---- CONTACT FORM ---- */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.contact-info-item { display:flex; gap:1rem; margin-bottom:1.5rem; align-items:flex-start; }
.contact-info-icon { width:44px; height:44px; border-radius:10px; background:rgba(181,131,106,.1); color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:1.25rem; flex-shrink:0; }
.form-group { margin-bottom:1.25rem; }
.form-group label { display:block; font-weight:700; font-size:.85rem; margin-bottom:.4rem; color:var(--secondary); }
.form-group input,.form-group textarea,.form-group select { width:100%; padding:.875rem 1rem; border:2px solid var(--border); border-radius:10px; font-family:var(--font-b); font-size:.9rem; background:var(--surface); color:var(--text); transition:border-color var(--transition); }
.form-group input:focus,.form-group textarea:focus,.form-group select:focus { outline:none; border-color:var(--accent); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.alert { padding:1rem 1.25rem; border-radius:10px; margin-bottom:1rem; font-size:.9rem; }
.alert-success { background:#dcfce7; color:#166534; border:1px solid #bbf7d0; }
.alert-error { background:#fee2e2; color:#991b1b; }

/* ---- FOOTER ---- */
.site-footer { background:var(--secondary); color:rgba(255,255,255,.75); padding:4rem 0 0; margin-top:5rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-heading { color:#fff; font-size:.75rem; font-weight:700; margin-bottom:1rem; text-transform:uppercase; letter-spacing:.12em; opacity:.5; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a { font-size:.82rem; color:rgba(255,255,255,.65); transition:color var(--transition); }
.footer-links a:hover { color:var(--accent); }
.social-btn { width:34px; height:34px; border-radius:8px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7); font-size:.82rem; text-decoration:none; transition:all var(--transition); }
.social-btn:hover { background:var(--accent); color:#fff; }
.footer-bottom-bar { border-top:1px solid rgba(255,255,255,.08); }
.footer-bottom { padding:1.25rem 0; display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.35); flex-wrap:wrap; gap:.5rem; }
.footer-bottom a { color:rgba(255,255,255,.35); }
.footer-bottom a:hover { color:var(--accent); }

/* ---- Responsive ---- */
.reassurance-icon { width:44px; height:44px; border-radius:10px; background:rgba(181,131,106,.1); color:var(--accent); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.service-card-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; margin-bottom:1rem; color:inherit; }

@media (max-width:1100px) {
  .footer-grid { grid-template-columns:2fr 1fr 1fr; gap:2rem; }
  .footer-grid > div:last-child { grid-column:1/-1; display:flex; gap:1rem; flex-wrap:wrap; }
  .footer-grid > div:last-child .footer-links { display:flex; gap:.5rem 1.5rem; flex-wrap:wrap; }
  .footer-grid > div:last-child .footer-links li { margin-bottom:0; }
}
@media (max-width:900px) {
  .text-image { grid-template-columns:1fr; }
  .text-image.reverse { direction:ltr; }
  .two-cols { grid-template-columns:1fr; gap:1.5rem; }
  .contact-grid { grid-template-columns:1fr; gap:2rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .footer-grid > div:last-child { grid-column:1/-1; }
}
@media (max-width:680px) {
  .main-nav { display:none; position:absolute; top:72px; left:0; right:0; background:var(--surface); flex-direction:column; align-items:flex-start; padding:1rem 1.5rem; border-bottom:1px solid var(--border); box-shadow:0 8px 24px rgba(0,0,0,.08); gap:0; z-index:99; }
  .main-nav.open { display:flex; }
  .main-nav li { width:100%; }
  .main-nav a { display:block; padding:.75rem 0; border-bottom:1px solid var(--border); }
  .nav-cta { margin-top:.5rem; border-radius:8px; display:inline-flex; width:auto; }
  .menu-toggle { display:flex; }
  .footer-grid { grid-template-columns:1fr; gap:1.75rem; }
  .footer-grid > div:last-child { grid-column:auto; }
  .footer-grid > div:last-child .footer-links { display:block; }
  .form-row { grid-template-columns:1fr; }
}
