/*
Theme Name: Rankly
Theme URI: https://example.com/rankly
Author: Rankly
Author URI: https://example.com
Description: A lightweight, fast directory & review theme. The homepage stacks multiple ranked lists (one per category); every site row has a magnifying-glass button that opens its full review. Built with no framework and no jQuery dependency for speed.
Version: 1.0.5
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rankly
Tags: directory, reviews, listings, blog, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar
*/

/* ============================================================
   Rankly — Design tokens
   Palette is exposed as CSS custom properties so the Customizer
   accent color can override --accent at runtime.
   ============================================================ */
:root{
  --ink:#1b1d22;
  --ink-soft:#444b57;
  --muted:#797f8b;
  --line:#ededf1;
  --line-strong:#dcdde3;
  --bg:#f5f6f8;
  --surface:#ffffff;
  --surface-2:#fafafc;
  --accent:#5b5fc7;          /* refined indigo — overridden by Customizer */
  --accent-ink:#ffffff;
  --accent-soft:#eef0fb;
  --gold:#dba24a;            /* rating stars (softened) */
  --good:#15935f;            /* visit / positive */
  --bad:#d6584f;
  --shadow-sm:0 1px 2px rgba(20,22,30,.04), 0 1px 1px rgba(20,22,30,.03);
  --shadow-md:0 10px 30px -14px rgba(20,22,30,.16), 0 2px 8px -4px rgba(20,22,30,.06);
  --radius:14px;
  --radius-sm:11px;
  --radius-pill:999px;
  --mono:ui-monospace,"SF Mono",SFMono-Regular,"Roboto Mono","DejaVu Sans Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Inter","Helvetica Neue","PingFang SC","Hiragino Sans GB","Microsoft YaHei",Arial,sans-serif;
  --maxw:1280px;
}

/* ----------  Reset / base  ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;margin:0 0 .4em;color:var(--ink);font-weight:780;letter-spacing:-.02em}
h1{font-size:clamp(1.8rem,1.2rem + 2.4vw,2.65rem)}
h2{font-size:clamp(1.35rem,1.1rem + 1vw,1.7rem)}
p{margin:0 0 1em}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}

/* ----------  Header  ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;gap:22px;min-height:74px;padding-block:10px}
.brand-block{flex:none;display:flex;align-items:center}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{
  width:38px;height:38px;border-radius:11px;flex:none;
  background:linear-gradient(140deg,var(--accent),color-mix(in srgb,var(--accent) 50%,#9b6bff));
  display:grid;place-items:center;color:#fff;font-size:18px;
  box-shadow:0 4px 12px -4px color-mix(in srgb,var(--accent) 60%, transparent);
}
.brand-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.brand-name{font-weight:750;font-size:1.16rem;letter-spacing:-.02em}
.brand-desc{font-size:.74rem;font-weight:500;color:var(--muted);letter-spacing:.01em;
  max-width:30ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.brand img{max-height:40px;width:auto}

.main-nav ul{list-style:none;display:flex;align-items:center;gap:4px;margin:0;padding:0}
.main-nav a{
  position:relative;display:block;padding:8px 14px;border-radius:var(--radius-pill);
  color:var(--ink-soft);font-weight:600;font-size:.92rem;letter-spacing:.005em;
  transition:color .15s, background .15s;
}
.main-nav a:hover{background:color-mix(in srgb,var(--accent) 8%,#fff);color:var(--accent);text-decoration:none}
.main-nav .current-menu-item>a,.main-nav .current_page_item>a{
  background:var(--accent);color:#fff;box-shadow:0 4px 12px -5px color-mix(in srgb,var(--accent) 70%, transparent);
}
.main-nav .current-menu-item>a:hover,.main-nav .current_page_item>a:hover{background:var(--accent);color:#fff}

.header-search{flex:none;margin-left:auto;width:280px;max-width:34vw}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle svg{width:20px;height:20px;stroke:var(--ink)}

/* search box (header + search results) */
.search-box{position:relative;display:flex;min-width:0}
.search-box input[type=search]{
  width:100%;min-width:0;border:1px solid var(--line-strong);background:var(--surface);
  border-radius:var(--radius-pill);padding:13px 52px 13px 44px;font-size:1rem;color:var(--ink);
  box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s;
}
.search-box input[type=search]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.search-box .ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:19px;height:19px;stroke:var(--muted);pointer-events:none}
.search-box button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  border:none;background:var(--accent);color:#fff;border-radius:var(--radius-pill);
  height:38px;padding:0 18px;font-weight:600;cursor:pointer;font-size:.92rem;
}
.search-box.compact input[type=search]{padding:9px 14px 9px 38px;font-size:.92rem}
.search-box.compact .ico{left:12px;width:17px;height:17px}
/* Header search: no visible submit button, so reclaim its right padding. */
.header-search .search-box input[type=search]{padding:10px 16px 10px 40px;font-size:.94rem}
.header-search .ico{left:14px;width:18px;height:18px}
.header-search button{display:none}

