// Framework grid generation
//
// Used only by Bootstrap to generate the correct number of grid classes given
// any value of `$grid-columns`.

@mixin make-grid-columns($columns: $grid-columns, $gutter: $grid-gutter-width, $breakpoints: $grid-breakpoints) {
  // Common properties for all breakpoints
  %grid-column {
    position: relative;
    // Prevent columns from collapsing when empty
    min-height: 1px;
    // Inner gutter via padding
    padding-left: ($gutter / 2);
    padding-right: ($gutter / 2);
    @if $enable-flex {
      flex: 0 0 auto;
      width: 100%;
    }
  }
  @each $breakpoint in map-keys($breakpoints) {
    @for $i from 1 through $columns {
      .grid__#{$breakpoint}-#{$i} {
        @extend %grid-column;
      }
    }
    @include media-breakpoint-up($breakpoint) {
      // create --hidden modifier classes to dynamically hide at certain breakpoints
      // .grid__#{$breakpoint}--hidden {
      //   display: none !important;
      // }
      @for $i from 1 through $columns {
        .grid__#{$breakpoint}-#{$i} {
          @if $enable-flex {
            // Do nothing
          } @else {
            float: left;
          }
          @include make-col-span($i, $columns);
        }
      }
      @each $modifier in (pull, push, offset) {
        @for $i from 0 through $columns {
          .grid__#{$breakpoint}--#{$modifier}-#{$i} {
            @include make-col-modifier($modifier, $i, $columns)
          }
        }
      }
    }
  }
}
