/* ============================================================
   Brad Matthews Investment Strategies — adviser portal
   Shared design system (Libre Franklin + IBM Plex Mono, green/creme).
   Used by index, funds, portfolio, research, platform.
   ============================================================ */
:root{
  --green:#8DC63F;--green-600:#6FA82E;--green-700:#4E7A1E;--green-tint:#E2EFCB;--green-wash:#F2F7E6;
  --ink:#1B1A16;--ink-700:#4A463F;--ink-600:#6A655B;--mute:#8A847A;
  --line:#E6E1D6;--page:#F7F5EF;--panel:#FFFFFF;--neg:#B4452F;
  --blue:#3F5E8C;--blue-300:#6E89B8;--amber:#D9A441;
  --sans:'Libre Franklin',-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:none;            /* fluid — content expands to the viewport width */
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:var(--page);font-family:var(--sans);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
::selection{background:var(--green-tint);}
a{color:inherit;}
img{max-width:100%;}

/* ---- masthead ---- */
.masthead{position:sticky;top:0;z-index:50;background:rgba(247,245,239,0.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.masthead-in{max-width:var(--maxw);margin:0 auto;padding:16px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.masthead .logo{height:46px;width:auto;display:block;}
.mast-nav{display:flex;align-items:center;gap:26px;}
.mast-nav a{font:500 13.5px/1 var(--sans);color:var(--ink-700);text-decoration:none;letter-spacing:.01em;padding-bottom:2px;border-bottom:2px solid transparent;}
.mast-nav a:hover{color:var(--green-700);}
.mast-nav a[aria-current="page"]{color:var(--ink);font-weight:600;border-bottom-color:var(--green);}
.mast-nav .vtag{font:600 11px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--mute);border-left:1px solid #D7D1C4;padding-left:24px;}
@media (max-width:780px){.mast-nav{gap:16px;}.mast-nav .vtag{display:none;}}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:36px 40px 56px;}
.hero{max-width:var(--maxw);margin:0 auto;padding:64px 40px 12px;}
.eyebrow{font:600 12px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--green-700);margin-bottom:22px;}
h1.display{font:300 54px/1.03 var(--sans);letter-spacing:-0.025em;margin:0;color:var(--ink);max-width:20ch;}
h1.display b{font-weight:600;}
.lede{font:400 18px/1.6 var(--sans);color:var(--ink-700);max-width:64ch;margin:24px 0 0;}

.section-head{display:flex;align-items:baseline;gap:14px;border-bottom:2px solid var(--ink);padding-bottom:12px;margin:48px 0 24px;}
.section-head .n{font:600 12px/1 var(--mono);color:var(--green-700);}
.section-head h2{font:600 24px/1.1 var(--sans);letter-spacing:-0.02em;margin:0;color:var(--ink);}
.section-head .sub{font:400 14px/1.4 var(--sans);color:var(--ink-600);margin-left:auto;text-align:right;}

/* ---- badges / pills ---- */
.badge{display:inline-flex;align-items:center;gap:7px;font:600 11px/1 var(--sans);letter-spacing:.04em;text-transform:uppercase;padding:7px 11px;white-space:nowrap;}
.badge.rating{color:#3A6610;background:var(--green-tint);}
.badge.rating .dot{width:6px;height:6px;border-radius:50%;background:var(--green-600);}
.badge.neutral{color:var(--ink-700);background:#F2F0EA;border:1px solid var(--line);}
.badge.updated{color:#2c5f2c;background:var(--green-wash);border:1px solid var(--green-tint);}
.badge.illustrative{color:#8a5a16;background:#FBF1DC;border:1px solid #EAD6A8;}
.badge.illustrative .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);}

/* ---- demo flag banner ---- */
.demo-flag{display:inline-flex;align-items:center;gap:9px;font:600 12px/1 var(--sans);letter-spacing:.05em;text-transform:uppercase;
  color:#8a5a16;background:#FBF1DC;border:1px solid #EAD6A8;padding:10px 15px;}
.demo-flag .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);flex-shrink:0;}

/* ---- cards / panels ---- */
.card{background:var(--panel);border:1px solid var(--line);padding:24px 28px;}
.card .ch{font:600 12px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-bottom:18px;display:flex;justify-content:space-between;gap:10px;align-items:baseline;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
@media (max-width:860px){.grid-2,.grid-3{grid-template-columns:1fr;}}

/* capability tile (home) */
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.tile{background:var(--panel);padding:28px 30px;text-decoration:none;color:inherit;display:flex;flex-direction:column;min-height:170px;transition:background .12s;position:relative;}
.tile:hover{background:var(--green-wash);}
.tile .tn{font:600 11px/1 var(--mono);color:var(--green-700);letter-spacing:.08em;margin-bottom:14px;}
.tile h3{font:600 19px/1.25 var(--sans);letter-spacing:-0.01em;margin:0 0 8px;color:var(--ink);}
.tile p{font:400 14px/1.55 var(--sans);color:var(--ink-600);margin:0;}
.tile .go{margin-top:auto;padding-top:16px;font:600 13px/1 var(--sans);color:var(--green-700);}
.tile .soon{position:absolute;top:24px;right:26px;}
@media (max-width:860px){.tiles{grid-template-columns:1fr;}}

/* ---- stat blocks ---- */
.statrow{display:flex;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-wrap:wrap;}
.statrow .stat{flex:1;min-width:140px;padding:20px 28px;border-right:1px solid var(--line);}
.statrow .stat:first-child{padding-left:0;}
.statrow .stat:last-child{border-right:none;}
.stat .k{font:500 12px/1 var(--mono);color:var(--mute);margin-bottom:9px;letter-spacing:.02em;}
.stat .v{font:600 17px/1.25 var(--sans);color:var(--ink);font-variant-numeric:tabular-nums;}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);}
.stats-grid .cell{background:#fff;padding:14px 16px;}
.stats-grid .cell .k{font:500 11px/1.2 var(--sans);color:var(--mute);margin-bottom:8px;}
.stats-grid .cell .v{font:600 22px/1 var(--sans);color:var(--ink);font-variant-numeric:tabular-nums;}
.v.pos{color:var(--green-700);}.v.neg{color:var(--neg);}

/* ---- detail / KV list ---- */
.kv{display:flex;flex-direction:column;}
.kv .row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:11px 0;border-bottom:1px solid var(--line);}
.kv .row:last-child{border-bottom:none;}
.kv .row .k{font:400 13.5px/1.3 var(--sans);color:var(--ink-600);}
.kv .row .v{font:600 13.5px/1.3 var(--sans);color:var(--ink);font-variant-numeric:tabular-nums;text-align:right;}

/* ---- tables ---- */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px;}
.tbl th{font:600 10px/1.2 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--mute);text-align:right;padding:0 0 10px;border-bottom:1px solid var(--line);}
.tbl th:first-child{text-align:left;}
.tbl td{padding:10px 0;border-bottom:1px solid var(--line);text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-700);}
.tbl td:first-child{text-align:left;color:var(--ink);font-weight:500;}
.tbl tr:last-child td{border-bottom:none;}
.tbl td.pos{color:var(--green-700);}.tbl td.neg{color:var(--neg);}
.tbl .total td{border-top:2px solid var(--ink);font-weight:700;color:var(--ink);padding-top:11px;}
.tbl .muted{color:var(--mute);}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;font:600 14px/1 var(--sans);color:#1B3A00;background:var(--green);border:none;padding:13px 22px;cursor:pointer;text-decoration:none;}
.btn:hover{background:var(--green-600);color:#fff;}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid #D7D1C4;}
.btn.ghost:hover{background:var(--green-wash);border-color:var(--green-600);}
.btn.sm{font-size:13px;padding:9px 15px;}

/* ---- donut + legend (illustrative SAA/portfolio) ---- */
.donut-row{display:flex;align-items:center;gap:28px;flex-wrap:wrap;}
.donut{width:200px;height:200px;border-radius:50%;flex-shrink:0;position:relative;}
.donut::after{content:"";position:absolute;inset:34px;background:var(--panel);border-radius:50%;}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;}
.donut-center .e{font:600 10px/1 var(--mono);color:var(--green-700);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;}
.donut-center .v{font:300 30px/1 var(--sans);color:var(--ink);letter-spacing:-0.01em;}
.donut-center .v b{font-weight:600;}
.legend{display:flex;flex-direction:column;gap:9px;min-width:0;flex:1;}
.legend .li{display:flex;align-items:center;gap:9px;font:500 12.5px/1.2 var(--sans);color:var(--ink-700);}
.legend .sw{width:11px;height:11px;flex-shrink:0;}
.legend .w{margin-left:auto;font:600 12.5px/1 var(--sans);color:var(--ink);font-variant-numeric:tabular-nums;padding-left:14px;}

