:root{
  /* "clean swiss": branco, grayscale neutro, um acento cobalto, hairlines, zero textura */
  --bg:#ffffff; --bg-soft:#f5f6f8; --panel:#ffffff; --panel-2:#fafbfc;
  --line:#e6e8ec; --line-soft:#eef0f3; --line-strong:#d7dae0;
  --ink:#0a0c10; --ink-soft:#3d424d; --ink-mute:#767b86;
  --accent:#1b46e0; --accent-2:#1437b8; --accent-soft:rgba(27,70,224,.08);
  --gold:#9a6a12;
  --ok:#0f9d6b; --warn:#b16a09; --bad:#dc2c3f;
  --radius:10px; --radius-sm:7px;
  --shadow:0 1px 2px rgba(10,12,16,.04);
  --shadow-lift:0 10px 26px -16px rgba(10,12,16,.30);
  --sans:"Geist","Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --mono:"Geist Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  min-height:100vh;
}
.app,.topbar{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--accent-soft)}

/* layout */
.app{max-width:1180px;margin:0 auto;padding:0 24px 96px}
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:rgba(255,255,255,.82);border-bottom:1px solid var(--line)}
.topbar-in{max-width:1180px;margin:0 auto;padding:13px 24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer}
.brand .logo{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;
  background:var(--accent);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.brand .logo svg{width:22px;height:22px;display:block}
.brand h1{font-weight:700;font-size:20px;margin:0;letter-spacing:-.4px;color:var(--ink)}
.brand small{display:block;color:var(--ink-mute);font-size:11px;font-weight:500;letter-spacing:.2px;margin-top:1px}
.nav{display:flex;gap:3px;margin-left:auto;flex-wrap:wrap}
.nav a{padding:8px 13px;border-radius:7px;color:var(--ink-soft);font-weight:500;font-size:14px;transition:.14s;cursor:pointer;position:relative}
.nav a:hover{color:var(--ink);background:var(--bg-soft)}
.nav a.active{color:var(--accent);background:var(--accent-soft);font-weight:600}

/* page header */
.page-head{padding:44px 0 24px}
.page-head h2{font-weight:700;font-size:38px;margin:0 0 10px;color:var(--ink);letter-spacing:-1.1px;line-height:1.08}
.page-head p{color:var(--ink-soft);margin:0;max-width:680px;line-height:1.6;font-size:15px}
.eyebrow{font-family:var(--mono);color:var(--accent);font-weight:500;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:13px}

/* kpi */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:8px 0 30px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px 19px;transition:.14s}
.kpi:hover{border-color:var(--line-strong)}
.kpi .v{font-family:var(--mono);font-size:30px;font-weight:500;line-height:1;color:var(--ink);letter-spacing:-1px}
.kpi .l{color:var(--ink-mute);font-size:12.5px;margin-top:9px;font-weight:500}
.kpi .v.accent{color:var(--accent)} .kpi .v.gold{color:var(--gold)} .kpi .v.ok{color:var(--ok)}

/* cards & panels */
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:1.45fr .85fr}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.panel h3{font-weight:700;font-size:18px;margin:0 0 16px;display:flex;align-items:center;gap:9px;color:var(--ink);letter-spacing:-.3px}
.panel h3 .count{font-family:var(--mono);font-size:11.5px;color:var(--ink-mute);font-weight:500;
  background:var(--bg-soft);border:1px solid var(--line);padding:2px 8px;border-radius:6px;letter-spacing:0}

/* badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;
  padding:3px 9px;border-radius:6px;border:1px solid var(--line);white-space:nowrap;letter-spacing:.1px}
.badge.trib{color:#fff;border:none;font-weight:600}
.badge.status-vigente{background:rgba(15,157,107,.1);color:var(--ok);border-color:rgba(15,157,107,.24)}
.badge.status-transitado{background:var(--accent-soft);color:var(--accent);border-color:rgba(27,70,224,.22)}
.badge.status-afetado{background:rgba(177,106,9,.1);color:var(--warn);border-color:rgba(177,106,9,.26)}
.badge.imp-alto{background:rgba(220,44,63,.08);color:var(--bad);border-color:rgba(220,44,63,.24)}
.badge.imp-médio{background:rgba(177,106,9,.09);color:var(--warn);border-color:rgba(177,106,9,.24)}
.badge.prov-verificado{background:rgba(15,157,107,.09);color:var(--ok);border-color:rgba(15,157,107,.22)}
.badge.prov-ilustrativo{background:rgba(154,106,18,.1);color:var(--gold);border-color:rgba(154,106,18,.26)}
.badge.rel{background:var(--bg-soft);color:var(--ink-soft)}
.chip{display:inline-block;font-size:12px;color:var(--ink-soft);background:var(--bg-soft);
  border:1px solid var(--line);padding:4px 10px;border-radius:6px;margin:0 6px 6px 0}

/* feed timeline */
.feed{display:flex;flex-direction:column;gap:0}
.feed-item{display:grid;grid-template-columns:88px 1fr;gap:18px;padding:17px 0;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:.14s}
.feed-item:hover{background:var(--bg-soft);border-radius:8px;padding-left:12px;padding-right:12px}
.feed-item:last-child{border-bottom:none}
.feed-date{color:var(--ink-mute);font-size:12px;font-weight:500;padding-top:4px;letter-spacing:.2px}
.feed-date .day{font-family:var(--mono);font-size:22px;font-weight:500;color:var(--ink);display:block;line-height:1;letter-spacing:-1px}
.feed-body .row1{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:7px}
.feed-body h4{margin:0 0 5px;font-size:15px;font-weight:600;line-height:1.4;color:var(--ink);letter-spacing:-.2px}
.feed-body p{margin:0;color:var(--ink-soft);font-size:13.5px;line-height:1.55}
.change-tag{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.6px;text-transform:uppercase;color:var(--accent)}

/* lists / toolbar */
.toolbar{display:flex;gap:9px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.input,.select{background:var(--panel);border:1px solid var(--line);color:var(--ink);
  padding:10px 13px;border-radius:var(--radius-sm);font-size:14px;outline:none;font-family:inherit;transition:.13s}
.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.input{min-width:240px;flex:1}
.select{cursor:pointer}
.list{display:flex;flex-direction:column;gap:9px}
.prec-row{display:block;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 19px;transition:.14s;cursor:pointer}
.prec-row:hover{border-color:var(--line-strong);background:var(--panel-2)}
.prec-row-main{display:block;cursor:pointer}
.prec-row .r1{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:8px}
.prec-row .ident{font-family:var(--mono);font-weight:500;font-size:14.5px;color:var(--ink);letter-spacing:-.3px}
.prec-row h4{margin:0;font-size:14.5px;font-weight:500;line-height:1.5;color:var(--ink-soft)}
.prec-row .meta{margin-top:11px;display:flex;gap:14px;flex-wrap:wrap;color:var(--ink-mute);font-size:12.5px}
.prec-row .meta b{color:var(--ink-soft);font-weight:600}

/* detail */
.detail-head{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.detail-title{font-weight:700;font-size:29px;margin:10px 0 16px;line-height:1.18;color:var(--ink);letter-spacing:-.8px}
.kv{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin:18px 0}
.kv .item .k{font-family:var(--mono);color:var(--ink-mute);font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.kv .item .v{color:var(--ink);font-size:14.5px;margin-top:5px;font-weight:500}
.tese-box{background:var(--bg-soft);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:var(--radius);padding:18px 20px;margin:14px 0;line-height:1.65;font-size:15.5px;color:var(--ink)}
.tese-box.q{border-left-color:var(--warn)}
.sit-card{border:1px solid var(--line);border-radius:var(--radius);padding:15px 17px;margin:14px 0}
.sit-card.afetado,.sit-card.em_julgamento{background:rgba(177,106,9,.06);border-color:rgba(177,106,9,.24)}
.sit-card.julgado,.sit-card.vigente{background:rgba(15,157,107,.05);border-color:rgba(15,157,107,.22)}
.sit-card.transitado{background:var(--accent-soft);border-color:rgba(27,70,224,.22)}
.sit-card.cancelada{background:rgba(220,44,63,.05);border-color:rgba(220,44,63,.2)}
.sit-card .sit-line{font-size:16px;margin:4px 0 6px;color:var(--ink);font-weight:600;letter-spacing:-.2px}
.sit-card p{margin:0 0 6px;color:var(--ink-soft);font-size:13.5px;line-height:1.55}
.label-mini{font-family:var(--mono);color:var(--ink-mute);font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;font-weight:500;margin-bottom:7px}
.rel-list a{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius);margin-bottom:8px;transition:.13s;cursor:pointer}
.rel-list a:hover{border-color:var(--accent);background:var(--panel)}
.rel-list a b{color:var(--ink)}
.back{color:var(--ink-soft);font-size:14px;display:inline-flex;gap:7px;align-items:center;margin:6px 0 10px;cursor:pointer;transition:.13s}
.back:hover{color:var(--accent)}

/* fonte oficial — destaque permanente */
.fonte-oficial{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;
  font-weight:600;font-size:13.5px;padding:10px 15px;border-radius:var(--radius-sm);margin-top:6px;cursor:pointer;transition:.13s;text-decoration:none}
.fonte-oficial:hover{background:var(--accent-2)}

/* law timeline */
.law-tl{position:relative;margin-left:8px;padding-left:26px;border-left:2px solid var(--line)}
.law-tl .node{position:relative;padding:0 0 22px}
.law-tl .node::before{content:"";position:absolute;left:-34px;top:3px;width:13px;height:13px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px var(--bg)}
.law-tl .node.t-transitado::before{background:var(--accent)}
.law-tl .node.t-afetado::before{background:var(--warn)}
.law-tl .node.t-vigente::before{background:var(--ok)}
.law-tl .date{font-family:var(--mono);font-weight:500;font-size:12.5px;color:var(--ink);margin-bottom:4px;letter-spacing:-.2px}
.law-tl .node h4{margin:2px 0 6px;font-size:14.5px;color:var(--ink);font-weight:600;letter-spacing:-.2px}
.law-tl .why{color:var(--ink-mute);font-size:12.5px;margin-top:6px}
.law-tl .node-click{cursor:pointer;border-radius:8px;transition:.13s;margin-left:-8px;padding-left:8px;padding-top:2px}
.law-tl .node-click:hover{background:var(--bg-soft)}

/* graph */
#cy{width:100%;height:620px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius)}
.cy-mini{height:300px}
.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px;color:var(--ink-soft);font-size:12.5px}
.legend .dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:6px;vertical-align:-1px}

