.app-page {
  min-height: 100vh;
}

.app-layout {
  display: grid;
  grid-template-columns: 286px 1fr;
  grid-template-rows: 74px 1fr;
  min-height: 100vh;
  height: 100vh;
  transition: grid-template-columns 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.app-layout.sidebar-collapsed {
  grid-template-columns: 90px 1fr;
}

.app-header {
  grid-column: 1 / span 2;
  display: grid;
  grid-template-columns: auto minmax(120px, 180px) minmax(280px, 1fr) auto minmax(200px, 290px) auto auto;
  align-items: center;
  gap: 0.75rem;
  padding: 0.62rem 1rem;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 75%, #ffffff 25%);
  background: linear-gradient(110deg, color-mix(in srgb, var(--panel) 72%, #ffffff 28%), color-mix(in srgb, var(--surface) 82%, #ffffff 18%));
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 28px color-mix(in srgb, var(--brand-4) 8%, transparent 92%);
}

.hamburger {
  width: 42px;
  height: 42px;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 1.08rem;
}

.brand-wrap {
  display: grid;
  gap: 0.18rem;
  align-items: center;
}

.header-team-spot {
  display: flex;
  justify-content: center;
  min-width: 0;
  padding-inline: 0.4rem;
}

.brand-name {
  font-size: 1.22rem;
  letter-spacing: -0.02em;
}

.brand-team {
  display: inline-block;
  max-width: min(56vw, 720px);
  font-size: clamp(1.18rem, 2vw, 1.7rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: color-mix(in srgb, var(--text-main) 92%, #000000 8%);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0.3rem 0.85rem;
  border-radius: var(--radius-lg);
  background: linear-gradient(120deg, color-mix(in srgb, var(--panel) 84%, #ffffff 16%), color-mix(in srgb, var(--panel) 68%, var(--surface) 32%));
  border: 1px solid color-mix(in srgb, var(--card-edge) 84%, transparent 16%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), var(--shadow-soft);
}

.role-badge {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.62rem;
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in srgb, var(--brand-2) 40%, var(--border) 60%);
  background: color-mix(in srgb, var(--brand-1) 18%, var(--panel) 82%);
  font-size: 0.78rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--text-main) 90%, #000000 10%);
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}

.role-badge.admin {
  border-color: color-mix(in srgb, #11b57f 48%, var(--border) 52%);
  background: color-mix(in srgb, #11b57f 22%, var(--panel) 78%);
}

.header-clock {
  font-size: 0.84rem;
  color: color-mix(in srgb, var(--text-soft) 84%, var(--text-main) 16%);
  text-align: right;
  justify-self: end;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 88%, #ffffff 12%), color-mix(in srgb, var(--panel) 78%, var(--surface) 22%));
  border: 1px solid color-mix(in srgb, var(--card-edge) 82%, transparent 18%);
}

.header-user-wrap {
  position: relative;
  justify-self: end;
}

.header-user-trigger {
  cursor: pointer;
}

.header-user-menu {
  position: absolute;
  top: calc(100% + 0.55rem);
  right: 0;
  width: min(360px, 80vw);
  padding: 0.9rem;
  border-radius: var(--radius-xl);
  border: 1px solid color-mix(in srgb, var(--card-edge) 84%, transparent 16%);
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 98%, var(--panel) 2%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  box-shadow: var(--shadow-strong);
  z-index: 45;
}

.header-user-menu-head {
  display: grid;
  gap: 0.2rem;
  padding-bottom: 0.72rem;
  margin-bottom: 0.72rem;
  border-bottom: 1px solid color-mix(in srgb, var(--card-edge) 82%, transparent 18%);
}

.header-user-menu-head strong {
  font-size: 1rem;
}

.header-user-menu-head span {
  font-size: 0.86rem;
  color: color-mix(in srgb, var(--text-soft) 84%, var(--text-main) 16%);
}

.header-user-menu-grid {
  display: grid;
  gap: 0.68rem;
}

.header-user-menu-grid div {
  display: grid;
  gap: 0.16rem;
  padding: 0.65rem 0.72rem;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--card-edge) 82%, transparent 18%);
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 98%, var(--panel) 2%), color-mix(in srgb, var(--panel) 94%, var(--surface) 6%));
}

.header-user-menu-grid span {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--text-soft) 82%, var(--text-main) 18%);
}

.header-user-menu-grid strong {
  font-size: 0.92rem;
  word-break: break-word;
}

.header-user-menu-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 0.82rem;
}

