/* ==========================================================================
   GUARIDA VIAJERA — Estilos de artículos y categorías
   Lectura cómoda sobre cream. Mobile-first.
   ========================================================================== */

/* ---- Breadcrumbs ---- */
.crumbs{
  margin-top:90px;padding:18px 0 0;
  font-family:var(--f-mono);font-size:.75rem;
  color:var(--text-3);letter-spacing:.04em;
}
.crumbs ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.crumbs li:not(:last-child)::after{content:'/';margin-left:6px;color:var(--text-3)}
.crumbs a{color:var(--text-3);transition:color var(--t-fast)}
.crumbs a:hover{color:var(--moss)}
.crumbs li:last-child{color:var(--moss-deep);font-weight:600}

/* ---- Article header ---- */
.art-hero{padding:48px 0 24px;position:relative}
.art-cat{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--bg-moss);color:var(--moss-deep);
  border:1px solid var(--moss-soft);
  font-family:var(--f-mono);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  margin-bottom:18px;
}
.art-cat.amber{background:var(--bg-warm);color:var(--amber-text);border-color:rgba(240,180,25,.4)}
.art-cat.sky{background:var(--bg-sky);color:#1A6685;border-color:rgba(63,168,201,.45)}
.art-cat.coral{background:var(--bg-coral);color:#A03D1F;border-color:rgba(218,106,71,.4)}
.art-cat.lav{background:#EDE2F4;color:#5A3870;border-color:rgba(123,78,145,.35)}

/* ---- Color por categoría (body class) ---- */
body.cat-camping  { --cat-color:var(--moss);  --cat-deep:var(--moss-deep); --cat-soft:var(--bg-moss);  --cat-line:var(--moss-soft);          --cat-glow:rgba(58,136,97,.16) }
body.cat-bushcraft{ --cat-color:var(--amber); --cat-deep:var(--amber-text);--cat-soft:var(--bg-warm);  --cat-line:rgba(240,180,25,.4);       --cat-glow:rgba(242,201,76,.22) }
body.cat-camper   { --cat-color:var(--sky);   --cat-deep:#1A6685;          --cat-soft:var(--bg-sky);   --cat-line:rgba(63,168,201,.45);      --cat-glow:rgba(63,168,201,.20) }
body.cat-rutas    { --cat-color:var(--coral); --cat-deep:#A03D1F;          --cat-soft:var(--bg-coral); --cat-line:rgba(218,106,71,.4);       --cat-glow:rgba(218,106,71,.18) }
body.cat-gear     { --cat-color:var(--lav);   --cat-deep:#5A3870;          --cat-soft:#EDE2F4;         --cat-line:rgba(123,78,145,.35);      --cat-glow:rgba(123,78,145,.16) }

body[class*="cat-"] .cat-hero{
  background:
    radial-gradient(ellipse 80% 60% at 30% 0%,var(--cat-glow) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 100%,var(--cat-glow) 0%,transparent 70%);
}
body[class*="cat-"] .cat-pillar-card{
  border-color:var(--cat-line);
  background:linear-gradient(135deg,var(--bg-2) 0%,var(--cat-soft) 100%);
}
body[class*="cat-"] .cat-pillar-card::before{
  color:var(--cat-color);
}
body[class*="cat-"] .prose h2::before{
  background:var(--cat-color);
}
body[class*="cat-"] .crumbs li:last-child{
  color:var(--cat-deep);font-weight:700;
}
body[class*="cat-"] .tldr{
  background:linear-gradient(135deg,var(--cat-soft) 0%,var(--bg-warm) 100%);
  border-color:var(--cat-line);
}
body[class*="cat-"] .tldr h4{
  color:var(--cat-deep);
}
body[class*="cat-"] .toc h5{
  color:var(--cat-deep);
}
body[class*="cat-"] .related{
  background:linear-gradient(180deg,var(--bg-2) 0%,var(--cat-soft) 100%);
}
/* Acento en CTA del cat-pillar-card hereda color */
body[class*="cat-"] .cat-pillar-card .btn-primary{
  box-shadow:0 6px 18px var(--cat-glow),inset 0 1px 0 rgba(255,255,255,.5);
}
.art-hero h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:18px;letter-spacing:-.03em;color:var(--moss-deep)}
.art-hero .lead{font-size:1.1875rem;color:var(--text-2);margin-bottom:24px}
.art-meta{
  display:flex;flex-wrap:wrap;gap:20px;align-items:center;
  font-family:var(--f-mono);font-size:.8125rem;color:var(--text-3);
  padding-top:18px;border-top:1px solid var(--line);
}
.art-meta span{display:inline-flex;align-items:center;gap:6px}
.art-meta svg{width:14px;height:14px}

/* ---- Featured image / cover ---- */
.art-cover{
  margin:32px 0 48px;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);
  position:relative;aspect-ratio:21/9;
  background:linear-gradient(135deg,var(--sky-soft) 0%,var(--moss-soft) 50%,var(--sun) 100%);
  box-shadow:var(--shadow);
}
.art-cover img{width:100%;height:100%;object-fit:cover;display:block}
.art-cover .illu{color:rgba(31,78,54,.4)}
@media(max-width:640px){.art-cover{aspect-ratio:4/3}}

/* ---- Article body / prose ---- */
.prose{
  font-family:var(--f-body);font-size:1.0625rem;line-height:1.75;
  color:var(--text);
  max-width:760px;margin:0 auto;
}
.prose > * + *{margin-top:1.4em}
.prose h2{
  font-size:1.875rem;margin-top:2.4em;margin-bottom:.6em;
  letter-spacing:-.02em;color:var(--moss-deep);
  scroll-margin-top:100px;
}
.prose h2::before{
  content:'';display:inline-block;width:6px;height:24px;border-radius:3px;
  background:var(--amber);margin-right:14px;vertical-align:-3px;
}
.prose h3{font-size:1.375rem;margin-top:2em;margin-bottom:.5em;color:var(--moss-deep)}
.prose p{color:var(--text-2);font-size:1.0625rem}
.prose strong{color:var(--moss-deep);font-weight:600}
.prose a{color:var(--moss);text-decoration:underline;text-decoration-color:var(--moss-soft);text-underline-offset:3px;transition:text-decoration-color var(--t-fast),color var(--t-fast)}
.prose a:hover{text-decoration-color:var(--moss);color:var(--moss-deep)}
.prose ul,.prose ol{padding-left:1.4em;color:var(--text-2)}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose li{margin-bottom:.4em;line-height:1.7}
.prose li::marker{color:var(--amber);font-weight:700}
.prose blockquote{
  border-left:4px solid var(--amber);padding:14px 22px;
  background:var(--bg-warm);border-radius:0 var(--r) var(--r) 0;
  font-style:italic;color:var(--text);
  margin-block:1.6em;
}
.prose code{
  font-family:var(--f-mono);font-size:.9em;
  background:var(--bg-3);padding:2px 7px;border-radius:5px;
  color:var(--moss-deep);border:1px solid var(--line);font-weight:600;
}
.prose pre{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);padding:16px;overflow-x:auto}
.prose pre code{background:none;border:0;padding:0}
.prose hr{border:0;height:1px;background:var(--line);margin:2.4em 0}
.prose img{border-radius:var(--r);border:1px solid var(--line);margin:1.4em 0}

/* ---- Callout / TLDR ---- */
.tldr{
  margin:0 0 32px;padding:22px 24px;
  background:linear-gradient(135deg,var(--bg-warm) 0%,var(--bg-coral) 100%);
  border:1px solid rgba(232,148,31,.3);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
}
.tldr h4{
  font-family:var(--f-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--amber-text);margin-bottom:8px;font-weight:700;
}
.tldr p{margin:0;font-size:1rem;color:var(--text)}
.tldr p strong{color:var(--moss-deep)}

/* ---- Tables ---- */
.prose table{
  width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.9375rem;
  background:var(--bg-2);border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);
}
.prose th,.prose td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}
.prose th{font-family:var(--f-mono);font-size:.8125rem;letter-spacing:.04em;text-transform:uppercase;color:var(--moss-deep);background:var(--bg-moss);font-weight:700}
.prose td{color:var(--text-2)}
.prose tr:hover td{background:var(--bg-warm)}
.prose tr:last-child td{border-bottom:0}

/* ---- Comparativa rows (product-card style) ---- */
.compare{
  display:grid;grid-template-columns:1fr;gap:14px;
  margin:1.8em 0;
}
.cmp-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:18px;align-items:center;
  padding:18px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
  box-shadow:var(--shadow-sm);
}
.cmp-row:hover{transform:translateX(4px);border-color:var(--moss-soft);box-shadow:var(--shadow)}
.cmp-row .rk{
  font-family:var(--f-display);font-size:1.5rem;font-weight:700;
  width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
  background:var(--bg-moss);color:var(--moss-deep);border:1px solid var(--moss-soft);
}
.cmp-row.gold .rk{background:linear-gradient(135deg,var(--sun) 0%,var(--amber) 100%);color:var(--moss-deep);border:0}
.cmp-row .info h4{font-size:1.125rem;margin-bottom:4px;color:var(--moss-deep)}
.cmp-row .info p{font-size:.875rem;color:var(--text-2);margin:0}
.cmp-row .price{font-family:var(--f-mono);font-size:1rem;color:var(--amber-text);text-align:right;white-space:nowrap;font-weight:700}
@media(max-width:640px){
  .cmp-row{grid-template-columns:60px 1fr;gap:12px;padding:14px}
  .cmp-row .price{grid-column:1/-1;text-align:left;padding-top:6px;border-top:1px dashed var(--line)}
}