/* bars */
.bars{display:flex;flex-direction:column;gap:10px}
.bar-row{display:grid;grid-template-columns:130px 1fr 38px;align-items:center;gap:10px;font-size:13px}
.bar-row .lbl{color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{height:7px;background:var(--bg-soft);border-radius:99px;overflow:hidden;border:1px solid var(--line)}
.bar-fill{height:100%;background:var(--accent);border-radius:99px}
.bar-row .num{font-family:var(--mono);color:var(--ink-mute);text-align:right;font-weight:500;font-size:12.5px}

/* busca: destaque + relacionados por item */
.hl{background:var(--accent-soft);color:var(--accent);border-radius:3px;padding:0 2px;font-weight:600}
.relrow{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft)}
.relrow .rl{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:500;color:var(--ink-mute);margin-right:2px}
.relchip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:6px;
  border:1px solid var(--line);background:var(--bg-soft);color:var(--ink-soft);cursor:pointer;transition:.12s}
.relchip:hover{border-color:var(--accent);color:var(--accent);background:var(--panel)}
.relchip .d{width:7px;height:7px;border-radius:50%;flex:none}
.relchip.lei{border-style:dashed}

.notice{display:flex;gap:10px;align-items:flex-start;background:rgba(177,106,9,.07);
  border:1px solid rgba(177,106,9,.22);border-radius:var(--radius);padding:13px 16px;color:#7c4a0c;font-size:13px;line-height:1.55;margin:16px 0}
.notice.stale{margin-top:18px}
.status-strip{display:flex;gap:14px;flex-wrap:wrap;align-items:center;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;margin:0 0 24px;color:var(--ink-soft);font-size:13px}
.status-strip b{color:var(--ink)}
.error-box{max-width:640px;margin:48px auto;background:var(--panel);border:1px solid rgba(220,44,63,.24);
  border-left:4px solid var(--bad);border-radius:var(--radius);padding:24px}
.error-box h3{font-weight:700;font-size:22px;margin:0 0 8px;color:var(--ink);letter-spacing:-.4px}
.error-box p{color:var(--ink-soft);line-height:1.6;margin:0 0 14px}
.btn{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:9px 14px;
  font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-family:inherit;transition:.13s}
.btn:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn.secondary{background:var(--panel);color:var(--accent)}
.btn.secondary:hover{background:var(--accent-soft)}
.btn.link{text-decoration:none;background:var(--bg-soft);border-color:var(--line);color:var(--ink-soft)}
.btn.link:hover{border-color:var(--accent);color:var(--accent)}
/* andamentos / detalhe completo */
.and-summary{cursor:pointer;font-weight:600;font-size:14px;color:var(--ink);letter-spacing:-.2px;list-style:none}
.and-summary::-webkit-details-marker{display:none}
.and-summary::before{content:"▸ ";color:var(--accent)}
details[open] .and-summary::before{content:"▾ "}
.and-list{margin-top:14px;display:flex;flex-direction:column;max-height:540px;overflow:auto}
.and-row{display:grid;grid-template-columns:88px 1fr;gap:12px;padding:9px 0;border-top:1px solid var(--line-soft);font-size:13px}
.and-row:first-child{border-top:none}
.and-date{font-family:var(--mono);font-size:11.5px;color:var(--ink-mute);padding-top:1px;white-space:nowrap}
.and-body b{font-weight:600;color:var(--ink)}
.and-obs{font-size:12px;line-height:1.5;margin-top:3px}
.load-more{display:flex;justify-content:center;margin:20px 0 4px}
.load-more .btn{background:var(--panel);color:var(--accent);border-color:var(--line)}
.load-more .btn:hover{border-color:var(--accent);background:var(--accent-soft)}
.action-row{display:flex;gap:9px;flex-wrap:wrap;margin:0 0 16px}
.timeline-mini{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin:12px 0 14px}
.timeline-mini div{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 13px}
.timeline-mini span{font-family:var(--mono);display:block;color:var(--ink-mute);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:500}
.timeline-mini b{display:block;color:var(--ink);font-size:13px;margin-top:5px;font-weight:600;letter-spacing:-.2px}
.soft-box{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.soft-box h3{font-weight:700;font-size:17px;margin:0 0 10px;color:var(--ink);letter-spacing:-.3px}
.plain-list{margin:0;padding-left:18px;color:var(--ink-soft);line-height:1.7}
.source-list{display:flex;flex-direction:column;gap:10px}
.source-row{display:grid;grid-template-columns:1fr minmax(180px,260px);gap:14px;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius);padding:15px}
.source-row p{margin:5px 0 0;color:var(--ink-soft);font-size:13px;line-height:1.5}
.source-meta{display:flex;flex-direction:column;gap:5px;color:var(--ink-mute);font-size:12px}
.source-meta span{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:4px 8px;width:max-content;max-width:100%}
.glossary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:11px}
.glossary-item{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px}
.glossary-item b{display:block;text-transform:capitalize;color:var(--ink);margin-bottom:5px;letter-spacing:-.2px}
.glossary-item span{color:var(--ink-soft);font-size:13px;line-height:1.55}
.muted{color:var(--ink-mute)}
.empty{color:var(--ink-mute);text-align:center;padding:44px;font-size:14px}
.src-link{color:var(--accent);font-size:13px;display:inline-flex;gap:6px;align-items:center;cursor:pointer;font-weight:500}
.src-link:hover{text-decoration:underline}

