/* components.css – Cards, KPIs, progress bars, badges, filter bar, tabs, region cards, insight cards, forecast banner */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  transition:var(--t)
}
.card:hover{border-color:var(--cyan);box-shadow:0 0 15px color-mix(in srgb, var(--cyan) 25%, transparent)}
.ct{
  font-family:'Syne',sans-serif;
  font-size:12px;
  font-weight:700;
  color:var(--text-secondary);
  text-transform:uppercase;
  letter-spacing:.9px;
  margin-bottom:16px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap
}
.ct span{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:400;color:var(--text-muted);text-transform:none;letter-spacing:0}

.kpig{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-bottom:20px
}
.kc{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  transition:var(--t);
  cursor:default
}
.kc::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.06) 0%,rgba(255,255,255,0.02) 40%,transparent 50%);
  pointer-events:none;
  z-index:1
}
.kc::after{
  content:'';
  position:absolute;
  right:-20px;
  top:-20px;
  width:90px;
  height:90px;
  border-radius:50%;
  opacity:.07
}
.kc.g::after{background:var(--green)}
.kc.gold::after{background:var(--gold)}
.kc.r::after{background:var(--red)}
.kc.b::after{background:var(--blue)}
.kc.c::after{background:var(--cyan)}
.kc.p::after{background:var(--purple)}
.kc.or::after{background:var(--orange)}
@keyframes shine{0%{transform:translateX(-100%) skewX(-20deg)}100%{transform:translateX(200%) skewX(-20deg)}}
.kc:hover::before{animation:shine .8s ease}
.kc:hover{transform:translateY(-3px);border-color:var(--cyan);box-shadow:0 8px 24px color-mix(in srgb, var(--cyan) 15%, transparent), 0 0 12px color-mix(in srgb, var(--cyan) 30%, transparent)}
.ki{
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:19px;
  margin-bottom:12px
}
.ki.g{background:color-mix(in srgb, var(--green) 15%, transparent);color:var(--green)}
.ki.gold{background:color-mix(in srgb, var(--gold) 15%, transparent);color:var(--gold)}
.ki.r{background:color-mix(in srgb, var(--red) 15%, transparent);color:var(--red)}
.ki.b{background:color-mix(in srgb, var(--blue) 15%, transparent);color:var(--blue)}
.ki.c{background:color-mix(in srgb, var(--cyan) 15%, transparent);color:var(--cyan)}
.ki.p{background:color-mix(in srgb, var(--purple) 15%, transparent);color:var(--purple)}
.ki.or{background:color-mix(in srgb, var(--orange) 15%, transparent);color:var(--orange)}
.klbl{font-size:10.5px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.7px;margin-bottom:5px}
.kval{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;line-height:1.05;margin-bottom:7px}
.kval.g{color:var(--green2)}.kval.gold{color:var(--gold2)}.kval.r{color:var(--red)}.kval.b{color:var(--blue2)}.kval.c{color:var(--cyan)}.kval.p{color:#ce93d8}
.ksub{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.kbadge{
  display:inline-flex;
  align-items:center;
  gap:2px;
  padding:2px 7px;
  border-radius:20px;
  font-size:10px;
  font-weight:700
}
.kbadge.up{background:color-mix(in srgb, var(--green) 15%, transparent);color:var(--green)}
.kbadge.dn{background:color-mix(in srgb, var(--red) 15%, transparent);color:var(--red)}
.kbadge.gold{background:color-mix(in srgb, var(--gold) 15%, transparent);color:var(--gold)}
.kbadge.or{background:color-mix(in srgb, var(--orange) 15%, transparent);color:var(--orange)}

.pb{margin-bottom:12px}
.pb-hdr{display:flex;justify-content:space-between;margin-bottom:5px;font-size:12px}
.pb-track{height:6px;background:var(--bg-base);border-radius:10px;overflow:hidden}
.pb-fill{height:100%;border-radius:10px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}

.badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px 9px;
  border-radius:20px;
  font-size:11px;
  font-weight:600
}
.bdot{width:6px;height:6px;border-radius:50%}
.badge.paid{background:color-mix(in srgb, var(--green) 15%, transparent);color:var(--green)}
.badge.paid .bdot{background:var(--green)}
.badge.notpaid{background:color-mix(in srgb, var(--orange) 15%, transparent);color:var(--orange)}
.badge.notpaid .bdot{background:var(--orange)}
.badge.unbilled{background:color-mix(in srgb, var(--red) 15%, transparent);color:var(--red)}
.badge.unbilled .bdot{background:var(--red)}

.fbar{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:12px 16px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:18px;
  box-shadow:0 2px 12px rgba(0,0,0,.08)
}
.flbl{font-size:9.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;opacity:.8}
.fsel{
  background:var(--bg-card2);
  border:1px solid var(--border);
  color:var(--text-secondary);
  padding:6px 28px 6px 10px;
  border-radius:var(--radius-sm);
  font-size:12px;
  font-family:'DM Sans',sans-serif;
  outline:none;
  cursor:pointer;
  transition:var(--t);
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238da6c8'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 8px center;
  background-size:10px 6px;
  min-width:90px
}
.fsel:hover{border-color:var(--gold);background-color:var(--bg-hover)}
.fsel:focus{border-color:var(--gold);box-shadow:0 0 0 2px color-mix(in srgb, var(--gold) 15%, transparent)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{
  padding:5px 13px;
  border-radius:20px;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  border:1px solid var(--border);
  background:var(--bg-card2);
  color:var(--text-secondary);
  transition:var(--t);
  user-select:none
}
.chip:hover,.chip.on{background:color-mix(in srgb, var(--gold) 15%, transparent);border-color:var(--gold);color:var(--gold)}

.tabnav{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:18px}
.tbtn{
  padding:9px 16px;
  font-size:12px;
  font-weight:600;
  color:var(--text-muted);
  cursor:pointer;
  border-bottom:2px solid transparent;
  transition:var(--t);
  border-radius:var(--radius-sm) var(--radius-sm) 0 0
}
.tbtn:hover{color:var(--text-secondary)}
.tbtn.on{color:var(--gold);border-bottom-color:var(--gold)}
.tpanel{display:none}.tpanel.on{display:block}

.rgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}
.rcard{
  background:var(--bg-card2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:15px;
  cursor:pointer;
  transition:var(--t);
  position:relative;
  overflow:hidden
}
.rcard:hover,.rcard.sel{border-color:var(--gold);background:color-mix(in srgb, var(--gold) 5%, transparent)}
.rn{font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:4px}
.rv{font-family:'Syne',sans-serif;font-size:19px;font-weight:800;margin-bottom:3px}
.rp{font-size:10px;color:var(--text-muted)}
.rb{position:absolute;bottom:0;left:0;height:3px;border-radius:0 3px 0 0;transition:width 1s ease}

.ins{
  background:linear-gradient(135deg,color-mix(in srgb, var(--gold) 9%, transparent),color-mix(in srgb, var(--gold) 3%, transparent));
  border:1px solid color-mix(in srgb, var(--gold) 20%, transparent);
  border-radius:var(--radius);
  padding:16px;
  margin-bottom:12px;
  transition:var(--t)
}
.ins:hover{border-color:color-mix(in srgb, var(--gold) 35%, transparent)}
.ins-hdr{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:10.5px;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:1.1px}
.ins-body{font-size:12.5px;color:var(--text-secondary);line-height:1.65}
.ins-val{font-family:'Syne',sans-serif;font-weight:700;color:var(--text-primary)}

.fcbanner{
  background:linear-gradient(90deg,color-mix(in srgb, var(--cyan) 12%, transparent),color-mix(in srgb, var(--cyan) 3%, transparent));
  border:1px solid color-mix(in srgb, var(--cyan) 25%, transparent);
  border-radius:var(--radius-sm);
  padding:11px 16px;
  margin-bottom:18px;
  font-size:12px;
  color:var(--cyan);
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:500
}

/* ── Extracted from index.html inline styles ── */
.hbtn-cyan{border-color:color-mix(in srgb, var(--cyan) 40%, transparent);color:var(--cyan)}
.hbtn-cyan:hover{border-color:var(--cyan);color:var(--cyan)}
.hbtn-gold{border-color:color-mix(in srgb, var(--gold) 40%, transparent);color:var(--gold)}
.kc-pad{padding:18px}
.ki-sm{width:36px;height:36px;font-size:16px}
.kval-lg{font-size:20px}
.flbl-offset{margin-left:14px}
.kpig-4{grid-template-columns:repeat(4,1fr)}
.kpig-3{grid-template-columns:repeat(3,1fr)}
.ct-mb10{margin-bottom:10px}
.kval.or{color:var(--orange)}
.tx-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.tx-page-info{font-size:11px;color:var(--text-muted)}
#tx-sum-btn{margin-left:auto;color:var(--gold)}
#theme-icon{color:var(--gold)}
.export-icon{color:var(--gold)}

/* ── PnL glass filter panel ── */
.pnl-glass-panel {
  max-height:0;
  overflow:hidden;
  transition:max-height 0.3s ease, opacity 0.2s ease 0.05s, margin-bottom 0.3s ease;
  opacity:0;
  margin-bottom:0
}
.pnl-glass-panel.open {
  max-height:120px;
  opacity:1;
  margin-bottom:10px
}
.pnl-glass-inner {
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:14px;
  background:rgba(15,23,42,0.5);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 8px 32px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.04) inset, 0 0 20px rgba(212,168,67,0.08)
}
.pnl-glass-inner:hover{border-color:rgba(255,255,255,0.14);box-shadow:0 8px 32px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.06) inset, 0 0 30px rgba(212,168,67,0.15)}
.pnl-glass-inner .flbl{color:var(--text-muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.pnl-glass-inner .fsel.glass {
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  color:var(--text-primary);
  border-radius:6px;
  padding:5px 24px 5px 8px;
  font-size:12px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  cursor:pointer;
  transition:border-color .2s
}
.pnl-glass-inner .fsel.glass:hover{border-color:rgba(255,255,255,0.2)}
.pnl-glass-inner .fsel.glass:focus{outline:none;border-color:var(--gold)}
.pnl-glass-inner .fsel.glass option{background:#1a1f2e;color:#e8edf5}
#pnl-flt-toggle{transition:color .25s ease, border-color .25s ease}.pnl-glass-inner .flbl{transition:color .25s ease}.pnl-glass-inner .csel-trigger{transition:color .25s ease}
#pnl-flt-toggle.open .export-icon{display:inline-block;transform:rotate(180deg)}
#pnl-clear-btn{transition:var(--t)}#pnl-clear-btn:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 12px rgba(231,76,60,.2)}
#pnl-clear-btn:active{transform:scale(.92)}

/* ── Custom glass select ── */
.csel{position:relative;display:inline-block;min-width:90px}
.csel-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:6px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);
  color:var(--text-primary);border-radius:8px;padding:5px 8px;font-size:12px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  cursor:pointer;transition:border-color .2s, box-shadow .2s;
  user-select:none;white-space:nowrap
}
.csel-trigger:hover{border-color:rgba(255,255,255,0.2)}
.csel.open .csel-trigger{border-color:var(--gold);box-shadow:0 0 0 2px rgba(212,168,67,0.15)}
.csel-arrow{font-size:8px;color:var(--text-muted);transition:transform .25s;line-height:1}
.csel.open .csel-arrow{transform:rotate(180deg)}
.csel-drop{
  padding:4px;border-radius:10px;
  background:rgba(15,23,42,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1);
  box-shadow:0 12px 48px rgba(0,0,0,0.6), 0 0 40px rgba(212,168,67,0.08);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s ease
}
.csel-drop.open{opacity:1;visibility:visible;transform:translateY(0)}
.csel-opt{
  padding:7px 10px;border-radius:6px;font-size:12px;color:var(--text-secondary);
  cursor:pointer;transition:background .15s, color .15s;white-space:nowrap
}
.csel-opt:hover{background:rgba(255,255,255,0.08);color:var(--text-primary)}
.csel-opt.sel{background:rgba(212,168,67,0.15);color:var(--gold);font-weight:600}
.csel-opt+.csel-opt{margin-top:1px}

/* light mode overrides for PnL filter bar & custom selects */
body.lm .pnl-glass-inner {
  background:rgba(248,250,252,0.85);
  border-color:rgba(0,0,0,0.06);
  box-shadow:0 4px 16px rgba(0,0,0,0.04), 0 0 0 1px rgba(0,0,0,0.03) inset, 0 0 20px rgba(212,168,67,0.04)
}
body.lm .pnl-glass-inner:hover {
  border-color:rgba(0,0,0,0.1);
  box-shadow:0 4px 20px rgba(0,0,0,0.06), 0 0 0 1px rgba(0,0,0,0.04) inset, 0 0 30px rgba(212,168,67,0.08)
}
body.lm .pnl-glass-inner .fsel.glass {
  background:rgba(0,0,0,0.03);
  border-color:rgba(0,0,0,0.1);
  color:#0f172a;
}
body.lm .pnl-glass-inner .fsel.glass:hover{border-color:rgba(0,0,0,0.18)}
body.lm .pnl-glass-inner .fsel.glass option{background:#fff;color:#0f172a}
body.lm .csel-trigger {
  background:rgba(0,0,0,0.03);
  border-color:rgba(0,0,0,0.1);
  color:#0f172a;
}
body.lm .csel-trigger:hover{border-color:rgba(0,0,0,0.18)}
body.lm .csel-drop {
  background:rgba(255,255,255,0.95);
  border-color:rgba(0,0,0,0.1);
  box-shadow:0 12px 48px rgba(0,0,0,0.12), 0 0 40px rgba(212,168,67,0.03);
}
body.lm .csel-opt{color:rgba(0,0,0,0.6)}
body.lm .csel-opt:hover{background:rgba(0,0,0,0.04);color:rgba(0,0,0,0.85)}

/* Custom Floating Tooltip Card */
.custom-floating-tooltip {
  position: fixed;
  z-index: 999999;
  pointer-events: none;
  background: var(--bg-card-tooltip);
  border: 1px solid var(--border-tooltip);
  border-radius: 8px;
  padding: 6px 12px;
  color: var(--text-primary);
  font-family: 'DM Sans', sans-serif;
  font-size: 11.5px;
  font-weight: 600;
  box-shadow: var(--shadow-tooltip);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  transform: translateY(4px) scale(0.98);
  transition: opacity 0.12s cubic-bezier(0.4, 0, 0.2, 1), transform 0.12s cubic-bezier(0.4, 0, 0.2, 1);
  display: none;
  white-space: nowrap;
}