/* ============================================================
   CRUCIANI ADVISORY — Conseils / Articles
   Feuille de style partagée (hub + articles). Marine & Or.
   Header + footer alignés sur la page d'accueil.
   ============================================================ */
:root{
  --paper:#F5F1E8;
  --paper-2:#ECE6D8;
  --navy:#192440;
  --navy-2:#222F54;
  --navy-deep:#111A30;
  --gold:#C49D5F;
  --gold-light:#DCC399;
  --gold-deep:#7E6030;
  --line:rgba(25,36,64,.16);
  --line-light:rgba(245,241,232,.18);
  --ff-display:"Fraunces",Georgia,serif;
  --ff-body:"Hanken Grotesk",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-body);
  background:var(--paper);
  color:var(--navy);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--navy);color:var(--gold-light)}
img{display:block;max-width:100%}
a{color:inherit}

/* ============================================================
   HEADER (identique à l'accueil, en état "marine" permanent
   puisqu'il n'y a pas de hero derrière)
   ============================================================ */
#header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,5vw,64px);
  background:rgba(14,22,40,.82);
  backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);
  box-shadow:0 12px 36px rgba(8,13,26,.34);
}
#header::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(196,157,95,.42) 22%,rgba(196,157,95,.42) 78%,transparent);
}
.logo{
  font-family:var(--ff-display);font-weight:600;font-size:1.18rem;letter-spacing:.02em;
  text-decoration:none;color:var(--paper);display:flex;align-items:center;gap:13px;
}
.logo img{height:40px;width:auto;filter:brightness(0) invert(1)}
.logo em{font-style:italic;font-weight:400;color:var(--gold)}
nav.main{display:flex;gap:34px;align-items:center}
nav.main a{
  text-decoration:none;font-size:.8rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;position:relative;padding:4px 0;
}
nav.main a:not(.btn){color:rgba(245,241,232,.78);transition:color .3s var(--ease)}
nav.main a:not(.btn):hover{color:var(--paper)}
nav.main a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1.5px;background:var(--gold);
  transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease);
}
nav.main a:not(.btn):hover::after{transform:scaleX(1);transform-origin:left}

