/* Glossário Contábil — estilos */

.gl__main { padding-top: clamp(1.5rem, 3vw, 2.5rem); }

/* busca + categorias */
.gl__tools { display: flex; flex-direction: column; gap: 1.1rem; margin-bottom: 1.4rem; }
.gl__search { position: relative; display: flex; align-items: center; }
.gl__search > svg { position: absolute; left: 16px; width: 22px; height: 22px; color: var(--text-faint); pointer-events: none; }
.gl__search input { width: 100%; font-family: var(--font-body); font-size: 1.05rem; color: var(--text); padding: 16px 16px 16px 50px; border: 1px solid var(--border-strong); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow-sm); transition: border-color .2s, box-shadow .2s; }
.gl__search input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.gl__clear { position: absolute; right: 12px; display: grid; place-items: center; width: 30px; height: 30px; border: none; background: var(--bg-soft); border-radius: 50%; color: var(--text-muted); cursor: pointer; }
.gl__clear svg { width: 16px; height: 16px; }
.gl__clear:hover { background: var(--bg-softer); color: var(--primary); }
.gl__cats { display: flex; flex-wrap: wrap; gap: .5rem; }
.gl__cat { font-family: var(--font-body); font-weight: 600; font-size: .88rem; color: var(--text-muted); background: #fff; border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 8px 16px; cursor: pointer; transition: all .18s ease; }
.gl__cat:hover { border-color: var(--border-strong); color: var(--primary); }
.gl__cat.is-on { background: var(--accent); border-color: var(--accent); color: #fff; box-shadow: var(--shadow-accent); }

.gl__count { font-size: .9rem; color: var(--text-muted); margin-bottom: 1.6rem; }
.gl__count b { color: var(--primary); }

/* grid de termos */
.gl__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.4rem); }
.gl__card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: clamp(1.4rem, 2.4vw, 1.8rem); display: flex; flex-direction: column; scroll-margin-top: 100px; transition: box-shadow .25s, border-color .25s; }
.gl__card:hover { box-shadow: var(--shadow); border-color: #D4E0F2; }
.gl__card--flash { animation: glflash 1.4s ease; }
@keyframes glflash { 0%, 40% { box-shadow: 0 0 0 4px var(--accent-soft), var(--shadow); border-color: var(--accent); } 100% { box-shadow: var(--shadow-sm); } }
.gl__card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; margin-bottom: .7rem; }
.gl__card-head h3 { font-size: 1.28rem; color: var(--primary); }
.gl__badge { flex: none; font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--accent); background: var(--accent-soft); border: 1px solid #DCE7FB; padding: 4px 9px; border-radius: 999px; }
.gl__def { font-size: .95rem; color: var(--text-muted); line-height: 1.6; }
.gl__rel { margin-top: 1.1rem; padding-top: 1rem; border-top: 1px dashed var(--border); display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.gl__rel > span { font-size: .8rem; color: var(--text-faint); font-weight: 600; }
.gl__rel-link { font-family: var(--font-body); font-size: .82rem; font-weight: 600; color: var(--accent); background: none; border: none; cursor: pointer; padding: 2px 0; border-bottom: 1px solid transparent; transition: border-color .2s; }
.gl__rel-link:hover { border-color: var(--accent); }

/* vazio */
.gl__empty { text-align: center; padding: clamp(2.5rem, 6vw, 4rem) 1rem; }
.gl__empty > svg { width: 48px; height: 48px; color: var(--text-faint); margin-bottom: 1rem; }
.gl__empty h3 { font-size: 1.5rem; color: var(--primary); margin-bottom: .5rem; }
.gl__empty p { color: var(--text-muted); margin-bottom: 1.6rem; }

@media (max-width: 900px) { .gl__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .gl__grid { grid-template-columns: 1fr; } }
