/* ══ GPDStore Blog — design port (gsb-*) ════════════════════════════════
   Source: design-implementations/gpdstore-new-design-handoff/project/blog.css
   Phase B1: hub (header, chips, featured, grid, news band, pagination).
   Loaded only on blog views (see inc/blog.php); replaces parent blog.css. */

/* ── Shoptimizer container integration ──────────────────────────────── */
/* The blog templates own the full content area: neutralise the parent
   .col-full constraint so .gs-wrap (1240px) governs, and hide the archive
   breadcrumb row on the hub (the design has none there). */
body.gpd-blog .shoptimizer-archive > .archive-header{display:none}
body.gpd-blog #content > .shoptimizer-archive > .col-full{max-width:none;padding:0;margin:0;width:100%}
body.gpd-blog #primary{float:none;width:100%;margin:0;padding:0}
body.gpd-blog .site-main{margin:0;padding:0}
body.gpd-blog #content{background:var(--bg-2)}

/* ── Shared gs-* primitives (from design theme.css; blog-scoped for now —
      promote to a shared file if the Phase 7 home rebuild needs them) ── */
/* Base CSS sets body{overflow-x:hidden}, which forces overflow-y:auto and turns <body> into a
   never-scrolling scroll container — that breaks position:sticky for the article aside (TOC).
   overflow-x:clip keeps the horizontal clipping without creating a scroll container (same trick
   as body.single-product in single-product.css). */
body.gpd-blog{overflow-x:clip}
body.gpd-blog .gs-sec{padding:62px 0}
body.gpd-blog .gs-wrap{max-width:1240px;margin:0 auto;padding:0 36px}
body.gpd-blog .gs-sechead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:34px}
body.gpd-blog .gs-sechead h2{margin:0;font-size:34px;font-weight:800;line-height:1.05;letter-spacing:-.8px;color:#fff}
body.gpd-blog .gs-sechead .sub{margin:8px 0 0;font-size:15px;color:var(--fg-secondary);max-width:760px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gs-featstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gs-feat{display:flex;align-items:center;gap:13px;background:var(--surface-glass);border:1px solid var(--line-1);border-radius:var(--r-lg);padding:15px 17px}
.gs-feat .ic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.06);color:var(--acc);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.gs-feat .ic svg{width:21px;height:21px}
.gs-feat .t{font-size:14px;font-weight:700;color:#fff}
.gs-feat .s{font-size:12px;color:var(--fg-secondary);margin-top:2px}

/* ── Hub header ─────────────────────────────────────────────────────── */
.gsb-head{position:relative;padding:54px 0 8px;overflow:visible}
.gsb-head::before{content:"";position:absolute;inset:-120px 0 0;pointer-events:none;
  background:radial-gradient(620px 300px at 18% 0%,rgba(211,255,95,.09),transparent 70%),
             radial-gradient(560px 280px at 82% -10%,rgba(35,221,190,.07),transparent 70%)}
.gsb-head-in{position:relative;display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.gsb-head h1{margin:10px 0 12px;font-size:46px;font-weight:800;letter-spacing:-1.2px;line-height:1.02;color:var(--fg-0)}
.gsb-head .sub{margin:0;max-width:560px;font-size:15.5px;line-height:1.6;color:var(--fg-secondary);text-wrap:pretty}
.gsb-head-flag{position:static}
.gsb-search{display:flex;align-items:center;gap:10px;min-width:330px;padding:0 8px 0 16px;height:50px;margin:0;
  background:var(--surface-glass);border:1px solid var(--line-1);border-radius:var(--r-full)}
.gsb-search svg{width:18px;height:18px;color:var(--fg-tertiary);flex:0 0 auto}
.gsb-search input[type="search"]{flex:1;background:none;border:0;outline:0;box-shadow:none;color:var(--fg-0);font:500 14px var(--font-sans);padding:0;height:auto}
.gsb-search input[type="search"]::placeholder{color:var(--fg-tertiary)}
.gsb-search button{height:36px;padding:0 16px;border:0;border-radius:var(--r-full);background:var(--acc);
  color:var(--acc-ink);font:700 13px var(--font-sans);cursor:pointer;transition:box-shadow var(--dur-normal) var(--ease)}
.gsb-search button:hover{box-shadow:var(--shadow-glow);background:var(--acc);color:var(--acc-ink)}

/* ── Category chips ─────────────────────────────────────────────────── */
.gsb-cats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:30px 0 0}
a.gsb-cat{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--r-full);cursor:pointer;
  background:var(--surface-glass);border:1px solid var(--line-1);color:var(--fg-1);text-decoration:none;
  font:600 13.5px var(--font-sans);transition:all var(--dur-normal) var(--ease)}
a.gsb-cat .n{font:500 11.5px var(--font-mono);color:var(--fg-tertiary)}
a.gsb-cat:hover{border-color:rgba(255,255,255,.22);transform:translateY(-1px);color:var(--fg-1)}
a.gsb-cat.active{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
a.gsb-cat.active .n{color:var(--acc-ink);opacity:.6}
.gsb-cats .rss{margin-left:auto;display:inline-flex;align-items:center;gap:7px;color:var(--fg-secondary);font:600 13px var(--font-sans);cursor:pointer;text-decoration:none}
.gsb-cats .rss svg{width:15px;height:15px}
.gsb-cats .rss:hover{color:var(--acc)}

/* ── Featured area ──────────────────────────────────────────────────── */
.gsb-featured{display:grid;grid-template-columns:1.55fr 1fr;gap:20px;margin-top:34px}
a.gsb-fcard{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:430px;
  border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--line-1);cursor:pointer;text-decoration:none;
  background:var(--bg-3);
  box-shadow:var(--shadow-sm);transition:transform var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal) var(--ease)}
