/* ========================================================
   ALTIORA — Design system partagé
   ======================================================== */
:root{
  --ink:#0C1712;
  --pine:#1B4332;
  --pine-deep:#0F2A1F;
  --gold:#C9A84C;
  --gold-deep:#A9843A;
  --gold-soft:#E4CE8C;
  --cream:#FAF8F3;
  --cream-dim:#F1ECE0;
  --stone:#7C7867;
  --ink-text:#3a3930;
  --line: rgba(201,168,76,0.28);
  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'Inter', -apple-system, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
}
.eyebrow.on-dark{ color:var(--gold-soft); }

h1,h2,h3{ font-family:var(--serif); font-weight:600; letter-spacing:-0.01em; }

.wrap{ max-width:1180px; margin:0 auto; padding:0 32px; }
@media (max-width:640px){ .wrap{padding:0 22px;} }

a:focus-visible, button:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

/* ---------- LOGO MARK (image détourée du fichier officiel) ---------- */
.brand-mark{ object-fit:contain; }

/* ---------- NAV ---------- */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  background:rgba(12,23,18,0);
  backdrop-filter:blur(0px);
  transition:background .4s ease, backdrop-filter .4s ease, box-shadow .4s ease, padding .3s ease;
  padding:22px 0;
}
header.nav.scrolled, header.nav.solid{
  background:rgba(12,23,18,0.94);
  backdrop-filter:blur(10px);
  padding:14px 0;
  box-shadow:0 1px 0 var(--line);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark{ width:30px; height:30px; flex-shrink:0; }
.brand-name{ font-family:var(--serif); font-weight:600; letter-spacing:.14em; color:var(--cream); font-size:1.05rem; }
.brand-tag{ display:block; font-family:var(--sans); font-size:.55rem; letter-spacing:.18em; color:var(--gold-soft); text-transform:uppercase; margin-top:1px; opacity:.8; }
nav.links{ display:flex; align-items:center; gap:26px; }
nav.links a{ color:var(--cream); font-size:.84rem; letter-spacing:.03em; opacity:.82; transition:opacity .2s, color .2s; position:relative; padding:4px 0; }
nav.links a:hover{ opacity:1; color:var(--gold-soft); }
nav.links a.current{ opacity:1; color:var(--gold-soft); }
nav.links a.current::after{ content:''; position:absolute; left:0; right:0; bottom:-4px; height:1px; background:var(--gold); }
.nav-cta{ border:1px solid var(--gold); color:var(--gold-soft) !important; padding:9px 20px; border-radius:2px; font-size:.78rem !important; letter-spacing:.06em; opacity:1 !important; transition:background .25s, color .25s; }
.nav-cta:hover{ background:var(--gold); color:var(--ink) !important; }

.nav-toggle{ display:none; background:none; border:1px solid var(--line); border-radius:2px; width:42px; height:38px; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.nav-toggle span{ width:18px; height:1px; background:var(--cream); display:block; }

/* dropdown (Partenaires) */
.nav-drop{ position:relative; }
.nav-drop > span{ cursor:pointer; display:inline-flex; align-items:center; gap:6px; color:var(--cream); font-size:.84rem; letter-spacing:.03em; opacity:.82; padding:4px 0; }
.nav-drop:hover > span, .nav-drop:focus-within > span{ opacity:1; color:var(--gold-soft); }
.nav-drop .chev{ font-size:.55rem; opacity:.7; transition:transform .2s; margin-top:1px; }
.nav-drop:hover .chev, .nav-drop:focus-within .chev{ transform:rotate(180deg); }
.nav-drop-panel{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(-6px); padding-top:16px;
  opacity:0; visibility:hidden; transition:opacity .2s, transform .2s, visibility .2s; z-index:50;
}
.nav-drop:hover .nav-drop-panel, .nav-drop:focus-within .nav-drop-panel{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav-drop-panel-inner{ background:rgba(12,23,18,0.97); border:1px solid var(--line); min-width:250px; padding:8px; box-shadow:0 20px 40px -10px rgba(0,0,0,.5); }
.nav-drop-panel a{ display:block; padding:12px 14px; font-size:.82rem; color:var(--cream); opacity:.85; border-radius:2px; white-space:nowrap; }
.nav-drop-panel a:hover{ background:rgba(201,168,76,.1); opacity:1; color:var(--gold-soft); }
.nav-drop-panel a .sub{ display:block; font-size:.72rem; color:var(--stone); margin-top:3px; opacity:.9; }

.mobile-menu .sub-heading{ font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-top:22px; }
.mobile-menu a.sub-link{ font-family:var(--sans); font-size:1rem; padding:14px 0 14px 14px; border-bottom:1px dashed var(--line); }

/* ---------- FAQ ACCORDION ---------- */
.faq{ margin-top:10px; }
.faq details{ border-top:1px solid var(--line); padding:22px 0; }
.faq details:last-child{ border-bottom:1px solid var(--line); }
.faq summary{ cursor:pointer; font-family:var(--serif); font-size:1.12rem; color:var(--pine-deep); list-style:none; display:flex; justify-content:space-between; align-items:center; gap:20px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:'+'; font-family:var(--sans); font-size:1.5rem; font-weight:300; color:var(--gold); transition:transform .25s; flex-shrink:0; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq .faq-a{ margin-top:14px; color:#54523f; font-size:.94rem; max-width:640px; line-height:1.65; }
.dark .faq summary, .pine-bg .faq summary{ color:var(--cream); }
.dark .faq .faq-a, .pine-bg .faq .faq-a{ color:rgba(250,248,243,.65); }

/* ---------- CONTACT FORM ---------- */
.form-grid{ display:grid; gap:18px; max-width:600px; margin-top:34px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.field label{ display:block; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-bottom:9px; }
.field input, .field select, .field textarea{
  width:100%; background:rgba(250,248,243,.03); border:1px solid var(--line); color:var(--cream);
  padding:13px 14px; font-family:var(--sans); font-size:.92rem; border-radius:2px;
}
.field select option{ background:var(--ink); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--gold); }
.field textarea{ resize:vertical; min-height:130px; font-family:var(--sans); }
.form-note{ font-size:.78rem; color:rgba(250,248,243,.5); margin-top:4px; }

/* ---------- INFO CARDS (contact) ---------- */
.info-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:10px; }
@media (max-width:860px){ .info-row{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .info-row{ grid-template-columns:1fr; } }
.info-cell{ background:var(--cream); padding:30px 26px; }
.info-cell .eyebrow{ display:block; margin-bottom:10px; }
.info-cell p{ font-size:.95rem; color:var(--pine-deep); font-weight:500; }
.info-cell a{ font-size:.95rem; color:var(--pine-deep); font-weight:500; }
.info-cell a:hover{ color:var(--gold-deep); }
.mobile-menu{
  display:none; position:fixed; inset:0; z-index:190; background:var(--ink);
  padding:110px 32px 40px; flex-direction:column; gap:0;
}
.mobile-menu.open{ display:flex; }
.mobile-menu a{ color:var(--cream); font-family:var(--serif); font-size:1.5rem; padding:18px 0; border-bottom:1px solid var(--line); }
.mobile-menu a.current{ color:var(--gold-soft); }
@media (max-width:1040px){
  nav.links{ display:none; }
  .nav-toggle{ display:flex; }
}

/* ---------- HERO (grande, accueil) ---------- */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center;
  background:
    radial-gradient(1100px 640px at 82% -10%, rgba(201,168,76,0.16), transparent 60%),
    radial-gradient(900px 500px at 10% 110%, rgba(27,67,50,0.55), transparent 60%),
    linear-gradient(180deg, #0B120E 0%, var(--ink) 55%, #0A0F0C 100%);
  overflow:hidden; padding:150px 0 90px;
}
/* ---------- SUBHERO (pages intérieures) ---------- */
.subhero{
  position:relative; display:flex; align-items:flex-end; min-height:56vh;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(201,168,76,0.15), transparent 60%),
    linear-gradient(180deg, #0B120E 0%, var(--ink) 70%, #0A0F0C 100%);
  overflow:hidden; padding:170px 0 74px;
}
.hero-grid{
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(201,168,76,0.045) 1px, transparent 1px), linear-gradient(90deg, rgba(201,168,76,0.045) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(700px 500px at 70% 30%, black, transparent 75%);
}
.hero-inner{ position:relative; z-index:2; width:100%; }
.hero-eyebrow{ display:flex; align-items:center; gap:14px; margin-bottom:26px; }
.hero-eyebrow .rule{ width:44px; height:1px; background:var(--gold); }
.hero h1{ color:var(--cream); font-size:clamp(2.2rem, 5.4vw, 4.4rem); line-height:1.06; max-width:920px; font-weight:600; }
.subhero h1{ font-size:clamp(2rem, 4.4vw, 3.4rem); }
.hero h1 em, .subhero h1 em{
  font-style:italic; font-weight:500;
  background:linear-gradient(100deg, var(--gold-soft), var(--gold) 60%, #a9843a);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero p.lede{ margin-top:26px; max-width:580px; color:rgba(250,248,243,0.72); font-size:1.08rem; font-weight:300; }
.hero-actions{ display:flex; gap:18px; margin-top:44px; flex-wrap:wrap; align-items:center; }
.btn-primary{
  background:linear-gradient(135deg, var(--gold-soft), var(--gold)); color:var(--ink); padding:15px 30px; font-weight:600; font-size:.86rem;
  letter-spacing:.03em; border-radius:2px; display:inline-flex; align-items:center; gap:10px;
  transition:transform .25s ease, box-shadow .25s ease; box-shadow:0 8px 30px -10px rgba(201,168,76,.5);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 36px -10px rgba(201,168,76,.65); }
.btn-ghost{ color:var(--cream); padding:15px 8px; font-size:.86rem; letter-spacing:.03em; border-bottom:1px solid rgba(250,248,243,.35); transition:border-color .25s, color .25s; }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-soft); }

.hero-steps{ margin-top:88px; display:flex; gap:0; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:26px; }
.hero-step{ flex:1; min-width:130px; padding-right:24px; }
.hero-step .num{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:.95rem; }
.hero-step .label{ color:var(--cream); font-size:.86rem; letter-spacing:.02em; margin-top:4px; }

.traj{ position:absolute; right:6%; top:16%; width:min(38vw, 460px); height:min(38vw,460px); z-index:1; opacity:.9; }
@media (max-width:980px){ .traj{ display:none; } }
.traj svg{ width:100%; height:100%; }
.traj-bar{ transform-origin:bottom; animation:rise 1.6s cubic-bezier(.2,.8,.2,1) both; }
.traj-line{ stroke-dasharray:600; stroke-dashoffset:600; animation:draw 2.2s 0.3s cubic-bezier(.2,.8,.2,1) forwards; }
.traj-dot{ opacity:0; animation:fadeIn .6s 2.2s forwards; }
@keyframes rise{ from{ transform:scaleY(0);} to{ transform:scaleY(1);} }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@keyframes fadeIn{ to{ opacity:1; } }

/* ---------- SECTION SCAFFOLD ---------- */
section{ padding:120px 0; position:relative; }
@media (max-width:768px){ section{ padding:76px 0; } }
.section-head{ max-width:660px; margin-bottom:64px; }
.section-head h2{ font-size:clamp(1.9rem,3.4vw,2.7rem); margin-top:16px; color:var(--pine-deep); }
.section-head p{ margin-top:18px; color:#4b4a42; font-size:1.02rem; max-width:560px; }
.dark{ background:var(--ink); color:var(--cream); }
.dark .section-head h2{ color:var(--cream); }
.dark .section-head p{ color:rgba(250,248,243,.68); }
.pine-bg{ background:linear-gradient(160deg, var(--pine-deep), var(--pine)); color:var(--cream); }
.pine-bg .section-head h2{ color:var(--cream); }
.pine-bg .section-head p{ color:rgba(250,248,243,.75); }
.dim{ background:var(--cream-dim); }

/* ---------- DEFI / LISTES NUMÉROTÉES ---------- */
.defi-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
@media (max-width:860px){ .defi-grid{ grid-template-columns:1fr; } }
.defi-list li{ display:flex; gap:18px; padding:20px 0; border-top:1px solid var(--line); font-size:1.02rem; color:#3a3930; }
.defi-list li:last-child{ border-bottom:1px solid var(--line); }
.defi-list .tag{ font-family:var(--serif); font-style:italic; color:var(--gold); flex-shrink:0; width:26px; }
.defi-result{ background:var(--pine-deep); color:var(--cream); padding:38px 34px; border-radius:2px; margin-top:8px; }
.defi-result .eyebrow{ color:var(--gold-soft); }
.defi-result p{ font-family:var(--serif); font-size:1.35rem; margin-top:14px; line-height:1.35; font-style:italic;}

/* ---------- QUOTE ---------- */
.quote-block{ text-align:center; padding:100px 0; }
.quote-block blockquote{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.5rem, 3.4vw, 2.3rem); line-height:1.4; max-width:840px; margin:0 auto; color:var(--cream); }
.quote-block blockquote .accent{ color:var(--gold-soft); font-style:normal; }
.quote-block cite{ display:block; margin-top:32px; font-style:normal; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }

/* ---------- GRID DE CELLULES (dimensions, cartes) ---------- */
.cell-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:10px; }
.cell-grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.cell-grid.cols-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:920px){ .cell-grid{ grid-template-columns:repeat(2,1fr) !important; } }
@media (max-width:560px){ .cell-grid{ grid-template-columns:1fr !important; } }
.cell{ background:var(--cream); padding:32px 28px; min-height:190px; display:flex; flex-direction:column; justify-content:space-between; transition:background .3s ease; }
.cell:hover{ background:var(--cream-dim); }
.cell .cell-name{ font-family:var(--serif); font-style:italic; font-size:1.12rem; color:var(--pine-deep); }
.cell .cell-eyebrow{ font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; display:block; }
.cell p{ font-size:.87rem; color:#5c5a4f; margin-top:14px; }
.dark .cell{ background:#111f18; }
.dark .cell:hover{ background:#152a20; }
.dark .cell .cell-name{ color:var(--cream); }
.dark .cell p{ color:rgba(250,248,243,.65); }

/* ---------- TIMELINE (parcours, feuille de route) ---------- */
.timeline{ position:relative; margin-top:20px; }
.timeline::before{ content:''; position:absolute; left:29px; top:8px; bottom:8px; width:1px; background:linear-gradient(180deg, var(--gold), transparent); }
@media (max-width:640px){ .timeline::before{ left:19px; } }
.t-item{ display:flex; gap:30px; padding:26px 0; position:relative; }
.t-num{ width:60px; height:60px; border-radius:50%; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-family:var(--serif); font-style:italic; color:var(--gold-soft); font-size:1.1rem; background:var(--ink); position:relative; z-index:2; }
@media (max-width:640px){ .t-num{ width:40px; height:40px; font-size:.85rem; } }
.t-content h3{ font-size:1.2rem; color:var(--cream); font-weight:600; }
.t-content p{ color:rgba(250,248,243,.65); margin-top:6px; max-width:480px; font-size:.94rem; }

/* horizontal phase timeline (feuille de route) */
.phase-row{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:20px; }
@media (max-width:920px){ .phase-row{ grid-template-columns:1fr; } }
.phase{ background:var(--ink); padding:30px 24px; }
.phase .p-num{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.6rem; }
.phase h3{ font-size:1.02rem; color:var(--cream); margin-top:10px; }
.phase .p-time{ font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-soft); margin-top:6px; display:block; }
.phase ul{ margin-top:14px; }
.phase li{ font-size:.8rem; color:rgba(250,248,243,.6); padding:5px 0; padding-left:14px; position:relative; }
.phase li::before{ content:'—'; position:absolute; left:0; color:var(--gold); }

/* ---------- OFFRES / cards 3 col ---------- */
.offres{ display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--line); border:1px solid var(--line); }
@media (max-width:860px){ .offres{ grid-template-columns:1fr; } }
.offre{ background:var(--cream); padding:44px 36px; }
.offre .idx{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:.95rem; }
.offre h3{ font-size:1.4rem; margin-top:16px; color:var(--pine-deep); }
.offre p{ margin-top:14px; color:#54523f; font-size:.94rem; }

/* ---------- LISTE PRINCIPE / POURQUOI (2 col) ---------- */
.why-list{ display:flex; flex-direction:column; }
.why-item{ display:grid; grid-template-columns:240px 1fr; gap:36px; padding:30px 0; border-top:1px solid var(--line); align-items:baseline; }
.why-item:last-child{ border-bottom:1px solid var(--line); }
@media (max-width:700px){ .why-item{ grid-template-columns:1fr; gap:8px; } }
.why-item h3{ font-size:1.05rem; color:var(--pine-deep); font-weight:600; font-family:var(--sans); letter-spacing:.02em; }
.why-item p{ color:#54523f; font-size:.95rem; }
.dark .why-item{ border-color:var(--line); }
.dark .why-item h3{ color:var(--cream); }
.dark .why-item p{ color:rgba(250,248,243,.65); }

/* ---------- MANIFESTE ---------- */
.manifeste{ display:grid; grid-template-columns:1fr 1.15fr; gap:70px; align-items:center; }
@media (max-width:900px){ .manifeste{ grid-template-columns:1fr; gap:40px; } }
.manifeste-visual{ aspect-ratio:3/4; border:1px solid var(--line); position:relative; background:linear-gradient(160deg, var(--pine-deep), #08120D); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.manifeste-visual .mark{ width:42%; }
.manifeste-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(400px 300px at 30% 20%, rgba(201,168,76,.12), transparent 60%); }
.manifeste blockquote{ font-family:var(--serif); font-size:1.5rem; line-height:1.45; color:var(--pine-deep); font-style:italic; }
.manifeste .sig{ margin-top:28px; font-family:var(--serif); font-size:1.3rem; color:var(--pine); }
.manifeste .role{ font-size:.78rem; color:var(--stone); letter-spacing:.06em; text-transform:uppercase; margin-top:4px; }

/* ---------- TAG CLOUD (types de partenaires) ---------- */
.tag-cloud{ display:flex; flex-wrap:wrap; gap:12px; margin-top:14px; }
.tag-pill{ border:1px solid var(--line); padding:11px 20px; font-size:.86rem; color:var(--cream); border-radius:2px; background:rgba(201,168,76,0.04); transition:background .25s, border-color .25s; }
.tag-pill:hover{ background:rgba(201,168,76,.12); border-color:var(--gold); }

/* ---------- FLOW (comment fonctionne la collaboration) ---------- */
.flow{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; margin-top:20px; counter-reset:flow; }
@media (max-width:920px){ .flow{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .flow{ grid-template-columns:1fr; } }
.flow-step{ border:1px solid var(--line); padding:22px 18px; background:var(--cream); }
.flow-step .f-num{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.3rem; }
.flow-step h4{ font-size:.92rem; margin-top:10px; color:var(--pine-deep); font-family:var(--sans); font-weight:600; }
.flow-step p{ font-size:.8rem; color:#5c5a4f; margin-top:8px; }

/* ---------- APPORT / RECOIT (partenaires institutionnels) ---------- */
.apport-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:36px; }
@media (max-width:820px){ .apport-grid{ grid-template-columns:1fr; } }
.apport-card{ background:var(--cream); padding:30px 30px 34px; }
.apport-card h3{ font-size:1.2rem; color:var(--pine-deep); margin-bottom:18px; display:flex; align-items:center; gap:10px; }
.apport-card h3 .dot{ width:8px; height:8px; border-radius:50%; background:var(--gold); display:inline-block; }
.apport-cols{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:520px){ .apport-cols{ grid-template-columns:1fr; } }
.apport-cols h4{ font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:10px; font-family:var(--sans); font-weight:700; }
.apport-cols ul li{ font-size:.85rem; color:#54523f; padding:6px 0; padding-left:14px; position:relative; }
.apport-cols ul li::before{ content:'·'; position:absolute; left:0; color:var(--gold); font-weight:700; }

/* ---------- TABLE (modèle économique qui finance quoi) ---------- */
.finance-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:20px; }
@media (max-width:920px){ .finance-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .finance-grid{ grid-template-columns:1fr; } }
.finance-cell{ background:var(--ink); padding:26px 22px; }
.finance-cell .f-eyebrow{ font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.finance-cell h4{ font-size:1rem; color:var(--cream); margin-top:10px; font-family:var(--sans); font-weight:600; }
.finance-cell p{ font-size:.8rem; color:rgba(250,248,243,.6); margin-top:10px; }

/* ---------- CTA final ---------- */
.cta-final{ background:linear-gradient(160deg, var(--pine-deep), var(--ink)); color:var(--cream); text-align:center; padding:140px 0; position:relative; overflow:hidden; }
.cta-final::before{ content:''; position:absolute; inset:0; background:radial-gradient(700px 400px at 50% 0%, rgba(201,168,76,.14), transparent 65%); }
.cta-final-inner{ position:relative; z-index:2; }
.cta-final h2{ font-size:clamp(2rem,4.5vw,3.2rem); color:var(--cream); max-width:740px; margin:18px auto 0; }
.cta-final p{ margin-top:20px; color:rgba(250,248,243,.68); max-width:540px; margin-left:auto; margin-right:auto; }
.cta-final .hero-actions{ justify-content:center; margin-top:44px; }

/* ---------- LIENS RAPIDES (accueil → autres pages) ---------- */
.hub-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:10px; }
@media (max-width:860px){ .hub-grid{ grid-template-columns:1fr; } }
.hub-card{ background:var(--cream); padding:40px 34px; display:flex; flex-direction:column; justify-content:space-between; min-height:230px; transition:background .3s; }
.hub-card:hover{ background:var(--cream-dim); }
.hub-card .eyebrow{ margin-bottom:4px; }
.hub-card h3{ font-size:1.5rem; color:var(--pine-deep); margin-top:8px; }
.hub-card p{ color:#54523f; font-size:.9rem; margin-top:14px; }
.hub-card .go{ margin-top:24px; font-size:.8rem; letter-spacing:.06em; color:var(--gold-deep); display:inline-flex; align-items:center; gap:8px; font-weight:600; }

/* ---------- CONTACT STRIP / FOOTER ---------- */
.contact-strip{ background:var(--cream-dim); padding:56px 0; border-top:1px solid var(--line); }
.contact-grid{ display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between; align-items:center; }
.contact-item{ display:flex; align-items:center; gap:12px; font-size:.92rem; color:var(--pine-deep); }
.contact-item .ic{ color:var(--gold); }

footer.site-footer{ background:var(--ink); color:rgba(250,248,243,.55); padding:60px 0 34px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--line); }
@media (max-width:800px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-col h4{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; font-family:var(--sans); font-weight:700; }
.footer-col a, .footer-col p{ display:block; font-size:.86rem; color:rgba(250,248,243,.62); padding:5px 0; }
.footer-col a:hover{ color:var(--gold-soft); }
.footer-brand .brand-name{ color:var(--cream); font-size:1.15rem; }
.footer-brand p{ margin-top:14px; max-width:280px; color:rgba(250,248,243,.55); font-size:.86rem; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; padding-top:26px; font-size:.78rem; }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }


/* ---------- ALTIORA PLATFORM PROTOTYPE ---------- */
.portal-shell{ background:linear-gradient(180deg,var(--cream) 0%,var(--cream-dim) 100%); }
.portal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media(max-width:900px){ .portal-grid{ grid-template-columns:1fr; } }
.portal-card{ background:var(--cream); padding:34px; min-height:260px; display:flex; flex-direction:column; justify-content:space-between; }
.portal-card h3{ font-size:1.55rem; color:var(--pine-deep); }
.portal-card p{ margin-top:14px; color:#54523f; font-size:.92rem; }
.portal-card .mini{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; margin-bottom:14px; }
.dashboard{ display:grid; grid-template-columns:280px 1fr; gap:28px; align-items:start; }
@media(max-width:900px){ .dashboard{ grid-template-columns:1fr; } }
.side-panel{ background:var(--ink); color:var(--cream); padding:28px; border:1px solid var(--line); position:sticky; top:100px; }
.side-panel h3{ color:var(--cream); font-size:1.4rem; }
.side-panel a{ display:block; color:rgba(250,248,243,.72); padding:12px 0; border-bottom:1px solid var(--line); font-size:.9rem; }
.side-panel a:hover{ color:var(--gold-soft); }
.dash-main{ display:grid; gap:22px; }
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media(max-width:760px){ .stat-grid{ grid-template-columns:repeat(2,1fr); } }
.stat{ background:var(--cream); padding:24px; }
.stat strong{ display:block; color:var(--pine-deep); font-size:2rem; font-family:var(--serif); }
.stat span{ font-size:.75rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); }
.panel{ background:var(--cream); border:1px solid var(--line); padding:30px; }
.panel h3{ color:var(--pine-deep); font-size:1.45rem; }
.progress-list{ display:grid; gap:14px; margin-top:22px; }
.progress-row{ display:grid; grid-template-columns:160px 1fr 52px; gap:18px; align-items:center; }
@media(max-width:620px){ .progress-row{ grid-template-columns:1fr; gap:8px; } }
.progress-bar{ height:10px; background:#e7e0cf; border-radius:999px; overflow:hidden; }
.progress-bar i{ display:block; height:100%; background:linear-gradient(90deg,var(--gold),var(--pine)); border-radius:999px; }
.resource-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:24px; }
@media(max-width:900px){ .resource-grid{ grid-template-columns:1fr; } }
.resource-card{ border:1px solid var(--line); padding:22px; background:#fffdf7; }
.resource-card .type{ font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; }
.resource-card h4{ color:var(--pine-deep); margin-top:10px; }
.badge{ display:inline-flex; border:1px solid var(--gold); color:var(--gold-deep); padding:6px 10px; font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; margin-top:16px; }
.assessment-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:28px; }
@media(max-width:900px){ .assessment-grid{ grid-template-columns:1fr; } }
.question{ padding:18px 0; border-bottom:1px solid var(--line); }
.question label{ display:block; color:var(--pine-deep); font-weight:600; }
.question input[type=range]{ width:100%; margin-top:12px; accent-color:#b88723; }
.score-box{ background:linear-gradient(160deg,var(--pine-deep),var(--ink)); color:var(--cream); padding:34px; border:1px solid var(--line); position:sticky; top:100px; }
.score-big{ font-family:var(--serif); font-size:4rem; color:var(--gold-soft); line-height:1; }
.reco-list li{ padding:12px 0; border-bottom:1px solid rgba(250,248,243,.14); color:rgba(250,248,243,.72); }
.lock-note{ background:rgba(201,168,76,.08); border:1px solid var(--line); padding:18px; color:#54523f; margin-top:20px; }

/* ---------- EXTENSIONS PLATEFORME ALTIORA V1 ---------- */
.login-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
@media(max-width:760px){.login-grid{grid-template-columns:1fr;}}
.login-panel{background:var(--cream);padding:36px;min-height:260px;display:flex;flex-direction:column;justify-content:space-between;}
.login-panel h3{font-size:1.55rem;color:var(--pine-deep);margin-top:10px;}
.login-panel p{color:#54523f;margin:14px 0 24px;}
.check-list{margin-top:16px;display:grid;gap:8px;}
.check-list li{position:relative;padding-left:22px;color:#54523f;font-size:.9rem;}
.check-list li::before{content:'✓';position:absolute;left:0;color:var(--gold-deep);font-weight:800;}
.payment-box,.member-hero-card{border:1px solid var(--line);background:#fffdf7;padding:30px;display:flex;justify-content:space-between;gap:24px;align-items:center;margin-top:28px;}
@media(max-width:720px){.payment-box,.member-hero-card{display:block;}}
.member-hero-card{margin-top:0;}
.member-hero-card h2{color:var(--pine-deep);font-size:2rem;margin-top:8px;}
.member-hero-card p{color:#54523f;margin-top:10px;}
.member-score{background:var(--ink);color:var(--cream);border:1px solid var(--line);padding:22px 30px;text-align:center;min-width:150px;}
.member-score strong{display:block;font-family:var(--serif);font-size:3rem;color:var(--gold-soft);line-height:1;}
.member-score span{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(250,248,243,.7);}
.priority-list{display:grid;gap:12px;margin-top:22px;}
.priority-list div{border:1px solid var(--line);background:#fffdf7;padding:18px;}
.priority-list b{display:block;color:var(--pine-deep);}
.priority-list span{display:block;color:#54523f;font-size:.9rem;margin-top:5px;}
.doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px;}
@media(max-width:680px){.doc-grid{grid-template-columns:repeat(2,1fr);}}
.doc-grid span{border:1px solid var(--line);background:#fffdf7;color:var(--pine-deep);padding:14px;text-align:center;font-size:.86rem;font-weight:600;}
.orientation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px;}
@media(max-width:680px){.orientation-grid{grid-template-columns:1fr;}}
.orientation-grid div{border:1px solid var(--line);background:#fffdf7;padding:18px;}
.orientation-grid b{display:block;color:var(--pine-deep);}
.orientation-grid span{display:block;color:#54523f;font-size:.88rem;margin-top:5px;}
.demo-note{width:100%;min-height:140px;margin-top:18px;border:1px solid var(--line);background:#fffdf7;color:var(--ink);padding:16px;font-family:var(--sans);}
.small-note{font-size:.8rem;color:#77725e;margin-top:8px;}
.table-card{overflow:auto;border:1px solid var(--line);margin-top:18px;background:#fffdf7;}
table{width:100%;border-collapse:collapse;min-width:520px;} th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:.9rem;} th{color:var(--gold-deep);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;}td{color:#54523f;}
.numbered{counter-reset:item;display:grid;gap:12px;margin-top:18px;}
.numbered li{counter-increment:item;list-style:none;border:1px solid var(--line);background:#fffdf7;padding:16px 16px 16px 52px;position:relative;color:#54523f;}
.numbered li::before{content:counter(item);position:absolute;left:16px;top:14px;width:24px;height:24px;border-radius:50%;background:var(--gold);color:var(--ink);display:grid;place-items:center;font-weight:800;font-size:.8rem;}
.dark-card{background:var(--ink)!important;border-color:var(--line)!important;}
.dark-card h4{color:var(--cream)!important;}.dark-card p{color:rgba(250,248,243,.62)!important;}
.report-page{background:#fffdf7;border:1px solid var(--line);padding:44px;box-shadow:0 20px 70px -50px rgba(0,0,0,.45);}
.report-head{display:flex;justify-content:space-between;gap:30px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:24px;}
@media(max-width:700px){.report-head{display:block;}.report-score{margin-top:20px;}}
.report-head h2{color:var(--pine-deep);font-size:2.3rem;margin-top:8px;}.report-head p{color:#54523f;margin-top:8px;}
.report-score{width:120px;height:120px;background:linear-gradient(160deg,var(--pine-deep),var(--ink));color:var(--gold-soft);font-family:var(--serif);font-size:3.2rem;display:grid;place-items:center;border:1px solid var(--line);}
.score-bars{display:grid;gap:14px;margin:32px 0;}.score-bars div{display:grid;grid-template-columns:150px 1fr 42px;gap:12px;align-items:center;}.score-bars span{color:var(--pine-deep);font-weight:600;}.score-bars i{height:10px;background:linear-gradient(90deg,var(--gold),var(--pine));width:var(--w);display:block;border-radius:999px;box-shadow:0 0 0 999px #ebe4d2 inset;}.score-bars b{color:var(--gold-deep);}
.report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;border-top:1px solid var(--line);padding-top:28px;}@media(max-width:800px){.report-grid{grid-template-columns:1fr;}}
.report-grid h3{color:var(--pine-deep);font-size:1.25rem;}
.range-value{float:right;color:var(--gold-deep);font-weight:700;}
