
:root {
  --bg: #1e2130;
  --surface: #272b3d;
  --surface2: #2f344a;
  --surface3: #373d55;
  --border: #424868;
  --border-light: #525a7a;
  --gold: #c9a96e;
  --gold-dim: rgba(201,169,110,0.15);
  --gold-glow: rgba(201,169,110,0.08);
  --sage: #7eab93;
  --sage-dim: rgba(126,171,147,0.12);
  --cream: #ffffff;
  --cream-dim: rgba(255,255,255,0.85);
  --muted: rgba(255,255,255,0.5);
  --danger: #e8645a;
  --danger-dim: rgba(232,100,90,0.12);
  --success: #7eab93;
  --tx: #ffffff;
  --tx-muted: #ffffff;
  --tx-faint: #ffffff;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
  --r: 10px;
  --r-sm: 6px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--tx);
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  min-height: 100vh;
}

/* ─── NOISE OVERLAY ─── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: .4;
}

/* ─── SIDEBAR LAYOUT ─── */
/* ── Estado de autenticação ── */
#loginScreen { display: none; }
#alunoScreen { display: none; }
#app { display: none; }
body.state-login  #loginScreen { display: flex !important; }
body.state-app    #app         { display: flex !important; }
body.state-app    #loginScreen { display: none !important; }
body.state-app    #alunoScreen { display: none !important; }
body.state-aluno  #alunoScreen { display: block !important; }
body.state-aluno  #loginScreen { display: none !important; }
body.state-aluno  #app         { display: none !important; }

#app {
  display: flex;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

#sidebar {
  width: 220px;
  min-height: 100vh;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  flex-shrink: 0;
}

#sidebar-logo {
  padding: 28px 24px 24px;
  border-bottom: 1px solid var(--border);
}

#sidebar-logo .logo-mark {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 300;
  letter-spacing: 0.02em;
  color: var(--cream);
  line-height: 1;
}

#sidebar-logo .logo-mark em {
  color: var(--gold);
  font-style: italic;
}

#sidebar-logo .logo-sub {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 4px;
}

#sidebar-nav {
  flex: 1;
  padding: 12px 12px;
  overflow-y: auto;
  overflow-x: hidden;
}

.nav-label {
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tx-faint);
  padding: 10px 12px 6px;
}

.nav-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  border: none;
  background: transparent;
  color: var(--tx-muted);
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  text-align: left;
  transition: all 0.18s ease;
  letter-spacing: 0.01em;
}

.nav-btn .nav-icon {
  width: 18px;
  height: 18px;
  opacity: 0.5;
  flex-shrink: 0;
  transition: opacity 0.18s;
}

.nav-btn:hover {
  background: var(--surface2);
  color: var(--cream);
}

.nav-btn:hover .nav-icon { opacity: 0.75; }

.nav-btn.active {
  background: var(--gold-dim);
  color: var(--gold);
  font-weight: 500;
  border: 1px solid rgba(201,169,110,0.2);
}

.nav-btn.active .nav-icon { opacity: 1; filter: brightness(1.4) sepia(1) saturate(2) hue-rotate(-10deg); }

#sidebar-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--tx-faint);
  text-align: center;
  letter-spacing: 0.04em;
}

/* ─── MAIN CONTENT ─── */
#main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

#topbar {
  padding: 16px 28px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  position: sticky;
  top: 0;
  z-index: 100;
}

#topbar-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: 0.02em;
}

#topbar-date {
  font-size: 11.5px;
  color: var(--tx-muted);
  letter-spacing: 0.04em;
}

#content {
  padding: 24px 28px;
  flex: 1;
}

/* ─── SECTIONS ─── */
section[id^="tab-"] { display: none; }

/* ─── CARDS ─── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 18px;
  margin-bottom: 14px;
}

.card-title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 400;
  color: var(--cream);
  letter-spacing: 0.02em;
  margin-bottom: 4px;
}

.card-sub {
  font-size: 11px;
  color: var(--tx-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

/* ─── KPI GRID ─── */
.kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}

.kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s;
}

.kpi::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), transparent);
}

.kpi:hover { border-color: var(--border-light); }

.kpi .k-label {
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tx-faint);
  margin-bottom: 10px;
}

.kpi .k-value {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: 0.01em;
  line-height: 1;
}

.kpi .k-sub {
  font-size: 11px;
  color: var(--gold);
  margin-top: 4px;
}

/* ─── INPUTS & CONTROLS ─── */
.controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-end;
}