/* topsearch */
.topsearch{display:flex;align-items:center;gap:8px;flex:1;max-width:430px;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 14px;color:var(--ink-mute);transition:.13s}
.topsearch:focus-within{border-color:var(--accent);background:var(--panel);box-shadow:0 0 0 3px var(--accent-soft)}
.topsearch svg{width:16px;height:16px;flex:none}
.topsearch input{border:none;background:transparent;outline:none;width:100%;font-size:14px;color:var(--ink);font-family:inherit}
.topsearch input::placeholder{color:var(--ink-mute)}
.topsearch input::-webkit-search-cancel-button{cursor:pointer}

/* reveal orquestrado no load (não em itens de lista que re-renderizam) */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.page-head{animation:fadeUp .45s cubic-bezier(.2,.65,.25,1) both}
.kpi{animation:fadeUp .45s cubic-bezier(.2,.65,.25,1) both}
.kpi:nth-child(1){animation-delay:.03s}.kpi:nth-child(2){animation-delay:.07s}
.kpi:nth-child(3){animation-delay:.11s}.kpi:nth-child(4){animation-delay:.15s}.kpi:nth-child(5){animation-delay:.19s}
.panel{animation:fadeUp .5s cubic-bezier(.2,.65,.25,1) both;animation-delay:.08s}

@media(max-width:820px){
  .cols-2{grid-template-columns:1fr}.nav a{padding:7px 10px;font-size:13px}
  .source-row{grid-template-columns:1fr}
  .topsearch{max-width:none;order:3;flex-basis:100%}
  .page-head h2{font-size:29px;letter-spacing:-.8px}.detail-title{font-size:24px}
}
@media print{
  .topbar,.action-row,#cy,.legend{display:none!important}
  body{background:#fff}
  .app{max-width:100%;padding:0 18px}
  .panel,.prec-row,.tese-box,.sit-card{box-shadow:none}
}
@media(prefers-reduced-motion:reduce){
  .page-head,.kpi,.panel{animation:none}
}