a.gsb-fcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.gsb-fcard img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.gsb-fcard:hover img.bg{transform:scale(1.03)}
.gsb-fcard .shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,13,15,.05) 30%,rgba(10,13,15,.88) 78%,rgba(10,13,15,.96))}
.gsb-fcard .body{position:relative;padding:28px 30px 26px;display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.gsb-fcard .meta{display:flex;align-items:center;gap:10px;font:500 12.5px var(--font-sans);color:var(--fg-secondary)}
.gsb-fcard h3{margin:0;font-size:27px;font-weight:800;letter-spacing:-.5px;line-height:1.12;color:#fff;text-wrap:pretty}
.gsb-fcard .ex{margin:0;font-size:14px;line-height:1.55;color:var(--fg-1);max-width:560px;text-wrap:pretty}
.gsb-fcard .top{position:absolute;top:18px;left:18px;right:18px;display:flex;gap:8px;align-items:center;z-index:1}
.gsb-fside{display:grid;grid-template-rows:1fr 1fr;gap:20px}
.gsb-fside .gsb-fcard{min-height:0}
.gsb-fside .gsb-fcard h3{font-size:19px}
.gsb-fside .gsb-fcard .body{padding:20px 22px 18px;gap:8px}
.gsb-scorechip{display:inline-flex;align-items:center;gap:6px;margin-left:auto;padding:6px 12px;border-radius:var(--r-full);
  background:rgba(10,13,15,.72);border:1px solid var(--acc-line);backdrop-filter:blur(8px);
  color:var(--acc);font:700 12.5px var(--font-sans)}
.gsb-scorechip svg{width:13px;height:13px;fill:currentColor}

/* ── Post grid ──────────────────────────────────────────────────────── */
.gsb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
a.gsb-card{display:flex;flex-direction:column;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;text-decoration:none;
  background:var(--surface-glass);border:1px solid var(--line-1);box-shadow:var(--shadow-sm);
  transition:transform var(--dur-normal) var(--ease-out),border-color var(--dur-normal) var(--ease),box-shadow var(--dur-normal) var(--ease)}
a.gsb-card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.2);box-shadow:var(--shadow-lg)}
.gsb-card .well{position:relative;aspect-ratio:16/9.4;overflow:hidden;background:
  radial-gradient(70% 90% at 50% 110%,rgba(211,255,95,.10),transparent 70%),var(--bg-3)}
.gsb-card .well img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.gsb-card:hover .well img{transform:scale(1.04)}
.gsb-card .well .gs-flag{position:absolute;top:12px;left:12px;z-index:1}
.gsb-card .body{display:flex;flex-direction:column;gap:9px;padding:18px 18px 16px;flex:1}
.gsb-card .meta{display:flex;align-items:center;gap:8px;font:500 12px var(--font-sans);color:var(--fg-tertiary)}
.gsb-card h3{margin:0;font-size:16.5px;font-weight:700;letter-spacing:-.2px;line-height:1.3;color:var(--fg-0);text-wrap:pretty}
.gsb-card .ex{margin:0;font-size:13.5px;line-height:1.55;color:var(--fg-secondary);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gsb-card .foot{display:flex;align-items:center;gap:9px;margin-top:auto;padding-top:12px;border-top:1px solid var(--line-2);
  font:500 12.5px var(--font-sans);color:var(--fg-secondary)}
.gsb-card .foot img{width:24px;height:24px;border-radius:50%;object-fit:cover}
.gsb-card .foot .cm{margin-left:auto;display:inline-flex;align-items:center;gap:5px;color:var(--fg-tertiary)}
.gsb-card .foot .cm svg{width:13.5px;height:13.5px}

/* category flag colours */
.gs-flag{display:inline-flex;align-items:center;padding:5px 11px;border-radius:var(--r-full);
  right:auto;width:max-content;white-space:nowrap;
  font:700 11px var(--font-sans);letter-spacing:.06em;text-transform:uppercase}
.gsb-flag-reviews{background:var(--lime-500);color:#0A0D0F}
.gsb-flag-news{background:var(--teal-500);color:#06160F}
.gsb-flag-editorials{background:rgba(255,255,255,.92);color:#0A0D0F}

/* ── Newsletter band ────────────────────────────────────────────────── */
.gsb-bands{display:flex;flex-direction:column;gap:26px;padding-bottom:56px}
.gsb-news{display:flex;align-items:center;gap:26px;flex-wrap:wrap;padding:26px 30px;margin:8px 0;
  border-radius:var(--r-2xl);border:1px solid var(--line-1);box-shadow:var(--shadow-sm);
  background:radial-gradient(420px 180px at 8% 0%,var(--acc-soft),transparent 70%),var(--surface-elev)}
.gsb-news .ic{flex:0 0 auto;width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);border:1px solid var(--acc-line);color:var(--acc)}
.gsb-news .ic svg{width:24px;height:24px}
.gsb-news .cp{flex:1;min-width:240px}
.gsb-news .cp b{display:block;font-size:17px;color:var(--fg-0);letter-spacing:-.2px}
.gsb-news .cp span{font-size:13.5px;color:var(--fg-secondary)}
.gsb-newsform{display:flex;gap:8px;min-width:340px;margin:0}
.gsb-newsform input[type="email"]{flex:1;height:46px;padding:0 16px;background:var(--bg-2);border:1px solid var(--line-1);
  border-radius:var(--r-full);color:var(--fg-0);font:500 13.5px var(--font-sans);outline:0;box-shadow:none}
.gsb-newsform input[type="email"]::placeholder{color:var(--fg-tertiary)}
.gsb-newsform input[type="email"]:focus{border-color:var(--acc-line)}
.gsb-newsform button{height:46px;padding:0 20px;border:0;border-radius:var(--r-full);background:var(--acc);
  color:var(--acc-ink);font:700 13.5px var(--font-sans);cursor:pointer;white-space:nowrap;transition:box-shadow var(--dur-normal) var(--ease)}
.gsb-newsform button:hover{box-shadow:var(--shadow-glow);background:var(--acc);color:var(--acc-ink)}
.gsb-newsform .gsb-hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0}
.gsb-news-msg{font:600 13px var(--font-sans);color:var(--acc)}
.gsb-news-msg:empty{display:none}
.gsb-newsform.done input,.gsb-newsform.done button{display:none}

/* ── Pagination (paginate_links markup mapped to design .gsb-page) ──── */
.gsb-pages{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:42px;flex-wrap:wrap}
.gsb-pages .page-numbers{min-width:42px;height:42px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border-radius:var(--r-md);background:var(--surface-glass);border:1px solid var(--line-1);
  color:var(--fg-1);font:600 14px var(--font-sans);cursor:pointer;text-decoration:none;transition:all var(--dur-normal) var(--ease)}
.gsb-pages a.page-numbers:hover{border-color:rgba(255,255,255,.24);transform:translateY(-1px);color:var(--fg-1)}
.gsb-pages .page-numbers.current{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.gsb-pages .page-numbers.dots{border:0;background:none;cursor:default;color:var(--fg-tertiary)}
.gsb-prev-ic::before{content:"‹";font-size:18px;line-height:1}
.gsb-next-ic::before{content:"›";font-size:18px;line-height:1}

/* hub misc */
.gsb-count{font:500 13px var(--font-sans);color:var(--fg-tertiary)}
.gsb-latest{padding-top:38px}
.gsb-none{color:var(--fg-secondary);font-size:15px}

/* ── Article (single post, phase B3) ════════════════════════════════ */
html{scroll-behavior:smooth}
.gsb-crumbs{display:flex;align-items:center;gap:8px;font:500 12.5px var(--font-sans);color:var(--fg-tertiary);padding-top:26px}
.gsb-crumbs a{color:var(--fg-secondary);cursor:pointer;text-decoration:none}
.gsb-crumbs a:hover{color:var(--acc)}
.gsb-crumbs svg{width:13px;height:13px;flex:0 0 auto}
.gsb-crumbs .here{color:var(--fg-tertiary);max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.gsb-art-head{max-width:880px;padding:22px 0 6px}
.gsb-art-head h1{margin:16px 0 18px;font-size:42px;font-weight:800;letter-spacing:-1.1px;line-height:1.06;color:var(--fg-0);text-wrap:pretty}
.gsb-art-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.gsb-art-meta .who{display:flex;align-items:center;gap:11px}
.gsb-art-meta .who img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1px solid var(--line-1)}
.gsb-art-meta .who .nm{font:700 14px var(--font-sans);color:var(--fg-0)}
.gsb-art-meta .who .rl{font:500 12px var(--font-sans);color:var(--fg-tertiary)}
.gsb-art-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--fg-tertiary)}
.gsb-art-meta .mi{display:inline-flex;align-items:center;gap:6px;font:500 13px var(--font-sans);color:var(--fg-secondary)}
.gsb-art-meta .mi svg{width:14.5px;height:14.5px;color:var(--fg-tertiary)}

.gsb-updated{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--r-full);margin-bottom:14px;
  background:rgba(35,221,190,.08);border:1px solid rgba(35,221,190,.3);font:600 12px var(--font-sans);color:var(--teal-500)}
