/* Foxlister Learn — supplements assets/site.css (tokens, nav, .btn, .wrap, base) */
:root{ --primary-2:#ffbc00; --radius-md:12px; --text:#334155; --bg-card:#fff; }
.wrap-narrow{max-width:720px;margin:0 auto;padding:0 1.5rem}
/* clear the fixed site nav with generous breathing room (Learn heroes are short) */
.learn-hero{padding-top:9rem}
.article-head{padding-top:8rem}
@media(max-width:560px){
  .brand{font-size:1.02rem}
  .learn-hero{padding-top:7rem}
  .article-head{padding-top:6.5rem}
}

/* ===== HUB (index can use cards — that's normal for a blog index) ===== */
.learn-hero{text-align:center;padding:8.5rem 0 1.5rem}
.learn-hero .eyebrow{display:inline-block;padding:.4rem .9rem;border-radius:100px;background:var(--primary-glow);color:var(--primary);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.2rem}
.learn-hero h1{font-size:clamp(2.2rem,5vw,3.3rem);font-weight:800;letter-spacing:-.03em;line-height:1.08;color:var(--ink);margin-bottom:1rem}
.learn-hero h1 .grad{background:linear-gradient(120deg,var(--primary),var(--primary-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.learn-hero p{max-width:640px;margin:0 auto;font-size:1.15rem;color:var(--muted)}
.tagbar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:2rem 0 2.5rem}
.tagbar button{border:1px solid var(--border);background:#fff;color:var(--ink);padding:.5rem 1rem;border-radius:100px;font-family:inherit;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .15s var(--ease)}
.tagbar button:hover{border-color:var(--primary);color:var(--primary)}
.tagbar button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s var(--ease);text-decoration:none}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cbd5e1}
.card .thumb{position:relative;aspect-ratio:16/9;padding:1.3rem;display:flex;align-items:flex-end;overflow:hidden;background:linear-gradient(135deg,var(--c1,#0f172a),var(--c2,#1e293b))}
.card .thumb::after{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(130% 120% at 88% 6%,rgba(255,255,255,.22),transparent 55%)}
.card .thumb .badge{position:absolute;top:.9rem;left:.9rem;z-index:2;background:rgba(255,255,255,.95);color:var(--ink);font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:.25rem .55rem;border-radius:100px}
.card .thumb .wm{position:absolute;right:-14px;bottom:-14px;width:104px;height:104px;object-fit:contain;opacity:.17;z-index:0;filter:brightness(0) invert(1)}
.card .thumb .tt{position:relative;z-index:1;color:#fff;font-weight:800;font-size:1.2rem;line-height:1.24;letter-spacing:-.01em;text-shadow:0 1px 14px rgba(0,0,0,.22);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card .body{padding:1.1rem 1.25rem 1.35rem;display:flex;flex-direction:column;flex:1}
.card .meta{font-size:.74rem;color:var(--muted);font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.03em}
.card .meta .snd{width:12px;height:12px;display:inline-block;vertical-align:-2px;margin:0 1px;color:var(--primary)}
.card .meta strong{color:var(--ink);font-weight:800}
/* inline play + speed overlay on the thumbnail */
.card .thumb .thumb-play{position:absolute;top:.7rem;right:.7rem;z-index:3;display:flex;gap:.35rem}
.card .thumb-play button{display:inline-flex;align-items:center;gap:.28rem;background:rgba(255,255,255,.95);color:var(--ink);border:0;border-radius:100px;padding:.32rem .6rem;font-family:inherit;font-weight:800;font-size:.7rem;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.18);transition:background .15s}
.card .thumb-play button:hover{background:#fff}
.card .thumb-play .lplay.playing{background:var(--ink);color:#fff}
.card .thumb-play svg{width:10px;height:10px;flex:0 0 auto}
.card p{font-size:.92rem;color:var(--muted);flex:1;margin:0}
.card .more{margin-top:.9rem;font-weight:700;font-size:.85rem;color:var(--primary)}
.empty-note{text-align:center;color:var(--muted);padding:3rem;grid-column:1/-1}

/* ===== ARTICLE — clean, written-blog feel (minimal chrome) ===== */
.article-head{padding:8rem 0 .5rem}
.crumbs{font-size:.82rem;color:var(--muted);margin-bottom:1rem}
.crumbs a{color:var(--muted);font-weight:600}.crumbs a:hover{color:var(--primary)}
.article-head h1{font-size:clamp(1.9rem,4.4vw,2.7rem);font-weight:800;letter-spacing:-.02em;line-height:1.14;color:var(--ink);margin-bottom:.9rem}
.byline{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;color:var(--muted);font-size:.92rem;border-bottom:1px solid var(--border);padding-bottom:1.2rem;margin-bottom:.4rem}
.byline .sep{opacity:.5}
.share-btn{margin-left:auto;display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--border);color:var(--ink);font-family:inherit;font-weight:700;font-size:.82rem;padding:.42rem .85rem;border-radius:100px;cursor:pointer;transition:all .15s var(--ease)}
.share-btn:hover{border-color:var(--primary);color:var(--primary)}
.share-btn svg{width:15px;height:15px}

.listen{display:flex;align-items:center;gap:.7rem;margin:1.6rem 0;color:var(--muted)}
.listen .ic{flex:0 0 auto;width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center}
.listen .ic svg{width:18px;height:18px}
.listen .lbl{flex:0 0 auto;white-space:nowrap}
.listen audio{height:40px;flex:1 1 auto;min-width:150px;max-width:360px}
.listen .speed{flex:0 0 auto;background:#fff;border:1px solid var(--border);color:var(--ink);font-family:inherit;font-weight:700;font-size:.8rem;padding:.36rem .55rem;border-radius:7px;cursor:pointer;line-height:1}
.listen .speed:hover{border-color:var(--primary);color:var(--primary)}
@media(max-width:560px){.listen{flex-wrap:wrap}.listen .lbl{flex:1 1 auto}.listen audio{flex:1 1 100%;max-width:none;order:3}.listen .speed{order:2}}

.article-body{font-size:1.12rem;color:var(--text);line-height:1.8}
.article-body>p{margin:1.25rem 0}
.article-body>p:first-of-type{font-size:1.2rem;color:var(--ink)}
.article-body h2{font-size:1.5rem;font-weight:800;color:var(--ink);letter-spacing:-.01em;margin:2.6rem 0 .8rem;scroll-margin-top:90px}
.article-body h3{font-size:1.18rem;font-weight:800;color:var(--ink);margin:1.9rem 0 .5rem}
.article-body ul,.article-body ol{margin:1rem 0 1rem 1.4rem}
.article-body li{margin:.55rem 0}
.article-body strong{color:var(--ink)}
.article-body a{font-weight:600;color:var(--primary);text-decoration:underline;text-decoration-color:var(--primary-glow);text-underline-offset:2px}
.article-body blockquote{border-left:3px solid var(--primary);padding:.2rem 0 .2rem 1.3rem;margin:1.8rem 0;color:var(--ink);font-size:1.22rem;font-style:italic;line-height:1.6}
.article-body hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}

/* clips read as part of the article */
.clip-gallery{display:flex;gap:1rem;overflow-x:auto;padding:.5rem 0 1.2rem;margin:1.5rem 0;-webkit-overflow-scrolling:touch}
.clip{flex:0 0 auto;width:170px}
.clip video{width:170px;aspect-ratio:9/16;object-fit:cover;border-radius:12px;background:#000;border:1px solid var(--border);display:block}
.clip .cap{margin-top:.5rem}
.clip .cap b{display:block;font-size:.95rem;color:var(--ink);line-height:1.1}
.clip .cap span{font-size:.76rem;color:var(--muted)}

/* simple inline CTA — a sign-off line, not a banner card */
.cta-inline{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.6rem 0;margin:2.6rem 0}
.cta-inline p{margin:0 0 1rem;font-size:1.12rem;color:var(--ink)}
.cta-inline .btn{height:auto;padding:.8rem 1.6rem;background:var(--primary);color:#fff}
.cta-inline .btn:hover{background:var(--primary-dark)}
.cta-inline small{display:block;margin-top:.7rem;color:var(--muted);font-size:.85rem}

.related{margin:2.6rem 0}
.related h3{font-size:1.05rem;font-weight:800;color:var(--ink);margin-bottom:.6rem}
.related ul{list-style:none;margin:0;padding:0}
.related li{margin:.4rem 0}
.related a{color:var(--primary);font-weight:600}

footer.lfoot{border-top:1px solid var(--border);padding:2.5rem 0;margin-top:2rem;text-align:center;color:var(--muted);font-size:.85rem}
footer.lfoot a{color:var(--muted);text-decoration:none}footer.lfoot a:hover{color:var(--primary)}
