/* ============================================================
   HarmoCare — Landing page (teaser)
   ============================================================ */
:root{
  --accent:#2E9E68;
  --ink:#19231F;
  --muted:#5C6B64;
  --body:#3E4A44;
  --bg:#F4F7F4;
  --deep-a:#1f6149;
  --deep-b:#184635;
  --deep-c:#143a2c;
  --tint:#E7F1EC;
  --hairline:#E3EAE5;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,sans-serif;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
h1,h2,h3,p{margin:0;}
svg{display:block;}

@keyframes harmoUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
@keyframes harmoDot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.8);}}

/* ---------- shared ---------- */
.container{max-width:1080px;margin:0 auto;}
.badge{
  display:inline-flex;align-items:center;gap:9px;
  padding:7px 15px 7px 13px;border-radius:999px;
  border:1px solid rgba(255,255,255,.26);background:rgba(255,255,255,.06);
}
.badge__dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:harmoDot 2.4s ease-in-out infinite;}
.badge__label{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.92);}
.badge--light{border-color:#C6DECF;background:#fff;margin-bottom:24px;}
.badge--light .badge__label{color:#2c5d49;}

/* ============================================================
   HERO
   ============================================================ */
.hero{display:flex;flex-wrap:wrap;min-height:660px;background:var(--deep-c);}
.hero__panel{
  flex:1 1 540px;min-width:320px;position:relative;overflow:hidden;
  background:linear-gradient(157deg,var(--deep-a) 0%,var(--deep-b) 56%,var(--deep-c) 100%);
  padding:46px clamp(32px,5vw,72px) 52px;
  display:flex;flex-direction:column;justify-content:space-between;gap:44px;
}
.hero__glow{
  position:absolute;top:-140px;right:-120px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,158,104,.35) 0%,rgba(46,158,104,0) 70%);pointer-events:none;
}
.hero__logo{position:relative;animation:harmoUp .7s ease both;}
.hero__logo img{height:36px;width:auto;}
.hero__main{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:22px;animation:harmoUp .8s ease .08s both;}
.hero__title{font-family:var(--serif);font-weight:500;font-size:clamp(36px,4.4vw,56px);line-height:1.06;letter-spacing:-.015em;color:#fff;text-wrap:balance;max-width:14ch;}
.hero__sub{font-size:clamp(16px,1.4vw,18px);line-height:1.62;color:rgba(255,255,255,.82);max-width:50ch;}
.hero__tagline{font-family:var(--serif);font-style:italic;font-size:clamp(16px,1.4vw,19px);line-height:1.5;color:rgba(255,255,255,.7);max-width:42ch;margin-top:6px;}

.community{position:relative;padding-top:30px;border-top:1px solid rgba(255,255,255,.16);animation:harmoUp .8s ease .16s both;}
.community__eyebrow{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.community__title{font-family:var(--serif);font-weight:500;font-size:clamp(25px,2.7vw,32px);line-height:1.1;letter-spacing:-.01em;color:#fff;margin-bottom:12px;}
.community__text{font-size:15px;line-height:1.55;color:rgba(255,255,255,.8);max-width:48ch;margin-bottom:20px;}

.socials{display:flex;flex-wrap:wrap;gap:11px;}
.social-btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:11px 18px;border-radius:999px;background:#fff;color:#143a2c;
  font-weight:600;font-size:14.5px;transition:transform .18s ease,box-shadow .18s ease;
}
.social-btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.22);}

.hero__photo{
  flex:1 1 480px;min-width:300px;position:relative;min-height:420px;
  background-image:url('assets/hero.jpg');background-size:cover;background-position:30% 30%;
}
.hero__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(20,58,44,.55) 0%,rgba(20,58,44,.12) 26%,rgba(20,58,44,0) 50%);
}

/* ============================================================
   POURQUOI
   ============================================================ */
.why{padding:clamp(72px,9vw,120px) 24px;background:var(--bg);}
.why__head{text-align:center;max-width:760px;margin:0 auto;}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.why__title{font-family:var(--serif);font-weight:500;font-size:clamp(30px,3.6vw,44px);line-height:1.1;letter-spacing:-.015em;color:var(--ink);margin-top:14px;}
.rule{width:44px;height:2px;background:var(--accent);margin:22px auto 0;border-radius:2px;}
.why__intro{max-width:720px;margin:40px auto 0;}
.why__intro p{font-size:17px;line-height:1.78;color:var(--body);}
.why__intro p + p{margin-top:20px;}
.why__intro strong{color:var(--ink);font-weight:600;}
.why__sub{text-align:center;font-family:var(--serif);font-weight:500;font-size:clamp(21px,2.2vw,26px);color:var(--ink);margin:clamp(48px,6vw,72px) 0 28px;}

