/* =======================================================================
   Fonte + tokens do tema
   ======================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@200;300;400;500;600;700;800&display=swap');

:root {
  --bs-font-sans-serif: "Plus Jakarta Sans", sans-serif;

  --bs-primary: #0085db;
  --bs-secondary: #707a82;
  --bs-danger: #fb977d;

  --bs-body-font-size: 0.875rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.5;
  --bs-body-color: #5A6A85;
  --bs-body-bg: #fff;

  --bs-border-color: #ebf1f6;
  --bs-heading-color: #2A3547;
  --bs-border-radius: 7px;

  --bs-gutter-x: 24px;
  --bs-btn-font-size: 0.875rem;

  --bs-card-spacer-y: 30px;
  --bs-card-spacer-x: 30px;
  --bs-card-border-width: 0px;

  --bs-success-rgb: 75,208,139;
  --bs-primary-rgb: 0,133,219;
  --bs-light-rgb: 246,249,252;
  --bs-dark-rgb: 42,53,71;

  /* Layout fixo */
  --gp-navbar-height: 64px;
  --gp-footer-height: 64px;

  /* Inputs menores */
  --gp-input-height: 28px;
  --gp-input-font-size: 0.875rem;
  --gp-input-py: 0.4rem;
  --gp-input-px: 0.6rem;

  /* Áreas seguras (footer fixo) */
  --footer-safe: calc(16px + env(safe-area-inset-bottom, 0px));

  /* Altura fixa do card da árvore (ajuste conforme sua “foto/banner”) */
  --tree-height: 420px;
}

/* =======================================================================
   Dark theme básico (opcional)
   ======================================================================= */
[data-bs-theme="dark"] {
  --bs-body-bg: #0f172a;
  --bs-body-color: #cbd5e1;
  --bs-border-color: #1f2937;
  --bs-heading-color: #e2e8f0;
}

/* =======================================================================
   Botões
   ======================================================================= */
.btn {
  --bs-btn-padding-x: 16px;
  --bs-btn-padding-y: 7px;
  --bs-btn-font-size: 0.875rem;
}
.btn-primary {
  --bs-btn-bg: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-focus-shadow-rgb: 49,132,253;
  --bs-btn-active-bg: var(--bs-primary);
  --bs-btn-active-border-color: var(--bs-primary);
  --bs-btn-disabled-bg: var(--bs-primary);
  --bs-btn-disabled-border-color: var(--bs-primary);
}
.btn-secondary {
  --bs-btn-bg: var(--bs-secondary);
  --bs-btn-border-color: var(--bs-secondary);
  --bs-btn-hover-bg: var(--bs-secondary);
  --bs-btn-hover-border-color: var(--bs-secondary);
  --bs-btn-focus-shadow-rgb: 49,132,253;
  --bs-btn-active-bg: var(--bs-secondary);
  --bs-btn-active-border-color: var(--bs-secondary);
  --bs-btn-disabled-bg: var(--bs-secondary);
  --bs-btn-disabled-border-color: var(--bs-secondary);
}
.btn-danger {
  --bs-btn-bg: var(--bs-danger);
  --bs-btn-border-color: var(--bs-danger);
  --bs-btn-hover-bg: var(--bs-danger);
  --bs-btn-hover-border-color: var(--bs-danger);
  --bs-btn-focus-shadow-rgb: 49,132,253;
  --bs-btn-active-bg: var(--bs-danger);
  --bs-btn-active-border-color: var(--bs-danger);
  --bs-btn-disabled-bg: var(--bs-danger);
  --bs-btn-disabled-border-color: var(--bs-danger);
}
.btn-outline-primary {
  --bs-btn-color: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-focus-shadow-rgb: 13,110,253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--bs-primary);
  --bs-btn-active-border-color: var(--bs-primary);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,.125);
  --bs-btn-disabled-color: var(--bs-primary);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--bs-primary);
}

/* =======================================================================
   Backgrounds / textos utilitários
   ======================================================================= */
