/* =========================================================================
   Colectivo Enlace Tarahumara — shared stylesheet
   Original palette & typography preserved from the homepage design.
   ========================================================================= */
:root{
  --night:#11201A;        /* pine night */
  --forest:#1E3527;       /* deep forest */
  --moss:#2E4B33;         /* moss green */
  --earth:#A6432B;        /* tierra colorada - the reddened earth */
  --earth-bright:#C2572F;
  --gold:#C99B4E;         /* maize / dusk light */
  --bone:#EDE4D3;         /* maize bone */
  --bone-dim:#C9BFAE;
  --line:rgba(237,228,211,.16);
  --maxw:1180px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Archivo',system-ui,sans-serif;
  --narrow:'Archivo Narrow','Archivo',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{
  background:var(--night);
  color:var(--bone);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.22em;
  font-size:12.5px;font-weight:600;color:var(--gold);
}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.01em}
a{color:inherit}

/* ---------- top bar ---------- */
header.nav{position:absolute;top:0;left:0;right:0;z-index:30}
header.nav.solid{position:sticky;background:rgba(10,19,15,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;max-width:var(--maxw);margin:0 auto}
.brand{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.2em;font-size:13px;font-weight:600;color:var(--bone);text-decoration:none}
.brand b{color:var(--gold);font-weight:600}
nav.links{display:flex;gap:26px;align-items:center}
nav.links a{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:500;color:var(--bone-dim);text-decoration:none;transition:color .25s;white-space:nowrap}
nav.links a:hover,nav.links a.active{color:var(--gold)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);color:var(--bone);padding:8px 12px;border-radius:3px;font-family:var(--narrow);letter-spacing:.14em;text-transform:uppercase;font-size:12px;cursor:pointer}
@media(max-width:860px){
  nav.links{
    position:absolute;top:100%;right:28px;left:28px;flex-direction:column;align-items:flex-start;gap:0;
    background:rgba(10,19,15,.98);border:1px solid var(--line);border-radius:6px;padding:8px;
    display:none;box-shadow:0 18px 50px rgba(0,0,0,.5)
  }
  nav.links.open{display:flex}
  nav.links a{padding:12px 14px;width:100%;font-size:13px}
  .nav-toggle{display:inline-block}
}

/* ---------- generic interior page hero ---------- */
.page-hero{
  position:relative;padding:150px 0 60px;
  background:
    radial-gradient(120% 90% at 78% 0%, rgba(201,155,78,.14), transparent 55%),
    radial-gradient(140% 120% at 12% 100%, rgba(166,67,43,.28), transparent 60%),
    linear-gradient(180deg,#0C1813 0%, #13241B 60%, #162A1F 100%);
  border-bottom:1px solid var(--line);
}
.page-hero .eyebrow{margin-bottom:14px}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.8rem);max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero .lede{margin-top:18px;max-width:60ch;color:var(--bone-dim);font-size:1.08rem}

/* ---------- generic section frame ---------- */
section{padding:72px 0;position:relative}
.section-soft{background:linear-gradient(180deg,#13241B,#101E18)}
.seclabel{display:flex;align-items:baseline;gap:16px;margin-bottom:30px}
.seclabel .num{font-family:var(--narrow);font-size:12px;letter-spacing:.2em;color:var(--earth-bright);font-weight:600}
.lead-serif{font-family:var(--serif);font-size:clamp(1.6rem,3.2vw,2.5rem);line-height:1.22;max-width:20ch}
.lead-serif em{font-style:italic;color:var(--gold)}

/* ---------- photo / document gallery ---------- */
.gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-top:8px;
}
.docs .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.gcard{
  position:relative;display:block;border:1px solid var(--line);border-radius:6px;overflow:hidden;
  background:#0d1813;cursor:zoom-in;text-decoration:none;color:inherit;
  transition:transform .3s, border-color .3s, box-shadow .3s;
}
.gcard:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 16px 40px rgba(0,0,0,.45)}
.gcard .ph{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;background:#0a130f}
.docs .gcard .ph{aspect-ratio:3/4}
.gcard figcaption{padding:13px 15px;font-size:.9rem;color:var(--bone-dim);line-height:1.4}
.gcard figcaption .t{display:block;font-family:var(--serif);color:var(--bone);font-size:1.02rem;margin-bottom:2px}
.empty-note{border:1px dashed var(--line);border-radius:8px;padding:40px;text-align:center;color:var(--bone-dim);margin-top:10px}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;background:rgba(6,11,9,.94);display:none;align-items:center;justify-content:center;z-index:100;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:82vh;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb .cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:var(--bone-dim);font-size:.95rem;padding:0 30px}
.lb .x,.lb .prev,.lb .next{position:absolute;background:rgba(20,34,27,.85);border:1px solid var(--line);color:var(--bone);width:48px;height:48px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.lb .x:hover,.lb .prev:hover,.lb .next:hover{border-color:var(--gold);color:var(--gold)}
.lb .x{top:24px;right:24px}
.lb .prev{left:24px;top:50%;transform:translateY(-50%)}
.lb .next{right:24px;top:50%;transform:translateY(-50%)}
@media(max-width:600px){.lb .prev,.lb .next{display:none}}

/* ---------- external links ---------- */
.link-list{margin-top:14px;border-top:1px solid var(--line)}
.link-row{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 6px;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;
  transition:padding-left .3s,background .25s;
}
.link-row:hover{padding-left:16px}
.link-row .lt{font-family:var(--serif);font-size:1.35rem;color:var(--bone);line-height:1.2;margin-bottom:4px}
.link-row:hover .lt{color:var(--gold)}
.link-row .ld{font-size:.95rem;color:var(--bone-dim);max-width:62ch}
.link-row .lhost{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--earth-bright);margin-top:6px;display:block}
.link-row .arrow{font-family:var(--serif);font-size:1.6rem;color:var(--earth-bright);flex:none}

