/* Portal IBG - responsividade premium */
@media (max-width: 1180px) {
  .quick-actions-grid {
    grid-template-columns: repeat(2, minmax(140px, 1fr));
  }

  .hero-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .mobile-menu-btn {
    display: inline-flex;
  }

  .mobile-backdrop.show {
    display: block;
  }

  .sidebar {
    width: min(86vw, 320px);
    height: 100vh;
    position: fixed;
    flex-direction: column;
    flex-wrap: nowrap;
    padding: 0;
    gap: 0;
    transform: translateX(-105%);
    transition: transform .24s ease;
  }

  body.sidebar-open .sidebar {
    transform: translateX(0);
  }

  .sidebar-brand {
    padding: 24px;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }

  .sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 18px 14px 20px;
  }

  .sidebar-nav a {
    padding: 11px 12px;
    margin-bottom: 0;
  }

  .sidebar-footer {
    display: block;
    margin-top: auto;
  }

  .content {
    margin-left: 0;
    width: 100%;
  }

  .topbar {
    padding: 12px 16px;
    gap: 12px;
    align-items: flex-start;
  }

  .topbar-right {
    flex: 1 1 100%;
    justify-content: flex-start;
    width: 100%;
  }

  .empresa-select {
    max-width: none;
    width: 100%;
  }

  .page-title {
    align-items: flex-start;
    flex-direction: column;
    gap: 6px;
  }

  .page-title h2 {
    font-size: 23px;
  }

  .table-premium thead th {
    position: static;
  }

  .boleto-header-top {
    align-items: flex-start;
  }

  .boleto-valores,
  .boleto-venc {
    text-align: left;
  }
}

@media (max-width: 640px) {
  .page-body {
    padding: 14px;
  }

  .executive-hero {
    padding: 20px;
    border-radius: 20px;
  }

  .hero-actions,
  .quick-actions-grid {
    grid-template-columns: 1fr;
  }

  .quick-actions-grid {
    display: grid;
  }

  .hero-action,
  .quick-action-card {
    width: 100%;
  }

  .kpi-grid {
    grid-template-columns: 1fr;
  }

  .kpi {
    padding: 18px;
  }

  .filter-card .row > [class*="col"] {
    width: 100%;
  }

  .btn-ibg,
  .btn-outline-ibg,
  .btn-ghost {
    justify-content: center;
  }

  .login-card {
    padding: 30px 22px;
  }

  .code-input {
    letter-spacing: 6px;
    font-size: 26px;
  }

  .email-modal-footer {
    flex-direction: column-reverse;
  }

  .email-modal-footer .btn-ghost,
  .email-modal-footer .btn-ibg {
    width: 100%;
    justify-content: center;
  }

  .boleto-modal-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .boleto-modal-value {
    justify-content: space-between;
    text-align: left;
  }
}
