/* ─────────────────────────────────────────────────────────────────
   VCC Whitelabel Console — built on the codegotech.com design system.
   Editorial / Swiss: warm paper bg, sharp 1px rules, Inter Tight display,
   JetBrains Mono uppercase labels. Accent = green (live) / azure (sandbox).
   ───────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&family=Sora:wght@500;600;700&family=IBM+Plex+Mono:wght@500;600;700&family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&display=swap');

:root{
  --bg:#FFFFFF; --bg-2:#F2F1ED; --bg-3:#E6E5DF;
  --ink:#0A0A0A; --ink-2:#2B2B2B; --ink-3:#565656; --ink-mute:#8A8A8A;
  --rule:#DAD8D0; --rule-2:#1A1A1A;
  --acc:#1A6B43; --acc-d:#0E4D2C;            /* live = green */
  --ok:#1A6B43; --warn:#9A6B00; --danger:#B91C1C;
  --f-disp:'Inter Tight','Inter',system-ui,sans-serif;
  --f-body:'Inter',system-ui,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
:root[data-env="sandbox"]{ --acc:#1668C9; --acc-d:#0E4A9C; }  /* sandbox = azzurro */

*{box-sizing:border-box}
/* The hidden attribute must always win — otherwise .login{display:grid} /
   .app rules keep sections visible after toggling (login wouldn't hide). */
[hidden]{display:none !important}
html,body{margin:0;padding:0}
body{font-family:var(--f-body);background:var(--bg-2);color:var(--ink);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit}

/* mono label / kicker */
.kicker{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}

/* buttons (codegotech .btn) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--f-mono);font-size:11.5px;
  letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:14px 22px;border:1px solid var(--ink);
  background:transparent;color:var(--ink);transition:background .14s,color .14s,border-color .14s}
.btn:hover{background:var(--ink);color:var(--bg)}
.btn-acc{background:var(--acc);color:#fff;border-color:var(--acc)}
.btn-acc:hover{background:var(--ink);border-color:var(--ink)}
.btn-arrow::after{content:"→";font-size:14px}
.btn:disabled{opacity:.5;cursor:default}
.btn-sm{padding:9px 14px;font-size:10.5px}

/* brand lockup */
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{width:18px;height:18px;background:var(--acc);display:inline-block}
.brand-logo{height:24px;width:auto;display:inline-block}
.login-aside .brand-logo{filter:brightness(0) invert(1)}
.brand-name{font-family:var(--f-disp);font-weight:700;font-size:15px;letter-spacing:-.01em}
.brand-tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);
  border-left:1px solid var(--rule);padding-left:12px}

/* ── LOGIN ─────────────────────────────────────────────────────── */
.login{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.login-aside{background:var(--ink);color:var(--bg);padding:48px 52px;display:flex;flex-direction:column;justify-content:space-between}
.login-aside .brand-name{color:var(--bg)}
.login-aside .brand-tag{color:rgba(255,255,255,.55);border-left-color:rgba(255,255,255,.2)}
.la-head{font-family:var(--f-disp);font-weight:800;font-size:clamp(34px,4vw,56px);line-height:.96;letter-spacing:-.045em;margin:0}
.la-head .acc{color:var(--acc)}
.la-lede{color:rgba(255,255,255,.7);font-size:15px;line-height:1.6;max-width:42ch;margin-top:20px}
.la-points{list-style:none;padding:0;margin:28px 0 0;display:flex;flex-direction:column;gap:12px}
.la-points li{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.04em;color:rgba(255,255,255,.82);display:flex;gap:10px}
.la-points li::before{content:"—";color:var(--acc)}
.la-foot{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45)}

