/* ============================================================
   Little Threads — Journal & article styling
   (loads after styles.css; reuses the same tokens)
   ============================================================ */

/* slim top bar for journal/article pages */
.jnav{
  position:sticky; top:0; z-index:40;
  background:rgba(244,236,225,.9); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.jnav__row{ display:flex; align-items:center; justify-content:space-between; height:72px; gap:20px; }
.jnav__links{ display:flex; align-items:center; gap:28px; }
.jnav__links a{ font-size:14px; font-weight:500; color:var(--ink-soft); }
.jnav__links a:hover{ color:var(--ink); }
.jnav .btn{ padding:10px 20px; font-size:13.5px; }
.jnav__right{ display:flex; align-items:center; gap:16px; }

/* bilingual content toggle */
.jt-hide{ display:none !important; }
@media (max-width:640px){
  .jnav__links{ display:none; }
}

/* ---- breadcrumb ---- */
.crumb{ font-size:13px; color:var(--muted); display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.crumb a{ color:var(--muted); }
.crumb a:hover{ color:var(--terra); }
.crumb span{ color:var(--faint); }

/* ============================================================
   Journal index
   ============================================================ */
.jhero{ background:var(--blush); border-bottom:1px solid var(--line-soft); }
.jhero__in{ max-width:var(--maxw); margin:0 auto; padding:clamp(48px,7vw,88px) var(--pad) clamp(40px,6vw,64px); }
.jhero h1{ font-family:var(--display); font-weight:500; font-size:clamp(40px,6vw,76px); line-height:1.02; letter-spacing:-.01em; margin-top:16px; }
.jhero p{ font-size:clamp(17px,1.8vw,20px); color:var(--ink-soft); max-width:54ch; margin-top:18px; }

.jlist{ max-width:var(--maxw); margin:0 auto; padding:clamp(48px,6vw,72px) var(--pad) clamp(64px,9vw,110px); }

/* ---- category filter ---- */
.jfilter{
  display:flex; align-items:center; flex-wrap:wrap; gap:10px;
  padding-bottom:clamp(32px,4vw,48px); margin-bottom:clamp(36px,4vw,52px);
  border-bottom:1px solid var(--line);
}
.jfilter__lab{
  font-size:11.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-right:6px;
}
.fpill{
  font-family:var(--body); font-size:13.5px; font-weight:600; letter-spacing:.01em;
  color:var(--ink-soft); background:var(--paper-2); border:1px solid var(--line);
  border-radius:999px; padding:9px 17px; line-height:1; transition:.18s;
  display:inline-flex; align-items:center; gap:8px;
}
.fpill:hover{ border-color:var(--faint); color:var(--ink); }
.fpill .n{ font-size:11.5px; color:var(--faint); font-weight:600; }
.fpill[aria-pressed="true"]{ background:var(--terra); border-color:var(--terra); color:#fdf7ef; }
.fpill[aria-pressed="true"] .n{ color:rgba(255,255,255,.7); }
.is-hidden{ display:none !important; }
.jempty{ padding:40px 0 20px; color:var(--muted); font-size:16px; }

/* featured (first) post */
.jfeat{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,56px); align-items:center;
  padding-bottom:clamp(40px,5vw,60px); margin-bottom:clamp(40px,5vw,60px);
  border-bottom:1px solid var(--line);
}
.jfeat image-slot{ width:100%; aspect-ratio:4/3; box-shadow:var(--shadow); }
.jfeat__tag{ display:flex; gap:10px; align-items:center; margin-bottom:18px; }
.jfeat h2{ font-family:var(--display); font-weight:500; font-size:clamp(30px,3.6vw,46px); line-height:1.05; letter-spacing:-.01em; }
.jfeat h2 a:hover{ color:var(--terra-deep); }
.jfeat p{ color:var(--ink-soft); margin-top:14px; font-size:17px; max-width:50ch; }
.jfeat .more{ margin-top:22px; }

.jgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,34px); }
.jcard{ display:flex; flex-direction:column; }
.jcard image-slot{ width:100%; aspect-ratio:3/2; border-radius:14px; box-shadow:var(--shadow-sm); }
.jcard__tag{ margin:18px 0 10px; }
.jcard h3{ font-family:var(--display); font-weight:600; font-size:24px; line-height:1.12; }
.jcard h3 a:hover{ color:var(--terra-deep); }
.jcard p{ font-size:14.5px; color:var(--muted); margin-top:9px; }
.jcard .meta{ margin-top:14px; font-size:12.5px; color:var(--faint); letter-spacing:.02em; }

.chip{
  display:inline-block; font-size:11.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--terra-deep); background:rgba(181,101,74,.10); padding:5px 11px; border-radius:999px;
}
.chip--ghost{ color:var(--muted); background:transparent; border:1px solid var(--line); }
.readmore{
  font-size:14px; font-weight:600; color:var(--terra-deep); display:inline-flex; align-items:center; gap:7px;
}
.readmore svg{ width:15px; height:15px; transition:transform .2s; }
.readmore:hover svg{ transform:translateX(3px); }

