/* ============================================================
   MOLLEAU — Shared site styles
   Used across home, produit, articles, contact, legal pages
   Requires colors_and_type.css to be loaded first
   ============================================================ */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--fg);background:#fff;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.container{max-width:1200px;margin:0 auto;padding:0 32px}

.eyebrow{font-family:var(--font-tagline);font-size:12px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--molleau-blue)}
.eyebrow.on-blue{color:#fff;opacity:0.9}

.h1{font-family:var(--font-display);font-weight:800;font-size:clamp(44px,5.4vw,72px);line-height:1.05;letter-spacing:-0.02em;margin:0;text-wrap:balance}
.h2{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,3.6vw,52px);line-height:1.1;letter-spacing:-0.02em;margin:0;text-wrap:balance}
.h3{font-family:var(--font-display);font-weight:700;font-size:24px;line-height:1.2;margin:0}
.lead{font-family:var(--font-body);font-size:19px;line-height:1.6;color:var(--fg-soft);text-wrap:pretty}

.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:14px 26px;font-family:var(--font-display);font-weight:700;font-size:15px;cursor:pointer;border:0;transition:all 220ms cubic-bezier(0.16,1,0.3,1);text-decoration:none}
.btn-primary{background:var(--molleau-blue);color:#fff}
.btn-primary:hover{background:var(--molleau-blue-deep);transform:translateY(-1px)}
.btn-secondary{background:#fff;color:var(--molleau-blue);border:1.5px solid var(--molleau-blue);padding:12.5px 24.5px}
.btn-secondary:hover{background:var(--molleau-blue);color:#fff}
.btn-warm{background:var(--sun);color:var(--ink)}
.btn-warm:hover{background:#d99800;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--fg);padding:12.5px 22px}
.btn-ghost:hover{color:var(--molleau-blue)}

/* Header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,0.85);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color 220ms}
.hdr.scrolled{border-color:var(--border-soft)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 32px;max-width:1200px;margin:0 auto;gap:24px}
.hdr-logo{height:36px;width:auto;display:block}
.hdr-nav{display:flex;gap:28px;align-items:center}
.hdr-link{font-size:14px;font-weight:500;color:var(--fg);position:relative;padding:6px 12px;border-radius:8px;transition:background 180ms,color 180ms}
.hdr-link:hover{color:var(--molleau-blue)}
.hdr-link.active{color:var(--molleau-blue);background:rgba(14,79,147,0.10);box-shadow:inset 0 0 0 1px rgba(14,79,147,0.25)}
.hdr-link.active::after{display:none}
.hdr-mobile-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
@media(max-width:880px){
  .hdr-nav{display:none}
  .hdr-mobile-toggle{display:block}
  .hdr-nav.open{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:20px;gap:16px;box-shadow:0 8px 24px rgba(14,79,147,0.1)}
}

/* Section base */
.section{padding:104px 0}
.section-soft{background:var(--paper-soft)}
.section-head{text-align:center;max-width:740px;margin:0 auto 56px}
.section-head .eyebrow{margin-bottom:14px;display:block}
.section-head .h2{margin-bottom:16px}

/* Sub-page hero (smaller than home hero) */
.sub-hero{padding:96px 0 56px;background:linear-gradient(180deg,#F6F9FC 0%,#fff 100%);position:relative;overflow:hidden}
.sub-hero .blob{position:absolute;width:340px;height:340px;border-radius:65% 60% 70% 55% / 60% 55% 65% 50%;background:radial-gradient(circle,#36B2FF 0%,transparent 70%);opacity:0.18;top:-120px;right:-100px;z-index:0;pointer-events:none}
.sub-hero-inner{position:relative;z-index:1;max-width:880px}
.sub-hero .eyebrow{display:block;margin-bottom:14px}
.sub-hero h1{font-family:var(--font-display);font-weight:900;font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-0.025em;margin:0 0 20px;text-wrap:balance;color:var(--fg)}
.sub-hero h1 .accent{color:var(--molleau-blue);position:relative;display:inline-block}
.sub-hero h1 .accent::after{content:"";position:absolute;bottom:6px;left:0;right:0;height:14px;background:var(--sun);opacity:0.35;z-index:-1;border-radius:8px}
.sub-hero .lead{max-width:680px;margin:0 0 28px}
.sub-hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.sub-hero-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--fg-soft);margin-top:24px;align-items:center}
.sub-hero-meta span{display:inline-flex;gap:6px;align-items:center}
.sub-hero-meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--molleau-blue);display:inline-block}

/* Articles preview (home) */
.h-articles{padding:96px 0;background:var(--paper-soft);border-top:1px solid var(--border-soft)}
.h-articles-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;flex-wrap:wrap;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 32px}
.h-articles-head .eyebrow{display:block;margin-bottom:10px}
.h-articles-head h2{margin:0}
.h-articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto;padding:0 32px}
@media(max-width:980px){.h-articles-grid{grid-template-columns:1fr}}
.h-article{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border-soft);border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;transition:all 220ms cubic-bezier(0.16,1,0.3,1)}
.h-article:hover{transform:translateY(-3px);box-shadow:0 18px 36px rgba(14,79,147,0.12);border-color:var(--molleau-blue)}
.h-article-media{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.h-article-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(14,79,147,0.20))}
.play-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:999px;background:rgba(255,255,255,0.96);box-shadow:0 12px 32px rgba(0,0,0,0.35);display:grid;place-items:center;z-index:2;transition:transform 220ms cubic-bezier(0.16,1,0.3,1)}
.play-badge::after{content:"";width:0;height:0;border-left:18px solid var(--molleau-blue);border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.h-article:hover .play-badge{transform:translate(-50%,-50%) scale(1.08)}
.h-article-badge{position:absolute;top:14px;left:14px;background:#fff;color:var(--molleau-blue);font-family:var(--font-tagline);font-weight:700;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;padding:6px 12px;border-radius:8px;z-index:1}
.h-article-badge.warm{color:#7a5800;background:rgba(255,247,221,0.96)}
.h-article-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:8px;flex:1}
.h-article-meta{font-family:var(--font-tagline);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);font-weight:700;display:flex;gap:14px}
.h-article h3{font-family:var(--font-display);font-weight:800;font-size:18px;line-height:1.25;letter-spacing:-0.01em;margin:2px 0 0;color:var(--fg);text-wrap:balance}
.h-article p{font-size:14px;line-height:1.55;color:var(--fg-soft);margin:0}
.h-article-lk{margin-top:auto;padding-top:8px;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--molleau-blue);display:inline-flex;align-items:center;gap:5px}