.login-main{background:var(--bg);display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:380px}
.login-card .kicker{margin-bottom:10px}
.login-card h2{font-family:var(--f-disp);font-weight:700;font-size:28px;letter-spacing:-.03em;margin:0 0 4px}
.login-card .sub{color:var(--ink-3);font-size:14px;margin:0 0 28px}
form{display:flex;flex-direction:column;gap:16px}
label{display:flex;flex-direction:column;gap:7px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
input[type=email],input[type=password],input[type=text]{font-family:var(--f-body);font-size:15px;padding:13px 14px;
  border:1px solid var(--rule-2);background:var(--bg);color:var(--ink);border-radius:0}
input:focus{outline:none;border-color:var(--acc);box-shadow:inset 0 -2px 0 var(--acc)}
.login-card .btn{width:100%;margin-top:4px}
.divider{display:flex;align-items:center;gap:14px;color:var(--ink-mute);font-family:var(--f-mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;margin:6px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--rule)}
.btn-passkey{width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--rule-2)}
.btn-passkey:hover{background:var(--bg-2);color:var(--ink)}
.btn-passkey svg{width:15px;height:15px}
.cf-turnstile{display:flex;justify-content:center;margin:4px 0}
.err{color:var(--danger);font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;min-height:1em;margin:0}
.ok-msg{color:var(--acc);font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;margin:0}

/* ── APP SHELL ─────────────────────────────────────────────────── */
.app{min-height:100vh;background:var(--bg-2)}
.topbar{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 32px;
  background:var(--bg);border-bottom:1px solid var(--rule-2);position:sticky;top:0;z-index:30}
.topbar-right{display:flex;align-items:center;gap:18px}
.who{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3)}
.env-pill{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:4px 9px;border:1px solid var(--acc);color:var(--acc)}
.tabs{display:flex;gap:0;padding:0 32px;background:var(--bg);border-bottom:1px solid var(--rule);overflow-x:auto}
.tabs button{background:none;border:none;padding:15px 18px;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mute);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;font-weight:500}
.tabs button.active{color:var(--ink);border-bottom-color:var(--acc)}
.tabs button:hover{color:var(--ink-2)}
main{max-width:1180px;margin:0 auto;padding:34px 32px 64px}

.page-title{font-family:var(--f-disp);font-weight:700;font-size:26px;letter-spacing:-.03em;margin:0 0 2px}
.page-sub{color:var(--ink-3);font-size:13.5px;margin:0 0 26px}

/* KPI cards */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;background:var(--rule);
  border:1px solid var(--rule);margin-bottom:26px}
.kpi{background:var(--bg);padding:20px 22px;display:flex;flex-direction:column;gap:10px}
.kpi-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.kpi-val{font-family:var(--f-disp);font-size:30px;font-weight:700;letter-spacing:-.03em;line-height:1}
.kpi-val.sm{font-size:22px}

/* panel */
.panel{background:var(--bg);border:1px solid var(--rule);padding:24px 26px;margin-bottom:22px}
.panel h3{font-family:var(--f-disp);font-weight:700;font-size:16px;letter-spacing:-.02em;margin:0 0 18px}
.ls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:18px 28px;margin-bottom:18px}
.ls-grid > div{display:flex;flex-direction:column;gap:5px}
.ls-grid span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.ls-grid b{font-family:var(--f-disp);font-size:18px;font-weight:600;letter-spacing:-.01em}
.bar{height:6px;background:var(--bg-3);overflow:hidden}
.bar-fill{height:100%;width:0;background:var(--acc);transition:width .5s ease}
.note{color:var(--ink-3);font-size:12.5px;margin:12px 0 0;line-height:1.55}
.meta{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-mute)}
.meta b{color:var(--ink-2);font-weight:600}

/* tables */
table.data{width:100%;border-collapse:collapse;background:var(--bg);border:1px solid var(--rule);font-size:13px}
table.data th{text-align:left;padding:12px 14px;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mute);background:var(--bg-2);border-bottom:1px solid var(--rule);white-space:nowrap}
table.data td{padding:12px 14px;border-bottom:1px solid var(--rule);color:var(--ink-2)}
table.data tr:last-child td{border-bottom:none}
table.data tr:hover td{background:var(--bg-2)}
.badge{display:inline-block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;
  font-weight:600;padding:3px 8px;border:1px solid currentColor}
.badge.ok{color:var(--acc)} .badge.warn{color:var(--warn)} .badge.off{color:var(--ink-mute)}
.empty{color:var(--ink-mute);text-align:center;padding:40px;font-family:var(--f-mono);font-size:12px;letter-spacing:.04em}