/* ---- TOC sticky ---- */
.art-layout{
  display:grid;grid-template-columns:1fr 240px;gap:48px;align-items:start;
  margin-top:8px;
}
@media(max-width:980px){.art-layout{grid-template-columns:1fr}.toc{display:none}}
.toc{
  position:sticky;top:100px;
  padding:22px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);
  font-size:.875rem;
  box-shadow:var(--shadow-sm);
}
.toc h5{
  font-family:var(--f-mono);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--amber-text);margin-bottom:14px;font-weight:700;
}
.toc ul li{margin-bottom:8px}
.toc ul a{color:var(--text-2);transition:color var(--t-fast)}
.toc ul a:hover{color:var(--moss)}
.toc ul a.active{color:var(--moss-deep);font-weight:700}

/* ---- Related posts (footer of article) ---- */
.related{
  padding:64px 0;
  background:var(--bg-cream);
  border-top:1px solid var(--line);
}
.related h2{font-size:1.5rem;margin-bottom:24px;letter-spacing:-.02em;color:var(--moss-deep)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.related-grid{grid-template-columns:1fr}}

/* ---- FAQ accordion ---- */
.faq{margin-top:56px}
.faq-item{
  border:1px solid var(--line);border-radius:var(--r);
  background:var(--bg-2);margin-bottom:10px;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--t-fast),border-color var(--t-fast);
}
.faq-item[open]{border-color:var(--moss-soft);box-shadow:var(--shadow)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:18px 22px;font-weight:600;color:var(--moss-deep);
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  transition:background var(--t-fast);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{background:var(--bg-3)}
.faq-item summary::after{
  content:'+';font-family:var(--f-mono);color:var(--amber);font-size:1.4rem;font-weight:300;
  transition:transform var(--t-fast);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .a{padding:0 22px 20px;color:var(--text-2);line-height:1.7}
.faq-item .a a{color:var(--moss);text-decoration:underline;text-decoration-color:var(--moss-soft)}

/* ---- Category page cover ---- */
.cat-hero{
  position:relative;padding:80px 0 48px;
  background:radial-gradient(ellipse 80% 60% at 30% 0%,var(--cat-glow,rgba(58,136,97,.18)) 0%,transparent 60%);
  overflow:hidden;
}
.cat-hero h1{font-size:clamp(2.5rem,6vw,4rem);margin-bottom:14px;color:var(--moss-deep)}
.cat-hero p.lead{max-width:680px;font-size:1.125rem;color:var(--text-2)}
.cat-hero .stats{
  display:flex;gap:36px;margin-top:32px;flex-wrap:wrap;
  font-family:var(--f-mono);
}
.cat-hero .stats > div strong{display:block;font-family:var(--f-display);font-size:1.5rem;color:var(--moss-deep);font-weight:700}
.cat-hero .stats > div span{font-size:.6875rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}
.cat-pillar-card{
  margin:0 0 56px;padding:36px;
  border-radius:var(--r-lg);
  background:linear-gradient(135deg,var(--bg-2) 0%,var(--bg-moss) 100%);
  border:1px solid var(--moss-soft);position:relative;overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform var(--t),box-shadow var(--t);
}
.cat-pillar-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.cat-pillar-card::before{
  content:'PILAR';position:absolute;top:18px;right:24px;
  font-family:var(--f-mono);font-size:.6875rem;letter-spacing:.12em;color:var(--amber);font-weight:700;
}
.cat-pillar-card h3{font-size:1.5rem;margin-bottom:8px;color:var(--moss-deep)}
.cat-pillar-card p{color:var(--text-2);max-width:60ch}
.cat-pillar-card .btn{margin-top:18px}
