/* VAULT — Utility & Component Styles (non-dashboard tabs)
   Variables defined in /css/vault-pro.css */

/* ── Layout ── */
.main{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:28px 28px 60px}

/* ── Grid layouts ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.g5{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
@media(max-width:1100px){.g3,.g4{grid-template-columns:1fr 1fr}}
@media(max-width:800px){.g2,.g3,.g4{grid-template-columns:1fr}.main{padding:12px}}

/* ── Stat cards ── */
.sc{background:var(--s1);border:1px solid var(--border);border-radius:14px;padding:10px 12px;transition:all .3s;position:relative;overflow:hidden}
.sc:hover{border-color:var(--accent);transform:translateY(-1px)}
.sc .lb{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}
.sc .vl{font-family:var(--font-mono);font-size:16px;font-weight:700;margin-bottom:1px}
.sc .ch{font-family:var(--font-mono);font-size:10px;font-weight:500}
.sc .spark{position:absolute;bottom:0;right:0;width:70px;height:28px;opacity:.35;pointer-events:none}

/* ── Legacy card (mapped: .card → .pro-card in Step 7) ── */
.card{background:var(--s1);border:1px solid var(--border);border-radius:14px;padding:18px;transition:all .25s ease;margin-bottom:14px}
.card:hover{border-color:var(--borderH)}
.card-t{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* ── Hero (non-dashboard) ── */
.hero{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(34,211,238,.04));border:1px solid rgba(59,130,246,.2);border-radius:14px;padding:16px 20px;margin-bottom:10px;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(59,130,246,.06) 0%,transparent 70%);pointer-events:none}
.hero .h-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.hero .h-val{font-family:var(--font-mono);font-size:36px;font-weight:800;color:var(--text);line-height:1.1;letter-spacing:-1px}
.hero .h-sub{display:flex;gap:14px;margin-top:6px;flex-wrap:wrap}
.hero .h-tag{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px}

/* ── Regime (non-dashboard) ── */
.regime{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:14px;margin-bottom:10px;font-size:11px;font-weight:600;border:1px solid var(--border);background:var(--s1)}
.regime .r-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}
.regime .r-label{flex:1}.regime .r-score{font-family:var(--font-mono);font-size:10px;opacity:.7}
.regime .r-time{font-family:var(--font-mono);font-size:9px;color:var(--muted);margin-left:auto}

/* ── Market status ── */
.mkt-status{display:flex;gap:8px;font-size:8px;color:var(--muted);margin-left:12px}
.mkt-status span{display:flex;align-items:center;gap:3px}
.mkt-status .mkt-dot{width:5px;height:5px;border-radius:50%}
.mkt-status .mkt-open{background:var(--pos);box-shadow:0 0 4px rgba(52,211,153,.5)}
.mkt-status .mkt-closed{background:var(--neg);opacity:.5}

/* ── Utility ── */
.pos{color:var(--pos)}.neg{color:var(--neg)}

/* ── Fear & Greed (non-dashboard) ── */
.fg-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 0}
.fg-gauge{position:relative;width:160px;height:90px;overflow:hidden}.fg-gauge svg{width:160px;height:90px}
.fg-label{font-size:22px;font-family:var(--font-mono);font-weight:700}
.fg-text{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px}

/* ── Ticker list ── */
.tk{display:flex;flex-direction:column;gap:6px}
.tk-i{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;background:var(--s1);border-radius:8px;border:1px solid transparent;transition:all .2s}
.tk-i:hover{border-color:var(--border)}
.tk-n .sym{font-family:var(--font-mono);font-size:11px;font-weight:600}
.tk-n .nm{font-size:9px;color:var(--muted)}
.tk-p{text-align:right}
.tk-p .pr{font-family:var(--font-mono);font-size:11px;font-weight:600}
.tk-p .pc{font-family:var(--font-mono);font-size:10px;font-weight:500}

/* ── Tables ── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:5px 7px;border-bottom:1px solid var(--border);font-weight:500}
.tbl td{padding:6px 7px;font-size:11px;border-bottom:1px solid var(--border);font-family:var(--font-mono)}
.tbl tr:hover td{background:var(--s2)}
.broker-row:hover td{background:var(--s3)!important}.broker-row td{padding:8px 7px;transition:background .15s}

/* ── Forms ── */
.frm{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;padding:10px;background:var(--s1);border-radius:8px;margin-top:10px}
.fg{display:flex;flex-direction:column;gap:3px}.fg label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select{padding:5px 8px;background:var(--s2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-mono);font-size:11px;outline:none}
.fg input:focus,.fg select:focus{border-color:var(--accent)}

/* ── Chart container ── */
.ch-c{position:relative;height:220px;margin-top:4px}

