/* TradingBoard — gedeeld design-systeem
   Geëxtraheerd uit landing/index.html zodat alle portals dezelfde stijl delen. */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&family=Space+Mono:wght@400;700&display=swap');

:root{
  --paper:#F6F4EF; --card:#FFFFFF; --ink:#14202E; --ink-soft:#536173;
  --navy:#0F2238; --navy-2:#0A1726; --cobalt:#2746EC; --cobalt-soft:#E7EBFE;
  --gold:#B5891F; --gold-soft:#F4ECD7; --up:#1C9468; --down:#CB4338;
  --line:rgba(20,32,46,.10); --line-2:rgba(20,32,46,.16);
  --r:14px; --maxw:1180px;
  --disp:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"Space Mono","SF Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;line-height:1.1;letter-spacing:-.02em;margin:0}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}
.up{color:var(--up)} .down{color:var(--down)}
.muted{color:var(--ink-soft)}
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-weight:500;
  font-size:15px;padding:11px 20px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:.16s}
.btn-pri{background:var(--cobalt);color:#fff}
.btn-pri:hover{background:#1d39d4}
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(20,32,46,.03)}
.btn-light{background:#fff;color:var(--navy)}
.btn-danger{background:transparent;border-color:rgba(203,67,56,.4);color:var(--down)}
.btn-danger:hover{background:rgba(203,67,56,.06);border-color:var(--down)}
.btn-sm{padding:8px 14px;font-size:14px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* nav */
nav.tb{position:sticky;top:0;z-index:50;background:rgba(246,244,239,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;height:64px;position:relative}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-.03em}
.nav-links{display:flex;gap:26px;margin-left:8px}
.nav-links-center{position:absolute;left:50%;transform:translateX(-50%);margin-left:0}
.nav-links a{font-size:14.5px;color:var(--ink-soft);font-weight:500}
.nav-links a:hover,.nav-links a.on{color:var(--ink)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav-right .who{font-size:13.5px;color:var(--ink-soft)}
.nav-right .logout{font-size:14px;color:var(--ink-soft)}
.nav-right .logout:hover{color:var(--ink)}
.role-pill{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;
  background:var(--cobalt-soft);color:var(--cobalt);padding:4px 9px;border-radius:20px;font-weight:700}
.accdrop{position:relative}
.accdrop-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--line-2);border-radius:20px;padding:4px 10px 4px 4px;cursor:pointer;color:var(--ink-soft);transition:border-color .15s}
.accdrop-btn:hover{border-color:var(--cobalt)}
.accdrop-avatar{width:26px;height:26px;border-radius:50%;background:var(--cobalt);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.accdrop-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:220px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px -8px rgba(15,34,56,.18);z-index:200;padding:6px}
.accdrop.open .accdrop-menu{display:block}
.accdrop-header{padding:10px 12px 8px}
.accdrop-naam{display:block;font-size:13.5px;font-weight:600;color:var(--ink)}
.accdrop-email{display:block;font-size:12px;color:var(--ink-soft);margin-top:2px}
.accdrop-sep{border:none;border-top:1px solid var(--line);margin:4px 0}
.accdrop-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:8px;font-size:13.5px;color:var(--ink);text-decoration:none;transition:background .12s}
.accdrop-item:hover{background:var(--bg-2)}
.accdrop-item svg{flex-shrink:0;opacity:.6}
.accdrop-logout{color:var(--danger,#d93025)}

/* sections & headers */
.page{padding:40px 0 64px}
.sec-head{margin-bottom:26px}
.sec-head h1{font-size:34px}
.sec-head h2{font-size:26px}
.sec-head p{color:var(--ink-soft);font-size:16px;margin:10px 0 0}
.sec-label{font-family:var(--disp);font-weight:600;font-size:18px;margin:30px 0 14px}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px}
.card.click{cursor:pointer;transition:.16s}
.card.click:hover{transform:translateY(-3px);box-shadow:0 16px 36px -22px rgba(15,34,56,.45);border-color:var(--line-2)}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* kpi tiles */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:12px;overflow:hidden}
.kpi{background:#fff;padding:16px 18px}
.kpi .k{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft)}
.kpi .v{font-family:var(--mono);font-weight:700;font-size:22px;margin-top:4px}

/* tags / badges */
.tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.03em;background:#F1EFE9;
  color:var(--ink-soft);padding:3px 7px;border-radius:5px}
