/* extras.css — styles for new pages (fraud-map, verify, portal, categories, case-study, FAQ page) */

/* === Fraud Map === */
.map-section{padding:100px 0}
.map-wrap{background:#0a0b0d;border-radius:24px;padding:40px;color:#fff;position:relative;overflow:hidden;border:1px solid #1a1d22}
.map-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px;flex-wrap:wrap}
.map-head h2{font-size:28px;font-weight:600;letter-spacing:-.02em;margin:0 0 6px;color:#fff}
.map-head p{font-size:14px;color:rgba(255,255,255,.6);margin:0}
.map-filters{display:flex;gap:8px;flex-wrap:wrap}
.map-filter{font-family:var(--mono);font-size:11px;padding:7px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.65);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.map-filter.is-on{background:#fff;color:#000;border-color:#fff}
.map-body{display:grid;grid-template-columns:2fr 1fr;gap:32px;align-items:stretch;min-height:480px}
.map-svg{background:#0e1115;border-radius:16px;padding:20px;position:relative;border:1px solid rgba(255,255,255,.06);overflow:hidden}
.map-svg svg{width:100%;height:100%;display:block}
.map-svg .continent{fill:rgba(255,255,255,.05);stroke:rgba(255,255,255,.12);stroke-width:.5}
.map-dot{fill:#6E267B;stroke:rgba(255,255,255,.9);stroke-width:1.2;cursor:pointer;transition:r .15s}
.map-dot.hot{fill:#f43f5e}
.map-dot.med{fill:#f59e0b}
.map-dot-pulse{fill:#6E267B;opacity:.5;animation:mpulse 2s infinite}
@keyframes mpulse{0%{r:4;opacity:.6}100%{r:16;opacity:0}}
.map-label{fill:rgba(255,255,255,.7);font-size:9px;font-family:var(--mono);pointer-events:none}
.map-side{display:flex;flex-direction:column;gap:14px}
.map-stat{background:#0e1115;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px}
.map-stat-lbl{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.map-stat-val{font-size:26px;font-weight:600;letter-spacing:-.02em;color:#fff;margin-top:6px;font-variant-numeric:tabular-nums}
.map-stat-dim{font-size:12px;color:rgba(255,255,255,.55);margin-top:4px}
.map-side h4{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase;margin:8px 0 6px;font-weight:600}
.map-hot-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.map-hot-list li{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.8);padding:8px 12px;background:#0e1115;border:1px solid rgba(255,255,255,.05);border-radius:8px}
.map-hot-list li strong{color:#f43f5e;font-weight:700}
.map-legend{display:flex;gap:16px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.55);margin-top:14px;text-transform:uppercase;letter-spacing:.06em}
.map-legend span{display:inline-flex;align-items:center;gap:6px}
.map-legend i{width:10px;height:10px;border-radius:50%;display:inline-block}
html[data-theme="dark"] .map-wrap{background:#050608}
@media (max-width:900px){.map-body{grid-template-columns:1fr}.map-svg{min-height:360px}}

/* === Verify page === */
.verify-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px}
.verify-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:14px}
html[data-theme="dark"] .verify-card{background:var(--bg-elev)}
.verify-num{font-family:var(--mono);font-size:11px;color:var(--brand);letter-spacing:.1em;font-weight:700}
.verify-card h3{font-size:18px;font-weight:600;letter-spacing:-.012em;margin:0;color:var(--ink);line-height:1.3}
.verify-card p{font-size:14px;color:var(--ink-dim);line-height:1.55;margin:0}
.verify-link{margin-top:auto;font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--brand);text-decoration:none;padding-top:8px;border-top:1px solid var(--line);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.06em}
.verify-link:hover{gap:10px;transition:gap .2s}
.verify-link .ext{opacity:.6;font-size:10px}
@media (max-width:720px){.verify-list{grid-template-columns:1fr}}

.reg-big{background:var(--bg-deep);color:#fff;border-radius:20px;padding:40px;margin:40px 0;display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.reg-big-cell{text-align:center;padding:14px}
.reg-big .n{font-size:22px;font-weight:700;letter-spacing:.02em;color:#fff;font-family:var(--mono)}
.reg-big .d{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.reg-big .num{font-family:var(--mono);font-size:11px;color:#B884C5;margin-top:6px}
@media (max-width:720px){.reg-big{grid-template-columns:repeat(2,1fr);padding:24px}}

.scam-warn{background:#fef3c7;border:1px solid #fbbf24;border-radius:14px;padding:24px;margin:32px 0;color:#78350f}
html[data-theme="dark"] .scam-warn{background:rgba(251,191,36,.12);color:#fde68a;border-color:rgba(251,191,36,.3)}
.scam-warn h4{font-size:15px;font-weight:700;margin:0 0 8px;display:flex;align-items:center;gap:8px}
.scam-warn h4::before{content:"⚠";font-size:18px}
.scam-warn p{margin:0;font-size:13.5px;line-height:1.55}

/* === Portal mockup === */
.portal-frame{background:var(--bg-deep);color:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.portal-bar{background:#13161b;padding:12px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #23272e;font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.55)}
.portal-bar .dots{display:flex;gap:6px;margin-right:6px}
.portal-bar .dots i{width:11px;height:11px;border-radius:50%;background:#3a3f47;display:inline-block}
.portal-bar .dots i:nth-child(1){background:#ef4444}
.portal-bar .dots i:nth-child(2){background:#f59e0b}
.portal-bar .dots i:nth-child(3){background:#22c55e}
.portal-body{display:grid;grid-template-columns:220px 1fr;min-height:600px}
.portal-side{background:#0e1115;border-right:1px solid #23272e;padding:22px 18px;display:flex;flex-direction:column;gap:3px}
.portal-side .logo{color:#fff;font-weight:700;font-size:14px;margin-bottom:18px;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}
.portal-side .logo i{width:22px;height:22px;background:var(--brand);border-radius:5px;display:grid;place-items:center;font-size:12px;font-family:var(--mono)}
.portal-nav{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.4);letter-spacing:.08em;text-transform:uppercase;margin:16px 0 6px;padding-left:8px}
.portal-item{color:rgba(255,255,255,.65);text-decoration:none;padding:9px 12px;border-radius:8px;font-size:13px;display:flex;justify-content:space-between;align-items:center;transition:all .12s}
.portal-item:hover{background:rgba(255,255,255,.04);color:#fff}
.portal-item.is-on{background:rgba(110,38,123,.15);color:#fff;box-shadow:inset 2px 0 0 var(--brand)}
.portal-item .badge{background:var(--brand);color:#fff;font-size:10px;padding:1px 7px;border-radius:999px;font-weight:700}
.portal-main{padding:32px;overflow:hidden}
.portal-main h3{font-size:22px;font-weight:600;color:#fff;margin:0 0 4px;letter-spacing:-.015em}
.portal-main .case-id{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.08em}
.portal-tabs{display:flex;gap:4px;margin:24px 0;border-bottom:1px solid #23272e}
.portal-tab{font-family:var(--mono);font-size:11.5px;padding:10px 16px;color:rgba(255,255,255,.55);cursor:pointer;border-bottom:2px solid transparent;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.portal-tab.is-on{color:#fff;border-bottom-color:var(--brand)}
.portal-timeline{display:flex;flex-direction:column;gap:0}
.portal-evt{display:grid;grid-template-columns:110px 24px 1fr;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.05);align-items:start}
.portal-evt-date{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.05em}
.portal-evt-dot{position:relative;width:24px;display:flex;justify-content:center;padding-top:4px}
.portal-evt-dot::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px rgba(110,38,123,.25)}
.portal-evt-dot.done::before{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.25)}
.portal-evt-dot.pending::before{background:#3a3f47;box-shadow:none}
.portal-evt h5{font-size:13.5px;font-weight:600;color:#fff;margin:0 0 3px}
.portal-evt p{font-size:12.5px;color:rgba(255,255,255,.6);margin:0;line-height:1.5}
.portal-evt .evt-file{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:rgba(110,38,123,.14);border:1px solid rgba(110,38,123,.3);border-radius:6px;font-family:var(--mono);font-size:11px;color:#B884C5;margin-top:6px;text-decoration:none}
.portal-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.portal-kpi{background:#0e1115;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 16px}
.portal-kpi-lbl{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.45);letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.portal-kpi-val{font-size:20px;font-weight:600;color:#fff;margin-top:4px;letter-spacing:-.015em;font-variant-numeric:tabular-nums}
.portal-kpi-val.ok{color:#22c55e}
.portal-progress{background:#0e1115;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:20px;margin-bottom:18px}
.portal-progress h4{font-size:13px;margin:0 0 14px;color:#fff;font-weight:600;display:flex;justify-content:space-between;align-items:baseline}
.portal-progress h4 span{font-family:var(--mono);font-size:12px;color:#22c55e}
.portal-bar-outer{height:8px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.portal-bar-inner{height:100%;background:linear-gradient(90deg,var(--brand),#B884C5);border-radius:999px;transition:width .6s}
@media (max-width:820px){.portal-body{grid-template-columns:1fr}.portal-side{display:none}.portal-kpis{grid-template-columns:repeat(2,1fr)}}

/* === Category landing === */
.cat-hero{background:linear-gradient(145deg,#0a0b0d 0%,#050608 100%);color:#fff;padding:88px 0 72px;position:relative;overflow:hidden}
.cat-hero::before{content:"";position:absolute;top:-120px;right:-120px;width:520px;height:520px;background:radial-gradient(circle,rgba(110,38,123,.28),transparent 60%);filter:blur(20px)}
.cat-hero .wrap{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
.cat-hero .crumb a{color:rgba(255,255,255,.55)}
.cat-hero .crumb{color:rgba(255,255,255,.5)}
.cat-hero .eyebrow{color:#B884C5}
.cat-hero h1{font-size:56px;font-weight:600;letter-spacing:-.035em;line-height:1.02;margin:16px 0;color:#fff}
.cat-hero h1 .grad{background:linear-gradient(100deg,#B884C5,#fff);-webkit-background-clip:text;background-clip:text;color:transparent}
.cat-hero .lede{font-size:17px;color:rgba(255,255,255,.75);line-height:1.55;margin:0 0 28px;max-width:540px}
.cat-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:22px}
.cat-stat{text-align:left}
.cat-stat-val{font-size:28px;font-weight:600;color:#fff;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.cat-stat-lbl{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;margin-top:6px}
.cat-hero-side{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:26px;backdrop-filter:blur(12px)}
.cat-hero-side h4{font-family:var(--mono);font-size:11px;color:#B884C5;letter-spacing:.12em;margin:0 0 16px;text-transform:uppercase;font-weight:700}
.cat-hero-side .playbook{display:flex;flex-direction:column;gap:10px}
.cat-play-step{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.05);border-radius:10px}
.cat-play-step .n{font-family:var(--mono);font-size:11px;color:#B884C5;width:22px;flex-shrink:0;font-weight:700;padding-top:1px}
.cat-play-step h5{font-size:13.5px;color:#fff;margin:0 0 2px;font-weight:600}
.cat-play-step p{font-size:12px;color:rgba(255,255,255,.6);margin:0;line-height:1.45}
@media (max-width:860px){.cat-hero .wrap{grid-template-columns:1fr}.cat-hero h1{font-size:38px}}

.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.how-step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;position:relative}
html[data-theme="dark"] .how-step{background:var(--bg-elev)}
.how-step .n{font-family:var(--mono);font-size:11px;color:var(--brand);letter-spacing:.08em;font-weight:700}
.how-step h4{font-size:16px;font-weight:600;color:var(--ink);margin:8px 0 6px;letter-spacing:-.012em}
.how-step p{font-size:13.5px;color:var(--ink-dim);line-height:1.55;margin:0}
@media (max-width:720px){.how-grid{grid-template-columns:1fr}}

.red-flags{background:#fef2f2;border:1px solid #fecaca;border-radius:16px;padding:28px;margin-top:32px}
html[data-theme="dark"] .red-flags{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25)}
.red-flags h3{font-size:18px;font-weight:600;margin:0 0 14px;color:#991b1b;display:flex;align-items:center;gap:10px}
html[data-theme="dark"] .red-flags h3{color:#fca5a5}
.red-flags ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:8px 20px}
.red-flags li{font-size:13.5px;color:#7f1d1d;line-height:1.5;padding-left:18px;position:relative}
html[data-theme="dark"] .red-flags li{color:#fca5a5}
.red-flags li::before{content:"✕";position:absolute;left:0;color:#dc2626;font-weight:700}
@media (max-width:720px){.red-flags ul{grid-template-columns:1fr}}

/* === Case study detail === */
.cs-hero{padding:88px 0 48px;background:var(--bg-elev);border-bottom:1px solid var(--line)}
.cs-hero h1{font-size:44px;font-weight:600;letter-spacing:-.025em;line-height:1.1;margin:18px 0 16px;color:var(--ink);max-width:860px}
.cs-hero .lede{font-size:18px;color:var(--ink-dim);line-height:1.55;max-width:760px;margin:0 0 28px}
.cs-hero-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:26px;background:var(--bg);border:1px solid var(--line);border-radius:16px}
.cs-meta-lbl{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.cs-meta-val{font-size:19px;font-weight:600;color:var(--ink);margin-top:4px;letter-spacing:-.015em;font-variant-numeric:tabular-nums}
.cs-meta-val.ok{color:var(--green)}
@media (max-width:720px){.cs-hero h1{font-size:30px}.cs-hero-meta{grid-template-columns:repeat(2,1fr);padding:18px;gap:16px}}

.cs-body{display:grid;grid-template-columns:1fr 280px;gap:48px;padding:64px 0;align-items:start}
.cs-content h2{font-size:28px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:40px 0 14px;line-height:1.2}
.cs-content h2:first-child{margin-top:0}
.cs-content p{font-size:16px;line-height:1.7;color:var(--ink);margin:0 0 14px}
.cs-content p.lead{font-size:18px;color:var(--ink-dim)}
.cs-content blockquote{border-left:3px solid var(--brand);padding:6px 0 6px 20px;margin:28px 0;font-size:18px;font-style:italic;color:var(--ink);line-height:1.55}
.cs-content blockquote cite{display:block;font-size:13px;color:var(--muted);font-style:normal;margin-top:8px;font-family:var(--mono);letter-spacing:.05em}
.cs-content ul{padding-left:22px;color:var(--ink);font-size:15.5px;line-height:1.7}
.cs-content .callout{background:var(--brand-soft);border:1px solid rgba(110,38,123,.2);border-radius:12px;padding:20px 22px;margin:24px 0}
.cs-content .callout h4{font-family:var(--mono);font-size:11px;color:var(--brand);letter-spacing:.1em;text-transform:uppercase;margin:0 0 6px;font-weight:700}
.cs-content .callout p{margin:0;font-size:14.5px;color:var(--ink)}
.cs-timeline{display:flex;flex-direction:column;gap:0;margin:28px 0}
.cs-tl-item{display:grid;grid-template-columns:120px 20px 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.cs-tl-date{font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.05em}
.cs-tl-dot{position:relative;display:flex;justify-content:center;padding-top:6px}
.cs-tl-dot::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--brand)}
.cs-tl-dot.ok::before{background:var(--green)}
.cs-tl-item h5{font-size:14.5px;font-weight:600;color:var(--ink);margin:0 0 3px}
.cs-tl-item p{font-size:13.5px;color:var(--ink-dim);margin:0;line-height:1.55}

.cs-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:14px}
.cs-side-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;padding:22px}
.cs-side-card h4{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;font-weight:600}
.cs-side-card p{font-size:13.5px;color:var(--ink);margin:0;line-height:1.55}
.cs-side-card ul{list-style:none;padding:0;margin:0}
.cs-side-card li{font-size:13px;color:var(--ink-dim);padding:6px 0;border-bottom:1px dashed var(--line);display:flex;justify-content:space-between;font-variant-numeric:tabular-nums}
.cs-side-card li:last-child{border:0}
.cs-side-card li strong{color:var(--ink);font-weight:600}
@media (max-width:900px){.cs-body{grid-template-columns:1fr;gap:32px}.cs-side{position:static}}




/* === Banking partners — refined compact logo grid === */
.banks{padding:72px 0 56px;background:#fff;border-top:1px solid var(--line)}
.banks-head{max-width:720px;margin-bottom:40px}
.banks-head h2{font-size:clamp(28px,3.4vw,40px);line-height:1.1;letter-spacing:-.025em;margin:10px 0 14px;font-weight:600}
.banks-head .grad{background:linear-gradient(90deg,var(--brand),var(--brand-dark));-webkit-background-clip:text;background-clip:text;color:transparent}
.banks-head p{color:var(--ink-dim);font-size:16px;max-width:640px;margin:0}

.banks-group{margin-top:28px;padding-top:22px;border-top:1px dashed var(--line)}
.banks-group:first-of-type{border-top:none;padding-top:0}

.banks-region{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:18px}
.banks-flag{font-size:15px;filter:saturate(.9)}

.banks-logos{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:0;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.bank-logo{
  height:72px;
  display:flex;align-items:center;justify-content:center;
  padding:0 18px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:#6b7280;
  background:#fff;
  transition:background .2s, color .2s;
  position:relative;
}
.bank-logo:hover{background:#fafbfc;color:var(--ink)}
.bank-logo svg{max-width:100%;max-height:26px;width:auto;height:auto;display:block;opacity:.85;transition:opacity .2s}
.bank-logo:hover svg{opacity:1}

/* remove outer borders that overlap the rounded container */
.banks-logos .bank-logo:nth-child(n){border-bottom:1px solid var(--line)}

.banks-foot{
  display:flex;align-items:flex-start;gap:10px;
  margin-top:24px;padding:14px 16px;
  background:var(--bg-elev);border-radius:10px;
  font-size:12.5px;color:var(--ink-dim);line-height:1.5;
}
.banks-foot-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);margin-top:7px;flex-shrink:0;opacity:.6}

@media (max-width:720px){
  .banks-logos{grid-template-columns:repeat(2,1fr)}
  .bank-logo{height:64px;padding:0 14px}
  .bank-logo svg{max-height:22px}
}
