:root{
  --bg:#f6f7fb;
  --bg2:#eef1f7;
  --panel:#ffffff;
  --panel2:#fafbfd;
  --line:#e3e7ef;
  --line2:#eef1f7;
  --ink:#0f172a;
  --ink2:#1e293b;
  --mute:#64748b;
  --mute2:#94a3b8;
  --accent:#4f46e5;       /* インディゴ */
  --accent-d:#4338ca;
  --accent-l:#eef2ff;
  --pos:#059669;          /* エメラルド */
  --pos-l:#ecfdf5;
  --neg:#dc2626;          /* レッド */
  --neg-l:#fef2f2;
  --warn:#d97706;
  --b:#0ea5e9;
  --p:#7c3aed;
  --shadow-sm:0 1px 2px rgba(15,23,42,.04);
  --shadow:0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --sans:"Inter","Noto Sans JP",system-ui,sans-serif;
  --serif:"Playfair Display","Noto Serif JP",serif;
}
*{box-sizing:border-box}
html,body{background:var(--bg);height:100%;overflow:hidden}
body{
  margin:0;font-family:var(--sans);color:var(--ink);font-size:13.5px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;height:100vh;
}
header,nav.tabs{flex:0 0 auto}

/* HEADER */
header{
  padding:12px 24px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--line);background:#fff;
}
header .brand{display:flex;align-items:center;gap:14px}
header .logo{color:var(--accent);flex:0 0 auto}
header h1{margin:0;font-size:18px;font-weight:700;letter-spacing:-.01em;line-height:1.2;color:var(--ink)}
header h1 .accent{color:var(--accent);font-weight:800}
header h1 small{
  display:block;color:var(--mute);font-size:10px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;margin-top:3px;font-family:var(--mono);
}
header .meta{display:flex;align-items:center;gap:12px;color:var(--mute);font-size:11px;font-family:var(--mono)}
header button{
  background:#fff;border:1px solid var(--line);border-radius:6px;padding:7px 14px;cursor:pointer;
  font:600 11px var(--mono);color:var(--ink);letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:6px;transition:all .15s;
}
header button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}

/* TABS */
nav.tabs{
  display:flex;gap:0;padding:0 32px;border-bottom:1px solid var(--line);
  background:#fff;position:sticky;top:0;z-index:50;
}
nav.tabs button{
  background:none;border:none;padding:11px 18px;cursor:pointer;
  font:600 12.5px var(--sans);color:var(--mute);letter-spacing:.01em;
  position:relative;transition:color .15s;
}
nav.tabs button:hover{color:var(--ink)}
nav.tabs button.active{color:var(--accent)}
nav.tabs button.active::after{
  content:"";position:absolute;left:18px;right:18px;bottom:-1px;height:2px;
  background:var(--accent);border-radius:2px;
}

main{
  flex:1;min-height:0;display:grid;grid-template-columns:300px 1fr;gap:14px;
  padding:14px 24px;max-width:1720px;margin:0 auto;width:100%;overflow:hidden;
}

/* CARD */
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;
  box-shadow:var(--shadow-sm);
}
.card h2{
  margin:0 0 3px;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);font-family:var(--mono);display:flex;align-items:center;gap:6px;
}
.card .desc{color:var(--mute);font-size:11px;margin-bottom:10px;line-height:1.5}
.left{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:6px;min-height:0}
.left .card{flex:0 0 auto}
.left::-webkit-scrollbar{width:6px}

/* SLIDER */
.slider-wrap{margin-top:6px}
.slider-wrap label,
.row label{color:var(--mute2);font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:6px}
input[type=range]{width:100%;accent-color:var(--accent);margin-top:6px}
.legend{display:flex;justify-content:space-between;margin-top:10px;font-size:12px;font-family:var(--mono);color:var(--mute)}
.legend b{color:var(--ink);font-weight:700}
.legend .l1::before{content:"\25A0";margin-right:6px;color:var(--accent)}
.legend .l2::before{content:"\25A0";margin-right:6px;color:var(--pos)}
input[type=range]#alloc{
  -webkit-appearance:none;appearance:none;height:5px;border-radius:999px;outline:none;
  background:linear-gradient(to right,var(--accent) 0% var(--alloc,100%), #d1d5db var(--alloc,100%) 100%);
}
input[type=range]#alloc::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);cursor:pointer;box-shadow:0 2px 6px rgba(79,70,229,.3);
}
input[type=range]#alloc::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid var(--accent);
  cursor:pointer;box-shadow:0 2px 6px rgba(79,70,229,.3);
}

/* PRESET */
.preset{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px}
.preset button{
  font:600 11px var(--mono);padding:5px 9px;border-radius:5px;
  border:1px solid var(--line);background:#fff;cursor:pointer;color:var(--mute);
  transition:all .12s;
}
.preset button:hover{border-color:var(--accent);color:var(--accent)}
.preset button.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* FORM */
.row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
label{font-size:10px;color:var(--mute2);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;display:block}
select,input[type=number]{
  width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:6px;
  font:500 13px var(--sans);background:#fff;color:var(--ink);outline:none;
  transition:border-color .12s, box-shadow .12s;
}
select:focus,input[type=number]:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.12)}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path fill='%2364748b' d='M2 4l3 3 3-3z'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}

