/* =====================================================
   فاحص الروابط البنكية الكويتية — style.css
   تصميم احترافي بخط Cairo
   ===================================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --bg:          #06080F;
    --bg2:         #0D1017;
    --bg3:         #131926;
    --card:        #161D2E;
    --card2:       #1C2438;
    --border:      rgba(255,255,255,0.06);
    --border2:     rgba(255,255,255,0.1);
    --text:        #E2E8F4;
    --text-muted:  #6B7A99;
    --accent:      #4F8EF7;
    --accent2:     #7B5CF7;
    --safe:        #0FCA87;
    --warn:        #F7B731;
    --danger:      #F74545;
    --gateway:     #8B5CF6;
    --radius:      16px;
    --radius-lg:   24px;
    --shadow:      0 8px 40px rgba(0,0,0,0.6);
    --glow-blue:   0 0 40px rgba(79,142,247,0.15);
    --glow-safe:   0 0 50px rgba(15,202,135,0.2);
    --glow-danger: 0 0 50px rgba(247,69,69,0.2);
    --glow-gw:     0 0 50px rgba(139,92,246,0.2);
}

html { scroll-behavior: smooth; }

body {
    font-family: 'Cairo', sans-serif;
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    line-height: 1.7;
    font-size: 15px;
    overflow-x: hidden;
}

/* شبكة خلفية */
body::before {
    content: '';
    position: fixed; inset: 0; z-index: 0;
    background-image:
        linear-gradient(rgba(79,142,247,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(79,142,247,0.025) 1px, transparent 1px);
    background-size: 50px 50px;
    pointer-events: none;
}

.container {
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 24px;
    position: relative; z-index: 1;
}

/* ======================================
   HEADER
   ====================================== */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(6,8,15,0.85);
    backdrop-filter: blur(20px) saturate(1.8);
    border-bottom: 1px solid var(--border);
    padding: 12px 0;
}
.header-inner {
    display: flex; align-items: center; justify-content: space-between;
}
.logo {
    display: flex; align-items: center; gap: 12px;
}
.logo-icon-wrap {
    width: 40px; height: 40px; border-radius: 12px;
    background: linear-gradient(135deg, #1E3A8A, #4F8EF7);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px;
    box-shadow: 0 0 20px rgba(79,142,247,0.3);
}
.logo-title {
    display: block; font-weight: 800; font-size: 16px; color: #fff;
}
.logo-sub {
    display: block; font-size: 11px; color: var(--text-muted); margin-top: -2px;
}
.header-nav { display: flex; gap: 24px; }
.header-nav a {
    color: var(--text-muted); text-decoration: none;
    font-size: 13px; font-weight: 600;
    transition: color .2s;
}
.header-nav a:hover { color: var(--accent); }

/* ======================================
   HERO
   ====================================== */
.hero {
    padding: 90px 0 70px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
/* توهّج أزرق خلفي */
.hero::before {
    content: '';
    position: absolute;
    top: -100px; left: 50%;
    transform: translateX(-50%);
    width: 800px; height: 600px;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(79,142,247,0.1) 0%, transparent 70%);
    pointer-events: none;
}
.hero::after {
    content: '';
    position: absolute;
    bottom: -80px; left: 20%;
    width: 400px; height: 400px;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(123,92,247,0.07) 0%, transparent 70%);
    pointer-events: none;
}

.hero-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(79,142,247,0.08);
    border: 1px solid rgba(79,142,247,0.2);
    border-radius: 50px;
    padding: 7px 20px;
    font-size: 13px; color: #93C5FD; font-weight: 600;
    margin-bottom: 28px;
    backdrop-filter: blur(8px);
}
.pulse-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--safe);
    box-shadow: 0 0 10px var(--safe);
    animation: pulse 2s infinite;
}
@keyframes pulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(15,202,135,.5); }
    50%      { box-shadow: 0 0 0 8px rgba(15,202,135,0); }
}