.gsb-updated svg{width:13px;height:13px}

/* hero: 16:9 band (4:3 on mobile); the square featured uploads show in full
   (contain) over a blurred copy of themselves filling the sides — no crop,
   no stretch, any source aspect ratio. */
.gsb-art-hero{position:relative;margin:0 0 26px;width:100%;aspect-ratio:16/9;border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--line-1);box-shadow:var(--shadow-lg)}
.gsb-art-hero img{display:block;position:relative;width:100%;height:100%;object-fit:contain}
.gsb-art-hero img.bg{position:absolute;inset:0;object-fit:cover;filter:blur(30px) brightness(.5) saturate(1.15);transform:scale(1.15)}
.gsb-art-hero .gs-flag{position:absolute;top:18px;left:18px;z-index:1}

.gsb-art-grid{display:grid;grid-template-columns:minmax(0,1fr) 332px;gap:48px;align-items:start;margin-top:44px}
.gsb-aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}

/* prose (Gutenberg content) */
.gsb-prose{max-width:720px;font-size:16.5px;line-height:1.72;color:var(--fg-1)}
.gsb-prose::after{content:"";display:block;clear:both} /* contain floats (WP Review box) so .gsb-tags/.gsb-author/.gsb-pn keep full width */
.gsb-prose > p:first-child{font-size:19px;line-height:1.6;color:var(--fg-0);font-weight:500;margin:0 0 26px;text-wrap:pretty}
.gsb-prose h2{scroll-margin-top:84px;margin:42px 0 14px;font-size:25px;font-weight:800;letter-spacing:-.45px;line-height:1.2;color:var(--fg-0)}
.gsb-prose h3{margin:30px 0 12px;font-size:19px;font-weight:700;color:var(--fg-0)}
.gsb-prose p{margin:0 0 16px;text-wrap:pretty}
.gsb-prose a{color:var(--teal-500);text-decoration:underline;text-decoration-color:rgba(35,221,190,.35);text-underline-offset:3px}
.gsb-prose a:hover{text-decoration-color:var(--teal-500)}
.gsb-prose ul,.gsb-prose ol{margin:0 0 16px;padding-left:24px}
.gsb-prose li{margin:0 0 8px}
.gsb-prose figure{margin:24px 0 26px}
.gsb-prose figure img{display:block;width:100%;height:auto;border-radius:var(--r-lg);border:1px solid var(--line-1)}
.gsb-prose figcaption{margin-top:10px;font:500 12.5px var(--font-sans);color:var(--fg-tertiary);text-align:left}
.gsb-prose blockquote{margin:24px 0;padding:16px 22px;border-left:3px solid var(--acc);border-radius:0 var(--r-md) var(--r-md) 0;
  background:var(--surface-glass);color:var(--fg-1)}
.gsb-prose iframe,.gsb-prose .wp-block-embed{max-width:100%;border-radius:var(--r-lg)}
.gsb-prose .wp-block-embed iframe{width:100%;aspect-ratio:16/9;height:auto;border:1px solid var(--line-1)}

