/* Guia Machu Picchu 2026 — Estilo editorial + moderno */
:root{
--bg:#fdfcfa;--bg2:#f3ede1;--bg3:#e8e0cf;--text:#1f2937;--text2:#4b5563;--text3:#9ca3af;
--line:#ece5dc;--line2:#d9cdb8;--accent:#1f5d3a;--accent2:#2c7a4d;--accent-dark:#16432a;
--gold:#c8893b;--terra:#b4541f;--cream:#fff8eb;--green-bg:#e8f0e4;--warn:#fce8d8;--tip:#eef4e3;
--fs:1rem;--fs-sm:.875rem;--fs-xs:.78rem;--fs-lg:1.125rem;--fs-xl:1.5rem;
--h1:clamp(2rem,1.4rem+3vw,3.25rem);--h2:clamp(1.5rem,1.2rem+1.5vw,2.125rem);--h3:clamp(1.18rem,1.05rem+.6vw,1.45rem);
--f-serif:ui-serif,Georgia,"Iowan Old Style",Cambria,"Times New Roman",serif;
--f-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
--container:1200px;--reading:730px;--r:8px;--r-lg:12px;
--shadow:0 1px 3px rgba(20,15,5,.04),0 4px 18px rgba(20,15,5,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-sans);font-size:var(--fs);line-height:1.65;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-dark);text-decoration:underline;text-underline-offset:3px}
.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}
.narrow{max-width:var(--reading);margin:0 auto}

/* Top bar */
.topbar{background:#1a1410;color:#d4a04a;text-align:center;padding:.45rem 1rem;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}
.topbar a{color:#fde8b8;font-weight:500}

/* Header */
.hdr{background:rgba(253,252,250,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.hdr-in{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.55rem;color:var(--text);font-weight:600;font-size:1.1rem;letter-spacing:-.01em}
.brand:hover{text-decoration:none;color:var(--text)}
.brand-mk{width:30px;height:30px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700}
.brand small{display:block;font-size:.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;font-weight:400}
.nav{list-style:none;display:flex;gap:1.6rem;align-items:center}
.nav a{color:var(--text2);font-size:.92rem;font-weight:500;padding:.35rem 0}
.nav a:hover{color:var(--accent);text-decoration:none}
.nav .cta{background:var(--accent);color:#fff;padding:.55rem 1.05rem;border-radius:var(--r);font-size:.88rem}
.nav .cta:hover{background:var(--accent-dark);color:#fff;text-decoration:none}
.menu-btn{display:none;background:none;border:1px solid var(--line2);border-radius:var(--r);padding:.45rem .6rem;cursor:pointer;font-size:1.1rem;color:var(--text)}
@media(max-width:880px){
.nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg);border-bottom:1px solid var(--line);padding:.9rem 1.25rem;gap:.6rem;align-items:stretch}
.nav.open{display:flex}
.nav a{padding:.6rem .4rem;border-bottom:1px solid var(--line)}
.nav .cta{text-align:center}
.menu-btn{display:block}
}

/* Hero */
.hero{background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);padding:4rem 0 3.5rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-80px;right:-120px;width:480px;height:480px;background:radial-gradient(circle,var(--gold) 0%,transparent 60%);opacity:.12;pointer-events:none}
.hero-in{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto}
.badge{display:inline-block;background:var(--green-bg);color:var(--accent);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:.4rem .9rem;border-radius:20px;font-weight:600;margin-bottom:1.25rem}
.hero h1{font-family:var(--f-serif);font-size:var(--h1);line-height:1.08;font-weight:600;letter-spacing:-.025em;color:var(--text);margin-bottom:1.1rem}
.hero h1 em{color:var(--accent);font-style:italic;font-weight:500}
.hero .lead{font-size:1.18rem;color:var(--text2);line-height:1.55;max-width:600px;margin:0 auto 1.6rem}
.hero-stats{display:inline-flex;gap:2rem;margin-top:.5rem;flex-wrap:wrap;justify-content:center}
.hero-stats div{text-align:center}
.hero-stats strong{display:block;font-family:var(--f-serif);font-size:1.6rem;color:var(--accent);font-weight:600;line-height:1}
.hero-stats span{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.hero-cta{display:inline-flex;gap:.7rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}
.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:var(--r);font-weight:500;font-size:.94rem;text-decoration:none;cursor:pointer;transition:all .2s;border:1px solid transparent}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-dark);color:#fff;text-decoration:none}
.btn-outline{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff;text-decoration:none}

/* Sections */
section{padding:3.5rem 0}
section+section{border-top:1px solid var(--line)}
.sec-head{margin-bottom:2.5rem;text-align:center;max-width:680px;margin-left:auto;margin-right:auto}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);font-weight:700;margin-bottom:.6rem}
.sec-head h2{font-family:var(--f-serif);font-size:var(--h2);font-weight:600;letter-spacing:-.02em;color:var(--text);margin-bottom:.7rem;line-height:1.15}
.sec-head p{color:var(--text2);font-size:1.05rem;line-height:1.55}