/* ---- hamburger ---- */
.nav-toggle{
  display:none;width:46px;height:46px;border:none;background:none;cursor:pointer;
  position:relative;z-index:201;color:var(--paper);margin-right:-10px;
}
.nav-toggle span{
  position:absolute;left:11px;right:11px;height:2px;background:currentColor;border-radius:2px;
  transition:transform .45s var(--ease),opacity .25s var(--ease);
}
.nav-toggle span:nth-child(1){top:17px}
.nav-toggle span:nth-child(2){top:23px}
.nav-toggle span:nth-child(3){top:29px}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---- menu plein écran ---- */
.mobile-menu{
  position:fixed;inset:0;z-index:200;
  background:linear-gradient(158deg,var(--navy) 0%,var(--navy-deep) 100%);
  display:flex;flex-direction:column;justify-content:center;
  padding:120px clamp(28px,8vw,56px) calc(44px + env(safe-area-inset-bottom));
  visibility:hidden;
  clip-path:circle(0% at calc(100% - 46px) 46px);
  transition:clip-path .6s var(--ease),visibility .6s var(--ease);
}
body.menu-open .mobile-menu{visibility:visible;clip-path:circle(150% at calc(100% - 46px) 46px)}
.mobile-menu .m-nav{display:flex;flex-direction:column}
.mobile-menu a.m-link{
  font-family:var(--ff-display);font-size:clamp(2rem,8.5vw,2.9rem);font-weight:400;letter-spacing:-.01em;
  color:var(--paper);text-decoration:none;padding:18px 0;line-height:1.05;
  border-bottom:1px solid rgba(245,241,232,.12);
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  opacity:0;transform:translateY(24px);
  transition:color .3s var(--ease),opacity .5s var(--ease),transform .5s var(--ease);
}
.mobile-menu a.m-link .chev{font-size:1.4rem;color:var(--gold);opacity:0;transform:translateX(-8px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.mobile-menu a.m-link:active{color:var(--gold)}
.mobile-menu a.m-link:active .chev{opacity:1;transform:none}
body.menu-open .mobile-menu a.m-link{opacity:1;transform:none}
body.menu-open .mobile-menu a.m-link:nth-child(1){transition-delay:.14s}
body.menu-open .mobile-menu a.m-link:nth-child(2){transition-delay:.2s}
body.menu-open .mobile-menu a.m-link:nth-child(3){transition-delay:.26s}
body.menu-open .mobile-menu a.m-link:nth-child(4){transition-delay:.32s}
body.menu-open .mobile-menu a.m-link:nth-child(5){transition-delay:.38s}
.mobile-menu .m-cta{
  margin-top:38px;opacity:0;transform:translateY(24px);
  transition:opacity .5s var(--ease) .4s,transform .5s var(--ease) .4s;
}
body.menu-open .mobile-menu .m-cta{opacity:1;transform:none}
.mobile-menu .m-cta .btn{width:100%;justify-content:center;padding:20px}
.mobile-menu .m-foot{
  margin-top:30px;font-size:.82rem;color:rgba(245,241,232,.5);
  opacity:0;transition:opacity .5s var(--ease) .5s;
}
body.menu-open .mobile-menu .m-foot{opacity:1}
body.menu-open{overflow:hidden}
@media(max-width:900px){
  nav.main{display:none}
  .nav-toggle{display:block}
}
@media(min-width:901px){.mobile-menu{display:none}}

/* ---- buttons (identiques à l'accueil) ---- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--ff-body);font-weight:700;font-size:.85rem;
  letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
  padding:17px 30px;border-radius:60px;border:1.5px solid var(--navy);
  color:var(--navy);background:transparent;cursor:pointer;
  transition:all .35s var(--ease);
}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--gold);border-color:var(--gold);color:var(--navy-deep)}
.btn-primary:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:var(--paper);transform:translateY(-2px);box-shadow:0 12px 30px rgba(196,157,95,.35)}
.btn-light{border-color:rgba(245,241,232,.7);color:var(--paper)}
.btn-light:hover{background:var(--paper);color:var(--navy);transform:translateY(-2px)}
#header .btn{padding:11px 22px;font-size:.74rem}

/* ============================================================
   CONTENU
   ============================================================ */
main{padding-top:86px}
.wrap{max-width:760px;margin:0 auto;padding:0 clamp(20px,5vw,32px)}
.breadcrumb{
  font-size:.82rem;letter-spacing:.02em;color:rgba(25,36,64,.6);
  padding-top:clamp(26px,4vw,40px);
}
.breadcrumb a{color:var(--gold-deep);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb span{margin:0 8px;opacity:.5}

.eyebrow{
  display:inline-block;font-size:.74rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);
  margin-bottom:18px;
}

/* ---- article header ---- */
.article-head{padding:clamp(18px,3vw,26px) 0 clamp(28px,4vw,40px)}
.article-head h1{
  font-family:var(--ff-display);font-weight:400;
  font-size:clamp(2rem,5vw,3.1rem);line-height:1.08;
  letter-spacing:-.01em;color:var(--navy-deep);
}
.article-meta{
  display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;
  margin-top:22px;font-size:.88rem;color:rgba(25,36,64,.62);
}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--gold)}
.lead{
  font-size:clamp(1.12rem,2.4vw,1.32rem);line-height:1.55;
  color:var(--navy-2);margin-top:26px;font-weight:400;
}

/* ---- prose ---- */
.prose{padding-bottom:clamp(36px,6vw,64px)}
.prose h2{
  font-family:var(--ff-display);font-weight:500;
  font-size:clamp(1.45rem,3vw,1.95rem);line-height:1.15;
  color:var(--navy-deep);margin:clamp(38px,5vw,54px) 0 16px;
  letter-spacing:-.005em;
}
.prose h3{
  font-family:var(--ff-display);font-weight:500;
  font-size:1.22rem;color:var(--navy-deep);margin:30px 0 12px;
}
.prose p{margin:0 0 20px;color:rgba(25,36,64,.86)}
.prose a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:2px}
.prose ul,.prose ol{margin:0 0 22px;padding-left:1.3em;color:rgba(25,36,64,.86)}
.prose li{margin-bottom:9px}
.prose li::marker{color:var(--gold-deep)}
.prose strong{color:var(--navy-deep);font-weight:700}
.prose blockquote{
  margin:30px 0;padding:4px 0 4px 24px;
  border-left:2px solid var(--gold);
  font-family:var(--ff-display);font-style:italic;font-size:1.2rem;
  line-height:1.5;color:var(--navy-2);
}

/* ---- callout ---- */
.callout{
  margin:30px 0;padding:24px 26px;border-radius:14px;
  background:var(--paper-2);border:1px solid var(--line);
}
.callout p{margin:0;color:rgba(25,36,64,.84)}
.callout strong{color:var(--gold-deep)}