.app-sidebar {
  border-right: 1px solid color-mix(in srgb, var(--border) 70%, #ffffff 30%);
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 86%, #ffffff 14%) 0%, color-mix(in srgb, var(--panel) 90%, #e9e9e9 10%) 100%);
  padding: 0.95rem 0.62rem;
  overflow: auto;
  min-height: 0;
}

.app-layout.sidebar-collapsed .app-sidebar {
  padding-inline: 0.36rem;
}

.sidebar-nav {
  display: grid;
  gap: 0.46rem;
  padding-bottom: 1rem;
}

.nav-group-label {
  padding: 0.6rem 0.8rem 0.2rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text-soft) 82%, var(--text-main) 18%);
}

.nav-item,
.nav-subitem {
  text-align: left;
  border: 1px solid transparent;
  background: transparent;
  border-radius: var(--radius-md);
  padding: 0.7rem 0.82rem;
  cursor: pointer;
  font-weight: 700;
  color: color-mix(in srgb, var(--text-main) 86%, #000000 14%);
  transition: transform 180ms ease, background-color 220ms ease, border-color 220ms ease;
  position: relative;
  overflow: hidden;
}

.nav-item:hover,
.nav-subitem:hover {
  transform: translateX(2px);
  border-color: color-mix(in srgb, var(--brand-2) 35%, transparent 65%);
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand-1) 14%, transparent 86%), color-mix(in srgb, var(--brand-2) 12%, transparent 88%));
}

.nav-item.active,
.nav-subitem.active {
  border-color: color-mix(in srgb, var(--brand-2) 44%, transparent 56%);
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand-1) 20%, transparent 80%), color-mix(in srgb, var(--brand-2) 20%, transparent 80%));
}

.nav-item.active::before,
.nav-subitem.active::before {
  content: '';
  position: absolute;
  inset: 10px auto 10px 8px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--brand-1), var(--brand-2));
}

.team-nav-submenu {
  display: none;
  margin-left: 0.35rem;
}

.team-nav-submenu.open {
  display: grid;
  gap: 0.35rem;
}

.app-main {
  padding: 1rem;
  overflow-x: hidden;
  overflow-y: auto;
  position: relative;
  overscroll-behavior: contain;
  min-height: 0;
}

.app-main::before {
  content: '';
  position: absolute;
  inset: 0 1rem auto;
  height: 220px;
  border-radius: 24px;
  background: var(--section-tint);
  opacity: 0.85;
  pointer-events: none;
  z-index: 0;
}

.tab-section {
  display: none;
  opacity: 0;
  transform: translateY(10px) scale(0.992);
  filter: blur(6px);
  pointer-events: none;
  position: relative;
  z-index: 1;
  transition:
    opacity 220ms ease,
    transform 260ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 220ms ease;
}

.tab-section.active,
.tab-section.is-leaving {
  display: block;
}

.tab-section.active {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
  pointer-events: auto;
}

.tab-section.active > * {
  animation: sectionCascade 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

.tab-section.is-leaving {
  opacity: 0;
  transform: translateY(-6px) scale(0.994);
  filter: blur(4px);
}

.section-title {
  margin-bottom: 1.15rem;
  padding: 0.9rem 1rem;
  border: 1px solid color-mix(in srgb, var(--card-edge) 78%, transparent 22%);
  border-radius: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 88%, #ffffff 12%), color-mix(in srgb, var(--panel) 74%, var(--surface) 26%)),
    var(--section-tint);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}

.section-title::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--brand-1), var(--brand-2));
}

.section-title p {
  margin: 0.28rem 0 0;
  color: color-mix(in srgb, var(--text-soft) 88%, var(--text-main) 12%);
  max-width: 70ch;
}

.section-title h1 {
  font-size: 1.42rem;
  letter-spacing: -0.02em;
}

.section-title.with-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.8rem;
}