input, select, textarea {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--tx);
  padding: 7px 10px;
  font-family: var(--font-body);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
}

input:focus, select:focus, textarea:focus {
  border-color: var(--gold);
  background: var(--surface3);
}

input::placeholder { color: var(--tx-faint); }

select option { background: var(--surface2); }

label.field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

label.field .lbl {
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tx-faint);
}

/* ─── BUTTONS ─── */
button {
  font-family: var(--font-body);
  font-size: 13px;
  cursor: pointer;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  padding: 7px 14px;
  transition: all 0.15s ease;
  font-weight: 500;
  letter-spacing: 0.02em;
}

button.primary {
  background: var(--gold);
  color: #1a1508;
  border-color: var(--gold);
}
button.primary:hover { background: #d4b27c; filter: brightness(1.05); }

button.ghost {
  background: transparent;
  color: var(--tx-muted);
  border-color: var(--border);
}
button.ghost:hover { background: var(--surface2); color: var(--cream); border-color: var(--border-light); }

button.sage-btn {
  background: var(--sage-dim);
  color: var(--sage);
  border-color: rgba(126,171,147,0.2);
}
button.sage-btn:hover { background: rgba(126,171,147,0.2); }

button.danger-btn {
  background: var(--danger-dim);
  color: var(--danger);
  border-color: rgba(232,100,90,0.2);
}
button.danger-btn:hover { background: rgba(232,100,90,0.22); }

/* ─── DIVIDER ─── */
.hr { height: 1px; background: var(--border); margin: 12px 0; }

/* ─── TABLES ─── */
.table {
  width: 100%;
  border-collapse: collapse;
}

.table thead th {
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tx-faint);
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  font-weight: 500;
  text-align: left;
}

.table tbody td {
  padding: 9px 10px;
  border-bottom: 1px solid var(--border);
  color: var(--cream-dim);
  font-size: 13px;
}

.table tbody tr:last-child td { border-bottom: none; }

.table tbody tr:hover td { background: var(--surface2); }

.table input { width: 100%; background: transparent; border: 1px solid transparent; padding: 4px 6px; }
.table input:focus { background: var(--surface2); border-color: var(--gold); border-radius: 4px; }

/* ─── BADGE ─── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 11px;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.badge-active { background: var(--sage-dim); color: var(--sage); border: 1px solid rgba(126,171,147,0.2); }
.badge-cancel { background: var(--danger-dim); color: var(--danger); border: 1px solid rgba(232,100,90,0.2); }
.badge-open { background: var(--gold-dim); color: var(--gold); border: 1px solid rgba(201,169,110,0.2); }
.badge-paid { background: var(--sage-dim); color: var(--sage); border: 1px solid rgba(126,171,147,0.2); }

/* ─── AGENDA ─── */
.wk-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.grid-week {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.grid-week th {
  padding: 8px 6px;
  border-bottom: 1px solid var(--border);
  text-align: center;
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tx-faint);
  font-weight: 500;
}

.grid-week .hour-col {
  padding: 5px 8px;
  font-size: 11px;
  color: var(--tx-faint);
  text-align: right;
  white-space: nowrap;
  background: var(--bg);
  width: 52px;
  vertical-align: top;
  border-right: 1px solid var(--border);
}

.grid-week td {
  border: 1px solid var(--border);
  padding: 3px 4px;
  vertical-align: top;
  min-height: 38px;
  height: 38px;
  cursor: pointer;
  transition: background 0.12s;
}

.grid-week td:hover { background: var(--surface3); }

.grid-week td.over { background: rgba(232,100,90,0.08); }
.grid-week td.ok { background: rgba(126,171,147,0.06); }

.ev {
  display: block;
  font-size: 11px;
  margin: 2px 0;
  padding: 3px 6px;
  border-radius: 4px;
  background: var(--gold-dim);
  border: 1px solid rgba(201,169,110,0.18);
  color: var(--gold);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wk-label {
  font-size: 12px;
  font-weight: 500;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--cream-dim);
}

.wk-label.alert { color: var(--danger); border-color: rgba(232,100,90,0.3); background: var(--danger-dim); }

/* ─── DRE TABLE ─── */
#dreTable .table td { font-size: 13px; }
#dreTable button.ghost {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.01em;
  color: var(--cream);
  padding: 2px 6px;
  border-color: transparent;
}
#dreTable button.ghost:hover { color: var(--gold); background: var(--gold-glow); border-color: rgba(201,169,110,0.15); }