.bg-light    { background-color: rgba(var(--bs-light-rgb),var(--bs-bg-opacity,1))!important; }
.text-success{ color: rgba(var(--bs-success-rgb),var(--bs-text-opacity,1))!important; }
.text-primary{ color: rgba(var(--bs-primary-rgb),var(--bs-text-opacity,1))!important; }
.text-dark   { color: rgba(var(--bs-dark-rgb),var(--bs-text-opacity,1))!important; }
.text-muted  { color: #5a6a85!important; }

/* =======================================================================
   Cards
   ======================================================================= */
.card{
  --bs-card-spacer-y: 30px;
  --bs-card-spacer-x: 30px;
  --bs-card-title-color: var(--bs-heading-color);
  --bs-card-subtitle-color: var(--bs-heading-color);
  --bs-card-border-width: 0px;
  --bs-card-box-shadow: rgba(145,158,171,.2) 0 0 2px 0, rgba(145,158,171,.12) 0 12px 24px -4px;
  --bs-card-inner-border-radius: 7px;
}

/* =======================================================================
   Container (limite de largura)
   ======================================================================= */
.container {
  max-width: min(96vw, 1400px);
}

/* =======================================================================
   Custom misc
   ======================================================================= */
html, body { overflow-x: hidden; }
.spacer { padding: 80px 0; }
.pro-demo { box-shadow: 0 4px 45px rgb(0 0 0 / 9%); }
.line-h33 { line-height: 33px; }

.icon-circle {
  background-color: rgb(var(--bs-dark-rgb));
  display: inline-block;
  width: 15px; height: 15px;
  border-radius: 100%;
  position: relative;
}
.icon-circle.circle-primary { background-color: rgb(var(--bs-primary-rgb)) !important; }
.icon-circle.circle-muted   { background-color: var(--bs-body-color) !important; opacity: .8; }
.icon-circle:before {
  content: '';
  position: absolute; left: 0; right: 0; top: 5px;
  width: 5px; height: 5px; border-radius: 100%; background-color: #fff; margin: 0 auto;
}

.live-box { position: relative; height: 275px; overflow: hidden; }

/* =======================================================================
   1) Inputs menores
   ======================================================================= */
.form-control,
.form-select,
.input-group-text{
  font-size: var(--gp-input-font-size);
  padding: var(--gp-input-py) var(--gp-input-px);
  border-radius: 6px;
}
.form-control:not(textarea){
  height: var(--gp-input-height);
  line-height: 1.3;
}
.form-select{
  line-height: 1.5;
  padding-right: 2rem;
}

/* =======================================================================
   2) Navbar fixa + respiro no topo
   ======================================================================= */
.navbar{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1030;
  min-height: var(--gp-navbar-height);
  box-shadow: 0 2px 10px rgba(42,53,71,.06);
}
body{
  padding-top: var(--gp-navbar-height);
}

/* =======================================================================
   3) Footer fixo + área segura
   ======================================================================= */
footer.site-footer{
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: var(--gp-footer-height);
  z-index: 1020;
  display: flex; align-items: center;
  background: #fff;
  border-top: 1px solid var(--bs-border-color);
}

/* A página principal já reserva espaço para o footer fixo */
main#mainContent{
  min-height: calc(100vh - var(--gp-navbar-height) - var(--gp-footer-height));
  padding-bottom: calc(var(--gp-footer-height) + var(--footer-safe));
}
main#mainContent::after{
  content: "";
  display: block;
  height: var(--footer-safe);
}

/* Se o footer não for fixo no mobile, reduzimos o preenchimento */
@media (max-width: 575.98px){
  footer.site-footer{ position: static; height:auto; }
  main#mainContent{
    min-height: auto;
    padding-bottom: 16px;
  }
  main#mainContent::after{ height: 0; }
}

/* =======================================================================
   Navbar mobile
   ======================================================================= */
@media (max-width: 991.98px){
  .navbar .navbar-collapse{
    background:#fff;
    padding:.75rem 0;
    border-top:1px solid var(--bs-border-color);
  }
}

/* =======================================================================
   Feed centralizado
   ======================================================================= */
