/* GangaTop — sistema de diseño midnight (compartido por toda la web pública).
   Tokens y componentes reutilizables: nav, hero, buscador, tarjetas, mercados, fiabilidad,
   badges, contenido editorial, footer, estados de carga/vacío/error, responsive. */
:root{
  --bg:#0a0d13; --panel:#141925; --panel2:#1b2230; --border:#252d3d;
  --text:#dfe6f0; --dim:#8a94a6; --accent:#4c8dff; --accent2:#9b7bff;
  --good:#2ecc71; --bad:#ff5c6c; --warn:#ffb648;
  --radius:14px; --gap:16px;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Consolas,monospace;
  --maxw:1040px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.55;
  -webkit-font-smoothing:antialiased;padding-bottom:64px}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:40;background:rgba(10,13,19,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);padding-top:env(safe-area-inset-top)}
/* foco visible accesible (teclado) */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
input:focus-visible,input:focus{box-shadow:0 0 0 3px rgba(76,141,255,.18)}
.topbar .inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:6px;
  padding:11px 22px;flex-wrap:wrap}
.topbar .brand{font-weight:800;font-size:17px;display:inline-flex;align-items:center;gap:8px;margin-right:8px}
.topbar .brand .logo{width:24px;height:24px;flex:none}
.topbar .spacer{flex:1}
.topbar .nav-link{font-size:13.5px;font-weight:600;color:var(--dim);padding:7px 11px;border-radius:9px;
  border:1px solid transparent;white-space:nowrap}
.topbar .nav-link:hover{color:var(--text);background:var(--panel)}
.topbar .nav-link.active{color:var(--text);background:var(--panel);border-color:#2a4a86}
.topbar .cta{background:var(--accent);color:#06101f;font-weight:800;border:none;border-radius:9px;
  padding:8px 14px;font-size:13px;cursor:pointer}
.topbar .cta:hover{filter:brightness(1.08)}
@media(max-width:760px){.topbar .nav-link.collapse{display:none}.topbar .brand{font-size:15px}}

/* ---------- Bottom tab bar (móvil) ---------- */
.tabbar{display:none}
@media(max-width:760px){
  .tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:rgba(15,19,28,.97);
    border-top:1px solid var(--border);backdrop-filter:blur(8px);padding-bottom:env(safe-area-inset-bottom)}
  .tabbar a{flex:1;text-align:center;padding:9px 2px 8px;font-size:10.5px;color:var(--dim);font-weight:600}
  .tabbar a .ic{display:block;font-size:19px;line-height:1.2}
  .tabbar a.active{color:var(--accent)}
  body{padding-bottom:64px}
}

/* ---------- Hero + buscador ---------- */
.hero{text-align:center;padding:46px 0 18px}
.hero h1{font-size:34px;font-weight:800;letter-spacing:-.5px;line-height:1.15}
.hero h1 .grad{background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .sub{font-size:16px;color:var(--dim);margin-top:12px;max-width:620px;margin-left:auto;margin-right:auto}
.search{display:grid;grid-template-columns:1fr auto;gap:10px;max-width:740px;margin:26px auto 8px}
@media(max-width:560px){.search{grid-template-columns:1fr}}
.search input{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:12px;color:var(--text);
  font-size:16px;padding:16px 18px;font-family:var(--font)}
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(76,141,255,.16)}
.search button{background:var(--accent);color:#06101f;border:none;border-radius:12px;font-weight:800;font-size:15px;
  padding:16px 30px;cursor:pointer;white-space:nowrap}
.search button:hover{filter:brightness(1.08)}
.routehint{text-align:center;font-size:12.5px;color:var(--dim);max-width:740px;margin:0 auto}
.routehint b{color:var(--text);font-weight:600}
.chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:14px auto 0}
.chip{font-size:12.5px;color:var(--dim);background:var(--panel);border:1px solid var(--border);
  border-radius:999px;padding:6px 13px;cursor:pointer}
.chip:hover{color:var(--text);border-color:var(--accent)}
#rpreview{text-align:center;font-size:12.5px;min-height:18px;margin:8px auto 0;color:var(--accent)}

/* ---------- Banda de confianza ---------- */
.trust{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:18px auto 0;font-size:12.5px;color:var(--dim)}
.trust .t{display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);
  border-radius:999px;padding:6px 13px}
.trust .t b{color:var(--text);font-weight:700}

/* ---------- Secciones ---------- */
section{padding:40px 0}
.sec-h{font-size:22px;font-weight:800;text-align:center;margin-bottom:6px}
.sec-sub{font-size:14px;color:var(--dim);text-align:center;max-width:640px;margin:0 auto 26px}