/* spec-style tables for in-content tables */
.gsb-prose table{width:100%;border-collapse:collapse;font-size:14px;margin:22px 0;border:1px solid var(--line-1);
  border-radius:var(--r-lg);overflow:hidden;display:table}
.gsb-prose table th{padding:12px 18px;text-align:left;vertical-align:top;background:rgba(255,255,255,.03);
  font:600 12.5px var(--font-sans);letter-spacing:.02em;color:var(--fg-secondary);border-bottom:1px solid var(--line-2)}
/* key/value spec tables (th per row, like the design's gsb-spec) get the fixed key column */
.gsb-prose table tbody th:first-child{width:34%}
.gsb-prose table td{padding:12px 18px;text-align:left;color:var(--fg-0);font-weight:500;border-bottom:1px solid var(--line-2);background:none}
.gsb-prose table tr:last-child th,.gsb-prose table tr:last-child td{border-bottom:0}
.gsb-prose .wp-block-table{margin:22px 0}
.gsb-prose .wp-block-table table{margin:0}

/* share rail */
.gsb-share{display:flex;gap:8px;margin:22px 0 4px}
.gsb-share a,.gsb-share button{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:var(--surface-glass);border:1px solid var(--line-1);color:var(--fg-1);cursor:pointer;padding:0;
  transition:all var(--dur-normal) var(--ease)}
.gsb-share a svg,.gsb-share button svg{width:16px;height:16px}
.gsb-share a:hover,.gsb-share button:hover{color:var(--acc);border-color:var(--acc-line);transform:translateY(-1px);background:var(--surface-glass)}
.gsb-share button.copied{color:var(--acc);border-color:var(--acc)}

/* TOC */
.gsb-toc{margin:0 0 30px;padding:20px 22px;border-radius:var(--r-lg);background:var(--surface-glass);border:1px solid var(--line-1)}
.gsb-toc .tt{display:flex;align-items:center;gap:8px;font:700 12px var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-secondary);margin-bottom:12px}
.gsb-toc .tt svg{width:14px;height:14px;color:var(--acc)}
.gsb-toc ol{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:2px;counter-reset:toc}
.gsb-toc li{counter-increment:toc;margin:0}
.gsb-toc a{display:flex;align-items:baseline;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;
  color:var(--fg-1);font:500 14px var(--font-sans);text-decoration:none;transition:all var(--dur-fast) var(--ease)}
.gsb-toc a::before{content:counter(toc,decimal-leading-zero);font:600 11px var(--font-mono);color:var(--fg-tertiary)}
.gsb-toc a:hover{background:rgba(255,255,255,.05);color:var(--fg-0)}
.gsb-toc a.on{color:var(--acc)}
.gsb-toc a.on::before{color:var(--acc)}
/* TOC lives in the sticky aside on desktop; the inline article copy takes over ≤1100px */
.gsb-toc--inline{display:none}
.gsb-aside .gsb-toc{margin:0}

/* tags */
.gsb-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:28px 0 0}
a.gsb-tag{padding:6px 13px;border-radius:var(--r-full);background:var(--surface-glass);border:1px solid var(--line-1);
  font:600 12px var(--font-sans);color:var(--fg-secondary);cursor:pointer;text-decoration:none;transition:all var(--dur-fast) var(--ease)}
a.gsb-tag:hover{color:var(--acc);border-color:var(--acc-line)}

/* author box */
.gsb-author{display:flex;gap:18px;align-items:flex-start;margin:30px 0 0;padding:22px 24px;border-radius:var(--r-lg);
  background:var(--surface-glass);border:1px solid var(--line-1)}
.gsb-author img{width:62px;height:62px;border-radius:50%;object-fit:cover;border:1px solid var(--line-1)}
.gsb-author .ey{font:700 10.5px var(--font-sans);letter-spacing:.13em;text-transform:uppercase;color:var(--fg-tertiary)}
.gsb-author b{display:block;margin:3px 0 5px;font-size:16px;color:var(--fg-0)}
.gsb-author p{margin:0;font-size:13.5px;line-height:1.6;color:var(--fg-secondary)}

/* prev / next */
.gsb-pn{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:30px 0 0}
.gsb-pn a{display:flex;flex-direction:column;gap:7px;padding:18px 20px;border-radius:var(--r-lg);cursor:pointer;
  background:var(--surface-glass);border:1px solid var(--line-1);text-decoration:none;transition:all var(--dur-normal) var(--ease)}
.gsb-pn a:hover{border-color:var(--acc-line);transform:translateY(-1px)}
.gsb-pn .dir{display:flex;align-items:center;gap:6px;font:600 11px var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-tertiary)}
.gsb-pn .dir svg{width:13px;height:13px}
.gsb-pn a.next{text-align:right}
.gsb-pn a.next .dir{justify-content:flex-end}
.gsb-pn b{font-size:14px;line-height:1.35;font-weight:700;color:var(--fg-0);letter-spacing:-.1px}

/* related posts band */
.gsb-related{margin-top:54px}
.gsb-related .hd{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px}
.gsb-related h2{margin:0;font-size:26px;font-weight:800;letter-spacing:-.6px;color:var(--fg-0)}
.gsb-related .all{font:600 13.5px var(--font-sans);color:var(--lime-500);cursor:pointer;text-decoration:none}

.gsb-art-bands{padding:40px 0 56px}

/* ── Comments (B5) ──────────────────────────────────────────────────── */
.gsb-comments{margin:40px 0 0;max-width:720px}
.gsb-comments h3{margin:0 0 16px;font-size:21px;font-weight:800;letter-spacing:-.4px;color:var(--fg-0)}
.gsb-comment{display:flex;flex-wrap:wrap;gap:14px;padding:18px 0;border-top:1px solid var(--line-2)}
/* div-style wp_list_comments nests replies INSIDE the parent .gsb-comment (no
   .children wrapper) — without these rules replies become side-by-side flex items. */
