/* =========================================================
   CRIE PRIVATE SHELL — UNICORN (SINGLE SOURCE OF TRUTH)
   Topbar premium + Sidebar (mobile offcanvas + desktop push)
========================================================= */

:root{
  --cr-topbar-h: 72px;
  --cr-sidebar-w: 292px;
  --cr-sidebar-max: 340px;
  --cr-glass: rgba(255,255,255,.82);
}

/* =========================================================
   BASE
========================================================= */

body.layout-container{
  background: var(--cr-bg, #f8fafc);
  padding-top: var(--cr-topbar-h);
}

/* =========================================================
   TOPBAR — premium glass + aura
========================================================= */

.cr-topbar{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--cr-topbar-h);
  z-index: 1100;

  background:
  radial-gradient(900px 240px at 14% 0%, var(--cr-aura-blue), transparent 60%),
  radial-gradient(900px 240px at 86% 0%, var(--cr-aura-green), transparent 60%),
  var(--cr-glass);

  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);

  border-bottom: 1px solid var(--cr-border);
  box-shadow: 0 10px 30px rgba(2,6,23,.08);
}

.cr-topbar__inner{
  display:flex;
  align-items:center;
  gap:20px;
  height:100%;
  padding:0 20px;
}

.cr-topbar__search{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:center;
  min-width:0;
}

.cr-topbar__actions{
  display:flex;
  align-items:center;
  gap:14px;
  margin-left:auto;
}

/* botão do menu (hamburger) */
.cr-iconbtn{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 10px 26px rgba(2,6,23,.06);
}
.cr-iconbtn .material-icons{
  font-size: 22px;
  color: rgba(15,23,42,.82);
}

.cr-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.cr-brand__logo{
  display:block;
  height:42px;
  width:auto;
}

/* USER MENU */
.cr-user{ position:relative; }
.cr-user__btn{
  width:46px; height:46px;
  border-radius:50%;
  overflow:hidden;
  border:2px solid rgba(0,0,0,.06);
  padding:0;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.cr-user__avatar{
  width:100%;
  height:100%;
  object-fit:cover;
}
.cr-menu{
  position:absolute;
  top:60px;
  right:0;
  min-width:200px;
  background:#fff;
  border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.15);
  padding:10px;
  display:none;
}
@media (hover:hover){
  .cr-user:hover .cr-menu{ display:block; }
}
.cr-user.is-open .cr-menu{ display:block; }

.cr-menu__item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  font-weight:900;
  color:rgba(15,23,42,.88);
  text-decoration:none;
}
.cr-menu__item:hover{
  background: rgba(25,118,210,.10);
  color: rgba(15,23,42,.94);
}

/* Responsivo topbar */
@media (max-width: 860px){
  .cr-brand__logo{ height: 34px; }
  .cr-topbar__inner{ gap: 12px; padding: 0 12px; }
}
@media (max-width: 520px){
  .cr-topbar__search .input-group-btn,
  .cr-topbar__search button,
  .cr-topbar__search .btn{ display:none !important; }
}

/* =========================================================
   SIDEBAR — overlay + offcanvas
========================================================= */

.cr-sidebar-overlay{
  position: fixed;
  inset: 0;
  background: rgba(2,6,23,.45);
  opacity: 0;
  pointer-events: none;
  transition: .15s ease;
  z-index: 1047;
}

#sidebarLeft{
  position: fixed;
  top: var(--cr-topbar-h);
  left: 0;
  height: calc(100dvh - var(--cr-topbar-h));

  width: min(var(--cr-sidebar-w), 92vw);
  max-width: var(--cr-sidebar-max);

  background: rgba(255,255,255,.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  border-right: 1px solid var(--cr-border);
  box-shadow: 12px 0 30px rgba(2,6,23,.06);

  overflow: auto;
  padding: 14px 12px;

  transform: translateX(-105%);
  transition: transform .18s ease;
  z-index: 1048;

  contain: layout paint;
}

/* MOBILE: abre via .cr-sidebar-open */
body.cr-sidebar-open #sidebarLeft{ transform: translateX(0); }
body.cr-sidebar-open .cr-sidebar-overlay{ opacity:1; pointer-events:auto; }

/* trava scroll só no mobile quando aberto */
@media (max-width: 991.98px){
  body.cr-sidebar-open{ overflow:hidden; }
}

/* =========================================================
   DESKTOP PUSH (>= 992)
   - começa fechado (porque body tem cr-sidebar-closed)
   - abre quando body tiver cr-sidebar-open (ou você remove cr-sidebar-closed e coloca open)
========================================================= */

/* Desktop: fechado por padrão (cr-sidebar-closed no body) */
@media (min-width: 992px){

  /* estado padrão: fechado */
  body.layout-container{
    padding-left: 0;
    overflow-x: hidden;
  }
  #sidebarLeft{
    transform: translateX(-105%);
  }

  /* quando ABERTO no desktop (ou seja: NÃO tem .cr-sidebar-closed) */
  body.layout-container:not(.cr-sidebar-closed){
    padding-left: var(--cr-sidebar-w);
  }
  body.layout-container:not(.cr-sidebar-closed) #sidebarLeft{
    transform: translateX(0);
  }

  /* overlay não existe no desktop */
  .cr-sidebar-overlay{ display:none !important; }
}



/* Mobile: abre com overlay */
@media (max-width: 991.98px){
  body.layout-container{ padding-left: 0 !important; }

  body.cr-sidebar-open #sidebarLeft{ transform: translateX(0); }
  body.cr-sidebar-open .cr-sidebar-overlay{ opacity: 1; pointer-events:auto; }
  body.cr-sidebar-open{ overflow: hidden; }
}