/* Featured grid (4 columns) */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line2)}
.card a{color:inherit;text-decoration:none;display:flex;flex-direction:column;height:100%}
.card a:hover{text-decoration:none;color:inherit}
.card-img{aspect-ratio:16/10;background:var(--bg3);position:relative;overflow:hidden}
.card-img svg{width:100%;height:100%;object-fit:cover}
.card-bd{padding:1.2rem 1.25rem 1.4rem;flex:1;display:flex;flex-direction:column}
.tag{display:inline-block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700;padding:.25rem .65rem;background:var(--cream);border-radius:4px;margin-bottom:.7rem;align-self:flex-start}
.tag.t-green{color:var(--accent);background:var(--green-bg)}
.tag.t-terra{color:var(--terra);background:#fce8d8}
.card h3{font-family:var(--f-serif);font-size:1.18rem;line-height:1.3;color:var(--text);margin-bottom:.5rem;font-weight:600;letter-spacing:-.01em}
.card p{font-size:.92rem;color:var(--text2);line-height:1.5;flex:1}
.card-meta{margin-top:.85rem;font-size:.78rem;color:var(--text3);font-family:var(--f-sans)}
.card-meta::before{content:'';display:inline-block;width:14px;height:1px;background:var(--text3);vertical-align:middle;margin-right:.5rem}

/* Categories index (legacy .cat - kept for compatibility) */
.cat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.1rem 1.1rem;transition:all .2s;display:block;text-decoration:none;color:inherit}
.cat:hover{border-color:var(--accent);background:var(--green-bg);text-decoration:none;color:inherit;transform:translateY(-2px)}
.cat-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:.45rem}
.cat h3{font-family:var(--f-serif);font-size:1.05rem;font-weight:600;color:var(--text);letter-spacing:-.01em}
.cat-count{background:var(--bg2);color:var(--text2);font-size:.7rem;font-weight:600;padding:.15rem .55rem;border-radius:20px;font-family:var(--f-sans)}
.cat p{font-size:.82rem;color:var(--text3);line-height:1.4}

/* Section .cats (homepage categories section) */
section.cats{padding:3rem 0 4rem;background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}
section.cats .section-head{margin-bottom:2rem;text-align:left;max-width:780px}
section.cats .section-head .kicker{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);font-weight:700;margin-bottom:.55rem;font-family:var(--f-sans)}
section.cats .section-head h2{font-family:var(--f-serif);font-size:1.95rem;font-weight:600;color:var(--text);letter-spacing:-.02em;line-height:1.18;margin-bottom:.6rem}
section.cats .section-head p{font-size:.98rem;color:var(--text2);line-height:1.55;max-width:680px}

/* Category cards grid */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cat-grid{grid-template-columns:1fr}}

.cat-card{display:flex;flex-direction:column;gap:.4rem;padding:1.15rem 1.2rem 1.1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);text-decoration:none;color:inherit;transition:all .18s;min-height:140px;position:relative}
.cat-card:hover{border-color:var(--accent);background:var(--green-bg);transform:translateY(-2px);text-decoration:none;color:inherit;box-shadow:0 4px 12px rgba(31,93,58,.08)}
.cat-card .cat-num{font-family:var(--f-serif);font-size:1.55rem;font-weight:600;color:var(--gold);line-height:1;letter-spacing:-.02em;margin-bottom:.15rem}
.cat-card h3{font-family:var(--f-serif);font-size:1.05rem;line-height:1.25;color:var(--text);font-weight:600;letter-spacing:-.01em;margin-bottom:.15rem}
.cat-card .cat-desc{font-size:.82rem;color:var(--text2);line-height:1.4;margin-bottom:.5rem;flex:1}
.cat-card .cat-stats{font-size:.74rem;color:var(--text3);font-family:var(--f-sans);padding-top:.55rem;border-top:1px solid var(--line);letter-spacing:.02em}
.cat-card .cat-stats strong{color:var(--accent);font-weight:600}
.cat-card .cat-stats .cat-tot{color:var(--text3)}

