/* Legisla — tema "Legislativo" (portado do gabarito Pirangi) */
*{box-sizing:border-box;margin:0}
:root{--azul-dk:#16263b;--bg:#f0f3f7;--card:#fff;--txt:#23344a;--txt2:#5f7185;--txt3:#8a99ab;--borda:#e3e9f0;--r:14px;--sombra:0 2px 10px rgba(20,35,60,.06);--sombra-h:0 10px 26px rgba(20,35,60,.14)}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3','Segoe UI',system-ui,sans-serif;background:var(--bg);background-image:radial-gradient(#dfe6ee 1px,transparent 1px);background-size:22px 22px;color:var(--txt);font-size:15.5px;line-height:1.6}
h1,h2,h3,h4,.f-tit{font-family:'Raleway',sans-serif;font-weight:800}
a{color:var(--p)}
/* ---- skip + barra de acessibilidade (govbar) ---- */
.skip{position:absolute;left:-9999px;top:0;background:var(--p);color:#fff;padding:10px 18px;z-index:999;border-radius:0 0 8px 0;text-decoration:none}
.skip:focus{left:0}
.abar{background:var(--azul-dk)}
.abar-in{max-width:1120px;margin:0 auto;padding:6px 20px;display:flex;gap:8px;justify-content:flex-end;align-items:center}
.abar button,.abar a{background:none;border:1px solid rgba(255,255,255,.22);color:#cfdcec;font-size:12px;font-weight:700;padding:4px 12px;border-radius:14px;cursor:pointer;text-decoration:none;font-family:inherit;transition:background .15s}
.abar button:hover,.abar a:hover{background:rgba(255,255,255,.14)}
/* ---- header ---- */
header.topo{background:var(--card);border-bottom:1px solid var(--borda)}
.topo-in{max-width:1120px;margin:0 auto;padding:20px;display:flex;align-items:center;gap:16px}
.brasao{width:64px;height:64px;border-radius:12px;background:var(--p);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:12px;flex:0 0 64px;overflow:hidden}
.brasao img{width:100%;height:100%;object-fit:contain}
.t-tag{font-family:'Raleway';font-size:12.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.t-nome{font-size:30px;color:var(--p);line-height:1.1}
.t-uf{font-family:'Raleway';font-size:12px;color:var(--s);text-transform:uppercase;letter-spacing:.2em;font-weight:800}
/* ---- nav ---- */
nav.menu{background:var(--p);border-bottom:4px solid var(--s);position:sticky;top:0;z-index:90}
.menu-in{max-width:1120px;margin:0 auto;padding:0 12px;display:flex;flex-wrap:wrap}
.menu a,.menu .drop>a{color:#fff;text-decoration:none;padding:15px 17px;font-family:'Raleway';font-weight:800;font-size:13.5px;text-transform:uppercase;letter-spacing:.03em;display:block}
.menu a:hover{background:rgba(255,255,255,.1)}
.drop{position:relative}
.drop .dd{display:none;position:absolute;top:100%;left:0;background:#fff;min-width:250px;box-shadow:var(--sombra-h);border-radius:0 0 12px 12px;z-index:99;padding:6px 0;border-top:3px solid var(--s)}
.drop:hover .dd,.drop:focus-within .dd{display:block}
.drop .dd a{color:var(--txt);padding:11px 18px;text-transform:none;letter-spacing:0;font-weight:600;font-size:14px}
.drop .dd a:hover{background:#f1f5f9;color:var(--p)}
/* ---- main / crumb / page header ---- */
main{max-width:1120px;margin:26px auto;padding:0 20px}
.crumb{font-size:13px;color:var(--txt3);margin-bottom:14px}
.crumb a{color:var(--s);text-decoration:none;font-weight:700}
.page-h{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.page-h::before{content:'';width:6px;height:30px;background:var(--s);border-radius:3px}
.page-h h1,.page-h h2{font-size:27px;color:var(--p)}
/* ---- cartões / listas / docs / chips / badges (gramática do gabarito) ---- */
.cartao{background:var(--card);border-radius:var(--r);padding:26px;box-shadow:var(--sombra);margin-bottom:18px}
.cartao h2{color:var(--p);font-size:21px;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.cartao h2::before{content:'';width:5px;height:22px;background:var(--s);border-radius:3px}
.cartao h3{color:var(--p);margin:18px 0 8px}
.lista a{display:flex;gap:12px;align-items:baseline;padding:12px 6px;border-bottom:1px solid #eef2f6;color:var(--txt);text-decoration:none;transition:background .12s}
.lista a:hover{background:#f7fafc;color:var(--p)}
.lista .d{color:var(--s);font-weight:800;font-size:13px;font-family:'Raleway';white-space:nowrap}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chips a{padding:7px 17px;border-radius:20px;border:1.5px solid #cdd7e2;background:#fff;font-family:'Raleway';font-weight:800;font-size:13px;color:var(--p);text-decoration:none;transition:all .14s}
.chips a.on,.chips a:hover{background:var(--p);border-color:var(--p);color:#fff}
.doc{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 6px;border-bottom:1px solid #eef2f6}
.doc a{color:var(--p);font-weight:700;text-decoration:none}
.doc a:hover{color:var(--s)}
.badge{display:inline-block;background:var(--p);color:#fff;border-radius:7px;font-size:12px;font-weight:800;padding:3px 10px;font-family:'Raleway'}
.badge.enc{background:var(--txt3)}
table{width:100%;border-collapse:collapse}
th{text-align:left;color:var(--p);font-family:'Raleway';border-bottom:2px solid var(--p);padding:9px 6px}
td{padding:10px 6px;border-bottom:1px solid #eef2f6}
/* ---- home: grade + lateral ---- */
.home-grid{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:20px;align-items:start}
.n-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.n-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--borda);text-decoration:none;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.n-card:hover{transform:translateY(-3px);box-shadow:var(--sombra-h)}
.n-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--p),var(--azul-dk)) center/cover no-repeat;position:relative}
.n-thumb .nd{position:absolute;left:10px;bottom:10px;background:var(--s);color:#fff;font-size:11.5px;font-weight:800;font-family:'Raleway';padding:3px 10px;border-radius:6px}
.n-tit{padding:12px 14px;font-weight:700;font-size:14.5px;color:var(--txt);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.btn{display:inline-block;background:var(--s);color:#fff;border:0;border-radius:10px;padding:12px 26px;font-family:'Raleway';font-weight:800;font-size:14px;text-decoration:none;cursor:pointer;transition:filter .15s}
.btn:hover{filter:brightness(1.08)}
.btn.azul{background:var(--p)}
/* lateral de serviços */
.svc{display:flex;flex-direction:column;gap:10px}
.svc a{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--borda);border-radius:12px;padding:13px 15px;text-decoration:none;color:var(--txt);transition:border-color .15s,box-shadow .15s}
.svc a:hover{border-color:var(--p);box-shadow:var(--sombra)}
.svc .ic{width:42px;height:42px;border-radius:10px;background:var(--p);color:#fff;display:flex;align-items:center;justify-content:center;font-size:19px;flex:0 0 42px}
.svc strong{display:block;font-family:'Raleway';font-size:14px;color:var(--p)}
.svc small{color:var(--txt3);font-size:12px}
.widget{background:#fff;border:1px solid var(--borda);border-radius:12px;overflow:hidden;margin-top:14px}
.widget .wh{background:var(--p);color:#fff;font-family:'Raleway';font-weight:800;font-size:13px;letter-spacing:.05em;padding:11px 16px}
.widget .wb{padding:14px 16px}
/* tv */
.tvc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.tvc{all:unset;cursor:pointer;background:#fff;border:1px solid var(--borda);border-radius:12px;overflow:hidden;display:block;transition:transform .15s,box-shadow .15s}
.tvc:hover{transform:translateY(-2px);box-shadow:var(--sombra-h)}
.tvc-th{position:relative;display:block;aspect-ratio:16/9;background:#0e1722 center/cover no-repeat}
.tvc-th b{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;background:rgba(14,23,34,.3)}
.tvc-th i{position:absolute;right:7px;bottom:7px;background:rgba(0,0,0,.8);color:#fff;font-style:normal;font-size:11px;padding:2px 7px;border-radius:5px}
.tvc-tit{display:block;padding:10px 12px 2px;font-weight:600;font-size:13.5px;color:var(--txt)}
.tvc-dt{display:block;padding:0 12px 11px;color:var(--txt3);font-size:12px}
/* selos (radar / tcesp) */
.selos{display:flex;gap:14px;flex-wrap:wrap;margin:22px 0 6px}
.selo{display:flex;align-items:center;gap:14px;flex:1 1 340px;padding:14px 18px;border:1px solid var(--borda);border-radius:12px;background:#f8fafc;text-decoration:none;transition:border-color .15s,box-shadow .15s}
.selo:hover{border-color:var(--p);box-shadow:var(--sombra)}
.selo .ic{flex:0 0 42px;height:42px;color:var(--p)}
.selo b{display:block;color:var(--p);font-family:'Raleway';font-size:14.5px}
.selo small{color:var(--txt2);font-size:12.5px;line-height:1.45}
/* footer */
footer{background:var(--azul-dk);color:#b9c8da;margin-top:40px}
.foot-in{max-width:1120px;margin:0 auto;padding:36px 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px}
.foot-in h4{color:#fff;font-size:15px;margin-bottom:12px}
.foot-in a{color:#b9c8da;text-decoration:none;display:block;padding:4px 0;font-size:14px}
.foot-in a:hover{color:#fff}
.foot-bar{border-top:1px solid rgba(255,255,255,.12);text-align:center;padding:16px;font-size:13px;color:#8fa3b8}
/* contraste + responsivo */
html.contraste body{background:#000!important;background-image:none!important;color:#fff!important}
html.contraste .cartao,html.contraste header.topo,html.contraste .n-card,html.contraste .svc a,html.contraste .widget,html.contraste .selo,html.contraste .tvc{background:#0a0a0a!important;border-color:#444!important;color:#fff!important}
html.contraste h1,html.contraste h2,html.contraste h3,html.contraste p,html.contraste td,html.contraste th,html.contraste .lista a,html.contraste .n-tit,html.contraste .t-nome,html.contraste .svc strong{color:#fff!important}
html.contraste .lista a:hover,html.contraste .doc a{color:#ffd34d!important}
@media(max-width:980px){.home-grid{grid-template-columns:1fr}.t-nome{font-size:23px}.menu a,.menu .drop>a{padding:13px 13px;font-size:12.5px}}