.gsb-comment .gsb-comment{flex:1 1 100%;margin-left:54px;padding-bottom:0}
.gsb-comment > img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.gsb-comment .gsb-comment-bd{flex:1;min-width:0}
.gsb-comment .hd{display:flex;align-items:baseline;gap:10px}
.gsb-comment .hd b{font-size:14px;color:var(--fg-0)}
.gsb-comment .hd span{font:500 12px var(--font-sans);color:var(--fg-tertiary)}
.gsb-comment p{margin:6px 0 0;font-size:14px;line-height:1.6;color:var(--fg-1)}
.gsb-comment .moderation{color:var(--fg-tertiary);font-style:italic}
.gsb-comment .reply{margin-top:8px}
.gsb-comment .reply a,.gsb-comment .comment-reply-link{background:none;border:0;padding:0;font:600 12.5px var(--font-sans);color:var(--fg-secondary);cursor:pointer;text-decoration:none}
.gsb-comment .reply a:hover,.gsb-comment .comment-reply-link:hover{color:var(--acc)}
.gsb-comment .children,.gsb-comment-list .children{margin-left:54px}
.gsb-cform{margin-top:10px;padding:20px;border-radius:var(--r-lg);background:var(--surface-glass);border:1px solid var(--line-1)}
.gsb-cform textarea{width:100%;min-height:96px;padding:13px 15px;box-sizing:border-box;resize:vertical;outline:0;
  background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-md);color:var(--fg-0);font:500 14px var(--font-sans)}
.gsb-cform textarea::placeholder{color:var(--fg-tertiary)}
.gsb-cform textarea:focus{border-color:var(--acc-line)}
.gsb-cform .comment-form-author,.gsb-cform .comment-form-email,.gsb-cform .comment-form-url{display:inline-block;margin:10px 12px 0 0}
.gsb-cform .comment-form-author input,.gsb-cform .comment-form-email input,.gsb-cform .comment-form-url input{
  height:40px;padding:0 14px;background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--r-md);color:var(--fg-0);font:500 13.5px var(--font-sans)}
.gsb-cform label,.gsb-comments #respond label{font:600 12px var(--font-sans);color:var(--fg-secondary);display:block;margin-bottom:4px}
.gsb-comments #respond label .required{color:var(--orange-500)}
.gsb-cform .comment-form-cookies-consent{display:flex;align-items:center;gap:8px;margin:10px 0 0;font:500 12px var(--font-sans);color:var(--fg-tertiary)}
.gsb-cform .comment-form-cookies-consent label{display:inline;margin:0}
.gsb-cform .row{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:12px;flex-wrap:wrap}
.gsb-cform .note{font:500 12px var(--font-sans);color:var(--fg-tertiary)}
.gsb-cform button.post{height:42px;padding:0 22px;border:0;border-radius:var(--r-full);background:var(--lime-500);
  color:#0A0D0F;font:700 13.5px var(--font-sans);cursor:pointer}
.gsb-cform button.post:hover{box-shadow:var(--shadow-glow);background:var(--lime-500);color:#0A0D0F}
.gsb-comments .comments-pagination{margin:14px 0 0}
.gsb-comments-closed{color:var(--fg-tertiary);font-size:13.5px}

/* ── Verdict / review box (B4; accents baked teal per alt scheme) ───── */
.gsb-verdict{margin:36px 0 8px;border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--acc-line);
  background:radial-gradient(540px 240px at 0% 0%,var(--acc-soft),transparent 65%),var(--surface-elev);box-shadow:var(--shadow-lg)}
.gsb-verdict .hd{display:flex;align-items:center;gap:22px;padding:24px 26px 20px;border-bottom:1px solid var(--line-2)}
.gsb-verdict .ring{position:relative;flex:0 0 auto;width:92px;height:92px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:conic-gradient(var(--acc) calc(var(--pct)*1%),rgba(255,255,255,.09) 0)}
.gsb-verdict .ring::before{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--bg-1)}
.gsb-verdict .ring b{position:relative;font:800 26px var(--font-sans);letter-spacing:-.5px;color:var(--fg-0)}
.gsb-verdict .ring span{position:relative;font:600 10px var(--font-sans);letter-spacing:.08em;color:var(--fg-tertiary)}
.gsb-verdict .hd .cp{flex:1}
.gsb-verdict .hd .ey{font:700 11px var(--font-sans);letter-spacing:.14em;text-transform:uppercase;color:var(--acc)}
.gsb-verdict .hd h3{margin:6px 0 0;font-size:21px;font-weight:800;letter-spacing:-.4px;color:var(--fg-0)}
.gsb-verdict .subs{display:flex;flex-direction:column;gap:9px;min-width:200px}
.gsb-verdict .sub{display:grid;grid-template-columns:92px 1fr 30px;align-items:center;gap:10px;font:600 12px var(--font-sans);color:var(--fg-secondary)}
.gsb-verdict .sub .bar{height:5px;border-radius:99px;background:rgba(255,255,255,.09);overflow:hidden}
.gsb-verdict .sub .bar i{display:block;height:100%;border-radius:99px;background:var(--acc)}
.gsb-verdict .sub .v{font:600 12px var(--font-mono);color:var(--fg-0);text-align:right}
.gsb-verdict .sm{padding:18px 26px;margin:0;font-size:14.5px;line-height:1.62;color:var(--fg-1);border-bottom:1px solid var(--line-2)}
.gsb-verdict .pc{display:grid;grid-template-columns:1fr 1fr;gap:0}
.gsb-verdict .pc > div{padding:18px 26px 22px}
.gsb-verdict .pc > div + div{border-left:1px solid var(--line-2)}
.gsb-verdict .pc h4{display:flex;align-items:center;gap:8px;margin:0 0 10px;font:700 12px var(--font-sans);letter-spacing:.1em;text-transform:uppercase}
.gsb-verdict .pc .pros h4{color:var(--acc)}
.gsb-verdict .pc .cons h4{color:var(--fg-secondary)}
.gsb-verdict .pc h4 svg{width:14px;height:14px}
.gsb-verdict .pc ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.gsb-verdict .pc li{display:flex;gap:9px;font-size:13.5px;line-height:1.45;color:var(--fg-1);margin:0}
.gsb-verdict .pc li::before{content:"";flex:0 0 5px;height:5px;border-radius:50%;margin-top:8px;background:currentColor;opacity:.55}
.gsb-verdict .buy{display:flex;align-items:center;gap:14px;padding:16px 26px;border-top:1px solid var(--line-2)}
.gsb-verdict .buy img{flex:0 0 auto;width:54px;height:54px;border-radius:var(--r-md);object-fit:contain;border:1px solid var(--line-1);background:#fff}
.gsb-verdict .buy .nm{flex:1;min-width:0}
.gsb-verdict .buy .nm b{display:block;font:700 15px var(--font-sans);color:var(--fg-0)}
.gsb-verdict .buy .nm span{font:600 12.5px var(--font-mono);color:var(--acc)}
.gsb-verdict .buy a.cta{display:inline-flex;align-items:center;gap:9px;height:46px;padding:0 24px;border-radius:var(--r-full);
  background:var(--lime-500);color:#0A0D0F;font:700 14px var(--font-sans);text-decoration:none;white-space:nowrap;
  transition:box-shadow var(--dur-normal) var(--ease),transform var(--dur-fast) var(--ease)}
.gsb-verdict .buy a.cta:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px);color:#0A0D0F}
.gsb-verdict .buy a.cta svg{width:16px;height:16px}