.card-grid {
  display: grid;
  gap: 1rem;
  align-items: stretch;
}

.card-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.metric-card {
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  border: 1px solid var(--card-edge);
  border-radius: 20px;
  padding: 0.95rem;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  backdrop-filter: blur(10px);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.metric-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--card-highlight);
  pointer-events: none;
  z-index: 0;
}

.metric-card > * {
  position: relative;
  z-index: 1;
}

.metric-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--brand-2) 28%, var(--card-edge) 72%);
  box-shadow: var(--shadow);
}

.metric-card h3 {
  font-size: 0.84rem;
  color: color-mix(in srgb, var(--text-soft) 92%, var(--text-main) 8%);
  margin-bottom: 0.42rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.metric-value {
  font-size: 1.2rem;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.03em;
}

.metric-value.small {
  font-size: 0.98rem;
}

.inline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.35rem;
  font-size: 0.86rem;
}

.chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-bottom: 0.5rem;
  font-size: 0.82rem;
  color: color-mix(in srgb, var(--text-soft) 94%, var(--text-main) 6%);
}

.chart-legend span {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
}

.line-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
}

.line-dot.receitas {
  background: #11b57f;
}

.line-dot.despesas {
  background: #ff7a59;
}

.line-dot.saldo {
  background: var(--brand-1);
}

.line-chart {
  width: 100%;
  max-width: 100%;
  display: block;
  border: 1px solid var(--card-edge);
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 97%, #ffffff 3%), color-mix(in srgb, var(--panel) 90%, var(--surface) 10%));
}

.panel-grid {
  margin-top: 1.05rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}

.dashboard-utility-grid {
  margin-top: 1rem;
}

.dashboard-notice-panel {
  margin-top: 1rem;
}

.search-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(260px, 0.9fr);
  gap: 1rem;
  align-items: start;
}

.search-panel-main,
.search-panel-side {
  min-height: 100%;
}

.search-form-grid {
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 0.9rem;
  align-items: end;
}

.search-form-actions {
  justify-content: flex-start;
}

.search-results-grid {
  margin-top: 1rem;
}

.dashboard-top-grid {
  display: grid;
  grid-template-columns: minmax(0, 2.25fr) minmax(250px, 0.9fr);
  gap: 1rem;
  align-items: stretch;
}

.dashboard-metrics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.dashboard-games-panel {
  min-height: 100%;
  align-self: stretch;
}

.dashboard-games-list {
  align-content: start;
  min-height: 100%;
}

.dashboard-games-list li {
  padding: 0.68rem 0.78rem;
  border: 1px solid color-mix(in srgb, var(--card-edge) 82%, transparent 18%);
  border-radius: 14px;
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 98%, var(--panel) 2%), color-mix(in srgb, var(--panel) 93%, var(--surface) 7%));
  box-shadow: var(--shadow-soft);
}

#team-join-requests-list .event-item {
  align-content: start;
}

.panel {
  border: 1px solid var(--card-edge);
  border-radius: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  padding: 0.98rem;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  backdrop-filter: blur(10px);
  transition: transform 220ms ease, box-shadow 240ms ease, border-color 220ms ease;
}

.panel::before,
.calendar-wrap::before,
.table-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--card-highlight);
  pointer-events: none;
  z-index: 0;
}

.panel > *,
.calendar-wrap > *,
.table-wrap > * {
  position: relative;
  z-index: 1;
}

.context-panel {
  margin-bottom: 1rem;
  background:
    linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 90%, var(--surface) 10%)),
    var(--section-tint);
}

.panel:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.quick-actions-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.68rem;
}

.quick-chip {
  width: 100%;
  justify-content: center;
  text-align: center;
  min-height: 54px;
  border-radius: 14px;
  font-weight: 800;
}

.quick-actions-grid .quick-chip:first-child {
  grid-column: span 2;
}

.note-list {
  margin: 0.9rem 0 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.3rem;
  font-size: 0.9rem;
  color: color-mix(in srgb, var(--text-soft) 94%, var(--text-main) 6%);
}

