/*
Theme Name: Boardly
Theme URI: https://example.com/boardly
Author: Boardly
Author URI: https://example.com
Description: Boardly is an original Pinterest-style masonry theme built for affiliate stores. Curated product "pins" in a responsive masonry grid, click-through deal buttons, price + sale badges, star ratings, coupon boxes, pros/cons review boxes, sidebar widgets, and a deep Customizer for Header, Footer, colors, typography and layout. Built-in SEO (Open Graph, Twitter Cards, JSON-LD Product/Offer/Rating/Breadcrumb schema), social sharing, announcement bar, hero, newsletter capture, ad slots, related pins, sticky mobile CTA, dark mode, WooCommerce + block-editor support, and one-click demo import.
Version: 1.1.0
Requires at least: 5.6
Tested up to: 6.5
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: boardly
Tags: masonry, grid, affiliate, e-commerce, custom-colors, custom-menu, custom-logo, featured-images, two-columns, right-sidebar, left-sidebar, sticky-post, threaded-comments, translation-ready
*/

/* ==========================================================================
   Boardly — base tokens (overridden live by the Customizer via inline CSS)
   ========================================================================== */
:root{
  --bl-ink:#1d1d28;
  --bl-paper:#ffffff;
  --bl-canvas:#f6f5f9;
  --bl-primary:#ff4d6d;
  --bl-secondary:#5b6cff;
  --bl-muted:#8b8b9c;
  --bl-border:#ececf1;
  --bl-radius:18px;
  --bl-radius-sm:11px;
  --bl-shadow:0 1px 2px rgba(29,29,40,.04), 0 8px 24px rgba(29,29,40,.06);
  --bl-shadow-hover:0 6px 14px rgba(29,29,40,.08), 0 18px 50px rgba(29,29,40,.14);
  --bl-font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --bl-font-head:"Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --bl-container:1240px;
  --bl-gap:20px;
  --bl-cols:4;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--bl-font-body);
  color:var(--bl-ink);
  background:var(--bl-canvas);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:var(--bl-font-head);line-height:1.2;font-weight:700;margin:0 0 .5em}
