:root {
  --blue-900:#0A2D5C; --blue-800:#0E3F84; --blue-700:#0B5FBE; --blue-600:#1976E0;
  --blue-500:#3D8FF1; --blue-300:#9CC4F4; --blue-100:#E5F0FC; --blue-50:#F4F8FE;
  --teal:#06B6D4; --green:#10B981; --amber:#F59E0B; --coral:#FB7185; --violet:#7C3AED;
  --ink:#0B1220; --ink-2:#1E293B; --gray-700:#334155; --gray-500:#64748B; --gray-400:#94A3B8;
  --gray-300:#CBD5E1; --gray-200:#E2E8F0; --gray-100:#F1F5F9; --gray-50:#F8FAFC;
  --paper:#FAFBFD; --white:#FFFFFF;
  --primary:var(--blue-700); --primary-dark:var(--blue-800); --primary-soft:var(--blue-100);
  --r-sm:6px; --r-md:10px; --r-lg:14px; --r-xl:20px;
  --pad-x:24px; --pad-y:18px; --row-h:64px;
  --shadow-sm:0 1px 2px rgba(11,18,32,.05),0 0 0 1px rgba(11,18,32,.04);
  --shadow:0 4px 14px rgba(11,18,32,.06),0 0 0 1px rgba(11,18,32,.05);
  --shadow-lg:0 24px 60px -20px rgba(11,18,32,.18),0 0 0 1px rgba(11,18,32,.05);
  --font-h:'Outfit','Plus Jakarta Sans',ui-sans-serif,system-ui,sans-serif;
  --font-b:'DM Sans','Plus Jakarta Sans',ui-sans-serif,system-ui,sans-serif;
  --font-m:'JetBrains Mono',ui-monospace,monospace;
}
[data-density="compact"]{--pad-x:16px;--pad-y:12px;--row-h:52px;}
[data-density="comfy"]{--pad-x:32px;--pad-y:24px;--row-h:76px;}

*{box-sizing:border-box}
html,body,#app{height:100%}
body{margin:0;font-family:var(--font-b);font-size:14px;line-height:1.5;color:var(--ink);
  background:var(--paper);-webkit-font-smoothing:antialiased;}
button{font-family:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-h);font-weight:600;letter-spacing:-0.012em;margin:0;color:var(--ink)}
.mono{font-family:var(--font-m)}

/* layout shell — TOP NAV layout */
.shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.topnav{background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;
  padding:0 22px;gap:18px;flex-shrink:0;height:68px;z-index:10;
  box-shadow:0 1px 0 rgba(11,18,32,.02)}
.tn-brand{display:flex;align-items:center;gap:12px}
.tn-mark{height:42px;width:42px;border-radius:10px;background:linear-gradient(135deg,var(--blue-500),var(--teal));
  display:grid;place-items:center;color:#fff;flex-shrink:0;
  box-shadow:0 4px 14px rgba(13,143,229,.45),inset 0 1px 0 rgba(255,255,255,.3)}
.tn-sub-only{font-size:10.5px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.1em;font-weight:600;line-height:1.2}
.tn-divider{width:1px;height:30px;background:var(--gray-200)}
.tn-menu{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none}
.tn-menu::-webkit-scrollbar{display:none}
.tn-item{padding:9px 13px;border-radius:9px;font-weight:500;font-size:13.5px;color:var(--gray-700);
  cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .12s;position:relative;white-space:nowrap;flex-shrink:0}
.tn-item:hover{background:var(--gray-50);color:var(--ink)}
.tn-item.active{background:var(--blue-100);color:var(--blue-800)}
.tn-item .badge{margin-left:4px;background:var(--gray-200);color:var(--gray-700);
  font-size:10.5px;padding:1px 7px;border-radius:99px;font-weight:600}
.tn-item.active .badge{background:var(--blue-700);color:#fff}
.tn-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.tn-search{position:relative;width:38px;height:38px;flex-shrink:0;transition:width .22s ease}
.tn-search.is-open{width:260px}
.tn-search-btn{position:absolute;left:0;top:0;width:38px;height:38px;border-radius:9px;
  border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-600);
  display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:all .15s}