.directory-results {
  margin-top: 0.95rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.directory-results h4 {
  margin: 0 0 0.55rem;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text-soft) 90%, var(--text-main) 10%);
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.82rem;
  gap: 0.5rem;
  flex-wrap: wrap;
  padding-bottom: 0.72rem;
  border-bottom: 1px solid color-mix(in srgb, var(--card-edge) 82%, transparent 18%);
}

.panel-head h3 {
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.panel-head small {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.56rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand-1) 14%, #ffffff 86%);
  border: 1px solid color-mix(in srgb, var(--brand-1) 24%, var(--card-edge) 76%);
  color: color-mix(in srgb, var(--text-soft) 90%, var(--text-main) 10%);
}

.calendar-wrap {
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 91%, var(--surface) 9%));
  border: 1px solid var(--card-edge);
  border-radius: 20px;
  padding: 0.9rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  box-shadow: var(--shadow-soft);
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.34rem;
}

.calendar-day {
  min-height: 64px;
  border: 1px solid color-mix(in srgb, var(--card-edge) 82%, #ffffff 18%);
  border-radius: 14px;
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 99%, var(--panel) 1%), color-mix(in srgb, var(--panel) 95%, var(--surface) 5%));
  padding: 0.42rem;
  font-size: 0.84rem;
  display: grid;
  align-content: space-between;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  transition: transform 180ms ease, border-color 220ms ease, background-color 220ms ease, box-shadow 220ms ease;
}

.calendar-day.has-event {
  border-color: color-mix(in srgb, var(--brand-2) 45%, var(--border) 55%);
  background: color-mix(in srgb, var(--brand-2) 22%, var(--panel) 78%);
}

.calendar-day:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--brand-4) 8%, transparent 92%);
}

.calendar-day.is-past {
  opacity: 0.72;
  cursor: not-allowed;
}

.calendar-day.is-past:hover {
  transform: none;
}

.calendar-day.empty {
  visibility: hidden;
}

.day-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--brand-2);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-2) 24%, transparent 76%);
}

.list-wrap {
  margin-top: 1.15rem;
  display: grid;
  gap: 0.82rem;
}

.list-wrap > h3 {
  padding-left: 0.2rem;
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.event-list {
  display: grid;
  gap: 0.68rem;
}

.event-item {
  border: 1px solid var(--card-edge);
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  padding: 0.82rem;
  cursor: pointer;
  transition: transform 180ms ease, border-color 220ms ease, box-shadow 220ms ease, background-color 220ms ease;
  box-shadow: var(--shadow-soft);
}

.event-item:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--brand-1) 28%, var(--card-edge) 72%);
  box-shadow: var(--shadow);
}

.notice-card {
  gap: 0.55rem;
}

.notice-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.inline-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.22rem 0.55rem;
  background: color-mix(in srgb, var(--brand-1) 18%, #ffffff 82%);
  border: 1px solid color-mix(in srgb, var(--brand-2) 24%, var(--card-edge) 76%);
  color: color-mix(in srgb, var(--text-main) 92%, #000000 8%);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.team-subtab {
  display: none;
  margin-top: 0.82rem;
  opacity: 0;
  transform: translateY(8px) scale(0.994);
  filter: blur(4px);
  pointer-events: none;
  transition:
    opacity 200ms ease,
    transform 240ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 200ms ease;
}

.team-subtab.active,
.team-subtab.is-leaving {
  display: block;
}

.team-subtab.active {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
  pointer-events: auto;
}

.team-subtab.is-leaving {
  opacity: 0;
  transform: translateY(-4px) scale(0.996);
  filter: blur(3px);
}

.team-dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.1fr) minmax(280px, 1fr);
  gap: 0.92rem;
  align-items: start;
}

.team-stats-group {
  display: grid;
  gap: 0.35rem;
  padding: 0.88rem;
  border-radius: 18px;
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  border: 1px solid var(--card-edge);
  box-shadow: var(--shadow-soft);
}

.team-stats-group h4 {
  font-size: 0.84rem;
  color: color-mix(in srgb, var(--text-soft) 90%, var(--text-main) 10%);
}

.team-stats-row {
  display: flex;
  justify-content: space-between;
  gap: 0.4rem;
  font-size: 0.88rem;
}