/* Top 20 box (home) — encajonado con grid de 3 columnas */
.top20-box{background:linear-gradient(135deg,#fff 0%,var(--bg2) 100%);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.2rem 2rem;margin-top:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.top20-box .box-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.2rem;border-bottom:2px solid var(--line);flex-wrap:wrap;gap:.7rem}
.top20-box .box-head .label{font-family:var(--f-serif);font-size:1.2rem;font-weight:600;color:var(--accent);letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}
.top20-box .box-head .label::before{content:'★';color:var(--gold);font-size:1.1em}
.top20-box .box-head .browse-cats{font-size:.82rem;color:var(--text2);font-family:var(--f-sans)}
.top20-box .box-head .browse-cats a{color:var(--accent);font-weight:600;border-bottom:1px solid var(--accent);padding-bottom:1px}
.top20-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:900px){.top20-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.top20-grid{grid-template-columns:1fr}}
.top-item{display:flex;gap:.85rem;padding:1rem 1.1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);text-decoration:none;color:inherit;transition:all .18s;align-items:flex-start;min-height:108px}
.top-item:hover{border-color:var(--accent);background:var(--green-bg);transform:translateY(-2px);text-decoration:none;color:inherit;box-shadow:0 4px 12px rgba(31,93,58,.08)}
.top-num{font-family:var(--f-serif);font-size:1.55rem;font-weight:600;color:var(--gold);line-height:1;flex-shrink:0;width:34px;letter-spacing:-.02em}
.top-bd{flex:1;min-width:0}
.top-tag{display:inline-block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--terra);font-weight:700;margin-bottom:.35rem}
.top-bd h3{font-family:var(--f-serif);font-size:.96rem;line-height:1.28;color:var(--text);font-weight:600;letter-spacing:-.01em;margin-bottom:.25rem}
.top-bd p{font-size:.78rem;color:var(--text2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.top20-note{margin-top:1.5rem;padding:1.1rem 1.3rem;background:var(--green-bg);border-left:3px solid var(--accent);border-radius:6px;font-size:.92rem;color:var(--text);line-height:1.5}
.top20-note strong{color:var(--accent)}
.top20-note a{color:var(--accent);font-weight:600;text-decoration:underline}

/* Category page list */
.cat-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-top:1.5rem}
.cat-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1rem 1.15rem;transition:all .2s;display:block;text-decoration:none;color:inherit}
.cat-item:hover{border-color:var(--accent);background:var(--green-bg);transform:translateY(-2px);text-decoration:none;color:inherit}
.cat-item h3{font-family:var(--f-serif);font-size:1.02rem;font-weight:600;color:var(--text);line-height:1.35;letter-spacing:-.01em;margin-bottom:.35rem}
.cat-item .cat-item-meta{font-size:.75rem;color:var(--text3);letter-spacing:.05em;font-family:var(--f-sans)}
.cat-item.published h3::before{content:'●';color:var(--accent);margin-right:.45rem;font-size:.7em;vertical-align:middle}
.cat-item.draft h3::before{content:'○';color:var(--text3);margin-right:.45rem;font-size:.7em;vertical-align:middle}
.cat-item.draft h3{color:var(--text2)}
.cat-item.draft .cat-item-meta{color:var(--gold)}