a{color:var(--bl-secondary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
figure{margin:0}
button,input,select,textarea{font:inherit;color:inherit}

.bl-container{max-width:var(--bl-container);margin:0 auto;padding:0 22px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--bl-ink);color:#fff;padding:10px 16px;z-index:9999;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.bl-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--bl-primary);color:#fff;border:0;cursor:pointer;
  padding:11px 20px;border-radius:999px;font-family:var(--bl-font-head);
  font-weight:600;font-size:14px;letter-spacing:.2px;line-height:1;
  transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease;
  text-decoration:none;
}
.bl-btn:hover{transform:translateY(-1px);text-decoration:none;color:#fff;box-shadow:0 8px 20px rgba(255,77,109,.35)}
.bl-btn--ghost{background:transparent;color:var(--bl-ink);border:1.5px solid var(--bl-border)}
.bl-btn--ghost:hover{border-color:var(--bl-ink);color:var(--bl-ink);box-shadow:none}

/* ==========================================================================
   Header
   ========================================================================== */
.bl-header{background:var(--bl-paper);border-bottom:1px solid var(--bl-border);position:relative;z-index:50}
.bl-header.is-sticky{position:sticky;top:0}
.bl-header__bar{display:flex;align-items:center;gap:18px;min-height:72px}
.bl-brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.bl-brand img{max-height:42px;width:auto}
.bl-brand__text{font-family:var(--bl-font-head);font-weight:800;font-size:22px;color:var(--bl-ink);letter-spacing:-.4px}
.bl-brand__text:hover{text-decoration:none}
.bl-brand__tagline{display:block;font-size:11px;color:var(--bl-muted);font-weight:500;font-family:var(--bl-font-body);letter-spacing:.3px}

.bl-nav{margin-inline-start:auto}
.bl-nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:4px}
.bl-nav li{position:relative}
.bl-nav a{
  display:block;padding:9px 14px;color:var(--bl-ink);font-weight:600;font-size:14.5px;
  font-family:var(--bl-font-head);border-radius:10px;transition:background .15s,color .15s
}
.bl-nav a:hover,.bl-nav .current-menu-item>a{background:var(--bl-canvas);text-decoration:none}
.bl-nav ul ul{
  position:absolute;top:100%;inset-inline-start:0;min-width:200px;background:var(--bl-paper);
  border:1px solid var(--bl-border);border-radius:14px;box-shadow:var(--bl-shadow);
  padding:8px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;
  transform:translateY(6px);transition:.18s;z-index:60
}
.bl-nav li:hover>ul,.bl-nav li:focus-within>ul{opacity:1;visibility:visible;transform:translateY(0)}
.bl-nav ul ul a{font-size:14px}

.bl-header__search{flex:0 0 auto}
.bl-search-form{display:flex;align-items:center;background:var(--bl-canvas);border-radius:999px;padding:5px 6px 5px 16px;border:1px solid transparent;transition:border-color .15s}
.bl-search-form:focus-within{border-color:var(--bl-secondary)}
.bl-search-form input[type=search]{border:0;background:transparent;outline:0;width:160px;font-size:14px}
.bl-search-form button{background:var(--bl-ink);color:#fff;border:0;border-radius:999px;width:32px;height:32px;cursor:pointer;display:grid;place-items:center}

.bl-menu-toggle{display:none;background:var(--bl-canvas);border:0;border-radius:10px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.bl-menu-toggle span,.bl-menu-toggle span::before,.bl-menu-toggle span::after{content:"";display:block;width:18px;height:2px;background:var(--bl-ink);border-radius:2px;position:relative;transition:.2s}
.bl-menu-toggle span::before{position:absolute;top:-6px}
.bl-menu-toggle span::after{position:absolute;top:6px}

/* category pill bar */
.bl-pillbar{background:var(--bl-paper);border-bottom:1px solid var(--bl-border)}
.bl-pillbar ul{list-style:none;margin:0;padding:11px 0;display:flex;gap:9px;overflow-x:auto;scrollbar-width:none}
.bl-pillbar ul::-webkit-scrollbar{display:none}
.bl-pillbar a{
  white-space:nowrap;padding:7px 15px;border-radius:999px;background:var(--bl-canvas);
  font-size:13.5px;font-weight:600;font-family:var(--bl-font-head);color:var(--bl-ink)
}
.bl-pillbar a:hover{background:var(--bl-ink);color:#fff;text-decoration:none}

/* ==========================================================================
   Layout shell
   ========================================================================== */
.bl-site-main{padding:30px 0 56px}
.bl-layout{display:grid;gap:34px;align-items:start}
.bl-layout--right{grid-template-columns:1fr 312px}
.bl-layout--left{grid-template-columns:312px 1fr}
.bl-layout--left .bl-content{order:2}
.bl-layout--none{grid-template-columns:1fr}

.bl-page-head{margin:0 0 22px}
.bl-page-head h1{font-size:30px;letter-spacing:-.5px}
.bl-page-head p{color:var(--bl-muted);margin:.3em 0 0}

/* ==========================================================================
   Masonry grid of pins (CSS multi-column)
   ========================================================================== */
.bl-masonry{
  column-count:var(--bl-cols);
  column-gap:var(--bl-gap);
}
.bl-masonry .bl-pin{break-inside:avoid;margin-bottom:var(--bl-gap)}

.bl-pin{
  background:var(--bl-paper);border-radius:var(--bl-radius);overflow:hidden;
  box-shadow:var(--bl-shadow);position:relative;transition:transform .2s ease, box-shadow .2s ease
}
.bl-pin:hover{transform:translateY(-4px);box-shadow:var(--bl-shadow-hover)}
.bl-pin__media{position:relative;display:block;overflow:hidden;background:var(--bl-canvas)}
.bl-pin__media img{width:100%;display:block;transition:transform .4s ease}
.bl-pin:hover .bl-pin__media img{transform:scale(1.04)}
.bl-pin__badge{
  position:absolute;top:12px;inset-inline-start:12px;background:rgba(29,29,40,.86);color:#fff;
  font-family:var(--bl-font-head);font-weight:700;font-size:12px;padding:6px 11px;border-radius:999px;backdrop-filter:blur(4px)
}
.bl-pin__price{
  position:absolute;top:12px;inset-inline-end:12px;background:#fff;color:var(--bl-ink);
  font-family:var(--bl-font-head);font-weight:800;font-size:14px;padding:6px 12px;border-radius:999px;box-shadow:var(--bl-shadow)
}
.bl-pin__deal{
  position:absolute;inset-inline:12px;bottom:12px;opacity:0;transform:translateY(12px);
  transition:.22s ease;pointer-events:none;width:calc(100% - 24px)
}
.bl-pin:hover .bl-pin__deal,.bl-pin:focus-within .bl-pin__deal{opacity:1;transform:translateY(0);pointer-events:auto}
.bl-pin__body{padding:15px 16px 17px}
.bl-pin__cat{font-size:11.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--bl-secondary)}
.bl-pin__title{font-size:16px;margin:6px 0 0;line-height:1.32}
.bl-pin__title a{color:var(--bl-ink)}
.bl-pin__title a:hover{color:var(--bl-primary);text-decoration:none}
.bl-pin__meta{display:flex;align-items:center;gap:8px;margin-top:11px;font-size:12.5px;color:var(--bl-muted)}
.bl-pin__store{display:inline-flex;align-items:center;gap:5px;font-weight:600}
.bl-pin__save{margin-inline-start:auto;background:var(--bl-canvas);border:0;border-radius:999px;width:34px;height:34px;cursor:pointer;display:grid;place-items:center;color:var(--bl-primary)}
.bl-pin__save:hover{background:var(--bl-primary);color:#fff}

/* ==========================================================================
   Single / page content
   ========================================================================== */
.bl-content > article.bl-single,
.bl-content > .bl-page-article{
  background:var(--bl-paper);border-radius:var(--bl-radius);box-shadow:var(--bl-shadow);
  padding:32px;overflow:hidden
}
.bl-single__hero{margin:-32px -32px 26px}
.bl-single__hero img{width:100%}
.bl-single__title{font-size:32px;letter-spacing:-.6px}
.bl-single__deal-row{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin:18px 0 26px;padding:18px;background:var(--bl-canvas);border-radius:var(--bl-radius-sm)}
.bl-single__price{font-family:var(--bl-font-head);font-weight:800;font-size:26px}
.bl-entry{font-size:16.5px;line-height:1.75}
.bl-entry p{margin:0 0 1.1em}
.bl-entry h2{font-size:24px;margin:1.4em 0 .5em}
.bl-entry h3{font-size:20px;margin:1.3em 0 .5em}
.bl-entry img{border-radius:12px;margin:1em 0}
.bl-entry a{color:var(--bl-secondary);text-decoration:underline}
.bl-entry blockquote{margin:1.4em 0;padding:6px 0 6px 22px;border-inline-start:4px solid var(--bl-primary);font-size:18px;font-style:italic;color:#3a3a48}

/* ==========================================================================
   Sidebar + Widgets
   ========================================================================== */
.bl-sidebar{position:sticky;top:90px}
.bl-widget{background:var(--bl-paper);border-radius:var(--bl-radius);box-shadow:var(--bl-shadow);padding:22px;margin-bottom:22px}
.bl-widget__title{font-size:16px;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--bl-border);display:flex;align-items:center;gap:9px}
.bl-widget__title::before{content:"";width:8px;height:8px;border-radius:3px;background:var(--bl-primary)}
.bl-widget ul{list-style:none;margin:0;padding:0}
.bl-widget li{padding:7px 0;border-bottom:1px dashed var(--bl-border);font-size:14.5px}
.bl-widget li:last-child{border-bottom:0}
.bl-widget li a{color:var(--bl-ink)}
.bl-widget li a:hover{color:var(--bl-primary);text-decoration:none}
.bl-widget select{width:100%;padding:9px 12px;border-radius:10px;border:1px solid var(--bl-border);background:var(--bl-canvas)}
.bl-widget .bl-search-form{background:var(--bl-canvas)}
.bl-widget .bl-search-form input[type=search]{width:100%}

/* ==========================================================================
   Footer
   ========================================================================== */
.bl-footer{background:var(--bl-ink);color:#c9c9d6;margin-top:auto}
.bl-footer a{color:#fff}
.bl-footer__widgets{padding:52px 0 34px;display:grid;gap:34px;grid-template-columns:repeat(4,1fr)}
.bl-footer .bl-widget{background:transparent;box-shadow:none;padding:0;margin:0}
.bl-footer .bl-widget__title{color:#fff;border-bottom-color:rgba(255,255,255,.12)}
.bl-footer .bl-widget li{border-bottom-color:rgba(255,255,255,.08)}
.bl-footer .bl-widget li a{color:#c9c9d6}
.bl-footer .bl-widget li a:hover{color:#fff}
.bl-footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;font-size:13.5px}
.bl-footer__social{display:flex;gap:10px}
.bl-footer__social a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center}
.bl-footer__social a:hover{background:var(--bl-primary)}
.bl-footer__disclosure{font-size:12px;color:#9a9aab;padding:0 0 22px;max-width:760px;margin:0 auto;text-align:center;line-height:1.5}

/* ==========================================================================
   Pagination / comments / misc
   ========================================================================== */
.bl-pagination{margin-top:34px;display:flex;justify-content:center}
.bl-pagination .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;padding:0 12px;border-radius:12px;background:var(--bl-paper);box-shadow:var(--bl-shadow);font-weight:600;color:var(--bl-ink);margin:0 4px}
.bl-pagination .page-numbers.current{background:var(--bl-ink);color:#fff}
.bl-pagination a.page-numbers:hover{background:var(--bl-primary);color:#fff;text-decoration:none}

.bl-comments{background:var(--bl-paper);border-radius:var(--bl-radius);box-shadow:var(--bl-shadow);padding:30px;margin-top:24px}
.bl-comments input[type=text],.bl-comments input[type=email],.bl-comments input[type=url],.bl-comments textarea{width:100%;padding:11px 14px;border:1px solid var(--bl-border);border-radius:10px;background:var(--bl-canvas);margin-bottom:12px}

.bl-notice{background:var(--bl-paper);border-radius:var(--bl-radius);box-shadow:var(--bl-shadow);padding:42px;text-align:center}
.bl-notice h2{font-size:24px}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1100px){:root{--bl-cols:3}}
@media (max-width:1024px){
  .bl-layout--right,.bl-layout--left{grid-template-columns:1fr}
  .bl-layout--left .bl-content{order:1}
  .bl-sidebar{position:static}
  .bl-footer__widgets{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .bl-header__search{display:none}
  .bl-menu-toggle{display:flex}
  .bl-nav{position:absolute;top:100%;inset-inline:0;background:var(--bl-paper);border-bottom:1px solid var(--bl-border);box-shadow:var(--bl-shadow);margin:0;padding:10px;display:none}
  .bl-nav.is-open{display:block}
  .bl-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .bl-nav ul ul{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding-inline-start:14px}
}
@media (max-width:680px){:root{--bl-cols:2;--bl-gap:14px}}
@media (max-width:420px){:root{--bl-cols:1}.bl-single__hero{margin:-32px -22px 26px}.bl-content>article.bl-single,.bl-content>.bl-page-article{padding:22px}.bl-single__hero{margin:-22px -22px 22px}}

@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ==========================================================================
   v1.1 — Announcement bar
   ========================================================================== */
.bl-announce{background:var(--bl-ink);color:#fff;font-size:14px}
.bl-announce__inner{display:flex;align-items:center;gap:14px;min-height:42px;padding:7px 0}
.bl-announce__text{flex:1;text-align:center}
.bl-announce__cta{color:#fff;font-weight:700;text-decoration:underline;margin-inline-start:6px}
.bl-announce__close{background:transparent;border:0;color:#fff;font-size:22px;line-height:1;cursor:pointer;opacity:.7}
.bl-announce__close:hover{opacity:1}

/* Dark-mode toggle button */
.bl-darktoggle{flex:0 0 auto;background:var(--bl-canvas);border:0;border-radius:10px;width:42px;height:42px;cursor:pointer;display:grid;place-items:center;color:var(--bl-ink)}
.bl-darktoggle:hover{background:var(--bl-ink);color:#fff}
.bl-darktoggle__moon{display:none}
[data-theme=dark] .bl-darktoggle__sun{display:none}
[data-theme=dark] .bl-darktoggle__moon{display:block}

/* ==========================================================================
   Hero
   ========================================================================== */
.bl-hero{background:linear-gradient(135deg,#fff,var(--bl-canvas));border-bottom:1px solid var(--bl-border)}
.bl-hero--image{background-size:cover;background-position:center;border-bottom:0}
.bl-hero__inner{max-width:720px;margin:0 auto;text-align:center;padding:58px 0}
.bl-hero__title{font-size:clamp(30px,5vw,48px);letter-spacing:-1px;margin:0 0 14px}
.bl-hero__sub{font-size:18px;color:var(--bl-muted);margin:0 0 26px}
.bl-hero--image .bl-hero__title,.bl-hero--image .bl-hero__sub{color:#fff}
.bl-hero--image .bl-hero__sub{color:rgba(255,255,255,.85)}
.bl-hero__actions{display:flex;flex-direction:column;align-items:center;gap:16px}
.bl-hero__search{width:100%;max-width:420px}
.bl-hero__search .bl-search-form{padding:8px 8px 8px 18px}
.bl-hero__search .bl-search-form input[type=search]{width:100%}
.bl-btn--lg{padding:15px 30px;font-size:16px}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */
.bl-breadcrumbs{margin:0 0 18px;font-size:13px}
.bl-breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0;padding:0}
.bl-breadcrumbs a{color:var(--bl-muted)}
.bl-breadcrumbs a:hover{color:var(--bl-primary);text-decoration:none}
.bl-breadcrumbs__sep{margin-inline-start:6px;color:var(--bl-muted);opacity:.6}
.bl-breadcrumbs [aria-current=page]{color:var(--bl-ink);font-weight:600}

/* ==========================================================================
   Star ratings
   ========================================================================== */
.bl-stars{position:relative;display:inline-flex;align-items:center;font-size:15px;line-height:1;margin-top:8px;font-family:Arial,sans-serif}
.bl-stars__bg{color:#dcdce4;letter-spacing:2px}
.bl-stars__fill{position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap;color:#ffb300;letter-spacing:2px}
.bl-stars__count{margin-inline-start:8px;font-size:12.5px;color:var(--bl-muted);letter-spacing:normal}

/* ==========================================================================
   Sale price strikethrough + Pinterest save on grid
   ========================================================================== */
.bl-pin__price del{font-weight:500;font-size:11px;color:var(--bl-muted);margin-inline-start:5px}
.bl-pin__pinit{position:absolute;top:12px;left:50%;transform:translate(-50%,-8px);display:inline-flex;align-items:center;gap:5px;background:#e60023;color:#fff;font-family:var(--bl-font-head);font-weight:700;font-size:12px;padding:6px 11px;border-radius:999px;opacity:0;transition:.2s;pointer-events:none}
.bl-pin:hover .bl-pin__pinit{opacity:1;transform:translate(-50%,0);pointer-events:auto}
.bl-pin__pinit:hover{text-decoration:none;color:#fff}
.bl-pin--ad{background:transparent;box-shadow:none}

/* ==========================================================================
   Coupon box
   ========================================================================== */
.bl-coupon{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:repeating-linear-gradient(45deg,var(--bl-canvas),var(--bl-canvas) 10px,#eef0f7 10px,#eef0f7 20px);border:1.5px dashed var(--bl-secondary);border-radius:var(--bl-radius-sm);padding:14px 18px;margin:0 0 22px}
.bl-coupon__label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--bl-secondary)}
.bl-coupon__code{font-family:var(--bl-font-head);font-weight:800;font-size:20px;letter-spacing:1px;background:#fff;padding:6px 14px;border-radius:8px;border:1px solid var(--bl-border)}
.bl-coupon__copy{margin-inline-start:auto;background:var(--bl-secondary);color:#fff;border:0;border-radius:999px;padding:9px 18px;font-weight:600;cursor:pointer;font-family:var(--bl-font-head)}
.bl-coupon__copy.is-copied{background:#16a34a}

/* ==========================================================================
   Pros & cons
   ========================================================================== */
.bl-proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:26px 0}
.bl-proscons__col{border-radius:var(--bl-radius-sm);padding:18px 20px}
.bl-proscons__col h3{font-size:16px;margin:0 0 12px;display:flex;align-items:center;gap:8px}
.bl-proscons__col ul{list-style:none;margin:0;padding:0}
.bl-proscons__col li{position:relative;padding:5px 0 5px 26px;font-size:14.5px}
.bl-proscons__col--pro{background:#effaf3}
.bl-proscons__col--pro h3{color:#16a34a}
.bl-proscons__col--pro li::before{content:"✓";position:absolute;left:0;color:#16a34a;font-weight:800}
.bl-proscons__col--con{background:#fef2f2}
.bl-proscons__col--con h3{color:#dc2626}
.bl-proscons__col--con li::before{content:"✕";position:absolute;left:0;color:#dc2626;font-weight:800}

/* ==========================================================================
   Share bar
   ========================================================================== */
.bl-share{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:0 0 18px}
.bl-share__label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--bl-muted)}
.bl-share__btn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--bl-canvas);color:var(--bl-ink);border:0;cursor:pointer;transition:.15s;position:relative}
.bl-share__btn:hover{color:#fff;text-decoration:none;transform:translateY(-2px)}
.bl-share__btn--pinterest:hover{background:#e60023}
.bl-share__btn--facebook:hover{background:#1877f2}
.bl-share__btn--x:hover{background:#000}
.bl-share__btn--whatsapp:hover{background:#25d366}
.bl-share__btn--email:hover{background:var(--bl-secondary)}
.bl-share__copy:hover,.bl-share__native:hover{background:var(--bl-ink)}
.bl-share__copy.is-copied{background:#16a34a;color:#fff}
.bl-share__copy.is-copied::after{content:"✓";position:absolute;font-size:11px;top:-8px;inset-inline-end:-4px;background:#16a34a;color:#fff;border-radius:50%;width:16px;height:16px;display:grid;place-items:center}

/* ==========================================================================
   Ad slots
   ========================================================================== */
.bl-ad{margin:22px 0;text-align:center;background:var(--bl-paper);border:1px solid var(--bl-border);border-radius:var(--bl-radius-sm);padding:14px;overflow:hidden}
.bl-ad__label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--bl-muted);margin-bottom:8px}
.bl-ad--ingrid{break-inside:avoid;margin-bottom:var(--bl-gap)}

/* ==========================================================================
   Newsletter
   ========================================================================== */
.bl-newsletter{text-align:center}
.bl-newsletter__title{font-size:24px;margin:0 0 6px;color:inherit}
.bl-newsletter__text{color:var(--bl-muted);margin:0 0 18px}
.bl-newsletter__form{display:flex;gap:10px;max-width:460px;margin:0 auto}
.bl-newsletter__form input[type=email]{flex:1;padding:13px 16px;border:1px solid var(--bl-border);border-radius:999px;background:var(--bl-paper);font-size:15px}
.bl-newsletter--compact .bl-newsletter__form{flex-direction:column}
.bl-newsletter-band{background:linear-gradient(135deg,var(--bl-primary),var(--bl-secondary));padding:46px 0;color:#fff}
.bl-newsletter-band .bl-newsletter__title,.bl-newsletter-band .bl-newsletter__text{color:#fff}
.bl-newsletter-band .bl-newsletter__text{opacity:.9}
.bl-newsletter-band .bl-newsletter__form input[type=email]{border:0}
.bl-footer .bl-newsletter{text-align:start}
.bl-footer .bl-newsletter__form{flex-direction:column;margin:0}

/* ==========================================================================
   Related pins
   ========================================================================== */
.bl-related{margin-top:30px}
.bl-related__title{font-size:22px;margin:0 0 18px}
.bl-masonry--related{column-count:2}

/* ==========================================================================
   Sticky mobile CTA + back to top
   ========================================================================== */
.bl-sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;align-items:center;gap:14px;background:var(--bl-paper);border-top:1px solid var(--bl-border);box-shadow:0 -6px 20px rgba(29,29,40,.1);padding:10px 16px}
.bl-sticky-cta__info{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.bl-sticky-cta__info strong{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bl-sticky-cta__info span{font-family:var(--bl-font-head);font-weight:800;color:var(--bl-primary)}
.bl-sticky-cta .bl-btn{margin-inline-start:auto;flex:0 0 auto}

.bl-totop{position:fixed;right:20px;bottom:20px;z-index:70;width:46px;height:46px;border-radius:14px;border:0;background:var(--bl-ink);color:#fff;cursor:pointer;display:grid;place-items:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:.2s;box-shadow:var(--bl-shadow-hover)}
.bl-totop.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.bl-totop:hover{background:var(--bl-primary)}

@media (max-width:680px){
	.bl-proscons{grid-template-columns:1fr}
	.bl-sticky-cta{display:flex}
	.bl-totop{bottom:78px}
	.bl-announce__text{text-align:start}
	.bl-newsletter__form{flex-direction:column}
}

/* ==========================================================================
   Dark mode
   ========================================================================== */
[data-theme=dark]{
	--bl-ink:#ecECf4;
	--bl-canvas:#15151c;
	--bl-paper:#1f1f29;
	--bl-border:#2c2c39;
	--bl-muted:#9a9aab;
	--bl-shadow:0 1px 2px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.35);
	--bl-shadow-hover:0 6px 14px rgba(0,0,0,.4),0 18px 50px rgba(0,0,0,.5);
}
[data-theme=dark] body{background:var(--bl-canvas);color:var(--bl-ink)}
[data-theme=dark] .bl-header,[data-theme=dark] .bl-pillbar{background:var(--bl-paper);border-color:var(--bl-border)}
[data-theme=dark] .bl-brand__text,[data-theme=dark] .bl-nav a{color:var(--bl-ink)}
[data-theme=dark] .bl-pin__price{background:var(--bl-paper);color:var(--bl-ink)}
[data-theme=dark] .bl-coupon__code{background:var(--bl-paper);color:var(--bl-ink)}
[data-theme=dark] .bl-proscons__col--pro{background:rgba(22,163,74,.12)}
[data-theme=dark] .bl-proscons__col--con{background:rgba(220,38,38,.12)}
[data-theme=dark] .bl-hero{background:linear-gradient(135deg,#22222e,#15151c)}
[data-theme=dark] .bl-search-form input::placeholder{color:var(--bl-muted)}