.tn-search-btn:hover{background:#fff;color:var(--ink);border-color:var(--gray-300)}
.tn-search.is-open .tn-search-btn{background:transparent;border-color:transparent;color:var(--gray-400);pointer-events:none}
.tn-search input{width:100%;height:38px;border:1px solid var(--gray-200);border-radius:9px;
  padding:0 14px 0 38px;font:inherit;font-size:13px;background:var(--gray-50);color:var(--ink);outline:none;
  opacity:0;pointer-events:none;transition:opacity .18s}
.tn-search.is-open input{opacity:1;pointer-events:auto;background:#fff;border-color:var(--blue-500);box-shadow:0 0 0 4px var(--blue-100)}

.sidebar-OFF{background:var(--blue-900);color:#E5F0FC;display:none}
.sb-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:10px}
.sb-mark{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--blue-500),var(--teal));
  display:grid;place-items:center;color:#fff;font-family:var(--font-h);font-weight:700;font-size:15px;letter-spacing:.5px;flex-shrink:0;
  box-shadow:0 4px 14px rgba(13,143,229,.45),inset 0 1px 0 rgba(255,255,255,.3)}
.sb-brand-name{font-family:var(--font-h);font-weight:600;font-size:13.5px;line-height:1.2;letter-spacing:-0.01em}
.sb-brand-sub{font-size:10.5px;color:rgba(229,240,252,.55);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.sb-section-label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(229,240,252,.45);padding:14px 8px 6px}
.sb-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;color:rgba(229,240,252,.78);
  font-weight:500;cursor:pointer;font-size:13.5px;transition:background .12s,color .12s}
.sb-item:hover{background:rgba(255,255,255,.05);color:#fff}
.sb-item.active{background:rgba(255,255,255,.1);color:#fff;
  box-shadow:inset 3px 0 0 var(--teal),0 1px 0 rgba(255,255,255,.05)}
.sb-item .ico{width:18px;height:18px;display:grid;place-items:center;color:rgba(229,240,252,.6);flex-shrink:0}
.sb-item.active .ico{color:var(--teal)}
.sb-item .badge{margin-left:auto;background:rgba(255,255,255,.1);color:rgba(229,240,252,.7);font-size:11px;
  padding:1px 7px;border-radius:99px;font-weight:600}
.sb-item.active .badge{background:var(--teal);color:#062a3a}
.sb-foot{margin-top:auto;padding:12px 8px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;
  color:rgba(229,240,252,.5);line-height:1.5}
.sb-foot strong{color:rgba(229,240,252,.85);font-weight:600}

/* main */
.main{display:flex;flex-direction:column;min-width:0;background:var(--paper);overflow:hidden}
.topbar{height:64px;background:#fff;border-bottom:1px solid var(--gray-200);
  display:flex;align-items:center;padding:0 24px;gap:18px;flex-shrink:0;z-index:10}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-500);font-weight:500}
.crumbs strong{color:var(--ink);font-weight:600}
.crumbs .sep{color:var(--gray-300)}
.search{flex:1;max-width:520px;position:relative;margin-left:auto}
.search input{width:100%;height:38px;border:1px solid var(--gray-200);border-radius:9px;
  padding:0 14px 0 38px;font:inherit;font-size:13.5px;background:var(--gray-50);color:var(--ink);outline:none;
  transition:border-color .12s,background .12s}
.search input:focus{border-color:var(--blue-500);background:#fff;box-shadow:0 0 0 4px var(--blue-100)}
.search .icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--gray-400)}
.search kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);
  font-family:var(--font-m);font-size:11px;color:var(--gray-500);background:#fff;
  border:1px solid var(--gray-200);border-radius:5px;padding:2px 6px;font-weight:500}

.persona{display:flex;align-items:center;gap:8px;padding:5px 6px 5px 12px;background:var(--gray-50);
  border:1px solid var(--gray-200);border-radius:99px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--ink-2)}
.persona:hover{background:var(--blue-50);border-color:var(--blue-300)}
.persona-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(16,185,129,.18)}
.persona-name{}
.persona-arrow{color:var(--gray-400);font-size:10px}

.persona-panel{position:absolute;top:54px;right:24px;width:300px;background:#fff;border:1px solid var(--gray-200);
  border-radius:14px;box-shadow:var(--shadow-lg);z-index:50;padding:8px;font-size:13px;overflow:hidden}
