:root {
  --bg: #f5f2ed;
  --white: #ffffff;
  --primary: #ffe601;
  --primary-hover: #e6cf00;
  --blue: #00036e;
  --text: #888888;
  --text-soft: #888888;
  --border: #e5e7eb;
  --radius: 12px;
  --shadow-soft: 0 2px 8px rgba(0, 0, 0, 0.05);
  --login-input-bg: #eef4ff;
  /* Borda dos campos: sempre tom do azul SNOW, sem dourado */
  --login-input-border: rgba(0, 3, 110, 0.22);
  /* Nome no header: destaque sem tom dourado nas linhas */
  --welcome-name: rgba(0, 3, 110, 0.78);
  --header-border: rgba(0, 3, 110, 0.12);
  --header-accent-line: rgba(0, 3, 110, 0.2);
  --sidebar-hover-bg: #f8f7f3;
  --sidebar-active-bg: #f0f2ff;
  --input-bg: #f1f5f9;
  --search-input-bg: #f9fafb;
  --table-header-bg: #f8f8f7;
  --table-cell-border: #f0f1f3;
  --table-toolbar-bg: #fafbfc;
  --table-head-text: #1e293b;
  --table-body-text: #475569;
  --table-row-hover: #f8fafc;
  --bar-track-bg: #eee7dc;
  --alert-warn-bg: #fff8db;
  --alert-warn-border: #f0e3ae;
}

[data-theme='dark'] {
  color-scheme: dark;
  --bg: #0f1117;
  --white: #151a24;
  --primary: #e8c84a;
  --primary-hover: #f0d56a;
  --blue: #c8d4ff;
  --text: #b4bcc8;
  --text-soft: #8b95a8;
  --border: #2a3348;
  --shadow-soft: 0 2px 12px rgba(0, 0, 0, 0.35);
  --login-input-bg: #1e2638;
  --login-input-border: rgba(200, 212, 255, 0.2);
  --welcome-name: rgba(200, 212, 255, 0.92);
  --header-border: rgba(200, 212, 255, 0.14);
  --header-accent-line: rgba(200, 212, 255, 0.28);
  --sidebar-hover-bg: #1c2433;
  --sidebar-active-bg: #222c42;
  --input-bg: #1a2230;
  --search-input-bg: #151c28;
  --table-header-bg: #1a2230;
  --table-cell-border: #2a3348;
  --table-toolbar-bg: #171e2a;
  --table-head-text: #e8edf5;
  --table-body-text: #b4bcc8;
  --table-row-hover: #1c2433;
  --bar-track-bg: #252e40;
  --alert-warn-bg: #2d2618;
  --alert-warn-border: #5c4d20;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: 'Kenyan Coffee', sans-serif; color: var(--text); background: var(--bg); }

.login-shell {
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  justify-content: center;
  padding: 1.25rem 1rem;
  background: linear-gradient(165deg, #fffdf7 0%, #f3f6ff 42%, #faf8f3 100%);
}
[data-theme='dark'] .login-shell {
  background: linear-gradient(165deg, #121722 0%, #151d2e 48%, #0f141c 100%);
}
.login-layout {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(0, 440px);
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3rem);
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
}
.login-brand {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 0.5rem 0.75rem 0.5rem 0;
  border-right: 1px solid rgba(0, 3, 110, 0.1);
  min-width: 0;
}
.login-title--panel {
  text-align: left;
  font-size: clamp(1.65rem, 3.2vw, 2.15rem);
}
.login-brand-tagline {
  margin: 1rem 0 0;
  font-size: 0.95rem;
  line-height: 1.45;
  color: rgba(0, 3, 110, 0.55);
  max-width: 18rem;
}
[data-theme='dark'] .login-brand-tagline {
  color: var(--text-soft);
}
.login-main {
  width: 100%;
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .login-layout {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .login-brand {
    align-items: center;
    text-align: center;
    padding: 0.25rem 0 0.5rem;
    border-right: 0;
    border-bottom: 1px solid rgba(0, 3, 110, 0.1);
  }
  .login-title--panel {
    text-align: center;
  }
  .login-brand-tagline {
    max-width: 22rem;
    margin-top: 0.65rem;
  }
}
.login-card {
  width: 100%;
  max-width: 470px;
  background: var(--white);
  border: 1px solid rgba(0, 3, 110, 0.1);
  border-radius: 22px;
  box-shadow: 0 16px 48px rgba(0, 3, 110, 0.1), 0 0 0 1px rgba(0, 3, 110, 0.06) inset;
  padding: 2rem 2rem 1.75rem;
  position: relative;
  overflow: hidden;
}
.login-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--primary-hover) 40%, var(--blue) 100%);
}
.login-title {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0;
  text-align: center;
  letter-spacing: 0.02em;
  color: var(--blue);
}
.login-title-accent {
  display: inline-block;
  margin-left: 0.25rem;
  padding: 0.12rem 0.5rem;
  border-radius: 8px;
  background: var(--primary);
  color: var(--blue);
  font-weight: 800;
}
.snow-blue { color: var(--blue); }
.login-subtitle {
  text-align: center;
  color: rgba(0, 3, 110, 0.55);
  margin-top: 0.55rem;
  font-size: 0.95rem;
}
.login-footer { margin: 1.4rem 0 0; text-align: center; color: var(--text-soft); font-size: .9rem; }

