/*
Theme Name: Verdor
Theme URI: https://www.ecoturismocolombia.com.co/
Author: Ecoturismo Colombia
Description: Tema editorial para Ecoturismo Colombia. Una publicación digital sobre naturaleza, viajes responsables y los lugares que vale la pena cuidar.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: verdor
*/

:root{
  --ink:#14201a;
  --bosque:#1f3a2b;
  --musgo:#4f6b4a;
  --musgo-soft:#7d9377;
  --agua:#2f6b78;
  --tierra:#b97a52;
  --arena:#e8dcc4;
  --arena-2:#dccfb1;
  --paper:#f6f1e8;
  --paper-2:#efe9dc;
  --line:rgba(20,32,26,.14);
  --line-strong:rgba(20,32,26,.32);
  --serif:'Spectral','Iowan Old Style',Georgia,serif;
  --sans:'DM Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--bosque);color:var(--paper)}

/* WP block helpers / fallback */
.alignleft{float:left;margin:0 24px 18px 0}
.alignright{float:right;margin:0 0 18px 24px}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.wp-caption-text{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);margin-top:8px}

/* ==========================================================
   Layout — site shell
   ========================================================== */
.site-nav{display:flex;align-items:center;justify-content:space-between;padding:18px 40px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(246,241,232,.92);backdrop-filter:blur(12px);z-index:50}
.site-nav .brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:500;font-size:19px;letter-spacing:-.01em}
.site-nav .brand .mark{width:30px;height:30px;border-radius:50%;background:var(--bosque);display:grid;place-items:center;color:var(--arena);font-family:var(--serif);font-size:14px;font-style:italic}
.site-nav .brand b{color:var(--bosque);font-weight:500}
.site-nav .brand small{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--musgo);display:block;line-height:1}
.site-nav .brand .stack{display:flex;flex-direction:column;gap:3px}
.site-nav .navlinks{display:flex;gap:28px;font-size:14px;font-weight:500;list-style:none;margin:0;padding:0}
.site-nav .navlinks a{position:relative;padding:4px 0;color:var(--ink)}
.site-nav .navlinks a:hover{color:var(--bosque)}
.site-nav .navlinks .current-menu-item > a,
.site-nav .navlinks .current_page_item > a,
.site-nav .navlinks .current-cat > a,
.site-nav .navlinks li.active > a{color:var(--bosque)}
.site-nav .navlinks .current-menu-item > a:after,
.site-nav .navlinks .current_page_item > a:after,
.site-nav .navlinks .current-cat > a:after,
.site-nav .navlinks li.active > a:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--tierra)}
.site-nav .nav-actions{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo)}
.site-nav .nav-actions .pill{border:1px solid var(--line-strong);padding:7px 14px;border-radius:99px;color:var(--ink);background:transparent;cursor:pointer}
.site-nav .nav-actions .pill:hover{background:var(--bosque);color:var(--paper);border-color:var(--bosque)}
.site-nav .nav-actions .icon{width:32px;height:32px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--ink);background:transparent;cursor:pointer;font-size:14px}
.site-nav .nav-actions .icon:hover{background:var(--bosque);color:var(--paper);border-color:var(--bosque)}
.menu-toggle{display:none;background:transparent;border:1px solid var(--line-strong);border-radius:99px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:7px 14px;color:var(--ink);cursor:pointer}

/* ==========================================================
   Buttons / shared
   ========================================================== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:99px;font-weight:500;font-size:13.5px;font-family:var(--sans);cursor:pointer;border:0;line-height:1;transition:transform .12s ease}
.btn:hover{transform:translateY(-1px)}
.btn-dark{background:var(--bosque);color:var(--paper)}
.btn-dark:hover{background:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(20,32,26,.05)}
.btn-arena{background:var(--arena);color:var(--bosque)}
.btn-arena:hover{background:var(--arena-2)}
.arrow{display:inline-block;transform:translateY(-1px)}

.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--tierra)}
.kicker-line{display:flex;align-items:center;gap:10px}
.kicker-line:before{content:"";width:24px;height:1px;background:var(--tierra)}

/* ==========================================================
   Image fallback (gradient placeholder)
   ========================================================== */