/* ---- CTA block ---- */
.cta-block{
  margin:clamp(40px,6vw,68px) 0 0;
  padding:clamp(34px,5vw,52px) clamp(26px,5vw,48px);
  border-radius:20px;
  background:linear-gradient(160deg,var(--navy-2),var(--navy-deep));
  color:var(--paper);text-align:center;
  position:relative;overflow:hidden;
}
.cta-block::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% -10%,rgba(196,157,95,.22),transparent 60%);
}
.cta-block>*{position:relative}
.cta-block h2{
  font-family:var(--ff-display);font-weight:400;
  font-size:clamp(1.55rem,3.4vw,2.1rem);line-height:1.15;color:var(--paper);
  margin-bottom:14px;
}
.cta-block p{color:rgba(245,241,232,.78);max-width:46ch;margin:0 auto 26px}

/* ---- article cards (hub) ---- */
.hub-head{padding:clamp(30px,5vw,52px) 0 clamp(24px,4vw,40px);max-width:680px}
.hub-head h1{
  font-family:var(--ff-display);font-weight:400;
  font-size:clamp(2.1rem,5.4vw,3.4rem);line-height:1.06;
  color:var(--navy-deep);letter-spacing:-.01em;margin-top:6px;
}
.hub-head p{font-size:clamp(1.05rem,2.2vw,1.22rem);color:var(--navy-2);margin-top:20px}
.card-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  padding-bottom:clamp(40px,6vw,72px);
}
.post-card{
  display:block;text-decoration:none;color:inherit;
  padding:clamp(24px,3vw,32px);border-radius:16px;
  background:#fff;border:1px solid var(--line);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.post-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px -24px rgba(25,36,64,.4);
  border-color:rgba(196,157,95,.5);
}
.post-card .eyebrow{margin-bottom:12px}
.post-card h2{
  font-family:var(--ff-display);font-weight:500;
  font-size:clamp(1.3rem,2.6vw,1.65rem);line-height:1.18;
  color:var(--navy-deep);
}
.post-card p{margin-top:12px;color:rgba(25,36,64,.74);font-size:1rem}
.post-card .read{
  margin-top:18px;display:inline-flex;align-items:center;gap:7px;
  font-weight:600;font-size:.9rem;color:var(--gold-deep);
}
.post-card.soon{opacity:.62;pointer-events:none}
.post-card.soon .read{color:rgba(25,36,64,.5)}

/* ============================================================
   FOOTER (identique à l'accueil : crème + mentions légales)
   ============================================================ */
footer{background:var(--paper);border-top:1px solid var(--line);margin-top:clamp(40px,6vw,72px)}
.foot{
  max-width:1240px;margin:0 auto;padding:64px clamp(20px,5vw,64px) 48px;
  display:flex;flex-direction:column;align-items:center;gap:28px;text-align:center;
  font-size:.85rem;color:rgba(25,36,64,.65);
}
.foot img{height:110px;width:auto}
.foot nav{display:flex;gap:26px;flex-wrap:wrap;justify-content:center}
.foot nav a{
  color:var(--navy);text-decoration:none;font-size:.78rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;transition:color .3s;
}
.foot nav a:hover{color:var(--gold-deep)}
.foot-legal{width:100%;max-width:760px;margin-top:4px;border-top:1px solid var(--line);padding-top:22px}
.foot-legal summary{
  cursor:pointer;list-style:none;font-size:.74rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:8px;
  transition:color .3s var(--ease);
}
.foot-legal summary::-webkit-details-marker{display:none}
.foot-legal summary::after{content:"+";font-size:1.1em;color:var(--gold-deep);transition:transform .3s var(--ease)}
.foot-legal[open] summary::after{transform:rotate(45deg)}
.foot-legal summary:hover{color:var(--gold-deep)}
.foot-legal .fl-body{margin-top:18px;text-align:left;font-size:.82rem;line-height:1.65;color:rgba(25,36,64,.7)}
.foot-legal .fl-body p{margin-bottom:10px}
.foot-legal .fl-body strong{color:var(--navy);font-weight:600}
.foot-legal .fl-body a{color:var(--gold-deep);text-decoration:none}
.foot-legal .fl-body a:hover{text-decoration:underline}

/* ---- focus ---- */
a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:2px solid var(--gold-deep);outline-offset:3px;border-radius:5px;
}
#header :focus-visible,.nav-toggle:focus-visible,.mobile-menu :focus-visible,
.cta-block :focus-visible{outline-color:var(--gold-light)}

@media(prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto}
}