/* ── Sidebar: shop card (B4; CTA stays lime — data-cta=lime) ────────── */
.gsb-shop{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line-1);background:var(--surface-elev);box-shadow:var(--shadow-lg)}
.gsb-shop .ey{display:flex;align-items:center;gap:8px;padding:13px 18px;border-bottom:1px solid var(--line-2);
  font:700 11px var(--font-sans);letter-spacing:.13em;text-transform:uppercase;color:var(--acc)}
.gsb-shop .ey svg{width:14px;height:14px}
.gsb-shop .well{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(70% 90% at 50% 100%,rgba(211,255,95,.12),transparent 70%),var(--bg-3)}
.gsb-shop .well img{max-width:78%;max-height:82%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 18px 28px rgba(0,0,0,.5))}
.gsb-shop .stock{position:absolute;top:12px;left:12px;z-index:1;display:inline-flex;align-items:center;gap:6px;padding:5px 11px;
  border-radius:var(--r-full);background:rgba(10,13,15,.72);border:1px solid var(--acc-line);
  font:600 11px var(--font-sans);color:var(--acc)}
.gsb-shop .stock i{width:6px;height:6px;border-radius:50%;background:var(--acc)}
.gsb-shop .bd{padding:16px 18px 18px;display:flex;flex-direction:column;gap:11px}
.gsb-shop .nm{font:700 15.5px var(--font-sans);letter-spacing:-.2px;color:var(--fg-0);line-height:1.3}
.gsb-shop .rt{display:flex;align-items:center;gap:8px;font:500 12.5px var(--font-sans);color:var(--fg-secondary)}
.gsb-shop .pr{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.gsb-shop .pr b{font:800 24px var(--font-sans);letter-spacing:-.5px;color:var(--fg-0)}
.gsb-shop .pr b .woocommerce-Price-amount{font:inherit;color:inherit}
.gsb-shop .pr span{font:500 12.5px var(--font-sans);color:var(--fg-tertiary)}
a.gsb-shop-cta,.gsb-shop a.cta{display:flex;align-items:center;justify-content:center;gap:9px;height:48px;border:0;border-radius:var(--r-full);
  background:var(--lime-500);color:#0A0D0F;font:700 14.5px var(--font-sans);cursor:pointer;text-decoration:none;
  transition:box-shadow var(--dur-normal) var(--ease),transform var(--dur-fast) var(--ease)}
.gsb-shop a.cta:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px);background:var(--lime-500);color:#0A0D0F}
.gsb-shop a.cta svg{width:17px;height:17px}
.gsb-shop a.cta.loading{opacity:.7;pointer-events:none}

/* BNPL line inside shop card */
button.gsb-bnpl{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--r-md);cursor:pointer;width:100%;text-align:left;
  background:rgba(255,255,255,.035);border:1px dashed rgba(255,255,255,.16);transition:border-color var(--dur-fast) var(--ease)}
