/* ==========================================================================
   weeQuesters Activities — Design System
   Sister-site to weeQuesters blog. Same warm-paper editorial feel,
   teal-led palette (vs blog's tangerine-led) to read as "the lab/maker side".
   Fonts: Fraunces (display) + Work Sans (body) — same family for consistency.
   No purple gradients. Hand-drawn, picture-book editorial energy.
   ========================================================================== */

/* --------------------------------------------------------------------------
   FONTS (only external resource in this CMS).
   To go fully self-hosted, comment out the @import below and download
   Fraunces & Work Sans WOFF2 files into /assets/fonts/ then add @font-face
   rules. The site falls back to system serif/sans if Google Fonts is blocked.
   -------------------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,800;0,9..144,900;1,9..144,600&family=Work+Sans:wght@400;500;600;700&display=swap');

:root{
  --paper:#faf6ec;
  --paper-2:#f5efdd;
  --paper-3:#ede4c4;
  --ink:#1a1510;
  --ink-soft:#4a4438;
  --ink-mute:#8a8373;

  --teal:#0d9488;          /* primary — distinguishes activities */
  --teal-dk:#0a7068;
  --teal-soft:#e6f5f3;
  --tangerine:#f06b3d;
  --tangerine-dk:#d44f22;
  --butter:#f4c65d;
  --butter-soft:#fcefc8;
  --coral:#ee6c6c;
  --pink:#ec4899;
  --aubergine:#3b2540;
  --mint:#b8e6c8;
  --sky:#dcecf5;

  /* Difficulty / mess / cost color hints */
  --d-easy:#7fc7a4;
  --d-medium:#f4c65d;
  --d-hard:#f06b3d;

  --rad-sm:10px;
  --rad:18px;
  --rad-lg:28px;
  --rad-blob:42% 58% 70% 30% / 45% 45% 55% 55%;

  --shadow-sm:0 2px 0 var(--ink);
  --shadow:4px 4px 0 var(--ink);
  --shadow-lg:6px 6px 0 var(--ink);
  --shadow-soft:0 12px 40px -18px rgba(26,21,16,.35);
  --shadow-card:0 1px 0 rgba(26,21,16,.05), 0 8px 24px -12px rgba(26,21,16,.18);

  --t-fast:.15s ease;
  --t:.25s cubic-bezier(.3,1.2,.6,1);
}

/* ---------- Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Work Sans',system-ui,-apple-system,sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
  background-image:
    radial-gradient(ellipse at top right, rgba(13,148,136,.05), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(244,198,93,.06), transparent 50%);
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--teal-dk);text-decoration:none;transition:var(--t-fast)}
a:hover{color:var(--tangerine)}
button{font-family:inherit;cursor:pointer}
hr{border:0;border-top:2px dashed var(--ink-mute);margin:32px 0}

h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,serif;
  font-weight:900;
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--ink);
  margin:0 0 .5em;
}
h1{font-size:clamp(2.2rem, 5vw + .5rem, 4rem)}
h2{font-size:clamp(1.6rem, 3vw + .5rem, 2.4rem)}
h3{font-size:clamp(1.2rem, 1.5vw + .5rem, 1.5rem)}
p{margin:0 0 1em}
em{font-style:italic;color:var(--tangerine)}

.container{max-width:1280px;margin:0 auto;padding:0 24px}
@media(max-width:640px){.container{padding:0 18px}}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 14px;z-index:99;border-radius:var(--rad-sm)}
.skip-link:focus{left:14px;top:14px}

/* ---------- Header ---------- */
.site-header{background:var(--paper);border-bottom:2px solid var(--ink);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;gap:20px;max-width:1280px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:900;font-size:1.45rem;color:var(--ink);letter-spacing:-.02em}
.brand:hover{color:var(--teal)}
.brand img{height:var(--logo-h, 44px);width:auto;max-width:240px;max-height:64px;object-fit:contain;display:block}
@media(max-width:640px){.brand img{height:var(--logo-h-mobile, 36px);max-width:180px}}
.brand-mark{display:inline-block;padding:2px 4px;position:relative}
.brand-mark::before{content:"";position:absolute;inset:auto -2px 2px -2px;height:10px;background:var(--butter);z-index:-1;border-radius:3px}
.brand-mark .accent{color:var(--teal)}

.nav-toggle{background:none;border:0;width:44px;height:44px;display:none;flex-direction:column;justify-content:center;gap:5px;padding:0;cursor:pointer}
.nav-toggle span{display:block;height:3px;width:24px;background:var(--ink);border-radius:2px;transition:var(--t);margin:0 auto}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.site-nav ul.nav-root{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center}
.site-nav .nav-root>li{position:relative}
.site-nav a{color:var(--ink);font-weight:600;font-size:15px;padding:8px 14px;border-radius:var(--rad-sm);position:relative}
.site-nav a:not(.nav-search *):hover{background:var(--butter);color:var(--ink);transform:rotate(-1deg)}

.nav-search{display:flex;gap:4px;align-items:center;background:var(--paper-2);border:2px solid var(--ink);border-radius:999px;padding:3px 3px 3px 14px;margin-left:10px}
.nav-search input{border:0;background:transparent;outline:0;width:160px;padding:6px 0;font-family:inherit;color:var(--ink)}
.nav-search input::placeholder{color:var(--ink-mute)}
.nav-search button{background:var(--ink);color:var(--paper);border:0;border-radius:50%;width:34px;height:34px;display:grid;place-items:center}
.nav-search button:hover{background:var(--teal)}

@media(max-width:900px){
  .nav-toggle{display:flex}
  .site-nav{position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:2px solid var(--ink);display:none;box-shadow:var(--shadow-soft);max-height:calc(100vh - 80px);overflow-y:auto}
  .site-nav.open{display:block}
  .site-nav ul.nav-root{flex-direction:column;align-items:stretch;gap:0;padding:14px 20px}
  .site-nav .nav-root>li{border-bottom:1px dashed var(--ink-mute)}
  .site-nav .nav-root>li:last-child{border:0}
  .site-nav a{display:block;padding:14px 12px;border-radius:0}
  .site-nav a:hover{transform:none;background:var(--butter)}
  .nav-search{margin:12px 0 6px;justify-content:space-between}
  .nav-search input{width:100%}
}

/* ---------- Hero ---------- */
.hero{padding:60px 0 50px;position:relative;overflow:hidden}
.hero-container{max-width:1280px;position:relative}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;opacity:.5;z-index:0;pointer-events:none}
.hero::before{width:280px;height:280px;top:-80px;right:-50px;background:var(--butter);border-radius:var(--rad-blob);animation:float 14s ease-in-out infinite}
.hero::after{width:200px;height:200px;bottom:-30px;left:-80px;background:var(--mint);border-radius:60% 40% 55% 45% / 55% 45% 55% 45%;animation:float 18s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(6deg)}}

.hero-inner{position:relative;z-index:1;max-width:780px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--aubergine);color:var(--paper);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.3px;margin-bottom:20px}
.hero .eyebrow::before{content:"✦";color:var(--butter)}
.hero h1{margin:0 0 20px;font-size:clamp(2.4rem, 6.5vw, 5rem);max-width:22ch}
.hero h1 em{font-style:italic;color:var(--teal);position:relative;display:inline-block}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.02em;height:.22em;background:var(--butter);z-index:-1;border-radius:3px;transform:skewX(-8deg)}
.hero .lead{font-size:clamp(1.05rem, 1.4vw, 1.25rem);color:var(--ink-soft);max-width:680px;line-height:1.65}
.hero-cats{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;max-width:900px}

.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;background:var(--paper);border:2px solid var(--ink);
  border-radius:999px;font-size:14px;font-weight:600;color:var(--ink);
  box-shadow:var(--shadow-sm);transition:var(--t);
}
.chip:hover{transform:translate(-2px,-2px) rotate(-1deg);background:var(--butter);color:var(--ink);box-shadow:4px 4px 0 var(--ink)}
.chip .icon{font-size:1.05em}

/* ---------- Filter Bar (the activity-discovery hero feature) ---------- */
.filter-bar{
  background:var(--paper-2);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  padding:20px 0;position:sticky;top:78px;z-index:40;backdrop-filter:saturate(180%) blur(8px);
}
.filter-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:flex-start}
.filter-label{font-weight:700;color:var(--ink);font-size:14px;margin-right:4px}
.filter-pill{
  display:inline-flex;align-items:center;gap:6px;padding:7px 14px;
  background:var(--paper);border:2px solid var(--ink);border-radius:999px;
  font-size:13px;font-weight:600;color:var(--ink);transition:var(--t-fast);
  cursor:pointer;text-decoration:none;
}
.filter-pill:hover{background:var(--butter);transform:translateY(-1px)}
.filter-pill.active{background:var(--teal);color:#fff;border-color:var(--ink)}
.filter-pill .x{margin-left:4px;font-size:.85em;opacity:.7}
.filter-clear{font-size:13px;color:var(--ink-mute);text-decoration:underline;margin-left:auto}
.filter-clear:hover{color:var(--tangerine)}

@media(max-width:900px){.filter-bar{position:static}}

/* ---------- Layout grid ---------- */
.layout-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;padding:48px 24px;align-items:start}
@media(max-width:1024px){.layout-grid{grid-template-columns:1fr;gap:32px}}