.gp-feed{ max-width: 720px; margin-left:auto; margin-right:auto; }
.gp-post .card-body{ padding: 16px 20px; }
.gp-post{ margin-bottom: .75rem; }
@media (max-width: 575.98px){ .gp-feed{ max-width: 100%; } }

/* Variante compacta opcional (use .gp-feed.compact) */
.gp-feed.compact { max-width: 600px; }
.gp-feed.compact .gp-post .card-body{ padding: 10px 12px;}

/* =======================================================================
   Modal sempre acima (compat BS5)
   ======================================================================= */
.modal{
  position: fixed;
  top: 0; right: 0; bottom: 0; left: 0;
  display: none;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 2000 !important;
}
.modal.show{ display:block; }
.modal-backdrop{ position: fixed !important; z-index:1990 !important; }
body.modal-open{ overflow: hidden; }

/* Botão câmera flutuante (modal) */
.camera-fab{
  position: absolute;
  top: 190px;
  right: 5px;
  width: 38px; height: 38px;
  border-radius: 50%;
  background:#22c55e;
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  border:2px solid #fff;
  box-shadow:0 4px 12px rgba(0,0,0,.18);
  cursor:pointer;
}
.camera-fab svg{ display:block; }

/* =======================================================================
   Utilitários: listas/contêineres com "área segura" para footer fixo
   -----------------------------------------------------------------------
   Use .scroll-safe em qualquer área rolável para garantir espaçamento
   no final (evita último card atrás do footer).
   ======================================================================= */
.scroll-safe{
  padding-bottom: var(--footer-safe);
  scroll-padding-bottom: var(--footer-safe);
}
.scroll-safe > *{ scroll-margin-bottom: calc(var(--footer-safe) + 8px); }

/* =======================================================================
   CARD + PALCO DA ÁRVORE (ROLAGEM HORIZONTAL NO CARD)
   ======================================================================= */

/* travamos a altura do card da árvore */
.stage-card{ height: var(--tree-height); }
.stage-card .card-body{
  height: 100%;
  padding: .75rem;      /* ajuste fino de respiro */
  overflow: hidden;     /* impede vazamento vertical fora do card */
  min-height: 0;        /* importante em grid/flex */
}

/* palco (área rolável) ocupa 100% do card */
.tree-stage{
  --scale:0.95; --gap-x:calc(44px*var(--scale)); --gap-y:calc(56px*var(--scale));
  --edge-color:#14b8a6; --edge-thick:4;

  background:#f6f9fc;
  border-radius:12px;
  border:1px solid #e5e7eb;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
  padding:24px;

  position:relative;
  height: 100%;           /* usa toda a altura do card */

  /* rolagem apenas lateral dentro do card */
  overflow-x: auto;
  overflow-y: hidden;

  -webkit-overflow-scrolling: touch;
  min-height: 0;
  transform-origin: top center;
  will-change: scroll-position;
}

/* Container interno: pode alargar para criar overflow horizontal */
.tree-container{
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  padding-top: 10px;

  width: max-content;
  min-width: 100%;
}

/* Edges atrás do conteúdo */
.tree-edges{
  position:absolute;
  top:0; left:0;
  pointer-events:none;
  z-index:0;
}

/* ===== Safe area automática p/ contêineres roláveis (footer fixo) ===== */
@media (min-width: 576px){
  .table-responsive,
  .dataTables_wrapper .dataTables_scrollBody,
  .overflow-y-auto,
  .card-body.overflow-auto,
  .offcanvas-body,
  .modal-body,
  .fc .fc-scroller,
  .scroll-safe { /* sua utilidade existente */
    padding-bottom: calc(var(--footer-safe));
    scroll-padding-bottom: calc(var(--footer-safe));
  }
  /* Se usa tabs com conteúdo alto e rolável */
  .tab-pane.show.active.overflow-y-auto {
    padding-bottom: calc(var(--footer-safe));
    scroll-padding-bottom: calc(var(--footer-safe));
  }
}

/* Evita que o último item cole na borda ao focar (teclado / mobile) */
.scroll-safe > * { scroll-margin-bottom: calc(var(--footer-safe) + 8px); }
