//Grid // @compass dependencies @import "compass/css3"; // //@variables // //Grid settings $number-of-columns: 12 !default; $column-separation-factor: 0.1833 !default; //Row config $row-text-rendering: optimizespeed !default; $row-next-to-row-separation: 0.14285714rem !default; //Columns settings $col-padding: 0.57142857rem !default; $stack-column-separation: 2px !default; //Media $grid-max-width: 54.85714286rem !default; $grid-max-width-media: "(max-width: #{$grid-max-width})" !default; //Row variations $grid-primary-background-color: rgba(52, 152, 219, 0.8) !default; $grid-danger-background-color: rgba(231, 76, 60, 0.8) !default; $grid-warning-background-color: rgba(241, 196, 15, 0.8) !default; $grid-success-background-color: rgba(46, 204, 113, 0.8) !default; //columns border $col-border-color: #FFF !default; $col-border-alpha: 0.5 !default; // //@mixin // @mixin grid-columns($columns: $number-of-columns) { $column-width: 100 / $columns; @for $i from 1 through $columns { .col-#{$i} { $current-width: ($column-width * $i) - $column-separation-factor; width: percentage($current-width / 100); margin-left: percentage($column-separation-factor / 100); } } } .row { @extend %clearfix; display: block; text-rendering: $row-text-rendering; &.primary, [class*="col-"].primary { background: $grid-primary-background-color; } &.danger, [class*="col-"].danger { background: $grid-danger-background-color; } &.warning, [class*="col-"].warning { background: $grid-warning-background-color; } &.success, [class*="col-"].success { background: $grid-success-background-color; } //Columns @include grid-columns; [class*="col-"]:first-child { margin-left: 0; } } //Separation between rows .row + .row { margin-top: $row-next-to-row-separation; } //Borders and paddings are applied inside the div element //This prevents the columns to stack by a border or padding [class*="col-"] { padding: $col-padding; float: left; &.border { border-width: 1px; border-style: solid; border-color: transparent; &.left { border-left-color: rgba($col-border-color, $col-border-alpha); } &.right { border-right-color: rgba($col-border-color, $col-border-alpha); } &.top { border-top-color: rgba($col-border-color, $col-border-alpha); } &.bottom { border-bottom-color: rgba($col-border-color, $col-border-alpha); } } [class*="col-"] { padding-left: 0; } } @media #{$grid-max-width-media} { [class*="col-"] { &.border { &.left { border-top-color: rgba($col-border-color, $col-border-alpha); border-left-color: transparent; } &.right { border-bottom-color: rgba($col-border-color, $col-border-alpha); border-right-color: transparent; } } } .row > [class *= "col-"] { width: 100%; margin-left: 0; margin-bottom: $stack-column-separation; } }