.table-wrap {
  overflow: auto;
  margin-top: 0.76rem;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--card-edge);
  border-radius: 18px;
  background: linear-gradient(180deg, color-mix(in srgb, #ffffff 97%, var(--panel) 3%), color-mix(in srgb, var(--panel) 92%, var(--surface) 8%));
  box-shadow: var(--shadow-soft);
  position: relative;
  isolation: isolate;
}

.table-wrap table {
  position: relative;
  z-index: 1;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
}

thead {
  background: color-mix(in srgb, var(--brand-1) 10%, #ffffff 90%);
}

thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  backdrop-filter: blur(8px);
}

th,
td {
  border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, #ffffff 40%);
  text-align: left;
  padding: 0.72rem 0.68rem;
  font-size: 0.88rem;
}

th {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--text-soft) 90%, var(--text-main) 10%);
}

tbody tr:nth-child(even) {
  background: color-mix(in srgb, var(--brand-1) 3%, transparent 97%);
}

tbody tr {
  cursor: pointer;
  transition: background-color 180ms ease, transform 180ms ease;
}

tbody tr:hover {
  background: color-mix(in srgb, var(--brand-1) 8%, transparent 92%);
  transform: translateX(1px);
}

.form-grid.two-col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.form-grid.compact {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.82rem;
}

.form-grid.compact label,
.form-grid.compact button {
  min-width: 0;
}

.form-grid textarea {
  width: 100%;
  resize: vertical;
  min-height: 64px;
}

.form-grid .full-row {
  grid-column: 1 / -1;
}

.form-actions {
  display: flex;
  gap: 0.72rem;
  flex-wrap: wrap;
  justify-content: flex-end;
  padding-top: 0.3rem;
}

.profile-photo-row {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.profile-avatar-preview {
  width: 92px;
  height: 92px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid color-mix(in srgb, var(--brand-2) 35%, var(--border) 65%);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--brand-4) 14%, transparent 86%);
  background: color-mix(in srgb, var(--panel) 86%, #ffffff 14%);
}

.profile-photo-actions {
  display: grid;
  gap: 0.5rem;
  min-width: 240px;
}

.profile-photo-actions input[type='file'] {
  min-height: 48px;
}

.profile-photo-actions .btn,
.form-grid input[type='file'] + .btn,
.form-actions .btn[id*='upload'],
.form-actions .btn[id*='avatar'] {
  min-height: 44px;
  border-radius: 12px;
}

.note-list li,
.inline-list li,
.team-stats-group,
.confirm-row {
  padding: 0.18rem 0;
}

.quick-actions-grid .btn,
.form-actions .btn,
.panel-head .btn {
  box-shadow: none;
}

.fx-dropdown {
  min-width: 220px;
}

.fx-dropdown-toggle,
.header-dropdown .fx-dropdown-toggle {
  border-radius: 999px;
  min-height: 44px;
}

.fx-option-badge,
.role-badge {
  letter-spacing: 0.03em;
}

.color-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.color-pill {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--border) 80%, #ffffff 20%);
  cursor: pointer;
}

.color-slider-wrap {
  display: grid;
  gap: 0.82rem;
  margin: 1rem 0;
}

.color-preview {
  height: 68px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--border) 80%, #ffffff 20%);
  margin-bottom: 0.8rem;
}

.confirm-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.35rem;
}

.confirm-row label,
.confirm-row span {
  line-height: 1.35;
}

.panel + .panel,
.panel + .card-grid,
.card-grid + .panel,
.calendar-wrap + .list-wrap,
.table-wrap + .panel,
.panel-grid + .panel,
.panel-grid + .card-grid,
.card-grid + .panel-grid {
  margin-top: 1rem;
}