/* ---------- Tarjetas de herramientas ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
@media(max-width:680px){.cards{grid-template-columns:1fr}}
.card{display:flex;gap:15px;align-items:flex-start;background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;cursor:pointer;transition:transform .12s,border-color .12s,box-shadow .12s}
.card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 26px rgba(0,0,0,.35)}
.card .ic{font-size:32px;flex:none;width:52px;height:52px;display:flex;align-items:center;justify-content:center;
  background:var(--panel2);border:1px solid var(--border);border-radius:12px}
.card .ct{font-size:16.5px;font-weight:800;display:flex;align-items:center;gap:7px}
.card .ct .arr{color:var(--dim);font-weight:600;transition:transform .12s}
.card:hover .ct .arr{transform:translateX(3px);color:var(--accent)}
.card .cd{font-size:13px;color:var(--dim);margin-top:5px}
.card .tag{display:inline-block;font-size:10.5px;font-family:var(--mono);color:var(--accent2);
  background:#0c1018;border:1px solid var(--border);border-radius:6px;padding:1px 7px;margin-top:8px}

/* ---------- Pasos / diferenciador ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
@media(max-width:680px){.steps{grid-template-columns:1fr}}
.step{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}
.step .n{width:34px;height:34px;border-radius:50%;background:var(--panel2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--accent);margin:0 auto 10px}
.step h4{font-size:15px;margin-bottom:5px}
.step p{font-size:13px;color:var(--dim)}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px}

/* ---------- Badges / semáforo ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;font-family:var(--mono);
  border-radius:6px;padding:2px 8px;border:1px solid var(--border)}
.badge.medido{color:var(--good);background:rgba(46,204,113,.1);border-color:rgba(46,204,113,.35)}
.badge.orient{color:var(--warn);background:rgba(255,182,72,.1);border-color:rgba(255,182,72,.35)}
.sem{display:inline-flex;align-items:center;gap:6px;font-weight:700;border-radius:8px;padding:4px 10px;font-size:13px}
.sem.ok{color:var(--good);background:rgba(46,204,113,.1)}
.sem.warn{color:var(--warn);background:rgba(255,182,72,.1)}
.sem.bad{color:var(--bad);background:rgba(255,92,108,.1)}

/* ---------- Contenido editorial (guías) ---------- */
.article{max-width:760px;margin:0 auto;padding:34px 0}
.article h1{font-size:28px;font-weight:800;line-height:1.2;margin-bottom:18px;letter-spacing:-.4px}
.article h2{font-size:21px;font-weight:800;margin:30px 0 10px}
.article h3{font-size:16.5px;font-weight:700;margin:22px 0 8px;color:#eef2f8}
.article h4{font-size:14.5px;font-weight:700;margin:18px 0 6px;color:var(--accent2)}
.article p{margin:11px 0;color:#cfd7e3}
.article ul,.article ol{margin:11px 0 11px 22px;color:#cfd7e3}
.article li{margin:6px 0}
.article strong{color:var(--text)}
.article blockquote{border-left:3px solid var(--accent);background:var(--panel);border-radius:0 10px 10px 0;
  padding:12px 16px;margin:16px 0;color:var(--dim);font-style:italic}
.article hr{border:none;border-top:1px solid var(--border);margin:24px 0}
.article a{color:var(--accent)}
.article a:hover{text-decoration:underline}
.crumb{font-size:12.5px;color:var(--dim);margin-bottom:6px}
.crumb a:hover{color:var(--accent)}

/* ---------- Estados ---------- */
.loading{text-align:center;color:var(--dim);font-size:14px;padding:30px}
.skeleton{background:linear-gradient(90deg,var(--panel) 25%,var(--panel2) 50%,var(--panel) 75%);
  background-size:200% 100%;animation:sk 1.3s infinite;border-radius:10px}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.empty,.error{text-align:center;color:var(--dim);font-size:14px;background:var(--panel);
  border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.error{color:var(--bad);border-color:rgba(255,92,108,.35)}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--border);margin-top:30px;padding:34px 0 24px;background:#080a0f}
.site-footer .cols{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:24px;max-width:var(--maxw);
  margin:0 auto;padding:0 22px}
@media(max-width:680px){.site-footer .cols{grid-template-columns:1fr 1fr}}
.site-footer .fb{font-weight:800;font-size:15px;display:flex;align-items:center;gap:7px}
.site-footer .ftag{font-size:12px;color:var(--dim);margin-top:8px}
.site-footer h5{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);margin-bottom:10px}
.site-footer a{display:block;font-size:13px;color:#c2cad6;padding:4px 0}
.site-footer a:hover{color:var(--accent)}
.afil{max-width:var(--maxw);margin:24px auto 0;padding:14px 22px 0;border-top:1px solid var(--border);
  font-size:11.5px;color:var(--dim);text-align:center}
.afil b{color:#c2cad6}
.disc{display:inline-block;font-size:11px;color:var(--good);margin-top:8px}