.ph{position:relative;width:100%;height:100%;background:repeating-linear-gradient(135deg,rgba(20,32,26,.05) 0 1px,transparent 1px 14px),linear-gradient(180deg,var(--musgo-soft),var(--bosque));color:var(--paper);overflow:hidden}
.ph.tone-arena{background:repeating-linear-gradient(135deg,rgba(20,32,26,.04) 0 1px,transparent 1px 14px),linear-gradient(180deg,var(--arena-2),var(--tierra))}
.ph.tone-agua{background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 1px,transparent 1px 14px),linear-gradient(180deg,#6c98a3,var(--agua))}
.ph.tone-bosque{background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 1px,transparent 1px 14px),linear-gradient(180deg,var(--bosque),#0d1a13)}
.ph.tone-paper{background:repeating-linear-gradient(135deg,rgba(20,32,26,.05) 0 1px,transparent 1px 14px),var(--paper-2);color:var(--musgo)}

.cover-img{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;background:var(--paper-2)}
.cover-img > img{display:block;width:100%;height:100%;object-fit:cover}
.cover-img .ph{position:absolute;inset:0}
.ph{position:absolute;inset:0;width:100%;height:100%}

/* ==========================================================
   Home — Hero
   ========================================================== */
.hero{padding:0 40px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:48px 0 0;border-bottom:1px solid var(--line);min-height:560px}
.hero-text{padding:24px 56px 64px 0;display:flex;flex-direction:column;justify-content:space-between;gap:32px}
.hero-text .edition{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--tierra)}
.hero-text h1{font-family:var(--serif);font-weight:400;font-size:84px;line-height:.95;letter-spacing:-.025em;margin:0;text-wrap:balance}
.hero-text h1 em{font-style:italic;color:var(--musgo)}
.hero-text .dek{font-family:var(--serif);font-size:20px;line-height:1.45;font-weight:300;max-width:42ch;color:#27332b;margin:24px 0 0}
.hero-text .ctas{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.hero-img{position:relative;border-left:1px solid var(--line);min-height:560px}
.hero-img .cover-img{position:absolute;inset:0}

/* Index strip */
.strip{display:flex;align-items:center;gap:28px;padding:18px 40px;border-bottom:1px solid var(--line);overflow-x:auto;background:var(--paper)}
.strip .label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--tierra);white-space:nowrap}
.strip a{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--ink);white-space:nowrap}
.strip a:hover{color:var(--musgo)}

