/* OBSERVATORIO AGETECH · sistema de diseño Syntropic v3.0
   papel técnico · tinta grafito · cobalto estructura · lima señal */
:root{
  --ink:#EAE7DE; --ink-2:#F5F3EC;
  --paper:#14181C; --cobalt:#1F3A6D; --cobalt2:#3E62A8; --cobalt-lt:#9FB4D8;
  --muted:#6B6E73; --muted-d:#54585E;
  --line:#D7D2C5; --line-dk:#28323A;
  --signal:#C6F24A; --sage:#4A6B4E; --clay:#9C5B33;
  --max:1120px;
  --disp:'Archivo',system-ui,sans-serif;
  --serif:'Zilla Slab',Georgia,serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;
  --body:'Archivo',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background-color:var(--ink);
  background-image:linear-gradient(rgba(20,24,28,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(20,24,28,.045) 1px,transparent 1px);
  background-size:32px 32px;
  color:var(--paper);font-family:var(--body);font-size:16.5px;line-height:1.62;
}
h1,h2,h3{font-family:var(--disp);font-weight:800;line-height:1.08;letter-spacing:-.01em;font-stretch:118%}
.wrap{max-width:var(--max);margin:0 auto;padding:0 40px}
@media(max-width:640px){.wrap{padding:0 20px}}
a{color:var(--cobalt);text-decoration:none}
::selection{background:var(--signal);color:var(--paper)}
.lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.serif{font-family:var(--serif)}
em.s{font-family:var(--serif);font-style:italic;color:var(--clay)}

/* ficha de sistema */
.systag{display:inline-flex;align-items:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;border:1px solid var(--cobalt);border-radius:4px;overflow:hidden;line-height:1;margin:2px 0;vertical-align:middle}
.systag span{padding:6px 9px}
.systag .k{background:var(--cobalt);color:var(--ink-2)}
.systag .v{color:var(--cobalt)}
.systag .s{background:var(--signal);color:var(--paper);font-weight:600}

/* NAV */
nav.top{position:sticky;top:0;z-index:50;background:rgba(234,231,222,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
nav.top .wrap{display:flex;align-items:center;justify-content:space-between;height:66px;gap:20px}
.brand{font-family:var(--disp);font-weight:800;font-size:17px;font-stretch:115%;display:flex;align-items:center;gap:10px;color:var(--paper)}
.brand .gl{width:26px;height:26px;flex:none}
.brand .ht{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-left:1px solid var(--line);padding-left:9px;font-weight:400}
.nlinks{display:flex;gap:22px;flex-wrap:wrap}
.nlinks a{font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted-d);padding-bottom:3px;border-bottom:1px solid transparent;transition:.2s}
.nlinks a:hover,.nlinks a.active{color:var(--paper);border-color:var(--clay)}
.nlinks a.ext{color:var(--cobalt);font-weight:500}
.nlinks a.ext:hover{color:var(--paper);border-color:var(--cobalt)}
@media(max-width:820px){.nlinks{gap:14px}.nlinks a{font-size:10.5px}.brand .ht{display:none}}
@media(max-width:520px){.nlinks a.ext{display:none}}

/* PAGE HEADER */
.phead{border-bottom:2px solid var(--paper);padding:54px 0 30px}
.phead .meta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.phead h1{font-size:clamp(28px,5vw,46px);max-width:20ch}
.phead .sub{font-family:var(--serif);font-size:19px;line-height:1.5;max-width:62ch;margin-top:16px}

section{padding:42px 0;border-bottom:1px solid var(--line)}
h2{font-size:clamp(21px,3.2vw,28px);margin-bottom:6px}
h2 .num{font-family:var(--mono);font-size:13px;color:var(--cobalt);font-weight:500;margin-right:9px}
h3{font-size:17px;margin:22px 0 6px;font-weight:700;font-stretch:110%}
p{margin:11px 0;max-width:72ch}
p.lead{font-family:var(--serif);font-size:18px}

/* módulos / cards */
.mod{background:var(--ink-2);border:1px solid var(--line);border-radius:8px;padding:20px 22px;margin:14px 0}
.mod.dark{background:var(--paper);color:var(--ink-2);border-color:var(--paper)}
.mod.dark .lbl{color:var(--cobalt-lt)}
.mod.dark .signal-txt{color:var(--signal)}
.mod.dark a{color:var(--cobalt-lt)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:820px){.grid3,.grid4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}

/* KPI */
.kpi{background:var(--ink-2);border:1px solid var(--line);border-radius:8px;padding:18px 18px 16px}
.kpi .v{font-family:var(--disp);font-stretch:118%;font-weight:800;font-size:38px;color:var(--cobalt);line-height:1}
.kpi.crit .v{color:var(--paper)}
.kpi.crit{background:var(--paper);border-color:var(--paper)}
.kpi.crit .v{color:var(--signal)}
.kpi.crit .k,.kpi.crit .c{color:var(--cobalt-lt)}
.kpi .k{display:block;margin-top:10px;font-size:13.5px;line-height:1.35;font-weight:600}
.kpi .c{display:block;margin-top:4px;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}

/* source chip */
.src{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;margin-top:8px}
.src::before{content:"↳ fuente";color:var(--cobalt);font-weight:500}
.src a{color:var(--muted);border-bottom:1px solid var(--line)}
.src a:hover{color:var(--cobalt)}

/* tablas */
table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px}
th,td{text-align:left;padding:9px 11px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1.5px solid var(--paper)}
td.mono{font-family:var(--mono);font-size:12px;color:var(--cobalt)}

/* listas */
ul.clean{list-style:none;margin:10px 0}
ul.clean li{padding:7px 0 7px 24px;position:relative;border-bottom:1px solid var(--line);max-width:74ch}
ul.clean li:last-child{border-bottom:0}
ul.clean li::before{content:"";position:absolute;left:3px;top:14px;width:7px;height:7px;background:var(--cobalt);border-radius:1px}
ul.clean li.crit::before{background:var(--signal);outline:1px solid var(--paper)}

.note{font-family:var(--mono);font-size:11.5px;color:var(--muted);border-left:2px solid var(--line);padding-left:12px;margin:13px 0;max-width:74ch}

/* viz container */
.viz{background:var(--paper);border:1px solid var(--paper);border-radius:10px;padding:22px;margin:16px 0;overflow-x:auto}
.viz .vtitle{font-family:var(--disp);font-weight:700;font-stretch:110%;font-size:16px;color:var(--ink-2);margin-bottom:3px}
.viz .vunit{font-family:var(--mono);font-size:10.5px;color:var(--cobalt-lt);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}
.viz svg{display:block;width:100%;height:auto;overflow:visible}
.viz .vsrc{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:12px}
.viz .vsrc a{color:var(--cobalt-lt)}

/* CTA */
.cta{display:inline-block;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--paper);border:1px solid var(--paper);border-radius:40px;padding:11px 22px;transition:.2s;margin-top:8px}
.cta:hover{background:var(--cobalt);border-color:var(--cobalt);color:var(--ink-2)}
.cta.sig:hover{background:var(--signal);border-color:var(--signal);color:var(--paper)}

footer.site{padding:40px 0 70px;background:var(--paper);color:var(--cobalt-lt);margin-top:0}
footer.site .wrap{display:flex;flex-direction:column;gap:14px}
footer.site a{color:var(--cobalt-lt);border-bottom:1px solid var(--line-dk)}
footer.site .fmono{font-family:var(--mono);font-size:11px;line-height:1.7}
footer.site h4{font-family:var(--disp);font-weight:700;color:var(--ink-2);font-size:15px;font-stretch:110%}

.audience{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin:16px 0}
.audience a{padding:16px 16px;border-right:1px solid var(--line);background:var(--ink-2);transition:.2s;color:var(--paper)}
.audience a:last-child{border-right:0}
.audience a:hover{background:var(--paper);color:var(--ink-2)}
.audience a:hover .lbl{color:var(--signal)}
.audience .who{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--cobalt)}
.audience a:hover .who{color:var(--cobalt-lt)}
.audience .do{display:block;margin-top:7px;font-size:13.5px;line-height:1.4}
@media(max-width:760px){.audience{grid-template-columns:1fr 1fr}.audience a{border-bottom:1px solid var(--line)}}
@media(max-width:440px){.audience{grid-template-columns:1fr}}
