/*
 * Praxion - Layout versionado da PWA.
 *
 * WEB: mantém o template atual.
 * APP desktop: sidebar compacta/expansível.
 * APP Android/iOS: menu lateral oculto e barra superior enxuta.
 *
 * Todas as regras ficam inativas no navegador comum.
 */

:root {
  --praxion-app-sidebar-collapsed: 76px;
  --praxion-app-sidebar-expanded: 284px;
  --praxion-app-topbar-height: 58px;
  --praxion-app-sidebar-bg: #124f73;
  --praxion-app-sidebar-bg-strong: #0d4161;
  --praxion-app-accent: #f28c00;
  --praxion-app-surface: #f4f7fb;
  --praxion-app-border: #dce4ee;
  --praxion-app-text: #172033;
}

html[data-praxion-standalone="1"] body {
  min-height: 100vh;
}

/* Seletor APP / WEB */
.praxion-layout-control {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  flex: 0 0 auto;
  padding: 3px;
  border: 1px solid #d7dfeb;
  border-radius: 999px;
  background: #eef2f7;
  box-shadow: 0 2px 8px rgba(15, 23, 42, .08);
}

.praxion-layout-control button {
  min-width: 54px;
  min-height: 32px;
  padding: .35rem .65rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #526174;
  font-size: .75rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: .02em;
  cursor: pointer;
}

.praxion-layout-control button:hover,
.praxion-layout-control button:focus-visible {
  color: #172033;
  outline: none;
}

.praxion-layout-control button.is-active {
  background: #fff;
  color: #0f4f73;
  box-shadow: 0 2px 7px rgba(15, 23, 42, .12);
}

.praxion-layout-control.is-compact button {
  min-width: 46px;
  min-height: 30px;
  padding: .3rem .52rem;
  font-size: .7rem;
}

/* =========================================================
   APP DESKTOP
   ========================================================= */
