/* PJ · Cap — layout & composants */
.app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
@media(max-width:800px){.app{grid-template-columns:1fr}}

/* Sidebar */
.side{background:var(--surface);border-right:.5px solid var(--border);padding:16px 12px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:2px}
@media(max-width:800px){.side{position:static;height:auto;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:.5px solid var(--border)}}
.brand{display:flex;flex-direction:column;padding:6px 10px 14px}
.brand b{font-size:16px;font-weight:720;letter-spacing:-.01em}
.brand small{font-size:9.5px;color:var(--text3);letter-spacing:.03em}
.navlink{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-size:13px;font-weight:550;color:var(--text2);text-decoration:none;white-space:nowrap;border:none;background:none;width:100%;text-align:left;transition:.12s}
.navlink:hover{background:var(--surface2)}
.navlink.on{background:var(--text);color:var(--bg)}
.navlink .ic{font-size:15px;width:20px;text-align:center}
.side-foot{margin-top:auto;padding:8px 10px;font-size:10px;color:var(--text3)}
@media(max-width:800px){.side-foot,.brand small{display:none}}

/* Content */
.content{padding:26px 30px 80px;max-width:1080px}
@media(max-width:800px){.content{padding:18px 16px 60px}}
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.page-title{font-size:22px;font-weight:680;letter-spacing:-.02em}
.page-q{font-size:12.5px;color:var(--text3);margin-top:1px}
.top-tools{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tbtn{font-size:12px;font-weight:600;color:var(--text2);background:var(--surface);border:.5px solid var(--border);border-radius:8px;padding:7px 12px;transition:.15s}
.tbtn:hover{background:var(--text);color:var(--bg);border-color:var(--text)}
.status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.online{background:var(--green)} .dot.offline{background:var(--text3)}

/* Profile pill */
.prof-sel{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2);background:var(--surface);border:.5px solid var(--border);border-radius:8px;padding:5px 8px}
.prof-sel select{border:none;background:none;font-weight:650;font-size:12px;color:var(--text);outline:none;cursor:pointer}

/* Cards */
.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.card + .card{margin-top:14px}
.card h3{font-size:14px;font-weight:650;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.card .sub{font-size:11.5px;color:var(--text3)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:720px){.grid2,.grid3{grid-template-columns:1fr}}

/* Hero patrimoine */
.wealth{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}
.wealth .big{font-size:38px;font-weight:720;letter-spacing:-.03em;line-height:1}
.wealth .perf{font-size:15px;font-weight:650}
.alloc-bar{display:flex;height:14px;border-radius:8px;overflow:hidden;margin:14px 0 8px;background:var(--surface3)}
.alloc-bar div{transition:width .4s}
.alloc-legend{display:flex;flex-wrap:wrap;gap:6px 16px}
.leg{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text2)}
.leg .d{width:9px;height:9px;border-radius:3px}
.leg b{color:var(--text);font-variant-numeric:tabular-nums}

/* Alerts */
.alert{display:flex;gap:10px;align-items:flex-start;padding:11px 13px;border-radius:10px;background:var(--surface2);border:.5px solid var(--border);margin-bottom:8px}
.alert .ab{font-size:15px;line-height:1.2}
.alert .at{font-size:12.5px;font-weight:600}
.alert .ad{font-size:11.5px;color:var(--text2);margin-top:2px;line-height:1.45}

/* Recommandations */
.reco{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-top:.5px solid var(--border)}
.reco:first-of-type{border-top:none}
.reco-stars{font-size:12px;letter-spacing:1px;color:var(--gold);min-width:64px;white-space:nowrap}
.reco-body{flex:1}
.reco-act{font-size:14.5px;font-weight:680}
.reco-act .amt{color:var(--green)}
.reco-why{font-size:12px;color:var(--text2);margin-top:3px;line-height:1.45}
.reco-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:7px}
.chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:650;padding:2px 9px;border-radius:20px;background:var(--surface3);color:var(--text2);white-space:nowrap}
.chip.green{background:var(--greenbg);color:var(--green)} .chip.blue{background:var(--bluebg);color:var(--blue)}
.chip.amber{background:var(--amberbg);color:var(--amber)} .chip.red{background:var(--redbg);color:var(--red)}
.chip.violet{background:var(--surface3);color:var(--violet)}

/* Tables */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:9.5px;font-weight:650;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:9px 10px;border-bottom:.5px solid var(--border)}
.tbl th:not(:first-child),.tbl td:not(:first-child){text-align:right}
.tbl td{font-size:12.5px;padding:9px 10px;border-bottom:.5px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--surface2)}
.nm{font-weight:600} .cell-sub{font-size:10px;color:var(--text3)}
.eur{font-variant-numeric:tabular-nums;font-weight:600}
.tbl-wrap{overflow-x:auto;border:.5px solid var(--border);border-radius:var(--radius);background:var(--surface)}

