:root{
  --bg:        #FDFBF6;
  --card:      #FFFFFF;
  --ink:       #14181A;
  --ink-2:     #4A4F4D;
  --ink-3:     #80847F;
  --rule:      #E6E2D8;
  --rule-2:    #F0EBDD;

  --green:     #3D8E6F;
  --green-soft:#E5F0EA;

  --t1: #32B8C9;
  --t2: #B1CA34;
  --t3: #FECD1A;
  --t4: #E95D0F;
  --t5: #E53075;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
body{
  font-family:'Work Sans',-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.55;font-weight:400;
}
a{color:var(--green);text-decoration:none;}
a:hover{text-decoration:underline;}
button{font:inherit;}
hr{border:none;border-top:1px solid var(--rule);}

.wrap{max-width:760px;margin:0 auto;padding:0 24px;}

/* Header */
header.top{
  border-bottom:1px solid var(--rule);
  padding:14px 0;background:var(--bg);
  position:sticky;top:0;z-index:30;
}
.top-inner{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.top-brand{font-weight:600;letter-spacing:-.005em;}
.top-brand span{color:var(--ink-3);font-weight:400;margin-left:6px;}
.top-link{color:var(--ink-2);font-size:13px;}
.top-link:hover{color:var(--ink);}

/* Intro */
section.intro{padding:56px 0 32px;}
.intro-tag{
  font-size:12px;font-weight:500;letter-spacing:.04em;
  color:var(--green);margin-bottom:16px;text-transform:uppercase;
}
.intro h1{
  font-size:32px;font-weight:600;line-height:1.18;letter-spacing:-.018em;
  margin-bottom:18px;max-width:18ch;
}
.intro p{
  font-size:16.5px;color:var(--ink-2);line-height:1.6;
  max-width:60ch;margin-bottom:14px;
}
.intro p strong{color:var(--ink);font-weight:600;}

/* Grille picker */
.pick{margin-top:36px;display:grid;gap:10px;}
.pick-h{
  font-size:13px;font-weight:600;color:var(--ink-2);
  letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px;
}
.pick-card{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;
  align-items:center;padding:18px 22px;
  background:var(--card);border:1px solid var(--rule);
  border-radius:8px;cursor:pointer;text-align:left;
  font-family:inherit;color:inherit;width:100%;
  transition:border-color .15s, transform .15s, box-shadow .15s;
}
.pick-card:hover{
  border-color:var(--ink);transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,0,0,.04);
}
.pick-card .stripe{width:4px;align-self:stretch;border-radius:2px;}
.pick-card .body{display:flex;flex-direction:column;gap:3px;min-width:0;}
.pick-card .num{
  font-size:11px;font-weight:600;color:var(--ink-3);
  letter-spacing:.06em;text-transform:uppercase;
}
.pick-card .name{font-size:17px;font-weight:600;letter-spacing:-.012em;line-height:1.3;}
.pick-card .meta{font-size:13px;color:var(--ink-2);margin-top:2px;}
.pick-card .arrow{
  color:var(--ink-3);font-size:18px;flex-shrink:0;
  transition:transform .15s, color .15s;
}
.pick-card:hover .arrow{color:var(--ink);transform:translateX(3px);}
.pick-source{font-size:12.5px;margin-top:6px;color:var(--ink-3);}
.pick-source a{color:var(--ink-2);}
.pick-source a:hover{color:var(--ink);}

/* Sources block */
.sources{
  margin-top:40px;padding:22px 24px;
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
}
.sources-h{
  font-size:11.5px;font-weight:600;color:var(--ink-3);
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px;
}
.sources-list{list-style:none;padding:0;font-size:13.5px;line-height:1.7;}
.sources-list li{padding:3px 0;}
.sources-list li::before{content:"·";margin-right:8px;color:var(--ink-3);}
.sources-list a{color:var(--ink-2);}
.sources-list a:hover{color:var(--ink);}
.sources-list .src-meta{font-size:12px;color:var(--ink-3);margin-left:4px;}

.test-source{margin-top:8px;font-size:13px;}
.test-source a{color:var(--ink-2);}
.test-source a:hover{color:var(--ink);}

.intro-foot{
  margin-top:32px;padding-top:20px;
  border-top:1px solid var(--rule);
  font-size:13px;color:var(--ink-3);
  display:flex;flex-wrap:wrap;gap:18px;
}
.intro-foot b{color:var(--ink-2);font-weight:500;}

/* Test view */
.test{padding:24px 0 0;}
.test-h{
  margin:24px 0 8px;
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;
}
.test-h-title{
  font-size:11.5px;font-weight:600;color:var(--ink-3);
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;
}
.test-h h2{font-size:24px;font-weight:600;line-height:1.2;letter-spacing:-.014em;}
.test-h-back{
  background:transparent;border:1px solid var(--rule);
  font-size:13px;padding:7px 14px;border-radius:6px;
  color:var(--ink-2);cursor:pointer;font-family:inherit;
}
.test-h-back:hover{border-color:var(--ink);color:var(--ink);}
.test-desc{
  font-size:14px;color:var(--ink-2);max-width:60ch;line-height:1.55;
  padding-bottom:16px;border-bottom:1px solid var(--rule);
}

/* Tier section */
.tier-block{margin-top:32px;}
.tier-head{
  display:flex;align-items:center;gap:12px;
  padding:10px 0 12px;border-bottom:2px solid;margin-bottom:4px;
}
.tier-head[data-t="1"]{border-color:var(--t1);}
.tier-head[data-t="2"]{border-color:var(--t2);}
.tier-head[data-t="3"]{border-color:var(--t3);}
.tier-head[data-t="4"]{border-color:var(--t4);}
.tier-head[data-t="5"]{border-color:var(--t5);}
.tier-head-num{
  width:30px;height:30px;border-radius:50%;
  display:grid;place-items:center;
  font-weight:600;font-size:14px;color:#fff;
  flex-shrink:0;font-feature-settings:"tnum";
}
.tier-head[data-t="1"] .tier-head-num{background:var(--t1);}
.tier-head[data-t="2"] .tier-head-num{background:var(--t2);color:#1a2606;}
.tier-head[data-t="3"] .tier-head-num{background:var(--t3);color:#3a2c00;}
.tier-head[data-t="4"] .tier-head-num{background:var(--t4);}
.tier-head[data-t="5"] .tier-head-num{background:var(--t5);}
.tier-head-info{flex:1;min-width:0;}
.tier-head-label{
  font-size:15px;font-weight:600;letter-spacing:-.005em;
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
}
.tier-head-count{
  font-size:12px;color:var(--ink-3);
  font-weight:500;font-feature-settings:"tnum";
}
.tier-head-desc{font-size:12.5px;color:var(--ink-2);margin-top:2px;}

.q{padding:18px 0;border-bottom:1px solid var(--rule-2);}
.q:last-child{border-bottom:none;}
.q-row{
  display:grid;grid-template-columns:32px 1fr;gap:10px;
  margin-bottom:12px;align-items:start;
}
.q-id{
  font-size:13px;font-weight:600;color:var(--ink-3);
  font-feature-settings:"tnum";padding-top:1px;
}
.q-text{
  font-size:15.5px;line-height:1.5;color:var(--ink);
  font-weight:500;letter-spacing:-.003em;
}
.likert{
  display:grid;grid-template-columns:repeat(5,1fr);gap:5px;
  margin-left:42px;
}
@media(max-width:520px){.likert{margin-left:0;}}
.lk-btn{
  padding:10px 4px;border:1px solid var(--rule);
  background:var(--card);border-radius:5px;
  font-size:13.5px;font-weight:500;color:var(--ink);
  cursor:pointer;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1px;
  font-family:inherit;
  transition:border-color .12s, background .12s, color .12s;
}
.lk-btn:hover{border-color:var(--ink);}
.lk-btn.sel{background:var(--ink);color:var(--card);border-color:var(--ink);}
.lk-btn-n{font-size:13.5px;font-weight:600;font-feature-settings:"tnum";}
.lk-btn-l{
  font-size:10px;font-weight:400;color:var(--ink-3);letter-spacing:0;
  display:none;line-height:1.1;
}
.lk-btn.sel .lk-btn-l{color:rgba(255,255,255,.6);}
@media(min-width:600px){.lk-btn-l{display:block;}}

/* Submit */
.submit-bar{
  position:sticky;bottom:0;background:var(--bg);
  border-top:1px solid var(--rule);
  padding:14px 0;margin-top:32px;
  display:flex;align-items:center;gap:16px;
  justify-content:space-between;flex-wrap:wrap;z-index:10;
}
.progress{
  flex:1;min-width:160px;
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:var(--ink-2);font-feature-settings:"tnum";
}
.progress-track{
  flex:1;height:3px;background:var(--rule);
  border-radius:99px;overflow:hidden;
}
.progress-fill{height:100%;background:var(--green);transition:width .4s ease;border-radius:99px;}
.btn{
  padding:11px 22px;border-radius:6px;
  font-size:14px;font-weight:500;
  border:1px solid transparent;
  cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;
  transition:background .15s, color .15s, border-color .15s;
}
.btn-primary{background:var(--ink);color:var(--card);}
.btn-primary:hover{background:var(--green);}
.btn-primary:disabled{background:var(--ink-3);cursor:not-allowed;}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--rule);}
.btn-ghost:hover{border-color:var(--ink);}

/* Result */
.result{padding:48px 0 32px;}
.result-head{
  padding-bottom:20px;margin-bottom:24px;
  border-bottom:2px solid var(--ink);
}
.result-tag{
  font-size:12px;font-weight:500;letter-spacing:.04em;
  text-transform:uppercase;color:var(--green);margin-bottom:8px;
}
.result-h{
  font-size:28px;font-weight:600;line-height:1.18;
  letter-spacing:-.018em;margin-bottom:8px;
}
.result-sub{font-size:14.5px;color:var(--ink-2);line-height:1.55;}
.result-sub b{color:var(--ink);font-weight:600;}

/* Score block */
.score-grid{
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  margin-bottom:32px;align-items:center;
}
@media(max-width:520px){.score-grid{grid-template-columns:1fr;}}
.score-big{display:flex;align-items:baseline;gap:6px;font-feature-settings:"tnum";}
.score-num{font-size:64px;font-weight:600;line-height:1;letter-spacing:-.04em;}
.score-tot{font-size:20px;color:var(--ink-3);font-weight:500;}
.score-info{font-size:14px;color:var(--ink-2);line-height:1.5;}
.tier-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 11px;border-radius:99px;
  font-size:13px;font-weight:600;margin-bottom:6px;
}
.tier-dot{width:8px;height:8px;border-radius:50%;}