.section-title{
  font-size:clamp(1.6rem, 2.5vw + .5rem, 2.2rem);margin:0 0 24px;
  display:flex;align-items:baseline;gap:14px;
}
.section-title::after{content:"";flex:1;height:3px;background:var(--ink);border-radius:2px;margin-top:.6em}

/* ---------- Activity Cards ---------- */
.activity-grid{
  display:grid;grid-template-columns:repeat(auto-fill, minmax(280px,1fr));gap:28px;
}
.activity-card{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  overflow:hidden;display:flex;flex-direction:column;
  transition:var(--t);position:relative;
  box-shadow:var(--shadow-sm);
}
.activity-card:hover{transform:translate(-3px,-3px) rotate(-.4deg);box-shadow:var(--shadow)}

.card-image{
  display:block;aspect-ratio:4/3;background:var(--paper-2);position:relative;overflow:hidden;
  border-bottom:2px solid var(--ink);
}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.activity-card:hover .card-image img{transform:scale(1.04)}
.card-ph{
  width:100%;height:100%;display:grid;place-items:center;font-size:3.5rem;
  background:linear-gradient(135deg,var(--butter) 0%,var(--mint) 100%);font-family:Fraunces,serif;color:var(--ink);
}

.card-badges{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px;max-width:calc(100% - 24px)}
.card-badge{
  background:var(--paper);border:1.5px solid var(--ink);
  border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;
  color:var(--ink);letter-spacing:.2px;display:inline-flex;align-items:center;gap:4px;
  box-shadow:0 1px 0 var(--ink);
}
.card-badge.b-age{background:var(--butter)}
.card-badge.b-time{background:var(--mint)}
.card-badge.b-mess{background:var(--sky)}
.card-badge.b-easy{background:var(--d-easy)}
.card-badge.b-medium{background:var(--d-medium)}
.card-badge.b-hard{background:var(--d-hard);color:#fff}
.card-badge.b-featured{background:var(--coral);color:#fff;border-color:var(--ink)}

.card-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1;gap:8px}
.card-cat{
  align-self:flex-start;font-size:11px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--teal-dk);background:var(--teal-soft);
  padding:3px 10px;border-radius:999px;
}
.card-body h3{margin:4px 0;font-size:1.2rem;line-height:1.2}
.card-body h3 a{color:var(--ink)}
.card-body h3 a:hover{color:var(--teal)}
.card-excerpt{font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.55}
.card-meta{font-size:12.5px;color:var(--ink-mute);display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:10px;border-top:1px dashed var(--paper-3)}

/* Card stats line (key activity attributes shown on cards) */
.card-stats{
  display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--ink-soft);font-weight:500;
  padding:6px 0 4px;
}
.card-stats .stat{display:inline-flex;align-items:center;gap:5px}
.card-stats .stat .ico{font-size:1em}

/* ---------- Featured activity (hero spot) ---------- */
.feature-activity{
  display:grid;grid-template-columns:1.1fr 1fr;gap:36px;
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad-lg);
  padding:32px;margin:32px 0;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.feature-activity::before{
  content:"⭐ Editor's pick";position:absolute;top:18px;right:-44px;
  background:var(--coral);color:#fff;padding:6px 60px;font-size:11px;font-weight:700;
  transform:rotate(35deg);box-shadow:0 1px 0 var(--ink);letter-spacing:.5px;
}
.feature-img{display:block;border-radius:var(--rad);overflow:hidden;border:2px solid var(--ink);aspect-ratio:4/3;background:var(--paper-2)}
.feature-img img{width:100%;height:100%;object-fit:cover}
.feature-body h2{font-size:clamp(1.6rem,2vw + 1rem,2.4rem);margin:8px 0}
.feature-body h2 a{color:var(--ink)}
.feature-body h2 a:hover{color:var(--teal)}
.feature-cat{display:inline-block;background:var(--teal);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.feature-excerpt{font-size:1.05rem;color:var(--ink-soft);margin:14px 0 18px}
.feature-meta{font-size:13px;color:var(--ink-mute);display:flex;flex-wrap:wrap;gap:8px}
.feature-stats{display:flex;flex-wrap:wrap;gap:14px;margin:14px 0}
.feature-stats .stat{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--ink-soft);font-size:14px}

@media(max-width:760px){
  .feature-activity{grid-template-columns:1fr;padding:24px}
  .feature-activity::before{display:none}
}

/* ---------- Activity Page (single) ---------- */
.activity-single{padding:0 0 60px}

.breadcrumbs{padding:24px 24px 8px;font-size:13px;color:var(--ink-mute);max-width:1280px;margin:0 auto}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.breadcrumbs li:not(:last-child)::after{content:"›";margin-left:8px;color:var(--ink-mute)}
.breadcrumbs a{color:var(--teal-dk)}
.breadcrumbs a:hover{color:var(--tangerine)}
.activity-header{padding:8px 24px 28px;max-width:1280px;margin:0 auto}

.activity-header{padding:8px 24px 28px;max-width:1280px;margin:0 auto}
.activity-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.activity-cats a{
  background:var(--teal-soft);color:var(--teal-dk);border:1.5px solid var(--teal);
  font-size:12px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
}
.activity-cats a:hover{background:var(--teal);color:#fff}
.activity-title{font-size:clamp(2rem,4.5vw + .5rem,3.6rem);margin:0 0 14px;max-width:24ch}
.activity-subtitle{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-soft);max-width:60ch;font-weight:500;margin:0 0 18px}
.activity-meta{font-size:14px;color:var(--ink-mute);display:flex;flex-wrap:wrap;gap:8px;align-items:center}

/* Quick-attribute strip — the "at-a-glance" panel critical for activity content */
.attribute-strip{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:0;
  background:var(--paper-2);
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  margin:18px auto 36px;
  max-width:1280px;
}
.attr{
  padding:14px 18px;
  border-right:2px dashed var(--ink-mute);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  min-width:0;
}
.attr:last-child{border-right:0}
.attr-icon{font-size:1.6rem;line-height:1}
.attr-label{font-size:11px;font-weight:700;color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;margin-top:2px}
.attr-value{font-size:15px;font-weight:700;color:var(--ink)}
@media(max-width:640px){
  .attribute-strip{grid-template-columns:repeat(2,1fr)}
  .attr{border-right:1px dashed var(--ink-mute);border-bottom:1px dashed var(--ink-mute)}
  .attr:nth-child(2n){border-right:0}
  .attr:nth-last-child(-n+2):not(:nth-child(2n)){border-bottom:0}
  .attr:last-child{border-bottom:0}
}

.activity-hero{margin:28px 0;border-radius:var(--rad-lg);overflow:hidden;border:2px solid var(--ink)}
.activity-hero img{width:100%;height:auto;display:block;max-height:540px;object-fit:cover}

.activity-body-wrap{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;max-width:1280px;margin:0 auto;padding:8px 24px 0}
@media(max-width:1024px){.activity-body-wrap{grid-template-columns:1fr;gap:32px}}

.activity-body{font-size:17px;line-height:1.75;color:var(--ink-soft)}
.activity-body h2{font-size:1.8rem;margin:36px 0 14px;color:var(--ink);letter-spacing:-.01em}
.activity-body h3{font-size:1.3rem;margin:28px 0 10px;color:var(--ink)}
.activity-body p{margin:0 0 16px}
.activity-body a{color:var(--teal-dk);font-weight:600;border-bottom:1.5px solid var(--butter);transition:var(--t-fast)}
.activity-body a:hover{color:var(--tangerine);border-bottom-color:var(--tangerine)}

/* Generic images inside activity body get a styled border. Step images
   are excluded because their .step-img figure wrapper already provides
   the border — applying it to the inner <img> too would double up. */