/* branding tab */
#tab-branding input[type=text]{font-family:var(--f-body);font-size:14px;padding:10px 12px;border:1px solid var(--rule-2);background:var(--bg);color:var(--ink);width:100%}
#tab-branding input[type=text]:focus{outline:none;border-color:var(--acc);box-shadow:inset 0 -2px 0 var(--acc)}
.br-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:20px}
.br-up{display:flex;flex-direction:column;gap:8px}
.br-up > span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.br-up input[type=file]{font-size:12px}
.br-preview{height:64px;border:1px dashed var(--rule);background:var(--bg-2);display:flex;align-items:center;justify-content:center;padding:8px}
.br-preview img{max-height:48px;max-width:100%}
.br-preview.dark{background:var(--ink)}

/* security / passkey list */
.pk-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--rule)}
.pk-row:last-child{border-bottom:none}
.pk-info b{font-family:var(--f-disp);font-size:14px;font-weight:600}
.pk-info span{display:block;font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;color:var(--ink-mute);margin-top:3px}
.link-danger{background:none;border:none;color:var(--danger);font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}

/* ── OVERVIEW REDESIGN ─────────────────────────────────────────── */
.ov-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.live-dot{display:inline-flex;align-items:center;gap:7px;font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--acc);font-weight:600}
.live-dot::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--acc);
  box-shadow:0 0 0 0 var(--acc);animation:pulse-dot 1.8s infinite}
@keyframes pulse-dot{0%{box-shadow:0 0 0 0 rgba(26,107,67,.5)}70%{box-shadow:0 0 0 7px rgba(26,107,67,0)}100%{box-shadow:0 0 0 0 rgba(26,107,67,0)}}

/* primary hero cards: float + admin wallet */
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border:1px solid var(--rule-2);margin-bottom:22px}
.hero-card{background:var(--ink);color:var(--bg);padding:30px 32px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.hero-card.wallet{background:var(--acc-d)}
.hero-card[role="button"]{cursor:pointer;transition:transform .12s,box-shadow .12s}
.hero-card[role="button"]:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(10,10,10,.18)}
.hero-card[role="button"]:focus-visible{outline:2px solid var(--acc);outline-offset:2px}
.hero-card::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.hero-label{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.hero-val{font-family:var(--f-disp);font-size:clamp(34px,4.4vw,52px);font-weight:800;letter-spacing:-.04em;line-height:.95}
.hero-foot{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.04em;color:rgba(255,255,255,.5)}

/* commitment */
.commit-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.commit-head h3{margin:0}
.commit-period{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-mute);font-weight:400}
.commit-bar{height:10px;background:var(--bg-3);overflow:hidden;position:relative;margin-bottom:20px}
.commit-fill{height:100%;width:0;background:linear-gradient(90deg,var(--acc),var(--acc-d));transition:width .6s ease}
.commit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px 26px}
.commit-stats > div{display:flex;flex-direction:column;gap:5px;border-left:2px solid var(--rule);padding-left:12px}
.commit-stats span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.commit-stats b{font-family:var(--f-disp);font-size:20px;font-weight:700;letter-spacing:-.02em}
.commit-stats b.hl{color:var(--acc)}

/* analytics strip */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;background:var(--rule);
  border:1px solid var(--rule);margin-bottom:22px}
.stat{background:var(--bg);padding:16px 18px;display:flex;flex-direction:column;gap:8px}
.stat span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.stat b{font-family:var(--f-disp);font-size:24px;font-weight:700;letter-spacing:-.02em}
.stat b.sm{font-size:16px}

/* ── WORLD MAP ─────────────────────────────────────────────────── */
.map-panel{padding-bottom:18px}
.map-legend{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);
  display:inline-flex;align-items:center;gap:8px}
.map-legend .lg{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:-3px}
.map-legend .lg-tx{background:var(--acc);box-shadow:0 0 6px var(--acc)}
.map-legend .lg-ch{background:rgba(255,255,255,.35);border:1px solid var(--ink-mute)}
.worldmap{position:relative;width:100%;aspect-ratio:2/1;background:
  radial-gradient(120% 90% at 50% 10%,#16181c,#0A0A0A);overflow:hidden;border:1px solid var(--rule-2)}
#map-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
#map-svg path{fill:#23242a;stroke:#34363d;stroke-width:.4;vector-effect:non-scaling-stroke}
.map-markers{position:absolute;inset:0;pointer-events:none}
.cdot{position:absolute;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.28);
  transform:translate(-50%,-50%);box-shadow:0 0 4px rgba(255,255,255,.25)}
.txdot{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--acc);transform:translate(-50%,-50%);
  box-shadow:0 0 10px var(--acc),0 0 18px var(--acc);z-index:3}