/* Metrics */
.metric{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:13px 15px}
.metric .ml{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.metric .mv{font-size:22px;font-weight:700;letter-spacing:-.02em}
.metric .ms{font-size:10px;color:var(--text3);margin-top:2px}

/* News */
.news-item{padding:12px 0;border-top:.5px solid var(--border)}
.news-item:first-child{border-top:none}
.news-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.news-title{font-size:13px;font-weight:600;text-decoration:none;color:var(--text)}
.news-title:hover{color:var(--blue)}
.news-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:5px;align-items:center}
.news-sum{font-size:11.5px;color:var(--text2);margin-top:4px;line-height:1.45}

/* Forms / settings */
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px}
.field input[type=range]{width:100%}
.field .val{font-weight:650}
.seg{display:flex;flex-wrap:wrap;gap:6px}
.seg button{font-size:12px;font-weight:560;color:var(--text2);background:var(--surface);border:.5px solid var(--border);border-radius:8px;padding:7px 12px}
.seg button.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.placeholder{padding:40px;text-align:center;color:var(--text3);font-size:13px}
.placeholder .em{font-size:30px;display:block;margin-bottom:10px}
.note{background:var(--surface2);border-left:3px solid var(--amber);border-radius:8px;padding:10px 13px;font-size:11px;color:var(--text3);line-height:1.5;margin-top:14px}

/* ===== Macro : scénario & signaux ===== */
.scenario{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center}
@media(max-width:600px){.scenario{grid-template-columns:1fr}}
.quad{position:relative;aspect-ratio:1/1;background:var(--surface2);border:.5px solid var(--border);border-radius:10px;overflow:hidden}
.quad .ql{position:absolute;font-size:8px;color:var(--text3);font-weight:600;letter-spacing:.03em}
.quad .cross{position:absolute;background:var(--border)}
.quad .mk{position:absolute;width:14px;height:14px;border-radius:50%;border:3px solid var(--surface);transform:translate(-50%,-50%);box-shadow:0 0 0 2px currentColor;z-index:3}
.scen-label{font-size:16px;font-weight:700;letter-spacing:-.01em}
.scen-syn{font-size:12.5px;color:var(--text2);line-height:1.5;margin-top:6px}
.sig-row{display:grid;grid-template-columns:150px 1fr;gap:12px;align-items:center;padding:9px 0;border-top:.5px solid var(--border)}
.sig-row:first-of-type{border-top:none}
.sig-name{font-size:12.5px;font-weight:600}
.sig-states{display:flex;gap:5px;flex-wrap:wrap}
.sig-states button{font-size:11px;font-weight:550;color:var(--text2);background:var(--surface2);border:.5px solid var(--border);border-radius:7px;padding:5px 9px}
.sig-states button.on{background:var(--text);color:var(--bg);border-color:var(--text)}

/* barre de score (onglets détaillés) */
.sbar{display:inline-flex;align-items:center;gap:8px;justify-content:flex-end}
.sbar .t{width:54px;height:6px;border-radius:4px;background:var(--surface3);overflow:hidden}
.sbar .f{height:100%;border-radius:4px}
.sbar b{font-size:12px;min-width:22px;text-align:right;font-variant-numeric:tabular-nums;font-weight:680}
.tbl tr.hi td{background:color-mix(in srgb,var(--green) 8%,transparent)}
.tab-intro{font-size:12.5px;color:var(--text2);margin-bottom:14px;line-height:1.5}
.tab-intro .rg{font-weight:650;color:var(--text)}

/* ===== Polish & états ===== */
*:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px}
button{transition:background .15s,border-color .15s,color .15s,transform .05s}
button:active{transform:translateY(1px)}
a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}
.card{transition:box-shadow .2s}
.navlink .ic{filter:grayscale(.2)}
.navlink.on .ic{filter:none}
.chip{transition:background .15s}
::-webkit-scrollbar{height:9px;width:9px}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:6px}
::-webkit-scrollbar-track{background:transparent}
.tbl-wrap{scrollbar-width:thin}

/* ===== Responsive (desktop d'abord, mobile correct) ===== */
@media(max-width:800px){
  .side{display:block;height:auto;padding:8px 10px;border-right:none;border-bottom:.5px solid var(--border);position:sticky;top:0;z-index:50}
  .brand,.side-foot{display:none}                 /* mobile : on libère la place */
  .side nav{display:flex;flex-direction:row;overflow-x:auto;gap:4px;width:100%;-webkit-overflow-scrolling:touch}
  .navlink{width:auto;flex:0 0 auto;gap:6px;padding:8px 12px;font-size:12.5px}
  .navlink span:not(.ic){display:none}            /* icônes seules dans la barre */
  .navlink.on span:not(.ic){display:inline}       /* sauf l'onglet actif : libellé visible */
  .topbar{gap:8px}
  .page-title{font-size:19px}
  .content{padding:16px 14px 72px}
  .wealth .big{font-size:32px}
  .prof-sel{font-size:11px}
  .reco{gap:10px}
  .reco-stars{min-width:56px;font-size:11px}
}
@media(max-width:500px){
  .top-tools{width:100%;order:3}
  .grid3{grid-template-columns:1fr 1fr}
  .scenario{grid-template-columns:1fr}
  .sig-row{grid-template-columns:1fr;gap:6px}
  .quad{max-width:180px}
}
@media print{.side,.top-tools,.tbtn{display:none!important}.app{display:block}.content{padding:0}.card{break-inside:avoid;box-shadow:none}}