.activity-body img{border-radius:var(--rad);margin:18px 0;border:2px solid var(--ink)}
.activity-body .step-img img,
.activity-body .step-image img{border:0;border-radius:0;margin:0}
.activity-body ul,.activity-body ol{padding-left:1.5em;margin:0 0 18px}
.activity-body li{margin-bottom:6px}
.activity-body blockquote{
  border-left:5px solid var(--teal);background:var(--teal-soft);
  padding:14px 22px;margin:24px 0;border-radius:0 var(--rad-sm) var(--rad-sm) 0;
  font-style:italic;color:var(--ink);
}

/* TLDR / Quick answer block (AEO gold — gets cited in AI Overviews) */
.tldr, .tldr-block{
  background:var(--butter-soft);
  border:2px solid var(--ink);
  border-left:6px solid var(--tangerine);
  border-radius:var(--rad-sm);
  padding:18px 22px;
  margin:18px 0 32px;
  font-size:1.02rem;
  line-height:1.6;
  position:relative;
}
/* "In short" label — rendered as a distinct badge above the text */
.tldr strong, .tldr-label{
  display:inline-block;
  background:var(--tangerine);
  color:#fff;
  font-family:'Fraunces',Georgia,serif;
  font-weight:900;
  font-size:11px;
  letter-spacing:.8px;
  text-transform:uppercase;
  padding:3px 9px;
  border-radius:99px;
  margin:0 0 10px;
  line-height:1.4;
}
/* Visual divider below tldr before main content starts */
.tldr-block + *,
.tldr + *{
  position:relative;
}
.activity-intro{
  padding-top:4px;
}

/* Key takeaways callout (AEO/GEO booster — concise factual bullets get pulled into answers) */
.takeaways{
  background:var(--mint);border:2px solid var(--ink);border-radius:var(--rad);
  padding:20px 24px;margin:24px 0;box-shadow:var(--shadow-sm);
}
.takeaways strong{
  display:block;font-family:Fraunces,serif;font-weight:900;font-size:1.15rem;
  color:var(--ink);margin-bottom:10px;letter-spacing:-.01em;
}
.takeaways ul{margin:0;padding-left:1.4em}
.takeaways li{margin-bottom:6px;color:var(--ink);font-weight:500}

/* Materials & Tools block */
.kit-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
@media(max-width:640px){.kit-grid{grid-template-columns:1fr}}
.kit-card{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  padding:18px 22px;box-shadow:var(--shadow-sm);
}
.kit-card h3{
  margin:0 0 12px;display:flex;align-items:center;gap:8px;
  font-size:1.15rem;
}
.kit-card h3 .ico{
  display:inline-grid;place-items:center;width:32px;height:32px;border-radius:50%;
  background:var(--butter);font-size:1.05rem;border:2px solid var(--ink);
}
/* Materials / Tools checklist */
.kit-list{list-style:none;padding:0;margin:0}
.kit-list li{
  display:flex;
  align-items:baseline;
  gap:8px;
  padding:9px 0;
  border-bottom:1px dashed var(--paper-3);
  font-size:15px;color:var(--ink);line-height:1.5;
}
.kit-list li:last-child{border-bottom:0}

/* Checkbox at the start of every row */
.kit-list li::before{
  content:"☐";
  color:var(--ink-mute);
  font-size:1.05em;
  flex:0 0 auto;
  line-height:1.5;
}

/* Quantity — sized to its own content, never wider than necessary.
   Hidden entirely when empty (the .kit-qty:empty rule below). */
.kit-list .kit-qty{
  flex:0 0 auto;
  color:var(--ink-soft);
  font-size:13.5px;
  font-weight:600;
  white-space:nowrap;
  /* Cap qty width so very long qty strings don't squeeze the name —
     anything longer wraps onto two lines within the qty column. */
  max-width:9em;
  white-space:normal;
  text-align:right;
}
.kit-list .kit-qty:empty{display:none}

/* Item name takes the remaining width and wraps freely */
.kit-list .kit-name{
  flex:1 1 0;
  min-width:0;          /* allow flex item to shrink below content width */
  line-height:1.5;
  word-wrap:break-word;
}

/* Optional badge — inline pill, never a separate column */
.kit-list .kit-opt{
  display:inline-block;
  font-size:11px;
  background:var(--paper-2);
  padding:1px 7px;
  border-radius:999px;
  color:var(--ink-mute);
  margin-left:6px;
  font-weight:600;
  letter-spacing:.4px;
  vertical-align:middle;
  white-space:nowrap;
}

/* Steps — the heart of the activity page */
.steps-section{margin:36px 0}
.steps-section h2{font-size:2rem;margin-bottom:24px}

/* Strip the default <ol> numbering — we render our own circle markers.
   Without this, browsers show "1." "2." "3." down the left margin
   on top of our custom .step-num circles. */
.steps-list{
  list-style:none;
  padding:0;
  margin:0;
  counter-reset:step;
}

.step, .step-card{
  display:grid;grid-template-columns:64px 1fr;gap:22px;margin:24px 0;
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  padding:22px 24px;box-shadow:var(--shadow-sm);position:relative;
}
.step:hover, .step-card:hover{box-shadow:var(--shadow)}
.step-num{
  display:grid;place-items:center;width:54px;height:54px;border-radius:50%;
  background:var(--teal);color:#fff;font-family:Fraunces,serif;font-weight:900;
  font-size:1.5rem;border:2px solid var(--ink);box-shadow:var(--shadow-sm);
  flex-shrink:0;
}
.step-card.alt-1 .step-num{background:var(--tangerine)}
.step-card.alt-2 .step-num{background:var(--coral)}
.step-card.alt-3 .step-num{background:var(--mint);color:var(--ink)}
.step-card.alt-4 .step-num{background:var(--butter);color:var(--ink)}
/* Legacy support for old .step-num.alt-X */
.step-num.alt-1{background:var(--tangerine)}
.step-num.alt-2{background:var(--coral)}
.step-num.alt-3{background:var(--mint);color:var(--ink)}
.step-num.alt-4{background:var(--butter);color:var(--ink)}

.step-content h3, .step-body .step-title, .step-body h3{
  margin:0 0 8px;font-size:1.3rem;color:var(--ink);
  font-family:Fraunces,serif;font-weight:800;line-height:1.3;
}
.step-content p, .step-body p, .step-text p{
  margin:0 0 10px;color:var(--ink-soft);font-size:16px;line-height:1.65;
}
.step-text{color:var(--ink-soft);font-size:16px;line-height:1.65}
.step-text > *:first-child{margin-top:0}
.step-text > *:last-child{margin-bottom:0}

.step-tip{
  background:var(--butter-soft);border-left:4px solid var(--butter);padding:10px 14px;
  border-radius:0 var(--rad-sm) var(--rad-sm) 0;margin:14px 0 4px;font-size:14.5px;color:var(--ink);
}
.step-tip strong{color:var(--tangerine);text-transform:uppercase;font-size:11px;letter-spacing:.5px;display:block;margin-bottom:2px}

.step-image, .step-img{
  margin:18px 0 4px;
  border-radius:var(--rad-sm);
  overflow:hidden;
  border:2px solid var(--ink);
  box-shadow:var(--shadow-sm);
  /* Take the full body-column width so the photo is clearly visible */
  max-width:100%;
}
.step-image img, .step-img img{
  display:block;
  width:100%;
  height:auto;
  /* Cap very tall images so they don't dominate the card */
  max-height:520px;
  object-fit:cover;
  object-position:center;
}
.step-img figcaption{
  padding:8px 12px;
  font-size:13px;
  color:var(--ink-mute);
  background:var(--paper-2);
  border-top:1.5px solid var(--ink);
  font-style:italic;
}

.step-time{display:inline-block;background:var(--mint);padding:3px 9px;border-radius:999px;font-size:12px;font-weight:700;color:var(--ink);margin-left:8px;border:1.5px solid var(--ink);vertical-align:middle}

@media(max-width:640px){
  .step, .step-card{
    /* Stack vertically so body uses the full card width */
    grid-template-columns:1fr;
    gap:10px;
    padding:16px 16px 18px;
  }
  /* Number circle on its own line, hugging the left edge */
  .step-num{
    width:36px;height:36px;
    font-size:1rem;
    margin:0 0 4px;
    justify-self:start;
  }
  .step-body, .step-content{
    /* No left indent — body flows edge-to-edge inside the card padding */
    padding:0;
    margin:0;
  }
  .step-body .step-title,
  .step-body h3,
  .step-content h3{
    font-size:1.1rem;
    line-height:1.3;
    margin:0 0 8px;
  }
  .step-text, .step-content p, .step-body p{
    font-size:15px;
    line-height:1.6;
  }
  .step-tip{margin:14px 0 0;padding:10px 12px;font-size:14px}
  .step-time{font-size:11px;padding:2px 7px}
}