.hero-title {
    font-size: clamp(30px, 5.5vw, 58px);
    font-weight: 900; line-height: 1.2;
    color: #fff; margin-bottom: 18px;
    letter-spacing: -0.5px;
}
.highlight        { color: var(--safe); text-shadow: 0 0 30px rgba(15,202,135,0.4); }
.highlight-danger { color: var(--danger); text-shadow: 0 0 30px rgba(247,69,69,0.4); }

.hero-desc {
    font-size: 16px; color: var(--text-muted); font-weight: 500;
    max-width: 580px; margin: 0 auto 50px;
    line-height: 1.8;
}

/* ======================================
   SEARCH CARD
   ====================================== */
.search-card {
    background: var(--card);
    border: 1px solid var(--border2);
    border-radius: var(--radius-lg);
    padding: 32px 36px 26px;
    max-width: 740px;
    margin: 0 auto;
    box-shadow: var(--shadow), var(--glow-blue);
    position: relative;
    overflow: hidden;
}
.search-card::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), var(--accent2), transparent);
}

.search-label {
    font-size: 12px; color: var(--text-muted); margin-bottom: 12px;
    font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
}
.search-row { display: flex; gap: 10px; }

.url-input {
    flex: 1;
    background: var(--bg3);
    border: 1.5px solid var(--border);
    border-radius: 12px;
    padding: 14px 18px;
    font-size: 14px; color: var(--text);
    font-family: 'Cairo', monospace;
    outline: none;
    transition: border-color .25s, box-shadow .25s, background .25s;
    direction: ltr; text-align: left;
}
.url-input::placeholder { color: #3A4560; font-family: 'Cairo', sans-serif; direction: rtl; text-align: right; }
.url-input:focus {
    border-color: var(--accent);
    background: rgba(79,142,247,0.04);
    box-shadow: 0 0 0 4px rgba(79,142,247,0.1), inset 0 0 20px rgba(79,142,247,0.03);
}
.url-input.shake { animation: shake .4s; border-color: var(--danger) !important; }
@keyframes shake {
    0%,100%{transform:translateX(0)}
    20%{transform:translateX(-8px)}
    40%{transform:translateX(8px)}
    60%{transform:translateX(-5px)}
    80%{transform:translateX(5px)}
}

.btn-check {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
    color: #fff; border: none; border-radius: 12px;
    padding: 14px 28px;
    font-size: 15px; font-weight: 800;
    cursor: pointer;
    display: flex; align-items: center; gap: 8px;
    white-space: nowrap;
    font-family: 'Cairo', sans-serif;
    position: relative; overflow: hidden;
    transition: transform .15s, box-shadow .2s;
    box-shadow: 0 4px 20px rgba(79,142,247,0.35);
}
.btn-check::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.1), transparent);
    opacity: 0; transition: opacity .2s;
}
.btn-check:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(79,142,247,0.45); }
.btn-check:hover::after { opacity: 1; }
.btn-check:active { transform: translateY(0); }

.search-hints {
    margin-top: 16px;
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    font-size: 11px; color: var(--text-muted); font-weight: 600;
}
.hint-pill {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 11px; color: var(--text-muted);
    cursor: pointer; font-family: 'Cairo', sans-serif;
    font-weight: 600;
    transition: all .2s;
    direction: ltr;
}
.hint-pill:hover { border-color: var(--accent); color: var(--accent); background: rgba(79,142,247,0.06); }
.hint-pill--warn   { border-color: rgba(247,183,49,.3) !important; color: var(--warn) !important; }
.hint-pill--warn:hover { background: rgba(247,183,49,0.06) !important; }
.hint-pill--danger { border-color: rgba(247,69,69,.3) !important;  color: var(--danger) !important; }
.hint-pill--danger:hover { background: rgba(247,69,69,0.06) !important; }

/* ======================================
   RESULT SECTION
   ====================================== */
.result-section { padding: 50px 0 30px; }