.txdot::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:2px solid var(--acc);
  animation:ping 1.6s ease-out infinite}
@keyframes ping{0%{transform:scale(.6);opacity:.9}100%{transform:scale(3.4);opacity:0}}
.txdot.calm{width:8px;height:8px;box-shadow:0 0 7px var(--acc)}
.txdot.calm::after{animation-duration:3.6s;border-width:1.5px;opacity:.5}
.txlabel{position:absolute;transform:translate(-50%,-150%);background:rgba(10,10,10,.92);color:#fff;
  border:1px solid var(--acc);padding:5px 9px;white-space:nowrap;z-index:4;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.02em;animation:label-in .3s ease}
.txlabel b{color:var(--acc);font-weight:700}
.txlabel .lbl-amt{display:block;font-family:var(--f-disp);font-size:13px;font-weight:700;letter-spacing:-.01em;margin-top:1px}
@keyframes label-in{from{opacity:0;transform:translate(-50%,-120%)}to{opacity:1;transform:translate(-50%,-150%)}}

.map-feed{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;min-height:1px}
.feed-item{display:inline-flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--rule);
  padding:6px 11px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.02em;color:var(--ink-2);
  animation:feed-in .35s ease}
.feed-item .fi-flag{font-size:13px;line-height:1}
.feed-item b{color:var(--ink)}
.feed-item .fi-amt{color:var(--acc);font-weight:700}
@keyframes feed-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.map-hint{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;color:var(--ink-mute);margin:12px 0 0}

/* latest lists (two columns) */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.link-more{background:none;border:none;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--acc);font-weight:600}
.mini-list{display:flex;flex-direction:column}
.mini-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--rule)}
.mini-row:last-child{border-bottom:none}
.mini-row .mr-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.mini-row .mr-main b{font-family:var(--f-disp);font-size:13.5px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-row .mr-main span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.05em;color:var(--ink-mute)}
.mini-row .mr-side{text-align:right;white-space:nowrap}
.mini-row .mr-side b{font-family:var(--f-disp);font-size:14px;font-weight:700;letter-spacing:-.01em}
.mini-row .mr-side span{display:block;font-family:var(--f-mono);font-size:9px;letter-spacing:.04em;color:var(--ink-mute);margin-top:2px}
.mini-empty{color:var(--ink-mute);font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;padding:20px 0;text-align:center}

/* clickable customer rows */
table.data.hover-rows tbody tr{cursor:pointer}
table.data.hover-rows tbody tr:hover td{background:var(--bg-2)}
.badge.danger{color:var(--danger)}
.muted{color:var(--ink-mute)}

/* ── CUSTOMER PROFILE DRAWER ───────────────────────────────────── */
.ch-modal{position:fixed;inset:0;z-index:60}
.ch-backdrop{position:absolute;inset:0;background:rgba(10,10,10,.45);backdrop-filter:blur(2px);animation:fade-in .2s ease}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
.ch-drawer{position:absolute;top:0;right:0;height:100%;width:min(560px,94vw);background:var(--bg);
  border-left:1px solid var(--rule-2);display:flex;flex-direction:column;animation:slide-in .24s ease;box-shadow:-12px 0 40px rgba(10,10,10,.18)}