/* CTA section (used everywhere) */
.cta{position:relative;padding:96px 0;background:var(--molleau-blue);color:#fff;overflow:hidden}
.cta-bg{position:absolute;inset:0;background-image:url(assets/img-water-1.jpg);background-size:cover;background-position:center;opacity:0.18}
.cta-inner{position:relative;text-align:center;max-width:860px;margin:0 auto;padding:0 32px}
.cta h2{color:#fff;margin-bottom:16px}
.cta p{font-size:18px;line-height:1.6;opacity:0.9;max-width:580px;margin:0 auto 36px}
.cta-tags{display:inline-flex;gap:24px;font-size:13px;opacity:0.85;flex-wrap:wrap;justify-content:center}
.cta-tags span{display:inline-flex;gap:6px;align-items:center}
.cta-tags span::before{content:"✓";font-weight:700}

/* Footer */
.ftr{background:#fff;border-top:1px solid var(--border);padding:64px 0 32px}
.ftr-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media(max-width:880px){.ftr-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:600px){.ftr-grid{grid-template-columns:1fr;gap:28px}}
.ftr-brand{display:flex;flex-direction:column;gap:4px;max-width:320px}
.ftr-brand img{height:auto;width:150px;align-self:flex-start;margin:0 0 12px}
.ftr-brand p{font-size:14px;line-height:1.6;color:var(--fg-soft);margin:0}
.ftr-solar{margin-top:18px;display:flex;flex-direction:column;gap:7px;align-items:flex-start}
.ftr-solar .lbl{font-family:var(--font-tagline);font-size:9.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute)}
.ftr-solar img{width:200px;max-width:100%;height:auto;margin:0;opacity:0.92;transition:opacity 200ms ease}
.ftr-solar a:hover img{opacity:1}
.ftr-col-title{font-family:var(--font-display);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:0.12em;margin:0 0 14px}
.ftr-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ftr-col a{font-size:14px;color:var(--fg-soft)}
.ftr-col a:hover{color:var(--molleau-blue)}
.ftr-bottom{border-top:1px solid var(--border-soft);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--fg-mute)}
.ftr-tagline{font-family:var(--font-tagline);letter-spacing:0.22em;text-transform:uppercase}

/* Legal page reading layout */
.legal-hero{padding:96px 0 32px;background:var(--paper-soft);border-bottom:1px solid var(--border-soft)}
.legal-hero .crumbs{margin-bottom:18px}
.legal-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(32px,4vw,46px);line-height:1.1;letter-spacing:-0.02em;margin:0 0 10px;color:var(--fg)}
.legal-hero .updated{font-family:var(--font-tagline);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute)}
.legal-body{max-width:760px;margin:0 auto;padding:56px 0 96px;font-size:16px;line-height:1.7;color:var(--fg)}
.legal-body h2{font-family:var(--font-display);font-weight:800;font-size:24px;line-height:1.2;letter-spacing:-0.01em;margin:42px 0 14px;color:var(--fg);padding-top:8px;border-top:1px solid var(--border-soft)}
.legal-body h2:first-of-type{border-top:0;padding-top:0;margin-top:0}
.legal-body h3{font-family:var(--font-display);font-weight:700;font-size:18px;margin:24px 0 8px;color:var(--fg)}
.legal-body p{margin:0 0 14px}
.legal-body ul,.legal-body ol{margin:0 0 18px;padding-left:22px;display:flex;flex-direction:column;gap:6px}
.legal-body strong{color:var(--fg);font-weight:700}
.legal-body a{color:var(--molleau-blue);font-weight:600}
.legal-body .todo{background:#FFF7E2;border:1px dashed #ECAA00;color:#7a5800;padding:3px 8px;border-radius:6px;font-family:var(--font-display);font-weight:700;font-size:13px;display:inline-block;letter-spacing:0.01em}
.legal-toc{background:#fff;border:1px solid var(--border-soft);border-radius:18px;padding:22px 26px;margin-bottom:36px}
.legal-toc-title{font-family:var(--font-tagline);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute);margin:0 0 12px}
.legal-toc ol{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:6px;font-size:14.5px}
.legal-toc a{color:var(--molleau-blue);font-weight:500;border-bottom:0}
.legal-table-wrap{margin:0 0 22px;border:1px solid var(--border-soft);border-radius:14px;overflow:hidden;background:#fff}
.legal-table{width:100%;border-collapse:collapse;font-size:14.5px}
.legal-table thead th{background:#F6F9FC;color:var(--fg);font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:0.04em;text-transform:uppercase;text-align:left;padding:12px 16px;border-bottom:1px solid #DDE5EE}
.legal-table tbody td{padding:12px 16px;border-bottom:1px solid #ECF1F6;vertical-align:top;line-height:1.55}
.legal-table tbody tr:last-child td{border-bottom:0}
.legal-table tbody td:first-child{font-weight:600;color:var(--fg)}
.legal-callout{background:#F6F9FC;border:1px solid #DDE5EE;border-left:3px solid var(--molleau-blue);border-radius:10px;padding:12px 16px;font-size:14.5px;color:var(--fg);margin:0 0 22px}
.legal-signature{margin-top:28px;padding-top:18px;border-top:1px solid var(--border-soft);font-size:14px;color:var(--fg-mute);font-style:italic}

/* Article reading layout */
.art-hero{padding:88px 0 32px;background:linear-gradient(180deg,#F6F9FC 0%,#fff 100%);position:relative;overflow:hidden}
.art-hero .blob{position:absolute;width:340px;height:340px;border-radius:65% 60% 70% 55% / 60% 55% 65% 50%;background:radial-gradient(circle,#36B2FF 0%,transparent 70%);opacity:0.16;top:-120px;right:-100px;pointer-events:none}
.art-hero-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.art-hero .crumbs{margin-bottom:18px}
.art-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.art-tag{font-family:var(--font-tagline);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--molleau-blue);background:rgba(14,79,147,0.08);padding:6px 12px;border-radius:8px}
.art-tag.warm{color:#7a5800;background:rgba(236,170,0,0.18)}
.art-hero h1{font-family:var(--font-display);font-weight:900;font-size:clamp(34px,4.4vw,52px);line-height:1.1;letter-spacing:-0.02em;margin:0 0 18px;color:var(--fg);text-wrap:balance}
.art-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13.5px;color:var(--fg-soft);font-weight:500}
.art-meta span{display:inline-flex;gap:6px;align-items:center}
.art-meta span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--molleau-blue);display:inline-block}
.art-cover{margin:36px 0 0;border-radius:24px;overflow:hidden;aspect-ratio:16/9;background:#EAF1F8}
.art-cover img{width:100%;height:100%;object-fit:cover}

.art-body{max-width:760px;margin:0 auto;padding:56px 0 64px;font-size:17px;line-height:1.72;color:var(--fg);text-wrap:pretty}
.art-body p{margin:0 0 22px}
.art-body p:first-child{font-size:20px;line-height:1.6;color:var(--fg);font-weight:500}
.art-body p:first-child::first-letter{font-family:var(--font-display);font-weight:800;font-size:62px;line-height:0.9;float:left;padding:6px 12px 0 0;color:var(--molleau-blue);letter-spacing:-0.02em}
.art-body h2{font-family:var(--font-display);font-weight:800;font-size:28px;line-height:1.2;letter-spacing:-0.015em;margin:42px 0 14px;color:var(--fg)}
.art-body h3{font-family:var(--font-display);font-weight:700;font-size:21px;line-height:1.25;margin:32px 0 10px;color:var(--fg)}
.art-body ul,.art-body ol{margin:0 0 22px;padding-left:20px;display:flex;flex-direction:column;gap:6px}
.art-body strong{color:var(--fg);font-weight:700}
.art-body em{font-style:italic}
.art-body a{color:var(--molleau-blue);font-weight:600;border-bottom:1px solid rgba(14,79,147,0.3);transition:border-color 180ms}
.art-body a:hover{border-bottom-color:var(--molleau-blue)}
.art-body blockquote{margin:32px 0;padding:24px 28px;background:var(--paper-soft);border-left:4px solid var(--molleau-blue);border-radius:0 14px 14px 0;font-family:var(--font-display);font-weight:600;font-size:19px;line-height:1.5;color:var(--molleau-blue);letter-spacing:-0.005em}
.art-body blockquote p:first-child::first-letter{font-size:inherit;float:none;padding:0;color:inherit;font-family:inherit;font-weight:inherit}
.art-body blockquote p{margin:0;font-size:inherit;line-height:inherit;color:inherit;font-weight:inherit}
.art-body .callout{margin:32px 0;padding:22px 26px;background:linear-gradient(135deg,rgba(54,178,255,0.06),rgba(236,170,0,0.06));border:1px solid var(--border-soft);border-radius:16px;font-size:15.5px;line-height:1.6}
.art-body .callout strong{display:block;margin-bottom:6px;color:var(--molleau-blue);font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:0.04em;text-transform:uppercase}
.art-body .callout p{margin:0}

.art-bottom-cta{max-width:760px;margin:0 auto;padding:24px 0 48px}
.art-bottom-cta-box{background:linear-gradient(135deg,var(--molleau-blue),var(--molleau-blue-soft));color:#fff;border-radius:24px;padding:36px 32px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.art-bottom-cta-box h3{font-family:var(--font-display);font-weight:800;font-size:22px;margin:0 0 4px;letter-spacing:-0.015em}
.art-bottom-cta-box p{margin:0;opacity:0.88;font-size:14.5px}
.art-bottom-cta-box .btn-warm{flex-shrink:0}

.art-related{padding:48px 0 96px;background:var(--paper-soft);border-top:1px solid var(--border-soft)}
.art-related-head{text-align:center;margin-bottom:32px}
.art-related-head .eyebrow{display:block;margin-bottom:10px}
.art-related-head h2{font-family:var(--font-display);font-weight:800;font-size:24px;margin:0;letter-spacing:-0.015em}
.art-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:880px;margin:0 auto}
@media(max-width:560px){.art-related-grid{grid-template-columns:1fr}}
.art-related-grid .post{background:#fff;border:1px solid var(--border-soft);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:all 220ms cubic-bezier(0.16,1,0.3,1)}
.art-related-grid .post:hover{border-color:var(--molleau-blue);box-shadow:0 12px 28px rgba(14,79,147,0.10);transform:translateY(-2px)}
/* Article share bar */
.art-share{max-width:680px;margin:44px auto 0;padding:22px 0 0;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.art-share-label{font-family:var(--font-tagline);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute)}
.art-share-btns{display:flex;gap:10px;flex-wrap:wrap}
.art-share-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:#fff;border:1px solid var(--border-soft);color:var(--fg-soft);cursor:pointer;transition:all 180ms cubic-bezier(0.16,1,0.3,1);position:relative}
.art-share-btn:hover{border-color:var(--molleau-blue);color:var(--molleau-blue);transform:translateY(-2px);box-shadow:0 8px 18px rgba(14,79,147,0.10)}
.art-share-btn svg{width:18px;height:18px}
.art-share-btn.copied{border-color:#1F8A5B;color:#1F8A5B}
.art-share-btn .tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--fg);color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 160ms}
.art-share-btn.copied .tip{opacity:1}
.art-related-grid .media{aspect-ratio:16/9;background-size:cover;background-position:center}
.art-related-grid .body{padding:18px 20px;display:flex;flex-direction:column;gap:6px}
.art-related-grid .meta{font-family:var(--font-tagline);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);font-weight:600}
.art-related-grid h3{font-family:var(--font-display);font-weight:700;font-size:16px;line-height:1.3;margin:2px 0 0;color:var(--fg)}
.art-related-grid .lk{margin-top:6px;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--molleau-blue)}

/* Breadcrumbs */
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-mute);margin-bottom:18px}
.crumbs a{color:var(--fg-soft)}
.crumbs a:hover{color:var(--molleau-blue)}
.crumbs .sep{opacity:0.5}
.crumbs .current{color:var(--fg)}