button.gsb-bnpl:hover{border-color:var(--acc-line);background:rgba(255,255,255,.035)}
.gsb-bnpl .tx{flex:1;font:500 12px var(--font-sans);color:var(--fg-secondary);line-height:1.4}
.gsb-bnpl .tx b{color:var(--fg-0);font-weight:700}
.gsb-bnpl .tx b .woocommerce-Price-amount{font:inherit;color:inherit}
.gsb-bnpl .marks{display:flex;gap:5px}
.gsb-bnpl .mk{padding:3px 7px;border-radius:5px;font:800 9.5px var(--font-sans);letter-spacing:.02em}
.mk-klarna{background:#FFB3C7;color:#17120F}
.mk-clearpay{background:#B2FCE4;color:#0B2520}
.mk-paypal{background:#FFC439;color:#003087}
.gsb-bnpl-pop{padding:14px 16px;border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--line-1);display:flex;flex-direction:column;gap:10px}
.gsb-bnpl-pop .ln{display:flex;justify-content:space-between;align-items:center;font:500 12.5px var(--font-sans);color:var(--fg-1)}
.gsb-bnpl-pop .ln b{font:700 13px var(--font-sans);color:var(--fg-0)}
.gsb-bnpl-pop .ln b .woocommerce-Price-amount{font:inherit;color:inherit}
.gsb-bnpl-pop .ft{font:500 10.5px var(--font-sans);color:var(--fg-tertiary);line-height:1.45}

/* payment marks row */
.gs-pay{display:flex;align-items:center;gap:10px;justify-content:center}
.gs-paymark{height:26px;display:inline-flex;align-items:center;justify-content:center;gap:1px;background:#fff;border-radius:4px;padding:0 7px;font-weight:800;font-size:12px;color:#10131a}
.gs-paymark.visa{color:#1434CB;font-style:italic;font-size:13px}
.gs-paymark.pp .p1{color:#003087;font-style:italic}
.gs-paymark.pp .p2{color:#0070E0;font-style:italic}
.gs-paymark.mc{gap:0;padding:0 6px}
.gs-paymark.mc .c1{width:14px;height:14px;border-radius:50%;background:#EB001B;display:inline-block}
.gs-paymark.mc .c2{width:14px;height:14px;border-radius:50%;background:#F79E1B;display:inline-block;margin-left:-6px;mix-blend-mode:multiply}
.gs-paymark.klarna{background:#FFB3C7;color:#0B051D}
.gs-paymark.apple{color:#000}

/* ── In-content product embeds (Gutenberg buttons + Woo single/featured
      product blocks, present in legacy post content) — dark GPD skin.
      !important needed to beat block preset color classes (e.g.
      has-cyan-bluish-gray-background-color, has-white-color) and the
      featured block's inline object-fit. ── */
.gsb-prose .wp-block-buttons{margin:26px 0}
.gsb-prose .wp-block-button__link{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:48px;padding:10px 28px;
  border-radius:var(--r-full)!important;border:0;background:var(--lime-500)!important;color:#0A0D0F!important;
  font:700 14.5px var(--font-sans);text-decoration:none!important;
  transition:box-shadow var(--dur-normal) var(--ease),transform var(--dur-fast) var(--ease)}
.gsb-prose .wp-block-button__link:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}
/* single-product block → card */
.gsb-prose .wp-block-woocommerce-single-product{margin:30px 0;padding:24px 26px;border-radius:var(--r-xl);
  border:1px solid var(--line-1);background:var(--surface-elev);box-shadow:var(--shadow-lg)}
.gsb-prose .wp-block-woocommerce-single-product .wc-block-components-product-image{margin:0}
.gsb-prose .wp-block-woocommerce-single-product .wc-block-components-product-image img{border-radius:var(--r-lg);border:1px solid var(--line-2)}
.gsb-prose .wp-block-woocommerce-single-product h2.wp-block-post-title,
.gsb-prose .wp-block-woocommerce-single-product h3.wp-block-post-title{margin:0 0 12px;font-size:20px;font-weight:800;letter-spacing:-.3px;line-height:1.25}
.gsb-prose .wp-block-woocommerce-single-product .wp-block-post-title a{color:var(--fg-0);text-decoration:none}
.gsb-prose .wp-block-woocommerce-single-product .wp-block-post-title a:hover{color:var(--acc);text-decoration:none}
.gsb-prose .wp-block-woocommerce-single-product ul{font-size:14px;margin-bottom:14px}
.gsb-prose .wp-block-woocommerce-single-product .gpd-card-price-starting-at{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin:6px 0 14px}
.gsb-prose .wp-block-woocommerce-single-product .gpd-card-price-prefix{font:500 13px var(--font-sans);color:var(--fg-secondary)}
.gsb-prose .wp-block-woocommerce-single-product .woocommerce-Price-amount{font:800 21px var(--font-sans);color:var(--fg-0)}
.gsb-prose .wp-block-woocommerce-single-product .woocommerce-price-suffix{font:500 12px var(--font-sans);color:var(--fg-tertiary)}
/* featured-product block → rounded banner with readable dim */
.gsb-prose .wc-block-featured-product{margin:30px 0;border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--line-1);box-shadow:var(--shadow-lg)}
.gsb-prose .wc-block-featured-product .wc-block-featured-product__background-image{object-fit:cover!important}
.gsb-prose .wc-block-featured-product.has-background-dim .background-dim__overlay{opacity:.6}
.gsb-prose .wc-block-featured-product h2.wp-block-post-title{margin:0 0 6px;color:#fff;font-size:27px}
.gsb-prose .wc-block-featured-product .wp-block-post-title a{color:#fff;text-decoration:none}
.gsb-prose .wc-block-featured-product .gpd-card-price-starting-at{justify-content:center;display:flex;align-items:baseline;gap:8px}
.gsb-prose .wc-block-featured-product .gpd-card-price-prefix{color:rgba(255,255,255,.75)}
.gsb-prose .wc-block-featured-product .woocommerce-Price-amount{font:800 20px var(--font-sans);color:#fff}
.gsb-prose .wc-block-featured-product .woocommerce-price-suffix{color:rgba(255,255,255,.65)}

/* trust strip (sidebar) */
.gsb-trust{display:flex;flex-direction:column;gap:0;border-radius:var(--r-xl);border:1px solid var(--line-1);background:var(--surface-glass);overflow:hidden}
.gsb-trust .it{display:flex;align-items:center;gap:13px;padding:13px 18px}
.gsb-trust .it + .it{border-top:1px solid var(--line-2)}
.gsb-trust .it svg{width:19px;height:19px;color:var(--acc);flex:0 0 auto}
.gsb-trust .it b{display:block;font:700 13px var(--font-sans);color:var(--fg-0)}
.gsb-trust .it span{font:500 11.5px var(--font-sans);color:var(--fg-tertiary)}
.gsb-trust .rv{display:flex;align-items:center;gap:10px;padding:13px 18px;border-top:1px solid var(--line-2);background:rgba(255,255,255,.02)}
.gsb-trust .rv:first-child{border-top:0}
.gsb-trust .rv .tp{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#00B67A;color:#fff;flex:0 0 auto}
.gsb-trust .rv .tp svg{width:16px;height:16px;fill:currentColor}
.gsb-trust .rv b{font:700 12.5px var(--font-sans);color:var(--fg-0)}
.gsb-trust .rv span{font:500 11.5px var(--font-sans);color:var(--fg-tertiary)}

/* sidebar: latest posts */
.gsb-side-latest{border-radius:var(--r-xl);border:1px solid var(--line-1);background:var(--surface-glass);padding:18px}
.gsb-side-latest .tt{font:700 12px var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-secondary);margin-bottom:13px}
a.gsb-side-latest-it,.gsb-side-latest a.it{display:flex;gap:12px;padding:9px 0;cursor:pointer;align-items:center;text-decoration:none}
.gsb-side-latest a.it + a.it{border-top:1px solid var(--line-2)}
.gsb-side-latest a.it img{width:64px;height:46px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.gsb-side-latest a.it b{display:block;font:600 13px var(--font-sans);line-height:1.35;color:var(--fg-0);letter-spacing:-.1px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gsb-side-latest a.it span{font:500 11px var(--font-sans);color:var(--fg-tertiary)}
.gsb-side-latest a.it:hover b{color:var(--acc)}

/* pairs-with mini card */
.gsb-pairs{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:var(--r-md);margin:20px 0;
  background:var(--surface-glass);border:1px solid var(--line-1)}
.gsb-pairs .ey{font:700 10px var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-tertiary)}
.gsb-pairs b{display:block;font:700 14px var(--font-sans);color:var(--fg-0)}
.gsb-pairs span{font:600 13px var(--font-mono);color:var(--acc)}
.gsb-pairs span .woocommerce-Price-amount{font:inherit;color:inherit}
a.gsb-pairs-btn{margin-left:auto;height:36px;padding:0 16px;border-radius:var(--r-full);border:1px solid var(--acc-line);display:inline-flex;align-items:center;
  background:none;color:var(--acc);font:700 12.5px var(--font-sans);cursor:pointer;white-space:nowrap;text-decoration:none}
a.gsb-pairs-btn:hover{background:var(--acc-soft);color:var(--acc)}

/* ── Promo banner slot (sale = lime, new = teal; from gs-promo.jsx) ─── */
.gs-promo{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:18px 0 0;padding:13px 14px 13px 16px;border-radius:var(--r-lg);
  border:1px solid rgba(211,255,95,.34);box-shadow:var(--shadow-sm);
  background:radial-gradient(440px 160px at 6% 0%,rgba(211,255,95,.13),transparent 70%),var(--surface-elev)}
.gs-promo.new{border-color:rgba(35,221,190,.36);
  background:radial-gradient(440px 160px at 6% 0%,rgba(35,221,190,.12),transparent 70%),var(--surface-elev)}
.gs-promo .flag{flex:0 0 auto;padding:6px 13px;border-radius:var(--r-full);background:var(--lime-500);color:#0A0D0F;
  font:800 11px var(--font-sans);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.gs-promo.new .flag{background:var(--teal-500);color:#06160F}
.gs-promo .cp{flex:1;min-width:220px}
.gs-promo .cp b{display:block;font:700 14.5px var(--font-sans);letter-spacing:-.2px;color:var(--fg-0);line-height:1.3}
.gs-promo .cp span{font:500 12.5px var(--font-sans);color:var(--fg-secondary)}
.gs-promo .meta{font:600 12px var(--font-mono);color:var(--lime-500);white-space:nowrap}
.gs-promo.new .meta{color:var(--teal-500)}
.gs-promo a.cta{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 17px;border:0;border-radius:var(--r-full);
  background:var(--lime-500);color:#0A0D0F;font:700 13px var(--font-sans);cursor:pointer;white-space:nowrap;text-decoration:none;
  transition:box-shadow var(--dur-normal) var(--ease),transform var(--dur-fast) var(--ease)}
.gs-promo a.cta:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px);background:var(--lime-500);color:#0A0D0F}
.gs-promo.new a.cta{background:var(--teal-500);color:#06160F}
.gs-promo.new a.cta:hover{background:var(--teal-500);color:#06160F}
.gs-promo a.cta svg{width:14px;height:14px}
.gs-promo .x{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:none;border:1px solid var(--line-2);color:var(--fg-tertiary);cursor:pointer;padding:0;transition:all var(--dur-fast) var(--ease)}
.gs-promo .x:hover{color:var(--fg-0);border-color:rgba(255,255,255,.3);background:none}
.gs-promo .x svg{width:14px;height:14px}

/* Revix minimal rating inside the shop card — keep it one quiet row */
.gsb-shop .rt .drvws-minimal-rating,.gsb-shop .rt > div{display:flex;align-items:center;gap:6px}

/* ── Responsive (design breakpoints: 1100 / 720) ────────────────────── */
@media (max-width:1100px){
  .gsb-featured{grid-template-columns:1fr}
  .gsb-fside{grid-template-rows:none;grid-template-columns:1fr 1fr}
  .gsb-grid{grid-template-columns:repeat(2,1fr)}
  .gsb-art-grid{grid-template-columns:1fr}
  .gsb-aside{position:static;flex-direction:row;flex-wrap:wrap}
  .gsb-aside > *{flex:1 1 300px}
  .gsb-toc--inline{display:block}
  .gsb-toc--side{display:none}
}
@media (max-width:720px){
  .gsb-head h1{font-size:34px}
  .gsb-grid,.gsb-fside{grid-template-columns:1fr}
  .gsb-search{min-width:0;width:100%}
  .gsb-newsform{min-width:0;width:100%}
  .gs-featstrip{grid-template-columns:1fr 1fr}
  .gsb-art-head h1{font-size:30px}
  .gsb-verdict .hd{flex-wrap:wrap}
  .gsb-verdict .pc{grid-template-columns:1fr}
  .gsb-verdict .pc > div + div{border-left:0;border-top:1px solid var(--line-2)}
  .gsb-pn{grid-template-columns:1fr}
  .gsb-art-hero{aspect-ratio:4/3}
  .gsb-comment .gsb-comment{margin-left:22px}
  .gsb-verdict .buy{flex-wrap:wrap}
  .gsb-verdict .buy a.cta{flex:1 1 100%;justify-content:center;white-space:normal}
}
