*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f7f9fc;--surface:#fff;--surface-2:#f9fafb;--surface-3:#eff6ff;
  --border:#e5e7eb;--text:#111827;--muted:#4b5563;--dim:#6b7280;--soft:#9ca3af;
  --accent:#2563eb;--accent-dark:#1d4ed8;--accent-soft:#e0ecff;
  --success:#16a34a;--success-soft:#dcfce7;
  --radius:18px;--shadow:0 10px 30px rgba(15,23,42,.04);
  --sans:Inter,Arial,sans-serif
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:var(--sans);
  font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,table,pre,iframe,video,canvas{max-width:100%}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-dark);text-decoration:underline}

    /* ── Header ─────────────────────────────────────────────────────────── */
    .site-header{background:rgba(255,255,255,.94);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;backdrop-filter:blur(10px)}
    .nav-wrap{max-width:1120px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
    .brand{display:flex;align-items:center;gap:10px;color:var(--text);font-weight:800;letter-spacing:-.03em;font-size:20px;text-decoration:none}
    .brand:hover{text-decoration:none;color:var(--text)}
    .brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#60a5fa);display:grid;place-items:center;color:#fff;font-weight:800;box-shadow:0 10px 20px rgba(37,99,235,.18)}
    .top-nav{display:flex;align-items:center;gap:18px;font-size:14px;font-weight:600}
    .top-nav a{color:var(--muted)}
    .top-nav a:hover{color:var(--accent)}
    .menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--text);border-radius:8px;line-height:1}

    /* ── Mobile nav ─────────────────────────────────────────────────────── */
    .mobile-nav{visibility:hidden;pointer-events:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}
    .mobile-nav.open{visibility:visible;pointer-events:auto}
    .mobile-nav-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(15,23,42,.5)}
    .mobile-nav-panel{position:absolute;top:0;right:0;width:280px;max-width:85vw;height:100%;background:#fff;box-shadow:-4px 0 24px rgba(15,23,42,.15);display:flex;flex-direction:column;overflow-y:auto;transform:translateX(100%);transition:transform .25s ease}
    .mobile-nav.open .mobile-nav-panel{transform:translateX(0)}
    .mobile-nav-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);background:#fff}
    .mobile-nav-head strong{font-weight:800;font-size:16px;color:var(--text)}
    .mobile-nav-close{background:none;border:none;cursor:pointer;color:var(--dim);padding:6px;border-radius:8px;line-height:1;font-size:22px}
    .mobile-nav-links{flex:1}
    .mobile-nav-links a{display:block;padding:15px 20px;font-size:15px;font-weight:600;color:var(--text);border-bottom:1px solid var(--border);text-decoration:none}
    .mobile-nav-links a:active{background:var(--surface-2)}
    .mobile-nav-footer{padding:16px 20px;border-top:1px solid var(--border);font-size:12px;color:var(--dim)}

    /* ── Main ───────────────────────────────────────────────────────────── */
    .main{max-width:1120px;margin:0 auto;padding:20px 20px 70px}
    .breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:7px;color:var(--dim);font-size:13px;margin-bottom:18px}
    .breadcrumb a{color:var(--dim)}
    .breadcrumb a:hover{color:var(--accent)}

    /* ── Hero ───────────────────────────────────────────────────────────── */
    .hero{background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);padding:28px 32px;margin-bottom:28px}
    .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent-dark);font-size:12px;font-weight:700;margin-bottom:10px}
    h1{font-size:clamp(26px,3.8vw,44px);max-width:100%;margin-bottom:10px;letter-spacing:-.035em;line-height:1.15}
    .hero-subtitle{color:var(--muted);font-size:15px;line-height:1.6;max-width:640px;margin-bottom:16px}

    /* ── Search ─────────────────────────────────────────────────────────── */
    .search-wrap{position:relative;max-width:520px}
    .search-icon-wrap{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--soft);pointer-events:none}
    .search-bar{width:100%;padding:13px 16px 13px 44px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:15px;font-family:var(--sans);outline:none;transition:border-color .15s ease,box-shadow .15s ease}
    .search-bar:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
    .search-bar::placeholder{color:var(--soft)}
    .search-count{font-size:13px;color:var(--dim);margin-top:8px}

    /* ── Category sections ──────────────────────────────────────────────── */
    .cat-section{margin-bottom:36px}
    .cat-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--border)}
    .cat-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
    .cat-title{font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--text)}
    .cat-count{font-size:12px;font-weight:700;color:var(--dim);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:2px 9px;margin-left:auto}

    /* ── Term cards ─────────────────────────────────────────────────────── */
    .term-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
    .term-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s ease,box-shadow .15s ease;text-decoration:none;min-width:0}
    .term-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(37,99,235,.1);text-decoration:none}
    .term-card h3{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin:0}
    .term-card p{font-size:13px;color:var(--muted);line-height:1.5;margin:0}
    .term-card .arrow{font-size:12px;font-weight:800;color:var(--accent);margin-top:4px}
    .term-card.hidden{display:none}

    /* ── Also known as pill ─────────────────────────────────────────────── */
    .also{display:inline-block;font-size:11px;font-weight:700;color:var(--dim);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:2px 8px;margin-bottom:4px}

    /* ── No results ─────────────────────────────────────────────────────── */
    .no-results{display:none;text-align:center;padding:48px 20px;color:var(--dim);font-size:15px}
    .no-results.show{display:block}

    /* ── Coming soon banner ─────────────────────────────────────────────── */
    .coming-soon{background:var(--surface-3);border:1px dashed #bfdbfe;border-radius:14px;padding:16px 20px;margin-top:12px;font-size:13px;color:var(--muted)}
    .coming-soon strong{color:var(--accent-dark)}

    /* ── Footer ─────────────────────────────────────────────────────────── */
    .footer{border-top:1px solid var(--border);background:#fff;padding:40px 20px 24px;margin-top:40px}
    .footer-inner{max-width:1120px;margin:0 auto}
    .footer-cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:32px;margin-bottom:32px}
    .footer-col h4{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}
    .footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
    .footer-col ul li a{color:var(--muted);font-size:13px;font-weight:600;transition:color .12s ease}
    .footer-col ul li a:hover{color:var(--accent);text-decoration:none}
    .footer-base{border-top:1px solid var(--border);padding-top:20px;color:var(--dim);font-size:12px}

    /* ── Responsive ─────────────────────────────────────────────────────── */
    @media(max-width:980px){
      .term-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
      .footer-cols{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
    }
    @media(max-width:760px){
      .top-nav{display:none}
      .menu-btn{display:block}
      .main{padding:16px 12px 48px}
      .hero{padding:18px 20px}
      h1{font-size:24px}
      .term-grid{grid-template-columns:1fr}
    }
    @media(max-width:420px){
      .footer-cols{grid-template-columns:1fr}
    }