/* Featured editorial */
.feat{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;padding:80px 40px;border-bottom:1px solid var(--line);align-items:center}
.feat-img{aspect-ratio:5/4;position:relative}
.feat-text .kick{margin-bottom:18px;color:var(--tierra);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.feat-text h2{font-family:var(--serif);font-weight:400;font-size:54px;line-height:1.02;letter-spacing:-.02em;margin:0 0 20px;text-wrap:balance}
.feat-text h2 em{font-style:italic;color:var(--musgo)}
.feat-text h2 a{color:inherit}
.feat-text h2 a:hover{color:var(--bosque)}
.feat-text .dek{font-family:var(--serif);font-size:18px;line-height:1.5;font-weight:300;color:#27332b;margin:0 0 24px}
.feat-text .byline{display:flex;justify-content:space-between;gap:24px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);border-top:1px solid var(--line);padding-top:18px;margin-top:24px}

/* Categories tiles */
.cats{padding:80px 40px;border-bottom:1px solid var(--line)}
.cats-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:32px;flex-wrap:wrap}
.cats-head h3{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:-.015em;margin:0;text-wrap:balance}
.cats-head .lk{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tierra)}
.cats-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:1px;background:var(--line)}
.cat-tile{background:var(--paper);padding:28px;display:flex;flex-direction:column;justify-content:space-between;color:var(--ink);transition:background .2s}
.cat-tile:hover{background:var(--paper-2)}
.cat-tile .glyph{width:34px;height:34px;display:grid;place-items:center;color:var(--bosque)}
.cat-tile h4{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1;letter-spacing:-.01em;margin:0 0 4px}
.cat-tile h4 em{font-style:italic;color:var(--musgo);font-weight:400}
.cat-tile .meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo)}
.cat-tile.feature{grid-column:span 2;grid-row:span 2;padding:0;position:relative;overflow:hidden;background:var(--bosque);color:var(--paper)}
.cat-tile.feature .cover-img{position:absolute;inset:0}
.cat-tile.feature .ph{position:absolute;inset:0}
.cat-tile.feature .body{position:relative;z-index:2;padding:36px;display:flex;flex-direction:column;justify-content:space-between;height:100%;background:linear-gradient(180deg,rgba(20,32,26,.1) 0%,rgba(20,32,26,.75) 100%);color:var(--paper)}
.cat-tile.feature h4{color:var(--paper);font-size:42px;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.cat-tile.feature .meta{color:var(--arena)}

/* Destinos */
.destinos{padding:80px 40px;border-bottom:1px solid var(--line);background:var(--paper-2)}
.destinos-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:48px;align-items:end}
.destinos-head h3{font-family:var(--serif);font-weight:400;font-size:54px;line-height:1;letter-spacing:-.02em;margin:0;text-wrap:balance}
.destinos-head h3 em{font-style:italic;color:var(--musgo)}
.destinos-head p{font-family:var(--serif);font-size:18px;line-height:1.5;font-weight:300;margin:0;max-width:46ch}
.destinos-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.destino{position:relative;color:var(--ink)}
.destino .img{position:relative;overflow:hidden}
.destino .img:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,32,26,.0) 60%,rgba(20,32,26,.0) 100%);transition:background .25s}
.destino:hover .img:after{background:rgba(20,32,26,.08)}
.destino .info{padding:14px 0 0;display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.destino .info h5{font-family:var(--serif);font-weight:500;font-size:20px;letter-spacing:-.01em;margin:0;line-height:1.1}
.destino .info .reg{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo)}
.destino.d1{grid-column:span 5}.destino.d1 .img{aspect-ratio:5/6}
.destino.d2{grid-column:span 4}.destino.d2 .img{aspect-ratio:4/5}
.destino.d3{grid-column:span 3}.destino.d3 .img{aspect-ratio:3/5}
.destino.d4{grid-column:span 7}.destino.d4 .img{aspect-ratio:7/4}
.destino.d5{grid-column:span 5}.destino.d5 .img{aspect-ratio:5/4}

/* Latest articles */
.latest{padding:96px 40px;border-bottom:1px solid var(--line);background:var(--paper)}
.latest-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:48px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:24px}
.latest-head h3{font-family:var(--serif);font-weight:400;font-size:48px;letter-spacing:-.02em;margin:0;text-wrap:balance}
.latest-head .lk{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tierra);white-space:nowrap}
.latest-head .lk:hover{color:var(--bosque)}
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px}
.articles.articles-6{gap:56px 32px}
.art{display:flex;flex-direction:column;gap:18px;color:var(--ink)}
.art .img{aspect-ratio:4/3;position:relative;overflow:hidden}
.art .img > .ph{position:absolute;inset:0}
.art .meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--tierra);display:flex;gap:14px;align-items:center}
.art .meta .dot{width:3px;height:3px;border-radius:50%;background:var(--musgo)}
.art h4{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1.2;letter-spacing:-.01em;margin:0;text-wrap:balance}
.art h4 a{color:inherit}
.art h4 a:hover{color:var(--bosque)}
.art .dek{font-size:14.5px;line-height:1.55;color:#3a4a40;margin:0}
.art .byline{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);margin-top:auto}

/* Purpose */
.purpose{padding:96px 40px;background:var(--bosque);color:var(--paper);border-bottom:1px solid var(--line)}
.purpose-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.purpose .kick{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--arena);margin-bottom:24px}
.purpose h3{font-family:var(--serif);font-weight:400;font-size:54px;line-height:1.05;letter-spacing:-.02em;margin:0 0 24px;text-wrap:balance}
.purpose h3 em{font-style:italic;color:var(--arena)}
.purpose p{font-family:var(--serif);font-size:19px;line-height:1.55;font-weight:300;margin:0 0 28px;color:rgba(246,241,232,.85);max-width:48ch}
.purpose .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(246,241,232,.18);margin-top:32px}
.purpose .stat{padding:24px 24px 0 0;border-right:1px solid rgba(246,241,232,.18)}
.purpose .stat:last-child{border-right:0}
.purpose .stat .n{font-family:var(--serif);font-size:42px;font-weight:400;letter-spacing:-.02em}
.purpose .stat .l{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--arena)}
.purpose-img{aspect-ratio:4/5;position:relative}

