  :root{
    --bg:#0a0a0a;
    --bg-elev:#111111;
    --bg-elev-2:#161616;
    --border:#222222;
    --border-bright:#2e2e2e;
    --text:#fafafa;
    --text-dim:#a1a1a1;
    --text-faint:#666666;
    --accent:#00ff88;
    --accent-dim:#00cc6e;
    --accent-bg:rgba(0,255,136,0.08);
    --btc:#f7931a;
    --danger:#ff4d4d;
    --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
    --sans:'Geist','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--sans);
    background:var(--bg);
    color:var(--text);
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  body::before{
    content:"";
    position:fixed;inset:0;
    background-image:
      radial-gradient(circle at 20% 0%,rgba(0,255,136,0.04),transparent 50%),
      radial-gradient(circle at 80% 100%,rgba(0,255,136,0.03),transparent 50%);
    pointer-events:none;z-index:0;
  }
  body::after{
    content:"";
    position:fixed;inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,0.015) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,0.015) 1px,transparent 1px);
    background-size:60px 60px;
    pointer-events:none;z-index:0;
  }
  ::selection{background:var(--accent);color:#000}
  a{color:inherit;text-decoration:none}
  .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

  /* NAV */
  .nav{
    position:sticky;top:0;z-index:50;
    background:rgba(10,10,10,0.85);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid var(--border);
  }
  .nav-inner{
    max-width:1400px;margin:0 auto;
    padding:18px 32px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
  }
  .logo{
    font-family:var(--mono);font-weight:700;font-size:20px;
    letter-spacing:-0.02em;
    display:inline-flex;align-items:baseline;
    line-height:1;
    text-decoration:none;
    position:relative;
  }
  .logo-paid{
    position:relative;
    color:var(--text);
    display:inline-block;
  }
  .logo-paid::after{
    content:"";
    position:absolute;
    left:-3px;right:-3px;
    top:52%;
    height:3px;
    background:var(--danger);
    transform:rotate(-6deg);
    border-radius:1px;
    box-shadow:0 0 8px rgba(255,77,77,0.4);
    pointer-events:none;
  }
  .logo-x{
    color:var(--danger);
    font-weight:800;
    font-size:1.4em;
    margin-left:3px;
    line-height:1;
    transform:translateY(2px);
    display:inline-block;
    text-shadow:0 0 12px rgba(255,77,77,0.35);
  }
  .logo:hover .logo-paid::after{
    background:var(--accent);
    box-shadow:0 0 8px rgba(0,255,136,0.5);
    transition:all .2s;
  }
  .logo:hover .logo-x{
    color:var(--accent);
    text-shadow:0 0 12px rgba(0,255,136,0.4);
    transition:all .2s;
  }
  .nav-links{display:flex;gap:28px;font-family:var(--mono);font-size:13px}
  .nav-links a{color:var(--text-dim);transition:color .15s}
  .nav-links a:hover{color:var(--accent)}
  .nav-cta{
    font-family:var(--mono);font-size:13px;font-weight:600;
    padding:8px 16px;border:1px solid var(--accent);
    color:var(--accent);border-radius:4px;
    transition:all .15s;
  }
  .nav-cta:hover{background:var(--accent);color:#000}

  /* HERO */
  .hero{
    position:relative;z-index:1;
    max-width:1400px;margin:0 auto;
    padding:120px 32px 80px;
  }
  .hero-tag{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--mono);font-size:12px;
    color:var(--accent);
    background:var(--accent-bg);
    border:1px solid rgba(0,255,136,0.25);
    padding:6px 14px;border-radius:100px;
    margin-bottom:32px;
  }
  .hero-tag::before{
    content:"";width:6px;height:6px;border-radius:50%;
    background:var(--accent);
    animation:pulse 2s infinite;
  }
  @keyframes pulse{
    0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,255,136,0.6)}
    50%{opacity:0.6;box-shadow:0 0 0 8px rgba(0,255,136,0)}
  }
  h1.hero-title{
    font-family:var(--mono);
    font-weight:800;
    font-size:clamp(48px,9vw,128px);
    line-height:0.95;
    letter-spacing:-0.045em;
    margin-bottom:32px;
  }
  h1.hero-title .crossed{
    position:relative;color:var(--text-dim);
  }
  h1.hero-title .crossed::after{
    content:"";position:absolute;left:-2%;right:-2%;top:54%;
    height:8px;background:var(--danger);
    transform:rotate(-3deg);
  }
  h1.hero-title .free{color:var(--accent)}
  .hero-sub{
    font-size:clamp(17px,1.6vw,21px);
    color:var(--text-dim);
    max-width:680px;
    margin-bottom:48px;
    line-height:1.55;
  }
  .hero-sub strong{color:var(--text);font-weight:500}
  .stats{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:0;
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
    margin-top:24px;
  }
  .stat{
    padding:28px 24px;
    border-right:1px solid var(--border);
  }
  .stat:last-child{border-right:none}
  .stat-num{
    font-family:var(--mono);
    font-weight:700;
    font-size:36px;
    color:var(--accent);
    letter-spacing:-0.03em;
    line-height:1;
  }
  .stat-label{
    font-family:var(--mono);
    font-size:11px;
    color:var(--text-faint);
    text-transform:uppercase;
    letter-spacing:0.1em;
    margin-top:8px;
  }

  /* MARQUEE */
  .marquee{
    overflow:hidden;
    border-bottom:1px solid var(--border);
    padding:18px 0;
    background:var(--bg-elev);
    position:relative;z-index:1;
  }
  .marquee-track{
    display:flex;gap:48px;
    width:max-content;
    animation:scroll 60s linear infinite;
    font-family:var(--mono);
    font-size:14px;
    color:var(--text-faint);
  }
  .marquee-track span{white-space:nowrap}
  .marquee-track .x{color:var(--danger)}
  .marquee-track .arrow{color:var(--text-faint)}
  .marquee-track .ok{color:var(--accent)}
  @keyframes scroll{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
  }

  /* DIRECTORY */
  .directory{
    position:relative;z-index:1;
    max-width:1400px;margin:0 auto;
    padding:80px 32px;
  }
  .section-head{
    margin-bottom:40px;
    display:flex;align-items:flex-end;justify-content:space-between;
    flex-wrap:wrap;gap:16px;
  }
  .section-eyebrow{
    font-family:var(--mono);font-size:12px;
    color:var(--accent);
    text-transform:uppercase;letter-spacing:0.15em;
    margin-bottom:12px;
  }
  .section-title{
    font-family:var(--mono);
    font-weight:700;
    font-size:clamp(32px,4vw,52px);
    letter-spacing:-0.03em;line-height:1;
  }
  .section-desc{
    color:var(--text-dim);
    max-width:420px;font-size:15px;
    line-height:1.6;
  }

  /* SEARCH */
  .search-wrap{
    position:relative;
    margin-bottom:24px;
  }
  .search{
    width:100%;
    background:var(--bg-elev);
    border:1px solid var(--border-bright);
    color:var(--text);
    font-family:var(--mono);
    font-size:15px;
    padding:18px 24px 18px 56px;
    border-radius:8px;
    outline:none;
    transition:border-color .15s, box-shadow .15s;
  }
  .search:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-bg);
  }
  .search::placeholder{color:var(--text-faint)}
  .search-icon{
    position:absolute;left:20px;top:50%;
    transform:translateY(-50%);
    color:var(--text-faint);
    pointer-events:none;
  }

  /* CATEGORIES */
  .categories{
    display:flex;flex-wrap:wrap;gap:8px;
    margin-bottom:48px;
  }
  .cat-pill{
    font-family:var(--mono);
    font-size:12px;
    padding:8px 14px;
    background:var(--bg-elev);
    border:1px solid var(--border);
    color:var(--text-dim);
    border-radius:100px;
    cursor:pointer;
    transition:all .15s;
    user-select:none;
  }
  .cat-pill:hover{
    border-color:var(--accent);
    color:var(--text);
  }
  .cat-pill.active{
    background:var(--accent);
    color:#000;
    border-color:var(--accent);
    font-weight:600;
  }
  .cat-count{
    opacity:0.5;margin-left:6px;
  }

  /* FILTER BAR */
  .filter-bar{
    display:flex;flex-wrap:wrap;gap:18px;
    padding:16px 18px;
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:8px;
    margin-bottom:24px;
    align-items:center;
  }
  .filter-group{
    display:flex;align-items:center;gap:8px;
    flex-wrap:wrap;
  }
  .filter-label{
    font-family:var(--mono);
    font-size:11px;
    color:var(--text-faint);
    text-transform:uppercase;
    letter-spacing:0.12em;
    margin-right:4px;
  }
  .filter-pill{
    font-family:var(--mono);
    font-size:11.5px;
    padding:6px 11px;
    background:var(--bg);
    border:1px solid var(--border-bright);
    color:var(--text-dim);
    border-radius:100px;
    cursor:pointer;
    transition:all .15s;
    user-select:none;
    display:inline-flex;align-items:center;gap:5px;
  }
  .filter-pill:hover{border-color:var(--accent);color:var(--text)}
  .filter-pill.active{
    background:var(--accent);color:#000;border-color:var(--accent);font-weight:600;
  }
  .filter-pill.active.foss{background:#a855f7;border-color:#a855f7;color:#fff}
  .filter-pill.active.selfhost{background:var(--btc);border-color:var(--btc);color:#000}
  .filter-pill.active.privacy{background:#63b3ed;border-color:#63b3ed;color:#000}
  .filter-reset{
    margin-left:auto;
    font-family:var(--mono);
    font-size:11px;font-weight:600;
    padding:6px 12px;
    background:transparent;
    border:1px solid var(--border-bright);
    color:var(--text-dim);
    border-radius:5px;
    cursor:pointer;
    transition:all .15s;
  }
  .filter-reset:hover{color:var(--danger);border-color:var(--danger)}
  .filter-result-count{
    font-family:var(--mono);
    font-size:11px;
    color:var(--text-faint);
    margin-left:auto;
    padding-right:8px;
  }

  /* SAVINGS BADGE in card */
  .card-savings-mini{
    font-family:var(--mono);
    font-size:11px;
    font-weight:600;
    color:var(--accent);
    background:var(--accent-bg);
    border:1px solid rgba(0,255,136,0.25);
    padding:3px 8px;
    border-radius:3px;
    white-space:nowrap;
    flex-shrink:0;
    margin-top:6px;
    align-self:flex-start;
  }
  .card-savings-mini.once{
    color:var(--btc);
    background:rgba(247,147,26,0.08);
    border-color:rgba(247,147,26,0.3);
  }

  /* SUGGEST CTA + MODAL */
  .suggest-cta{
    display:inline-flex;align-items:center;gap:6px;
    font-family:var(--mono);
    font-size:12px;font-weight:600;
    padding:7px 14px;
    background:transparent;
    border:1px dashed var(--accent);
    color:var(--accent);
    border-radius:5px;
    cursor:pointer;
    transition:all .15s;
  }
  .suggest-cta:hover{background:var(--accent-bg)}
  .suggest-cta::before{content:"+";font-weight:700;font-size:14px;line-height:1}

  .modal-overlay{
    display:none;
    position:fixed;inset:0;
    background:rgba(0,0,0,0.75);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    z-index:100;
    align-items:center;justify-content:center;
    padding:20px;
  }
  .modal-overlay.open{display:flex}
  .modal-card{
    background:var(--bg-elev);
    border:1px solid var(--border-bright);
    border-radius:12px;
    padding:36px;
    max-width:520px;
    width:100%;
    position:relative;
    max-height:90vh;
    overflow-y:auto;
  }
  .modal-close{
    position:absolute;top:14px;right:14px;
    background:transparent;border:none;
    color:var(--text-faint);
    cursor:pointer;
    font-size:24px;line-height:1;
    padding:6px 10px;
    border-radius:4px;
    transition:color .15s;
  }
  .modal-close:hover{color:var(--danger)}
  .modal-card h3{
    font-family:var(--mono);
    font-size:22px;font-weight:700;
    letter-spacing:-0.02em;
    margin-bottom:8px;
  }
  .modal-card p.modal-sub{
    color:var(--text-dim);
    font-size:14px;
    line-height:1.55;
    margin-bottom:24px;
  }
  .modal-form{
    display:flex;flex-direction:column;gap:14px;
  }
  .modal-field label{
    display:block;
    font-family:var(--mono);
    font-size:11px;
    color:var(--text-faint);
    text-transform:uppercase;
    letter-spacing:0.12em;
    margin-bottom:6px;
  }
  .modal-field input,
  .modal-field textarea,
  .modal-field select{
    width:100%;
    background:var(--bg);
    border:1px solid var(--border-bright);
    color:var(--text);
    font-family:var(--mono);
    font-size:13.5px;
    padding:11px 14px;
    border-radius:6px;
    outline:none;
    transition:border-color .15s;
    font-family:var(--sans);
    resize:vertical;
  }
  .modal-field input:focus,
  .modal-field textarea:focus,
  .modal-field select:focus{border-color:var(--accent)}
  .modal-field textarea{min-height:88px;font-family:var(--sans)}
  .modal-submit{
    font-family:var(--mono);
    font-size:13px;font-weight:700;
    background:var(--accent);color:#000;
    border:none;
    padding:13px 20px;
    border-radius:6px;
    cursor:pointer;
    transition:all .15s;
    margin-top:6px;
  }
  .modal-submit:hover{background:var(--accent-dim)}

  @media (max-width:880px){
    .filter-bar{padding:14px;gap:12px}
    .filter-reset{margin-left:0;width:100%;text-align:center;margin-top:4px}
    .filter-result-count{margin-left:0;width:100%;text-align:center;order:-1;padding-right:0}
    .modal-card{padding:28px 22px}
  }

  /* GRID */
  .grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
    gap:12px;
  }
  .card{
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:8px;
    padding:24px;
    transition:all .15s;
    display:flex;flex-direction:column;
    min-height:180px;
  }
  .card:hover{background:var(--bg-elev-2);border-color:var(--border-bright)}
  .card-head{
    display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
    margin-bottom:14px;
  }
  .card-paid{
    font-family:var(--mono);
    font-weight:700;
    font-size:16px;
    color:var(--text);
    letter-spacing:-0.01em;
    line-height:1.3;
    text-decoration:line-through;
    text-decoration-color:var(--danger);
    text-decoration-thickness:2px;
  }
  a.card-paid-link{display:inline-block;cursor:pointer;transition:color .15s}
  a.card-paid-link:hover{color:var(--accent)}
  .card-cat{
    font-family:var(--mono);
    font-size:10px;
    color:var(--text-faint);
    text-transform:uppercase;letter-spacing:0.1em;
    background:var(--bg);
    padding:4px 8px;
    border-radius:3px;
    border:1px solid var(--border);
    white-space:nowrap;
    flex-shrink:0;
  }
  .card-desc{
    font-size:13.5px;
    color:var(--text-dim);
    line-height:1.55;
    margin-bottom:16px;
    flex:1;
  }
  .card-arrow{
    font-family:var(--mono);
    color:var(--accent);
    font-size:13px;
    margin-bottom:8px;
    display:flex;align-items:center;gap:6px;
  }
  .card-arrow::before{content:"→";font-size:16px}
  .alts{
    display:flex;flex-wrap:wrap;gap:6px;
  }
  .alts-list{
    display:flex;flex-direction:column;gap:12px;
  }
  .alt-item{
    display:block;
  }
  .alt-wrap{
    display:flex;
    flex-direction:row;
    flex-wrap:wrap;
    align-items:center;
    gap:6px;
    margin-bottom:4px;
  }
  .alt-desc{
    font-family:var(--sans);
    font-size:12px;
    color:var(--text-faint);
    line-height:1.45;
    padding-left:2px;
    margin-top:1px;
  }
  /* SWITCH SCORE — difficulty dots + compat phrase under each alt */
  .switch-score{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:8px;
    margin-top:3px;
    padding-left:2px;
    font-family:var(--mono);
    font-size:11px;
    line-height:1.4;
    color:var(--text-faint);
  }
  .switch-diff{
    display:inline-flex;align-items:center;gap:5px;
    color:var(--accent);
  }
  .switch-dots{letter-spacing:1px;font-size:10px;line-height:1}
  .switch-diff.easy .switch-dots{color:var(--accent)}
  .switch-diff.medium .switch-dots{color:var(--btc)}
  .switch-diff.hard .switch-dots{color:var(--danger)}
  .switch-diff.easy{color:var(--accent)}
  .switch-diff.medium{color:var(--btc)}
  .switch-diff.hard{color:var(--danger)}
  .switch-sep{color:var(--text-faint);opacity:0.5}
  .switch-compat{color:var(--text-dim);font-family:var(--sans);font-size:11.5px}
  .alt{
    font-family:var(--mono);
    font-size:12.5px;
    font-weight:500;
    color:var(--accent);
    background:var(--accent-bg);
    border:1px solid rgba(0,255,136,0.25);
    padding:5px 10px;
    border-radius:4px;
    transition:all .15s;
    display:inline-block;
  }
  .alt:hover{
    background:var(--accent);
    color:#000;
    border-color:var(--accent);
    transform:translateY(-1px);
    box-shadow:0 4px 12px rgba(0,255,136,0.2);
  }
  .alt-ico{
    font-family:'Segoe UI Symbol','Arial',sans-serif;
    font-variant-east-asian:normal;
    display:inline-block;
  }
  .empty{
    grid-column:1/-1;
    background:var(--bg-elev);
    padding:60px 24px;
    text-align:center;
    color:var(--text-dim);
    font-family:var(--mono);
  }

  /* PAGINATION */
  .pagination{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    justify-content:center;
    gap:6px;
    margin-top:32px;
    font-family:var(--mono);
  }
  .pagination[hidden]{display:none}
  .page-btn{
    font-family:var(--mono);
    font-size:13px;
    font-weight:600;
    min-width:38px;
    height:38px;
    padding:0 12px;
    background:var(--bg-elev);
    border:1px solid var(--border-bright);
    color:var(--text-dim);
    border-radius:6px;
    cursor:pointer;
    transition:all .15s;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    user-select:none;
  }
  .page-btn:hover:not(:disabled):not(.active){
    color:var(--text);
    border-color:var(--accent);
    background:var(--bg-elev-2);
  }
  .page-btn.active{
    background:var(--accent);
    color:#000;
    border-color:var(--accent);
    cursor:default;
  }
  .page-btn:disabled{
    opacity:0.35;
    cursor:not-allowed;
  }
  .page-btn.nav{
    padding:0 14px;
    color:var(--text);
  }
  .page-ellipsis{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:28px;
    height:38px;
    color:var(--text-faint);
    font-family:var(--mono);
    font-size:14px;
    user-select:none;
  }
  .pagination-meta{
    width:100%;
    text-align:center;
    font-family:var(--mono);
    font-size:11.5px;
    color:var(--text-faint);
    margin-top:14px;
    letter-spacing:0.05em;
  }
  .pagination-meta strong{
    color:var(--text-dim);
    font-weight:600;
  }
  @media (max-width:560px){
    .page-btn{min-width:34px;height:34px;font-size:12px;padding:0 9px}
    .page-btn.nav{padding:0 10px}
    .page-ellipsis{min-width:22px;height:34px}
  }

  /* ABOUT */
  .about{
    position:relative;z-index:1;
    border-top:1px solid var(--border);
    background:var(--bg-elev);
    padding:100px 32px;
  }
  .about-inner{
    max-width:1000px;margin:0 auto;
    display:grid;grid-template-columns:1fr 1fr;gap:64px;
    align-items:start;
  }
  .about h2{
    font-family:var(--mono);
    font-size:clamp(32px,4vw,48px);
    font-weight:700;
    letter-spacing:-0.03em;
    line-height:1;
    margin-bottom:24px;
  }
  .about p{
    color:var(--text-dim);
    font-size:16px;
    line-height:1.7;
    margin-bottom:18px;
  }
  .about p strong{color:var(--text);font-weight:500}
  .about-list{
    list-style:none;
    display:flex;flex-direction:column;gap:18px;
  }
  .about-list li{
    font-family:var(--mono);
    font-size:14px;
    padding-left:28px;
    position:relative;
    color:var(--text-dim);
    line-height:1.6;
  }
  .about-list li::before{
    content:"$";
    position:absolute;left:0;top:0;
    color:var(--accent);
    font-weight:700;
  }
  .about-list li strong{color:var(--text);font-weight:600}

  /* DONATE */
  .donate{
    position:relative;z-index:1;
    padding:100px 32px;
    border-top:1px solid var(--border);
  }
  .donate-inner{
    max-width:880px;margin:0 auto;
    background:linear-gradient(135deg,rgba(0,255,136,0.04),rgba(0,255,136,0.015));
    border:1px solid rgba(0,255,136,0.25);
    border-radius:12px;
    padding:48px;
    position:relative;
    overflow:hidden;
  }
  .donate-inner::before{
    content:"◆";
    position:absolute;
    right:-40px;top:-60px;
    font-size:320px;
    font-family:var(--mono);
    color:rgba(0,255,136,0.05);
    font-weight:700;
    line-height:1;
    pointer-events:none;
  }
  .donate-eyebrow{
    font-family:var(--mono);font-size:12px;
    color:var(--accent);
    text-transform:uppercase;letter-spacing:0.15em;
    margin-bottom:16px;
    display:flex;align-items:center;gap:8px;
  }
  .donate-eyebrow::before{
    content:"◆";font-size:14px;font-weight:700;
  }
  .donate h2{
    font-family:var(--mono);
    font-size:clamp(28px,3.5vw,42px);
    font-weight:700;
    letter-spacing:-0.03em;
    line-height:1.05;
    margin-bottom:20px;
    position:relative;
  }
  .donate p{
    color:var(--text-dim);
    font-size:16px;
    line-height:1.65;
    margin-bottom:32px;
    max-width:560px;
    position:relative;
  }
  .crypto-list{
    display:flex;flex-direction:column;gap:10px;
    position:relative;
  }
  .crypto-row{
    background:#000;
    border:1px solid var(--border-bright);
    border-radius:8px;
    padding:16px 20px;
    display:flex;align-items:center;gap:16px;
    position:relative;
    flex-wrap:wrap;
    transition:border-color .15s;
  }
  .crypto-row:hover{border-color:var(--text-faint)}
  .crypto-meta{
    display:flex;align-items:center;gap:12px;
    min-width:170px;
    flex-shrink:0;
  }
  .crypto-symbol{
    width:36px;height:36px;
    display:inline-flex;align-items:center;justify-content:center;
    border-radius:50%;
    background:var(--bg-elev);
    border:1px solid var(--border-bright);
    font-family:var(--mono);
    font-size:18px;font-weight:700;
    line-height:1;
    flex-shrink:0;
  }
  .crypto-symbol.btc{color:var(--btc);border-color:rgba(247,147,26,0.4)}
  .crypto-symbol.eth{color:#9aa0ff;border-color:rgba(154,160,255,0.4)}
  .crypto-symbol.sol{color:#9945ff;border-color:rgba(153,69,255,0.4)}
  .crypto-symbol.doge{color:#c2a633;border-color:rgba(194,166,51,0.4)}
  .crypto-symbol.xrp{color:#e0e0e0;border-color:rgba(224,224,224,0.4)}
  .crypto-name-wrap{
    display:flex;flex-direction:column;gap:2px;
    line-height:1.2;
  }
  .crypto-name{
    font-family:var(--mono);
    font-size:14px;font-weight:700;
    color:var(--text);
    letter-spacing:-0.01em;
  }
  .crypto-net{
    font-family:var(--mono);
    font-size:10.5px;
    color:var(--text-faint);
    text-transform:uppercase;
    letter-spacing:0.1em;
  }
  .crypto-addr-wrap{flex:1;min-width:0}
  .crypto-addr{
    font-family:var(--mono);
    font-size:13px;
    color:var(--text);
    word-break:break-all;
    line-height:1.4;
    user-select:all;
    font-weight:500;
  }
  .copy-btn{
    font-family:var(--mono);
    font-size:13px;font-weight:600;
    padding:9px 16px;
    background:var(--accent);
    color:#000;
    border:none;
    border-radius:6px;
    cursor:pointer;
    transition:all .15s;
    white-space:nowrap;
  }
  .copy-btn:hover{background:var(--accent-dim);transform:translateY(-1px)}
  .copy-btn.copied{background:var(--accent);box-shadow:0 0 0 3px rgba(0,255,136,0.25)}
  .donate-warn{
    margin-top:18px;
    font-family:var(--mono);
    font-size:12.5px;
    color:var(--danger);
    background:rgba(255,77,77,0.08);
    border-left:3px solid var(--danger);
    padding:12px 16px;
    border-radius:0 4px 4px 0;
    position:relative;
  }
  .donate-warn strong{color:#fff}

  /* CONTACT */
  .contact{
    position:relative;z-index:1;
    padding:100px 32px;
    border-top:1px solid var(--border);
    background:var(--bg-elev);
  }
  .contact-inner{
    max-width:880px;margin:0 auto;
    text-align:center;
  }
  .contact h2{
    font-family:var(--mono);
    font-size:clamp(32px,4vw,52px);
    font-weight:700;
    letter-spacing:-0.03em;line-height:1;
    margin-bottom:20px;
  }
  .contact p{
    color:var(--text-dim);
    font-size:17px;line-height:1.6;
    margin-bottom:36px;
    max-width:560px;
    margin-left:auto;margin-right:auto;
  }
  .contact-actions{
    display:inline-flex;align-items:stretch;gap:10px;
    flex-wrap:wrap;justify-content:center;
  }
  .contact-link{
    display:inline-flex;align-items:center;gap:14px;
    font-family:var(--mono);
    font-size:clamp(18px,2.5vw,28px);
    font-weight:600;
    color:var(--accent);
    background:var(--accent-bg);
    border:1px solid rgba(0,255,136,0.3);
    padding:18px 32px;
    border-radius:8px;
    transition:all .2s;
    letter-spacing:-0.01em;
  }
  .contact-link:hover{
    background:var(--accent);
    color:#000;
    transform:translateY(-2px);
    box-shadow:0 12px 30px rgba(0,255,136,0.2);
  }
  .contact-link::before{content:"@";opacity:0.7}
  .contact-link.copied{
    background:var(--accent);
    color:#000;
    border-color:var(--accent);
  }
  .contact-link.copied::before{content:"✓";opacity:1}
  .contact-copy-btn{
    display:inline-flex;align-items:center;gap:8px;
    font-family:var(--mono);
    font-size:14px;font-weight:600;
    color:var(--text-dim);
    background:var(--bg);
    border:1px solid var(--border-bright);
    padding:0 18px;
    border-radius:8px;
    cursor:pointer;
    transition:all .15s;
    letter-spacing:0.02em;
    line-height:1;
  }
  .contact-copy-btn:hover{
    color:var(--accent);
    border-color:var(--accent);
    background:var(--accent-bg);
    transform:translateY(-2px);
  }
  .contact-copy-btn .contact-copy-icon{
    font-size:16px;line-height:1;
  }
  .contact-copy-btn.copied{
    color:#000;
    background:var(--accent);
    border-color:var(--accent);
  }

  /* FOOTER */
  footer{
    position:relative;z-index:1;
    padding:64px 32px 40px;
    border-top:1px solid var(--border);
    background:var(--bg-elev);
    font-family:var(--mono);
    font-size:13px;
    color:var(--text-faint);
  }
  .footer-inner{
    max-width:1400px;margin:0 auto;
  }
  .footer-grid{
    display:grid;
    grid-template-columns:1.5fr repeat(3,1fr);
    gap:40px;
    margin-bottom:48px;
  }
  .footer-brand{max-width:340px}
  .footer-logo{
    font-family:var(--mono);font-weight:700;font-size:22px;
    letter-spacing:-0.02em;
    color:var(--text);
    display:inline-flex;
    align-items:baseline;
    line-height:1;
    margin-bottom:14px;
  }
  .footer-logo .logo-paid{
    position:relative;
    color:var(--text);
  }
  .footer-logo .logo-paid::after{
    content:"";
    position:absolute;
    left:-3px;right:-3px;top:52%;
    height:3px;
    background:var(--danger);
    transform:rotate(-6deg);
    border-radius:1px;
    box-shadow:0 0 8px rgba(255,77,77,0.4);
  }
  .footer-logo .logo-x{
    color:var(--danger);
    font-weight:800;
    font-size:1.4em;
    margin-left:3px;
    line-height:1;
    transform:translateY(2px);
    text-shadow:0 0 12px rgba(255,77,77,0.35);
  }
  .footer-tagline{
    font-family:var(--sans);
    font-size:13.5px;
    color:var(--text-dim);
    line-height:1.6;
  }
  .footer-col{
    display:flex;flex-direction:column;gap:10px;
  }
  .footer-head{
    font-family:var(--mono);
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.15em;
    color:var(--text);
    margin-bottom:6px;
  }
  .footer-col a{
    color:var(--text-dim);
    font-size:13px;
    transition:color .15s;
  }
  .footer-col a:hover{color:var(--accent)}
  .footer-bottom{
    padding-top:32px;
    border-top:1px solid var(--border);
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:16px;
    font-size:12px;
  }
  .footer-meta{color:var(--text-faint)}
  .affiliate-disclosure{
    font-size:11px;
    color:var(--text-faint);
    margin-top:8px;
    display:block;
  }
  footer .heart{color:var(--accent)}

  /* REGION SELECTOR */
  .region-select{
    font-family:var(--mono);
    font-size:12px;
    font-weight:500;
    background:var(--bg-elev);
    border:1px solid var(--border-bright);
    color:var(--text);
    padding:7px 28px 7px 12px;
    border-radius:4px;
    cursor:pointer;
    outline:none;
    appearance:none;
    -webkit-appearance:none;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23a1a1a1' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat:no-repeat;
    background-position:right 10px center;
    transition:border-color .15s;
  }
  .region-select:hover,.region-select:focus{border-color:var(--accent)}

  /* CALCULATOR */
  .calc{
    position:relative;z-index:1;
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
    padding:80px 32px;
    background:
      radial-gradient(circle at 0% 0%,rgba(0,255,136,0.04),transparent 40%),
      radial-gradient(circle at 100% 100%,rgba(0,255,136,0.03),transparent 40%);
  }
  .calc-inner{
    max-width:1200px;margin:0 auto;
    display:grid;grid-template-columns:1fr 1fr;gap:48px;
    align-items:start;
  }
  .calc-left .section-eyebrow{margin-bottom:14px}
  .calc-left h2{
    font-family:var(--mono);
    font-weight:700;
    font-size:clamp(36px,5vw,64px);
    letter-spacing:-0.035em;
    line-height:1;
    margin-bottom:20px;
  }
  .calc-left h2 .free{color:var(--accent)}
  .calc-left p{
    color:var(--text-dim);
    font-size:16px;
    line-height:1.65;
    margin-bottom:24px;
    max-width:480px;
  }
  .calc-region{
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:8px;
    padding:18px 20px;
    margin-bottom:10px;
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    flex-wrap:wrap;
  }
  .calc-region-hint{
    font-family:var(--mono);
    font-size:11.5px;
    color:var(--text-faint);
    line-height:1.55;
    margin-bottom:24px;
    padding:0 4px;
  }
  .calc-region-label{
    font-family:var(--mono);
    font-size:11px;
    color:var(--text-faint);
    text-transform:uppercase;letter-spacing:0.12em;
    display:block;margin-bottom:4px;
  }
  .calc-region-current{
    font-family:var(--mono);
    font-size:15px;
    font-weight:600;
    color:var(--text);
  }
  .calc-region select{
    font-family:var(--mono);
    font-size:13px;
    background:var(--bg);
    border:1px solid var(--border-bright);
    color:var(--text);
    padding:10px 32px 10px 14px;
    border-radius:6px;
    cursor:pointer;
    outline:none;
    appearance:none;
    -webkit-appearance:none;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2300ff88' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat:no-repeat;
    background-position:right 12px center;
    transition:border-color .15s;
  }
  .calc-region select:focus{border-color:var(--accent)}

  /* RESULT BOX */
  .calc-result{
    background:linear-gradient(135deg,rgba(0,255,136,0.06),rgba(0,255,136,0.02));
    border:1px solid rgba(0,255,136,0.3);
    border-radius:12px;
    padding:32px;
    position:relative;
    overflow:hidden;
  }
  .calc-result::before{
    content:"$";
    position:absolute;right:-30px;top:-50px;
    font-family:var(--mono);
    font-size:280px;font-weight:700;
    color:rgba(0,255,136,0.05);line-height:1;
    pointer-events:none;
  }
  .calc-result-label{
    font-family:var(--mono);
    font-size:11px;
    color:var(--accent);
    text-transform:uppercase;letter-spacing:0.15em;
    margin-bottom:12px;
  }
  .calc-result-num{
    font-family:var(--mono);
    font-weight:800;
    font-size:clamp(38px,5.5vw,68px);
    letter-spacing:-0.04em;
    line-height:1;
    color:var(--accent);
    margin-bottom:14px;
    word-break:break-word;
  }
  .calc-result-num .small{
    font-size:0.55em;
    color:var(--text-dim);
    font-weight:600;
  }
  .calc-result-num .range-sep{
    color:var(--text-faint);
    font-weight:400;
  }
  .calc-result-sub{
    font-family:var(--mono);
    font-size:13.5px;
    color:var(--text-dim);
    line-height:1.6;
  }
  .calc-result-sub strong{color:var(--text);font-weight:600}
  .calc-empty{
    font-family:var(--mono);
    font-size:14px;
    color:var(--text-faint);
    font-style:italic;
  }

  /* RIGHT: APP LIST */
  .calc-right{
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:12px;
    padding:24px;
    max-height:640px;
    display:flex;flex-direction:column;
  }
  .calc-search-wrap{position:relative;margin-bottom:14px;flex-shrink:0}
  .calc-search{
    width:100%;
    background:var(--bg);
    border:1px solid var(--border-bright);
    color:var(--text);
    font-family:var(--mono);
    font-size:13px;
    padding:11px 14px 11px 38px;
    border-radius:6px;
    outline:none;
    transition:border-color .15s;
  }
  .calc-search:focus{border-color:var(--accent)}
  .calc-search::placeholder{color:var(--text-faint)}
  .calc-search-icon{
    position:absolute;left:13px;top:50%;
    transform:translateY(-50%);
    color:var(--text-faint);
    pointer-events:none;
  }
  .calc-list{
    flex:1;
    overflow-y:auto;
    margin:0 -8px;padding:0 8px;
  }
  .calc-list::-webkit-scrollbar{width:6px}
  .calc-list::-webkit-scrollbar-track{background:transparent}
  .calc-list::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}
  .calc-list::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}
  .calc-item{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:11px 12px;
    border-radius:6px;
    cursor:pointer;
    transition:background .12s;
    user-select:none;
  }
  .calc-item:hover{background:var(--bg)}
  .calc-item.checked{background:var(--accent-bg);border:1px solid rgba(0,255,136,0.25)}
  .calc-item-left{
    display:flex;align-items:center;gap:11px;
    min-width:0;flex:1;
  }
  .calc-check{
    width:18px;height:18px;
    border:1.5px solid var(--border-bright);
    border-radius:4px;
    background:var(--bg);
    display:flex;align-items:center;justify-content:center;
    transition:all .12s;
    flex-shrink:0;
  }
  .calc-item.checked .calc-check{
    background:var(--accent);
    border-color:var(--accent);
  }
  .calc-check::after{
    content:"";
    width:8px;height:5px;
    border-left:2px solid #000;
    border-bottom:2px solid #000;
    transform:rotate(-45deg) translateY(-1px);
    opacity:0;
  }
  .calc-item.checked .calc-check::after{opacity:1}
  .calc-name{
    font-family:var(--mono);
    font-size:13.5px;
    font-weight:500;
    color:var(--text);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .calc-price{
    font-family:var(--mono);
    font-size:12.5px;
    color:var(--text-dim);
    white-space:nowrap;
    flex-shrink:0;
  }
  .calc-price .per{color:var(--text-faint);font-size:11px}
  .calc-once-badge{
    display:inline-block;
    font-family:var(--mono);
    font-size:9.5px;font-weight:700;
    color:var(--btc);
    background:rgba(247,147,26,0.12);
    border:1px solid rgba(247,147,26,0.3);
    padding:1px 5px;
    border-radius:3px;
    margin-left:6px;
    vertical-align:middle;
    letter-spacing:0.05em;
  }
  .calc-empty-list{
    text-align:center;
    padding:32px 16px;
    color:var(--text-faint);
    font-family:var(--mono);
    font-size:13px;
  }
  .calc-actions{
    display:flex;gap:8px;
    padding-top:14px;margin-top:14px;
    border-top:1px solid var(--border);
    flex-shrink:0;
  }
  .calc-btn{
    flex:1;
    font-family:var(--mono);
    font-size:12px;font-weight:500;
    padding:9px 14px;
    background:transparent;
    border:1px solid var(--border-bright);
    color:var(--text-dim);
    border-radius:5px;
    cursor:pointer;
    transition:all .15s;
  }
  .calc-btn:hover{color:var(--text);border-color:var(--text-dim)}
  .calc-disclaimer{
    margin-top:18px;
    font-family:var(--mono);
    font-size:11.5px;
    color:var(--text-faint);
    line-height:1.6;
    text-align:center;
  }

  /* COMMUNITY COUNTER */
  .counter-bar{
    position:relative;z-index:1;
    background:#000;
    border-bottom:1px solid var(--border);
    padding:14px 32px;
    text-align:center;
    font-family:var(--mono);
    font-size:13px;
    color:var(--text-dim);
  }
  .counter-bar strong{
    color:var(--accent);
    font-weight:700;
    font-variant-numeric:tabular-nums;
  }
  .counter-bar .live{
    display:inline-block;
    width:7px;height:7px;
    background:var(--accent);
    border-radius:50%;
    margin-right:6px;
    animation:pulse 2s infinite;
    vertical-align:middle;
  }

  /* SHARE BOX */
  .share-box{
    display:none;
    align-items:center;gap:10px;
    margin-top:18px;padding-top:18px;
    border-top:1px solid rgba(0,255,136,0.15);
    flex-wrap:wrap;
  }
  .share-box-label{
    font-family:var(--mono);font-size:11px;
    color:var(--text-faint);
    text-transform:uppercase;letter-spacing:0.12em;
    margin-right:4px;
  }
  .share-btn{
    font-family:var(--mono);font-size:12px;font-weight:600;
    background:var(--bg);
    color:var(--text);
    border:1px solid var(--border-bright);
    padding:7px 14px;
    border-radius:5px;
    cursor:pointer;
    transition:all .15s;
    display:inline-flex;align-items:center;gap:6px;
  }
  .share-btn:hover{border-color:var(--accent);color:var(--accent)}
  .share-btn.switched{
    background:var(--accent);color:#000;border-color:var(--accent);
  }

  /* GENERIC SECTION HEAD */
  .section-wrap{
    position:relative;z-index:1;
    max-width:1400px;margin:0 auto;
    padding:80px 32px;
  }
  .section-wrap-tinted{
    background:var(--bg-elev);
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
  }

  /* WHY PAIDX comparison */
  .compare-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:0;
    border:1px solid var(--border);
    border-radius:10px;
    overflow:hidden;
    background:var(--bg-elev);
  }
  .compare-head{
    padding:18px 24px;
    font-family:var(--mono);
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:0.15em;
    font-weight:700;
    border-bottom:1px solid var(--border);
    display:flex;align-items:center;gap:10px;
  }
  .compare-head.other{
    color:var(--text-faint);
    background:var(--bg);
  }
  .compare-head.paidx{
    color:var(--accent);
    background:rgba(0,255,136,0.04);
    border-left:1px solid var(--border);
  }
  .compare-cell{
    padding:18px 24px;
    border-bottom:1px solid var(--border);
    font-family:var(--sans);
    font-size:14.5px;
    line-height:1.5;
    display:flex;align-items:flex-start;gap:12px;
  }
  .compare-cell.other{
    color:var(--text-faint);
    background:var(--bg);
  }
  .compare-cell.paidx{
    color:var(--text);
    background:rgba(0,255,136,0.025);
    border-left:1px solid var(--border);
  }
  .compare-cell:nth-last-child(-n+2){border-bottom:none}
  .compare-icon{
    flex-shrink:0;
    width:20px;height:20px;
    display:inline-flex;align-items:center;justify-content:center;
    border-radius:50%;
    font-family:var(--mono);
    font-size:11px;font-weight:700;
    line-height:1;
    margin-top:1px;
  }
  .compare-icon.cross{
    color:var(--danger);
    background:rgba(255,77,77,0.1);
    border:1px solid rgba(255,77,77,0.25);
  }
  .compare-icon.check{
    color:var(--accent);
    background:rgba(0,255,136,0.12);
    border:1px solid rgba(0,255,136,0.3);
  }
  .compare-closing{
    margin-top:32px;
    text-align:center;
    font-family:var(--mono);
    font-size:clamp(15px,1.6vw,18px);
    color:var(--text);
    letter-spacing:-0.01em;
  }
  .compare-closing strong{color:var(--accent);font-weight:600}
  @media (max-width:720px){
    .compare-grid{grid-template-columns:1fr}
    .compare-head.paidx,.compare-cell.paidx{border-left:none}
    .compare-cell:nth-last-child(-n+2){border-bottom:1px solid var(--border)}
    .compare-cell:last-child{border-bottom:none}
  }

  /* FAQ accordion */
  .faq-list{
    border:1px solid var(--border);
    border-radius:10px;
    overflow:hidden;
    background:var(--bg-elev);
  }
  .faq-item{
    border-bottom:1px solid var(--border);
  }
  .faq-item:last-child{border-bottom:none}
  .faq-q{
    width:100%;
    background:transparent;
    border:none;
    color:var(--text);
    font-family:var(--mono);
    font-size:15px;
    font-weight:700;
    text-align:left;
    padding:20px 24px;
    cursor:pointer;
    display:flex;align-items:center;gap:14px;
    transition:background .15s, color .15s;
    letter-spacing:-0.01em;
    line-height:1.4;
  }
  .faq-q:hover{
    background:var(--bg-elev-2);
    color:var(--accent);
  }
  .faq-q[aria-expanded="true"]{
    color:var(--accent);
  }
  .faq-icon{
    flex-shrink:0;
    width:22px;height:22px;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--accent);
    font-family:var(--mono);
    font-size:16px;
    font-weight:700;
    line-height:1;
    transition:transform .25s ease;
  }
  .faq-q[aria-expanded="true"] .faq-icon{
    transform:rotate(45deg);
  }
  .faq-q-text{flex:1;min-width:0}
  .faq-a-wrap{
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
  }
  .faq-a{
    padding:0 24px 22px 60px;
    font-family:var(--sans);
    font-size:14.5px;
    line-height:1.65;
    color:var(--text-dim);
  }
  @media (max-width:560px){
    .faq-q{padding:16px 18px;font-size:14px;gap:10px}
    .faq-a{padding:0 18px 18px 44px;font-size:14px}
  }

  /* FREE STACKS */
  .stacks-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
    gap:16px;
  }
  .stack-card{
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:10px;
    padding:24px;
    transition:all .2s;
    cursor:default;
  }
  .stack-card:hover{
    border-color:var(--accent);
    transform:translateY(-2px);
  }
  .stack-icon{
    font-size:32px;
    margin-bottom:14px;
    line-height:1;
  }
  .stack-name{
    font-family:var(--mono);
    font-weight:700;
    font-size:18px;
    color:var(--text);
    margin-bottom:6px;
    letter-spacing:-0.01em;
  }
  .stack-name .price{
    color:var(--accent);
    font-size:14px;
    margin-left:6px;
  }
  .stack-desc{
    font-size:13px;
    color:var(--text-dim);
    line-height:1.55;
    margin-bottom:16px;
  }
  .stack-list{
    list-style:none;
    display:flex;flex-direction:column;gap:8px;
    margin-bottom:18px;
  }
  .stack-list li{
    font-family:var(--mono);
    font-size:12.5px;
    color:var(--text);
    display:flex;justify-content:space-between;gap:8px;
    padding:7px 10px;
    background:var(--bg);
    border-radius:4px;
    border:1px solid var(--border);
  }
  .stack-list li .replaces{
    color:var(--text-faint);
    font-size:11px;
    text-decoration:line-through;
    text-decoration-color:var(--danger);
  }
  .stack-savings{
    font-family:var(--mono);
    font-size:13px;
    font-weight:600;
    color:var(--accent);
    padding-top:12px;
    border-top:1px dashed var(--border);
    text-align:center;
  }
  .stack-savings .num{font-size:18px;letter-spacing:-0.02em}

  /* MIGRATION GUIDES */
  .guides-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
    gap:12px;
  }
  .guide-card{
    background:var(--bg-elev);
    border:1px solid var(--border);
    border-radius:10px;
    padding:24px;
    transition:all .15s;
    display:flex;flex-direction:column;
    min-height:180px;
  }
  .guide-card:hover{background:var(--bg-elev-2);border-color:var(--border-bright)}
  .guide-head{
    font-family:var(--mono);
    font-size:14px;font-weight:600;
    margin-bottom:8px;
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  }
  .guide-from{
    color:var(--text-dim);
    text-decoration:line-through;
    text-decoration-color:var(--danger);
  }
  .guide-arrow{color:var(--text-faint)}
  .guide-to{color:var(--accent)}
  .guide-time{
    font-family:var(--mono);
    font-size:10.5px;
    color:var(--text-faint);
    text-transform:uppercase;letter-spacing:0.12em;
    margin-bottom:12px;
  }
  .guide-summary{
    font-size:13px;
    color:var(--text-dim);
    line-height:1.55;
    flex:1;
    margin-bottom:14px;
  }
  .guide-steps{
    list-style:none;
    counter-reset:step;
    display:flex;flex-direction:column;gap:6px;
    font-family:var(--mono);font-size:12px;
    color:var(--text-dim);
  }
  .guide-steps li{
    counter-increment:step;
    padding-left:24px;
    position:relative;
    line-height:1.5;
  }
  .guide-steps li::before{
    content:counter(step);
    position:absolute;left:0;top:0;
    font-weight:700;color:var(--accent);
    font-size:11px;
    width:18px;height:18px;
    border:1px solid var(--accent);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
  }

  /* CARD METADATA (alternatives) */
  .card-badges{
    display:inline-flex;
    flex-wrap:wrap;
    gap:5px;
    align-items:center;
  }
  .badge-pick{
    font-family:var(--mono);
    font-size:9.5px;font-weight:700;
    padding:3px 7px;border-radius:3px;
    letter-spacing:0.04em;
    display:inline-flex;align-items:center;gap:4px;
  }
  .badge-pick.editor{
    background:var(--accent);color:#000;
  }
  .badge-pick.privacy-high{
    background:rgba(99,179,237,0.15);color:#63b3ed;
    border:1px solid rgba(99,179,237,0.3);
  }
  .badge-pick.self-host{
    background:rgba(247,147,26,0.12);color:var(--btc);
    border:1px solid rgba(247,147,26,0.3);
  }
  .badge-pick.foss{
    background:rgba(168,85,247,0.12);color:#a855f7;
    border:1px solid rgba(168,85,247,0.3);
  }
  .badge-pick.free-trial{
    background:rgba(234,179,8,0.12);color:#eab308;
    border:1px solid rgba(234,179,8,0.3);
  }

  /* NEWSLETTER */
  .newsletter{
    position:relative;z-index:1;
    padding:80px 32px;
    border-top:1px solid var(--border);
    background:linear-gradient(180deg,var(--bg),var(--bg-elev));
  }
  .newsletter-inner{
    max-width:680px;margin:0 auto;
    text-align:center;
  }
  .newsletter h2{
    font-family:var(--mono);
    font-size:clamp(28px,3.5vw,42px);
    font-weight:700;
    letter-spacing:-0.03em;
    line-height:1.1;
    margin-bottom:14px;
  }
  .newsletter h2 .accent{color:var(--accent)}
  .newsletter p{
    color:var(--text-dim);
    font-size:15.5px;
    line-height:1.6;
    margin-bottom:28px;
  }
  .newsletter-form{
    display:flex;gap:8px;
    max-width:480px;margin:0 auto;
  }
  .newsletter-input{
    flex:1;
    background:var(--bg);
    border:1px solid var(--border-bright);
    color:var(--text);
    font-family:var(--mono);
    font-size:14px;
    padding:13px 18px;
    border-radius:6px;
    outline:none;
    transition:border-color .15s;
  }
  .newsletter-input:focus{border-color:var(--accent)}
  .newsletter-input::placeholder{color:var(--text-faint)}
  .newsletter-btn{
    font-family:var(--mono);
    font-size:13px;font-weight:700;
    background:var(--accent);
    color:#000;
    border:none;
    padding:13px 20px;
    border-radius:6px;
    cursor:pointer;
    transition:all .15s;
    white-space:nowrap;
  }
  .newsletter-btn:hover{background:#00cc6e}
  .newsletter-meta{
    font-family:var(--mono);
    font-size:11.5px;
    color:var(--text-faint);
    margin-top:14px;
  }

  /* HAMBURGER MENU */
  .hamburger{
    display:none;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
    padding:6px;
    z-index:60;
  }
  .hamburger span{
    display:block;
    width:22px;height:2px;
    background:var(--text);
    border-radius:1px;
    transition:all .25s;
  }
  .hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  .mobile-menu{
    display:none;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(10,10,10,0.97);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    z-index:55;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:32px;
  }
  .mobile-menu.open{display:flex}
  .mobile-menu a{
    font-family:var(--mono);
    font-size:20px;
    font-weight:600;
    color:var(--text-dim);
    transition:color .15s;
    letter-spacing:-0.01em;
  }
  .mobile-menu a:hover{color:var(--accent)}
  .mobile-menu-close{
    position:absolute;
    top:14px;right:14px;
    width:44px;height:44px;
    display:flex;align-items:center;justify-content:center;
    font-family:var(--mono);
    font-size:22px;font-weight:700;
    line-height:1;
    color:var(--text);
    background:rgba(255,255,255,0.04);
    border:1px solid var(--border-bright);
    border-radius:8px;
    cursor:pointer;
    padding:0;
    z-index:2;
    transition:color .15s, background .15s, border-color .15s, transform .15s;
    -webkit-tap-highlight-color:transparent;
  }
  .mobile-menu-close:hover,
  .mobile-menu-close:focus-visible{
    color:var(--accent);
    border-color:var(--accent);
    background:var(--accent-bg);
    outline:none;
  }
  .mobile-menu-close:active{transform:scale(0.94)}

  /* VS COMPARISON PAGES */
  .vspage-wrap{max-width:980px;margin:0 auto;padding:48px 24px 60px;position:relative;z-index:1}
  .vspage-eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent);letter-spacing:0.06em;margin-bottom:14px;text-transform:lowercase}
  .vspage h1{font-family:var(--sans);font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-0.02em;line-height:1.15;margin:0 0 18px;color:var(--text)}
  .vspage h1 .vs-sep{color:var(--text-faint);font-weight:500;margin:0 8px}
  .vspage h1 .vs-paid{color:var(--text)}
  .vspage h1 .vs-free{color:var(--accent)}
  .vspage-verdict{font-size:16px;line-height:1.6;color:var(--text-dim);background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px;padding:16px 20px;margin:0 0 36px}
  .vspage-verdict strong{color:var(--text)}
  .vspage h2{font-family:var(--sans);font-size:22px;font-weight:700;letter-spacing:-0.01em;color:var(--text);margin:40px 0 14px}
  .vspage h3{font-family:var(--sans);font-size:17px;font-weight:600;color:var(--text);margin:24px 0 10px}
  .vspage p{font-size:14.5px;line-height:1.65;color:var(--text-dim);margin:0 0 14px}
  .vstable{width:100%;border-collapse:collapse;font-size:13.5px;margin:0 0 8px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;overflow:hidden}
  .vstable th,.vstable td{padding:12px 16px;text-align:left;vertical-align:top;border-bottom:1px solid var(--border)}
  .vstable thead th{background:var(--bg-elev-2);font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--text);letter-spacing:0.04em;text-transform:uppercase}
  .vstable tbody th{font-family:var(--mono);font-size:11.5px;font-weight:600;color:var(--text-faint);letter-spacing:0.03em;text-transform:uppercase;width:30%}
  .vstable tbody td{color:var(--text-dim)}
  .vstable tbody tr:last-child th,.vstable tbody tr:last-child td{border-bottom:none}
  .vstable .v-paid{color:var(--text)}
  .vstable .v-free{color:var(--accent)}
  .vstable .v-price-paid{font-family:var(--mono);font-weight:600}
  .vstable .v-price-free{font-family:var(--mono);font-weight:600;color:var(--accent)}
  .vsdual{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:0 0 8px}
  .vsdual-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:18px 20px}
  .vsdual-card h3{margin:0 0 10px;font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--text)}
  .vsdual-card.paid h3{color:var(--text)}
  .vsdual-card.free h3{color:var(--accent)}
  .vsdual-card ul{margin:0;padding:0 0 0 18px;list-style:none}
  .vsdual-card li{font-size:14px;line-height:1.55;color:var(--text-dim);margin:0 0 8px;position:relative;padding-left:14px}
  .vsdual-card li::before{content:"›";position:absolute;left:0;color:var(--text-faint);font-family:var(--mono);font-weight:700}
  .vsdual-card.free li::before{color:var(--accent)}
  .vs-tradeoffs{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:16px 20px;margin:0}
  .vs-tradeoffs ul{margin:0;padding:0 0 0 18px;list-style:none}
  .vs-tradeoffs li{font-size:14px;line-height:1.6;color:var(--text-dim);margin:0 0 10px;position:relative;padding-left:18px}
  .vs-tradeoffs li::before{content:"⚠";position:absolute;left:0;color:var(--btc,#f7931a);font-family:var(--mono);font-size:13px}
  .vs-tradeoffs li:last-child{margin-bottom:0}
  .vs-migration{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:16px 20px;font-size:14px;line-height:1.65;color:var(--text-dim)}
  .vs-migration .switch-score{margin-top:10px}
  .vs-faq{margin:0}
  .vs-faq details{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;margin:0 0 10px;padding:0}
  .vs-faq summary{cursor:pointer;list-style:none;padding:14px 18px;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--text);position:relative;padding-right:40px}
  .vs-faq summary::-webkit-details-marker{display:none}
  .vs-faq summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:18px;color:var(--text-faint);transition:transform .15s}
  .vs-faq details[open] summary::after{content:"−"}
  .vs-faq .vs-faq-a{padding:0 18px 16px;font-size:14px;line-height:1.65;color:var(--text-dim)}
  .vs-links{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 0}
  .vs-links a{display:inline-block;font-family:var(--mono);font-size:13px;color:var(--text-dim);padding:9px 14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;transition:all .15s}
  .vs-links a:hover{color:var(--accent);border-color:var(--accent)}
  .vs-related{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}
  .vs-related h2{margin:0 0 14px}
  .vs-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
  .vs-related-grid a{font-family:var(--mono);font-size:13px;color:var(--text-dim);padding:10px 14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;transition:all .15s;display:block}
  .vs-related-grid a:hover{color:var(--accent);border-color:var(--accent)}

  /* /vs/ index */
  .vsindex-wrap{max-width:980px;margin:0 auto;padding:48px 24px 60px;position:relative;z-index:1}
  .vsindex-wrap h1{font-family:var(--sans);font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-0.02em;margin:0 0 14px;color:var(--text)}
  .vsindex-wrap > p{font-size:15.5px;color:var(--text-dim);line-height:1.65;margin:0 0 36px;max-width:780px}
  .vsindex-cat{margin:0 0 36px}
  .vsindex-cat h2{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text-faint);letter-spacing:0.06em;text-transform:lowercase;margin:0 0 12px}
  .vsindex-cat h2::before{content:"// "}
  .vsindex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
  .vsindex-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:14px 18px;transition:border-color .15s, transform .15s;display:block}
  .vsindex-card:hover{border-color:var(--accent);transform:translateY(-1px)}
  .vsindex-card .vsindex-title{font-family:var(--sans);font-size:15px;font-weight:600;color:var(--text);margin:0 0 6px;letter-spacing:-0.005em}
  .vsindex-card .vsindex-title .vs-paid{color:var(--text)}
  .vsindex-card .vsindex-title .vs-sep{color:var(--text-faint);font-weight:500;margin:0 6px}
  .vsindex-card .vsindex-title .vs-free{color:var(--accent)}
  .vsindex-card .vsindex-blurb{font-size:13px;color:var(--text-dim);line-height:1.55;margin:0}

  /* Quick-comparison section on /alternatives/<slug>/ */
  .alt-quickvs{background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:14px 18px;margin:24px 0 36px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
  .alt-quickvs-label{font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--text-faint);letter-spacing:0.06em;text-transform:uppercase}
  .alt-quickvs-link{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--text);text-decoration:none}
  .alt-quickvs-link .vs-paid{color:var(--text)}
  .alt-quickvs-link .vs-sep{color:var(--text-faint);font-weight:500;margin:0 6px}
  .alt-quickvs-link .vs-free{color:var(--accent)}
  .alt-quickvs-link:hover .vs-paid,.alt-quickvs-link:hover .vs-sep{color:var(--accent)}
  .alt-quickvs-arrow{color:var(--accent);font-family:var(--mono);margin-left:auto}

  /* RESPONSIVE */
  @media (max-width:880px){
    .nav-inner{padding:14px 20px}
    .nav-links{display:none}
    .hamburger{display:flex}
    .hero{padding:64px 20px 48px}
    .stats{grid-template-columns:repeat(2,1fr)}
    .stat:nth-child(2),.stat:nth-child(4){border-right:none}
    .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--border)}
    .directory{padding:48px 20px}
    .grid{grid-template-columns:1fr}
    .about{padding:64px 20px}
    .about-inner{grid-template-columns:1fr;gap:32px}
    .donate,.contact{padding:64px 20px}
    .donate-inner{padding:32px 24px}
    .crypto-row{padding:14px 14px;gap:12px}
    .crypto-meta{min-width:0;width:100%}
    .crypto-addr-wrap{flex-basis:100%;min-width:0}
    .copy-btn{flex:1}
    .calc{padding:48px 20px}
    .calc-inner{grid-template-columns:1fr;gap:32px}
    .calc-right{max-height:520px}
    .section-wrap{padding:56px 20px}
    .stacks-grid{grid-template-columns:1fr}
    .guides-grid{grid-template-columns:1fr}
    .newsletter{padding:56px 20px}
    .newsletter-form{flex-direction:column}
    .newsletter-input,.newsletter-btn{width:100%}
    .counter-bar{padding:12px 16px;font-size:11.5px;line-height:1.45}
    .share-box{gap:6px}
    .share-btn{font-size:11.5px;padding:6px 11px}
    footer{padding:48px 20px 32px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:32px}
    .footer-brand{grid-column:1/-1;max-width:none}
    .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left}
    /* VS pages — single column */
    .vspage-wrap,.vsindex-wrap{padding:36px 16px 48px}
    .vsdual{grid-template-columns:1fr}
    .vstable tbody th{width:42%}
    .alt-quickvs-arrow{display:none}
  }

  /* Accessibility: respect prefers-reduced-motion */
  @media (prefers-reduced-motion:reduce){
    *,*::before,*::after{
      animation-duration:0.01ms !important;
      animation-iteration-count:1 !important;
      transition-duration:0.01ms !important;
      scroll-behavior:auto !important;
    }
    .marquee-track{animation:none !important}
    .hero-tag::before,.live{animation:none !important}
  }
