/* =========================================================
   SIESTA — dashboard.css
   운용 대시보드 (데모/페이퍼테스트)
   ========================================================= */
.dash-body{min-height:100vh}
.dash-body{display:grid;grid-template-columns:248px 1fr}

/* ----- sidebar ----- */
.dash-side{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  padding:22px 18px;border-right:1px solid var(--line);background:rgba(11,15,23,.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.dash-side__brand{margin:4px 6px 26px}
.dash-nav{display:flex;flex-direction:column;gap:4px}
.dash-nav__item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;
  color:var(--muted);font-weight:500;font-size:.95rem;transition:.18s}
.dash-nav__item .ic{width:18px;text-align:center;opacity:.8}
.dash-nav__item:hover{background:rgba(255,255,255,.04);color:var(--text)}
.dash-nav__item.is-active{background:rgba(0,229,168,.1);color:var(--mint);border:1px solid rgba(0,229,168,.22)}
.dash-side__back{margin-top:auto;color:var(--muted-2);font-size:.86rem;padding:10px 13px}
.dash-side__back:hover{color:var(--text)}

/* ----- main ----- */
.dash-main{padding:26px 30px 60px;min-width:0}
.dash-top{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.dash-top__title{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}
.dash-top__sub{color:var(--muted);font-size:.92rem;margin-top:4px}
.dash-top__sub .sep{opacity:.4;margin:0 4px}
.dash-top__right{display:flex;align-items:center;gap:12px}
.demo-pill{font-size:.74rem;font-weight:700;letter-spacing:.04em;color:#FFCF6B;
  background:rgba(255,193,77,.1);border:1px solid rgba(255,193,77,.3);border-radius:999px;padding:5px 11px}
.live-tag{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--mint)}
.quote-status{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--muted)}
.quote-status .live-dot{background:var(--muted-2)}
.quote-status.is-live .live-dot{background:var(--mint)}
.quote-status.is-delay .live-dot{background:#FFC14D}
.px-live{color:var(--mint);font-size:.6rem;vertical-align:1px;margin-left:3px}
.dash-avatar{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  overflow:hidden;background:#fff;padding:4px;box-sizing:border-box}
.dash-avatar img{width:100%;height:100%;object-fit:contain;display:block}

/* ----- KPI ----- */
.kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:18px}
.kpi-card{padding:16px 16px 14px;border-radius:var(--r);position:relative;overflow:hidden}
.kpi-card__label{display:block;font-size:.78rem;color:var(--muted-2);margin-bottom:8px}
.kpi-card__value{font-size:1.5rem;font-weight:800;letter-spacing:-.01em;font-variant-numeric:tabular-nums;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.kpi-card__value--nav{font-size:1.18rem;letter-spacing:-.02em}
.kpi-card__sub{display:block;font-size:.74rem;color:var(--muted-2);margin-top:6px}
.kpi-card__sub b{color:var(--muted)}
.kpi-card__spark{display:block;height:26px;margin-top:8px}
.pos{color:var(--mint)}
.neg{color:#FF6B82}

/* ----- panels ----- */
.panel-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:18px}
.dash-panel{padding:20px;border-radius:var(--r)}
.dash-panel--wide{min-width:0}
.dash-panel__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.dash-panel__head h2{font-size:1.05rem}
.dash-panel__head .muted{color:var(--muted-2);font-weight:500;font-size:.82rem;margin-left:6px}
.small{font-size:.8rem}

/* range segmented */
.seg{display:inline-flex;gap:2px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-radius:999px;padding:3px}
.seg button{border:0;background:transparent;color:var(--muted);font-size:.8rem;font-weight:600;
  padding:5px 11px;border-radius:999px;cursor:pointer;font-family:inherit;transition:.16s}
.seg button.is-active{background:var(--grad);color:#04130E}

.chart-wrap{position:relative;width:100%}
.chart-wrap canvas{width:100%;display:block}
.chart-tip{position:absolute;pointer-events:none;z-index:5;transform:translate(-50%,-110%);
  background:rgba(7,10,16,.94);border:1px solid var(--line-2);border-radius:10px;padding:8px 11px;
  font-size:.78rem;white-space:nowrap;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.chart-tip b{font-variant-numeric:tabular-nums}

.legend{display:flex;gap:18px;margin-top:12px;font-size:.8rem;color:var(--muted)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:1px}
.dot--mint{background:var(--mint)}
.dot--gray{background:#5b6677}

.mini-stats{display:flex;justify-content:space-between;gap:10px;margin-top:14px;
  border-top:1px solid var(--line);padding-top:14px}
.mini-stats div{display:flex;flex-direction:column;gap:3px}
.mini-stats span{font-size:.72rem;color:var(--muted-2)}
.mini-stats b{font-size:1rem;font-variant-numeric:tabular-nums}

/* ----- heatmap ----- */
.heatmap{display:grid;grid-template-columns:repeat(13,1fr);gap:5px}
.heat-cell{aspect-ratio:1;border-radius:6px;display:grid;place-items:center;font-size:.6rem;
  color:rgba(255,255,255,.75);position:relative;cursor:default;border:1px solid rgba(255,255,255,.04)}
.heat-cell.head{background:none;color:var(--muted-2);font-size:.66rem;border:0}
.heat-cell[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:115%;left:50%;
  transform:translateX(-50%);background:rgba(7,10,16,.95);border:1px solid var(--line-2);
  border-radius:7px;padding:5px 8px;font-size:.72rem;white-space:nowrap;color:var(--text);z-index:6}
.heat-scale{display:flex;align-items:center;gap:8px;justify-content:flex-end;margin-top:12px;
  font-size:.72rem;color:var(--muted-2)}
.heat-grad{width:120px;height:8px;border-radius:5px;
  background:linear-gradient(90deg,#FF6B82,#3a2230 45%,#143a32 55%,#00E5A8)}

/* ----- donut + alloc ----- */
.donut-wrap{position:relative;width:180px;height:180px;margin:6px auto 14px}
.donut-wrap canvas{width:180px;height:180px;display:block}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-center b{font-size:1.4rem;font-weight:800}
.donut-center span{font-size:.72rem;color:var(--muted-2)}
.alloc-list{display:flex;flex-direction:column;gap:9px}
.alloc-list li{display:flex;align-items:center;gap:10px;font-size:.86rem}
.alloc-list .sw{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.alloc-list .nm{color:var(--text)}
.alloc-list .pct{margin-left:auto;color:var(--muted);font-variant-numeric:tabular-nums}

/* ----- tables ----- */
.table-scroll{overflow-x:auto}
.dash-table{width:100%;border-collapse:collapse;font-size:.86rem;min-width:560px}
.dash-table th,.dash-table td{padding:11px 12px;text-align:left;white-space:nowrap}
.dash-table thead th{color:var(--muted-2);font-weight:600;font-size:.76rem;letter-spacing:.02em;
  border-bottom:1px solid var(--line)}
.dash-table tbody tr{border-bottom:1px solid rgba(255,255,255,.05)}
.dash-table tbody tr:hover{background:rgba(255,255,255,.025)}
.dash-table .num{text-align:right;font-variant-numeric:tabular-nums}
.tk{font-weight:700}
.tk small{display:block;font-weight:400;color:var(--muted-2);font-size:.72rem}
.pill{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.03em}
.pill--buy{color:#04130E;background:var(--mint)}
.pill--sell{color:#fff;background:#FF6B82}
.pill--long{color:#04130E;background:var(--mint)}
.pill--short{color:#fff;background:#FF6B82}
.pill--on{color:var(--mint);background:rgba(0,229,168,.12);border:1px solid rgba(0,229,168,.25)}
.pill--paused{color:var(--muted);background:rgba(255,255,255,.06)}

/* ----- KPI 강조 카드 ----- */
.kpi-card--hl{border-color:rgba(0,229,168,.3);
  background:
    radial-gradient(120% 120% at 100% 0%,rgba(0,229,168,.12),transparent 55%),
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02))}

/* ----- 체결내역 블라인드 ----- */
.blind-wrap{position:relative}
.blind-target{filter:blur(7px) saturate(.7);opacity:.5;pointer-events:none;user-select:none;max-height:360px;overflow:hidden}
.blind-overlay{position:absolute;inset:0;display:grid;place-items:center;
  background:radial-gradient(ellipse at center,rgba(7,10,16,.35),rgba(7,10,16,.7))}
.blind-card{text-align:center;max-width:380px;padding:22px}
.blind-ic{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:50%;
  color:var(--mint);background:rgba(0,229,168,.1);border:1px solid rgba(0,229,168,.28);margin-bottom:14px}
.blind-title{font-size:1.08rem;font-weight:700;margin-bottom:8px}
.blind-sub{color:var(--muted);font-size:.9rem;margin-bottom:18px;line-height:1.55}

.dash-disclaimer{margin-top:24px;padding:16px 18px;border:1px solid rgba(255,193,77,.25);
  background:rgba(255,193,77,.05);border-radius:var(--r);color:var(--muted);font-size:.84rem;line-height:1.6}
.dash-disclaimer strong{color:#FFCF6B}

/* ----- responsive ----- */
@media (max-width:1080px){
  .kpi-row{grid-template-columns:repeat(3,1fr)}
  .panel-grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .dash-body{grid-template-columns:1fr}
  .dash-side{position:relative;height:auto;flex-direction:row;align-items:center;gap:14px;
    border-right:0;border-bottom:1px solid var(--line);padding:12px 16px;overflow-x:auto}
  .dash-side__brand{margin:0 8px 0 0}
  .dash-nav{flex-direction:row;gap:4px}
  .dash-nav__item{padding:8px 11px;white-space:nowrap}
  .dash-nav__item .ic{display:none}
  .dash-side__back{margin:0 0 0 auto;white-space:nowrap}
  .dash-main{padding:18px 16px 50px}
}
@media (max-width:560px){
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .heatmap{grid-template-columns:repeat(13,1fr);gap:3px}
}