.login-field-group { margin-bottom: 1.35rem; }
.login-field-group:last-of-type { margin-bottom: 0.75rem; }
.login-field-label {
  display: block;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue);
  margin-bottom: 0.45rem;
  letter-spacing: 0.01em;
}
/* Campo login: flex alinha ícone, texto e olho na mesma linha (modelo anexo) */
.login-input-shell {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.45rem;
  min-height: 48px;
  box-sizing: border-box;
  border-radius: 999px;
  border: 1px solid var(--login-input-border);
  background: var(--login-input-bg);
  padding: 0 0.4rem 0 0.85rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.login-input-shell:focus-within {
  border-color: var(--blue);
  background: var(--white);
  box-shadow: 0 0 0 2px rgba(0, 3, 110, 0.12);
}
[data-theme='dark'] .login-input-shell:focus-within {
  box-shadow: 0 0 0 2px rgba(200, 212, 255, 0.18);
}
.login-input-shell__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 28px;
  color: var(--blue);
  opacity: 0.65;
  pointer-events: none;
}
.login-input-shell__icon svg {
  display: block;
  width: 20px;
  height: 20px;
  stroke: var(--blue);
}
.login-input-shell .login-input-inner.form-control {
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0.5rem 0.15rem;
  font-size: 0.95rem;
  line-height: 1.35;
  color: var(--blue);
  border-radius: 0;
  align-self: center;
}
.login-input-shell .login-input-inner.form-control:focus {
  outline: none;
  box-shadow: none !important;
}
.login-input-shell .login-input-inner.form-control::placeholder {
  color: rgba(0, 3, 110, 0.32);
}
/* Chrome/Edge: autofill pinta fundo escuro por cima do transparent — “apaga” com inset igual ao pill */
.login-input-shell .login-input-inner.form-control:-webkit-autofill,
.login-input-shell .login-input-inner.form-control:-webkit-autofill:hover,
.login-input-shell .login-input-inner.form-control:-webkit-autofill:focus,
.login-input-shell .login-input-inner.form-control:-webkit-autofill:active {
  -webkit-text-fill-color: var(--blue) !important;
  caret-color: var(--blue);
  box-shadow: 0 0 0 1000px var(--login-input-bg) inset !important;
  -webkit-box-shadow: 0 0 0 1000px var(--login-input-bg) inset !important;
  transition: background-color 99999s ease-out;
}
.login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill,
.login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:hover,
.login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:focus,
.login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:active {
  box-shadow: 0 0 0 1000px var(--white) inset !important;
  -webkit-box-shadow: 0 0 0 1000px var(--white) inset !important;
}
[data-theme='dark'] .login-input-shell .login-input-inner.form-control:-webkit-autofill,
[data-theme='dark'] .login-input-shell .login-input-inner.form-control:-webkit-autofill:hover,
[data-theme='dark'] .login-input-shell .login-input-inner.form-control:-webkit-autofill:focus,
[data-theme='dark'] .login-input-shell .login-input-inner.form-control:-webkit-autofill:active {
  -webkit-text-fill-color: var(--blue) !important;
  box-shadow: 0 0 0 1000px var(--login-input-bg) inset !important;
  -webkit-box-shadow: 0 0 0 1000px var(--login-input-bg) inset !important;
}
[data-theme='dark'] .login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill,
[data-theme='dark'] .login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:hover,
[data-theme='dark'] .login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:focus,
[data-theme='dark'] .login-input-shell:focus-within .login-input-inner.form-control:-webkit-autofill:active {
  box-shadow: 0 0 0 1000px var(--white) inset !important;
  -webkit-box-shadow: 0 0 0 1000px var(--white) inset !important;
}
/* Botão olho: mesmo eixo vertical que ícone e texto (flex align-items: center no shell) */
.login-input-shell__toggle.toggle-password {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  min-width: 40px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--blue);
  opacity: 0.55;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  font-size: 0;
  -webkit-appearance: none;
  appearance: none;
  align-self: center;
}
.login-input-shell__toggle.toggle-password:hover {
  opacity: 1;
  background: rgba(255, 230, 1, 0.35);
}
.login-input-shell__toggle.toggle-password i,
.login-input-shell__toggle.toggle-password svg {
  display: block;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.login-input-shell__toggle.toggle-password svg {
  stroke: var(--blue);
  width: 20px;
  height: 20px;
  vertical-align: middle;
}
.login-shell .btn-primary-pill {
  margin-top: 0.35rem;
  min-height: 48px;
  font-size: 1rem;
  box-shadow: 0 2px 0 rgba(0, 3, 110, 0.12);
}
.login-shell .btn-primary-pill:hover {
  box-shadow: 0 3px 12px rgba(0, 3, 110, 0.15);
}
.login-shell .link-muted {
  color: rgba(0, 3, 110, 0.45);
}
.login-shell .link-muted:hover {
  color: var(--blue);
  text-decoration: underline;
}
.login-shell .alert-danger {
  border-radius: 12px;
  border: 1px solid rgba(185, 28, 28, 0.25);
}

.app-shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; background: var(--bg); color: var(--text); }
.app-sidebar { background: var(--white); border-right: 1px solid var(--border); padding: 1.4rem 1rem; position: sticky; top: 0; height: 100vh; }
/* Mesma marca da tela de login: SNOW + CBDN em destaque amarelo */
.brand {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 1rem;
  line-height: 1.2;
  letter-spacing: 0.02em;
}
.brand .snow-blue { color: var(--blue); }
.side-nav { display: grid; gap: .35rem; }
.side-link { display: flex; align-items: center; gap: .65rem; color: var(--text); text-decoration: none; border-radius: 10px; padding: .7rem .8rem; transition: .2s ease; }
.side-link:hover { background: var(--sidebar-hover-bg); color: var(--blue); }
.side-link.active { background: var(--sidebar-active-bg); color: var(--blue); font-weight: 600; }
.side-link svg { width: 16px; height: 16px; }
.side-nav-group { display: grid; gap: .2rem; }
.side-group-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}
.side-group-chevron {
  margin-left: auto;
  width: 14px !important;
  height: 14px !important;
  transition: transform .2s ease;
}
.side-nav-group.open .side-group-chevron { transform: rotate(180deg); }
.side-nav-sub {
  display: none;
  gap: .2rem;
  padding-left: .35rem;
  margin-left: .55rem;
  border-left: 1px solid var(--border);
}
.side-nav-group.open .side-nav-sub { display: grid; }
.side-sublink {
  display: flex;
  align-items: center;
  gap: .55rem;
  color: var(--text-soft);
  text-decoration: none;
  border-radius: 8px;
  padding: .5rem .65rem;
  font-size: .88rem;
}
.side-sublink:hover { background: var(--sidebar-hover-bg); color: var(--blue); }
.side-sublink.active { background: var(--sidebar-active-bg); color: var(--blue); font-weight: 600; }
.side-sublink svg { width: 14px; height: 14px; }
.user-role-chip {
  display: inline-block;
  margin-top: .25rem;
  font-size: .75rem;
  color: var(--text-soft);
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .1rem .5rem;
}
.calendar-toolbar {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .9rem;
}
.calendar-month-label {
  min-width: 180px;
  text-align: center;
  text-transform: capitalize;
}
.calendar-summary {
  margin-left: .35rem;
  font-size: .88rem;
  color: var(--text-soft);
}
.panel-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.panel-section-head--compact {
  align-items: center;
  margin-bottom: .75rem;
}
.panel-section-desc {
  font-size: .88rem;
  color: var(--text-soft);
  max-width: 52ch;
}
.events-filter-form { min-width: min(100%, 240px); }
.events-calendar-panel { overflow: hidden; }
.events-month-list {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}
.event-name-cell { min-width: 180px; }
.badge-sport {
  display: inline-flex;
  align-items: center;
  padding: .12rem .45rem;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 700;
  color: var(--blue);
  background: var(--sidebar-active-bg);
  border: 1px solid var(--border);
}
.nation-badge {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-width: 0;
}
.nation-badge__text {
  display: flex;
  flex-direction: column;
  gap: .05rem;
  min-width: 0;
}
.nation-badge__name {
  font-size: .86rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.2;
}
.nation-badge__code {
  font-size: .72rem;
  color: var(--text-soft);
  letter-spacing: .03em;
}
.fis-flag {
  width: 1.15rem;
  height: .85rem;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, .08);
  flex-shrink: 0;
  background-size: cover;
}
.fis-flag--sm {
  width: .95rem;
  height: .7rem;
}
.fis-flag--fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .55rem;
  font-weight: 700;
  color: var(--text-soft);
  background: var(--input-bg);
  border: 1px solid var(--border);
}
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: 2rem 1rem;
  text-align: center;
  color: var(--text-soft);
}
.empty-state svg {
  width: 28px;
  height: 28px;
  opacity: .65;
}
.empty-state--compact {
  padding: 1.25rem 1rem;
}
.empty-state p { margin: 0; }
.fis-calendar-weekdays,
.fis-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .35rem;
}
.fis-calendar-weekdays span {
  text-align: center;
  font-size: .78rem;
  font-weight: 600;
  color: var(--text-soft);
  padding: .35rem 0;
}
.fis-calendar-cell {
  min-height: 108px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--input-bg);
  padding: .45rem;
  display: flex;
  flex-direction: column;
  gap: .3rem;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.fis-calendar-cell--empty { background: transparent; border-color: transparent; }