/* Category page intro */
.cat-intro{background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);padding:3rem 0 2rem}
.cat-intro h1{font-family:var(--f-serif);font-size:var(--h1);font-weight:600;letter-spacing:-.02em;line-height:1.12;color:var(--text);margin-bottom:.7rem}
.cat-intro h1 em{color:var(--accent);font-style:italic}
.cat-intro .cat-count-big{display:inline-block;background:var(--accent);color:#fff;font-size:.78rem;padding:.32rem .85rem;border-radius:20px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.85rem}
.cat-intro p{font-size:1.08rem;color:var(--text2);line-height:1.55;max-width:680px}

/* Filter chips on category pages */
.cat-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin:1.5rem 0 .5rem;align-items:center}
.cat-filters span{font-size:.78rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-right:.4rem}
.cat-filter{padding:.4rem .9rem;background:#fff;border:1px solid var(--line);border-radius:20px;font-size:.82rem;cursor:pointer;font-family:var(--f-sans);color:var(--text2);transition:all .2s}
.cat-filter:hover{border-color:var(--accent);color:var(--accent)}
.cat-filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Search box */
.searchbox{max-width:540px;margin:0 auto 2rem;position:relative}
.searchbox input{width:100%;padding:.95rem 1.25rem .95rem 3rem;border:1px solid var(--line2);border-radius:30px;font-size:1rem;font-family:var(--f-sans);background:#fff;outline:none;transition:border .2s,box-shadow .2s}
.searchbox input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--green-bg)}
.searchbox::before{content:'⌕';position:absolute;left:1.15rem;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--text3)}