/* Newsletter */
.news{padding:80px 40px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;border-bottom:1px solid var(--line)}
.news h3{font-family:var(--serif);font-weight:400;font-size:42px;line-height:1.05;letter-spacing:-.02em;margin:0;text-wrap:balance}
.news h3 em{font-style:italic;color:var(--musgo)}
.news .form{display:flex;align-items:center;border-bottom:1px solid var(--line-strong);padding:14px 0;gap:8px}
.news .form input{flex:1;border:0;background:transparent;outline:none;font-family:var(--sans);font-size:16px;color:var(--ink);padding:6px 0}
.news .form button{background:var(--bosque);color:var(--paper);border:0;padding:11px 18px;border-radius:99px;font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer}
.news small{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);display:block;margin-top:14px}

/* Footer */
.foot{padding:64px 40px 32px;background:var(--paper-2);font-size:13.5px;color:#3a4a40}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;border-bottom:1px solid var(--line);padding-bottom:48px}
.foot h6{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--tierra);margin:0 0 16px;font-weight:500}
.foot ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.foot a{color:#3a4a40}
.foot a:hover{color:var(--bosque)}
.foot .blurb{font-family:var(--serif);font-size:18px;line-height:1.5;font-weight:300;color:var(--ink);max-width:34ch}
.foot .brand-foot{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;margin-bottom:18px}
.foot .brand-foot .mark{width:32px;height:32px;border-radius:50%;background:var(--bosque);display:grid;place-items:center;color:var(--arena);font-family:var(--serif);font-size:15px;font-style:italic}
.foot .brand-foot b{color:var(--bosque);font-weight:500}
.foot-bottom{display:flex;justify-content:space-between;padding-top:24px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo);flex-wrap:wrap;gap:16px}

/* ==========================================================
   Category page
   ========================================================== */
.cat-hero{padding:64px 40px 56px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end}
.cat-hero .kick{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--tierra);margin-bottom:18px}
.cat-hero .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo);margin-bottom:24px}
.cat-hero .crumb a{color:var(--musgo)}
.cat-hero .crumb a:hover{color:var(--bosque)}
.cat-hero h1{font-family:var(--serif);font-weight:400;font-size:104px;line-height:.92;letter-spacing:-.03em;margin:0 0 24px;text-wrap:balance}
.cat-hero h1 em{font-style:italic;color:var(--musgo)}
.cat-hero .dek{font-family:var(--serif);font-size:19px;line-height:1.5;font-weight:300;color:#27332b;max-width:48ch;margin:0}
.cat-meta{display:flex;flex-direction:column;gap:18px;align-items:flex-end;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);text-align:right}
.cat-meta b{color:var(--ink);font-weight:500;font-size:42px;font-family:var(--serif);font-style:italic;letter-spacing:-.02em;text-transform:none}

.filters{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 40px;border-bottom:1px solid var(--line);background:var(--paper-2);flex-wrap:wrap}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 14px;border:1px solid var(--line-strong);border-radius:99px;background:transparent;color:var(--ink);cursor:pointer;text-decoration:none;display:inline-block}
.chip:hover{background:rgba(20,32,26,.04)}
.chip.active{background:var(--bosque);color:var(--paper);border-color:var(--bosque)}
.sort{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--musgo)}