/* =========================================================
   Sidebar menu visual
========================================================= */

#sidebarLeft .sidebar-heading{
  margin: 14px 10px 8px;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .02em;
  color: var(--cr-muted);
  display:flex;
  align-items:center;
  gap: 8px;
}
#sidebarLeft .sidebar-heading::after{
  content:"";
  height:1px;
  flex:1;
  background: rgba(15,23,42,.08);
  margin-left: 8px;
}

#sidebarLeft .sidebar-menu{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}
#sidebarLeft .sidebar-menu-item{
  list-style:none !important;
  margin:0;
  padding:0;
}
#sidebarLeft .sidebar-menu-button{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  margin: 2px 6px;
  border-radius: 16px;
  text-decoration:none !important;
  color: rgba(15,23,42,.86);
  font-weight: 900;
  font-size: 13px;
  border: 1px solid transparent;
  background: transparent;
  transition: .15s ease;
}
#sidebarLeft .sidebar-menu-button:hover{
  background: rgba(15,23,42,.06);
  color: rgba(15,23,42,.92);
}
#sidebarLeft .sidebar-menu-icon.material-icons{
  font-size: 18px;
  opacity:.9;
}
#sidebarLeft .sidebar-menu-item.active > .sidebar-menu-button,
#sidebarLeft .sidebar-menu-item.is-active > .sidebar-menu-button{
  background: rgba(25,118,210,.10);
  border-color: rgba(25,118,210,.18);
  box-shadow: 0 10px 26px rgba(25,118,210,.08);
}

/* =========================================================
   SEARCH FORM FIXES (bootstrap override)
========================================================= */

.cr-topbar__search form{
  display:flex !important;
  align-items:center !important;
  gap:10px;
  float:none !important;
  margin:0 !important;
  width:100%;
  max-width:600px;
}
.cr-topbar__search .input-group{
  display:flex !important;
  align-items:center !important;
  width:100%;
}
.cr-topbar__search .input-group .form-control{
  flex:1 1 auto;
  min-width:0;
  height:44px !important;
  border-radius:16px !important;
  border:1px solid rgba(15,23,42,.12) !important;
  padding:0 14px !important;
  background:rgba(255,255,255,.85);
}
.cr-topbar__search .input-group-btn{
  display:flex !important;
  align-items:center !important;
  width:auto !important;
}
.cr-topbar__search .input-group-btn .btn{
  height:44px !important;
  border-radius:14px !important;
  border:1px solid rgba(15,23,42,.12) !important;
  padding:0 14px !important;
  background:rgba(255,255,255,.85);
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

/* =========================================================
   PERFORMANCE MODE
========================================================= */

@media (prefers-reduced-motion: reduce){
  .cr-topbar,
  #sidebarLeft{
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}
@media (max-width: 991.98px){
  .cr-topbar{
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
   background:
  radial-gradient(520px 160px at 14% 0%, var(--cr-aura-blue), transparent 60%),
  radial-gradient(520px 160px at 86% 0%, var(--cr-aura-green), transparent 60%),
  rgba(255,255,255,.94);
  }
  #sidebarLeft{
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    background: rgba(255,255,255,.98);
  }
}

/* =========================================================
   TOPBAR ICON BUTTON — premium polish (menu + theme)
========================================================= */

.cr-iconbtn{
  -webkit-tap-highlight-color: transparent;
  appearance: none;
  transition:
    transform .12s ease,
    box-shadow .16s ease,
    background-color .16s ease,
    border-color .16s ease,
    opacity .16s ease;
}

.cr-iconbtn:hover{
  background: rgba(255,255,255,.88);
  border-color: rgba(25,118,210,.18);
  box-shadow:
    0 10px 26px rgba(2,6,23,.06),
    0 0 0 4px rgba(25,118,210,.10),
    0 18px 44px rgba(46,125,50,.06);
  transform: translateY(-1px);
}

.cr-iconbtn:active{
  transform: translateY(0px);
  box-shadow: 0 10px 26px rgba(2,6,23,.06);
}

.cr-iconbtn:focus{ outline: none; }
.cr-iconbtn:focus-visible{
  box-shadow:
    0 10px 26px rgba(2,6,23,.06),
    0 0 0 4px rgba(25,118,210,.18);
  border-color: rgba(25,118,210,.30);
}

/* Tema: deixar o ícone mais “vivo” quando dark estiver ativo */
body[data-theme="dark"] .cr-iconbtn{
  background: rgba(17,24,39,.35);
  border-color: rgba(255,255,255,.14);
}
body[data-theme="dark"] .cr-iconbtn .material-icons{
  color: rgba(255,255,255,.86);
}
body[data-theme="dark"] .cr-iconbtn:hover{
  border-color: rgba(59,130,246,.35);
  box-shadow:
    0 16px 46px rgba(0,0,0,.40),
    0 0 0 4px rgba(59,130,246,.18),
    0 18px 44px rgba(34,197,94,.08);
}

/* garante overlay cobrindo a tela e aceitando o mouse */
.cr-sidebar-overlay{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 40;
  pointer-events: auto;
}

/* quando sidebar está aberto, overlay aparece */
body.cr-sidebar-open .cr-sidebar-overlay{
  display: block;
}

/* garante sidebar por cima do overlay */
.cr-sidebar{
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 50;
}

/* (opcional) evita "faixa morta" ao lado do sidebar */
.cr-sidebar{
  margin-right: 0 !important;
}