@keyframes slide-in{from{transform:translateX(100%)}to{transform:translateX(0)}}
.ch-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 28px;border-bottom:1px solid var(--rule)}
.ch-drawer-head h2{font-family:var(--f-disp);font-weight:700;font-size:22px;letter-spacing:-.03em;margin:4px 0 0}
.ch-close{background:none;border:1px solid var(--rule-2);width:34px;height:34px;font-size:14px;color:var(--ink);flex:none}
.ch-close:hover{background:var(--ink);color:var(--bg)}
.ch-drawer-body{padding:8px 28px 40px;overflow-y:auto}
.ch-sec{padding:20px 0;border-bottom:1px solid var(--rule)}
.ch-sec:last-child{border-bottom:none}
.ch-sec h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 14px}
.ch-row{display:flex;justify-content:space-between;gap:18px;padding:7px 0;font-size:13.5px;align-items:baseline}
.ch-row > span{color:var(--ink-mute);font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;flex:none;min-width:120px}
.ch-row > b{font-weight:600;text-align:right;word-break:break-word}
.ch-row code{font-family:var(--f-mono);font-size:11px;background:var(--bg-2);padding:2px 6px;word-break:break-all}
.ch-card{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid var(--rule);margin-bottom:8px;background:var(--bg-2)}
.ch-pan{font-family:var(--f-mono);font-size:13px;font-weight:600;letter-spacing:.06em}
.ch-pill{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--rule-2);padding:2px 7px}
.ch-exp{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--ink-mute)}
.ch-empty{color:var(--ink-mute);font-family:var(--f-mono);font-size:11.5px;letter-spacing:.03em;padding:6px 0}
.ch-drawer-body table.data{margin-top:4px;font-size:12px}
.ch-drawer-body table.data th,.ch-drawer-body table.data td{padding:8px 10px}

/* ── GLOBAL SEARCH (topbar) ────────────────────────────────────── */
.gsearch{position:relative;display:flex;align-items:center}
.gsearch-ico{width:15px;height:15px;color:var(--ink-mute);position:absolute;left:11px;pointer-events:none}
#gsearch-input{font-family:var(--f-body);font-size:13px;padding:8px 12px 8px 32px;border:1px solid var(--rule-2);
  background:var(--bg);color:var(--ink);width:240px;border-radius:0}
#gsearch-input:focus{outline:none;border-color:var(--acc);box-shadow:inset 0 -2px 0 var(--acc)}
.gsearch-results{position:absolute;top:calc(100% + 6px);right:0;width:340px;max-height:60vh;overflow-y:auto;
  background:var(--bg);border:1px solid var(--rule-2);box-shadow:0 12px 32px rgba(10,10,10,.18);z-index:50}
.gs-group{font-family:var(--f-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);
  padding:10px 14px 6px;border-bottom:1px solid var(--rule)}
.gs-item{display:flex;align-items:center;gap:11px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--rule)}
.gs-item:hover{background:var(--bg-2)}
.gs-ava{width:28px;height:28px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--acc);
  color:#fff;font-family:var(--f-disp);font-weight:700;font-size:12px;border-radius:50%}
.gs-t{min-width:0}
.gs-t b{display:block;font-family:var(--f-disp);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gs-t span{font-family:var(--f-mono);font-size:9.5px;color:var(--ink-mute);letter-spacing:.03em}
.gs-empty{padding:18px;text-align:center;font-family:var(--f-mono);font-size:11px;color:var(--ink-mute)}

/* ── TRANSACTIONS TABLE ────────────────────────────────────────── */
table.data .ar{text-align:right}
table.data td.mono{font-family:var(--f-mono);font-size:12px;color:var(--ink-3)}
.tx-merch{display:flex;align-items:center;gap:11px}
.m-logo{position:relative;width:30px;height:30px;flex:none;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--rule);background:var(--bg-2);overflow:hidden}
.m-logo .m-ico{font-size:15px;line-height:1}
.m-logo img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#fff;padding:3px}
.tx-merch-t{min-width:0}
.tx-merch-t b{display:block;font-family:var(--f-disp);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.tx-merch-t span{font-family:var(--f-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}
.tx-pan{font-family:var(--f-mono);font-size:11.5px;color:var(--ink-2)}
.tx-cat{font-size:12.5px;white-space:nowrap}
.tx-credit{color:var(--ok)} .tx-debit{color:var(--danger)}
.tx-local{display:block;font-family:var(--f-mono);font-size:9.5px;color:var(--ink-mute);margin-top:2px}

/* ── SPEND-BY-CATEGORY CHART ───────────────────────────────────── */
.cat-chart{display:flex;flex-direction:column;gap:11px}
.cat-row{display:grid;grid-template-columns:24px 130px 1fr 130px;align-items:center;gap:12px}
.cat-ico{font-size:16px;text-align:center}
.cat-name{font-family:var(--f-disp);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-name small{display:block;font-family:var(--f-mono);font-size:9px;font-weight:400;color:var(--ink-mute);letter-spacing:.04em}
.cat-bar{height:10px;background:var(--bg-3);position:relative;overflow:hidden}
.cat-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--acc),var(--acc-d));transition:width .6s ease}
.cat-amt{text-align:right;font-family:var(--f-disp);font-size:14px;font-weight:700;letter-spacing:-.01em}
.cat-amt small{font-family:var(--f-mono);font-size:10px;font-weight:400;color:var(--ink-mute);margin-left:4px}