/* Science explainer — E-E-A-T booster */
.science-block{
  background:linear-gradient(135deg,var(--sky) 0%,var(--paper) 100%);
  border:2px solid var(--ink);border-radius:var(--rad);padding:24px 26px;margin:32px 0;
  position:relative;
}
.science-block::before{
  content:"🔬";position:absolute;top:-18px;left:24px;background:var(--paper);
  width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  border:2px solid var(--ink);font-size:1.3rem;
}
.science-block h2{margin:8px 0 12px;font-size:1.5rem}
.science-block p{margin:0 0 10px;color:var(--ink-soft)}

/* Safety note callout */
.safety-note{
  background:#fff5f0;border:2px solid var(--ink);border-left-width:6px;border-left-color:var(--coral);
  border-radius:var(--rad-sm);padding:14px 18px;margin:20px 0;font-size:15px;color:var(--ink);
}
.safety-note strong{display:block;margin-bottom:4px;color:var(--coral);text-transform:uppercase;font-size:12px;letter-spacing:.5px}

/* Print / Save action bar */
.activity-actions{
  display:flex;gap:10px;flex-wrap:wrap;margin:24px 0;padding:14px 0;
  border-top:2px dashed var(--ink-mute);border-bottom:2px dashed var(--ink-mute);
}
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;
  background:var(--paper);border:2px solid var(--ink);border-radius:999px;
  color:var(--ink);font-weight:600;font-size:14px;
  box-shadow:var(--shadow-sm);transition:var(--t);cursor:pointer;font-family:inherit;
}
.btn:hover{background:var(--butter);transform:translate(-2px,-2px);box-shadow:var(--shadow);color:var(--ink)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-dk);color:#fff}
.btn-tangerine{background:var(--tangerine);color:#fff}
.btn-tangerine:hover{background:var(--tangerine-dk);color:#fff}

/* FAQ */
.activity-faq{margin:36px 0}
.activity-faq h2{font-size:1.8rem;margin:0 0 18px}
.faq-item{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad-sm);
  margin-bottom:12px;overflow:hidden;
}
.faq-item summary{
  padding:14px 20px;font-weight:600;cursor:pointer;font-family:'Work Sans',sans-serif;
  font-size:1.02rem;display:flex;align-items:center;gap:10px;list-style:none;color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{
  content:"+";display:inline-grid;place-items:center;width:24px;height:24px;
  background:var(--teal);color:#fff;border-radius:50%;font-weight:700;flex-shrink:0;font-size:1rem;line-height:1;
  transition:transform var(--t);
}
.faq-item[open] summary::before{content:"−"}
.faq-item div{padding:0 20px 16px;color:var(--ink-soft);font-size:15.5px;line-height:1.65}

/* Tags */
.activity-tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.activity-tags a{
  background:var(--paper-2);border:1.5px solid var(--ink);padding:5px 12px;border-radius:999px;
  font-size:13px;font-weight:500;color:var(--ink-soft);
}
.activity-tags a:hover{background:var(--butter);color:var(--ink)}

/* Author box */
.author-box{
  display:flex;gap:18px;background:var(--paper-2);border:2px solid var(--ink);
  border-radius:var(--rad);padding:20px 22px;margin:32px 0;align-items:center;box-shadow:var(--shadow-sm);
}
.author-box img{width:64px;height:64px;border-radius:50%;border:2px solid var(--ink);object-fit:cover;flex-shrink:0}
.author-box strong{display:block;font-family:Fraunces,serif;font-size:1.1rem;font-weight:800;margin-bottom:4px}
.author-box p{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.5}
.author-box .author-cred{display:block;font-size:12.5px;color:var(--teal-dk);font-weight:600;margin-top:2px}

/* Reviews */
.reviews-section{margin:36px 0}
.reviews-section h2{font-size:1.8rem;margin-bottom:8px}
.reviews-summary{display:flex;align-items:center;gap:14px;margin-bottom:18px;font-size:15px;color:var(--ink-soft)}
.stars{color:var(--butter);font-size:1.15rem;letter-spacing:1px}
.review-card{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm);
}
.review-card .row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;font-size:13px;color:var(--ink-mute)}
.review-card strong{color:var(--ink);font-size:14.5px}
.review-card p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.55}
.review-form{
  background:var(--teal-soft);border:2px solid var(--ink);border-radius:var(--rad);
  padding:22px 24px;margin-top:24px;
}
.review-form h3{font-size:1.2rem;margin:0 0 12px}
.review-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:640px){.review-form .form-row{grid-template-columns:1fr}}
.review-form input,.review-form textarea,.review-form select{
  padding:10px 14px;border:2px solid var(--ink);border-radius:var(--rad-sm);
  font-family:inherit;font-size:15px;background:var(--paper);width:100%;color:var(--ink);
}
.review-form textarea{min-height:80px;resize:vertical}
.review-form button{margin-top:8px}
.rating-input{display:flex;gap:4px;font-size:1.5rem;cursor:pointer;margin-bottom:12px}
.rating-input input{display:none}
.rating-input label{cursor:pointer;color:var(--ink-mute);transition:var(--t-fast)}
.rating-input input:checked ~ label,.rating-input label:hover,.rating-input label:hover ~ label{color:var(--butter)}

/* Related activities */
.related{margin:36px 0}
.related h2{font-size:1.8rem;margin:0 0 18px}
.related h2 em{color:var(--teal)}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
/* Hard cap at 3 columns — a single card without siblings must not stretch full-width */
@media(min-width:700px){.related-grid{grid-template-columns:repeat(3,1fr)}}
.related-card{
  display:flex;flex-direction:column;background:var(--paper);
  border:2px solid var(--ink);border-radius:var(--rad);overflow:hidden;
  text-decoration:none;color:var(--ink);transition:var(--t);box-shadow:var(--shadow-sm);
}
.related-card:hover{transform:translate(-2px,-2px) rotate(-.4deg);box-shadow:var(--shadow);color:var(--ink)}
/* Fixed pixel height prevents a lone card from being enormous */
.related-card img{width:100%;height:160px;object-fit:cover;display:block}
.related-card .card-ph{width:100%;height:160px;display:grid;place-items:center;font-family:Fraunces,serif;font-size:2rem}
.related-card strong{padding:10px 14px 4px;font-family:Fraunces,serif;font-weight:800;font-size:.95rem;line-height:1.3;display:block}
.related-card .related-card-body{padding:0 0 12px}
.related-meta{padding:2px 14px 10px;display:flex;gap:8px;flex-wrap:wrap}
.related-meta span{font-size:12px;color:var(--ink-soft)}

/* ---------- Sidebar / Widgets ---------- */
.sidebar{
  display:flex;flex-direction:column;gap:24px;
  /* Sticky behaviour: stays in view while user scrolls the main content
     until the sidebar's own bottom reaches the viewport bottom, then
     scrolls naturally. 140px clears the sticky site-header (78px) +
     sticky nav-bar (~62px). */
  position:sticky;
  top:140px;
  /* When the sidebar is taller than the viewport, allow it to scroll
     internally so all widgets remain reachable. max-height accounts for
     the sticky offset above. */
  max-height:calc(100vh - 160px);
  overflow-y:auto;
  /* Hide scrollbar visually but keep it functional — feels native */
  scrollbar-width:thin;
  scrollbar-color:var(--paper-3) transparent;
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:var(--paper-3);border-radius:99px}
.sidebar::-webkit-scrollbar-thumb:hover{background:var(--ink-mute)}

/* On small screens the sidebar stacks below the main content — sticky
   becomes pointless and counterproductive there, so disable it. */