/* ── Page animation ── */
.pg{display:none}.pg.on{display:block;animation:fi .3s ease}
@keyframes fi{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── Tags ── */
.tag{display:inline-block;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:600;font-family:var(--font-mono)}
.tag-c{background:rgba(249,115,22,.12);color:#f97316}
.tag-s{background:rgba(59,130,246,.12);color:var(--accent)}
.tag-e{background:rgba(6,182,212,.12);color:var(--cyan)}
.tag-m{background:rgba(245,158,11,.12);color:var(--warn)}
.tag-r{background:rgba(167,139,250,.12);color:var(--prem)}
.tag-ca{background:rgba(52,211,153,.12);color:var(--pos)}
.tag-al{background:rgba(236,72,153,.12);color:#ec4899}

/* ── Sort headers ── */
.sortH{cursor:pointer;user-select:none;white-space:nowrap}.sortH:hover{color:var(--cyan)}
.sortH.asc::after{content:' ▲';font-size:8px}.sortH.desc::after{content:' ▼';font-size:8px}

/* ── Modal ── */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center}
.mo.on{display:flex}
.mo-c{background:var(--s1);border:1px solid var(--border);border-radius:14px;padding:22px;max-width:440px;width:90%}
.mo-c h3{font-size:15px;margin-bottom:8px}
.mo-c p{font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:12px}
.mo-a{display:flex;gap:8px;justify-content:flex-end}

/* ── Toast ── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--s2);border:1px solid var(--pos);border-radius:8px;padding:7px 14px;font-size:11px;color:var(--pos);z-index:300;opacity:0;transform:translateY(8px);transition:all .3s;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0)}

/* ── Empty state ── */
.empty{text-align:center;padding:20px 12px;color:var(--muted);font-size:12px}

/* ── Sliders ── */
.slider-wrap{display:flex;flex-direction:column;gap:3px;flex:1;min-width:160px}
.slider-wrap label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.slider-wrap input[type=range]{-webkit-appearance:none;width:100%;height:5px;border-radius:3px;background:var(--s3);outline:none}
.slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}
.slider-val{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--cyan)}

/* ── Info panel ── */
.pi{background:rgba(52,211,153,.04);border:1px solid rgba(52,211,153,.12);border-radius:14px;padding:14px;margin-bottom:14px;display:flex;gap:10px;font-size:11px;color:var(--text2);line-height:1.7}
.pi strong{color:var(--pos)}

/* ── Dominance bar ── */
.dom-bar{height:24px;border-radius:6px;overflow:hidden;display:flex;margin:5px 0}
.dom-bar div{height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;font-family:var(--font-mono)}

/* ── Energy price ── */
.energy-price{display:flex;align-items:baseline;gap:5px}
.energy-price .ep-val{font-family:var(--font-mono);font-size:26px;font-weight:700}
.energy-price .ep-unit{font-size:11px;color:var(--muted)}

/* ── Macro signal cards ── */
.ms{background:var(--s1);border:1px solid var(--border);border-radius:14px;padding:16px;position:relative;overflow:hidden}
.ms:hover{border-color:rgba(59,130,246,.25)}
.ms .ms-h{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.ms .ms-title{font-size:10px;font-weight:600;color:var(--text2)}
.ms .ms-badge{font-size:8px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-mono)}
.ms .ms-val{font-family:var(--font-mono);font-size:28px;font-weight:700;line-height:1.1;margin-bottom:3px}
.ms .ms-sub{font-size:10px;color:var(--muted);margin-bottom:6px}
.ms .ms-bar{height:8px;border-radius:4px;width:100%;position:relative;margin:8px 0 4px}
.ms .ms-needle{position:absolute;top:-3px;width:3px;height:14px;background:var(--text);border-radius:2px;transition:left .6s;box-shadow:0 0 6px rgba(255,255,255,.3)}
.ms .ms-bar-labels{display:flex;justify-content:space-between;font-size:7px;color:var(--muted)}
.ms .ms-explain{font-size:9px;color:var(--text2);line-height:1.5;margin-top:6px;padding:6px 8px;background:var(--s1);border-radius:6px;border-left:2px solid var(--accent)}

/* ── Section header ── */
.sec-h{font-size:13px;font-weight:700;color:var(--text);margin:18px 0 10px;display:flex;align-items:center;gap:8px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.sec-h:first-child{margin-top:0}

/* ── Rainbow bar (macro indicators) ── */
.rainbow-bar{display:flex;height:30px;border-radius:6px;overflow:hidden;margin:6px 0;position:relative}
.rainbow-bar div{flex:1;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:600;color:rgba(0,0,0,.7)}
.rainbow-needle{position:absolute;top:-3px;width:3px;height:36px;background:#fff;border-radius:2px;box-shadow:0 0 8px rgba(255,255,255,.5);transition:left .6s}

/* ── Settings row ── */
.stg-row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;margin-bottom:12px}.stg-row .fg{flex:1;min-width:200px}

/* ── Input spin buttons ── */
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}

/* ── Animations ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ── Legacy button variants (used by other tabs) ── */
.btn-p{background:linear-gradient(135deg,var(--accent),#1d4ed8);border:none;color:#fff}.btn-p:hover{opacity:.9}
.btn-d{border-color:rgba(248,113,113,.25);color:var(--neg)}.btn-d:hover{background:rgba(248,113,113,.08)}

/* ── Responsive ── */
@media(max-width:768px){
  .g2,.g3,.g4{grid-template-columns:1fr !important}
  .g5{grid-template-columns:repeat(2,1fr) !important}
  .hero{grid-template-columns:1fr;padding:12px 14px}
  .hero .h-val{font-size:26px}
  .regime{flex-wrap:wrap;font-size:10px;padding:6px 10px}
  .mkt-status{margin-left:0;width:100%;margin-top:4px}
  .card,.pro-card{padding:10px}
  .frm{flex-direction:column}
  .frm .fg{width:100%}
  .ms .ms-val{font-size:22px}
  .tbl{font-size:10px}
  .tbl th,.tbl td{padding:4px 5px}
  .ch-c{height:180px !important}
  .sec-h{font-size:12px}
  .sc .vl{font-size:14px}
}
