/* XXX Reviews — dark, modern, bunny-accented */
:root{
  --bg:#0e0e12; --panel:#17171f; --panel2:#1f1f2a;
  --text:#eceaf0; --muted:#9a98a8; --line:#2a2a38;
  --accent:#ff3f7f; --accent2:#ffb347; --good:#4ade80; --bad:#f87171;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;line-height:1.55}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 1.25rem}

/* header */
.site-header{position:sticky;top:0;background:rgba(14,14,18,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);z-index:30}
.site-header .wrap{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1.25rem}
.logo{font-weight:800;font-size:1.2rem;color:var(--text)}
.logo span{color:var(--accent)}
.logo small{color:var(--muted);font-weight:500;margin-left:.35rem}
.site-header nav a{color:var(--muted);margin-left:1.1rem;font-weight:500}
.site-header nav a:hover{color:var(--text);text-decoration:none}

/* hero */
.hero{background:
  radial-gradient(800px 300px at 80% 0%, rgba(255,63,127,.18), transparent 60%),
  radial-gradient(700px 280px at 15% 20%, rgba(255,179,71,.12), transparent 55%),
  var(--bg);
  padding:3.5rem 0 2rem;border-bottom:1px solid var(--line)}
.hero h1{font-size:2.4rem;margin:0 0 .5rem;letter-spacing:-.02em}
.hero .lede{color:var(--muted);font-size:1.1rem;max-width:60ch}

/* categories */
.categories{margin:2rem 0 1rem}
.categories h2{font-size:1.1rem;margin:0 0 .75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.pills{display:flex;flex-wrap:wrap;gap:.5rem}
.pill{background:var(--panel);border:1px solid var(--line);padding:.4rem .9rem;border-radius:999px;
  font-size:.9rem;color:var(--text)}
.pill:hover{border-color:var(--accent);text-decoration:none}
.pill.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin:1.5rem 0 3rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.card:hover{transform:translateY(-2px);border-color:var(--accent)}
.card .thumb{aspect-ratio:16/9;background:var(--panel2);overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .body{padding:1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.card .rank{font-size:.75rem;color:var(--accent2);font-weight:700;letter-spacing:.1em}
.card h3{margin:0;font-size:1.15rem}
.card h3 a{color:var(--text)}
.card h3 a:hover{color:var(--accent);text-decoration:none}
.tagline{color:var(--muted);font-size:.92rem}
.rating{display:flex;align-items:baseline;gap:.2rem;margin:.2rem 0}
.rating .score{font-size:1.5rem;font-weight:800;color:var(--accent2)}
.rating .outof{color:var(--muted);font-size:.9rem}
.rating.big .score{font-size:2.5rem}
.cats{display:flex;flex-wrap:wrap;gap:.35rem}
.tag{background:var(--panel2);border:1px solid var(--line);border-radius:6px;padding:.15rem .5rem;
  font-size:.75rem;color:var(--muted)}
.price{font-size:.95rem;color:var(--text);font-weight:600}
.price.big{font-size:1.25rem;margin:.5rem 0 1rem}
.actions{display:flex;gap:.5rem;margin-top:auto;padding-top:.6rem}

/* buttons */
.btn{display:inline-block;padding:.55rem 1rem;border-radius:9px;font-weight:600;font-size:.9rem;
  border:1px solid transparent;cursor:pointer;text-align:center}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:#ff2a6f;text-decoration:none}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn.ghost:hover{border-color:var(--accent);text-decoration:none}
.btn.big{padding:.85rem 1.5rem;font-size:1rem}
.btn.small{padding:.3rem .6rem;font-size:.8rem}

/* review page */
.review{padding:2rem 0 3rem}
.crumbs{color:var(--muted);font-size:.9rem;margin-bottom:1rem}
.crumbs a{color:var(--muted)}
.review-head{display:grid;grid-template-columns:minmax(260px,420px) 1fr;gap:1.5rem;align-items:start;
  background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}
.review-head h1{margin:0 0 .25rem;font-size:2rem}
.thumb.large{aspect-ratio:16/9;background:var(--panel2);border-radius:10px;overflow:hidden}
.thumb.large img{width:100%;height:100%;object-fit:cover}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}
.two-col > div{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem 1.25rem}
.pros h3{color:var(--good);margin-top:0}
.cons h3{color:var(--bad);margin-top:0}
.two-col ul{margin:.25rem 0;padding-left:1.2rem}
.two-col li{margin:.15rem 0}
.body-text{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.5rem;margin:1rem 0}
.body-text h2{margin-top:0}
.body-text blockquote{border-left:3px solid var(--accent);padding:.25rem 1rem;color:var(--muted);margin:1rem 0}
.cta-row{margin-top:1rem}
.related{margin-top:2rem}
.related h2{margin-bottom:1rem}

/* admin */
.admin{background:#0b0b10}
.flash{background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.35);color:var(--good);
  padding:.75rem 1rem;border-radius:10px;margin:1rem 0}
.aff-form{margin-top:1rem}
.aff-table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.aff-table th,.aff-table td{padding:.6rem .75rem;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.aff-table th{background:var(--panel2);color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.aff-table input{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--text);
  padding:.45rem .6rem;border-radius:6px;font-family:inherit}
.aff-table input:focus{outline:none;border-color:var(--accent)}
.row-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}
code{background:var(--panel2);padding:.1rem .35rem;border-radius:4px;font-size:.88em}

/* footer */
.site-footer{border-top:1px solid var(--line);background:var(--panel);margin-top:3rem;padding:1.5rem 0;color:var(--muted);font-size:.88rem}
.site-footer p{margin:.2rem 0}

/* mobile */
@media (max-width:760px){
  .hero h1{font-size:1.8rem}
  .review-head{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
}
