main.container,
main.container-fluid{
  max-width: 100% !important;
}

main{
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

main.container{
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

.page-shell{
  background: var(--cmo-surface);
  border: 1px solid var(--cmo-border);
  border-radius: var(--cmo-radius-lg);
  box-shadow: var(--cmo-card-shadow);
  padding: 1rem;
}

.navbar-cmo{
  background: linear-gradient(90deg, var(--cmo-primary-dark), var(--cmo-primary));
  box-shadow: 0 2px 12px rgba(14, 44, 74, .12);
  position: sticky;
  top: 0;
  z-index: 1030;
}

.navbar-brand{
  font-weight: 700;
  letter-spacing: .3px;
}

.navbar .nav-link,
.navbar .navbar-text,
.navbar .dropdown-toggle{
  color: rgba(255,255,255,.92) !important;
}

.navbar .nav-link:hover,
.navbar .dropdown-toggle:hover,
.navbar .nav-link.active{
  color: #ffffff !important;
}

.navbar-search-wrap{
  width: 100%;
  max-width: 330px;
}

.navbar-search-input{
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.12);
  color: #fff;
  padding-left: .9rem;
  padding-right: .9rem;
  min-height: 34px;
}

.navbar-search-input::placeholder{
  color: rgba(255,255,255,.74);
}

.navbar-search-input:focus{
  background: #fff;
  color: var(--cmo-text);
  border-color: #fff;
  box-shadow: 0 0 0 .2rem rgba(255,255,255,.18);
}

.navbar-autocomplete{
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--cmo-border);
  border-radius: 1rem;
  overflow: hidden;
  z-index: 1050;
}

@media (max-width: 991.98px){
  .navbar-search-wrap{
    max-width: 100%;
    margin-top: .75rem;
    margin-bottom: .5rem;
  }

  main.container{
    margin-top: .75rem;
    margin-bottom: 1rem;
  }

  .page-shell{
    padding: .8rem;
  }
}

/* ===== Fase 2: navbar y layout fino ===== */
.navbar-cmo{
  backdrop-filter: saturate(140%) blur(6px);
}

.navbar-cmo .container{
  min-height: 60px;
}

.navbar-brand{
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: .02em;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}

.navbar-brand::before{
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255,255,255,.95);
  box-shadow: 0 0 0 4px rgba(255,255,255,.12);
  flex: 0 0 auto;
}

.navbar .nav-link,
.navbar .dropdown-toggle{
  padding-top: .5rem;
  padding-bottom: .5rem;
  border-radius: .7rem;
  font-weight: 600;
  transition: background-color .16s ease, color .16s ease;
}

.navbar .nav-link:hover,
.navbar .dropdown-toggle:hover{
  background: rgba(255,255,255,.08);
}

.navbar .nav-link.active,
.navbar .dropdown-toggle.active{
  background: rgba(255,255,255,.12);
}

.navbar-search-wrap{
  max-width: 360px;
}

.navbar-search-input{
  min-height: 38px;
  padding-left: 1rem;
  padding-right: 1rem;
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.1);
}

.navbar-autocomplete{
  margin-top: 2px;
  box-shadow: 0 10px 24px rgba(16, 42, 68, .14);
}

@media (max-width: 991.98px){
  .navbar-cmo .container{
    min-height: auto;
  }

  #navMain{
    padding-top: .75rem;
    padding-bottom: .25rem;
  }

  .navbar .nav-link,
  .navbar .dropdown-toggle{
    padding-left: .6rem;
    padding-right: .6rem;
  }
}

.navbar-brand.navbar-brand-cmo{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font-weight:800;
  letter-spacing:.02em;
  text-decoration:none;
}

.navbar-brand.navbar-brand-cmo::before{
  content:none;
}

.navbar-brand-logo{
  width:28px;
  height:28px;
  object-fit:contain;
  display:block;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.12));
}

.navbar-brand-text{
  display:inline-block;
  color:#fff;
  line-height:1;
}

@media (max-width: 991.98px){
  .navbar-brand-logo{
    width:26px;
    height:26px;
  }

  .navbar-brand-text{
    font-size:.98rem;
  }
}