/* ----------  Main layout  ---------- */
.site-main{padding:30px 0 64px}

/* Homepage ad / widget zones (top + bottom of the lists). */
.home-ad{margin:0 0 26px}
.home-ad-bottom{margin:30px 0 0}
.home-ad .widget{margin:0}
.home-ad img{height:auto;margin-inline:auto}
.home-ad:empty{display:none}

/* ----------  List section  ---------- */
.list-section{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);margin-bottom:26px;overflow:hidden;
}
.list-body{display:flex;flex-direction:column}

/* ----------  Homepage: grid of list cards (directory style)  ---------- */
.home-lists{
  display:grid;
  grid-template-columns:repeat(var(--cols,4),minmax(0,1fr));
  gap:20px;
  align-items:start;
}
.lcard{
  --card-accent:var(--accent);
  --card-tint:color-mix(in srgb, var(--card-accent) 12%, #fff);
  display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line);
  border-top:3px solid var(--card-accent);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden;min-width:0;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.lcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.lcard-head{
  padding:14px 16px 12px;border-bottom:1px solid var(--line);text-align:center;
}
.lcard-head h2{margin:0;font-size:1rem;font-weight:650;line-height:1.25;letter-spacing:-.01em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lcard-head h2 a{color:var(--ink);text-decoration:none}
.lcard-head h2 a:hover{color:var(--card-accent)}

/* card body — optional fixed height (set inline via --card-h) with internal scroll */
.lcard-body{list-style:none;margin:0;padding:4px 0;display:flex;flex-direction:column;flex:1}
.lcard.has-fixed .lcard-body{height:var(--card-h);flex:none;overflow-y:auto;overflow-x:hidden}
.lcard-body::-webkit-scrollbar{width:8px}
.lcard-body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}

.site{display:flex;align-items:center;gap:6px;padding:0 8px 0 14px}
.site + .site{border-top:1px solid var(--line)}
.site-rank{font-family:var(--mono);font-size:.72rem;font-weight:700;color:var(--card-accent);opacity:.65;
  flex:none;min-width:1.6em}
.site.is-featured .site-rank{opacity:1}
.site-name{flex:1;min-width:0;display:block;padding:10px 0;
  color:var(--ink-soft);font-weight:600;font-size:.9rem;line-height:1.3;
  text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  transition:color .12s}
.site-name:hover{color:var(--card-accent);text-decoration:none}
.site-zoom{flex:none;display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;
  color:var(--muted);transition:background .12s,color .12s}
.site-zoom svg{width:17px;height:17px;stroke:currentColor}
.site-zoom:hover{background:var(--card-tint);color:var(--card-accent)}

/* "More" footer button at the bottom of each card */
.lcard-foot{
  margin-top:auto;display:flex;align-items:center;justify-content:center;gap:5px;
  padding:11px 14px;border-top:1px solid var(--line);
  color:var(--card-accent);font-size:.82rem;font-weight:650;letter-spacing:.01em;
  text-decoration:none;transition:background .12s}
.lcard-foot svg{width:14px;height:14px;stroke:currentColor;transition:transform .15s}
.lcard-foot:hover{background:var(--card-tint);text-decoration:none}
.lcard-foot:hover svg{transform:translateX(3px)}

@media (max-width:980px){ .home-lists{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:560px){ .home-lists{grid-template-columns:1fr} }

/* ----------  Listing row (the core component)  ---------- */
.row{
  display:grid;
  grid-template-columns:46px 56px 1fr auto;
  align-items:center;gap:16px;
  padding:15px 22px;border-bottom:1px solid var(--line);
  transition:background .14s;position:relative;
}
.row:last-child{border-bottom:none}
.row:hover{background:var(--surface-2)}
.rank{
  font-family:var(--mono);font-size:1.05rem;font-weight:600;color:var(--muted);
  text-align:center;font-variant-numeric:tabular-nums;
}
.row.is-top .rank{color:var(--accent)}
.row-logo{
  width:56px;height:56px;border-radius:13px;flex:none;overflow:hidden;
  border:1px solid var(--line);background:var(--surface-2);display:grid;place-items:center;
}
.row-logo img{width:100%;height:100%;object-fit:cover}
.row-logo .ph{font-weight:800;font-size:1.4rem;color:var(--accent);font-family:var(--mono)}
.row-main{min-width:0}
.row-title{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.row-title .name{font-weight:760;font-size:1.08rem;color:var(--ink);letter-spacing:-.01em}
.row-title .name a{color:inherit}
.row-title .name a:hover{color:var(--accent);text-decoration:none}
.flag{
  font-size:.68rem;font-weight:750;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--radius-pill);background:var(--accent);color:#fff;
}
.flag.editor{background:linear-gradient(135deg,var(--gold),#ff8a3d)}
.row-tag{color:var(--muted);font-size:.92rem;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:48ch}
.row-meta{display:flex;align-items:center;gap:14px;margin-top:7px;flex-wrap:wrap}
.taglist{display:flex;gap:6px;flex-wrap:wrap}
.taglist a{
  font-size:.74rem;font-weight:600;color:var(--ink-soft);background:var(--bg);
  border:1px solid var(--line);padding:2px 9px;border-radius:var(--radius-pill);
}
.taglist a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}

/* stars */
.stars{display:inline-flex;align-items:center;gap:6px}
.stars .bar{position:relative;width:92px;height:16px;
  --star-mask:url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 20%22 fill=%22black%22%3E%3Cpath d=%22M10 1.5l2.6 5.27 5.82.85-4.2 4.1.99 5.78L10 14.8l-5.2 2.74.99-5.78-4.2-4.1 5.82-.85z%22/%3E%3Cpath d=%22M30 1.5l2.6 5.27 5.82.85-4.2 4.1.99 5.78L30 14.8l-5.2 2.74.99-5.78-4.2-4.1 5.82-.85z%22/%3E%3Cpath d=%22M50 1.5l2.6 5.27 5.82.85-4.2 4.1.99 5.78L50 14.8l-5.2 2.74.99-5.78-4.2-4.1 5.82-.85z%22/%3E%3Cpath d=%22M70 1.5l2.6 5.27 5.82.85-4.2 4.1.99 5.78L70 14.8l-5.2 2.74.99-5.78-4.2-4.1 5.82-.85z%22/%3E%3Cpath d=%22M90 1.5l2.6 5.27 5.82.85-4.2 4.1.99 5.78L90 14.8l-5.2 2.74.99-5.78-4.2-4.1 5.82-.85z%22/%3E%3C/svg%3E") left center / 100% 100% no-repeat}
.stars .bar i{position:absolute;inset:0;background:linear-gradient(90deg,var(--line-strong) 0 100%);
  -webkit-mask:var(--star-mask);mask:var(--star-mask)}
.stars .bar i.fill{background:linear-gradient(90deg,var(--gold),#ffbf47);width:var(--pct,0%)}
.stars .num{font-weight:750;font-size:.9rem;color:var(--ink);font-variant-numeric:tabular-nums}
.stars .num small{color:var(--muted);font-weight:500}

/* actions */
.row-actions{display:flex;align-items:center;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border-radius:var(--radius-pill);font-weight:680;cursor:pointer;
  border:1px solid transparent;white-space:nowrap;transition:transform .12s,box-shadow .15s,background .15s,border-color .15s;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-visit{background:var(--accent);color:var(--accent-ink);padding:10px 18px;font-size:.92rem;box-shadow:var(--shadow-sm)}
.btn-visit:hover{box-shadow:var(--shadow-md);filter:brightness(1.04)}
.btn-visit svg{width:15px;height:15px;stroke:currentColor}

/* the magnifying-glass review button — signature element */
.btn-review{
  width:44px;height:44px;flex:none;border-radius:13px;
  background:var(--surface);border:1px solid var(--line-strong);color:var(--ink-soft);
  position:relative;display:inline-grid;place-items:center;
}
.btn-review svg{width:21px;height:21px;stroke:currentColor;transition:transform .15s}
.btn-review:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.btn-review:hover svg{transform:scale(1.08)}
.btn-review::after{
  content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--ink);color:#fff;font-size:.74rem;font-weight:600;white-space:nowrap;
  padding:5px 9px;border-radius:7px;opacity:0;pointer-events:none;transition:opacity .14s,transform .14s;
}
.btn-review:hover::after,.btn-review:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* ----------  Single review page  ---------- */
.layout{display:grid;grid-template-columns:1fr 320px;gap:28px;align-items:start}
.breadcrumb{font-size:.86rem;color:var(--muted);margin:18px 0 16px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span.sep{opacity:.5}

.review-hero{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:26px;display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap;
}
.review-hero .logo{
  width:88px;height:88px;border-radius:18px;flex:none;overflow:hidden;border:1px solid var(--line);
  background:var(--surface-2);display:grid;place-items:center;
}
.review-hero .logo img{width:100%;height:100%;object-fit:cover}
.review-hero .logo .ph{font-family:var(--mono);font-weight:800;font-size:2rem;color:var(--accent)}
.review-hero .info{flex:1;min-width:240px}
.review-hero h1{margin:0 0 8px;font-size:clamp(1.6rem,1.2rem + 1.5vw,2.2rem)}
.review-hero .sub{color:var(--muted);font-size:1.04rem;margin:0 0 14px}
.review-hero .meta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.review-hero .cta{margin-left:auto;display:flex;flex-direction:column;gap:9px;align-items:stretch}
.review-hero .cta .btn-visit{padding:13px 26px;font-size:1rem}

.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:24px;margin-top:24px;
}
.card h2{font-size:1.25rem;margin-bottom:14px}
.entry-content{font-size:1.04rem;color:var(--ink-soft)}
.entry-content h2,.entry-content h3{color:var(--ink);margin-top:1.3em}
.entry-content img{border-radius:12px;margin:1em 0}
.entry-content a{font-weight:600}
.entry-content blockquote{border-left:3px solid var(--accent);margin:1em 0;padding:.2em 1.1em;color:var(--muted)}
.entry-content ul,.entry-content ol{padding-left:1.3em}
.entry-content li{margin:.3em 0}

/* pros / cons */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.proscons .col h3{display:flex;align-items:center;gap:8px;font-size:1.02rem;margin-bottom:10px}
.proscons .col h3 svg{width:19px;height:19px}
.proscons .pros h3{color:var(--good)} .proscons .pros h3 svg{stroke:var(--good)}
.proscons .cons h3{color:var(--bad)} .proscons .cons h3 svg{stroke:var(--bad)}
.proscons ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.proscons li{position:relative;padding-left:26px;color:var(--ink-soft);font-size:.97rem}
.proscons li::before{position:absolute;left:0;top:1px;font-weight:800}
.proscons .pros li::before{content:"+";color:var(--good)}
.proscons .cons li::before{content:"–";color:var(--bad)}

/* sidebar */
.sidebar{position:sticky;top:84px}
.facts{list-style:none;margin:0;padding:0}
.facts li{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px dashed var(--line);font-size:.94rem}
.facts li:last-child{border-bottom:none}
.facts .k{color:var(--muted)} .facts .v{font-weight:680;color:var(--ink);text-align:right}
.score-big{display:flex;align-items:center;gap:16px;margin-bottom:6px}
.score-big .n{font-size:3rem;font-weight:820;line-height:1;color:var(--ink);letter-spacing:-.04em}
.score-big .n small{font-size:1.1rem;color:var(--muted);font-weight:600}
.mini-list{list-style:none;margin:0;padding:0}
.mini-list li{padding:10px 0;border-bottom:1px solid var(--line)}
.mini-list li:last-child{border-bottom:none}
.mini-list a{display:flex;align-items:center;gap:10px;color:var(--ink);font-weight:600;font-size:.94rem}
.mini-list a:hover{color:var(--accent);text-decoration:none}
.mini-list .mlogo{width:34px;height:34px;border-radius:9px;flex:none;overflow:hidden;border:1px solid var(--line);display:grid;place-items:center;background:var(--surface-2)}
.mini-list .mlogo img{width:100%;height:100%;object-fit:cover}
.mini-list .ms{margin-left:auto;font-family:var(--mono);font-size:.84rem;color:var(--gold);font-weight:700}

/* ----------  Archive grid / pagination  ---------- */
.page-head{padding:34px 0 6px}
.page-head h1{margin-bottom:6px}
.page-head p{color:var(--muted);max-width:60ch;margin:0}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:18px 0}
.toolbar .filter{display:flex;gap:6px;flex-wrap:wrap}
.chip{
  font-size:.86rem;font-weight:650;color:var(--ink-soft);background:var(--surface);
  border:1px solid var(--line-strong);padding:7px 14px;border-radius:var(--radius-pill);cursor:pointer;
}
.chip:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}

.pagination{display:flex;gap:7px;justify-content:center;margin-top:30px;flex-wrap:wrap}
.pagination .page-numbers{
  min-width:42px;height:42px;display:inline-grid;place-items:center;padding:0 12px;
  border:1px solid var(--line-strong);border-radius:11px;background:var(--surface);
  color:var(--ink-soft);font-weight:650;text-decoration:none;
}
.pagination .page-numbers:hover{border-color:var(--accent);color:var(--accent)}
.pagination .current{background:var(--accent);border-color:var(--accent);color:#fff}

/* ----------  Posts (blog fallback)  ---------- */
.post-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px;margin-bottom:22px}
.post-card h2{margin-bottom:8px}
.post-card .post-meta{color:var(--muted);font-size:.86rem;margin-bottom:12px}

/* comments */
.comment-list{list-style:none;padding:0;margin:0}
.comment-list li{padding:14px 0;border-bottom:1px solid var(--line)}
.comment-list .children{list-style:none;padding-left:24px}
.comment-form input,.comment-form textarea{
  width:100%;border:1px solid var(--line-strong);border-radius:11px;padding:11px 14px;font:inherit;margin-bottom:12px;background:var(--surface);
}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}

/* ----------  Empty state  ---------- */
.empty{
  text-align:center;padding:60px 20px;background:var(--surface);border:1px dashed var(--line-strong);
  border-radius:var(--radius);color:var(--muted);
}
.empty svg{width:46px;height:46px;stroke:var(--muted);margin-bottom:14px}
.empty h2{color:var(--ink)}

/* ----------  Footer  ---------- */
.site-footer{border-top:1px solid var(--line);background:var(--surface);margin-top:auto}
.site-footer>.wrap{padding:40px 20px 26px}
.footer-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:center}
.site-footer .brand{font-size:1.05rem;font-weight:750;gap:10px}
.site-footer .brand .mark{width:32px;height:32px;border-radius:9px;font-size:16px}
.footer-nav ul{list-style:none;display:flex;gap:18px;margin:0;padding:0;flex-wrap:wrap}
.footer-nav a{color:var(--muted);font-weight:600;font-size:.92rem}
.footer-nav a:hover{color:var(--accent)}
.footer-note{color:var(--muted);font-size:.9rem;margin-top:20px;max-width:70ch}

/* Legal / compliance bar */
.footer-legal{border-top:1px solid var(--line);background:var(--surface-2)}
.footer-legal>.wrap{padding:22px 20px 26px}
.legal-nav ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px 22px;margin:0 0 14px;padding:0}
.legal-nav a{color:var(--ink-soft);font-weight:600;font-size:.84rem;letter-spacing:.01em}
.legal-nav a:hover{color:var(--accent)}
.legal-statement{color:var(--muted);font-size:.78rem;line-height:1.6;max-width:none}
.legal-statement p{margin:0 0 8px}
.age-notice{color:var(--muted);font-size:.78rem;line-height:1.6;margin:10px 0 0}
.footer-legal .copyright{color:var(--muted);font-size:.82rem;margin:16px 0 0;border:0;padding:0}

.site-content{flex:1}

/* ----------  Responsive  ---------- */
@media (max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .review-hero .cta{margin-left:0;width:100%}
}
@media (max-width:720px){
  .main-nav,.header-search{display:none}
  .main-nav.open{display:block;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--line);padding:10px 20px;box-shadow:var(--shadow-md)}
  .main-nav.open ul{flex-direction:column;gap:2px}
  .nav-toggle{display:inline-flex;margin-left:auto}
  .row{grid-template-columns:30px 46px 1fr;gap:12px;padding:14px 16px}
  .row-logo{width:46px;height:46px}
  .row-actions{grid-column:2 / -1;justify-content:flex-start;margin-top:4px}
  .row-tag{max-width:none;white-space:normal}
  .review-hero,.card{padding-inline:16px}
  .proscons{grid-template-columns:1fr}
  .review-hero{padding:18px}
}