.fis-calendar-cell.has-events {
  border-color: rgba(0, 3, 110, .28);
  background: var(--sidebar-active-bg);
}
.fis-calendar-cell.has-events:hover {
  border-color: var(--blue);
  box-shadow: var(--shadow-soft);
}
.fis-calendar-cell.is-today {
  border-color: var(--blue);
  box-shadow: inset 0 0 0 1px var(--blue);
}
.fis-calendar-cell.is-today .fis-calendar-day {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  background: var(--blue);
  color: var(--white);
}
.fis-calendar-day { font-size: .82rem; font-weight: 600; color: var(--text); }
.fis-calendar-events {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  min-width: 0;
}
.fis-calendar-event {
  display: flex;
  align-items: flex-start;
  gap: .3rem;
  font-size: .68rem;
  background: var(--white);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: .22rem .3rem;
  cursor: help;
  min-width: 0;
}
.fis-calendar-event__body {
  display: flex;
  flex-direction: column;
  gap: .05rem;
  min-width: 0;
}
.fis-calendar-event__name {
  font-weight: 700;
  color: var(--blue);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.fis-calendar-event__sport {
  font-size: .62rem;
  color: var(--text-soft);
  font-weight: 600;
}
.fis-calendar-more {
  font-size: .68rem;
  color: var(--text-soft);
  padding-left: .15rem;
  cursor: help;
}
.events-fis-table td { vertical-align: middle; }
@media (max-width: 992px) {
  .fis-calendar-cell { min-height: 88px; }
  .fis-calendar-event__name { white-space: normal; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
}
@media (max-width: 768px) {
  .fis-calendar-weekdays,
  .fis-calendar-grid { gap: .2rem; }
  .fis-calendar-cell { min-height: 72px; padding: .3rem; }
  .fis-calendar-event { display: none; }
  .fis-calendar-cell.has-events::after {
    content: '';
    width: .45rem;
    height: .45rem;
    border-radius: 999px;
    background: var(--blue);
    margin-top: auto;
  }
}

.app-main { padding: 0; display: flex; flex-direction: column; min-width: 0; min-height: 100vh; }
.app-header-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
  min-height: 52px;
  padding: 0.65rem 1.5rem;
  /* Mesmo fundo do menu lateral (.app-sidebar) */
  background: var(--white);
  border-bottom: 1px solid var(--header-border);
  border-left: 1px solid var(--header-accent-line);
}
.app-header-bar__greeting { min-width: 0; }
.app-header-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.app-header-title__prefix { color: var(--blue); margin-right: 0.35rem; }
.app-header-title__name { color: var(--welcome-name); }
.app-header-bar__actions { display: flex; align-items: center; gap: 0.45rem; flex-shrink: 0; }
.app-header-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--header-border);
  border-radius: 10px;
  background: transparent;
  color: var(--blue);
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}
.app-header-icon-btn:hover {
  border-color: var(--blue);
  color: var(--blue);
  background: rgba(0, 3, 110, 0.04);
}
[data-theme='dark'] .app-header-icon-btn:hover {
  background: rgba(200, 212, 255, 0.08);
}
.app-header-icon-btn svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
}