.pp-head{padding:8px 10px 10px;font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.pp-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;cursor:pointer}
.pp-item:hover{background:var(--blue-50)}
.pp-item.active{background:var(--blue-100)}
.pp-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;
  background:var(--blue-100);color:var(--blue-700);font-weight:600}
.pp-name{font-weight:600;color:var(--ink)}
.pp-sub{font-size:11.5px;color:var(--gray-500);margin-top:1px}

/* content */
.content{flex:1;overflow-y:auto}
.page{padding:var(--pad-y) var(--pad-x);max-width:1640px;margin:0 auto}
.page-head{display:flex;align-items:flex-end;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.page-title{font-family:var(--font-h);font-size:28px;font-weight:600;letter-spacing:-0.02em;line-height:1.1}
.page-sub{color:var(--gray-500);font-size:14px;margin-top:6px;max-width:560px}
.page-actions{margin-left:auto;display:flex;gap:10px;align-items:center}

/* card */
.card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:var(--pad-y) var(--pad-x);
  box-shadow:var(--shadow-sm)}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card-title{font-family:var(--font-h);font-size:14px;font-weight:600;color:var(--ink)}
.card-sub{font-size:12px;color:var(--gray-500);margin-top:2px}
.card-link{font-size:12.5px;color:var(--blue-700);font-weight:500;cursor:pointer}
.card-link:hover{text-decoration:underline}

/* button */
.btn{appearance:none;border:0;height:38px;padding:0 16px;border-radius:9px;font:inherit;font-size:13px;
  font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .12s;letter-spacing:-0.005em}
.btn-primary{background:var(--blue-700);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 4px 14px rgba(11,95,190,.28)}
.btn-primary:hover{background:var(--blue-800);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink-2);border:1px solid var(--gray-200)}
.btn-ghost:hover{background:var(--gray-50);border-color:var(--gray-300)}
.btn-soft{background:var(--blue-100);color:var(--blue-700)}
.btn-soft:hover{background:var(--blue-300);color:var(--blue-800)}
.btn-sm{height:30px;padding:0 12px;font-size:12px;border-radius:7px}

/* badge */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:11.5px;
  font-weight:600;background:var(--gray-100);color:var(--gray-700);letter-spacing:.01em;line-height:1.4}
.badge-blue{background:var(--blue-100);color:var(--blue-800)}
.badge-green{background:#D1FAE5;color:#065F46}
.badge-amber{background:#FEF3C7;color:#92400E}
.badge-violet{background:#EDE9FE;color:#5B21B6}
.badge-pink{background:#FCE7F3;color:#9D174D}
.badge-mr{padding:2px 7px;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}

/* selo / chip */
.selo{display:inline-flex;align-items:center;gap:5px;padding:4px 10px 4px 7px;border-radius:99px;
  font-size:11px;font-weight:600;background:var(--gray-100);color:var(--gray-700);line-height:1.3}
.selo-ic{width:16px;height:16px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:9px;font-weight:700}

/* avatar */
.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;
  font-family:var(--font-h);font-size:13px;flex-shrink:0;letter-spacing:-0.02em}
.avatar-sm{width:30px;height:30px;font-size:11px}
.avatar-lg{width:64px;height:64px;font-size:20px}
.avatar-xl{width:96px;height:96px;font-size:30px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:18px 18px 16px;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.kpi-label{font-size:11.5px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.kpi-value{font-family:var(--font-h);font-size:30px;font-weight:600;line-height:1.05;margin-top:8px;letter-spacing:-0.02em}
.kpi-delta{font-size:11.5px;color:var(--green);font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:4px}
.kpi-delta.neg{color:var(--coral)}
.kpi-spark{position:absolute;right:14px;top:14px;opacity:.55}
.kpi-accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue-700)}
.kpi[data-color="green"] .kpi-accent{background:var(--green)}
.kpi[data-color="violet"] .kpi-accent{background:var(--violet)}
.kpi[data-color="amber"] .kpi-accent{background:var(--amber)}
.kpi[data-color="teal"] .kpi-accent{background:var(--teal)}

/* dashboard layout */
.dash-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:14px}
.dash-col{display:flex;flex-direction:column;gap:14px}
[data-dashboard="column"] .dash-grid{grid-template-columns:1fr}

/* hub feed */
.feed-grid{display:grid;grid-template-columns:1fr 360px;gap:14px}
.match-card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:18px;
  box-shadow:var(--shadow-sm);display:grid;grid-template-columns:1fr auto;gap:14px;align-items:flex-start;
  transition:all .14s;cursor:pointer;position:relative;overflow:hidden}
.match-card:hover{border-color:var(--blue-300);box-shadow:var(--shadow);transform:translateY(-1px)}
.match-card .accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--blue-500),var(--teal))}
.mc-tag{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-700);
  display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:6px;background:var(--blue-100)}
