/*
Theme Name: CryptoCardsPerks
Theme URI: https://cryptocardsperks.com/
Author: CryptoCardsPerks
Author URI: https://cryptocardsperks.com/
Description: A fast, SEO-rich crypto card directory theme. Hardcoded list of 76+ crypto cards with filterable home page, rich review pages (referral code copy, cashback tiers, FAQ schema), and a side-by-side compare tool. No plugin required.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cryptocardsperks
*/


  :root{
    --ink:#ffffff;
    --ink-2:#ffffff;
    --panel:#ffffff;
    --panel-2:#f4f4f2;
    --line:#e4e4e0;
    --line-soft:#eeeeea;
    --text:#1a1d24;
    --text-dim:#5b6373;
    --text-faint:#8a93a4;
    --gold:#c8870b;
    --gold-soft:#e8a82a;
    --mint:#159a6a;
    --green:#16a34a;
    --green-soft:#22c55e;
    --violet:#6a58d6;
    --rose:#d6453f;
    --display:'Space Grotesk',system-ui,sans-serif;
    --mono:'JetBrains Mono',ui-monospace,monospace;
    --body:'Inter',system-ui,sans-serif;
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--ink);
    color:var(--text);
    font-family:var(--body);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--gold);color:#fff}

  /* ---------- top bar ---------- */
  header.site{
    position:sticky;top:0;z-index:50;
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
  }
  .bar{
    max-width:var(--maxw);margin:0 auto;
    display:flex;align-items:center;gap:1.2rem;
    padding:.85rem 1.25rem;
  }
  .brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.12rem;letter-spacing:-.02em}
  .brand .glyph{
    width:34px;height:34px;border-radius:9px;flex:none;
    background:#fff;object-fit:contain;
    box-shadow:0 0 0 1px var(--line),0 4px 12px -4px rgba(40,60,160,.35);
  }
  .brand b{color:#2b50e6}
  .bar nav{margin-left:auto;display:flex;gap:1.4rem;font-size:.86rem;color:var(--text-dim)}
  .bar nav a{padding:.2rem 0}
  .bar nav a:hover{color:var(--text)}

  /* hamburger toggle — hidden on desktop */
  .nav-toggle{
    display:none;margin-left:auto;width:42px;height:42px;flex:none;
    background:var(--panel);border:1px solid var(--line);border-radius:10px;
    cursor:pointer;align-items:center;justify-content:center;padding:0;
  }
  .nav-toggle:hover{border-color:var(--text-faint)}
  .nav-toggle-bars{position:relative;width:18px;height:14px;display:block}
  .nav-toggle-bars span{
    position:absolute;left:0;width:100%;height:2px;border-radius:2px;background:var(--text);
    transition:transform .22s ease,opacity .18s ease,top .22s ease;
  }
  .nav-toggle-bars span:nth-child(1){top:0}
  .nav-toggle-bars span:nth-child(2){top:6px}
  .nav-toggle-bars span:nth-child(3){top:12px}
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(1){top:6px;transform:rotate(45deg)}
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(3){top:6px;transform:rotate(-45deg)}

  @media(max-width:680px){
    .nav-toggle{display:flex}
    .bar{position:relative;flex-wrap:wrap}
    .bar nav{
      position:absolute;top:calc(100% + 1px);left:0;right:0;
      flex-direction:column;gap:0;margin:0;
      background:var(--panel);border-bottom:1px solid var(--line);
      box-shadow:0 18px 30px -18px rgba(30,40,90,.35);
      max-height:0;overflow:hidden;opacity:0;visibility:hidden;
      transition:max-height .28s ease,opacity .2s ease,visibility .28s;
      z-index:60;
    }
    .bar nav.open{max-height:70vh;opacity:1;visibility:visible}
    .bar nav a{
      padding:.95rem 1.25rem;font-size:1rem;border-top:1px solid var(--line-soft);
    }
    .bar nav a:first-child{border-top:none}
    .bar nav a:active{background:var(--panel-2)}
  }

  /* ---------- hero ---------- */
  .hero{
    position:relative;
    max-width:var(--maxw);margin:0 auto;
    padding:3.4rem 1.25rem 1.5rem;
  }
  .hero .eyebrow{
    font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
    color:var(--gold);display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;
  }
  .hero .eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}
  .hero h1{
    font-family:var(--display);font-weight:700;
    font-size:clamp(2.1rem,6vw,3.7rem);line-height:1.02;letter-spacing:-.03em;
    max-width:16ch;
  }
  .hero h1 em{font-style:normal;color:var(--green);position:relative}
  .hero p.lede{
    margin-top:1.1rem;max-width:54ch;color:var(--text-dim);font-size:1.04rem;
  }
  .stat-strip{
    display:flex;flex-wrap:wrap;gap:2.2rem;margin-top:2rem;
    padding-top:1.6rem;border-top:1px solid var(--line-soft);
  }
  .stat .num{font-family:var(--display);font-weight:700;font-size:1.6rem;letter-spacing:-.02em}
  .stat .num.g{color:var(--gold)}
  .stat .lab{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin-top:.15rem}

  /* ---------- featured card ---------- */
  /* Editor's Pick — premium gradient frame + glow */
  .featured-wrap{
    margin-top:2rem;border-radius:24px;padding:1.6px;
    background:linear-gradient(135deg,var(--green) 0%,#7bdcab 30%,var(--gold,#d8a84b) 75%,var(--green) 100%);
    box-shadow:0 26px 60px -30px rgba(22,163,74,.5);
    position:relative;
  }
  .featured-wrap::before{
    content:"";position:absolute;inset:-1px;border-radius:24px;z-index:-1;
    background:inherit;filter:blur(16px);opacity:.35;
  }
  .featured{
    display:grid;grid-template-columns:340px 1fr;gap:0;
    background:var(--panel);border-radius:23px;overflow:hidden;
    transition:transform .2s ease,box-shadow .2s ease;
  }
  .featured:hover{transform:translateY(-4px)}
  .featured-art{
    position:relative;background:var(--panel-2);min-height:240px;
    display:flex;align-items:center;justify-content:center;overflow:hidden;
  }
  /* image present -> show only the image, no colored panel */
  .featured-art:not(.gradient){background:transparent !important;}
  .featured-art:not(.gradient)::after{display:none !important;}
  .featured-img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:1.7rem;
    transition:transform .35s cubic-bezier(.2,.8,.2,1);
    filter:drop-shadow(0 18px 30px rgba(0,0,0,.16));
  }
  .featured:hover .featured-img{transform:scale(1.06) translateY(-2px)}
  .featured-art.gradient::after{
    content:"";position:absolute;inset:0;
    background:radial-gradient(120% 80% at 80% 10%,rgba(255,255,255,.2),transparent 60%),linear-gradient(180deg,transparent 40%,rgba(0,0,0,.32));
    mix-blend-mode:overlay;
  }
  .featured-emboss{
    position:absolute;top:1.1rem;left:1.1rem;width:42px;height:31px;border-radius:6px;z-index:2;
    background:linear-gradient(135deg,#f7e3a1,#c89b3a);
    box-shadow:inset 0 1px 1px rgba(255,255,255,.5),inset 0 -2px 3px rgba(0,0,0,.25);
  }
  .featured-flag{
    position:absolute;top:1.1rem;right:1.1rem;z-index:3;display:inline-flex;align-items:center;gap:.34rem;
    font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
    background:linear-gradient(135deg,#16a34a,#0f7a37);color:#fff;padding:.34rem .66rem;border-radius:99px;
    box-shadow:0 6px 16px -5px rgba(22,163,74,.6);overflow:hidden;
  }
  .featured-flag .flag-star{color:#ffe9a8}
  .featured-flag::after{
    content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
    background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
    transform:skewX(-18deg);animation:ccp-shine 3.6s ease-in-out infinite;
  }
  @keyframes ccp-shine{0%,60%{left:-60%}80%,100%{left:130%}}
  .featured-rank{
    position:absolute;left:1.1rem;bottom:1.1rem;z-index:3;
    font-family:var(--display);font-weight:700;font-size:.92rem;letter-spacing:.02em;
    background:rgba(17,20,28,.74);color:#fff;backdrop-filter:blur(6px);
    padding:.3rem .62rem;border-radius:9px;border:1px solid rgba(255,255,255,.16);
  }
  .featured-art:not(.gradient) .featured-rank{background:rgba(17,20,28,.82)}
  .featured-body{padding:1.7rem 2rem;display:flex;flex-direction:column;gap:.7rem}
  .featured-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green);font-weight:600}
  .fe-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(22,163,74,.5);animation:ccp-pulse 2s infinite}
  @keyframes ccp-pulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.5)}70%{box-shadow:0 0 0 7px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}
  .featured-name{font-family:var(--display);font-weight:700;font-size:2.15rem;letter-spacing:-.025em;line-height:1.04}
  .featured-why{color:var(--text-dim);font-size:.95rem;line-height:1.45;margin-top:-.15rem}
  .featured-scoreline{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.2rem}
  .featured-score{font-family:var(--mono);font-weight:600;font-size:1.45rem;display:flex;align-items:baseline;gap:.15rem}
  .featured-score .fs-v{color:var(--green)}
  .featured-score .fs-max{color:var(--text-faint);font-size:.85rem}
  .featured-bar{flex:1;min-width:120px;height:7px;border-radius:99px;background:var(--line);overflow:hidden}
  .featured-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-soft));border-radius:99px}
  .featured-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.1rem}
  .featured-tags .tag{
    font-family:var(--mono);font-size:.7rem;padding:.28rem .56rem;border-radius:6px;
    border:1px solid var(--line);color:var(--text-dim);background:var(--panel-2);
  }
  .featured-tags .tag.region{color:var(--mint);border-color:rgba(21,154,106,.3)}
  .featured-tags .tag.cash{color:var(--green);border-color:rgba(22,163,74,.3)}
  .featured-tags .tag.nokyc{color:var(--violet);border-color:rgba(106,88,214,.3)}
  .featured-cta{
    margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:.45rem;
    font-family:var(--display);font-weight:600;font-size:.98rem;color:#fff;
    background:linear-gradient(135deg,#16a34a,#0f7a37);padding:.78rem 1.35rem;border-radius:12px;
    box-shadow:0 10px 22px -10px rgba(22,163,74,.6);
    transition:gap .16s ease,transform .16s,box-shadow .16s;
  }
  .featured:hover .featured-cta{gap:.8rem;transform:translateY(-1px);box-shadow:0 14px 26px -10px rgba(22,163,74,.7)}
  @media(max-width:640px){
    .featured-wrap{border-radius:20px}
    .featured{grid-template-columns:1fr;border-radius:19px}
    .featured-art{min-height:200px}
    .featured-name{font-size:1.6rem}
    .featured-body{padding:1.3rem 1.3rem 1.5rem}
    .featured-why{font-size:.9rem}
  }
  @media(prefers-reduced-motion:reduce){
    .featured-flag::after{animation:none;display:none}
    .fe-dot{animation:none}
  }

  /* ---------- controls ---------- */
  .controls{
    max-width:var(--maxw);margin:2.2rem auto 0;padding:0 1.25rem;
  }
  .search-row{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}
  .search{
    flex:1;min-width:230px;position:relative;
  }
  .search input{
    width:100%;background:var(--panel);border:1px solid var(--line);
    color:var(--text);padding:.8rem 1rem .8rem 2.6rem;border-radius:11px;
    font-family:var(--body);font-size:.95rem;outline:none;transition:border-color .15s,box-shadow .15s;
  }
  .search input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,135,11,.18)}
  .search svg{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--text-faint)}
  .sort{
    background:var(--panel);border:1px solid var(--line);color:var(--text);
    padding:.8rem 2.2rem .8rem .95rem;border-radius:11px;font-family:var(--mono);
    font-size:.8rem;cursor:pointer;outline:none;
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235b6373' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right .85rem center;
  }
  .sort:focus{border-color:var(--gold)}

  .chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
  .chip{
    font-family:var(--mono);font-size:.74rem;letter-spacing:.02em;
    background:var(--panel);border:1px solid var(--line);color:var(--text-dim);
    padding:.42rem .8rem;border-radius:999px;cursor:pointer;
    transition:all .14s;user-select:none;white-space:nowrap;
  }
  .chip:hover{border-color:var(--text-faint);color:var(--text)}
  .chip[aria-pressed="true"]{
    background:var(--gold);border-color:var(--gold);color:#fff;font-weight:600;
  }
  .chip.region[aria-pressed="true"]{background:var(--mint);border-color:var(--mint);color:#fff}
  .chip.feat[aria-pressed="true"]{background:var(--violet);border-color:var(--violet);color:#fff}

  .meta-row{
    display:flex;align-items:center;justify-content:space-between;gap:1rem;
    margin:1.4rem 0 .2rem;
  }
  .count{font-family:var(--mono);font-size:.78rem;color:var(--text-faint);letter-spacing:.04em}
  .count b{color:var(--gold)}
  .clear{font-family:var(--mono);font-size:.74rem;color:var(--text-dim);cursor:pointer;border:none;background:none;padding:.3rem .2rem}
  .clear:hover{color:var(--rose)}

  /* ---------- grid ---------- */
  .grid{
    max-width:var(--maxw);margin:1.2rem auto 0;padding:0 1.25rem 4rem;
    display:grid;gap:1rem;
    grid-template-columns:repeat(auto-fill,minmax(248px,1fr));
  }
  .card{
    background:var(--panel);border:1px solid var(--line-soft);border-radius:16px;
    overflow:hidden;display:flex;flex-direction:column;
    transition:transform .16s ease,border-color .16s,box-shadow .16s;
    position:relative;
  }
  .card:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:0 16px 36px -20px rgba(40,35,20,.28)}
  .card .art{
    height:150px;position:relative;display:flex;align-items:flex-end;
    padding:.85rem;overflow:hidden;background:var(--panel-2);
  }
  /* When a real card image is present, show ONLY the image — no panel, no color. */
  .card .art.has-img{align-items:flex-start;justify-content:flex-end;background:transparent !important;padding:0;}
  .card .art.has-img::after{display:none !important;}
  .card .art .cardimg{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:contain;padding:.9rem;
    transition:transform .25s ease;
  }
  .card:hover .art .cardimg{transform:scale(1.045)}
  .card .art.gradient::after{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(120% 80% at 80% 10%,rgba(255,255,255,.18),transparent 60%),
      linear-gradient(180deg,transparent 40%,rgba(0,0,0,.35));
    mix-blend-mode:overlay;
  }
  .chip-emboss{
    position:absolute;top:.85rem;left:.85rem;width:34px;height:25px;border-radius:5px;
    background:linear-gradient(135deg,#f7e3a1,#c89b3a);
    box-shadow:inset 0 1px 1px rgba(255,255,255,.5),inset 0 -2px 3px rgba(0,0,0,.25);
    opacity:.92;
  }
  .chip-emboss::before{content:"";position:absolute;inset:6px 5px;border:1px solid rgba(120,90,20,.45);border-radius:2px}
  .rank-badge{
    position:relative;z-index:2;font-family:var(--mono);font-size:.66rem;
    color:rgba(255,255,255,.92);letter-spacing:.1em;text-transform:uppercase;
    background:rgba(0,0,0,.42);backdrop-filter:blur(4px);
    padding:.22rem .5rem;border-radius:6px;border:1px solid rgba(255,255,255,.18);
  }
  /* On a clean image panel, use a light badge so it reads against the white background. */
  .card .art.has-img .rank-badge{
    color:var(--text-dim);background:rgba(255,255,255,.82);
    border-color:var(--line);box-shadow:0 1px 3px rgba(0,0,0,.08);
  }
  .card .body{padding:.95rem 1rem 1.05rem;display:flex;flex-direction:column;gap:.65rem;flex:1}
  .card .nameline{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}
  .card h3{font-family:var(--display);font-weight:600;font-size:1.04rem;letter-spacing:-.01em;line-height:1.2}
  .score{
    font-family:var(--mono);font-weight:600;font-size:.92rem;flex:none;
    display:flex;align-items:baseline;gap:.12rem;
  }
  .score .v{color:var(--green)}
  .score .max{color:var(--text-faint);font-size:.66rem}
  .score-bar{height:4px;border-radius:99px;background:var(--line);overflow:hidden}
  .score-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-soft));border-radius:99px}
  .tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.1rem}
  .tag{
    font-family:var(--mono);font-size:.64rem;letter-spacing:.02em;
    padding:.2rem .46rem;border-radius:5px;border:1px solid var(--line);
    color:var(--text-dim);background:var(--panel-2);
  }
  .tag.region{color:var(--mint);border-color:rgba(61,220,151,.28)}
  .tag.cash{color:var(--gold);border-color:rgba(240,180,41,.28)}
  .tag.nokyc{color:var(--violet);border-color:rgba(139,124,255,.3)}
  .card .review{
    margin-top:auto;display:flex;align-items:center;justify-content:space-between;
    padding-top:.7rem;border-top:1px solid var(--line-soft);
    font-family:var(--mono);font-size:.76rem;color:var(--text-dim);
  }
  .card .review .go{color:var(--gold);display:flex;align-items:center;gap:.3rem;transition:gap .14s}
  .card:hover .review .go{gap:.55rem}

  .empty{
    grid-column:1/-1;text-align:center;padding:3.5rem 1rem;color:var(--text-faint);
    font-family:var(--mono);font-size:.85rem;
  }
  .empty b{color:var(--text-dim)}

  /* ---------- benchmarks ---------- */
  .bench{max-width:var(--maxw);margin:0 auto;padding:1rem 1.25rem 4rem}
  .bench h2{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;margin-bottom:.4rem}
  .bench .sub{color:var(--text-faint);font-family:var(--mono);font-size:.74rem;margin-bottom:1.6rem}
  .bench-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
  .bcard{background:var(--panel);border:1px solid var(--line-soft);border-radius:14px;padding:1.3rem}
  .bcard .big{font-family:var(--display);font-weight:700;font-size:2.3rem;color:var(--gold);letter-spacing:-.03em}
  .bcard p{color:var(--text-dim);font-size:.9rem;margin-top:.4rem}

  /* ---------- footer ---------- */
  footer.site{border-top:1px solid var(--line-soft);background:var(--ink-2)}
  .foot{max-width:var(--maxw);margin:0 auto;padding:2.4rem 1.25rem;display:grid;gap:1.6rem;grid-template-columns:1.4fr 1fr 1fr}
  .foot h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.8rem}
  .foot a{display:block;color:var(--text-dim);font-size:.88rem;padding:.2rem 0}
  .foot a:hover{color:var(--gold)}
  .foot .blurb{color:var(--text-faint);font-size:.84rem;max-width:38ch;margin-top:.7rem}
  .foot-bottom{border-top:1px solid var(--line-soft);text-align:center;padding:1.1rem;font-family:var(--mono);font-size:.7rem;color:var(--text-faint)}
  @media(max-width:680px){.foot{grid-template-columns:1fr 1fr}.foot .about{grid-column:1/-1}}

  /* ---------- phones ---------- */
  @media(max-width:560px){
    .bar{padding:.7rem 1rem}
    .hero{padding:2.2rem 1rem 1.2rem}
    .hero h1{font-size:clamp(1.8rem,8vw,2.4rem)}
    .hero p.lede{font-size:.98rem}
    .stat-strip{gap:1.1rem 1.6rem;margin-top:1.5rem;padding-top:1.3rem}
    .stat .num{font-size:1.35rem}
    .controls{padding:0 1rem}
    .search-row{flex-direction:column;align-items:stretch}
    .search{min-width:0}
    .sort{width:100%}
    .grid{padding:0 1rem 3rem;grid-template-columns:1fr;gap:.9rem}
    .bench{padding:1rem 1rem 3rem}
    .bench-grid{grid-template-columns:1fr}
    .chips{gap:.45rem}
    .chip{padding:.5rem .85rem}              /* bigger tap targets */
    .clear{padding:.5rem .2rem}
    /* featured card stacks */
    .featured{grid-template-columns:1fr}
    .featured-art{min-height:170px}
    .featured-name{font-size:1.45rem}
    .featured-body{padding:1.2rem 1.15rem 1.4rem}
  }
  @media(max-width:380px){
    .hero h1{font-size:1.7rem}
    .stat-strip{gap:1rem 1.3rem}
  }

  .skip{position:absolute;left:-999px}
  .skip:focus{left:1rem;top:.6rem;z-index:99;background:var(--gold);color:#1a1305;padding:.5rem .9rem;border-radius:8px}
  :focus-visible{outline:2px solid var(--gold);outline-offset:2px}
  @media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