.app-main-body { padding: 1.5rem; flex: 1; }

.icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1px solid var(--border); border-radius: 50%; background: var(--white); color: var(--text); text-decoration: none; }
.icon-btn:hover { border-color: var(--blue); color: var(--blue); }

.page-head { display: flex; justify-content: space-between; align-items: center; gap: .8rem; margin-bottom: 1rem; flex-wrap: wrap; }
.page-head h2 { margin: 0; font-size: 1.35rem; font-weight: 600; }
.page-head p { margin: .2rem 0 0; color: var(--text-soft); }
.head-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

.panel { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-soft); padding: 1rem; }
.panel h3 { margin: 0; font-size: 1.08rem; font-weight: 600; }
.text-secondary { color: var(--text-soft); }

.alert-box { background: var(--alert-warn-bg); border: 1px solid var(--alert-warn-border); border-radius: var(--radius); padding: .8rem 1rem; display: flex; align-items: center; gap: .65rem; color: var(--text); }

.metrics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: .8rem; }
.metric-card h3.metric-season { font-size: 1.15rem; letter-spacing: -0.02em; }
.metric-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; box-shadow: var(--shadow-soft); display: flex; justify-content: space-between; align-items: center; }
.metric-card p { margin: 0; color: var(--text-soft); }
.metric-card h3 { margin: .4rem 0 0; font-size: 1.6rem; }
.metric-card i svg { color: var(--primary); }

