/**
 * Layout overrides for Falcon + React.
 * Yii page chrome + React funnel/inbox spacing and navbar fixes.
 * App-shell layout is defined in yii2-falcon-theme custom.css; core flex rules are
 * duplicated here because Yii publishes theme assets to a hashed bundle that may lag vendor.
 */

.app-shell-body {
  display: flex;
  align-items: flex-start;
  padding-left: calc(var(--falcon-gutter-x, 2rem) * 0.5);
  box-sizing: border-box;
}

.app-shell > .navbar-top {
  position: sticky;
  top: 0;
  width: 100%;
  z-index: 1045;
  background-color: var(--falcon-bg-navbar-glass);
  box-sizing: border-box;
}

/* App-shell: top bar is not inside .content, so restore mobile hamburger visibility */
.app-shell > .navbar-top .navbar-toggler {
  display: flex;
  align-items: center;
}

@media (min-width: 1200px) {
  .app-shell > .navbar-top .navbar-toggler {
    display: none !important;
  }
}

/* React CSS sets .collapse { visibility: collapse } which hides the vertical nav menu */
.navbar-vertical .navbar-collapse.collapse {
  visibility: visible !important;
}

@media (min-width: 1200px) {
  .navbar-vertical .navbar-collapse.collapse {
    display: flex !important;
    visibility: visible !important;
  }

  .navbar-vertical .navbar-collapse .nav-link,
  .navbar-vertical .navbar-collapse .nav-link-text {
    visibility: visible !important;
  }

  /* Pin logo/header at top; scroll menu items in the remaining rail height. */
  .navbar-vertical.navbar-expand-xl {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }

  .navbar-vertical.navbar-expand-xl > .d-flex:first-of-type {
    flex-shrink: 0;
  }

  .navbar-vertical.navbar-expand-xl .navbar-collapse {
    flex: 1 1 auto !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .navbar-vertical.navbar-expand-xl .navbar-vertical-content {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 0.75rem;
  }
}

@media (max-width: 1199.98px) {
  body:not(.landing-page) .navbar.navbar-vertical {
    display: none !important;
  }
}

@media (max-width: 1199.98px) {
  body.navbar-mobile-open .navbar-vertical .navbar-collapse {
    display: flex !important;
    visibility: visible !important;
  }
}

/* Top bar: single row, search grows, stays above page chrome */
:root {
  --navbar-top-inner-height: 3.5rem;
}

.navbar-top {
  z-index: 1040;
  min-height: var(--navbar-top-inner-height);
  height: var(--navbar-top-inner-height);
  padding-top: 0;
  padding-bottom: 0;
  margin-left: 0;
  margin-right: 0;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  margin-bottom: 0.5rem;
}

.navbar-top > * {
  position: relative;
  z-index: 1;
}

.navbar-top > .navbar-toggler,
.navbar-top > .navbar-brand {
  z-index: 2;
}

.navbar-top .navbar-brand {
  flex-shrink: 0;
  padding-top: 0;
  padding-bottom: 0;
  display: inline-flex;
  align-items: center;
}

@media (max-width: 1199.98px) {
  .navbar-top .navbar-brand {
    min-width: 0;
    padding-left: 0.35rem;
    margin-right: 0.25rem;
  }

  .navbar-top .navbar-brand img {
    max-width: min(9.5rem, 42vw);
    width: auto !important;
    height: auto !important;
    object-fit: contain;
  }
}

.navbar-top .navbar-top-search {
  display: flex;
  align-items: center;
  flex: 1 1 0;
  min-width: 0;
}

.navbar-top .navbar-top-search > [data-component] {
  flex: 1 1 0;
  min-width: 0;
}

.navbar-top .navbar-nav-icons {
  flex-shrink: 0;
}

.navbar-top::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  width: auto;
  height: 6px;
  top: 100%;
  bottom: auto;
  z-index: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0));
  pointer-events: none;
}

[data-bs-theme=dark] .navbar-top::after {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0));
}

/* Footer: static flow instead of absolute overlap on short pages */
.content .footer {
  position: static;
}

/* Reinforce app-shell layout (loads after theme; beats legacy + .content margin rules) */
@media (min-width: 1200px) {
  .app-shell .navbar-vertical.navbar-expand-xl > .d-flex:first-of-type {
    display: none !important;
  }

  .app-shell .navbar-vertical.navbar-expand-xl + .content,
  .app-shell .navbar-vertical.navbar-expand-xl.navbar-card + .content,
  .app-shell .navbar-vertical.navbar-expand-xl.navbar-vibrant + .content,
  .app-shell .navbar-vertical.navbar-expand-xl.navbar-inverted + .content {
    margin-left: 0 !important;
    padding-left: 0 !important;
  }

  .app-shell .navbar-vertical.navbar-expand-xl {
    position: sticky !important;
    top: var(--navbar-top-inner-height, 3.5rem) !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .app-shell .content {
    width: auto !important;
    max-width: none !important;
    margin-left: 0 !important;
    flex: 1 1 auto;
    min-width: 0;
  }
}

/* FunnelPage / React inbox mount points */
[class$='-index'][data-component] {
  width: 100%;
  min-width: 0;
  flex: 1 1 100%;
  padding: 1rem 1.5rem 2rem;
  box-sizing: border-box;
}

@media (min-width: 1200px) {
  [class$='-index'][data-component] {
    padding: 1.25rem 2rem 2rem;
  }
}