/* ─── MODAIS ─── */
.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1500;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.15s ease;
}

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal .box {
  background: var(--surface);
  border: 1px solid var(--border-light);
  border-radius: 14px;
  max-width: 540px;
  width: 92vw;
  padding: 22px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5), 0 0 0 1px rgba(201,169,110,0.06);
  animation: slideUp 0.2s ease;
}

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

.modal-title {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: 0.02em;
  margin-bottom: 16px;
}

/* ─── DRILL PANEL ─── */
#dreDrillInline {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
}

#dreDrillInline .box {
  background: var(--surface);
  color: var(--tx);
  border: 1px solid var(--border-light);
  border-radius: 14px;
  max-width: 720px;
  width: 94vw;
  max-height: 80vh;
  overflow: auto;
  padding: 22px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}

/* ─── SECTION HEADER ─── */
.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.section-header-left h2 {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: 0.02em;
  line-height: 1;
}

.section-header-left .section-desc {
  font-size: 12px;
  color: var(--tx-faint);
  letter-spacing: 0.04em;
  margin-top: 5px;
}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--surface); }
::-webkit-scrollbar-thumb { background: var(--border-light); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--tx-faint); }

/* ─── CHECKBOX ─── */
input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--gold);
  cursor: pointer;
}

/* ─── QUICK STATS BAR ─── */
.stat-bar {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 24px;
  margin-bottom: 14px;
}

.stat-bar .stat-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.stat-bar .stat-item .s-label {
  font-size: 11px;
  color: var(--tx-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.stat-bar .stat-item .s-val {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 300;
  color: var(--cream);
}

/* ─── CANVAS FIX ─── */
canvas { max-height: 220px; }

/* ─── RESPONSIVE ─── */
/* ─── TABLET & MOBILE RESPONSIVO ─── */

/* Navbar inferior para tablet/mobile */
#bottomNav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 200;
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 6px 0 max(6px, env(safe-area-inset-bottom));
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.bnav-btn {
  display: flex; flex-direction: column; align-items: center;
  gap: 2px; padding: 4px 8px; border: none; background: none;
  color: var(--tx-faint); cursor: pointer; font-size: 9.5px;
  letter-spacing: .04em; min-width: 52px; border-radius: 8px;
  transition: color .15s;
}
.bnav-btn .bnav-icon { font-size: 20px; line-height: 1; }
.bnav-btn.active { color: var(--gold); }
.bnav-btn.active .bnav-icon { transform: scale(1.1); }

/* Overlay do menu lateral em tablet */
#sidebarOverlay {
  display: none;
  position: fixed; inset: 0; z-index: 149;
  background: rgba(0,0,0,.55);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

@media (max-width: 1024px) {
  /* Sidebar vira gaveta lateral */
  #sidebar {
    position: fixed !important;
    top: 0; left: 0; bottom: 0;
    z-index: 150;
    transform: translateX(-100%);
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 24px rgba(0,0,0,.5);
    width: 260px !important;
  }
  #sidebar.open { transform: translateX(0); }
  #sidebarOverlay { display: block; opacity: 0; pointer-events: none; transition: opacity .25s; }
  #sidebarOverlay.open { opacity: 1; pointer-events: auto; }

  /* Header mobile com botão menu */
  #mobileHeader {
    display: flex !important;
    position: sticky; top: 0; z-index: 100;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 10px 16px;
    align-items: center; justify-content: space-between;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }

  #app { flex-direction: column; }
  #main-content { padding: 14px 14px 90px; }
  #bottomNav { display: flex; justify-content: space-around; }
  .kpis { grid-template-columns: repeat(2,1fr) !important; }
  .rel-kpi-row { grid-template-columns: repeat(2,1fr) !important; }
  .controls { flex-direction: column !important; }
  .card { padding: 14px !important; }

  /* Grids de 2 colunas → 1 coluna */
  [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }
  [style*="grid-template-columns:1fr 1fr"]  { grid-template-columns: 1fr !important; }
  [style*="grid-template-columns: 1fr 2fr"] { grid-template-columns: 1fr !important; }

  /* Tabelas com scroll horizontal */
  .table, table { display: block !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch; }

  /* Funil kanban com scroll */
  #funilBoard { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }

  /* Campos de formulário maiores para touch */
  input, select, textarea {
    font-size: 16px !important; /* evita zoom no iOS */
    min-height: 40px;
  }
  button, .primary, .ghost, .sage-btn, .danger-btn {
    min-height: 40px;
    padding: 8px 14px !important;
  }

  /* Modais em fullscreen no tablet */
  .modal > div, [style*="max-width:520px"], [style*="max-width:480px"],
  [style*="max-width:500px"], [style*="max-width:460px"] {
    max-width: 96vw !important;
    max-height: 88vh !important;
    overflow-y: auto;
  }

  /* Dinamômetro — grid 3 → linha única */
  #dinoGridMMSS > div > div > div,
  #dinoGridMMII > div > div > div {
    grid-template-columns: 1fr !important;
  }
}