/* ---------- videos ---------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:30px;margin-top:8px}
.vcard{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#0d1813}
.vframe{position:relative;width:100%;aspect-ratio:16/9;background:#0a130f}
.vframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vcard .vmeta{padding:16px 18px}
.vcard .vt{font-family:var(--serif);font-size:1.2rem;color:var(--bone);margin-bottom:6px;line-height:1.2}
.vcard .vd{font-size:.93rem;color:var(--bone-dim)}

/* ---------- audio / podcast ---------- */
.episode{border:1px solid var(--line);border-radius:10px;background:linear-gradient(180deg,#13241B,#0f1d16);padding:26px 28px;margin-bottom:28px}
.episode .etop{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.episode h2{font-size:1.7rem;color:var(--bone)}
.episode .edate{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--gold)}
.episode .edesc{color:var(--bone-dim);margin-bottom:18px;max-width:70ch}
.episode audio{width:100%;margin-bottom:8px;filter:saturate(.9)}
.transcript-toggle{
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:600;
  color:var(--gold);background:none;border:1px solid var(--line);padding:10px 18px;border-radius:3px;cursor:pointer;transition:all .2s;margin-top:8px
}
.transcript-toggle:hover{border-color:var(--gold)}
.transcript{display:none;margin-top:20px;padding-top:20px;border-top:1px solid var(--line);color:var(--bone-dim);white-space:pre-wrap;line-height:1.7;max-width:74ch}
.transcript.open{display:block}

/* ---------- contact form ---------- */
.contact-form{display:grid;gap:16px;max-width:620px;margin-top:10px}
.contact-form .field{display:flex;flex-direction:column;gap:6px}
.contact-form label{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--gold)}
.contact-form input,.contact-form textarea{
  background:#0d1813;border:1px solid var(--line);color:var(--bone);font-family:var(--sans);font-size:1rem;
  padding:13px 15px;border-radius:4px;transition:border-color .2s
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold)}
.contact-form textarea{min-height:140px;resize:vertical}
.notice{padding:14px 18px;border-radius:6px;margin-bottom:18px;font-size:.96rem}
.notice.ok{background:rgba(46,75,51,.4);border:1px solid var(--moss);color:var(--bone)}
.notice.err{background:rgba(166,67,43,.25);border:1px solid var(--earth);color:var(--bone)}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;font-size:13px;font-weight:600;
  padding:16px 30px;text-decoration:none;border-radius:2px;transition:all .25s;display:inline-block;border:none;cursor:pointer
}
.btn.solid{background:var(--earth);color:var(--bone)}
.btn.solid:hover{background:var(--earth-bright);transform:translateY(-2px)}
.btn.ghost{border:1px solid var(--line);color:var(--bone);background:none}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- footer ---------- */
footer{background:#0A130F;padding:64px 0 40px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:30px}}
.foot-grid h4{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--gold);margin-bottom:16px;font-weight:600}
.foot-brand{font-family:var(--serif);font-size:1.5rem;color:var(--bone);line-height:1.2;margin-bottom:12px}
.foot-brand em{font-style:italic;color:var(--gold)}
.foot-grid p,.foot-grid a{font-size:.94rem;color:var(--bone-dim);text-decoration:none;display:block;margin-bottom:8px}
.foot-grid a:hover{color:var(--gold)}
.legal{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);font-size:.82rem;color:var(--bone-dim);line-height:1.6}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- rich body (custom pages) ---------- */
.richbody{max-width:72ch;margin-top:8px}
.richbody p{margin-bottom:20px;color:var(--bone)}
.richbody h2{font-size:1.9rem;color:var(--bone);margin:34px 0 14px}
.richbody h3{font-size:1.4rem;color:var(--bone);margin:26px 0 10px}
.richbody ul,.richbody ol{margin:0 0 20px 22px;color:var(--bone-dim)}
.richbody li{margin-bottom:8px}
.richbody a{color:var(--gold);text-decoration:underline}
.richbody blockquote{border-left:2px solid var(--earth);padding-left:20px;font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.3rem;margin:24px 0}
.richbody img{max-width:100%;border-radius:6px;margin:18px 0}

/* ---- language switcher ------------------------------------------------- */
.lang-switch{display:inline-flex;align-items:center;gap:2px;margin-left:8px;
  padding-left:16px;border-left:1px solid var(--line)}
nav.links a.lang{font-size:11px;letter-spacing:.12em;color:var(--bone-dim);
  padding:3px 6px;border-radius:3px;line-height:1}
nav.links a.lang:hover{color:var(--bone)}
nav.links a.lang.on{color:var(--night);background:var(--gold)}
nav.links a.lang.on:hover{color:var(--night)}
@media(max-width:880px){
  .lang-switch{margin:6px 0 0;padding:10px 14px 0;border-left:none;
    border-top:1px solid var(--line);width:100%}
  nav.links a.lang{padding:6px 10px;width:auto}
}