html[data-praxion-layout="app"][data-praxion-device="desktop"] body {
  background: var(--praxion-app-surface) !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar {
  position: sticky;
  top: 0;
  z-index: 1045;
  min-height: var(--praxion-app-topbar-height);
  padding-top: .45rem;
  padding-bottom: .45rem;
  border-bottom: 1px solid var(--praxion-app-border);
  background: #fff !important;
  box-shadow: 0 3px 12px rgba(15, 23, 42, .07);
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .navbar-brand img {
  width: 132px;
  height: 34px;
  object-fit: contain;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .navbar-nav {
  margin-left: auto !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .navbar-nav .nav-link {
  color: #334155 !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .btn-outline-light {
  border-color: #cbd5e1;
  background: #fff;
  color: #334155;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .btn-outline-light:hover,
html[data-praxion-layout="app"][data-praxion-device="desktop"] body > nav.navbar .btn-outline-light:focus {
  border-color: #94a3b8;
  background: #f1f5f9;
  color: #172033;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > .container-fluid {
  padding: 0;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] body > .container-fluid > .row {
  min-height: calc(100vh - var(--praxion-app-topbar-height));
  margin: 0;
  --bs-gutter-x: 0;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] aside.sidebar-col {
  position: sticky;
  top: var(--praxion-app-topbar-height);
  z-index: 1025;
  display: block !important;
  flex: 0 0 var(--praxion-app-sidebar-collapsed) !important;
  width: var(--praxion-app-sidebar-collapsed) !important;
  max-width: var(--praxion-app-sidebar-collapsed) !important;
  height: calc(100vh - var(--praxion-app-topbar-height));
  min-height: 0;
  padding: .6rem .45rem 1rem !important;
  overflow-x: hidden;
  overflow-y: auto;
  border-right: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, var(--praxion-app-sidebar-bg), var(--praxion-app-sidebar-bg-strong)) !important;
  transition: width .2s ease, max-width .2s ease, flex-basis .2s ease;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.25) transparent;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] aside.sidebar-col {
  flex-basis: var(--praxion-app-sidebar-expanded) !important;
  width: var(--praxion-app-sidebar-expanded) !important;
  max-width: var(--praxion-app-sidebar-expanded) !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] main {
  flex: 1 1 auto !important;
  width: calc(100% - var(--praxion-app-sidebar-collapsed)) !important;
  max-width: calc(100% - var(--praxion-app-sidebar-collapsed)) !important;
  min-width: 0;
  padding: 1rem !important;
  transition: width .2s ease, max-width .2s ease;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] main {
  width: calc(100% - var(--praxion-app-sidebar-expanded)) !important;
  max-width: calc(100% - var(--praxion-app-sidebar-expanded)) !important;
}

.praxion-sidebar-head {
  display: flex;
  align-items: center;
  margin-bottom: .45rem;
}

.praxion-sidebar-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
  width: 100%;
  min-height: 43px;
  padding: .55rem;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
}

.praxion-sidebar-toggle:hover,
.praxion-sidebar-toggle:focus-visible {
  background: rgba(255,255,255,.14);
  outline: none;
}

.praxion-sidebar-toggle-icon {
  flex: 0 0 auto;
  font-size: 1.15rem;
  line-height: 1;
}

.praxion-sidebar-toggle-label {
  display: none;
  overflow: hidden;
  font-size: .86rem;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

html[data-praxion-sidebar="expanded"] .praxion-sidebar-toggle {
  justify-content: flex-start;
  padding-right: .8rem;
  padding-left: .8rem;
}

html[data-praxion-sidebar="expanded"] .praxion-sidebar-toggle-label {
  display: inline;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root {
  width: 100%;
  min-width: 0;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-link,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-item > .nav-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 47px;
  margin: .18rem 0;
  padding: .55rem !important;
  overflow: hidden;
  border-radius: 11px;
  color: rgba(255,255,255,.92) !important;
  text-decoration: none;
  white-space: nowrap;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-link:hover,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-item > .nav-link:hover,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-link.is-active,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-item > .nav-link.is-active {
  background: rgba(255,255,255,.15) !important;
  color: #fff !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-icon,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .praxion-generated-menu-icon {
  flex: 0 0 25px;
  width: 25px !important;
  height: 25px !important;
  margin: 0 !important;
  object-fit: contain;
  font-size: 1.12rem;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .praxion-menu-label,
html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .praxion-menu-arrow {
  display: none;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] #menuDesktop .menu-root > .nav-item > .collapse {
  display: none !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-link,
html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .nav-link {
  justify-content: flex-start;
  gap: .65rem;
  padding-right: .8rem !important;
  padding-left: .8rem !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .praxion-menu-label {
  display: inline;
  min-width: 0;
  overflow: hidden;
  font-size: .9rem;
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .praxion-menu-arrow {
  display: inline-flex;
  margin-left: auto;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapse.show,
html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapsing {
  display: block !important;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapse {
  margin: .1rem 0 .35rem 2rem;
  padding-left: .45rem !important;
  border-left: 1px solid rgba(255,255,255,.18);
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapse .nav-link {
  padding: .38rem .55rem !important;
  border-radius: 8px;
  color: rgba(255,255,255,.72) !important;
  font-size: .82rem;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapse .nav-link:hover,
html[data-praxion-layout="app"][data-praxion-device="desktop"][data-praxion-sidebar="expanded"] #menuDesktop .menu-root > .nav-item > .collapse .nav-link.is-active {
  background: rgba(255,255,255,.1);
  color: #fff !important;
}

/* =========================================================
   APP ANDROID / IOS
   ========================================================= */
html[data-praxion-layout="app"][data-praxion-device="mobile"] body {
  padding-top: env(safe-area-inset-top, 0px);
  background: var(--praxion-app-surface) !important;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] aside.sidebar-col,
html[data-praxion-layout="app"][data-praxion-device="mobile"] #sidebarOffcanvas,
html[data-praxion-layout="app"][data-praxion-device="mobile"] #menuSource {
  display: none !important;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] body > .container-fluid {
  padding: 0;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] body > .container-fluid > .row {
  margin: 0;
  --bs-gutter-x: 0;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] main {
  flex: 0 0 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  padding: .75rem !important;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] main > .container-fluid {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] body > nav.navbar {
  position: sticky;
  top: 0;
  z-index: 1045;
  min-height: 56px;
  padding: .4rem .55rem;
  border-bottom: 1px solid var(--praxion-app-border);
  background: rgba(255,255,255,.97) !important;
  box-shadow: 0 3px 12px rgba(15,23,42,.07);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] body > nav.navbar .navbar-brand,
html[data-praxion-layout="app"][data-praxion-device="mobile"] body > nav.navbar .navbar-toggler,
html[data-praxion-layout="app"][data-praxion-device="mobile"] body > nav.navbar > .container-fluid > .navbar-nav {
  display: none !important;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] body.praxion-layout-own-header > nav.navbar {
  display: none !important;
}

.praxion-mobile-appbar {
  display: flex;
  align-items: center;
  gap: .45rem;
  width: 100%;
  min-width: 0;
}

.praxion-mobile-appbar-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid #d7dfeb;
  border-radius: 11px;
  background: #fff;
  color: #26364a;
  text-decoration: none;
  font-size: 1.05rem;
  font-weight: 800;
}

.praxion-mobile-appbar-button:hover,
.praxion-mobile-appbar-button:focus {
  background: #f4f7fb;
  color: #172033;
}

.praxion-mobile-appbar-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.praxion-mobile-appbar-title {
  display: block;
  overflow: hidden;
  color: var(--praxion-app-text);
  font-size: .94rem;
  font-weight: 850;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.praxion-mobile-appbar-subtitle {
  display: block;
  overflow: hidden;
  margin-top: .1rem;
  color: #738095;
  font-size: .68rem;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.praxion-layout-own-header .praxion-layout-control {
  margin-left: .35rem;
}

/* WEB dentro da PWA: não mexe no template, apenas mostra o seletor. */
html[data-praxion-layout="web"][data-praxion-standalone="1"] .praxion-layout-control {
  margin-left: auto;
  margin-right: .45rem;
}

@media (max-width: 575.98px) {
  .praxion-layout-control button {
    min-width: 44px;
    min-height: 30px;
    padding-right: .45rem;
    padding-left: .45rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  html[data-praxion-layout="app"] aside.sidebar-col,
  html[data-praxion-layout="app"] main {
    transition: none !important;
  }
}

/* =========================================================
   VOLTAR SEGURO DA PWA
   ========================================================= */
.praxion-safe-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .38rem;
  min-height: 38px;
  padding: .45rem .72rem;
  border: 1px solid #d7dfeb;
  border-radius: 11px;
  background: #fff;
  color: #26364a;
  font: inherit;
  font-size: .82rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 2px 7px rgba(15, 23, 42, .07);
}

.praxion-safe-back:hover,
.praxion-safe-back:focus-visible {
  background: #f4f7fb;
  color: #172033;
  outline: none;
}

.praxion-safe-back.is-disabled,
.praxion-safe-back:disabled {
  opacity: .42;
  cursor: default;
  box-shadow: none;
}

.praxion-safe-back-navbar {
  flex: 0 0 auto;
  margin-left: auto;
  margin-right: .45rem;
}

.praxion-safe-back-own-header {
  flex: 0 0 auto;
}

html[data-praxion-layout="app"][data-praxion-device="desktop"] .praxion-safe-back-navbar + .praxion-layout-control {
  margin-left: 0;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] .praxion-safe-back-label,
.pdv-app-header-back .praxion-safe-back-label {
  display: none;
}

html[data-praxion-layout="app"][data-praxion-device="mobile"] .praxion-safe-back-own-header {
  width: 40px;
  height: 40px;
  min-height: 40px;
  padding: 0;
}

.praxion-app-hero-status > .praxion-safe-back-own-header {
  align-self: flex-start;
  border-color: rgba(255,255,255,.34);
  background: rgba(255,255,255,.13);
  color: #fff;
  box-shadow: none;
}

.praxion-app-hero-status > .praxion-safe-back-own-header:hover,
.praxion-app-hero-status > .praxion-safe-back-own-header:focus-visible {
  background: rgba(255,255,255,.22);
  color: #fff;
}

@media (max-width: 575.98px) {
  .praxion-safe-back-navbar {
    width: 40px;
    min-width: 40px;
    padding-right: 0;
    padding-left: 0;
  }

  .praxion-safe-back-navbar .praxion-safe-back-label {
    display: none;
  }
}