/* Smartphone pequeno */
@media (max-width: 480px) {
  #main-content { padding: 10px 10px 90px; }
  .kpis { grid-template-columns: 1fr 1fr !important; }
  .section-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  #bottomNav .bnav-btn { font-size: 8.5px; min-width: 44px; }
  #bottomNav .bnav-btn .bnav-icon { font-size: 18px; }
}

/* iOS safe area */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  #bottomNav { padding-bottom: max(8px, env(safe-area-inset-bottom)); }
}

/* ─── LOADING STATE ─── */
.empty-state {
  text-align: center;
  padding: 40px 20px;
  color: var(--tx-faint);
}

.empty-state .es-icon {
  font-size: 32px;
  margin-bottom: 10px;
  opacity: 0.4;
}

.empty-state .es-text {
  font-size: 13px;
  letter-spacing: 0.04em;
}

/* ─── DRE HIGHLIGHT ─── */
.dre-highlight td { background: var(--surface2) !important; }
.dre-highlight td:first-child { font-weight: 600; color: var(--gold) !important; }

/* ─── OCORRÊNCIAS NO PAINEL DE TREINO ─── */
.tp-ocorr-area{
  border-top:1px solid var(--border);
  padding:10px 12px 12px;
  background:rgba(0,0,0,.12);
}
.tp-ocorr-title{
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--tx-faint);font-weight:600;margin-bottom:8px;
}
.tp-ocorr-form{display:flex;gap:6px;align-items:flex-start;flex-wrap:wrap;margin-bottom:8px;}
.tp-ocorr-form select{font-size:12px;min-width:130px;}
.tp-ocorr-form textarea{
  flex:1;min-width:160px;resize:none;height:56px;
  font-size:12px;line-height:1.4;padding:6px 8px;
}
.tp-ocorr-form button{font-size:12px;padding:6px 12px;align-self:flex-end;}
.tp-ocorr-list{display:flex;flex-direction:column;gap:5px;max-height:180px;overflow-y:auto;}
.tp-ocorr-item{
  padding:7px 9px;border-radius:var(--r-sm);
  background:var(--surface2);border-left:3px solid var(--border);
  font-size:12px;
}
.tp-ocorr-item.tipo-positivo{border-left-color:var(--sage);}
.tp-ocorr-item.tipo-atencao {border-left-color:#fbbf24;}
.tp-ocorr-item.tipo-negativo{border-left-color:var(--danger);}
.tp-ocorr-item.tipo-neutro  {border-left-color:var(--border-light);}
.tp-ocorr-meta{display:flex;align-items:center;gap:8px;margin-bottom:3px;}
.tp-ocorr-data{font-size:10.5px;color:var(--tx-faint);}
.tp-ocorr-tipo{font-size:10px;padding:1px 7px;border-radius:20px;font-weight:600;}
.tipo-badge-positivo{background:rgba(126,171,147,.15);color:var(--sage);}
.tipo-badge-atencao {background:rgba(251,191,36,.12);color:#fbbf24;}
.tipo-badge-negativo{background:rgba(232,100,90,.12);color:var(--danger);}
.tipo-badge-neutro  {background:rgba(255,255,255,.05);color:var(--tx-muted);}
.tp-ocorr-texto{color:var(--tx-muted);line-height:1.5;}
/* Relatório de ocorrências */
.ocorr-rel-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:14px 16px;margin-bottom:8px;
}
.ocorr-rel-nome{font-weight:700;font-size:14px;color:var(--cream);margin-bottom:8px;}
.ocorr-rel-item{
  padding:6px 9px;border-radius:var(--r-sm);
  background:var(--surface2);border-left:3px solid var(--border);
  font-size:12.5px;margin-bottom:5px;
}
.ocorr-rel-item.tipo-positivo{border-left-color:var(--sage);}
.ocorr-rel-item.tipo-atencao {border-left-color:#fbbf24;}
.ocorr-rel-item.tipo-negativo{border-left-color:var(--danger);}
.ocorr-rel-item.tipo-neutro  {border-left-color:var(--border-light);}
#agTreinoArea{
  display:none;
  flex-direction:column;
  border:1px solid var(--border);
  border-radius:var(--r);
  background:var(--surface);
  overflow:hidden;
  margin-bottom:12px;
  transition:border-radius .18s;
}
#agTreinoArea.visible{ display:flex; }

/* ── Modo tela cheia ── */
#agTreinoArea.fullscreen{
  position:fixed;
  inset:0;
  z-index:1200;
  border-radius:0;
  border:none;
  margin:0;
}
#agTreinoArea.fullscreen #agTreinoColunas{
  max-height:calc(100vh - 56px) !important;
  flex:1;
}
/* Colunas dividem o espaço disponível em fullscreen */
#agTreinoArea.fullscreen .tp-coluna{
  flex:1;
  min-width:260px;
  max-width:none;
}
/* Overlay escuro atrás do painel fullscreen */
#agTreinoOverlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(3px);
  z-index:1199;
}
#agTreinoToolbar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:10px 14px;
  background:var(--surface2);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