/* ---- Loading ---- */
.loading-card {
    display: flex; flex-direction: column; align-items: center; gap: 28px;
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 50px 40px;
    box-shadow: var(--shadow);
    position: relative; overflow: hidden;
}
.loading-card::before {
    content: ''; position: absolute; top: 0; left: -100%;
    width: 100%; height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    animation: scan 1.8s ease-in-out infinite;
}
@keyframes scan { to { left: 100%; } }

.scanner-ring {
    position: relative; width: 80px; height: 80px;
}
.scanner-ring::before,
.scanner-ring::after {
    content: ''; position: absolute; border-radius: 50%;
    border: 2px solid transparent;
}
.scanner-ring::before {
    inset: 0;
    border-top-color: var(--accent);
    border-right-color: rgba(79,142,247,0.3);
    animation: spin 1s linear infinite;
}
.scanner-ring::after {
    inset: 12px;
    border-top-color: var(--accent2);
    border-left-color: rgba(123,92,247,0.3);
    animation: spin .7s linear infinite reverse;
}
.scanner-inner {
    position: absolute; inset: 24px;
    background: radial-gradient(circle, rgba(79,142,247,0.2), transparent);
    border-radius: 50%;
    animation: glow-pulse 1.5s ease-in-out infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes glow-pulse { 0%,100%{opacity:.4} 50%{opacity:1} }

.loading-steps { text-align: center; }
.loading-steps .step {
    font-size: 14px; color: var(--text-muted); padding: 3px 0;
    display: none; font-weight: 600;
    transition: all .3s;
}
.loading-steps .step.active {
    display: block; color: var(--accent);
}
.loading-steps .step.done {
    display: block; color: var(--safe); font-size: 12px; opacity: .6;
}

/* Fade in */
.fade-in { animation: fadeIn .6s cubic-bezier(.4,0,.2,1) forwards; }
@keyframes fadeIn { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }

/* ======================================
   RESULT CARD
   ====================================== */
.result-main {
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 16px;
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
}

/* --- Verdict Block --- */
.verdict-block {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 24px;
    align-items: center;
    padding: 32px 36px;
    border-bottom: 1px solid var(--border);
    position: relative; overflow: hidden;
    transition: background .4s;
}
/* توهّج جانبي حسب النتيجة */
.verdict-block::after {
    content: '';
    position: absolute; right: 0; top: 0; bottom: 0; width: 4px;
}

.verdict-block.verdict-bank {
    background: linear-gradient(135deg, rgba(15,202,135,.1) 0%, rgba(15,202,135,.03) 60%, var(--card) 100%);
    box-shadow: var(--glow-safe);
}
.verdict-block.verdict-bank::after    { background: linear-gradient(180deg, var(--safe), rgba(15,202,135,0)); }
.verdict-block.verdict-gateway {
    background: linear-gradient(135deg, rgba(139,92,246,.12) 0%, rgba(139,92,246,.04) 60%, var(--card) 100%);
    box-shadow: var(--glow-gw);
}
.verdict-block.verdict-gateway::after { background: linear-gradient(180deg, var(--gateway), rgba(139,92,246,0)); }
.verdict-block.verdict-warn {
    background: linear-gradient(135deg, rgba(247,183,49,.08) 0%, rgba(247,183,49,.02) 60%, var(--card) 100%);
}
.verdict-block.verdict-warn::after    { background: linear-gradient(180deg, var(--warn), rgba(247,183,49,0)); }
.verdict-block.verdict-danger {
    background: linear-gradient(135deg, rgba(247,69,69,.12) 0%, rgba(247,69,69,.03) 60%, var(--card) 100%);
    box-shadow: var(--glow-danger);
}
.verdict-block.verdict-danger::after  { background: linear-gradient(180deg, var(--danger), rgba(247,69,69,0)); }
.verdict-block.verdict-unknown {
    background: linear-gradient(135deg, rgba(107,114,153,.08) 0%, rgba(107,114,153,.02) 60%, var(--card) 100%);
}
.verdict-block.verdict-unknown::after { background: linear-gradient(180deg, #4B5580, rgba(75,85,128,0)); }

.verdict-icon {
    font-size: 60px; line-height: 1;
    filter: drop-shadow(0 0 16px currentColor);
    animation: icon-pop .5s cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes icon-pop { from{transform:scale(0) rotate(-20deg)} to{transform:scale(1) rotate(0)} }

.verdict-label {
    font-size: 24px; font-weight: 900; margin-bottom: 6px;
    letter-spacing: -.3px;
}
.verdict-bank    .verdict-label { color: var(--safe); }
.verdict-gateway .verdict-label { color: #A78BFA; }
.verdict-warn    .verdict-label { color: var(--warn); }
.verdict-danger  .verdict-label { color: var(--danger); }
.verdict-unknown .verdict-label { color: #6B7A99; }

.verdict-desc { font-size: 14px; color: var(--text-muted); margin-bottom: 8px; font-weight: 500; line-height: 1.6; }
.verdict-url  {
    font-size: 11px; color: #3A4560;
    font-family: monospace; word-break: break-all;
    background: rgba(0,0,0,0.2); border-radius: 6px;
    padding: 4px 10px; display: inline-block; margin-top: 4px;
}

/* Risk Meter */
.risk-meter { text-align: center; min-width: 140px; }
.risk-label { font-size: 11px; color: var(--text-muted); margin-bottom: 10px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; }
.risk-bar-wrap {
    background: rgba(255,255,255,0.05);
    border-radius: 8px; height: 8px;
    overflow: hidden; margin-bottom: 8px;
    position: relative;
}
.risk-bar {
    height: 100%; border-radius: 8px;
    transition: width 1.2s cubic-bezier(.4,0,.2,1);
    position: relative;
}
.risk-bar::after {
    content: '';
    position: absolute; right: -1px; top: -2px; bottom: -2px; width: 3px;
    border-radius: 4px;
    filter: blur(3px);
}
.risk-bar.risk-low  { background: linear-gradient(90deg, #0FCA87, #34D399); }
.risk-bar.risk-low::after  { background: #0FCA87; }
.risk-bar.risk-mid  { background: linear-gradient(90deg, #F7B731, #FBBF24); }
.risk-bar.risk-mid::after  { background: #F7B731; }
.risk-bar.risk-high { background: linear-gradient(90deg, #F74545, #F97316); }
.risk-bar.risk-high::after { background: #F74545; }
.risk-value { font-size: 28px; font-weight: 900; }

/* Bank / Gateway Match Card */
.bank-match-card {
    background: var(--bg3);
    padding: 18px 36px;
    display: flex; align-items: center; gap: 14px;
    border-bottom: 1px solid var(--border);
}
.bank-match-header {
    font-size: 11px; color: var(--text-muted); font-weight: 700; letter-spacing: .5px;
    text-transform: uppercase; margin-bottom: 10px;
    display: flex; align-items: center; gap: 6px;
}
.bank-match-info { display: flex; align-items: center; gap: 14px; }
.bm-abbr {
    padding: 8px 16px; border-radius: 10px;
    font-weight: 900; font-size: 15px; color: #fff;
    letter-spacing: 1px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}
.bm-name    { font-weight: 700; font-size: 16px; }
.bm-name-en { font-size: 12px; color: var(--text-muted); margin-top: 1px; }
.bm-type    { font-size: 11px; color: #A78BFA; margin-top: 3px; font-weight: 600; }

/* ======================================
   CHECKS GRID
   ====================================== */
.checks-section {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 28px 32px;
    margin-bottom: 16px;
}
.checks-title {
    font-size: 15px; font-weight: 800;
    margin-bottom: 20px; color: var(--text);
    display: flex; align-items: center; gap: 10px;
    border-bottom: 1px solid var(--border); padding-bottom: 14px;
    letter-spacing: -.2px;
}
.checks-title::before {
    content: '⚙️'; font-size: 16px;
}
.checks-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 12px;
}

.check-card {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px 18px;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    animation: slideIn .4s ease forwards;
    opacity: 0;
    position: relative; overflow: hidden;
}
.check-card::before {
    content: '';
    position: absolute; top: 0; right: 0; bottom: 0; width: 3px;
    border-radius: 0 14px 14px 0;
}
@keyframes slideIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:none} }
.anim-delay-0{animation-delay:.05s}.anim-delay-1{animation-delay:.1s}
.anim-delay-2{animation-delay:.15s}.anim-delay-3{animation-delay:.2s}
.anim-delay-4{animation-delay:.25s}.anim-delay-5{animation-delay:.3s}
.anim-delay-6{animation-delay:.35s}.anim-delay-7{animation-delay:.4s}

.check-card:hover { transform: translateY(-2px); }
.check-card.check-pass::before { background: var(--safe); }
.check-card.check-fail::before { background: var(--danger); }
.check-card.check-warn::before { background: var(--warn); }

.check-card.check-pass { border-color: rgba(15,202,135,.2); }
.check-card.check-fail { border-color: rgba(247,69,69,.25); background: rgba(247,69,69,.03); }
.check-card.check-warn { border-color: rgba(247,183,49,.25); background: rgba(247,183,49,.03); }

.check-card.check-pass:hover { box-shadow: 0 4px 20px rgba(15,202,135,.1); }
.check-card.check-fail:hover { box-shadow: 0 4px 20px rgba(247,69,69,.1); }
.check-card.check-warn:hover { box-shadow: 0 4px 20px rgba(247,183,49,.1); }

.check-header {
    display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.check-status-icon { font-size: 15px; }
.check-label { font-weight: 700; font-size: 13px; flex: 1; }
.check-badge {
    font-size: 10px; padding: 3px 10px; border-radius: 20px; font-weight: 800;
    letter-spacing: .3px;
}
.check-badge.check-pass  { background: rgba(15,202,135,.15); color: var(--safe); }
.check-badge.check-fail  { background: rgba(247,69,69,.15);  color: var(--danger); }
.check-badge.check-warn  { background: rgba(247,183,49,.15); color: var(--warn); }
.check-detail { font-size: 12px; color: var(--text-muted); line-height: 1.6; font-weight: 500; }

/* Actions */
.result-actions { display: flex; gap: 12px; justify-content: flex-start; }
.btn-secondary, .btn-share {
    padding: 11px 22px; border-radius: 12px;
    font-size: 14px; font-weight: 700; cursor: pointer;
    font-family: 'Cairo', sans-serif; transition: all .2s;
    display: flex; align-items: center; gap: 6px;
}
.btn-secondary {
    background: var(--bg3); border: 1px solid var(--border); color: var(--text);
}
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); background: rgba(79,142,247,0.05); }
.btn-share {
    background: rgba(79,142,247,.1); border: 1px solid rgba(79,142,247,.25); color: var(--accent);
}
.btn-share:hover { background: rgba(79,142,247,.18); }

/* Error */
.error-card {
    background: rgba(247,69,69,.08); border: 1px solid rgba(247,69,69,.3);
    border-radius: var(--radius); padding: 24px; text-align: center;
    color: var(--danger); font-size: 15px; font-weight: 600;
}

/* ======================================
   HOW IT WORKS
   ====================================== */
.how-section { padding: 80px 0; background: var(--bg2); border-top: 1px solid var(--border); }
.section-title {
    text-align: center; font-size: 30px; font-weight: 900;
    margin-bottom: 14px; color: #fff; letter-spacing: -.5px;
}
.section-sub {
    text-align: center; font-size: 15px; color: var(--text-muted);
    margin-bottom: 40px; font-weight: 500;
}

.how-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 14px;
}
.how-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 26px 18px 22px;
    text-align: center;
    position: relative;
    transition: transform .25s, border-color .25s, box-shadow .25s;
    cursor: default;
}
.how-card:hover {
    transform: translateY(-4px);
    border-color: rgba(79,142,247,.25);
    box-shadow: 0 12px 40px rgba(79,142,247,.1);
}
.how-num {
    position: absolute; top: 14px; left: 14px;
    font-size: 10px; font-weight: 900; color: rgba(79,142,247,.35);
    letter-spacing: 1px;
}
.how-icon-wrap {
    width: 52px; height: 52px; border-radius: 16px;
    background: linear-gradient(135deg, rgba(79,142,247,.12), rgba(123,92,247,.12));
    border: 1px solid rgba(79,142,247,.15);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; margin: 0 auto 14px;
    transition: box-shadow .25s;
}
.how-card:hover .how-icon-wrap {
    box-shadow: 0 0 20px rgba(79,142,247,.2);
}
.how-card h4 { font-size: 14px; font-weight: 800; margin-bottom: 8px; color: #fff; }
.how-card p  { font-size: 12px; color: var(--text-muted); line-height: 1.6; font-weight: 500; }

/* ======================================
   BANKS LIST
   ====================================== */
.banks-section { padding: 80px 0; }

.banks-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 12px;
}
.bank-item {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 16px;
    text-align: center;
    border-top: 3px solid var(--c, var(--accent));
    transition: transform .2s, box-shadow .2s;
    cursor: default;
}
.bank-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.3), 0 0 20px rgba(var(--c, 79,142,247), 0.1);
}
.bank-abbr    { font-size: 18px; font-weight: 900; color: var(--c, var(--accent)); margin-bottom: 6px; letter-spacing: .5px; }
.bank-name-ar { font-size: 12px; font-weight: 700; margin-bottom: 6px; line-height: 1.4; }
.bank-domain  { font-size: 10px; color: var(--text-muted); font-family: monospace; margin-top: 2px; }

/* ======================================
   GATEWAYS SECTION
   ====================================== */
.gateways-section {
    padding: 70px 0;
    background: var(--bg2); border-top: 1px solid var(--border);
}
.gateways-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; margin-bottom: 8px;
}
.gateways-header .section-title { margin-bottom: 0; text-align: right; }
.cbk-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(79,142,247,.08);
    border: 1px solid rgba(79,142,247,.2);
    border-radius: 20px; padding: 8px 16px;
    font-size: 12px; color: #93C5FD;
    text-decoration: none; font-weight: 700;
    transition: background .2s;
}
.cbk-badge:hover { background: rgba(79,142,247,.15); }

.gw-category-title {
    font-size: 12px; font-weight: 800; color: var(--text-muted);
    letter-spacing: .6px; text-transform: uppercase;
    margin: 22px 0 10px;
    display: flex; align-items: center; gap: 8px;
}
.gw-category-title::after {
    content: ''; flex: 1; height: 1px; background: var(--border);
}
.gateways-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px; margin-bottom: 4px;
}
.gw-item {
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px 14px;
    text-align: center;
    border-top: 2px solid var(--gc, #6366F1);
    transition: transform .2s, box-shadow .2s;
    cursor: default;
}
.gw-item.gw-operator { border-top-color: var(--accent); }
.gw-item:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(0,0,0,.25); }
.gw-abbr   { font-size: 13px; font-weight: 900; color: var(--gc, #818CF8); margin-bottom: 5px; letter-spacing: .5px; }
.gw-item.gw-operator .gw-abbr { color: var(--accent); }
.gw-name   { font-size: 11px; font-weight: 700; margin-bottom: 5px; line-height: 1.4; }
.gw-domain { font-size: 10px; color: var(--text-muted); font-family: monospace; }

/* ======================================
   FOOTER
   ====================================== */
.site-footer {
    background: var(--bg);
    border-top: 1px solid var(--border);
    padding: 36px 0;
}
.footer-inner { text-align: center; }
.footer-logo  { font-size: 17px; font-weight: 800; margin-bottom: 10px; color: var(--text-muted); }
.footer-note  { font-size: 12px; color: #3A4560; margin-bottom: 8px; max-width: 480px; margin-inline: auto; font-weight: 500; line-height: 1.7; }
.footer-copy  { font-size: 11px; color: #252D40; font-weight: 600; }

/* ======================================
   STATS STRIP
   ====================================== */
.stats-strip {
    background: var(--bg2);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 20px 0;
}
.stats-inner {
    display: flex; align-items: center; justify-content: center;
    gap: 0; flex-wrap: wrap;
}
.stat-item {
    text-align: center; padding: 8px 32px;
    flex: 1; min-width: 100px;
}
.stat-num {
    font-size: 26px; font-weight: 900; color: #fff;
    letter-spacing: -.5px; margin-bottom: 3px;
}
.stat-lbl {
    font-size: 11px; color: var(--text-muted); font-weight: 600;
}
.stat-div {
    width: 1px; height: 40px;
    background: var(--border); flex-shrink: 0;
}

/* ======================================
   TRUST MICRO NOTE
   ====================================== */
.trust-micro {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; color: var(--text-muted);
    margin-top: 14px; margin-bottom: 4px;
    font-weight: 600; padding-top: 12px;
    border-top: 1px solid var(--border);
}
.trust-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--safe); flex-shrink: 0;
    box-shadow: 0 0 6px var(--safe);
}

/* ======================================
   ABOUT SECTION
   ====================================== */
.about-section {
    padding: 80px 0;
    background: var(--bg);
    border-top: 1px solid var(--border);
}
.about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.about-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 26px;
    transition: border-color .25s, transform .25s;
}
.about-card:hover {
    border-color: rgba(79,142,247,.2);
    transform: translateY(-2px);
}
.about-card--main {
    grid-column: 1 / -1;
    background: linear-gradient(135deg, rgba(79,142,247,.06) 0%, var(--card) 100%);
    border-color: rgba(79,142,247,.15);
    display: flex; align-items: flex-start; gap: 20px;
}
.about-icon {
    font-size: 32px; flex-shrink: 0; margin-top: 2px;
}
.about-card h3 {
    font-size: 16px; font-weight: 800; color: #fff;
    margin-bottom: 10px;
}
.about-card p {
    font-size: 13px; color: var(--text-muted); line-height: 1.8; font-weight: 500;
}
.about-card strong { color: var(--text); }

/* ======================================
   FOOTER (redesigned)
   ====================================== */
.site-footer {
    background: var(--bg);
    border-top: 1px solid var(--border);
    padding: 40px 0 24px;
}
.footer-top {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 20px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 20px;
}
.footer-brand {}
.footer-logo  { font-size: 18px; font-weight: 800; color: var(--text-muted); margin-bottom: 4px; }
.footer-tagline { font-size: 12px; color: #3A4560; font-weight: 600; }
.footer-links {
    display: flex; gap: 24px; flex-wrap: wrap;
}
.footer-links a {
    font-size: 12px; color: var(--text-muted); text-decoration: none;
    font-weight: 700; transition: color .2s;
}
.footer-links a:hover { color: var(--accent); }
.footer-disclaimer {
    font-size: 11px; color: #3A4560; line-height: 1.7;
    font-weight: 600; margin-bottom: 20px;
    background: rgba(247,183,49,.04);
    border: 1px solid rgba(247,183,49,.1);
    border-radius: 10px; padding: 12px 16px;
}
.footer-bottom {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 8px;
}
.footer-copy  { font-size: 11px; color: #252D40; font-weight: 600; }
.footer-cbk   { font-size: 10px; color: #252D40; font-weight: 600; }

/* ======================================
   RESPONSIVE
   ====================================== */
@media (max-width: 700px) {
    .about-grid       { grid-template-columns: 1fr; }
    .about-card--main { flex-direction: column; gap: 12px; }
    .footer-top       { flex-direction: column; align-items: flex-start; }
    .footer-bottom    { flex-direction: column; align-items: flex-start; }
    .stats-inner      { gap: 0; }
    .stat-item        { padding: 8px 16px; }
    .stat-div         { display: none; }
}