.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;}
.card{
  background:#fff;border:1px solid var(--hairline);border-radius:16px;padding:32px;
  display:flex;flex-direction:column;align-items:flex-start;
  box-shadow:0 1px 2px rgba(20,58,44,.04);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(20,58,44,.09);border-color:#CFE2D6;}
.card__icon{
  width:56px;height:56px;border-radius:15px;
  background:linear-gradient(150deg,var(--accent) 0%,#15402f 140%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 8px 18px rgba(20,58,44,.18);margin-bottom:20px;
}
.card__title{font-size:18px;font-weight:600;color:var(--ink);margin-bottom:7px;}
.card__desc{font-size:15px;line-height:1.62;color:var(--muted);}

.mission{
  max-width:840px;margin:clamp(48px,6vw,72px) auto 0;
  background:linear-gradient(160deg,#EEF5F0 0%,#E7F1EC 100%);
  border:1px solid #D5E5DB;border-radius:16px;padding:clamp(32px,4vw,48px);text-align:center;
}
.mission__lead{font-family:var(--serif);font-weight:500;font-size:clamp(20px,2.2vw,26px);line-height:1.3;color:var(--ink);margin-bottom:16px;}
.mission__text{font-size:16.5px;line-height:1.7;color:var(--body);}
.mission__text strong{color:var(--accent);font-weight:700;}

/* ============================================================
   COMMUNAUTÉ (rappel)
   ============================================================ */
.cta{padding:clamp(64px,8vw,104px) 24px;background:linear-gradient(170deg,#EAF3EE 0%,#DEEDE4 100%);border-top:1px solid #DAE9E0;}
.cta__inner{max-width:780px;margin:0 auto;text-align:center;}
.cta__title{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,44px);line-height:1.08;letter-spacing:-.015em;color:var(--ink);text-wrap:balance;}
.cta__text{max-width:56ch;margin:20px auto 0;font-size:17px;line-height:1.65;color:var(--body);}

.audience{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;max-width:680px;margin:36px auto 0;text-align:left;}
.aud-card{background:#fff;border:1px solid #D6E6DD;border-radius:16px;padding:22px;display:flex;gap:14px;align-items:flex-start;}
.aud-card__icon{flex:none;width:42px;height:42px;border-radius:12px;background:var(--tint);display:flex;align-items:center;justify-content:center;color:var(--accent);}
.aud-card__label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:5px;}
.aud-card__text{font-size:14px;line-height:1.55;color:var(--body);}

.socials--center{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:34px;}
.social-btn--solid{background:var(--accent);color:#fff;padding:15px 26px;font-size:15.5px;box-shadow:0 8px 20px rgba(46,158,104,.28);}
.social-btn--solid:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(46,158,104,.36);}

/* ============================================================
   PROS
   ============================================================ */
.pros{padding:clamp(8px,2vw,16px) 24px clamp(56px,7vw,88px);background:linear-gradient(170deg,#DEEDE4 0%,#F4F7F4 32%);}
.pros__card{
  max-width:1020px;margin:0 auto;position:relative;overflow:hidden;
  background:linear-gradient(157deg,var(--deep-a) 0%,var(--deep-b) 58%,var(--deep-c) 100%);
  border-radius:26px;padding:clamp(36px,4.6vw,60px);
  display:flex;flex-wrap:wrap;gap:40px;align-items:center;justify-content:space-between;
}
.pros__glow{position:absolute;top:-120px;right:-90px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(46,158,104,.34) 0%,rgba(46,158,104,0) 70%);pointer-events:none;}
.pros__content{position:relative;flex:1 1 460px;min-width:280px;}
.pros__eyebrow{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;}
.pros__title{font-family:var(--serif);font-weight:500;font-size:clamp(27px,3.2vw,40px);line-height:1.1;letter-spacing:-.015em;color:#fff;text-wrap:balance;margin-bottom:16px;}
.pros__text{font-size:16px;line-height:1.62;color:rgba(255,255,255,.82);max-width:52ch;margin-bottom:22px;}
.free-badge{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);}
.free-badge span{font-size:13.5px;font-weight:600;color:#fff;}
.pros__actions{position:relative;flex:0 1 auto;display:flex;flex-direction:column;gap:13px;align-items:stretch;min-width:240px;}
.btn-contact{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 26px;border-radius:999px;background:#fff;color:#143a2c;font-weight:600;font-size:15.5px;transition:transform .18s ease,box-shadow .18s ease;}
.btn-contact:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.26);}
.pros__note{font-size:13px;line-height:1.5;color:rgba(255,255,255,.6);text-align:center;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--deep-c);color:#fff;padding:clamp(48px,6vw,72px) 24px 30px;}
.footer__top{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between;align-items:flex-start;}
.footer__brand{flex:1 1 320px;min-width:280px;}
.footer__brand img{height:32px;width:auto;margin-bottom:18px;}
.footer__tagline{font-size:15px;line-height:1.6;color:rgba(255,255,255,.7);max-width:38ch;margin-bottom:22px;}
.footer__socials{display:flex;gap:12px;}
.icon-btn{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.85);transition:background .2s ease,border-color .2s ease,color .2s ease;}
.icon-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;}
.footer__renascor-label{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:14px;}
.renascor-link{display:inline-flex;align-items:center;gap:14px;}
.renascor-link:hover{opacity:.85;}
.renascor-link img{height:46px;width:46px;border-radius:50%;background:#fff;padding:3px;}
.renascor-link .name{display:block;font-size:15px;font-weight:600;color:#fff;}
.renascor-link .url{display:block;font-size:13.5px;color:var(--accent);margin-top:2px;}
.footer__bottom{margin-top:clamp(36px,5vw,52px);padding-top:22px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:rgba(255,255,255,.55);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:760px){
  .cards{grid-template-columns:1fr;}
  .audience{grid-template-columns:1fr;}
  .hero{min-height:0;}
}