.tag.risk-l{background:#E5F3EC;color:var(--up)}
.tag.risk-m{background:#FBF2DC;color:var(--gold)}
.tag.risk-h{background:#FAE7E5;color:var(--down)}
.tag.live{background:var(--cobalt-soft);color:var(--cobalt)}
.tag.soon{background:var(--gold-soft);color:var(--gold)}
.seal{display:inline-flex;align-items:center;gap:5px;background:var(--gold-soft);color:var(--gold);
  font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:4px 8px;border-radius:20px;font-weight:700}

/* tables */
table.tb{width:100%;border-collapse:collapse;font-size:14px}
table.tb th{text-align:left;font-family:var(--disp);font-weight:600;font-size:12px;text-transform:uppercase;
  letter-spacing:.05em;color:var(--ink-soft);padding:10px 12px;border-bottom:1px solid var(--line)}
table.tb td{padding:11px 12px;border-bottom:1px solid var(--line)}
table.tb tr:last-child td{border-bottom:none}
table.tb td.r,table.tb th.r{text-align:right}

/* forms */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:13px;font-weight:500;color:var(--ink-soft)}
.field input,.field select{font-family:var(--body);font-size:15px;padding:11px 14px;
  border:1px solid var(--line-2);border-radius:10px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus{outline:none;border-color:var(--cobalt)}

/* star rating */
.stars{display:inline-flex;gap:3px;font-size:18px;line-height:1}
.stars .s{color:var(--line-2);cursor:pointer}
.stars .s.on{color:var(--gold)}
.stars.ro .s{cursor:default}

/* signal feed */
.signal{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.signal:last-child{border-bottom:none}
.sig-badge{font-family:var(--mono);font-size:10px;font-weight:700;padding:3px 7px;border-radius:5px;flex:none}
.sig-buy{background:#E5F3EC;color:var(--up)} .sig-sell{background:#FAE7E5;color:var(--down)} .sig-hold{background:#F1EFE9;color:var(--ink-soft)}
.sig-time{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}

/* flash messages */
.flash{padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:18px}
.flash.ok{background:#E5F3EC;color:#0f6b48;border:1px solid #bfe3cf}
.flash.err{background:#FAE7E5;color:#9e2f26;border:1px solid #f0c5c0}
.flash.info{background:var(--cobalt-soft);color:#1d39d4;border:1px solid #c3cdfb}

/* taalkiezer (vlaggen-dropdown) */
.langdrop{position:relative;display:inline-block}
.langdrop-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--body);font-size:13px;
  color:var(--ink-soft);background:#fff;border:1px solid var(--line-2);border-radius:8px;padding:6px 10px;cursor:pointer}
.langdrop-btn:hover{border-color:var(--ink)}
.langdrop-flag{width:20px;height:14px;object-fit:cover;border-radius:2px;display:block;flex:none}
.langdrop-chevron{opacity:.55;flex:none}
.langdrop-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:170px;background:#fff;
  border:1px solid var(--line-2);border-radius:10px;box-shadow:0 14px 34px -14px rgba(15,34,56,.4);
  list-style:none;margin:0;padding:5px;display:none;z-index:60}
.langdrop:hover .langdrop-menu,.langdrop:focus-within .langdrop-menu{display:block}
.langdrop-menu li a{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;font-size:13.5px;color:var(--ink)}
.langdrop-menu li a:hover{background:rgba(20,32,46,.05)}
.langdrop-menu li[aria-selected="true"] a{color:var(--cobalt);font-weight:600}
.auth-card{position:relative}
.auth-card .langdrop{position:static;display:flex;justify-content:center;margin-bottom:16px}

/* custom langdrop */
.langdrop{position:relative}
.langdrop-btn{display:flex;align-items:center;gap:7px;font-family:var(--body);font-size:13px;
  color:var(--ink-soft);background:#fff;border:1px solid var(--line-2);border-radius:8px;
  padding:5px 10px;cursor:pointer;white-space:nowrap}
.langdrop-btn:hover{border-color:var(--ink);color:var(--ink)}
.langdrop-flag{width:18px;height:18px;border-radius:50%;object-fit:cover;flex-shrink:0;
  display:block;border:1px solid var(--line)}
.langdrop-chevron{color:var(--ink-soft);transition:transform .15s;flex-shrink:0}
.langdrop.open .langdrop-chevron{transform:rotate(180deg)}
.langdrop-menu{display:none;position:absolute;right:0;top:calc(100% + 6px);
  background:#fff;border:1px solid var(--line-2);border-radius:10px;
  box-shadow:0 4px 16px rgba(20,32,46,.10);min-width:148px;z-index:200;
  list-style:none;margin:0;padding:4px}
.langdrop.open .langdrop-menu{display:block}
.langdrop-menu li a{display:flex;align-items:center;gap:9px;padding:8px 10px;
  border-radius:7px;font-size:13.5px;color:var(--ink);text-decoration:none}
.langdrop-menu li a:hover{background:var(--cobalt-soft);color:var(--cobalt)}
.langdrop-menu li[aria-selected="true"] a{font-weight:600;color:var(--cobalt)}
.auth-card .langdrop{position:absolute;top:16px;right:16px}
/* Gate-pagina: taalkiezer gecentreerd bovenaan i.p.v. absoluut rechtsboven */
.auth-card--gate .langdrop{position:static;top:auto;right:auto}
.gate-lang{display:flex;justify-content:center;margin-bottom:22px}

/* auth card */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:40px 36px;width:100%;max-width:400px;
  box-shadow:0 20px 50px -28px rgba(15,34,56,.4)}
.auth-card .brand{justify-content:center;margin-bottom:22px}
.auth-card h1{font-size:22px;text-align:center;margin-bottom:6px}
.auth-card p.sub{text-align:center;color:var(--ink-soft);font-size:14px;margin:0 0 24px}

/* ── Maandelijkse rendementsmatrix ─────────────────────────────────────── */
.ret-matrix{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11.5px}
.ret-matrix thead th{padding:4px 7px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-soft);text-align:center;font-family:var(--body);font-weight:600;white-space:nowrap}
.ret-cel{padding:5px 7px;text-align:right;border-radius:4px;white-space:nowrap}
.ret-jaar{padding:5px 10px 5px 0;font-size:11px;color:var(--ink-soft);font-weight:700;white-space:nowrap;font-family:var(--body)}
.ret-totaal{font-weight:700}
.ret-pos{background:#d4edda;color:#0f6b48}
.ret-neg{background:#f8d7da;color:#9e2f26}
.ret-zero{color:var(--ink-soft);background:transparent}

/* ── Rank-badge ────────────────────────────────────────────────────────── */
.rank-badge{display:inline-flex;align-items:center;gap:4px;background:var(--navy);color:#fff;
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;padding:4px 9px;border-radius:20px;font-weight:700}

/* ── New High badge ────────────────────────────────────────────────────── */
.nh-badge{display:inline-flex;align-items:center;gap:4px;background:#E5F3EC;color:var(--up);
  font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:3px 8px;border-radius:5px;font-weight:700}

/* ── Tijdsperiode-tabs (catalogus) ──────────────────────────────────────── */
.period-tabs{display:flex;gap:6px;flex-wrap:wrap}
.period-tab{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 11px;border-radius:7px;border:1px solid var(--line-2);background:#fff;
  cursor:pointer;color:var(--ink-soft);transition:.13s}
.period-tab.on{background:var(--cobalt);color:#fff;border-color:var(--cobalt)}
.period-tab:hover:not(.on){border-color:var(--cobalt);color:var(--cobalt)}

/* ── Geverifieerd-badge (reviews) ───────────────────────────────────────── */
.verified-badge{display:inline-flex;align-items:center;gap:3px;background:var(--cobalt-soft);
  color:var(--cobalt);font-family:var(--mono);font-size:9px;letter-spacing:.04em;
  padding:2px 6px;border-radius:4px;font-weight:700;vertical-align:middle}

@media (max-width:960px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
  .sec-head h1{font-size:28px}
}

/* ── Portal footer ─────────────────────────────────────────────────────── */
.tb-footer{background:var(--navy);color:rgba(168,196,224,.7);font-size:13px;padding:14px 0}
.tb-footer-in{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tb-footer-sep{color:rgba(168,196,224,.35)}
.tb-footer a{color:rgba(168,196,224,.85);text-decoration:underline;text-underline-offset:2px}
.tb-footer a:hover{color:#fff}
.social-links{display:flex;align-items:center;gap:12px;margin-left:auto}
.social-icon{display:flex;align-items:center;justify-content:center;color:rgba(168,196,224,.6);transition:color .15s}
.social-icon:hover{color:#fff}