/* Per-tier scores */
.tier-scores{
  display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:36px;
}
@media(max-width:600px){.tier-scores{grid-template-columns:repeat(2,1fr);}}
.ts{
  border:1px solid var(--rule);background:var(--card);
  border-radius:6px;padding:12px 14px;
  position:relative;overflow:hidden;
}
.ts-stripe{position:absolute;top:0;left:0;right:0;height:3px;}
.ts-num{
  font-size:11px;color:var(--ink-3);font-weight:600;
  font-feature-settings:"tnum";letter-spacing:.04em;
  text-transform:uppercase;margin-bottom:2px;
}
.ts-label{font-size:12px;color:var(--ink-2);margin-bottom:6px;line-height:1.3;}
.ts-val{font-size:18px;font-weight:600;letter-spacing:-.018em;font-feature-settings:"tnum";}
.ts-val .ts-tot{font-size:12px;color:var(--ink-3);font-weight:500;margin-left:1px;}

/* Sections in result */
.r-block{margin-bottom:36px;}
.r-block:last-child{margin-bottom:0;}
.r-block-h{
  font-size:13px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink-3);
  padding-bottom:8px;margin-bottom:14px;
  border-bottom:1px solid var(--rule);
}
.r-text{font-size:15.5px;line-height:1.65;color:var(--ink-2);max-width:60ch;}
.r-text p{margin-bottom:10px;}
.r-text p:last-child{margin-bottom:0;}
.r-text strong{color:var(--ink);font-weight:600;}