.mc-pair{display:flex;align-items:center;gap:10px;margin:10px 0 8px}
.mc-pair-arrow{width:24px;height:24px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);
  display:grid;place-items:center;flex-shrink:0;font-size:11px}
.mc-name{font-weight:600;font-size:13.5px;color:var(--ink)}
.mc-meta{font-size:11.5px;color:var(--gray-500)}
.mc-reason{font-size:13px;color:var(--gray-700);margin-top:6px;line-height:1.5}
.mc-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.mc-score{font-family:var(--font-h);font-size:22px;font-weight:600;color:var(--blue-700);letter-spacing:-0.02em;line-height:1}
.mc-score-lbl{font-size:10px;font-weight:600;color:var(--gray-500);letter-spacing:.08em;text-transform:uppercase}

/* map */
.map-shell{background:#fff;border:1px solid var(--gray-200);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);position:relative}
.map-canvas{position:relative;background:linear-gradient(180deg,#F4F8FE,#EAF1FB);min-height:680px}
.map-svg{width:100%;height:100%;display:block}
.map-side{border-left:1px solid var(--gray-200);overflow-y:auto;display:flex;flex-direction:column}
.map-side-h{padding:14px 16px;border-bottom:1px solid var(--gray-200);background:#fff;position:sticky;top:0;z-index:1}
.map-side-h h3{font-size:14px;margin-bottom:2px}
.map-side-h .sub{font-size:11.5px;color:var(--gray-500)}
.mun-row{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--gray-100);
  cursor:pointer;transition:background .12s;position:relative}
.mun-row:hover{background:var(--blue-50)}
.mun-row.active{background:var(--blue-100)}
.mun-row.active::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue-700)}
.mun-name{font-weight:600;font-size:13px;color:var(--ink)}
.mun-meta{font-size:11.5px;color:var(--gray-500);margin-top:2px}
.mun-bar{flex:1;height:5px;background:var(--gray-100);border-radius:99px;overflow:hidden;margin:0 10px;max-width:60px}
.mun-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--blue-700));border-radius:99px}
.mun-count{font-family:var(--font-m);font-size:12.5px;font-weight:600;color:var(--ink-2);min-width:24px;text-align:right}

.map-toolbar{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--gray-200);border-radius:10px;padding:4px;display:flex;gap:2px;box-shadow:var(--shadow-sm)}
.map-tool{padding:6px 10px;border-radius:7px;font-size:11.5px;font-weight:600;color:var(--gray-700);cursor:pointer}
.map-tool:hover{background:var(--gray-100)}
.map-tool.active{background:var(--blue-700);color:#fff}
.map-legend{position:absolute;bottom:14px;left:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--gray-200);border-radius:10px;padding:10px 12px;font-size:11px;box-shadow:var(--shadow-sm);max-width:220px}
.map-legend-h{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500);margin-bottom:6px}
.map-legend-row{display:flex;align-items:center;gap:7px;margin-bottom:3px}
.map-legend-dot{width:11px;height:11px;border-radius:3px}
.map-tooltip{position:absolute;background:var(--ink);color:#fff;padding:10px 12px;border-radius:9px;
  font-size:12px;pointer-events:none;box-shadow:var(--shadow-lg);max-width:240px;z-index:5}
.map-tooltip .name{font-weight:700;font-size:13px;margin-bottom:4px}
.map-tooltip .stats{display:grid;grid-template-columns:1fr 1fr;gap:4px 10px;color:rgba(255,255,255,.75);font-size:11px;margin-top:4px}
.map-tooltip .stats strong{color:#fff}

/* talent grid */
.talent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}
.talent-card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:18px;
  cursor:pointer;transition:all .14s;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.talent-card:hover{border-color:var(--blue-300);box-shadow:var(--shadow);transform:translateY(-2px)}