/* ---- update feed (timely collateral) ---- */
.feed{display:flex;flex-direction:column;}
.feed .item{display:flex;align-items:center;gap:16px;padding:15px 0;border-bottom:1px solid var(--line);}
.feed .item:last-child{border-bottom:none;}
.feed .item .date{font:500 12px/1 var(--mono);color:var(--mute);width:84px;flex-shrink:0;}
.feed .item .what{font:500 14px/1.35 var(--sans);color:var(--ink);}
.feed .item .what span{color:var(--ink-600);font-weight:400;}
.feed .item .tag{margin-left:auto;}

/* ---- architecture diagram (platform) ---- */
.arch{display:flex;flex-direction:column;gap:14px;}
.arch-row{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center;}
.arch-row .lbl{font:600 11px/1.2 var(--mono);color:var(--green-700);letter-spacing:.06em;text-transform:uppercase;text-align:right;}
.arch-row .nodes{display:flex;gap:10px;flex-wrap:wrap;}
.node{font:500 13px/1.2 var(--sans);color:var(--ink);background:#fff;border:1px solid var(--line);padding:11px 15px;}
.node.accent{border-color:var(--green-600);background:var(--green-wash);}
.arch-flow{text-align:center;color:var(--mute);font:500 18px/1 var(--sans);}

/* ---- footer + disclaimer ---- */
.foot-bar{border-top:1px solid var(--line);background:var(--ink);margin-top:8px;}
.foot-in{max-width:var(--maxw);margin:0 auto;padding:40px;display:flex;align-items:flex-start;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.foot-in .disc{font:400 11.5px/1.6 var(--sans);color:#9C968B;max-width:78ch;}
.foot-in .disc b{color:#C9C3B7;font-weight:600;}
.foot-in .mark{font:600 12px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--green);flex-shrink:0;}
.disc-inline{font:400 12px/1.6 var(--sans);color:var(--mute);border-top:1px solid var(--line);padding-top:16px;margin-top:8px;}

@media (max-width:780px){
  .masthead-in,.hero,.wrap,.foot-in{padding-left:20px;padding-right:20px;}
  h1.display{font-size:38px;}
}
