/* Mapa de Interesses — tema Hostmoz (design original) */
:root{
  --navy:#003048; --navy-2:#304860; --navy-3:#16314a;
  --gold:#F0A818; --gold-2:#F0C048; --gold-soft:#fff5e0;
  --ink:#1d2733; --muted:#6b7891; --line:#e4e8ef; --bg:#f5f7fa; --white:#fff;
  /* categorias de nós */
  --cat-entity:#F0A818; --cat-officer:#2E6DB4; --cat-intermediary:#16A085;
  --cat-address:#8E6FC0; --cat-other:#8a98ad;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--gold)}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 20px}

/* ---------- Navbar ---------- */
.nav{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav-inner{display:flex;align-items:center;gap:24px;height:68px}
.nav-logo img{height:38px;display:block}
.nav-links{display:flex;gap:22px;margin-left:8px}
.nav-links a{color:var(--navy);font-size:14px;font-weight:500}
.nav-links a:hover{color:var(--gold)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:8px;
  padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-2);color:var(--navy)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--navy)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-3) 60%,#0b2236 100%);
  color:#fff;padding:72px 0 84px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;
  border-radius:50%;border:60px solid rgba(240,168,24,.10)}
.hero h1{font-size:42px;line-height:1.1;margin:0 0 14px;max-width:760px;font-weight:800}
.hero h1 .hl{color:var(--gold)}
.hero p.lead{font-size:18px;color:#c7d3e0;max-width:640px;margin:0 0 30px}
.searchbar{display:flex;background:#fff;border-radius:12px;overflow:hidden;max-width:720px;
  box-shadow:0 18px 40px rgba(0,0,0,.25)}
.searchbar input{flex:1;border:none;padding:18px 20px;font-size:16px;color:var(--ink);outline:none}
.searchbar button{border:none;background:var(--gold);color:var(--navy);padding:0 26px;font-size:16px;
  font-weight:700;cursor:pointer}
.searchbar button:hover{background:var(--gold-2)}
.hero .examples{margin-top:14px;font-size:13px;color:#9fb0c2}
.hero .examples a{color:#cfe0f0;border-bottom:1px dotted #5b7390;margin:0 4px}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:-46px auto 0;position:relative;z-index:5}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center;
  box-shadow:0 6px 18px rgba(16,40,70,.06)}
.stat .num{font-size:30px;font-weight:800;color:var(--navy)}
.stat .num span{color:var(--gold)}
.stat .lbl{font-size:13px;color:var(--muted);margin-top:4px}

/* ---------- Sections / cards ---------- */
section.block{padding:54px 0}
.section-title{font-size:24px;font-weight:800;color:var(--navy);margin:0 0 6px}
.section-sub{color:var(--muted);margin:0 0 26px;font-size:15px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:.15s;display:block}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(16,40,70,.12);border-color:#d7deea}
.card .card-top{height:8px;background:linear-gradient(90deg,var(--gold),var(--gold-2))}
.card .card-body{padding:20px}
.card h3{margin:0 0 8px;color:var(--navy);font-size:18px}
.card p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.card .meta{margin-top:14px;font-size:12px;color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:.04em}

/* ---------- Disclaimer banner ---------- */
.disclaimer{background:var(--gold-soft);border:1px solid #f0d9a8;color:#7a5a12;
  border-radius:10px;padding:12px 16px;font-size:13px;margin:18px 0}
.disclaimer b{color:#5d4509}

/* ---------- Footer ---------- */
footer.ft{background:var(--navy);color:#c7d3e0;padding:42px 0 28px;margin-top:30px}
footer.ft .ft-grid{display:flex;gap:40px;flex-wrap:wrap;align-items:flex-start}
footer.ft img{height:40px;background:#fff;border-radius:8px;padding:6px 10px}
footer.ft a{color:#cfe0f0}
footer.ft .small{font-size:12px;color:#8aa0b6;margin-top:18px;border-top:1px solid #1d4661;padding-top:16px}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:13px;color:var(--muted);padding:18px 0 0}
.crumb a{color:var(--navy)} .crumb b{color:var(--ink)}

/* ---------- Entity page ---------- */
.entity-head{display:flex;align-items:flex-start;gap:16px;padding:14px 0 22px}
.entity-ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:26px;color:#fff;flex:0 0 auto}
.entity-head h1{margin:0;font-size:26px;color:var(--navy)}
.badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:3px 10px;border-radius:20px;color:#fff;margin-top:6px}
.layout2{display:grid;grid-template-columns:1fr 300px;gap:26px;align-items:start;padding-bottom:50px}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border:1px solid var(--line);
  border-radius:12px;overflow:hidden;margin-bottom:22px}
.meta-grid .mi{padding:14px 18px;border-bottom:1px solid var(--line)}
.meta-grid .mi:nth-child(odd){border-right:1px solid var(--line)}
.meta-grid .mk{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.meta-grid .mv{font-size:15px;color:var(--ink);margin-top:3px;font-weight:600}

/* tabs */
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--line);margin-bottom:0}
.tab{padding:12px 22px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-2px}
.tab.active{color:var(--navy);border-bottom-color:var(--gold)}
.tab .c{color:var(--muted);font-weight:500}
.panel-view{background:#fff;border:1px solid var(--line);border-top:none;border-radius:0 0 12px 12px}

/* graph stage */
.graph-wrap{position:relative;height:560px}
#cy{position:absolute;inset:0}
.graph-tools{position:absolute;right:14px;top:14px;display:flex;flex-direction:column;gap:6px;z-index:6}
.graph-tools button{width:36px;height:36px;border:1px solid var(--line);background:#fff;border-radius:8px;
  font-size:16px;cursor:pointer;color:var(--navy);box-shadow:0 2px 6px rgba(0,0,0,.06)}
.graph-tools button:hover{border-color:var(--gold);color:var(--gold)}
.legend2{position:absolute;left:14px;bottom:14px;background:rgba(255,255,255,.95);border:1px solid var(--line);
  border-radius:10px;padding:10px 12px;font-size:12px;z-index:6;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.legend2 .li{display:flex;align-items:center;gap:7px;margin:3px 0}
.legend2 .dot{width:11px;height:11px;border-radius:50%}
.graph-hint{position:absolute;left:14px;top:14px;background:rgba(255,255,255,.92);border:1px solid var(--line);
  border-radius:8px;padding:6px 10px;font-size:12px;color:var(--muted);z-index:6}

/* tables */
.conn-group{padding:18px 22px}
.conn-group h4{margin:0 0 10px;color:var(--navy);font-size:16px}
.conn-group h4 .c{color:var(--muted);font-weight:500;font-size:14px}
table.conn{width:100%;border-collapse:collapse;font-size:14px}
table.conn th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;
  letter-spacing:.03em;padding:8px 10px;border-bottom:2px solid var(--line)}
table.conn td{padding:10px;border-bottom:1px solid var(--line)}
table.conn tr:hover td{background:#f9fbfd}
table.conn .name{font-weight:600;color:var(--navy)}
.pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:12px;background:#eef2f7;color:var(--navy-2)}

/* sidebar */
.side .box{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:18px}
.side .box h4{margin:0 0 8px;color:var(--navy);font-size:15px}
.side .box p,.side .box li{color:var(--muted);font-size:13px;line-height:1.5}
.side .box ul{margin:6px 0 0;padding-left:18px}

/* property panel (graph) reused */
.panel{position:absolute;width:250px;background:#fff;border:1px solid var(--line);border-radius:12px;z-index:8;
  display:none;box-shadow:0 12px 30px rgba(16,40,70,.18);overflow:hidden}
.panel-head{display:flex;align-items:center;gap:10px;padding:12px;border-left:4px solid #888;background:#f7f9fc}
.panel-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:15px;color:#fff;flex:0 0 auto}
.panel-title{font-size:14px;font-weight:700;color:var(--navy);line-height:1.2}
.panel-sub{font-size:11px;color:var(--muted)}
.panel-x{margin-left:auto;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}
.panel-tbl{width:100%;border-collapse:collapse;font-size:13px}
.panel-tbl th{text-align:left;color:var(--muted);font-weight:500;padding:7px 12px;width:42%}
.panel-tbl td{padding:7px 12px;text-align:right;color:var(--ink)}
.panel-tbl tr+tr{border-top:1px solid var(--line)}
.panel-foot{padding:9px 12px;font-size:11px;color:var(--muted);border-top:1px solid var(--line)}

/* ---------- Nav search (present on every page) ---------- */
.nav-search{display:flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.nav-search input{border:none;outline:none;padding:8px 10px;font-size:13px;width:190px;color:var(--ink)}
.nav-search button{border:none;background:var(--navy);color:#fff;padding:8px 12px;cursor:pointer}
.nav-search button:hover{background:var(--gold);color:var(--navy)}

/* ---------- Graph fullscreen ---------- */
.graph-wrap:fullscreen,.graph-wrap:-webkit-full-screen{width:100vw;height:100vh;border-radius:0;border:none}

@media(max-width:900px){
  .nav-search input{width:130px}
  .stats{grid-template-columns:repeat(2,1fr)} .cards{grid-template-columns:1fr}
  .layout2{grid-template-columns:1fr} .nav-links{display:none}
  .hero h1{font-size:32px}
}