/* clickable transaction rows */
table.data.tx-table tbody tr{cursor:pointer}
table.data.tx-table tbody tr:hover td{background:var(--bg-2)}

/* transaction detail hero (in drawer) */
.tx-hero{display:flex;align-items:center;gap:14px;padding:20px 0 6px}
.tx-hero .m-logo{width:44px;height:44px}
.tx-hero .m-logo .m-ico{font-size:22px}
.tx-hero-amt{display:block;font-family:var(--f-disp);font-size:30px;font-weight:800;letter-spacing:-.03em}
.tx-hero.cr .tx-hero-amt{color:var(--ok)} .tx-hero.db .tx-hero-amt{color:var(--danger)}
.tx-hero-sub{display:block;font-family:var(--f-mono);font-size:10.5px;color:var(--ink-mute);margin-top:3px}

/* search result meta */
.gs-item{justify-content:flex-start}
.gs-meta{margin-left:auto;display:flex;align-items:center;gap:8px;white-space:nowrap}
.gs-cards{font-family:var(--f-mono);font-size:10px;color:var(--ink-mute)}
.gs-meta .badge{font-size:8.5px;padding:2px 6px}

/* ── PRICING ───────────────────────────────────────────────────── */
.stat-link{cursor:pointer;transition:background .12s}
.stat-link:hover{background:var(--bg-2)}
.stat-link span{color:var(--acc)}
.pr-legend{display:flex;flex-wrap:wrap;gap:10px 24px;margin-bottom:18px}
.pr-legend span{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.02em;color:var(--ink-3);
  border-left:2px solid var(--rule-2);padding-left:10px}
.pr-table .pr-unit{font-family:var(--f-mono);font-size:10px;letter-spacing:.04em;color:var(--ink-mute);text-transform:uppercase;white-space:nowrap}
.pr-inp{display:inline-flex;align-items:center;gap:4px;justify-content:flex-end}
.pr-inp span{font-family:var(--f-mono);font-size:12px;color:var(--ink-mute)}
.pr-inp input{width:92px;text-align:right;font-family:var(--f-mono);font-size:13px;padding:7px 9px;border:1px solid var(--rule-2);background:var(--bg)}
.pr-inp input:focus{outline:none;border-color:var(--acc);box-shadow:inset 0 -2px 0 var(--acc)}
.pr-charged{font-family:var(--f-body);font-size:12.5px;padding:7px 8px;border:1px solid var(--rule-2);background:var(--bg);color:var(--ink)}
.pr-charged:focus{outline:none;border-color:var(--acc)}
.pr-actions{display:flex;align-items:center;gap:16px;margin-top:20px}

/* ── TEMPLATE GALLERY (wow preview of the 5 enduser portal designs) ── */
.tpl-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px}
.tpl-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--rule-2);cursor:pointer;
  text-align:left;padding:0;overflow:hidden;transition:transform .15s,box-shadow .15s;position:relative}
.tpl-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(10,10,10,.18)}
.tpl-card.sel{outline:2px solid var(--acc);outline-offset:-1px}
.tpl-card.sel::before{content:"✓ Active";position:absolute;top:10px;right:10px;z-index:3;background:var(--acc);color:#fff;
  font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:4px 8px}
/* live mini-mockup rendered with each theme's real tokens */
.tpl-prev{aspect-ratio:16/10;padding:16px;display:flex;background:var(--p-bg);background-image:var(--p-grad);
  font-family:var(--p-font);position:relative}