#agTreinoToolbar .tp-title{
  font-family:var(--font-display);font-size:17px;font-weight:300;
  color:var(--cream);letter-spacing:.02em;flex:1;
}
#agTreinoColunas{
  display:flex;
  flex-direction:row;
  overflow-x:auto;
  overflow-y:hidden;
  min-height:300px;
  max-height:70vh;
}
#agTreinoColunas::-webkit-scrollbar{height:5px;}
/* Cada coluna de aluno */
.tp-coluna{
  width:300px;min-width:280px;flex-shrink:0;
  display:flex;flex-direction:column;
  border-right:1px solid var(--border);
  overflow-y:auto;overflow-x:hidden;
}
.tp-coluna:last-child{border-right:none;}
.tp-col-header{
  padding:10px 13px 8px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:2;flex-shrink:0;
}
.tp-col-nome{
  font-weight:700;font-size:13.5px;color:var(--cream);
  display:flex;align-items:center;justify-content:space-between;
}
.tp-col-close{
  background:transparent;border:none;
  color:var(--tx-faint);font-size:18px;cursor:pointer;
  line-height:1;padding:0 2px;transition:color .12s;
}
.tp-col-close:hover{color:var(--danger);}
.tp-nivel{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;margin-top:5px;
}
.tp-nivel.nivel-iniciante    {background:rgba(126,171,147,.15);color:var(--sage);border:1px solid rgba(126,171,147,.3);}
.tp-nivel.nivel-intermediario{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.3);}
.tp-nivel.nivel-avancado     {background:rgba(232,100,90,.12);color:var(--danger);border:1px solid rgba(232,100,90,.3);}
.tp-col-body{padding:10px 12px;}
.tp-dia{margin-bottom:8px;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.tp-dia-h{
  padding:7px 10px;background:var(--surface2);
  display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;
}
.tp-dia-h:hover{background:var(--surface3);}
.tp-dia-title{font-weight:600;font-size:12.5px;color:var(--cream);flex:1;}
.tp-dia-body{padding:8px 10px;}
.tp-ex{
  display:flex;align-items:flex-start;gap:7px;
  padding:6px 0;border-bottom:1px solid var(--border);
}
.tp-ex:last-child{border-bottom:none;}
.tp-ex-num{
  min-width:18px;height:18px;border-radius:5px;
  background:var(--gold-dim);color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;margin-top:1px;flex-shrink:0;
}
.tp-ex-info{flex:1;min-width:0;}
.tp-ex-name{color:var(--cream);font-weight:500;font-size:12px;}
.tp-ex-meta{font-size:11px;color:var(--tx-faint);margin-top:2px;}
/* Nome clicável na grade */
.ev-nome{
  color:var(--gold);border-bottom:1px dotted rgba(201,169,110,.4);cursor:pointer;
}
.ev-nome:hover{border-bottom-color:var(--gold);}
.nivel-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.04em;}
.nivel-iniciante    {background:rgba(126,171,147,.15);color:var(--sage);border:1px solid rgba(126,171,147,.3);}
.nivel-intermediario{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.3);}
.nivel-avancado     {background:rgba(232,100,90,.12);color:var(--danger);border:1px solid rgba(232,100,90,.3);}
.treino-dia{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:10px;}
.treino-dia-header{padding:10px 14px;background:var(--surface2);display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;}
.treino-dia-header:hover{background:var(--surface3);}
.treino-dia-title{font-weight:600;font-size:13.5px;color:var(--cream);flex:1;}
.treino-dia-body{padding:0 12px 12px;}
.ex-row{display:grid;grid-template-columns:1fr 80px 80px 70px 70px 28px;gap:6px;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:12.5px;}
.ex-row:last-child{border-bottom:none;}
.ex-row .ex-name{color:var(--cream);font-weight:500;}
.ex-row .ex-cat{font-size:11px;color:var(--tx-faint);letter-spacing:.04em;}
.ex-row input{font-size:12px;padding:4px 6px;text-align:center;}
.ex-row .ex-del{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(232,100,90,.2);border-radius:4px;padding:3px 6px;cursor:pointer;font-size:13px;}
.ex-row .ex-del:hover{background:rgba(232,100,90,.22);}
.lib-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--r-sm);background:var(--surface2);border:1px solid var(--border);font-size:12.5px;}
.lib-row .lr-name{flex:1;font-weight:500;color:var(--cream);}
.lib-row .lr-cat{font-size:11px;padding:2px 7px;border-radius:12px;background:var(--surface3);color:var(--tx-muted);}
.lib-row .lr-niv{font-size:11px;padding:2px 7px;border-radius:12px;}
.lr-niv.iniciante    {background:rgba(126,171,147,.12);color:var(--sage);}
.lr-niv.intermediario{background:rgba(251,191,36,.10);color:#fbbf24;}
.lr-niv.avancado     {background:rgba(232,100,90,.10);color:var(--danger);}
.lr-niv.todos        {background:rgba(201,169,110,.10);color:var(--gold);}

@media print {
  * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }
  body > * { display: none !important; }
  body.printing-lib #libPrintContainer {
    display: block !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important;
    background: #fff !important;
  }
  #libPrintContainer {
    font-family: Arial, sans-serif;
    background: #fff !important;
    color: #111 !important;
    padding: 8mm 10mm !important;
    margin: 0 !important;
  }
  .lp-header {
    text-align: center;
    margin-bottom: 10pt;
    padding-bottom: 6pt;
    border-bottom: 2px solid #111;
  }
  .lp-header h1 { font-size: 16pt; font-weight: 700; color: #000; margin: 0 0 3pt; }
  .lp-header p  { font-size: 8pt; color: #555; margin: 0; }
  .lp-grupo { margin-bottom: 10pt; }
  .lp-grupo-titulo {
    font-size: 12pt; font-weight: 700; color: #fff !important;
    background: #111 !important;
    padding: 5pt 8pt; margin-bottom: 6pt; border-radius: 2pt;
  }
  .lp-nivel-titulo {
    font-size: 7.5pt; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: #333 !important; border-bottom: 1pt solid #333;
    padding-bottom: 2pt; margin: 6pt 0 5pt;
  }
  .lp-grid {
    display: grid !important;
    grid-template-columns: repeat(3,1fr) !important;
    gap: 5pt !important;
  }
  .lp-card {
    border: 1pt solid #bbb !important;
    border-radius: 2pt; padding: 5pt 6pt;
    background: #fff !important;
    break-inside: avoid; page-break-inside: avoid;
  }
  .lp-card-nome  { font-size: 8.5pt; font-weight: 700; color: #000 !important; margin-bottom: 2pt; }
  .lp-card-equip { font-size: 7.5pt; color: #333 !important; margin-bottom: 1pt; }
  .lp-card-series{ font-size: 7.5pt; color: #444 !important; margin-bottom: 1pt; }
  .lp-card-desc  { font-size: 7pt;   color: #555 !important; line-height: 1.3; margin-bottom: 3pt; }
  .lp-card-video { font-size: 7pt; color: #c00 !important; border: 1pt solid #c00 !important; padding: 1pt 5pt; border-radius: 8pt; display: inline-block; text-decoration: none; }
  .lp-card-novideo { font-size: 6.5pt; color: #aaa !important; font-style: italic; }
}
.lib-rel-grupo { margin-bottom: 22px; }
.lib-rel-grupo-titulo {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 300;
  color: var(--cream);
  padding: 10px 14px;
  border-left: 4px solid var(--gold);
  background: var(--surface2);
  border-radius: 0 var(--r) var(--r) 0;
  margin-bottom: 10px;
  letter-spacing: .04em;
}
.lib-rel-nivel-titulo {
  font-size: 10.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--tx-faint); padding: 6px 0 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}
.lib-rel-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 10px; margin-bottom: 12px; }
.lib-rel-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); padding: 12px 14px;
}
.lib-rel-nome { font-weight: 700; font-size: 13px; color: var(--cream); margin-bottom: 4px; }
.lib-rel-equip { font-size: 11.5px; color: var(--gold); margin-bottom: 4px; }
.lib-rel-series { font-size: 12px; color: var(--tx-muted); margin-bottom: 4px; }
.lib-rel-desc { font-size: 11.5px; color: var(--tx-faint); line-height: 1.5; margin-bottom: 6px; }
.lib-rel-video-btn {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11.5px; padding: 3px 10px; border-radius: 20px;
  background: rgba(232,100,90,.1); color: #f66;
  border: 1px solid rgba(232,100,90,.25); text-decoration: none;
  cursor: pointer;
}
.rel-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px;overflow-x:auto;}
.rel-tab{padding:9px 18px;font-size:12.5px;font-weight:500;color:var(--tx-muted);border:none;background:transparent;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s;}
.rel-tab:hover{color:var(--cream);}
.rel-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
.rel-pane{display:none;}.rel-pane.active{display:block;}
.rel-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px;}
.rel-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:13px 15px;position:relative;overflow:hidden;}
.rel-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);}
.rel-kpi .rk-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-faint);margin-bottom:8px;}
.rel-kpi .rk-val{font-family:var(--font-display);font-size:24px;font-weight:300;color:var(--cream);line-height:1;}
.rel-kpi .rk-sub{font-size:11px;color:var(--tx-muted);margin-top:4px;}
.rel-table th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-faint);padding:7px 10px;border-bottom:1px solid var(--border);font-weight:600;}
.rel-table td{padding:8px 10px;border-bottom:1px solid var(--border);font-size:12.5px;color:var(--cream-dim);}
.rel-table tr:last-child td{border-bottom:none;}
.rel-table tr:hover td{background:var(--surface2);}
.rel-table .num{text-align:right;font-variant-numeric:tabular-nums;}
.rel-delta-up  {color:#4ade80;font-weight:700;}
.rel-delta-down{color:var(--danger);font-weight:700;}
.rel-delta-flat{color:var(--tx-faint);}
/* Perfil aluno */
.aluno-card-full{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;margin-bottom:10px;}
.aluno-card-full .ac-top{display:flex;align-items:flex-start;gap:14px;}
.aluno-card-full .ac-avatar{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--surface3),var(--border-light));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;color:var(--gold);flex-shrink:0;}
.aluno-card-full .ac-info{flex:1;}
.aluno-card-full .ac-nome{font-weight:700;font-size:15px;color:var(--cream);}
.aluno-card-full .ac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:10px;font-size:12px;}
.aluno-card-full .ac-field span:first-child{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-faint);display:block;margin-bottom:2px;}
.aluno-card-full .ac-field span:last-child{color:var(--tx-muted);}
/* Comparativo avaliação */
.comp-table th,.comp-table td{padding:7px 10px;border-bottom:1px solid var(--border);font-size:12px;}
.comp-table th{background:var(--surface2);color:var(--tx-faint);font-size:10px;letter-spacing:.08em;text-transform:uppercase;}
.comp-table .better{color:var(--sage);font-weight:700;}
.comp-table .worse {color:var(--danger);font-weight:700;}
.plano-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:18px 20px;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .18s;position:relative;overflow:hidden;
}
.plano-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.plano-mensal::before    {background:linear-gradient(90deg,var(--sage),transparent);}
.plano-trimestral::before{background:linear-gradient(90deg,var(--gold),transparent);}
.plano-semestral::before {background:linear-gradient(90deg,#a78bfa,transparent);}
/* grupo de frequência */
.plano-freq-header{
  grid-column:1/-1;
  display:flex;align-items:center;gap:12px;
  padding:10px 4px 4px;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--tx-faint);font-weight:600;
}
.plano-freq-header::after{content:'';flex:1;height:1px;background:var(--border);}
.plano-freq-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 12px;border-radius:20px;font-size:11.5px;font-weight:700;
  letter-spacing:.04em;white-space:nowrap;
}
.freq-2x{background:rgba(59,130,246,.12);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}
.freq-3x{background:rgba(201,169,110,.12);color:var(--gold);border:1px solid rgba(201,169,110,.2);}
.plano-card:hover{border-color:var(--border-light);}
.plano-card.inativo{opacity:.5;}
.plano-nome{font-family:var(--font-display);font-size:22px;font-weight:300;color:var(--cream);letter-spacing:.02em;}
.plano-preco{font-family:var(--font-display);font-size:34px;font-weight:300;line-height:1;color:var(--cream);}
.plano-preco span{font-size:14px;color:var(--tx-muted);font-family:var(--font-body);}
.plano-desc{font-size:12.5px;color:var(--tx-muted);line-height:1.6;}
.plano-tags{display:flex;flex-wrap:wrap;gap:6px;}
.plano-tag{font-size:11px;padding:2px 9px;border-radius:20px;background:var(--surface2);border:1px solid var(--border);color:var(--tx-muted);}
.plano-tag.destaque{background:var(--gold-dim);color:var(--gold);border-color:rgba(201,169,110,.25);}
.assinante-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);background:var(--surface2);border:1px solid var(--border);margin-bottom:6px;font-size:12.5px;flex-wrap:wrap;}
.assinante-nome{flex:1;font-weight:600;color:var(--cream);min-width:100px;}
.assinante-datas{font-size:11.5px;color:var(--tx-muted);}
.assinante-status{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:600;white-space:nowrap;}
.st-ativo   {background:var(--sage-dim);color:var(--sage);border:1px solid rgba(126,171,147,.25);}
.st-vencido {background:var(--danger-dim);color:var(--danger);border:1px solid rgba(232,100,90,.25);}
.st-pendente{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(201,169,110,.25);}
.st-suspenso{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.3);}