.talent-head{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.talent-name{font-family:var(--font-h);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-0.01em}
.talent-meta{font-size:12px;color:var(--gray-500);margin-top:2px}
.talent-resumo{font-size:12.5px;color:var(--gray-700);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}
.talent-selos{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.talent-foot{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--gray-100)}
.classif-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--gray-700);
  padding:3px 10px;border-radius:99px;background:var(--gray-50)}
.classif-pill .dot{width:7px;height:7px;border-radius:50%}
.pontos{margin-left:auto;font-family:var(--font-m);font-size:11.5px;color:var(--gray-500);font-weight:500}
.pontos strong{color:var(--ink);font-weight:700}

/* radar */
.radar-wrap{display:flex;align-items:center;gap:18px}
.radar svg{display:block}
.radar-legend{display:flex;flex-direction:column;gap:6px;font-size:11.5px}
.radar-legend-row{display:flex;align-items:center;gap:6px}
.radar-legend-dot{width:9px;height:9px;border-radius:2px;background:var(--blue-700)}
.radar-legend-name{color:var(--gray-700);font-weight:500}
.radar-legend-val{color:var(--ink);font-weight:700;font-family:var(--font-m);margin-left:auto}

/* trail / timeline */
.trail{display:flex;gap:0;align-items:center;overflow-x:auto;padding-bottom:6px;margin:6px 0}
.trail-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;min-width:120px;position:relative}
.trail-step::before{content:"";position:absolute;top:22px;left:50%;right:-50%;height:2px;
  background:linear-gradient(90deg,var(--blue-300),var(--gray-200));z-index:0}
.trail-step:last-child::before{display:none}
.trail-step.done::before{background:linear-gradient(90deg,var(--blue-700),var(--blue-500))}
.trail-bubble{width:44px;height:44px;border-radius:50%;background:#fff;border:2px solid var(--gray-200);
  display:grid;place-items:center;color:var(--gray-400);font-size:18px;font-weight:700;position:relative;z-index:1;
  font-family:var(--font-h)}
.trail-step.done .trail-bubble{background:linear-gradient(135deg,var(--blue-700),var(--teal));border-color:var(--blue-700);color:#fff;
  box-shadow:0 4px 14px rgba(11,95,190,.3)}
.trail-step.current .trail-bubble{background:#fff;border:2px solid var(--blue-700);color:var(--blue-700);
  box-shadow:0 0 0 4px var(--blue-100)}
.trail-label{font-size:11.5px;font-weight:600;color:var(--gray-700);text-align:center;line-height:1.3}
.trail-step.done .trail-label{color:var(--ink)}
.trail-step.current .trail-label{color:var(--blue-700)}

/* timeline (vertical) */
.tl{display:flex;flex-direction:column;gap:0;position:relative}
.tl::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:var(--gray-200)}
.tl-item{display:grid;grid-template-columns:24px 1fr auto;gap:12px;padding:8px 0;align-items:flex-start;position:relative}
.tl-dot{width:12px;height:12px;border-radius:50%;background:#fff;border:2.5px solid var(--blue-700);margin-top:6px;margin-left:5px;z-index:1}
.tl-tipo{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500)}
.tl-titulo{font-weight:600;color:var(--ink);margin-top:2px;font-size:13.5px}
.tl-resultado{font-size:12px;color:var(--gray-600);color:var(--gray-700);margin-top:2px}
.tl-side{font-family:var(--font-m);font-size:11.5px;color:var(--gray-500);font-weight:500}

/* network graph */
.network-shell{background:#fff;border:1px solid var(--gray-200);border-radius:14px;overflow:hidden;
  position:relative;height:620px}
.network-svg{width:100%;height:100%;display:block;background:radial-gradient(ellipse at center,#F4F8FE 0%,#fff 60%,#EAF1FB 100%)}
.net-legend{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--gray-200);border-radius:10px;padding:12px 14px;font-size:11.5px;box-shadow:var(--shadow-sm)}
.net-legend h4{font-size:11.5px;margin-bottom:6px}
.net-legend .row{display:flex;align-items:center;gap:7px;margin-bottom:4px}
.net-legend .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.net-info{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--gray-200);border-radius:10px;padding:12px 14px;font-size:11.5px;box-shadow:var(--shadow-sm);max-width:280px}

/* opportunity card */
.op-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:12px}
.op-card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:18px;
  position:relative;overflow:hidden;cursor:pointer;transition:all .14s;box-shadow:var(--shadow-sm)}