.money-input{display:flex;align-items:center;gap:8px;margin-top:6px}
.money-input input{
  flex:1;text-align:right;font:700 18px var(--mono);padding:10px 12px;
  background:var(--bg2);color:var(--ink);border-color:var(--line2);
}
.money-input .unit{font:600 11px var(--mono);color:var(--mute);min-width:54px}
.sub{margin-top:6px;color:var(--mute2);font-size:10.5px;font-family:var(--mono);text-align:right}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px 18px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
}
.kpi::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--accent);
}
.kpi.k-asset::before{background:var(--accent)}
.kpi.k-principal::before{background:var(--b)}
.kpi.k-pnl::before{background:var(--pos)}
.kpi.k-ret::before{background:var(--p)}
.kpi .label{
  font:600 10px var(--mono);color:var(--mute);letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;
}
.kpi .label .dot{width:8px;height:8px;border-radius:50%}
.kpi .value{font:700 22px var(--mono);margin-top:8px;letter-spacing:-.02em;color:var(--ink)}
.kpi.sub{padding:8px 14px}
.kpi.sub::before{display:none}
.kpi.sub{border-left:3px solid var(--line)}
.kpi.sub .value{font-size:14px;font-weight:600}
.kpi.sub .sub2{font:500 10px var(--mono);color:var(--mute2);margin-top:3px}
.pos{color:var(--pos)}
.neg{color:var(--neg)}

/* CHART */
.chart-card{margin-top:6px}
.chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.chart-head h2{margin:0;font-size:11px;color:var(--accent);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase}
.chart-tabs select{
  background:#fff;border:1px solid var(--line);color:var(--ink);padding:7px 30px 7px 14px;
  border-radius:6px;cursor:pointer;font:600 11px var(--mono);letter-spacing:.05em;text-transform:uppercase;
  appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path fill='%234f46e5' d='M2 4l3 3 3-3z'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;
}
.chart-tabs select:focus{border-color:var(--accent);outline:none}
.chart-box{position:relative;height:380px}

/* INVESTMENT EVENTS */
.ev-actions{display:flex;gap:6px;margin-top:8px}
.ev-btn{
  flex:1;padding:9px 6px;font:600 10.5px var(--mono);letter-spacing:.05em;
  border:1px solid var(--line);background:#fff;border-radius:6px;cursor:pointer;color:var(--mute);
  text-transform:uppercase;transition:all .12s;
}
.ev-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}
.ev-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.ev-item{background:var(--bg2);border:1px solid var(--line2);border-radius:8px;padding:10px 12px}
.ev-item-head{display:flex;justify-content:space-between;align-items:center}
.ev-tag{display:inline-block;padding:3px 9px;border-radius:4px;font:700 9.5px var(--mono);letter-spacing:.1em;text-transform:uppercase}
.ev-tag.change{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}
.ev-tag.lump  {background:var(--accent-l);color:var(--accent-d);border:1px solid #c7d2fe}
.ev-tag.wd    {background:var(--pos-l);color:#047857;border:1px solid #a7f3d0}
.ev-del{background:none;border:none;cursor:pointer;color:var(--mute);font-size:13px;padding:2px 6px;border-radius:4px}
.ev-del:hover{color:var(--neg);background:var(--neg-l)}
.ev-body{display:grid;grid-template-columns:.7fr .5fr 1fr;gap:8px;margin-top:8px;align-items:end}
.ev-body label{font-size:9.5px}
.ev-body select,.ev-body input{padding:6px 8px;font-size:11.5px;background:#fff}
.ev-body .amt{display:flex;align-items:center;gap:4px}
.ev-body .amt input{text-align:right;font-family:var(--mono);font-weight:700}

.addbtn{
  margin-top:8px;width:100%;padding:9px;border:1px dashed var(--line);background:#fff;
  border-radius:6px;cursor:pointer;font:600 11px var(--mono);color:var(--mute);letter-spacing:.08em;text-transform:uppercase;
}
.addbtn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}

/* WD EVENT */
.wd-ev{display:grid;grid-template-columns:1.3fr .9fr auto 32px;gap:6px;align-items:center;margin-top:6px}
.wd-ev select,.wd-ev input{padding:6px 8px;font-size:11.5px}
.wd-ev .wd-ev-del{background:#fff;border:1px solid var(--line);border-radius:6px;cursor:pointer;font-size:11px;color:var(--mute);padding:4px}
.wd-ev .wd-ev-del:hover{background:var(--neg-l);color:var(--neg);border-color:var(--neg)}

/* CALC INDICATOR */
.calc-indicator{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 18px;
  box-shadow:var(--shadow-md);font:600 11px var(--mono);color:var(--mute);
  letter-spacing:.1em;text-transform:uppercase;display:none;z-index:1000;
}
.calc-indicator.on{display:flex;align-items:center;gap:10px}
.calc-indicator::before{
  content:"";width:10px;height:10px;border-radius:50%;
  border:2px solid var(--accent);border-top-color:transparent;animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.right{display:flex;flex-direction:column;gap:10px;min-height:0;overflow:hidden}
.kpi-sub-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;flex:0 0 auto}
.kpis{flex:0 0 auto}
.chart-card{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}
.chart-card .chart-box{flex:1 1 auto;height:auto;min-height:0}
.kpi{padding:10px 14px}
.kpi .value{font-size:19px;margin-top:4px}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:var(--mute2)}

@media(max-width:1000px){
  html,body{height:auto;overflow:auto}
  body{height:auto}
  main{grid-template-columns:1fr;padding:14px;overflow:visible;height:auto}
  .left{overflow:visible}
  .right{overflow:visible}
  .chart-card{height:380px;flex:0 0 auto}
  .chart-card .chart-box{height:340px}
  .kpis,.kpi-sub-row{grid-template-columns:repeat(2,1fr)}
  header{padding:12px 16px}
  nav.tabs{padding:0 14px;overflow-x:auto}
}