/* ============================================================
   Article page
   ============================================================ */
.artwrap{ max-width:760px; margin:0 auto; padding:0 var(--pad); }
.artwrap--wide{ max-width:1000px; }

.arthead{ padding:clamp(34px,5vw,56px) 0 clamp(24px,3vw,34px); }
.arthead .crumb{ margin-bottom:26px; }
.arthead .chip{ margin-bottom:20px; }
.arthead h1{
  font-family:var(--display); font-weight:500; font-size:clamp(34px,5vw,58px);
  line-height:1.04; letter-spacing:-.012em; text-wrap:balance;
}
.artmeta{ display:flex; align-items:center; gap:16px; margin-top:22px; font-size:13.5px; color:var(--muted); }
.artmeta .dot{ width:4px; height:4px; border-radius:50%; background:var(--faint); }
.artmeta .by b{ color:var(--ink-soft); font-weight:600; }

.artlede{ font-family:var(--display); font-style:italic; font-size:clamp(20px,2.4vw,26px); line-height:1.4; color:var(--ink-soft); margin:6px 0 0; }

.artfig{ margin:clamp(28px,4vw,40px) 0; }
.artfig image-slot{ width:100%; aspect-ratio:16/10; border-radius:16px; box-shadow:var(--shadow); }
.artfig figcaption{ font-size:12.5px; color:var(--faint); margin-top:10px; text-align:center; }

/* prose */
.prose{ font-size:17.5px; line-height:1.72; color:var(--ink); }
.prose > p{ margin:0 0 1.25em; }
.prose h2{
  font-family:var(--display); font-weight:600; font-size:clamp(26px,3vw,34px); line-height:1.12;
  letter-spacing:-.01em; margin:1.8em 0 .55em;
}
.prose h3{ font-family:var(--display); font-weight:600; font-size:22px; margin:1.5em 0 .4em; }
.prose strong{ font-weight:600; color:var(--ink); }
.prose a{ color:var(--terra-deep); text-decoration:underline; text-decoration-color:var(--terra-soft); text-underline-offset:3px; }
.prose a:hover{ text-decoration-color:var(--terra-deep); }
.prose ul, .prose ol{ margin:0 0 1.25em; padding-left:1.3em; }
.prose li{ margin:.4em 0; }
.prose li::marker{ color:var(--terra); }

.pullquote{
  font-family:var(--display); font-style:italic; font-size:clamp(22px,2.8vw,30px); line-height:1.32;
  color:var(--ink); border-left:3px solid var(--terra); padding:6px 0 6px 26px; margin:1.6em 0;
}

/* in-article CTA */
.artcta{
  margin:2.4em 0; background:var(--ink); color:var(--paper); border-radius:20px;
  padding:clamp(28px,4vw,40px); display:grid; grid-template-columns:1fr auto; gap:24px; align-items:center;
}
.artcta h3{ font-family:var(--display); font-weight:600; font-size:clamp(24px,3vw,30px); color:var(--paper); line-height:1.1; }
.artcta p{ color:#d8cab8; margin-top:8px; font-size:15.5px; max-width:46ch; }
.artcta .btn{ white-space:nowrap; }

/* FAQ */
.faq{ margin:2.4em 0 1em; }
.faq h2{ font-family:var(--display); font-weight:600; font-size:clamp(26px,3vw,34px); margin-bottom:14px; }
.faq details{ border-top:1px solid var(--line); padding:6px 0; }
.faq details:last-child{ border-bottom:1px solid var(--line); }
.faq summary{
  list-style:none; cursor:pointer; padding:16px 36px 16px 0; position:relative;
  font-family:var(--body); font-weight:600; font-size:17px; color:var(--ink);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:'+'; position:absolute; right:4px; top:50%; transform:translateY(-50%);
  font-size:24px; font-weight:400; color:var(--terra); transition:transform .2s;
}
.faq details[open] summary::after{ content:'–'; }
.faq details p{ margin:0 0 16px; color:var(--ink-soft); font-size:16px; line-height:1.65; }

/* tags + share row */
.artfoot{ margin:2.6em 0 0; padding-top:24px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.artfoot .lab{ font-size:13px; color:var(--muted); margin-right:4px; }

/* related */
.related{ background:var(--blush); border-top:1px solid var(--line-soft); margin-top:clamp(48px,7vw,84px); }
.related__in{ max-width:var(--maxw); margin:0 auto; padding:clamp(48px,6vw,72px) var(--pad); }
.related h2{ font-family:var(--display); font-weight:500; font-size:clamp(26px,3.4vw,40px); margin-bottom:30px; }

@media (max-width:880px){
  .jfeat{ grid-template-columns:1fr; }
  .jfeat image-slot{ order:-1; }
  .jgrid{ grid-template-columns:1fr 1fr; }
  .artcta{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  .jnav__links{ display:none; }
  .jgrid{ grid-template-columns:1fr; }
  .prose{ font-size:17px; }
}
