/* ═══ ABOUT PAGE ═══ */

.about-hero {
  min-height: 70vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; padding: 8rem 2rem 4rem;
  position: relative; overflow: hidden;
  background-image: url('../assets/images/backgrounds/bg-10.jpg');
  background-size: cover; background-position: center; background-attachment: fixed;
}
.about-hero::before { content:''; position:absolute; inset:0; background:rgba(255,255,255,0.45); }
.about-hero::after { content:''; position:absolute; bottom:0; left:0; right:0; height:120px; background:linear-gradient(to bottom, transparent, #f0f4f8); z-index:2; }
.about-hero-inner { position:relative; z-index:1; }
.about-hero h1 { font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3.5rem); font-weight:800; line-height:1.2; margin:1rem 0; }
.about-hero p { color:var(--text-soft); font-size:1.05rem; max-width:500px; margin:0 auto; }

.about-container { max-width:1100px; margin:0 auto; padding:0 2rem; }
.about-header { text-align:center; margin-bottom:3rem; }
.about-header h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3vw,2.5rem); font-weight:800; margin-bottom:0.5rem; }

/* STORY */
.about-story { padding:6rem 0; }
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.story-text .section-tag { display:block; margin-bottom:1rem; }
.story-text h2 { font-family:'Playfair Display',serif; font-size:clamp(1.6rem,2.5vw,2.2rem); font-weight:800; margin-bottom:1.5rem; }
.story-text p { color:var(--text-soft); line-height:1.9; margin-bottom:1rem; font-size:0.97rem; }
.story-text strong { color:var(--text); font-weight:700; }

.story-visual { display:flex; flex-direction:column; align-items:center; gap:2rem; }
.logo-showcase {
  position:relative; width:160px; height:160px;
  display:flex; align-items:center; justify-content:center;
}
.logo-showcase img { width:100%; height:100%; object-fit:contain; position:relative; z-index:1; animation:float 4s ease-in-out infinite; }
.logo-glow {
  position:absolute; inset:-20px;
  background:radial-gradient(circle, rgba(0,200,83,0.2), transparent 70%);
  border-radius:50%; animation:pulse 3s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:0.4;transform:scale(1)} 50%{opacity:1;transform:scale(1.1)} }

.story-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; width:100%; }
.story-stat {
  background:rgba(255,255,255,0.7); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.85); border-radius:16px;
  padding:1.5rem; text-align:center;
  box-shadow:0 4px 20px rgba(0,0,0,0.06);
  transition:all 0.3s;
}
.story-stat:hover { transform:translateY(-4px); border-color:rgba(0,200,83,0.3); }
.story-stat span { display:block; font-size:2rem; font-weight:800; color:var(--green); font-family:'Playfair Display',serif; }
.story-stat p { font-size:0.78rem; color:var(--text-soft); margin:0; }

/* VALEURS */
.about-values {
  padding:6rem 0;
  background-image:url('../assets/images/backgrounds/bg-05.jpg');
  background-size:cover; background-position:center; background-attachment:fixed;
  position:relative;
}
.about-values::before { content:''; position:absolute; inset:0; background:rgba(255,255,255,0.5); }
.about-values .about-container { position:relative; z-index:1; }

.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.value-card {
  background:rgba(255,255,255,0.7); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.85); border-radius:20px;
  padding:2rem 1.5rem; text-align:center;
  box-shadow:0 4px 20px rgba(0,0,0,0.06); transition:all 0.3s;
}
.value-card:hover { transform:translateY(-6px); border-color:rgba(0,200,83,0.3); box-shadow:0 16px 40px rgba(0,200,83,0.12); }
.value-icon {
  width:56px; height:56px; border-radius:14px;
  background:rgba(0,200,83,0.1); color:var(--green);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1rem;
}
.value-card h3 { font-size:1rem; font-weight:700; margin-bottom:0.6rem; }
.value-card p { font-size:0.85rem; color:var(--text-soft); line-height:1.7; }

/* SERVICES RÉSUMÉ */
.about-services { padding:6rem 0; }
.services-resume { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.resume-card {
  background:rgba(255,255,255,0.7); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.85); border-radius:20px;
  padding:2rem; text-decoration:none; color:var(--text);
  transition:all 0.3s; position:relative; overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,0.06);
}
.resume-card:hover { transform:translateY(-5px); border-color:rgba(0,200,83,0.3); box-shadow:0 20px 50px rgba(0,200,83,0.12); }
.resume-card.featured { border-color:rgba(0,200,83,0.3); background:rgba(255,255,255,0.85); }
.resume-num { font-size:0.75rem; color:var(--green); font-weight:600; letter-spacing:1px; display:block; margin-bottom:0.8rem; }
.resume-card h3 { font-size:1.2rem; font-weight:700; margin-bottom:0.4rem; }
.resume-card p { font-size:0.85rem; color:var(--text-soft); margin-bottom:1.2rem; }
.resume-arrow { color:var(--green); font-size:1.1rem; font-weight:600; }

/* CONTACT BANNER */
.about-contact { padding:5rem 0 6rem; }
.contact-banner {
  background:rgba(255,255,255,0.7); backdrop-filter:blur(20px);
  border:1px solid rgba(0,200,83,0.2); border-radius:24px;
  padding:2.5rem 3rem;
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; flex-wrap:wrap;
  box-shadow:0 8px 40px rgba(0,200,83,0.1);
}
.contact-banner h2 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:800; margin-bottom:0.3rem; }
.contact-banner p { color:var(--text-soft); font-size:0.9rem; }
.banner-btns { display:flex; gap:0.8rem; }
.btn-wa-about {
  padding:0.9rem 2rem; background:#25d366; color:#000;
  border-radius:12px; text-decoration:none; font-weight:700;
  font-size:0.95rem; transition:all 0.2s;
  box-shadow:0 4px 16px rgba(37,211,102,0.3);
}
.btn-wa-about:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,0.4); }

/* RESPONSIVE */
@media (max-width:900px) {
  .story-grid { grid-template-columns:1fr; gap:3rem; }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .services-resume { grid-template-columns:1fr; }
  .contact-banner { flex-direction:column; text-align:center; }
  .banner-btns { justify-content:center; }
  .story-stats { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:600px) {
  .values-grid { grid-template-columns:1fr; }
  .story-stats { grid-template-columns:1fr; }
}