.op-card:hover{border-color:var(--blue-300);transform:translateY(-2px);box-shadow:var(--shadow)}
.op-tipo{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 8px;border-radius:6px;background:var(--blue-100);color:var(--blue-700);display:inline-block;margin-bottom:10px}
.op-tipo[data-t="edital"]{background:#D1FAE5;color:#065F46}
.op-tipo[data-t="hackathon"]{background:#FEF3C7;color:#92400E}
.op-tipo[data-t="programa"]{background:#EDE9FE;color:#5B21B6}
.op-tipo[data-t="evento"]{background:#FCE7F3;color:#9D174D}
.op-tipo[data-t="desafio"]{background:var(--blue-100);color:var(--blue-700)}
.op-tipo[data-t="mentoria"]{background:#CFFAFE;color:#0E7490}
.op-card h4{font-size:15px;font-family:var(--font-h);font-weight:600;letter-spacing:-0.01em}
.op-meta{display:flex;gap:14px;color:var(--gray-500);font-size:12px;margin-top:6px}
.op-desc{color:var(--gray-700);font-size:13px;line-height:1.5;margin-top:10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.op-bar{height:6px;background:var(--gray-100);border-radius:99px;margin-top:14px;overflow:hidden}
.op-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--blue-700),var(--teal));border-radius:99px}
.op-stats{display:flex;justify-content:space-between;margin-top:6px;font-size:11.5px;color:var(--gray-500)}
.op-stats strong{color:var(--ink);font-weight:600}

/* filter chips */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.chip{padding:6px 12px;border-radius:99px;font-size:12px;font-weight:500;color:var(--gray-700);
  background:#fff;border:1px solid var(--gray-200);cursor:pointer;transition:all .12s}
.chip:hover{border-color:var(--blue-300);color:var(--blue-700)}
.chip.active{background:var(--blue-700);border-color:var(--blue-700);color:#fff}
.chip-count{margin-left:5px;color:var(--gray-400);font-weight:500}
.chip.active .chip-count{color:rgba(255,255,255,.7)}

/* city info popover (anchored on map) */
.city-pop{position:absolute;width:420px;background:#fff;border:1px solid var(--gray-200);
  border-radius:14px;box-shadow:0 18px 50px rgba(11,18,32,.18);z-index:6;overflow:hidden;
  animation:popIn .2s cubic-bezier(.2,.8,.2,1)}
@keyframes popIn{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.city-pop-h{padding:14px 16px 12px;border-bottom:1px solid var(--gray-100);position:relative}
.city-pop-h h3{font-family:var(--font-h);font-size:17px;font-weight:600;letter-spacing:-0.01em;line-height:1.15}
.city-pop-h .meta{font-size:11.5px;color:var(--gray-500);margin-top:4px}
.city-pop-close{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:7px;
  border:0;background:var(--gray-100);color:var(--gray-700);cursor:pointer;display:grid;place-items:center;font-size:13px}
.city-pop-close:hover{background:var(--gray-200)}
.city-pop-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:10px 0;border-bottom:1px solid var(--gray-100)}
.city-pop-stat{padding:6px 12px;text-align:center;border-right:1px solid var(--gray-100)}
.city-pop-stat:last-child{border-right:0}
.city-pop-stat .v{font-family:var(--font-h);font-weight:600;font-size:18px;letter-spacing:-0.02em;color:var(--ink)}
.city-pop-stat .l{font-size:10px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-top:2px}
.city-pop-section{display:flex;align-items:center;gap:8px;padding:10px 16px;
  background:var(--gray-50);border-bottom:1px solid var(--gray-100)}
.city-pop-section-l{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;
  color:var(--blue-700);text-transform:uppercase;letter-spacing:.06em}
.city-pop-section-c{margin-left:auto;font-family:var(--font-m);font-weight:700;font-size:13px;
  color:var(--ink);background:#fff;padding:2px 9px;border-radius:99px;border:1px solid var(--gray-200)}
.city-pop-tabs{display:flex;gap:0;padding:0 12px;border-bottom:1px solid var(--gray-100);background:#fff}
.city-pop-tab{padding:10px 14px;font-size:12px;font-weight:600;color:var(--gray-500);cursor:pointer;
  border-bottom:2px solid transparent;display:inline-flex;align-items:center;gap:6px}
.city-pop-tab:hover{color:var(--ink)}
.city-pop-tab.active{color:var(--blue-700);border-bottom-color:var(--blue-700)}
.city-pop-tab .ct{background:var(--gray-100);color:var(--gray-700);font-size:10.5px;padding:1px 6px;border-radius:99px;font-weight:600}
.city-pop-tab.active .ct{background:var(--blue-100);color:var(--blue-700)}
.city-pop-filters{display:flex;flex-wrap:wrap;gap:5px;padding:10px 14px;background:var(--gray-50);border-bottom:1px solid var(--gray-100)}
.city-pop-filter{font-size:11px;font-weight:500;padding:3px 9px;border-radius:99px;background:#fff;
  border:1px solid var(--gray-200);color:var(--gray-700);cursor:pointer}
.city-pop-filter.active{background:var(--blue-700);border-color:var(--blue-700);color:#fff}
.city-pop-list{max-height:300px;overflow-y:auto;padding:4px 0}
.city-pop-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;border-bottom:1px solid var(--gray-100)}
.city-pop-item:last-child{border-bottom:0}
.city-pop-item:hover{background:var(--blue-50)}
.city-pop-empty{padding:24px 16px;text-align:center;font-size:12.5px;color:var(--gray-400)}

/* drawer / detail panel */
.detail-overlay{position:fixed;inset:0;background:rgba(11,18,32,.4);z-index:60;
  animation:fadeIn .18s ease}
.detail-panel{position:fixed;top:0;right:0;bottom:0;width:min(720px,92vw);background:#fff;
  z-index:61;box-shadow:-12px 0 60px rgba(11,18,32,.18);overflow-y:auto;
  animation:slideIn .24s cubic-bezier(.2,.8,.2,1)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Splash de carregamento — talentos convergindo para o centro */
#mrti-splash{position:fixed;inset:0;background:linear-gradient(180deg,#F4F8FE 0%,#EAF1FB 100%);z-index:999;
  display:flex;align-items:center;justify-content:center;animation:mrtiSplashOut .6s ease 3s forwards;pointer-events:none}
.mrti-splash-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.mrti-splash-svg .ring{animation:mrtiRing 1.1s ease forwards .1s}
.mrti-splash-svg .pins circle{transform-origin:center;transform:scale(0);animation:mrtiPin .4s cubic-bezier(.2,.8,.3,1.3) var(--d) forwards}
.mrti-splash-svg .lines{animation:mrtiLines .5s ease .55s forwards}
.mrti-splash-brand{text-align:center;opacity:0;animation:mrtiFadeUp .6s ease .8s forwards}
.mrti-splash-mark{font-family:'Outfit',sans-serif;font-weight:700;font-size:30px;letter-spacing:-0.02em;color:#0B5FBE;line-height:1}
.mrti-splash-sub{font-family:'DM Sans',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#64748B;font-weight:600;margin-top:6px}
@keyframes mrtiPin{0%{transform:scale(0)}60%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes mrtiRing{from{stroke-dashoffset:289;opacity:.25}to{stroke-dashoffset:0;opacity:.6}}
@keyframes mrtiLines{from{opacity:0}to{opacity:.35}}
@keyframes mrtiFadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes mrtiSplashOut{to{opacity:0;visibility:hidden}}
@keyframes slideIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}
.detail-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:8px;
  border:0;background:var(--gray-100);color:var(--gray-700);cursor:pointer;display:grid;place-items:center;font-size:16px}
.detail-close:hover{background:var(--gray-200)}
.detail-hero{padding:28px 32px 20px;background:linear-gradient(180deg,var(--blue-50),#fff);border-bottom:1px solid var(--gray-200)}
.detail-body{padding:24px 32px 60px;display:flex;flex-direction:column;gap:24px}
.detail-section{display:flex;flex-direction:column;gap:10px}
.detail-section h4{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gray-500);margin-bottom:4px}

/* CV (formação / experiência) */
.cv-list{display:flex;flex-direction:column;gap:10px}
.cv-item{display:flex;gap:11px;padding:11px 12px;border:1px solid var(--gray-200);border-radius:10px;background:#fff}
.cv-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.cv-title{font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.3}
.cv-org{font-size:12px;color:var(--gray-500);margin-top:2px}
.cv-desc{font-size:12px;color:var(--gray-700);margin-top:5px;line-height:1.45}
.cv-side{font-size:11.5px;color:var(--gray-500);text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-family:var(--font-m);flex-shrink:0;min-width:90px}
.cv-status,.cv-tipo{font-family:var(--font);font-size:10px;font-weight:600;padding:2px 7px;border-radius:99px;letter-spacing:.04em;text-transform:uppercase}
.cv-status.done{background:#D1FAE5;color:#065F46}
.cv-status.cur{background:var(--blue-100);color:var(--blue-800)}
.cv-tipo{background:var(--gray-100);color:var(--gray-700)}

/* city popover — make scrollable + mobile-friendly */
.city-pop{display:flex;flex-direction:column;max-height:calc(100vh - 100px)}
.city-pop-list{flex:1;min-height:0;overflow-y:auto}

/* mobile / small screens */
@media (max-width: 1180px){
  .tn-item .badge{display:none}
  .tn-item{padding:9px 11px;font-size:13px}
}
@media (max-width: 820px){
  .topnav{padding:0 14px;gap:10px;height:62px}
  .tn-divider{display:none}
  .tn-sub-only{display:none}
  .tn-search.is-open{width:200px}
  .tn-menu{gap:2px}
  .tn-item{padding:7px 9px;font-size:12.5px}
  .tn-item .badge{display:none}
  .persona-name{display:none}
  .persona{padding:5px 8px}
}
@media (max-width: 640px){
  .city-pop{position:fixed;left:0!important;right:0;top:auto!important;bottom:0;width:100%;
    max-height:80vh;border-radius:18px 18px 0 0;animation:popInBot .25s cubic-bezier(.2,.8,.2,1)}
  @keyframes popInBot{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
  .city-pop::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:42px;height:4px;background:var(--gray-300);border-radius:99px}
  .city-pop-h{padding-top:22px}
  .detail-panel{width:100vw}
  .map-toolbar{padding:3px;flex-wrap:wrap;max-width:calc(100vw - 28px)}
  .map-tool{padding:5px 8px;font-size:11px}
}

/* charts */
.spark{display:block}
.bar-row{display:grid;grid-template-columns:90px 1fr 36px;gap:10px;align-items:center;font-size:12px;margin-bottom:6px}
.bar-row .name{color:var(--gray-700);font-weight:500}
.bar-row .v{font-family:var(--font-m);color:var(--ink);font-weight:600;text-align:right}
.bar-row .bar{height:8px;border-radius:99px;background:var(--gray-100);overflow:hidden}
.bar-row .bar i{display:block;height:100%;border-radius:99px}

.map-allbtn-s{display:none}

@media (max-width: 820px){
  .map-allbtn-h{display:none}
}
@media (max-width: 640px){
  .map-toolbar{top:8px;left:8px;right:8px;max-width:none;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}
  .map-toolbar::-webkit-scrollbar{display:none}
  .map-tool{flex-shrink:0}
  .map-welcome{display:none}
  .map-legend{bottom:auto;top:60px;left:8px;padding:8px 10px;max-width:160px;font-size:10.5px}
  .map-allbtn{bottom:12px!important;right:12px!important;left:12px!important;justify-content:center;padding:13px 14px!important;font-size:13px!important}
  .map-allbtn-l{display:none}
  .map-allbtn-s{display:inline}
}

/* misc */
.section-title{font-family:var(--font-h);font-size:18px;font-weight:600;letter-spacing:-0.012em;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.section-sub{font-size:12.5px;color:var(--gray-500);font-weight:500}
.divider{height:1px;background:var(--gray-200);margin:14px 0}
.skill-tag{display:inline-block;padding:3px 9px;background:var(--gray-100);color:var(--gray-700);
  border-radius:6px;font-size:11.5px;font-weight:500}

/* network nodes */
.net-node{cursor:pointer;transition:transform .15s}
.net-node:hover{transform:scale(1.18)}
.net-node text{pointer-events:none;font-size:9px;font-weight:600;font-family:var(--font-h);fill:#fff;text-anchor:middle;dominant-baseline:central}

/* responsive */
@media (max-width:1100px){
  .feed-grid{grid-template-columns:1fr}
  .map-shell{grid-template-columns:1fr}
  .dash-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
}