@media(max-width:1024px){
  .sidebar{
    position:static;
    max-height:none;
    overflow:visible;
  }
}
.widget{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  padding:22px 24px;box-shadow:var(--shadow-sm);
}
.widget h3{font-size:1.15rem;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.widget h3::before{content:"✦";color:var(--tangerine)}
.widget-list{list-style:none;padding:0;margin:0}
.widget-list li{padding:7px 0;border-bottom:1px dashed var(--paper-3)}
.widget-list li:last-child{border-bottom:0}
.widget-list a{color:var(--ink);font-weight:500}
.widget-list a:hover{color:var(--teal)}

.widget-cta{background:var(--butter-soft);border-color:var(--ink)}
.widget-cta h3::before{content:"🎈"}
.widget-cta p{font-size:14px;color:var(--ink-soft);margin:0 0 12px}
.widget-cta input{width:100%;padding:10px 14px;border:2px solid var(--ink);border-radius:var(--rad-sm);font-family:inherit;font-size:15px;background:var(--paper);margin-bottom:8px}
.widget-cta button{
  width:100%;padding:11px;background:var(--teal);color:#fff;border:2px solid var(--ink);
  border-radius:var(--rad-sm);font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;
  transition:var(--t-fast);
}
.widget-cta button:hover{background:var(--teal-dk);transform:translateY(-1px)}

/* Sidebar TOC for activity pages */
.toc-widget ol{list-style:none;padding:0;margin:0;counter-reset:toc-counter}
.toc-widget li{counter-increment:toc-counter;padding:6px 0;font-size:14px}
.toc-widget li::before{content:counter(toc-counter) ".";color:var(--teal);font-weight:700;margin-right:6px}
.toc-widget a{color:var(--ink-soft)}
.toc-widget a:hover{color:var(--teal)}

/* ---------- Subscribe strip ---------- */
.subscribe-strip{
  background:var(--teal);color:#fff;padding:48px 0;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  position:relative;overflow:hidden;
}
.subscribe-strip::before{
  content:"";position:absolute;width:240px;height:240px;background:var(--butter);
  border-radius:50%;top:-100px;right:-50px;opacity:.4;animation:float 16s ease-in-out infinite;
}
.subscribe-strip::after{
  content:"";position:absolute;width:160px;height:160px;background:var(--tangerine);
  border-radius:50%;bottom:-60px;left:-40px;opacity:.4;animation:float 20s ease-in-out infinite reverse;
}
.sub-wrap{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;position:relative;z-index:1}
@media(max-width:760px){.sub-wrap{grid-template-columns:1fr}}
.sub-wrap h2{color:#fff;margin:0 0 8px;font-size:clamp(1.5rem, 2.5vw + .5rem, 2.2rem)}
.sub-wrap h2 em{color:var(--butter);font-style:normal;position:relative;display:inline-block}
.sub-wrap h2 em::after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.18em;background:rgba(244,198,93,.4);z-index:-1}
.sub-wrap p{color:#fff;opacity:.9;margin:0;font-size:1.05rem}
.subscribe-form{display:flex;gap:8px}
.subscribe-form input{flex:1;padding:14px 18px;border:2px solid var(--ink);border-radius:999px;font-family:inherit;font-size:15px;background:var(--paper);color:var(--ink)}
.subscribe-form button{
  padding:14px 22px;background:var(--ink);color:var(--paper);border:2px solid var(--ink);
  border-radius:999px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:var(--t-fast);
}
.subscribe-form button:hover{background:var(--tangerine);color:#fff}
@media(max-width:520px){.subscribe-form{flex-direction:column}}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);padding:48px 0 0;margin-top:0}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding-bottom:32px}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr}}
.footer-col h4{color:#fff;font-size:1rem;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}
.footer-col p{color:rgba(250,246,236,.7);font-size:14.5px;margin:0 0 12px;line-height:1.55}
.footer-col strong{color:#fff;font-family:Fraunces,serif;font-size:1.4rem;font-weight:900;display:block;margin-bottom:8px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{padding:5px 0}
.footer-col a{color:rgba(250,246,236,.85)}
.footer-col a:hover{color:var(--butter)}
.footer-bottom{border-top:1px solid rgba(250,246,236,.15);padding:18px 0}
.footer-bottom p{color:rgba(250,246,236,.6);font-size:13px;margin:0;text-align:center}

/* ---------- Pagination ---------- */
.pager{display:flex;gap:6px;justify-content:center;margin:48px 0 0;flex-wrap:wrap}
.pager a{
  display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 14px;
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad-sm);
  color:var(--ink);font-weight:600;text-decoration:none;transition:var(--t-fast);
}
.pager a:hover{background:var(--butter)}
.pager a.current{background:var(--teal);color:#fff}

/* ---------- Archive header ---------- */
.archive-header{padding:36px 24px 24px;max-width:1280px;margin:0 auto}
.archive-header h1{margin:8px 0 12px}
.archive-header .lead{font-size:1.1rem;color:var(--ink-soft);max-width:60ch}
.archive-intro{
  background:var(--paper-2);border:2px solid var(--ink);border-radius:var(--rad);
  padding:22px 26px;margin:24px 0;font-size:15.5px;color:var(--ink-soft);line-height:1.7;
}

/* ---------- Empty state ---------- */
.empty{
  text-align:center;padding:48px 24px;color:var(--ink-mute);font-size:1.1rem;
  background:var(--paper-2);border:2px dashed var(--ink-mute);border-radius:var(--rad);
}

/* ---------- Ads ---------- */
.ad{margin:24px 0;text-align:center;display:block;position:relative;min-height:50px}
.ad-header{padding:14px 0;background:var(--paper-2);border-bottom:2px solid var(--ink)}
.ad-side{margin:0 0 24px}
.ad-incontent{margin:30px 0;padding:18px;background:var(--paper-2);border-radius:var(--rad);border:2px dashed var(--ink-mute)}
.ad-incontent::before{content:"Sponsored";display:block;font-size:11px;color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.ad-below{margin:36px 0}
.card-wide{grid-column:1/-1}

/* ---------- Reading progress bar ---------- */
.read-progress{
  position:fixed;top:0;left:0;height:4px;width:0;
  background:linear-gradient(90deg,var(--teal),var(--butter));
  z-index:100;transition:width .08s linear;
  border-bottom-right-radius:4px;
}

/* ---------- Print styles (printable activity pages) ---------- */
@media print{
  .site-header,.site-nav,.subscribe-strip,.site-footer,.sidebar,.activity-actions,
  .ad,.ad-header,.ad-side,.ad-incontent,.ad-below,.read-progress,.related,.review-form,
  .nav-toggle,.skip-link,.filter-bar,.hero::before,.hero::after,
  .subscribe-strip::before,.subscribe-strip::after{display:none !important}
  body{background:#fff;color:#000;font-size:12pt;line-height:1.5}
  .container,.activity-body-wrap{max-width:100%;padding:0;display:block}
  .activity-body{font-size:11pt}
  .step{break-inside:avoid;page-break-inside:avoid;border:1px solid #000;box-shadow:none}
  .activity-hero img{max-height:280px}
  a{color:#000;text-decoration:underline}
  .attr-strip{border:1px solid #000;background:#f8f8f8}
  .takeaways,.tldr{background:#f8f8f8;border:1px solid #000;box-shadow:none}
}

/* ---------- Utility: visually hidden ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- 404 ---------- */
.page-404{padding:80px 24px;text-align:center}
.page-404 h1{font-size:6rem;color:var(--tangerine);margin:0}
.page-404 p{font-size:1.2rem;color:var(--ink-soft);max-width:480px;margin:0 auto 24px}

/* ---------- Search ---------- */
.search-form-big{display:flex;gap:8px;max-width:640px;margin:24px 0}
.search-form-big input{flex:1;padding:14px 20px;border:2px solid var(--ink);border-radius:999px;font-size:1.05rem;background:var(--paper);font-family:inherit}
.search-form-big button{padding:14px 28px;background:var(--teal);color:#fff;border:2px solid var(--ink);border-radius:999px;font-weight:700;font-size:1.05rem;cursor:pointer;font-family:inherit}
.search-form-big button:hover{background:var(--teal-dk)}

/* ---------- Forms (general) ---------- */
.form-block{
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--rad);
  padding:22px 24px;margin:18px 0;box-shadow:var(--shadow-sm);
}
.form-block label{display:block;font-weight:600;margin-bottom:6px;font-size:14px}
.form-block input,.form-block textarea,.form-block select{
  width:100%;padding:10px 14px;border:2px solid var(--ink);border-radius:var(--rad-sm);
  font-family:inherit;font-size:15px;background:var(--paper);color:var(--ink);margin-bottom:14px;
}

/* Visit-us hint banner shown to users coming from blog or going to it */
.sister-banner{
  background:var(--aubergine);color:#fff;text-align:center;padding:8px 16px;font-size:13.5px;
}
.sister-banner a{color:var(--butter);font-weight:600;text-decoration:underline}
.sister-banner a:hover{color:#fff}

/* Toast / flash messages */
.flash{padding:14px 22px;border-radius:var(--rad-sm);margin:18px 0;font-weight:600;border:2px solid var(--ink)}
.flash.success{background:var(--mint);color:var(--ink)}
.flash.error{background:#ffe5e0;color:var(--ink)}
.flash.info{background:var(--butter-soft);color:var(--ink)}

/* Save/heart button */
.save-btn{display:inline-flex;align-items:center;gap:6px}
.save-btn .heart{font-size:1.05rem;transition:transform var(--t-fast)}
.save-btn.saved .heart{color:var(--coral);transform:scale(1.15)}

/* Difficulty bar (small visual indicator) */
.diff-bar{display:inline-flex;gap:3px}
.diff-bar span{width:8px;height:14px;background:var(--paper-3);border:1px solid var(--ink);border-radius:2px}
.diff-bar.l1 span:nth-child(-n+1),.diff-bar.l2 span:nth-child(-n+2),.diff-bar.l3 span:nth-child(-n+3){background:var(--teal)}

/* ============================================================
   PATCH v6 — fixes for hero layout + filter UI
   ============================================================ */

/* ---------- Hero: 2-column layout with sized mascot art ---------- */
.hero-container{
  max-width:1280px;
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px, 420px);
  gap:48px;
  align-items:center;
  padding:0 24px;
  margin:0 auto;
}
.hero-art{
  position:relative;
  width:100%;
  max-width:420px;
  aspect-ratio:1/1;
  margin:0 auto;
}
.hero-art svg{
  width:100%;
  height:100%;
  display:block;
}
@media (max-width: 880px){
  .hero-container{grid-template-columns:1fr; gap:24px}
  .hero-art{max-width:300px}
}
@media (max-width: 520px){
  .hero-art{max-width:220px}
}

/* Mascot animations (bubbles + sparkles) */
.hero-beaker{transform-origin:180px 175px; animation:beaker-tilt 6s ease-in-out infinite}
@keyframes beaker-tilt{
  0%,100%{transform:rotate(-2deg)}
  50%    {transform:rotate( 2deg)}
}
.m-sparkle{transform-origin:center; animation:sparkle 4s ease-in-out infinite}
.m-sparkle-1{animation-delay:0s}
.m-sparkle-2{animation-delay:1s}
.m-sparkle-3{animation-delay:2s}
.m-sparkle-4{animation-delay:1.5s}
@keyframes sparkle{
  0%,100%{transform:scale(.8); opacity:.6}
  50%    {transform:scale(1.15); opacity:1}
}
@media (prefers-reduced-motion: reduce){
  .hero-beaker, .m-sparkle{animation:none}
}

/* Hero CTAs */
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:28px}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border:2px solid var(--ink);
  padding:11px 22px;
  border-radius:999px;
  font-weight:600;
  text-decoration:none;
  transition:transform var(--t-fast), box-shadow var(--t-fast);
  display:inline-flex; align-items:center; gap:6px;
}
.btn-ghost:hover{
  transform:translate(-1px,-1px);
  box-shadow:3px 3px 0 var(--ink);
  background:var(--paper-2);
}

/* Hero category chips */
.hero-cats .chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px;
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:999px;
  font-size:14px; font-weight:600;
  color:var(--ink); text-decoration:none;
  transition:transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.hero-cats .chip:hover{
  transform:translate(-1px,-1px);
  box-shadow:3px 3px 0 var(--ink);
  background:var(--butter);
}
.hero-cats .chip-icon{font-size:1.05em; line-height:1}

/* ---------- Quick-filter strip (used on home + category pages) ---------- */
.quick-filter{
  background:var(--paper-2);
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  padding:16px 0;
  margin:8px 0 24px;
}
.quick-filter > .container{padding:0 24px; max-width:1280px; margin:0 auto}
.qf-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
}
.qf-label{
  font-weight:700;
  color:var(--ink);
  font-size:14px;
  margin-right:4px;
  white-space:nowrap;
}
.qf-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px;
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:999px;
  font-size:13px; font-weight:600;
  color:var(--ink); text-decoration:none;
  transition:transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
  white-space:nowrap;
}
.qf-chip:hover{
  transform:translate(-1px,-1px);
  box-shadow:2px 2px 0 var(--ink);
  background:var(--butter);
}
.qf-chip.is-active{
  background:var(--teal);
  color:#fff;
  border-color:var(--ink);
}
.qf-chip.is-active::after{
  content:"✕";
  margin-left:4px;
  font-size:.85em;
  opacity:.85;
}

/* ---------- Full filter page (theme/filter.php) ---------- */
.filter-bar{
  background:var(--paper-2);
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  padding:24px;
  /* Use longhand top/bottom margins so `margin: 0 auto` from the
     .container class (the bar has both classes) stays in effect for
     left/right centering. Otherwise the panel renders flush at the
     left edge of the viewport. */
  margin-top:16px;
  margin-bottom:32px;
  max-width:1280px;       /* re-assert in case the bar isn't `.container` */
  position:static;          /* override the sticky version above */
  backdrop-filter:none;
  border-radius:var(--rad);
  box-shadow:4px 4px 0 var(--ink);
}
.filter-bar .filter-row{
  display:grid;
  /* Distribute groups evenly across the bar width — 4/5 columns wide,
     2 columns on tablet, 1 on phone. Avoids the "all bunched left" look
     when there are fewer groups than auto-fit thinks could fit. */
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:24px 28px;
  align-items:start;
}
@media (max-width: 1100px){
  .filter-bar .filter-row{grid-template-columns:repeat(3, minmax(0,1fr))}
}
@media (max-width: 760px){
  .filter-bar .filter-row{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 480px){
  .filter-bar .filter-row{grid-template-columns:1fr}
}
.filter-group{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}
.filter-group .filter-label{
  font-family:'Fraunces', Georgia, serif;
  font-weight:800;
  font-size:13px;
  color:var(--ink);
  letter-spacing:.4px;
  text-transform:uppercase;
}
.filter-group .qf-row{gap:6px}
.filter-group .qf-chip{
  padding:5px 11px;
  font-size:12.5px;
}

/* "Clear all" line on the filter page */
.filter-summary,
.filter-clear-row{
  margin:14px 0 0;
  padding-top:14px;
  border-top:1px dashed var(--ink-mute);
  font-size:13px;
  color:var(--ink-soft);
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.filter-summary a,
.filter-clear-row a{color:var(--teal); font-weight:600}
.filter-clear-row .filter-clear{margin-left:auto}

@media (max-width: 600px){
  .filter-bar{padding:16px}
  .filter-bar .filter-row{grid-template-columns:1fr; gap:14px}
}

/* The category-page inline filter (from category.php) — tighten spacing */
.archive-header + .quick-filter{margin-top:18px}

/* ============================================================
   PATCH v8 — search form, action bar, hide meta toggle
   ============================================================ */

/* ---------- Search page form ---------- */
.search-form-large{
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--paper-2);
  border:2px solid var(--ink);
  border-radius:999px;
  padding:4px 4px 4px 18px;
  max-width:560px;
  box-shadow:3px 3px 0 var(--ink);
  transition:transform var(--t-fast), box-shadow var(--t-fast);
}
.search-form-large:focus-within{
  transform:translate(-1px,-1px);
  box-shadow:5px 5px 0 var(--ink);
}
.search-form-large input[type=search]{
  flex:1; min-width:0;
  border:0; background:transparent; outline:0;
  padding:10px 0;
  font-family:inherit;
  font-size:16px;
  color:var(--ink);
}
.search-form-large input[type=search]::placeholder{color:var(--ink-mute)}
.search-form-large input[type=search]::-webkit-search-cancel-button{
  -webkit-appearance:none; appearance:none;
  height:14px; width:14px;
  background:var(--ink);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 3 L13 13 M13 3 L3 13' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 3 L13 13 M13 3 L3 13' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat;
  cursor:pointer;
}
.search-form-large button{
  background:var(--ink);
  color:var(--paper);
  border:0;
  border-radius:999px;
  padding:10px 22px;
  font-weight:700;
  font-family:inherit;
  font-size:14px;
  cursor:pointer;
  transition:background var(--t-fast);
}
.search-form-large button:hover{background:var(--teal)}
@media (max-width:560px){
  .search-form-large{padding:4px 4px 4px 14px}
  .search-form-large button{padding:8px 16px}
}

/* ---------- Activity action bar (Save / Print / Copy / Free printable) ---------- */
.action-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:18px 0 0;
  align-items:center;
}
.ab-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 18px;
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:999px;
  color:var(--ink);
  font-family:inherit;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  text-decoration:none;
  transition:transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast), color var(--t-fast);
  -webkit-tap-highlight-color:transparent;
}
.ab-btn:hover{
  transform:translate(-1px,-1px);
  box-shadow:3px 3px 0 var(--ink);
  background:var(--butter);
}
.ab-btn:active{
  transform:translate(0,0);
  box-shadow:1px 1px 0 var(--ink);
}
.ab-btn .ab-icon{font-size:1.05em; line-height:1}
.ab-btn.is-active{
  background:var(--coral);
  color:#fff;
  border-color:var(--ink);
}
.ab-btn.is-active:hover{background:var(--coral)}
.ab-btn-primary{
  background:var(--teal);
  color:#fff;
  border-color:var(--ink);
}
.ab-btn-primary:hover{
  background:var(--teal-dk, var(--teal));
  color:#fff;
}
.ab-btn-success{
  background:var(--mint);
  color:var(--ink);
}

/* "Copied!" toast bubble that the JS shows briefly after Copy link */
.ab-btn[data-copied="1"]::after{
  content:"Copied!";
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:var(--ink); color:var(--paper);
  padding:5px 10px; border-radius:8px; font-size:12px; font-weight:600;
  white-space:nowrap;
  animation:ab-fade 1.4s ease-out forwards;
  pointer-events:none;
  z-index:5;
}
@keyframes ab-fade{
  0%   {opacity:0; transform:translateY(4px)}
  20%  {opacity:1; transform:translateY(0)}
  80%  {opacity:1}
  100% {opacity:0; transform:translateY(-2px)}
}
@media print{
  .action-bar{display:none}
}

/* When the byline meta is hidden, tighten the spacing above the action bar */
.activity-meta:empty{display:none}
.activity-meta:empty + .action-bar{margin-top:6px}

/* ============================================================
   PATCH v9 — listing grid alias, card sizing, alignment, action bar fixes
   ============================================================ */

/* Templates use .post-grid + .post-card. CSS already styles .activity-grid
   + .activity-card. Alias them so the grid actually applies and the giant
   placeholder card collapses to a normal 4:3 thumbnail. */
.post-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:28px;
  margin:0 0 36px;
}
.post-card{
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:var(--rad);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:var(--t);
  position:relative;
  box-shadow:var(--shadow-sm);
}
.post-card:hover{transform:translate(-3px,-3px) rotate(-.4deg);box-shadow:var(--shadow)}

/* Cap card images so a single result on the search page can't go full-bleed */
.post-card .card-image{
  display:block;
  aspect-ratio:4/3;
  background:var(--paper-2);
  position:relative;
  overflow:hidden;
  border-bottom:2px solid var(--ink);
  max-height:260px;
}
.post-card .card-image img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .4s ease;
}
.post-card:hover .card-image img{transform:scale(1.04)}

.post-card .card-ph{
  width:100%; height:100%;
  display:grid; place-items:center;
  font-size:2.4rem;
  background:linear-gradient(135deg, var(--butter) 0%, var(--mint) 100%);
  font-family:'Fraunces', Georgia, serif;
  color:var(--ink);
}

.post-card .card-body{
  padding:18px 18px 20px;
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
}
.post-card .card-body h3{
  font-family:'Fraunces', Georgia, serif;
  font-size:1.15rem;
  line-height:1.25;
  margin:0;
  letter-spacing:-.01em;
}
.post-card .card-body h3 a{
  color:var(--ink);
  text-decoration:none;
  background:none;
  border:0;
}
.post-card .card-body h3 a:hover{color:var(--teal)}
.post-card .card-excerpt{
  font-size:14px;
  color:var(--ink-soft);
  margin:0;
  line-height:1.5;
}

/* Single-result rows shouldn't stretch one card to 100% of the grid.
   max-width on the implicit row prevents the "balloon card" effect. */
.post-grid .post-card{ max-width:100% }
.post-grid:has(> .post-card:only-child){
  grid-template-columns:repeat(auto-fill, minmax(280px, 360px));
  justify-content:start;
}

/* Card badges — keep them in the body, not floated over the image */
.post-card .card-badges{
  position:static;
  display:flex; flex-wrap:wrap; gap:6px;
  margin-top:auto;
  padding-top:6px;
}
.post-card .card-badges .badge{
  font-size:11.5px; font-weight:700;
  padding:3px 9px; border-radius:999px;
  background:var(--paper-2);
  border:1.5px solid var(--ink);
  color:var(--ink); display:inline-flex; gap:3px; align-items:center;
}
.post-card .card-badges .b-age{background:var(--butter)}
.post-card .card-badges .b-time{background:var(--mint)}
.post-card .card-badges .b-easy{background:#b8e6c8}
.post-card .card-badges .b-medium{background:#fde68a}
.post-card .card-badges .b-hard{background:#fca5a5}

/* ---------- Activity hero (image cap on the activity page) ---------- */
.activity-hero{
  margin:28px auto;
  max-width:1100px;
  border-radius:var(--rad-lg);
  overflow:hidden;
  border:2px solid var(--ink);
}
.activity-hero img{
  width:100%; height:auto;
  display:block;
  max-height:480px;
  object-fit:cover;
}

/* ---------- Action bar centering & spacing ---------- */
.action-bar{ margin-top:14px }
.activity-meta + .action-bar{ margin-top:8px }
.activity-meta:empty + .action-bar{ margin-top:18px }

/* ---------- Per-category quick filter chips: active state + correct sizing ---------- */
.archive-header + .quick-filter,
.quick-filter{ margin-top:0 }
.quick-filter .qf-chip.is-active{
  background:var(--teal);
  color:#fff;
  border-color:var(--ink);
}
.quick-filter .qf-chip.is-active::after{
  content:"✕";
  margin-left:6px;
  font-size:.85em; opacity:.85;
}

/* ---------- Stop subtle layout drift around the featured-image-less hero ---------- */
.activity-header{ padding-top:8px }
.activity-title{ margin:0 0 6px }
.activity-subtitle{ margin:0 0 14px; color:var(--ink-soft); font-size:1.05rem }

/* "Featured image" sits above the body grid, not inside it.
   When there's NO featured image, the hero block must vanish completely
   instead of leaving a blank gradient. */
.activity-hero:empty{display:none}

/* ============================================================
   PATCH v10 — home CTA band, alignment cleanups
   ============================================================ */

/* Yellow CTA band that replaces the old quick-find chip strip */
.home-cta-band{
  background:var(--butter);
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
  padding:22px 0;
  margin:0 0 36px;
}
.home-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  justify-content:center;
  padding:0 24px;
  max-width:1280px;
  margin:0 auto;
}
.home-cta-row .btn{font-size:15px; padding:12px 26px}
.home-cta-band + .container{margin-top:0}

@media (max-width: 600px){
  .home-cta-band{padding:16px 0}
  .home-cta-row{gap:10px}
  .home-cta-row .btn{flex:1; min-width:140px; text-align:center; justify-content:center}
}

/* The old .archive-icon (test-tube emoji above category H1) is now removed
   from the templates, but be defensive in case any cached pages still have
   it in markup. */
.archive-icon{display:none}

/* Ensure on the activity page the breadcrumb and the title use the same
   max-width container. The earlier .activity-header rule was 1080px; the
   patch bumps it back up to 1280 so it aligns with breadcrumbs / .container. */
.activity-single .breadcrumbs.container,
.activity-single .activity-header.container{
  max-width:1280px;
}

/* Add breathing room on activity-header */
.activity-header{padding-bottom:32px}
.activity-header .post-cat-tags{margin:6px 0 14px}
.activity-title{margin:6px 0 10px; line-height:1.05}
.activity-subtitle{margin:0 0 18px; color:var(--ink-soft); font-size:1.1rem; line-height:1.5}

/* ============================================================
   PATCH v12 — footer logo + sister-sites panel
   ============================================================ */

/* ---------- Footer logo ---------- */
.footer-logo{
  display:block;
  max-width:200px;        /* was unbounded — now caps at a sensible footer size */
  max-height:64px;
  width:auto;
  height:auto;
  margin:0 0 14px;
  object-fit:contain;
}
/* Monochrome white-on-dark version. Logos that ship as full colour can be
   reduced to a paper-coloured silhouette by combining a hard brightness
   pin with an invert. The is-white toggle (admin Layout setting) opts in. */
.footer-logo.is-white{
  filter:brightness(0) invert(1);
  opacity:.95;
}
/* If the logo is already white/SVG, the .is-white toggle should NOT be on
   (the filter would invert it back to black). For coloured raster logos
   (PNG with full colour), turning .is-white on gives a clean silhouette. */

/* ---------- Sister sites panel (above subscribe strip) ---------- */
.sister-sites{
  background:var(--paper-2);
  border-top:2px solid var(--ink);
  padding:36px 0;
}
.ss-heading{
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(1.4rem, 2.2vw, 1.8rem);
  margin:0 0 22px;
  text-align:center;
  letter-spacing:-.01em;
}
.ss-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:14px;
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}
.ss-card-link{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px 18px;
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:14px;
  text-decoration:none;
  color:var(--ink);
  transition:transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.ss-card-link:hover{
  transform:translate(-2px,-2px);
  box-shadow:4px 4px 0 var(--ink);
  background:var(--butter);
}
.ss-icon{
  flex-shrink:0;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  background:var(--paper-2);
  border:1.5px solid var(--ink);
  border-radius:10px;
  font-size:1.3rem;
  line-height:1;
}
.ss-body{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.ss-body strong{
  font-family:'Fraunces', Georgia, serif;
  font-size:1.05rem;
  letter-spacing:-.01em;
  color:var(--ink);
}
.ss-desc{
  font-size:12.5px;
  color:var(--ink-soft);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ss-arrow{
  flex-shrink:0;
  font-size:1.2rem;
  color:var(--ink-mute);
  transition:transform var(--t-fast), color var(--t-fast);
}
.ss-card-link:hover .ss-arrow{
  transform:translateX(3px);
  color:var(--ink);
}
@media (max-width:600px){
  .ss-grid{padding:0 16px; gap:10px}
  .ss-card-link{padding:12px 14px; gap:10px}
  .ss-icon{width:36px; height:36px; font-size:1.15rem}
}
@media print{ .sister-sites{display:none} }

/* ============================================================
   PATCH v15 — subscribe inline feedback notice
   ============================================================ */
.sub-notice{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px 20px;
  border-radius:14px;
  border:2px solid var(--ink);
  background:var(--paper);
  box-shadow:3px 3px 0 var(--ink);
  /* Always use ink-on-paper — never inherit parent's inverted text color */
  color:var(--ink);
  font-family:'Work Sans','Helvetica Neue',Arial,sans-serif;
}
.sub-notice-ok{
  background:#edfaf5;
  border-color:#047857;
  box-shadow:3px 3px 0 #047857;
  color:var(--ink);
}
.sub-notice-err{
  background:#fff1f2;
  border-color:var(--coral,#ee6c6c);
  box-shadow:3px 3px 0 var(--coral,#ee6c6c);
  color:var(--ink);
}
.sub-notice-icon{
  font-size:1.8rem;
  line-height:1;
  flex-shrink:0;
  margin-top:2px;
  /* Prevent emoji being washed out on teal backgrounds */
  filter:none;
}
.sub-notice strong{
  display:block;
  font-family:'Fraunces',Georgia,serif;
  font-size:1.05rem;
  font-weight:700;
  margin-bottom:4px;
  color:var(--ink);
}
.sub-notice p{
  margin:0 0 4px;
  font-size:14px;
  line-height:1.55;
  color:var(--ink);
}
.sub-notice small{
  font-size:12.5px;
  color:#2d6a4f;   /* dark green — readable on the light green bg */
  display:block;
  margin-top:4px;
}
.sub-notice-err small{ color:var(--ink-soft,#4a4438); }
.sub-notice em{ font-style:normal; font-weight:600; color:inherit; }

/* Footer subscribe strip — white card that lifts out of the teal bg */
.subscribe-strip .sub-notice{
  max-width:540px;
  margin:0 auto;
  background:#fff;
  border-color:#047857;
  box-shadow:3px 3px 0 #047857;
  color:var(--ink);
}
.subscribe-strip .sub-notice strong,
.subscribe-strip .sub-notice p,
.subscribe-strip .sub-notice small{ color:var(--ink); }
.subscribe-strip .sub-notice-err{
  border-color:var(--coral,#ee6c6c);
  box-shadow:3px 3px 0 var(--coral,#ee6c6c);
}

/* Sidebar widget notice — compact */
.widget .sub-notice{ padding:14px 16px; }
.widget .sub-notice-icon{ font-size:1.3rem; }
.widget .sub-notice strong{ font-size:1rem; }

/* ============================================================
   PATCH v20 — sidebar widgets
   ============================================================ */

/* Recent activities / Popular this week — image+title rows */
.widget-thumbs .thumb-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.widget-thumbs .thumb-row{
  display:grid;grid-template-columns:60px 1fr;gap:10px;align-items:center;
  text-decoration:none;color:var(--ink);transition:opacity .15s;
}
.widget-thumbs .thumb-row:hover{opacity:.85}
.widget-thumbs .thumb-row img,
.widget-thumbs .thumb-row .thumb-ph{
  width:60px;height:60px;border-radius:10px;object-fit:cover;
  border:1.5px solid var(--ink);background:var(--paper-2);
  display:grid;place-items:center;font-size:1.4rem;
}
.widget-thumbs .thumb-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.widget-thumbs .thumb-meta strong{
  font-family:'Fraunces',Georgia,serif;font-size:.95rem;font-weight:700;line-height:1.25;
  color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.widget-thumbs .thumb-row:hover strong{color:var(--teal-dk)}
.widget-thumbs .thumb-sub{font-size:11.5px;color:var(--ink-mute)}

/* Browse by age — colourful chips */
.widget-age-jump .age-chips{display:flex;flex-wrap:wrap;gap:6px}
.widget-age-jump .age-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 12px;background:var(--paper-2);
  border:1.5px solid var(--ink);border-radius:99px;
  font-size:13px;font-weight:600;color:var(--ink);text-decoration:none;
  transition:transform .12s,box-shadow .12s,background .12s;
}
.widget-age-jump .age-chip:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink);background:var(--butter)}

/* Tag cloud — varying sizes */
.widget-tag-cloud .tag-cloud{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.widget-tag-cloud .tag-bubble{
  display:inline-block;padding:3px 9px;
  background:var(--paper-2);border:1.5px solid var(--paper-3);border-radius:99px;
  color:var(--ink-soft);text-decoration:none;font-weight:500;
  transition:background .12s,color .12s,border-color .12s;
}
.widget-tag-cloud .tag-bubble:hover{background:var(--butter);color:var(--ink);border-color:var(--ink)}
.widget-tag-cloud .tw-1{font-size:11.5px}
.widget-tag-cloud .tw-2{font-size:12.5px}
.widget-tag-cloud .tw-3{font-size:13.5px;color:var(--ink)}
.widget-tag-cloud .tw-4{font-size:14.5px;color:var(--ink);font-weight:600}
.widget-tag-cloud .tw-5{font-size:15.5px;color:var(--teal-dk);font-weight:700}

/* Free printable promo */
.widget-printable{background:linear-gradient(135deg,var(--mint) 0%,var(--paper) 100%)}
.widget-printable h3::before{content:"📄"}
.widget-printable p{font-size:14px;color:var(--ink-soft);margin:0 0 12px;line-height:1.5}
.widget-printable .btn-block{display:block;width:100%;text-align:center}

/* Custom HTML widget — admin-controlled, render whatever they put in */
.widget-custom .widget-custom-body{font-size:14.5px;line-height:1.55;color:var(--ink-soft)}
.widget-custom .widget-custom-body p:last-child{margin-bottom:0}
.widget-custom .widget-custom-body img{max-width:100%;height:auto;border-radius:10px;border:1.5px solid var(--ink);margin:8px 0}
.widget-custom .widget-custom-body a{color:var(--teal-dk);font-weight:600}

/* ============================================================
   PATCH v21 — additional widget types (text/image/search/social)
   ============================================================ */

/* Heading + text block widget */
.widget-text p{font-size:14.5px;line-height:1.6;color:var(--ink-soft);margin:0}

/* Image widget */
.widget-image img{display:block;width:100%;height:auto;border-radius:10px;border:1.5px solid var(--ink)}
.widget-image a{display:block;line-height:0}
.widget-image a:hover img{opacity:.95}

/* Search widget */
.widget-search .widget-search-form{display:flex;gap:6px}
.widget-search input[type=search]{
  flex:1;min-width:0;padding:8px 12px;
  border:2px solid var(--ink);border-radius:var(--rad-sm);
  font-family:inherit;font-size:14px;background:var(--paper);
}
.widget-search input[type=search]:focus{outline:none;background:#fff}
.widget-search button{
  padding:8px 14px;background:var(--ink);color:var(--paper);
  border:2px solid var(--ink);border-radius:var(--rad-sm);
  font-family:inherit;font-weight:600;font-size:13.5px;cursor:pointer;
  transition:transform .12s,box-shadow .12s;
}
.widget-search button:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink)}

/* Social links — pill style */
.widget-social .social-pills{display:flex;flex-wrap:wrap;gap:6px}
.widget-social .social-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 11px;background:var(--paper-2);
  border:1.5px solid var(--ink);border-radius:99px;
  font-size:13px;font-weight:600;color:var(--ink);text-decoration:none;
  transition:transform .12s,box-shadow .12s,background .12s;
}
.widget-social .social-pill:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink);background:var(--butter)}

/* Categories list — count badge */
.widget-categories .widget-count{
  display:inline-block;float:right;
  background:var(--paper-2);color:var(--ink-mute);
  font-size:11.5px;font-weight:600;
  padding:1px 8px;border-radius:99px;border:1px solid var(--paper-3);
  margin-left:6px;
}