.cat-feature{padding:64px 40px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.cat-feature .img{aspect-ratio:4/3;position:relative}
.cat-feature h2{font-family:var(--serif);font-weight:400;font-size:48px;line-height:1.05;letter-spacing:-.02em;margin:0 0 18px;text-wrap:balance}
.cat-feature h2 em{font-style:italic;color:var(--musgo)}
.cat-feature h2 a{color:inherit}
.cat-feature .dek{font-family:var(--serif);font-size:18px;line-height:1.5;font-weight:300;color:#27332b;margin:0 0 24px}

.cat-list{padding:64px 40px;border-bottom:1px solid var(--line)}
.cat-list .articles{grid-template-columns:repeat(3,1fr);gap:48px 32px}

.pag{display:flex;justify-content:center;align-items:center;gap:18px;padding:48px 40px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo);flex-wrap:wrap}
.pag a, .pag span.current{display:grid;place-items:center;min-width:34px;height:34px;border:1px solid var(--line-strong);border-radius:50%;color:var(--ink);padding:0 10px}
.pag span.current,.pag a:hover{background:var(--bosque);color:var(--paper);border-color:var(--bosque)}

.related-cats{padding:64px 40px;border-bottom:1px solid var(--line)}
.related-cats h3{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:-.015em;margin:0 0 32px}
.rcat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.rcat{background:var(--paper);padding:24px;color:var(--ink);min-height:140px;display:flex;flex-direction:column;justify-content:space-between;transition:background .2s}
.rcat:hover{background:var(--paper-2)}
.rcat h5{font-family:var(--serif);font-weight:500;font-size:22px;margin:0;letter-spacing:-.01em}
.rcat .meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--musgo);display:flex;justify-content:space-between;align-items:center}

/* ==========================================================
   Article page
   ========================================================== */
.progress-bar{position:sticky;top:73px;height:2px;background:var(--line);overflow:hidden;z-index:40}
.progress-bar:after{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--tierra);transition:width .15s}

.art-head{padding:64px 40px 48px;text-align:center;border-bottom:1px solid var(--line)}
.art-head .kick{margin-bottom:18px}
.art-head h1{font-family:var(--serif);font-weight:400;font-size:62px;line-height:1.05;letter-spacing:-.02em;margin:0 auto 22px;max-width:22ch;text-wrap:balance}
.art-head h1 em{font-style:italic;color:var(--musgo)}
.art-head .dek{font-family:var(--serif);font-size:21px;line-height:1.45;font-weight:300;color:#27332b;max-width:54ch;margin:0 auto 28px}
.art-head .byline{display:flex;gap:24px;justify-content:center;align-items:center;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo)}
.art-head .byline b{color:var(--ink);font-weight:500}
.art-hero{aspect-ratio:21/9;position:relative;background:var(--paper-2)}
.art-hero .cover-img{position:absolute;inset:0}

.art-body{display:grid;grid-template-columns:240px minmax(0,640px) 220px;gap:48px;padding:64px 40px;justify-content:center;border-bottom:1px solid var(--line)}
.toc{position:sticky;top:96px;align-self:start;padding-right:24px;border-right:1px solid var(--line);max-height:calc(100vh - 120px);overflow:auto}
.toc h6{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--tierra);margin:0 0 14px}
.toc ol{list-style:none;padding:0;margin:0;font-size:13.5px;display:flex;flex-direction:column;gap:10px;counter-reset:toc}
.toc li{counter-increment:toc;line-height:1.4}
.toc li:before{content:"0" counter(toc) "  ";font-family:var(--mono);font-size:10px;color:var(--musgo);letter-spacing:.1em}
.toc li a{color:var(--ink)}
.toc li.active a{color:var(--bosque);font-weight:500}
.toc li:hover a{color:var(--bosque)}