@keyframes tabIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes sectionCascade {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1180px) {
  .card-grid.four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .dashboard-top-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-metrics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .search-page-grid {
    grid-template-columns: 1fr;
  }

  .search-form-grid {
    grid-template-columns: 1fr;
  }

  .form-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quick-actions-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quick-actions-grid .quick-chip:first-child {
    grid-column: span 2;
  }

  .directory-results {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .app-layout {
    grid-template-columns: 1fr;
    grid-template-rows: 74px 1fr;
    height: 100dvh;
  }

  .app-header {
    grid-column: 1;
    grid-template-columns: auto 1fr auto;
    grid-auto-rows: auto;
    gap: 0.55rem;
    padding: 0.56rem 0.72rem;
  }

  .brand-wrap {
    min-width: auto;
  }

  .header-team-spot {
    grid-column: 1 / -1;
    order: 10;
  }

  .brand-team {
    max-width: 100%;
    font-size: clamp(1.05rem, 4.6vw, 1.4rem);
  }

  .header-dropdown,
  #header-role-badge,
  .header-user-wrap,
  #logout-btn {
    grid-column: 1 / -1;
  }

  .header-user-wrap {
    justify-self: stretch;
  }

  .header-user-menu {
    left: 0;
    right: auto;
    width: 100%;
  }

  .app-sidebar {
    position: fixed;
    left: 0;
    top: 74px;
    bottom: 0;
    width: min(84vw, 320px);
    transform: translateX(-108%);
    transition: transform 220ms ease;
    z-index: 35;
    border-right: 1px solid color-mix(in srgb, var(--border) 76%, #ffffff 24%);
    border-bottom: 0;
    box-shadow: 0 18px 30px color-mix(in srgb, var(--brand-4) 16%, transparent 84%);
    padding-bottom: max(1rem, env(safe-area-inset-bottom));
  }

  .app-layout.sidebar-collapsed .app-sidebar {
    display: block;
    transform: translateX(-108%);
  }

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

  .card-grid.four,
  .card-grid.three,
  .form-grid.two-col {
    grid-template-columns: 1fr;
  }

  .team-dashboard-layout {
    grid-template-columns: 1fr;
  }

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

  .quick-actions-grid .quick-chip:first-child {
    grid-column: auto;
  }

  .app-main {
    padding: 0.78rem;
    min-height: 0;
    overflow-y: auto;
  }

  .section-title h1 {
    font-size: 1.24rem;
  }

  .metric-card,
  .panel {
    border-radius: 14px;
  }

  .calendar-day {
    min-height: 54px;
    font-size: 0.78rem;
    padding: 0.34rem;
  }

  .form-grid.compact {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .app-header {
    position: sticky;
    top: 0;
  }

  .brand-name {
    font-size: 1.08rem;
  }

  .role-badge {
    font-size: 0.72rem;
    padding: 0.25rem 0.52rem;
  }

  .header-clock {
    font-size: 0.78rem;
  }

  th,
  td {
    padding: 0.5rem 0.42rem;
    font-size: 0.82rem;
    white-space: nowrap;
  }

  .panel-head {
    margin-bottom: 0.66rem;
  }

  .section-title.with-action {
    grid-template-columns: 1fr;
  }

  .event-item {
    padding: 0.62rem;
  }

  .profile-photo-actions {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 560px) {
  .app-main {
    padding: 0.62rem;
  }

  .section-title.with-action {
    gap: 0.5rem;
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .metric-value {
    font-size: 1.08rem;
  }

  .metric-value.small {
    font-size: 0.9rem;
  }

  .calendar-grid {
    gap: 0.22rem;
  }

  .calendar-day {
    min-height: 48px;
  }

  .fx-option-badge {
    font-size: 0.68rem;
  }
}

/* Sobriedade visual: menos arredondamento, menos aspecto genérico */
.app-header,
.app-sidebar,
.content-shell,
.section-title,
.panel,
.metric-card,
.event-item,
.table-wrap,
.search-panel-main,
.calendar-day,
.notice-card,
.header-user-menu,
.header-user-menu-grid div,
.profile-avatar-preview,
.quick-chip,
.team-stats-group,
.inline-badge,
.brand-team,
.header-clock,
.role-badge,
.hamburger {
  border-radius: var(--radius-lg) !important;
}

.nav-item,
.nav-subitem,
.btn,
.btn-small,
.fx-dropdown-toggle,
.fx-dropdown-item,
.modal-close,
input,
textarea,
select,
.select-like {
  border-radius: var(--radius-md) !important;
}

.role-badge,
.header-clock,
.inline-badge,
.fx-option-badge {
  border-radius: var(--radius-sm) !important;
}