.tpl-screen{flex:1;display:flex;flex-direction:column;gap:9px;min-width:0}
.tpl-top{display:flex;gap:5px}
.tpl-top i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.22);display:inline-block}
.tpl-bodyp{flex:1;display:flex;flex-direction:column;gap:9px;justify-content:center;padding:2px 4px}
.tpl-chipp{align-self:flex-start;font-family:'Inter',sans-serif;font-size:8px;letter-spacing:.05em;color:rgba(255,255,255,.75);
  border:1px solid var(--p-border);background:var(--p-chip);padding:3px 8px;border-radius:999px}
.tpl-hp{font-size:21px;font-weight:700;line-height:1.02;color:#fff;letter-spacing:var(--p-disp)}
.tpl-hp b{background:var(--p-gradtext);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tpl-cardlet{height:46px;border-radius:calc(var(--p-radius) * .7);background:var(--p-card);border:1px solid var(--p-border);
  display:flex;align-items:flex-end;padding:8px;box-shadow:var(--p-shadow)}
.tpl-cardlet span{font-family:'Inter',sans-serif;font-size:8px;color:#fff;opacity:.9;letter-spacing:.12em}
.tpl-btnp{align-self:flex-start;font-family:'Inter',sans-serif;font-size:9.5px;font-weight:700;color:#fff;
  padding:8px 13px;border-radius:var(--p-radius-btn);background:var(--p-btn);box-shadow:0 6px 16px -6px rgba(0,0,0,.5)}
/* distinct per-template mockup bits */
.tpl-center{align-items:center;text-align:center;justify-content:center}
.tpl-h2{font-size:17px;font-weight:700;color:#fff;letter-spacing:var(--p-disp);margin-top:auto}
.tpl-term{border:1px solid var(--p-border);background:rgba(0,0,0,.5);border-radius:calc(var(--p-radius)*.5);overflow:hidden}
.tpl-termbar{display:flex;gap:4px;padding:6px 8px;border-bottom:1px solid var(--p-border)}
.tpl-termbar i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.25)}
.tpl-termbody{padding:8px 10px;display:flex;flex-direction:column;gap:3px;font-family:'IBM Plex Mono',monospace;font-size:8.5px;color:rgba(255,255,255,.6)}
.tpl-termbody b{color:var(--p-accent)} .tpl-termbody em{color:#5ad08a;font-style:normal}
.tpl-bubbles{display:flex;gap:7px;justify-content:center}
.tpl-bubbles span{width:30px;height:30px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:14px;
  background:linear-gradient(135deg,var(--p-accent),#A855F7);opacity:.9}
.tpl-split{flex-direction:row;gap:10px;align-items:stretch}
.tpl-col{flex:1;display:flex;flex-direction:column;gap:6px;justify-content:center}
.tpl-eyebrow{font-family:'Inter',sans-serif;font-size:8px;text-transform:uppercase;letter-spacing:.14em;color:var(--p-accent);font-weight:700}
.tpl-statband{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--p-border);border:1px solid var(--p-border);align-self:center}
.tpl-statband > div{background:var(--p-bg);padding:8px;text-align:center}
.tpl-statband b{font-family:var(--p-font);font-size:14px;color:var(--p-accent);display:block}
.tpl-statband span{font-family:'Inter',sans-serif;font-size:7px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em}
.tpl-rule{height:1px;width:36px;background:#d6b25e;margin:2px 0}
.tpl-meta{padding:15px 16px;border-top:1px solid var(--rule)}
.tpl-meta b{font-family:var(--f-disp);font-size:15px;font-weight:700;letter-spacing:-.02em;display:block}
.tpl-meta span{font-size:12px;color:var(--ink-3);line-height:1.45;display:block;margin-top:3px}

/* per-theme preview tokens — mirror the portal globals.css themes */
.tpl-prev[data-tpl="midnight"]{--p-bg:#06070a;
  --p-grad:radial-gradient(ellipse 85% 60% at 50% -18%,color-mix(in srgb,var(--p-accent) 34%,transparent),transparent 70%);
  --p-card:linear-gradient(135deg,var(--p-accent),rgba(255,255,255,.08));--p-border:rgba(255,255,255,.09);
  --p-chip:rgba(255,255,255,.05);--p-radius:16px;--p-radius-btn:10px;--p-font:'Space Grotesk',sans-serif;--p-disp:-.02em;
  --p-btn:linear-gradient(135deg,var(--p-accent),color-mix(in srgb,var(--p-accent) 70%,#fff));
  --p-gradtext:linear-gradient(180deg,#fff,rgba(255,255,255,.55));--p-shadow:0 8px 26px -10px rgba(0,0,0,.6)}
.tpl-prev[data-tpl="carbon"]{--p-bg:#000;
  --p-grad:radial-gradient(ellipse 92% 55% at 50% -10%,rgba(255,255,255,.05),transparent 70%);
  --p-card:linear-gradient(135deg,var(--p-accent),rgba(255,255,255,.04));--p-border:rgba(255,255,255,.15);
  --p-chip:rgba(255,255,255,.04);--p-radius:6px;--p-radius-btn:6px;--p-font:'IBM Plex Mono',monospace;--p-disp:-.01em;
  --p-btn:var(--p-accent);--p-gradtext:linear-gradient(180deg,#fff,rgba(255,255,255,.7));--p-shadow:0 2px 14px -6px rgba(0,0,0,.8)}
.tpl-prev[data-tpl="aurora"]{--p-bg:#080612;
  --p-grad:radial-gradient(ellipse 90% 60% at 16% -10%,color-mix(in srgb,var(--p-accent) 42%,transparent),transparent 62%),radial-gradient(ellipse 80% 60% at 92% 112%,rgba(168,85,247,.30),transparent 60%);
  --p-card:linear-gradient(135deg,var(--p-accent),#A855F7);--p-border:rgba(255,255,255,.12);
  --p-chip:rgba(255,255,255,.07);--p-radius:22px;--p-radius-btn:14px;--p-font:'Sora',sans-serif;--p-disp:-.025em;
  --p-btn:linear-gradient(135deg,var(--p-accent),#A855F7);--p-gradtext:linear-gradient(135deg,#fff,#c4b5fd);--p-shadow:0 10px 30px -10px rgba(168,85,247,.5)}
.tpl-prev[data-tpl="slate"]{--p-bg:#0e1014;
  --p-grad:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(255,255,255,.04),transparent 70%);
  --p-card:linear-gradient(135deg,var(--p-accent),rgba(255,255,255,.06));--p-border:rgba(255,255,255,.10);
  --p-chip:rgba(255,255,255,.05);--p-radius:12px;--p-radius-btn:8px;--p-font:'Inter',sans-serif;--p-disp:-.015em;
  --p-btn:var(--p-accent);--p-gradtext:linear-gradient(180deg,#fff,rgba(255,255,255,.6));--p-shadow:0 6px 22px -10px rgba(0,0,0,.5)}
.tpl-prev[data-tpl="onyx"]{--p-bg:#08070a;
  --p-grad:radial-gradient(ellipse 80% 55% at 50% -18%,rgba(214,178,94,.16),transparent 70%);
  --p-card:linear-gradient(135deg,var(--p-accent),#d6b25e);--p-border:rgba(214,178,94,.30);
  --p-chip:rgba(214,178,94,.10);--p-radius:10px;--p-radius-btn:6px;--p-font:'Fraunces',Georgia,serif;--p-disp:0;
  --p-btn:linear-gradient(135deg,var(--p-accent),#d6b25e);--p-gradtext:linear-gradient(135deg,#fff,#e6c878);--p-shadow:0 8px 24px -10px rgba(214,178,94,.4)}

@media(max-width:560px){ .tpl-gallery{grid-template-columns:1fr} }

/* map label / feed extras */
.txlabel .lbl-m{display:block;font-family:var(--f-disp);font-size:12px;font-weight:700}
.txlabel .lbl-sub{display:block;color:rgba(255,255,255,.7);font-size:9.5px;margin-top:2px}
.feed-item .fi-city{color:var(--ink-mute)}

@media(max-width:880px){
  .login{grid-template-columns:1fr}
  .login-aside{display:none}
  .hero-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  #gsearch-input{width:150px}
  .cat-row{grid-template-columns:22px 90px 1fr 96px}
}

.ls-grid code,.note code{font-family:var(--f-mono);font-size:12px;background:var(--bg-2);padding:2px 6px;word-break:break-all}
