:root{--navy:#071426;--navy2:#0d1b2f;--gold:#c9a45c;--gold2:#f3d694;--ink:#eef4ff;--muted:#9fafc7;--panel:rgba(13,27,47,.88);--line:rgba(201,164,92,.22);--danger:#ef4444;--ok:#22c55e}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:radial-gradient(circle at 10% 0%,#18385b 0,#071426 42%,#050a12 100%);color:var(--ink);min-height:100vh}a{color:var(--gold2)}.shell{width:min(1240px,calc(100% - 32px));margin:auto;padding:34px 0}.narrow{width:min(760px,calc(100% - 32px))}.hero,header{display:flex;justify-content:space-between;gap:22px;align-items:flex-start;margin-bottom:22px}.eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--gold2);font-size:12px;margin:0 0 10px}h1{font-family:Georgia,serif;font-weight:500;font-size:clamp(34px,5vw,64px);line-height:1;margin:0 0 12px}.sub{color:var(--muted);max-width:760px;line-height:1.6;margin:0}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}button,.logout{border:0;border-radius:999px;padding:12px 18px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#111827;font-weight:800;cursor:pointer;text-decoration:none;display:inline-block}.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.logout{background:rgba(255,255,255,.08);border:1px solid var(--line);color:var(--ink)}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:20px 0}.tabs button{background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--ink)}.tabs button.active{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#111}.tab{display:none}.tab.active{display:block}.panel,.card,.kpis article,.source,.docGrid article,.loginCard{background:var(--panel);border:1px solid var(--line);border-radius:26px;box-shadow:0 18px 60px rgba(0,0,0,.22);backdrop-filter:blur(10px)}.panel{padding:24px;margin:18px 0}.panelHead{display:flex;justify-content:space-between;gap:16px;margin-bottom:16px}.panel h2{font-family:Georgia,serif;font-size:28px;margin:0 0 6px}.panel p{color:var(--muted);line-height:1.55}.status{padding:12px 16px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.06);color:var(--gold2)}.grid{display:grid;gap:14px}.kpis{grid-template-columns:repeat(4,1fr);margin:18px 0}.kpis article{padding:18px}.kpis small{display:block;color:var(--muted);margin-bottom:8px}.kpis strong{font-size:24px;color:white}.sourceGrid,.instrumentGrid,.docGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.source,.docGrid article{padding:16px}.source b,.source span{display:block}.source span{color:var(--muted);font-size:13px;margin:6px 0}.source em{color:var(--gold2);font-size:13px}.card{padding:18px}.card.manual{border-style:dashed}.card h3{margin:0;color:white}.cellTag{font-size:13px;color:var(--gold2)!important}.card label,.loginCard label,.leadForm label{display:block;margin:12px 0}.card label span,.loginCard label span,.leadForm label span{display:block;color:var(--muted);font-size:13px;margin-bottom:6px}input,textarea,select{width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.08);color:var(--ink);outline:none}select option{color:#111}textarea{min-height:110px}.mini{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:14px;margin-top:14px}.mini span{color:var(--muted)}.mini strong{color:var(--gold2)}.tableWrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:900px}th,td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.09);text-align:right}th:first-child,td:first-child{text-align:left;color:var(--muted)}th{color:var(--gold2);font-size:13px}.leadForm{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.leadForm .wide,.formStatus{grid-column:1/-1}.formStatus{color:var(--gold2)}.notes code,.panel code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:6px;color:#fef3c7}.loginBody{display:grid;place-items:center;min-height:100vh;padding:20px}.loginCard{width:min(480px,100%);padding:34px}.loginCard button{width:100%;margin-top:10px}.alert{padding:12px;border-radius:12px;margin:12px 0}.error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4)}.tiny{font-size:12px;color:var(--muted)}.nda{margin-top:70px}.check{display:flex!important;gap:12px;align-items:flex-start}.check input{width:auto;margin-top:5px}@media(max-width:1000px){.kpis,.sourceGrid,.instrumentGrid,.docGrid{grid-template-columns:repeat(2,1fr)}header{flex-direction:column}.leadForm{grid-template-columns:1fr}}@media(max-width:640px){.kpis,.sourceGrid,.instrumentGrid,.docGrid{grid-template-columns:1fr}.shell{width:min(100% - 20px,1240px);padding:20px 0}}@media print{body{background:white;color:#111}.tabs,.actions,.leadPanel,.logout{display:none!important}.tab{display:block!important}.tab:not(#dashboard){display:none!important}.panel,.card,.kpis article,.source{background:white;border:1px solid #ddd;color:#111;box-shadow:none}h1,h2,h3,td,th,.kpis strong{color:#111!important}.sub,p,span,small,td:first-child{color:#333!important}}

/* FX sensitivity + private bank exit option cards */
.exitGrid,.chartGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.exitCard,.chartCard{background:#fff;border:1px solid #e7dfd2;border-radius:18px;padding:16px;box-shadow:0 14px 35px rgba(22,30,45,.06)}
.exitCard h3,.chartCard h3{margin:0 0 8px;color:#172033}
.exitMeta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.exitMeta div{background:#f7f3ec;border-radius:12px;padding:10px}
.exitMeta small{display:block;color:#7b6b55;font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.exitMeta strong{display:block;margin-top:4px;font-size:17px;color:#172033}
.exitCard.positive .outcome{color:#1f7a4d}.exitCard.negative .outcome{color:#a7392f}
.chartCard canvas{width:100%;height:190px;border-radius:12px;background:linear-gradient(180deg,#fff,#fbf8f2);border:1px solid #efe6d8}
.chartLegend{display:flex;justify-content:space-between;gap:8px;margin-top:8px;color:#75664f;font-size:12px}.chartLegend b{color:#172033}
@media(max-width:1100px){.exitGrid,.chartGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.exitGrid,.chartGrid{grid-template-columns:1fr}}
@media print{.chartCard canvas{height:160px}.exitGrid,.chartGrid{grid-template-columns:repeat(2,1fr)}}

/* SAVE-only Portfolio Inputs update */
.instrumentGrid{grid-template-columns:repeat(4,minmax(0,1fr))}
.percentRow{display:grid;grid-template-columns:110px 1fr;gap:8px}.percentRow select,.percentRow input{min-width:0}.portfolioSaveBar{grid-column:1/-1;display:flex;align-items:center;gap:14px;justify-content:flex-end;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:20px;padding:16px;margin-top:4px}.saveBtn.disabled,.saveBtn:disabled{opacity:.45;filter:grayscale(1);cursor:not-allowed}.warn{color:#facc15}.successText{color:#22c55e!important}.errorText{color:#fca5a5!important}
@media(max-width:1180px){.instrumentGrid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.instrumentGrid{grid-template-columns:1fr}.portfolioSaveBar{justify-content:flex-start;flex-direction:column;align-items:flex-start}}

.feeInputBlock{border:1px solid rgba(201,164,92,.35);background:rgba(201,164,92,.07);border-radius:18px;padding:12px;margin:14px 0}.feeInputBlock h4{margin:0 0 8px;color:var(--gold2);font-size:13px;text-transform:uppercase;letter-spacing:.08em}.mini.highlight{background:rgba(201,164,92,.08);border:1px solid rgba(201,164,92,.2);border-radius:14px;padding:12px;margin-top:10px}.portfolioSaveBar{position:sticky;bottom:12px;z-index:5}.portfolioSaveBar .formStatus{grid-column:auto}

.source em a{color:var(--gold2);word-break:break-all;text-decoration:underline}
.card .tiny{display:block;margin:6px 0 10px;color:var(--muted);font-size:12px;line-height:1.4}

/* UI UPGRADE — Private bank Portfolio Inputs layout v14
   Keeps all four Portfolio Input cards on one desktop line. */
#cards.instrumentGrid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:18px !important;
  align-items:stretch !important;
}
#cards.instrumentGrid > .card{
  min-width:0 !important;
  width:auto !important;
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
  border-radius:24px !important;
  padding:16px !important;
  background:linear-gradient(180deg,rgba(18,36,60,.96),rgba(9,20,36,.96)) !important;
  border:1px solid rgba(201,164,92,.28) !important;
  box-shadow:0 18px 45px rgba(0,0,0,.28) !important;
}
#cards.instrumentGrid > .card h3{
  min-height:34px;
  display:flex;
  align-items:flex-start;
  font-family:Georgia,serif;
  font-size:20px;
  line-height:1.1;
  border-bottom:1px solid rgba(201,164,92,.18);
  padding-bottom:10px;
  margin-bottom:8px;
}
#cards.instrumentGrid > .card .cellTag{
  min-height:34px;
  font-size:12px;
  line-height:1.35;
  margin:0 0 8px;
}
#cards.instrumentGrid > .card label{
  margin:8px 0 !important;
}
#cards.instrumentGrid > .card label span{
  font-size:11px !important;
  text-transform:uppercase;
  letter-spacing:.05em;
}
#cards.instrumentGrid > .card input,
#cards.instrumentGrid > .card select{
  min-height:38px;
  padding:9px 10px !important;
  border-radius:12px !important;
  font-size:13px;
}
#cards.instrumentGrid .feeInputBlock{
  margin:12px 0 !important;
  padding:10px !important;
  border-radius:16px !important;
}
#cards.instrumentGrid .feeInputBlock h4{
  font-size:11px !important;
  margin-bottom:6px !important;
}
#cards.instrumentGrid .percentRow{
  grid-template-columns:82px minmax(0,1fr) !important;
  gap:6px !important;
}
#cards.instrumentGrid .mini{
  margin-top:8px !important;
  padding-top:8px !important;
  gap:8px;
}
#cards.instrumentGrid .mini span{
  font-size:12px;
  line-height:1.25;
}
#cards.instrumentGrid .mini strong{
  font-size:13px;
  white-space:nowrap;
}
#cards.instrumentGrid .mini.highlight{
  margin-top:8px !important;
  padding:9px !important;
}
#cards.instrumentGrid .tiny{
  font-size:11px !important;
  line-height:1.35;
}
#cards.instrumentGrid .portfolioSaveBar{
  grid-column:1 / -1 !important;
  margin-top:4px;
  position:sticky;
  bottom:14px;
  backdrop-filter:blur(14px);
  background:rgba(7,20,38,.92);
  box-shadow:0 12px 30px rgba(0,0,0,.22);
}
@media (min-width:1024px){
  #cards.instrumentGrid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
}
@media (max-width:1023px){
  #cards.instrumentGrid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:700px){
  #cards.instrumentGrid{grid-template-columns:1fr !important;}
  #cards.instrumentGrid .portfolioSaveBar{position:static;}
}