.prose{max-width:640px;font-size:18px;line-height:1.7;color:#202b22}
.prose .lead{font-family:var(--serif);font-size:24px;line-height:1.45;font-weight:300;color:var(--ink);margin:0 0 32px}
.prose h2{font-family:var(--serif);font-weight:500;font-size:34px;line-height:1.1;letter-spacing:-.015em;margin:48px 0 16px;text-wrap:balance;scroll-margin-top:96px}
.prose h3{font-family:var(--serif);font-weight:500;font-size:22px;line-height:1.2;margin:32px 0 12px;scroll-margin-top:96px}
.prose p{margin:0 0 18px}
.prose a{color:var(--bosque);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.prose a:hover{color:var(--tierra)}
.prose ul,.prose ol{margin:0 0 24px;padding-left:24px}
.prose li{margin-bottom:8px}
.prose img,.prose figure{margin:32px 0;max-width:100%;height:auto}
.prose figure img{margin:0}
.prose figcaption{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);margin-top:10px}
.prose blockquote{font-family:var(--serif);font-size:30px;line-height:1.25;font-style:italic;font-weight:300;color:var(--bosque);border-left:2px solid var(--tierra);padding:8px 0 8px 24px;margin:32px 0;text-wrap:balance}
.prose blockquote p{margin:0}
.prose code{font-family:var(--mono);font-size:14px;background:var(--paper-2);padding:2px 6px;border-radius:3px}
.prose pre{font-family:var(--mono);font-size:14px;background:var(--ink);color:var(--paper);padding:18px;border-radius:4px;overflow-x:auto;margin:24px 0}
.prose pre code{background:transparent;padding:0;color:inherit}
.prose hr{border:0;border-top:1px solid var(--line);margin:48px 0}
.prose table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.prose th,.prose td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
.prose th{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);font-weight:500}
.prose iframe{max-width:100%;margin:24px 0}

.callout{background:var(--paper-2);padding:24px 28px;border-left:3px solid var(--tierra);margin:32px 0;font-size:15.5px;line-height:1.6}
.callout h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tierra);margin:0 0 12px}
.callout ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}

.aside{position:sticky;top:96px;align-self:start;display:flex;flex-direction:column;gap:24px;font-size:13px;color:#3a4a40}
.aside h6{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--tierra);margin:0 0 8px}
.aside .related{padding:16px 0;border-top:1px solid var(--line)}
.aside .related a{display:block;font-family:var(--serif);font-size:16px;line-height:1.25;color:var(--ink);margin-top:6px}
.aside .related a:hover{color:var(--bosque)}
.share{display:flex;gap:8px}
.share a{width:32px;height:32px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--ink);font-family:var(--mono);font-size:11px}
.share a:hover{background:var(--bosque);color:var(--paper);border-color:var(--bosque)}

.art-end-cta{padding:64px 40px;text-align:center;border-bottom:1px solid var(--line);background:var(--paper-2)}
.art-end-cta .kick{margin-bottom:14px}
.art-end-cta h3{font-family:var(--serif);font-weight:400;font-size:42px;line-height:1.05;letter-spacing:-.02em;margin:0 auto 20px;max-width:22ch;text-wrap:balance}
.art-end-cta h3 em{font-style:italic;color:var(--musgo)}
.art-end-cta .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}

/* Comments minimal */
.comments-area{padding:48px 40px;border-bottom:1px solid var(--line);max-width:760px;margin:0 auto}
.comments-area h3{font-family:var(--serif);font-weight:500;font-size:28px;margin:0 0 24px}
.comments-area ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:24px}
.comments-area .comment{border-bottom:1px solid var(--line);padding-bottom:24px}
.comments-area .comment-meta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--musgo);margin-bottom:8px}
.comments-area .comment-meta b{color:var(--ink)}

/* ==========================================================
   Generic page (about, contact, etc.)
   ========================================================== */
.page-shell{padding:64px 40px 96px;max-width:760px;margin:0 auto}
.page-shell h1{font-family:var(--serif);font-weight:400;font-size:62px;line-height:1.05;letter-spacing:-.02em;margin:0 0 24px;text-wrap:balance}
.page-shell h1 em{font-style:italic;color:var(--musgo)}
.page-shell .prose{max-width:none}

/* ==========================================================
   Search & 404
   ========================================================== */