/* ============================================================
   WordPress compatibility & hardening
   Keeps core markup (admin bar, alignments, captions, galleries,
   blocks, embeds, wide media, long words) from breaking layout.
   ============================================================ */
/* Sticky header must clear the WP admin bar when logged in. */
body.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){ body.admin-bar .site-header{top:46px} }
body.admin-bar .sidebar{top:116px}

/* Media never overflows its container (img base set earlier; cover other embeds). */
svg,video,iframe,embed,object{max-width:100%}
figure{margin:1em 0;max-width:100%}

/* Long URLs / unbroken strings wrap instead of stretching cards. */
.entry-content,.review-body,.site-name,.lcard-head h2{overflow-wrap:break-word;word-wrap:break-word}

/* Core alignment classes. */
.alignleft{float:left;margin:.3em 1.4em 1em 0}
.alignright{float:right;margin:.3em 0 1em 1.4em}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.alignwide{margin-left:auto;margin-right:auto}
.alignfull{width:100%}
.entry-content::after,.review-body::after{content:"";display:table;clear:both}

/* Captions & galleries. */
.wp-caption{max-width:100%}
.wp-caption img{display:block;margin:0 auto}
.wp-caption-text,.wp-element-caption{font-size:.85rem;color:var(--muted);text-align:center;margin-top:.4em}
.gallery{display:grid;grid-template-columns:repeat(var(--gcols,3),1fr);gap:8px;margin:1em 0}
.gallery-columns-2{--gcols:2}.gallery-columns-4{--gcols:4}.gallery-columns-5{--gcols:5}
.gallery-item img{width:100%}

/* Block editor essentials. */
.wp-block-image{margin:1em 0}
.wp-block-image img{height:auto}
.wp-block-button__link{display:inline-block;background:var(--accent);color:#fff;
  padding:10px 20px;border-radius:var(--radius-pill);text-decoration:none;font-weight:650}
.wp-block-quote,blockquote{border-left:3px solid var(--accent);margin:1em 0;padding:.2em 1em;color:var(--ink-soft)}
.wp-block-code,pre{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;overflow:auto;font-family:var(--mono);font-size:.88rem}
.wp-block-table table,.entry-content table{width:100%;border-collapse:collapse;margin:1em 0}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:8px 10px;text-align:left}

/* Responsive embeds (oEmbed). */
.wp-block-embed__wrapper{position:relative}
.wp-has-aspect-ratio .wp-block-embed__wrapper{aspect-ratio:16/9}
.wp-has-aspect-ratio iframe{position:absolute;inset:0;width:100%;height:100%}

/* Sticky post & comment helpers. */
.sticky{}
.bypostauthor{}
.post-password-form input[type="password"]{padding:8px 10px;border:1px solid var(--line-strong);border-radius:var(--radius-sm)}