.content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.rank-list { margin: .6rem 0 0; list-style: none; padding: 0; display: grid; gap: .5rem; }
.rank-list li { display: grid; grid-template-columns: 30px 1fr auto; align-items: center; border: 1px solid var(--border); border-radius: 10px; padding: .45rem .6rem; }
.rank-num { color: var(--primary); font-weight: 700; }
.rank-points { color: var(--text-soft); font-size: .9rem; }
.bar-row { display: grid; grid-template-columns: 120px 1fr 34px; gap: .5rem; align-items: center; margin-top: .6rem; }
.result-view-tabs { border-bottom: 1px solid var(--border); gap: .25rem; }
.result-view-tabs .nav-link { color: var(--text-soft); border: none; border-bottom: 2px solid transparent; border-radius: 0; padding: .55rem 1rem; font-weight: 600; }
.result-view-tabs .nav-link:hover { color: var(--blue); }
.result-view-tabs .nav-link.active { color: var(--blue); background: transparent; border-bottom-color: var(--primary); }
.chart-wrap { position: relative; height: 240px; }
.chart-wrap-wide { height: 280px; }
.bar-track { background: var(--bar-track-bg); border-radius: 999px; height: 10px; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; }
.bar-1, .bar-3 { background: var(--blue); }
.bar-2, .bar-4 { background: #d7b77b; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .8rem; }
.form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.athlete-filters { margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border); }
.athlete-filters h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.75rem; color: var(--text-soft); }
.athlete-filters-inner { display: flex; flex-direction: column; gap: 0.8rem; }
.athlete-filter-metric-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-left: -2px;
  margin-right: -2px;
  padding-bottom: 2px;
}
.athlete-filter-metric-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
  align-items: end;
  min-width: 640px;
}
.athlete-filter-hint {
  font-size: 0.8125rem;
  color: var(--text-soft);
  white-space: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 2px;
  -webkit-overflow-scrolling: touch;
}
.athlete-filters .filter-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem; justify-content: flex-end; margin-top: 0.25rem; }
.athlete-filters .filter-actions .records-inline { margin-left: auto; display: flex; align-items: center; gap: 0.4rem; }
.field-label { font-size: .9rem; font-weight: 500; margin-bottom: .35rem; display: inline-block; }
.input-modern { background: var(--input-bg); border: 1px solid var(--border); border-radius: 10px; height: 44px; color: var(--text); }
.input-modern:focus { border-color: var(--blue); box-shadow: 0 0 0 .2rem rgba(0, 3, 110, .15); background: var(--white); }
[data-theme='dark'] .input-modern:focus { box-shadow: 0 0 0 0.2rem rgba(200, 212, 255, 0.12); }