.archive-shell{padding:64px 40px;border-bottom:1px solid var(--line)}
.archive-shell h1{font-family:var(--serif);font-weight:400;font-size:62px;line-height:1.05;letter-spacing:-.02em;margin:0 0 24px;text-wrap:balance}
.archive-shell h1 em{font-style:italic;color:var(--musgo)}
.archive-shell .dek{font-family:var(--serif);font-size:19px;line-height:1.5;font-weight:300;color:#27332b;max-width:48ch;margin:0 0 32px}

.search-form{display:flex;align-items:center;border-bottom:1px solid var(--line-strong);padding:14px 0;gap:8px;max-width:560px;margin:0 0 24px}
.search-form input{flex:1;border:0;background:transparent;outline:none;font-family:var(--sans);font-size:16px;color:var(--ink);padding:6px 0}
.search-form button{background:var(--bosque);color:var(--paper);border:0;padding:11px 18px;border-radius:99px;font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer}

/* ==========================================================
   Mobile menu (off-canvas)
   ========================================================== */
.mobile-menu{position:fixed;inset:0;background:var(--paper);z-index:60;display:none;flex-direction:column;padding:24px;overflow-y:auto}
.mobile-menu.is-open{display:flex}
.mobile-menu .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}
.mobile-menu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.mobile-menu ul a{font-family:var(--serif);font-size:34px;font-weight:400;color:var(--ink);letter-spacing:-.015em}
.mobile-menu .close{background:transparent;border:1px solid var(--line-strong);border-radius:99px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:7px 14px;color:var(--ink);cursor:pointer}

/* ==========================================================
   Responsive
   ========================================================== */
@media (max-width: 1100px){
  .hero-text h1{font-size:64px}
  .feat-text h2,.cat-feature h2{font-size:42px}
  .cat-hero h1{font-size:80px}
  .destinos-head h3,.purpose h3{font-size:42px}
  .art-body{grid-template-columns:1fr;max-width:680px;margin:0 auto;padding:48px 24px}
  .toc,.aside{position:static;border:0;padding:0}
  .toc{order:-1}
  .aside{margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
}
@media (max-width: 880px){
  .site-nav{padding:14px 20px}
  .site-nav .navlinks,.site-nav .nav-actions{display:none}
  .menu-toggle{display:inline-flex}
  .hero,.feat,.cats,.destinos,.latest,.purpose,.news,.foot,.cat-hero,.cat-feature,.cat-list,.related-cats,.archive-shell,.art-head,.art-end-cta{padding-left:20px;padding-right:20px}
  .hero-grid{grid-template-columns:1fr;border-bottom:0}
  .hero-img{border-left:0;border-top:1px solid var(--line);min-height:380px;aspect-ratio:5/4}
  .hero-text{padding:24px 0 48px}
  .hero-text h1{font-size:46px}
  .feat,.cat-feature,.purpose-grid,.news,.cat-hero,.destinos-head{grid-template-columns:1fr;gap:32px}
  .cat-hero{padding-bottom:32px}
  .cat-meta{align-items:flex-start;text-align:left}
  .cats-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .cat-tile{min-height:160px}
  .cat-tile.feature{grid-column:auto;grid-row:auto;min-height:280px}
  .destinos-grid{grid-template-columns:1fr 1fr}
  .destino.d1,.destino.d2,.destino.d3,.destino.d4,.destino.d5{grid-column:span 1}
  .destino.d4{grid-column:span 2}
  .destino .img{aspect-ratio:4/5 !important}
  .destino.d4 .img{aspect-ratio:7/4 !important}
  .articles{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .art-head h1{font-size:36px}
  .cat-hero h1{font-size:54px}
  .feat-text h2,.cat-feature h2,.destinos-head h3,.purpose h3{font-size:34px}
  .latest-head h3,.cats-head h3{font-size:26px}
  .prose{font-size:17px;line-height:1.65}
  .prose h2{font-size:26px;margin:32px 0 12px}
  .prose blockquote{font-size:22px;padding-left:16px}
  .rcat-grid{grid-template-columns:1fr 1fr}
  .purpose .stats{grid-template-columns:1fr;border-top:0}
  .purpose .stat{border-right:0;border-bottom:1px solid rgba(246,241,232,.18);padding:18px 0}
}
@media (max-width: 480px){
  .foot-grid{grid-template-columns:1fr}
  .destinos-grid{grid-template-columns:1fr}
  .destino.d4{grid-column:span 1}
  .strip{padding-left:20px;padding-right:20px}
}

/* WP admin bar offset */
body.admin-bar .site-nav{top:32px}
body.admin-bar .progress-bar{top:105px}
@media (max-width:782px){body.admin-bar .site-nav{top:46px}body.admin-bar .progress-bar{top:119px}}