/* CTA Strip */
.cta-strip{background:var(--text);color:#fff;padding:3rem 0;text-align:center}
.cta-strip h2{font-family:var(--f-serif);font-size:var(--h2);font-weight:600;margin-bottom:.7rem;letter-spacing:-.02em}
.cta-strip p{color:#d1d5db;font-size:1.05rem;margin-bottom:1.5rem;max-width:540px;margin-left:auto;margin-right:auto}
.cta-strip .btn-primary{background:var(--gold);border-color:var(--gold);color:#1a1410;font-weight:600}
.cta-strip .btn-primary:hover{background:#fde8b8;color:#1a1410}

/* Article hero */
.art-hero{background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);padding:3rem 0 2.5rem}
.breadcrumb{font-size:.82rem;color:var(--text3);margin-bottom:1rem}
.breadcrumb a{color:var(--text3)}
.breadcrumb a:hover{color:var(--accent)}
.art-hero h1{font-family:var(--f-serif);font-size:var(--h1);font-weight:600;letter-spacing:-.02em;line-height:1.12;color:var(--text);margin-bottom:1rem;max-width:820px}
.art-meta{display:flex;gap:1.4rem;font-size:.85rem;color:var(--text3);flex-wrap:wrap;font-family:var(--f-sans);margin-top:.7rem}
.art-meta span::before{content:'·';margin-right:.6rem;color:var(--text3)}
.art-meta span:first-child::before{display:none}

/* Article body */
.art-body{padding:2.5rem 0 4rem}
.art-body .narrow{max-width:730px;margin:0 auto}
.art-body p{font-family:var(--f-serif);font-size:1.115rem;line-height:1.75;color:var(--text);margin-bottom:1.15rem}
.art-body h2{font-family:var(--f-serif);font-size:var(--h2);font-weight:600;letter-spacing:-.02em;line-height:1.18;color:var(--text);margin:2.5rem 0 1rem}
.art-body h3{font-family:var(--f-serif);font-size:var(--h3);font-weight:600;color:var(--text);margin:1.8rem 0 .7rem;line-height:1.25}
.art-body ul,.art-body ol{font-family:var(--f-serif);font-size:1.08rem;line-height:1.7;color:var(--text);margin:0 0 1.2rem 1.5rem}
.art-body li{margin-bottom:.4rem}
.art-body strong{font-weight:600;color:var(--text)}
.art-body em{font-style:italic}
.art-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.art-body a:hover{color:var(--accent-dark)}
.art-body figure{margin:2rem 0}
.art-body figure img,.art-body figure svg{border-radius:var(--r);background:var(--bg3)}
.art-body figcaption{font-size:.85rem;color:var(--text3);text-align:center;margin-top:.6rem;font-style:italic}

/* TOC */
.toc{background:var(--bg2);border-left:3px solid var(--accent);padding:1.2rem 1.4rem;border-radius:0 var(--r) var(--r) 0;margin:0 0 2.2rem}
.toc h4{font-family:var(--f-sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:.6rem}
.toc ol{margin:0 0 0 1.2rem;font-family:var(--f-sans);font-size:.95rem;line-height:1.55}
.toc li{margin-bottom:.25rem;color:var(--text2)}
.toc a{color:var(--text);text-decoration:none}
.toc a:hover{color:var(--accent);text-decoration:underline}

/* Callouts */
.callout{background:var(--cream);border-left:4px solid var(--gold);padding:1rem 1.25rem;border-radius:0 var(--r) var(--r) 0;margin:1.5rem 0;font-family:var(--f-sans);font-size:.97rem;line-height:1.55;color:var(--text)}
.callout.warn{background:var(--warn);border-left-color:var(--terra)}
.callout.tip{background:var(--tip);border-left-color:var(--accent)}
.callout strong{font-weight:600;display:inline}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-family:var(--f-sans);font-size:.92rem;margin:1.5rem 0;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tbl thead{background:var(--text);color:#fff}
.tbl th{padding:.85rem 1rem;text-align:left;font-weight:600;font-size:.85rem;letter-spacing:.02em}
.tbl td{padding:.75rem 1rem;border-bottom:1px solid var(--line);color:var(--text2)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:nth-child(even) td{background:var(--bg2)}

/* Article nav */
.art-nav{display:flex;justify-content:space-between;gap:1rem;margin:3rem 0 0;padding:1.5rem 0;border-top:1px solid var(--line);font-family:var(--f-sans);font-size:.9rem;flex-wrap:wrap}
.art-nav a{color:var(--accent);text-decoration:none}
.art-nav a:hover{color:var(--accent-dark);text-decoration:underline}

/* Related articles in sidebar (in-article) */
.related{background:var(--bg2);padding:1.5rem;border-radius:var(--r-lg);margin:2.5rem 0}
.related h4{font-family:var(--f-sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--terra);font-weight:700;margin-bottom:1rem}
.related ul{list-style:none;margin:0}
.related li{padding:.5rem 0;border-bottom:1px solid var(--line);font-family:var(--f-sans);font-size:.92rem}
.related li:last-child{border-bottom:none}
.related a{color:var(--text);text-decoration:none}
.related a:hover{color:var(--accent);text-decoration:underline}

/* Footer */
.footer{background:#1a1410;color:#d1d5db;padding:3.5rem 0 1.5rem;margin-top:4rem;font-family:var(--f-sans);font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer h4{font-family:var(--f-serif);color:#fde8b8;font-size:1rem;font-weight:600;margin-bottom:.85rem}
.footer ul{list-style:none}
.footer li{margin-bottom:.45rem}
.footer a{color:#9ca3af;text-decoration:none;font-size:.88rem}
.footer a:hover{color:#fff;text-decoration:underline}
.footer p{color:#9ca3af;font-size:.88rem;line-height:1.55}
.footer-bot{border-top:1px solid #2c2c2a;padding-top:1.5rem;text-align:center;font-size:.8rem;color:#6b7280}
.footer-bot a{color:#9ca3af}

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

/* Categoría: items con título y tag */
.cat-item{display:flex;flex-direction:column;gap:.35rem}
.cat-item-title{font-family:var(--f-serif);font-size:1rem;font-weight:600;color:var(--text);line-height:1.35;letter-spacing:-.01em;display:block}
.cat-item-tag{font-size:.7rem;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;font-family:var(--f-sans);display:none}
.cat-item .status-dot{display:none}
.cat-item.published .cat-item-title::before{content:'●';color:var(--accent);margin-right:.45rem;font-size:.7em;vertical-align:middle}
.cat-item.draft .cat-item-title::before{content:'○';color:var(--text3);margin-right:.45rem;font-size:.7em;vertical-align:middle}
.cat-item.draft .cat-item-title{color:var(--text2)}
.cat-filter-btn{padding:.4rem .9rem;background:#fff;border:1px solid var(--line);border-radius:20px;font-size:.82rem;cursor:pointer;font-family:var(--f-sans);color:var(--text2);transition:all .2s}
.cat-filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.cat-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.cat-search{padding:.4rem .9rem;background:#fff;border:1px solid var(--line);border-radius:20px;font-size:.82rem;font-family:var(--f-sans);color:var(--text);min-width:200px}
.cat-search:focus{outline:none;border-color:var(--accent)}

/* ===== Estilos complementarios para home nueva ===== */

/* Header */
.hdr{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:50}
.hdr-in{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--text);text-decoration:none;font-family:var(--f-serif);font-weight:600;line-height:1.1}
.brand:hover{text-decoration:none;color:var(--accent)}
.brand-mk{background:var(--accent);color:#fff;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-family:var(--f-serif);font-weight:700}
.brand small{display:block;font-size:.7rem;color:var(--text3);font-weight:400;letter-spacing:.05em;text-transform:uppercase;margin-top:.15rem}
.menu-btn{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text)}
.nav{display:flex;list-style:none;gap:1.5rem;align-items:center;margin:0;padding:0}
.nav a{color:var(--text2);font-size:.92rem;font-weight:500;text-decoration:none}
.nav a:hover{color:var(--accent);text-decoration:none}
.nav .cta{background:var(--accent);color:#fff;padding:.55rem 1.1rem;border-radius:6px}
.nav .cta:hover{background:var(--accent-dark);color:#fff}

/* Hero */
.hero{background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);padding:4rem 1rem 5rem;text-align:center}
.hero-in{max-width:800px;margin:0 auto}
.hero-sub{font-size:1.15rem;color:var(--text2);line-height:1.55;max-width:680px;margin:1rem auto 2rem}

/* Sections */
.section{padding:4rem 0}
.section-alt{background:var(--bg2)}
.section-title{font-family:var(--f-serif);font-size:var(--h2);color:var(--text);text-align:center;margin-bottom:.5rem;font-weight:600;letter-spacing:-.02em}
.section-sub{text-align:center;color:var(--text2);font-size:1.02rem;margin-bottom:2.5rem;max-width:600px;margin-left:auto;margin-right:auto}

/* Category grid - homepage */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;margin-top:2rem}
.cat-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;text-decoration:none;color:inherit;transition:all .2s;box-shadow:var(--shadow)}
.cat-card:hover{transform:translateY(-3px);border-color:var(--accent);text-decoration:none;color:inherit;box-shadow:0 4px 20px rgba(20,15,5,.1)}
.cat-card img{width:100%;height:120px;object-fit:cover;background:var(--bg2);display:block}
.cat-card div{padding:1rem 1.1rem 1.1rem}
.cat-card h3{font-family:var(--f-serif);font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.25rem;letter-spacing:-.01em}
.cat-card p{font-size:.82rem;color:var(--text3);letter-spacing:.04em}

/* Top/Featured grid */
.top-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1.5rem}
.top-card{display:flex;align-items:center;padding:1rem 1.15rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);text-decoration:none;color:var(--text);transition:all .2s;line-height:1.4;min-height:60px}
.top-card:hover{border-color:var(--accent);background:var(--green-bg);transform:translateX(3px);color:var(--text);text-decoration:none}
.top-title{font-family:var(--f-serif);font-size:.98rem;font-weight:500;letter-spacing:-.005em}

/* Why grid */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.why-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem 1.4rem}
.why-card h3{font-family:var(--f-serif);font-size:1.18rem;color:var(--accent);font-weight:600;margin-bottom:.7rem;letter-spacing:-.01em}
.why-card p{color:var(--text2);line-height:1.55;font-size:.95rem}

/* Footer */
.ftr{background:#1a1410;color:#d4cdb5;padding:3rem 0 2rem;margin-top:4rem}
.ftr-in{display:flex;flex-wrap:wrap;gap:2rem;align-items:flex-start;justify-content:space-between}
.ftr-brand{font-family:var(--f-serif);font-size:1.15rem;color:#fff;font-weight:600;margin-bottom:.4rem}
.ftr-tag{color:#a8a08c;font-size:.92rem;max-width:340px}
.ftr-links{display:flex;flex-direction:column;gap:.6rem}
.ftr-links a{color:#d4cdb5;font-size:.92rem;text-decoration:none}
.ftr-links a:hover{color:#fde8b8;text-decoration:none}
.ftr-legal{width:100%;text-align:center;color:#7a7363;font-size:.78rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #2a241c}

/* Mobile */
@media (max-width: 768px) {
  .menu-btn{display:block}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:1rem;border-bottom:1px solid var(--line);gap:0}
  .nav.open{display:flex}
  .nav li{width:100%}
  .nav a{display:block;padding:.75rem 0;border-bottom:1px solid var(--line)}
  .nav .cta{margin-top:.5rem;text-align:center}
  .hero{padding:2.5rem 1rem 3rem}
  .section{padding:2.5rem 0}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .cat-card img{height:90px}
  .cat-card div{padding:.7rem .8rem}
  .cat-card h3{font-size:.92rem}
  .top-grid{grid-template-columns:1fr}
  .ftr-in{flex-direction:column}
}

/* Article hero meta */
.art-hero{background:var(--bg2);padding:2.5rem 0 2rem;border-bottom:1px solid var(--line)}
.art-hero h1{font-family:var(--f-serif);font-size:var(--h1);line-height:1.15;color:var(--text);margin:.5rem 0 1rem;font-weight:600;letter-spacing:-.02em}
.art-hero .lead{font-size:1.12rem;color:var(--text2);line-height:1.55;max-width:680px}
.art-meta-top,.cat-meta-top{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:.5rem}
.art-meta{display:flex;gap:1.5rem;font-size:.85rem;color:var(--text3);margin-top:1rem;flex-wrap:wrap}
.art-meta strong{color:var(--text)}
.breadcrumb{font-size:.85rem;color:var(--text3);margin-bottom:1rem}
.breadcrumb a{color:var(--text2)}
.breadcrumb a:hover{color:var(--accent)}

/* Article body */
.art-body{padding:3rem 0}
.art-body h2{font-family:var(--f-serif);font-size:var(--h2);color:var(--text);margin:2.2rem 0 1rem;font-weight:600;letter-spacing:-.015em;line-height:1.25}
.art-body h3{font-family:var(--f-serif);font-size:var(--h3);color:var(--text);margin:1.7rem 0 .75rem;font-weight:600;line-height:1.3}
.art-body p{margin-bottom:1.1rem;line-height:1.7}
.art-body ul,.art-body ol{margin:1rem 0 1.3rem 1.5rem;line-height:1.7}
.art-body li{margin-bottom:.4rem}
.art-body strong{color:var(--text);font-weight:600}
.art-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem;background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.art-body thead{background:var(--green-bg)}
.art-body th{padding:.7rem .9rem;text-align:left;font-family:var(--f-sans);font-weight:600;color:var(--text);border-bottom:1px solid var(--line2)}
.art-body td{padding:.6rem .9rem;border-bottom:1px solid var(--line)}
.art-body tbody tr:last-child td{border-bottom:none}
.art-body tbody tr:hover{background:var(--bg2)}

/* Callouts */
.callout{background:var(--cream);border-left:4px solid var(--gold);padding:1rem 1.2rem;margin:1.5rem 0;border-radius:0 var(--r) var(--r) 0;font-size:.96rem}
.callout.warn{background:var(--warn);border-left-color:var(--terra)}
.callout.tip{background:var(--tip);border-left-color:var(--accent)}
.callout strong{color:var(--text)}

/* Related */
.related{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line)}
.related h2{font-family:var(--f-serif);font-size:1.5rem;color:var(--text);margin-bottom:1rem;font-weight:600}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.75rem}
.rel-card{display:block;padding:.85rem 1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);text-decoration:none;color:var(--text);transition:all .2s}
.rel-card:hover{border-color:var(--accent);background:var(--green-bg);text-decoration:none;color:var(--text)}
.rel-card h3{font-family:var(--f-serif);font-size:.95rem;font-weight:500;color:var(--text);line-height:1.35}

/* Article navigation */
.art-nav{display:flex;justify-content:space-between;gap:1rem;margin:2.5rem 0;padding-top:2rem;border-top:1px solid var(--line);flex-wrap:wrap}
.nav-prev,.nav-next{padding:.7rem 1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);color:var(--text2);text-decoration:none;font-size:.9rem;flex:1;min-width:200px}
.nav-prev:hover,.nav-next:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.nav-next{text-align:right}

/* Category page */
.cat-intro{margin:0 auto 1.5rem;text-align:center}
.cat-intro .lead{font-size:1.05rem;color:var(--text2);line-height:1.6}