/* ─── FUNIL CRM ─── */
.funil-col {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 120px;
}
.funil-col.drag-over { border-color: var(--gold); background: var(--gold-dim); }
.funil-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.funil-title {
  font-size: 10.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
}
.funil-count {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 300;
  color: var(--cream);
  line-height: 1;
}
.funil-card {
  padding: 8px 10px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: grab;
  transition: border-color .15s, transform .1s;
  font-size: 12.5px;
}
.funil-card:hover { border-color: var(--border-light); transform: translateY(-1px); }
.funil-card.dragging { opacity: .45; transform: scale(.97); }
.funil-card .fc-name { font-weight: 600; color: var(--cream); }
.funil-card .fc-tel  { font-size: 11px; color: var(--tx-muted); margin-top: 2px; }
.funil-card .fc-actions { display: flex; gap: 5px; margin-top: 6px; }
.funil-card .fc-btn {
  flex: 1; font-size: 10.5px; padding: 3px 0;
  border-radius: 4px; border: 1px solid var(--border);
  background: transparent; color: var(--tx-muted); cursor: pointer;
  transition: all .12s;
}
.funil-card .fc-btn:hover { background: var(--surface3); color: var(--cream); }
.funil-col-lead            .funil-title { color: #94a3b8; }
.funil-col-acompanhamento  .funil-title { color: #60a5fa; }
.funil-col-visita          .funil-title { color: #fbbf24; }
.funil-col-matriculado     .funil-title { color: var(--sage); }
.funil-col-dispensado      .funil-title { color: var(--danger); }
.funil-col-lead            { border-top: 2px solid #94a3b8; }
.funil-col-acompanhamento  { border-top: 2px solid #60a5fa; }
.funil-col-visita          { border-top: 2px solid #fbbf24; }
.funil-col-matriculado     { border-top: 2px solid var(--sage); }
.funil-col-dispensado      { border-top: 2px solid var(--danger); }

/* ─── DASHBOARD LISTS ─── */
.dash-empty { font-size: 12px; color: var(--tx-faint); letter-spacing: .04em; padding: 4px 0; }
.dash-item {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 7px 10px;
  border-radius: var(--r-sm);
  background: var(--surface2);
  border: 1px solid var(--border);
  font-size: 12.5px;
}
.dash-item .di-name { font-weight: 500; color: var(--cream); }
.dash-item .di-meta { font-size: 11px; color: var(--tx-muted); white-space: nowrap; }
.dash-item .di-badge {
  font-size: 10.5px; padding: 2px 7px; border-radius: 20px;
  font-weight: 500; letter-spacing: .03em; white-space: nowrap;
}
.di-badge.today { background: var(--gold-dim); color: var(--gold); border: 1px solid rgba(201,169,110,.25); }
.di-badge.soon  { background: var(--danger-dim); color: var(--danger); border: 1px solid rgba(232,100,90,.25); }
.di-badge.ok    { background: var(--sage-dim); color: var(--sage); border: 1px solid rgba(126,171,147,.2); }
.di-badge.susp  { background: var(--surface3); color: var(--tx-muted); border: 1px solid var(--border); }

