/* =======================
   App Layout (PrimeFaces 15)
   ======================= */

/* --- Vari�veis de tema --- */
:root {
  --brand-topbar-bg: #3C4962;
  --brand-topbar-fg: #ffffff;
  --brand-page-bg: #ECF2F8;
  --separator-color: rgba(0,0,0,.08);
  --sidebar-width: 18rem;
  --topbar-height: 64px;
}

/* --- Resets globais & estrutura base --- */
html, body { height: 100%; margin: 0 !important; padding: 0 !important; }

body.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* garante largura total e zera espa�os inesperados */
body.app-shell > form,
body.app-shell > .page-body,
body.app-shell > footer {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

/* --- Topbar --- */
.topbar {
  height: var(--topbar-height);
  position: sticky;
  top: 0;
  z-index: 1000;
  background-color: var(--brand-topbar-bg) !important;
  margin: 0 !important;
}

/* �cones/bot�es na topbar */
.topbar .p-button.p-button-text.p-button-plain,
.topbar .pi {
  color: var(--brand-topbar-fg) !important;
}
.topbar .p-button.p-button-text.p-button-plain:hover {
  background: rgba(255,255,255,.08) !important;
}

/* --- �rea da p�gina --- */
.page-body {
  flex: 1 0 auto;
  display: flex;          /* aside + main lado a lado */
  background-color: var(--brand-page-bg);
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.page-body > * { margin-top: 0 !important; }

div.flex.flex-1 { min-width: 0; width: 100%; box-sizing: border-box; }
main.flex-1     { flex: 1 1 auto; min-width: 0; margin: 0 !important; padding: 0 !important; }
main.flex-1 > .surface-card {
  max-width: 100%;
  overflow: hidden;
  transition: margin .2s ease, width .2s ease;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* bordas discretas */
.surface-border { border-color: var(--separator-color) !important; }

/* --- Sidebar (desktop fixa) --- */
.sidebar-static {
  box-sizing: border-box;
  width: var(--sidebar-width);
  flex: 0 0 var(--sidebar-width);
  transition: width .2s ease, transform .2s ease, flex-basis .2s ease, padding .2s ease, border .2s ease;
}

/* Colapsada (esconde totalmente) */
@media (min-width: 768px) {
  .sidebar-static.sidebar-collapsed {
    width: 0 !important;
    flex: 0 0 0 !important;      /* <- ESSENCIAL */
    flex-basis: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    border-right: 0 !important;
    transform: none !important;
  }
}

/* Slim (�cones apenas) */
@media (min-width: 768px) {
  .sidebar-static.sidebar-slim {
    width: 4rem !important;
    flex-basis: 4rem !important;
    padding-left: .5rem !important;
    padding-right: .5rem !important;
 
  }

  /* centraliza os links de menu */
  .sidebar-static.sidebar-slim .p-menuitem-link,
  .sidebar-static.sidebar-slim .ui-menuitem-link {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0 !important;
    padding-left: .5rem !important;
    padding-right: .5rem !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
  }

  /* esconde o texto dos itens (todas variantes) */
  .sidebar-static.sidebar-slim .p-menuitem-text,
  .sidebar-static.sidebar-slim .ui-menuitem-text,
  .sidebar-static.sidebar-slim .p-panelmenu .p-panelmenu-header-label,
  .sidebar-static.sidebar-slim .p-menubar .p-menuitem-text,
  .sidebar-static.sidebar-slim .p-tieredmenu .p-menuitem-text {
    display: none !important;
  }

  /* mant�m �cones vis�veis e centrados */
  .sidebar-static.sidebar-slim .p-menuitem-icon,
  .sidebar-static.sidebar-slim .pi,
  .sidebar-static.sidebar-slim .ui-icon {
    margin-right: 0 !important;
    font-size: 1.25rem !important;
    line-height: 1 !important;
  }

  /* PanelMenu: esconde setas e subitens no slim */
  .sidebar-static.sidebar-slim .p-panelmenu .p-panelmenu-icon,
  .sidebar-static.sidebar-slim .ui-panelmenu .ui-panelmenu-icon {
    display: none !important;
  }
  .sidebar-static.sidebar-slim .p-panelmenu .p-toggleable-content,
  .sidebar-static.sidebar-slim .p-menubar .p-submenu-list,
  .sidebar-static.sidebar-slim .p-tieredmenu .p-submenu-list {
    display: none !important;
  }

  /* Cabe�alho do PanelMenu: esconde label e centraliza */
  .sidebar-static.sidebar-slim .p-panelmenu .p-panelmenu-header .p-menuitem-text,
  .sidebar-static.sidebar-slim .ui-panelmenu .ui-panelmenu-header .ui-menuitem-text {
    display: none !important;
  }
  .sidebar-static.sidebar-slim .p-panelmenu .p-panelmenu-header-link,
  .sidebar-static.sidebar-slim .ui-panelmenu .ui-panelmenu-header > a {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0 !important;
    padding-left: .5rem !important;
    padding-right: .5rem !important;
  }
}

/* Oculta sidebar fixa no mobile (usa p:sidebar m�vel) */
@media (max-width: 767px) { .sidebar-static { display: none; } }

/* --- Footer sempre 100% e colado --- */
footer {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  align-self: stretch !important;
}
footer > * {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

/* --- Dark mode --- */
body.dark { background-color: #0b1220 !important; }
body.dark .surface-ground { background-color: #0b1220 !important; }
body.dark .surface-card   { background-color: #111827 !important; color: #e5e7eb !important; }
body.dark .text-900       { color: #e5e7eb !important; }
body.dark .text-600       { color: #cbd5e1 !important; }
body.dark .surface-border { border-color: rgba(255,255,255,.08) !important; }
body.dark .p-button.p-button-text.p-button-plain { color: #cbd5e1 !important; }
body.dark .page-body { background-color: #0b1220 !important; }

/* --- Utilit�rios --- */
.surface-border { border-color: var(--separator-color) !important; }


.breadcrumb {
    display: flex;
    align-items: center;
    font-size: 14px;
    color: #555;

  }

  .breadcrumb span {
    margin: 0 5px;
    color: #999 !important;
  }

  .breadcrumb a {
    text-decoration: none;
    color: #007bff !important;
    transition: color 0.2s ease;
  }

  .breadcrumb a:hover {
    color: #0056b3;
    text-decoration: underline;
  }

  .breadcrumb .current {
    font-weight: bold;
    color: silver;
  }
  
  .icon-bread{
      color: #3C4962 !important;
  }
  
  .titulo-principal{
      margin-top: 15px;
  }
  
  /* não deixa email/senha virarem maiúsculos por CSS global */
#frmPrestador input[type="password"],
#frmPrestador input[type="email"],
#frmPrestador #email,
#frmPrestador #senha,
#frmPrestador #senha2 {
  text-transform: none !important;
}

.crud-tabs .ui-tabmenu-nav {
    border-radius: 4px !important;
    padding: 4px  !important;
}

.crud-tabs .ui-tabmenuitem .ui-menuitem-link {
    border-top-left-radius: 10px  !important;
    border-top-right-radius: 10px  !important;
}

@media (min-width: 768px){
  .sidebar-static.sidebar-slim{
    width: 4rem !important;
    flex: 0 0 4rem !important;      /* <- ESSENCIAL (sem isso não encolhe) */
    flex-basis: 4rem !important;
  }

  .sidebar-static.sidebar-collapsed{
    width: 0 !important;
    flex: 0 0 0 !important;         /* <- ESSENCIAL */
    flex-basis: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    border-right: 0 !important;
    transform: none !important;     /* evita “deslocar” e ficar espaço bugado */
  }
}

@media (min-width: 768px) {
  .sidebar-static.sidebar-slim {
    flex: 0 0 4rem !important; /* esta linha é o que realmente encolhe */
  }
  .sidebar-static.sidebar-collapsed {
    flex: 0 0 0 !important;    /* esta linha é o que realmente zera */
  }
}

/* === PATCH DEFINITIVO: o ASIDE é quem tem que encolher === */
@media (min-width: 768px){

  /* SLIM (fica fino) */
  aside.sidebar-static.sidebar-slim{
    width: 4rem !important;
    flex: 0 0 4rem !important;     /* ESSENCIAL: reserva 4rem no flex */
    max-width: 4rem !important;
    min-width: 4rem !important;
  }

  /* COLLAPSED (some de verdade) */
  aside.sidebar-static.sidebar-collapsed{
    width: 0 !important;
    flex: 0 0 0 !important;        /* ESSENCIAL: reserva 0 no flex */
    max-width: 0 !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
  }
}