.input-icon-wrap { position: relative; }
.input-icon-wrap > i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: #8a94a3; }
.input-icon-wrap .input-modern { padding-left: 2.2rem; }
.with-toggle { padding-right: 2.5rem; }
/* Só dentro de .input-icon-wrap — na login o olho fica no grid (.login-input-shell__toggle) */
.input-icon-wrap .toggle-password { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; color: #8a94a3; }
.link-muted { color: var(--text-soft); text-decoration: none; font-size: .9rem; }
.link-muted:hover { color: var(--blue); }

.btn-primary-pill { background: var(--primary); color: #1f2937; border: none; border-radius: 999px; padding: .62rem 1rem; font-weight: 600; text-decoration: none; display: inline-flex; justify-content: center; align-items: center; }
.btn-primary-pill:hover { background: var(--primary-hover); color: #1f2937; }
.btn-outline-modern { background: transparent; border: 1px solid var(--border); color: var(--text); border-radius: 999px; padding: .55rem .95rem; text-decoration: none; }
.btn-outline-modern:hover { border-color: var(--blue); color: var(--blue); }

.align-end { display: flex; align-items: end; }
.search-box { max-width: 340px; position: relative; }
.search-box i { position: absolute; top: 50%; transform: translateY(-50%); left: 12px; color: #8a94a3; }
.search-box input { width: 100%; height: 40px; border-radius: 10px; border: 1px solid var(--border); padding: .5rem .7rem .5rem 2.2rem; background: var(--search-input-bg); color: var(--text); }

.table-modern { margin: 0; width: 100%; border-collapse: separate; border-spacing: 0; }
.table-data-shell {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--white);
  overflow: hidden;
}
.table-data-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--table-toolbar-bg);
}
.table-pager {
  display: flex;
  align-items: center;
  gap: .35rem;
  flex-wrap: wrap;
}
.table-pager-btn {
  width: 34px;
  height: 34px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--table-head-text);
  text-decoration: none;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.table-pager-btn:hover:not(.is-disabled) {
  border-color: var(--blue);
  color: var(--blue);
}
.table-pager-btn.is-disabled {
  pointer-events: none;
  opacity: .4;
}
.table-pager-btn svg { width: 16px; height: 16px; }
.table-pager-status {
  font-size: .88rem;
  color: var(--text-soft);
  padding: 0 .45rem;
  white-space: nowrap;
}
.table-pager-status strong { color: var(--table-head-text); font-weight: 700; }
.table-limit-form { margin: 0; }
.table-limit-form .records-inline label {
  font-size: .86rem;
  color: var(--text-soft);
  white-space: nowrap;
}
.table-modern thead th {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  color: var(--table-head-text);
  font-weight: 700;
  font-size: .84rem;
  padding: .95rem 1rem;
  vertical-align: middle;
  white-space: nowrap;
}
.table-modern thead th.th-align-start { text-align: left; }
.table-modern thead th.th-align-center { text-align: center; }
.table-modern thead th.th-align-end { text-align: right; }
.table-modern thead th.th-actions { width: 1%; }
.table-modern tbody td {
  padding: 1rem;
  border-bottom: 1px solid var(--table-cell-border);
  border-top: 0;
  border-left: 0;
  border-right: 0;
  color: var(--table-body-text);
  vertical-align: middle;
  background: var(--white);
}
.table-modern tbody tr:last-child td { border-bottom: 0; }
.table-modern tbody tr:hover td { background: var(--table-row-hover); }
.table-modern tbody td.td-align-end,
.table-modern tbody td.text-end { text-align: right; }
.table-modern tbody td.td-align-center { text-align: center; }
.cell-stack {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  min-width: 0;
}
.cell-primary {
  font-weight: 700;
  color: var(--table-head-text);
  line-height: 1.25;
}
.cell-secondary {
  font-size: .8rem;
  color: var(--text-soft);
  line-height: 1.2;
}
.row-actions {
  display: flex;
  gap: .35rem;
  justify-content: center;
  align-items: center;
}
.icon-action {
  width: 34px;
  height: 34px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--table-head-text);
  text-decoration: none;
  padding: 0;
  cursor: pointer;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.icon-action svg { width: 16px; height: 16px; }
.icon-action:hover {
  border-color: var(--blue);
  color: var(--blue);
  background: var(--sidebar-active-bg);
}
.icon-action.danger {
  color: #dc2626;
  border-color: #fecaca;
  background: #fffafa;
}
.icon-action.danger:hover {
  border-color: #f87171;
  color: #b91c1c;
  background: #fef2f2;
}
[data-theme='dark'] .icon-action.danger {
  background: rgba(220, 38, 38, .08);
  border-color: rgba(248, 113, 113, .35);
}
.status-badge { background: #eef6ec; color: #2f7f3b; border-radius: 999px; padding: .25rem .6rem; font-size: .78rem; }
.char-count { font-size: .8rem; color: var(--text-soft); margin-top: .3rem; text-align: right; }
.hidden-by-default { display: none; }

.btn-icon-label { gap: .4rem; }
.btn-icon-only { width: 36px; height: 36px; padding: 0; display: inline-flex; align-items: center; justify-content: center; }
.table-tools { display: flex; justify-content: space-between; align-items: center; gap: .8rem; flex-wrap: wrap; margin-bottom: .8rem; }
.filter-inline, .records-inline { display: flex; align-items: center; gap: .5rem; }
.filter-inline svg { color: var(--blue); }
.compact-select { height: 36px; min-width: 170px; }
.compact-select-sm { min-width: 80px; width: 80px; }

.sort-link {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-weight: 700;
}
.sort-link:hover { color: var(--blue); }
.sort-link svg { width: 14px; height: 14px; opacity: .75; }

.status-chip { border-radius: 999px; padding: .2rem .55rem; font-size: .78rem; font-weight: 600; display: inline-flex; }
.badge-amd { background: #eaf4ff; color: #1e4fa3; }
.badge-lic { background: #e9f9ee; color: #2f7f3b; }
.badge-chitl { background: #fff2e6; color: #b45309; }
.badge-default { background: #f0f2f4; color: #4b5563; }
.status-badge-active { background: #e9f9ee; color: #2f7f3b; border-radius: 999px; padding: .22rem .55rem; font-size: .76rem; font-weight: 600; }
.status-badge-inactive { background: #fff1f2; color: #be123c; border-radius: 999px; padding: .22rem .55rem; font-size: .76rem; font-weight: 600; }

.table-footer { display: none; }
.disabled-link { pointer-events: none; opacity: .45; }

.native-multi-hidden { display: none; }
.multi-select-enhanced { display: grid; gap: .45rem; }
.multi-search { height: 40px; }
.multi-options {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--white);
  max-height: 180px;
  overflow: auto;
  padding: .35rem;
  display: grid;
  gap: .3rem;
}
.multi-option-item {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--input-bg);
  text-align: left;
  padding: .4rem .55rem;
  color: var(--text);
}
.multi-option-item.selected {
  border-color: var(--blue);
  background: var(--sidebar-active-bg);
  color: var(--blue);
}
.multi-chips { display: flex; flex-wrap: wrap; gap: .35rem; min-height: 22px; }
.chip-remove {
  border: 0;
  background: transparent;
  margin-left: .35rem;
  color: inherit;
  cursor: pointer;
  font-size: .75rem;
}

.sigla-with-info {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}
.sigla-label { font-weight: 600; color: var(--blue); }
.sigla-info-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--input-bg);
  color: var(--text-soft);
  text-decoration: none;
  flex-shrink: 0;
  transition: color .15s, border-color .15s, background .15s;
}
.sigla-info-btn:hover {
  color: var(--blue);
  border-color: var(--blue);
  background: var(--sidebar-active-bg);
}
.sigla-info-btn svg { width: .65rem; height: .65rem; }
.fis-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .04em;
  padding: .1rem .35rem;
  border-radius: 4px;
  background: var(--sidebar-active-bg);
  color: var(--blue);
  vertical-align: middle;
}

.modality-tabs { display: grid; gap: 1rem; }
.modality-tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
}
.modality-tab {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--input-bg);
  color: var(--text);
  padding: .35rem .75rem;
  font-size: .88rem;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
}
.modality-tab:hover { border-color: var(--blue); color: var(--blue); }
.modality-tab.active {
  border-color: var(--blue);
  background: var(--sidebar-active-bg);
  color: var(--blue);
  font-weight: 600;
}
.modality-tab-meta {
  font-size: .75rem;
  color: var(--text-soft);
  background: var(--white);
  border-radius: 999px;
  padding: .1rem .45rem;
}
.modality-panel { display: none; }
.modality-panel.active { display: block; }
.modality-profile-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1.25rem;
  font-size: .9rem;
  color: var(--text-soft);
}
.fis-summary-chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.modality-badge-row { display: flex; flex-wrap: wrap; gap: .3rem; }
.modality-badge {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .03em;
  padding: .15rem .45rem;
  border-radius: 999px;
  background: var(--sidebar-active-bg);
  color: var(--blue);
}
.athlete-filter-check { display: flex; align-items: flex-end; }
.fis-only-check {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .9rem;
  color: var(--text-soft);
  margin: 0;
  padding: .55rem 0;
}
.fis-inline-filters .athlete-filter-metric-row {
  align-items: flex-end;
}
.fis-field-hint {
  font-size: .75rem;
  color: var(--text-soft);
  font-weight: 500;
}

@media (max-width: 1024px) {
  .app-shell { grid-template-columns: 1fr; }
  .app-sidebar { position: static; height: auto; }
  .metrics-grid, .content-grid, .form-grid, .form-grid-3 { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .login-card { padding: 1.4rem; }
}