/* Action plan */
.plan{display:grid;gap:0;}
.plan-item{
  padding:12px 0;border-bottom:1px solid var(--rule-2);
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;
}
.plan-item:last-child{border-bottom:none;}
.plan-prio{
  font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:2px 8px;border-radius:99px;white-space:nowrap;
  align-self:start;margin-top:1px;
}
.plan-prio.haute{background:#FCE2EA;color:#A61E4D;}
.plan-prio.moyenne{background:#FFF1D6;color:#8A5800;}
.plan-prio.faible{background:#E5F0EA;color:#1F6B4F;}
.plan-text{color:var(--ink);font-size:14.5px;line-height:1.5;}
.plan-why{color:var(--ink-3);font-size:12.5px;margin-top:4px;line-height:1.45;}

/* Forces / axes */
.fa-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:520px){.fa-grid{grid-template-columns:1fr;}}
.fa-list{list-style:none;padding:0;}
.fa-item{
  font-size:14px;line-height:1.5;
  padding:7px 0;border-bottom:1px solid var(--rule-2);color:var(--ink-2);
}
.fa-item::before{
  content:"";display:inline-block;width:6px;height:6px;
  border-radius:50%;margin-right:8px;vertical-align:1px;
}
.fa-list.str .fa-item::before{background:var(--green);}
.fa-list.imp .fa-item::before{background:var(--t4);}

/* Refs */
.refs-list{
  font-size:13px;color:var(--ink-2);line-height:1.85;
  list-style:none;padding:0;columns:2;column-gap:24px;
}
@media(max-width:520px){.refs-list{columns:1;}}
.refs-list li{break-inside:avoid;}

.r-actions{display:flex;gap:8px;margin-top:32px;flex-wrap:wrap;}

/* Footer */
footer{
  margin-top:64px;padding:32px 0 40px;
  border-top:1px solid var(--rule);
  font-size:13px;color:var(--ink-3);background:var(--card);
}
.foot-inner{
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start;
}
@media(max-width:560px){.foot-inner{grid-template-columns:1fr;}}
.foot-cap{font-size:12.5px;line-height:1.55;color:var(--ink-3);max-width:48ch;}
.foot-cap a{color:var(--ink-2);text-decoration:underline;text-decoration-color:var(--rule);text-underline-offset:2px;}
.foot-cap a:hover{color:var(--ink);text-decoration-color:var(--ink);}
.foot-filomea{
  text-align:right;font-size:13px;line-height:1.55;
  display:flex;flex-direction:column;gap:2px;
}
@media(max-width:560px){.foot-filomea{text-align:left;}}
.foot-filomea-line{color:var(--ink-2);font-weight:500;}
.foot-filomea-line .heart{color:#E53075;display:inline-block;animation:beat 2.4s ease-in-out infinite;}
@keyframes beat{0%,40%,80%,100%{transform:scale(1);}20%{transform:scale(1.18);}60%{transform:scale(1.08);}}
.foot-filomea-line a{
  color:var(--ink);font-weight:600;
  border-bottom:1.5px solid var(--green);padding-bottom:1px;
}
.foot-filomea-line a:hover{border-bottom-color:var(--ink);text-decoration:none;}
.foot-filomea-tag{font-size:11.5px;color:var(--ink-3);}

/* Filomea hint on intro */
.filomea-hint{margin-top:14px;font-size:12.5px;color:var(--ink-3);}
.filomea-hint a{
  color:var(--ink-2);font-weight:500;
  border-bottom:1px solid var(--green);
}
.filomea-hint a:hover{color:var(--ink);}

/* Loading */
.loading{padding:60px 0;text-align:center;color:var(--ink-3);font-size:14px;}
.spin{
  width:24px;height:24px;border-radius:50%;
  border:2px solid var(--rule);border-top-color:var(--ink);
  animation:s 0.8s linear infinite;margin:0 auto 14px;
}
@keyframes s{to{transform:rotate(360deg);}}

/* JS-driven view toggling */
.test.hidden,.result.hidden{display:none;}
.intro.hidden{display:none;}

