/*

        Mathematical
        A simple, responsive framework

        Made with love by Jxnblk


*/
/*! normalize.css v2.1.2 | MIT License | git.io/normalize */
/* ==========================================================================
   HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined in IE 8/9.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block; }

/**
 * Correct `inline-block` display not defined in IE 8/9.
 */
audio,
canvas,
video {
  display: inline-block; }

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Address styling not present in IE 8/9.
 */
[hidden] {
  display: none; }

/* ==========================================================================
   Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/**
 * Remove default margin.
 */
body {
  margin: 0; }

/* ==========================================================================
   Links
   ========================================================================== */
/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted; }

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0; }

/* ==========================================================================
   Typography
   ========================================================================== */
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari 5, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/**
 * Address styling not present in IE 8/9, Safari 5, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/**
 * Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome.
 */
b,
strong {
  font-weight: bold; }

/**
 * Address styling not present in Safari 5 and Chrome.
 */
dfn {
  font-style: italic; }

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  height: 0; }

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/**
 * Correct font family set oddly in Safari 5 and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  font-size: 1em; }

/**
 * Improve readability of pre-formatted text in all browsers.
 */
pre {
  white-space: pre-wrap; }

/**
 * Set consistent quote types.
 */
q {
  quotes: "\201C" "\201D" "\2018" "\2019"; }

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* ==========================================================================
   Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9.
 */
img {
  border: 0; }

/**
 * Correct overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden; }

/* ==========================================================================
   Figures
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari 5.
 */
figure {
  margin: 0; }

/* ==========================================================================
   Forms
   ========================================================================== */
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct `color` not being inherited in IE 8/9.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Correct font family not being inherited in all browsers.
 * 2. Correct font size not being inherited in all browsers.
 * 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome.
 */
button,
input,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 2 */
  margin: 0;
  /* 3 */ }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal; }

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 8+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none; }

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */ }

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default; }

/**
 * 1. Address box sizing set to `` in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */ }

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/**
 * 1. Remove default vertical scrollbar in IE 8/9.
 * 2. Improve readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */ }

/* ==========================================================================
   Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

/*

        Mathematical Theme


*/
body {
  color: #444444;
  background-color: #fff;
  font-family: "Baskerville", Georgia, serif; }

.content {
  padding: 0 20px;
  max-width: 768px;
  margin-left: auto;
  margin-right: auto; }

/* This is the worst. How did I mess this up. */
.content-full {
  padding: 0 20px;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto; }

a {
  -webkit-transition: color .3s;
  transition: color .3s;
  color: #7336e5;
  text-decoration: none; }
  a:hover, a:active {
    -webkit-transition: color .3s;
    transition: color .3s;
    color: #4515a0; }

/* Skins */
.dkgry {
  color: #444444; }

.mdgry {
  color: #999999; }

.ltgry {
  color: #eeeeee; }

.wht {
  color: #fff; }

.gry {
  color: lightgrey; }

.link {
  color: #7336e5; }

.title {
  color: #3c1289; }

.bg-dkgry {
  background-color: #444444; }

.bg-gry {
  color: lightgrey; }

.bg-mdgry {
  background-color: #999999; }

.bg-ltgry {
  background-color: #eeeeee; }

.bg-link {
  background-color: #7336e5; }

.bg-purple {
  background-color: #7336e5;
  color: #fff; }

/* Borders */
.bor {
  border: 1px solid; }

.borto {
  border-top: 1px solid; }

.borri {
  border-right: 1px solid; }

.borbo {
  border-bottom: 1px solid; }

.borle {
  border-left: 1px solid; }

.bor-dkgry {
  border-color: #444444; }

.bor-gry {
  border-color: lightgrey; }

.bor-mdgry {
  border-color: #999999; }

.bor-ltgry {
  border-color: #eeeeee; }

.bor-wht {
  border-color: #fff; }

.rc {
  border-radius: .25rem; }

.circ {
  border-radius: 50%; }

.btn-link {
  color: #fff;
  -webkit-transition: background-color .3s;
  transition: background-color .3s;
  background-color: #7336e5;
  border-radius: .25rem;
  border: none; }
  .btn-link:hover, .btn-link:active {
    color: #fff;
    -webkit-transition: background-color .3s;
    transition: background-color .3s;
    background-color: #834ce8;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2); }

.input:focus {
  outline: none;
  border-color: #7336e5; }

.bg-img {
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(/images/book_bg.jpg);
  background-position: bottom; }

.shadow {
  box-shadow: 5px 5px 14px 1px rgba(0, 0, 0, 0.4); }

pre {
  background: #fff;
  border: solid thin #999999;
  padding: 10px;
  border-radius: .25rem; }

iframe {
  margin: 0 auto; }

/*
   Modal stuff

  This structure is forced on us by the plugin provider, and I'm too lazy
  to roll my own modal dialog.

*/
#simplemodal-overlay {
  background-color: #000; }

#simplemodal-container {
  height: 50%;
  width: 50%;
  color: #444444;
  background-color: #eeeeee;
  border: 5px solid #999999;
  padding: 20px; }

#simplemodal-container .simplemodal-data {
  padding: 10px; }

#simplemodal-container a.modalCloseImg {
  background: url(/images/x.png) no-repeat;
  width: 25px;
  height: 29px;
  display: inline;
  z-index: 3200;
  position: absolute;
  top: -15px;
  right: -16px;
  cursor: pointer; }

/*

        Base


*/
img {
  width: 100%;
  max-width: 100%; }

.input {
  padding: .75rem 1rem;
  margin-bottom: 1rem;
  font-size: 1.25rem;
  line-height: 1.5rem;
  border-radius: .25rem;
  border: 1px solid;
  max-width: 100%; }
  .input::-webkit-input-placeholder {
    line-height: 1.5rem; }

.select {
  margin-bottom: 1rem;
  padding: .5rem; }

/* ==========================================================================
   UGH
   ========================================================================== */
.dn {
  display: none !important; }

.db {
  display: block; }

.dib {
  display: inline-block; }

.list {
  list-style-type: none;
  margin-left: 0;
  padding: 0; }

.list-inline li {
  display: inline; }

.list-item {
  margin-bottom: 1rem; }

.sq96 {
  height: 96px;
  width: 96px;
  line-height: 96px; }

blockquote {
  margin: 0; }

/*

        Mathematical Type


*/
body {
  font-size: 100%;
  line-height: 1.6;
  font-weight: 400; }

.ss {
  font-family: "Avenir", helvetica, arial, sans-serif; }

.s {
  font-family: "Baskerville", Georgia, serif; }

h1, .f1 {
  font-size: 1.75rem; }

h2, .f2 {
  font-size: 1.5rem; }

h3, .f3 {
  font-size: 1.25rem; }

h4, .f4 {
  font-size: 1rem; }

h5, .f5 {
  font-size: .8rem; }

h6, .f6 {
  font-size: .7rem; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  h1, .f1 {
    font-size: 2rem; }

  h2, .f2 {
    font-size: 1.75rem; }

  h3, .f3 {
    font-size: 1.5rem; }

  h4, .f4 {
    font-size: 1.25rem; }

  h5, .f5 {
    font-size: 1rem; }

  h6, .f6 {
    font-size: .75rem; } }
@media screen and (min-width: 1024px) {
  h1, .f1 {
    font-size: 3rem; }

  h2, .f2 {
    font-size: 2.75rem; }

  h3, .f3 {
    font-size: 2rem; }

  h4, .f4 {
    font-size: 1.5rem; }

  h5, .f5 {
    font-size: 1rem; }

  h6, .f6 {
    font-size: .75rem !important; }

  .mega {
    font-size: 3rem !important;
    line-height: 1.3;
    margin-bottom: 0 !important; } }
/* Mobile-first font sizes
 *
*/
p, ul, ol, .p {
  font-size: 1.25rem; }

small, .small {
  font-size: .875rem;
  -webkit-text-size-adjust: 100%; }
  @media screen and (min-width: 640px) and (max-width: 1023px) {
    small, .small {
      font-size: 1rem; } }

strong, .bold {
  font-weight: 700; }

.reg {
  font-weight: normal; }

.i {
  font-style: italic; }

.caps {
  text-transform: uppercase;
  letter-spacing: .2em; }

/* generated markup + reset is squashing this for vanilla pre and code */
.mono, span.monospaced, pre, code, pre code {
  font-family: "source-code-pro", monospace; }

.tc {
  text-align: center; }

.tl {
  text-align: left; }

.tr {
  text-align: right; }

.thin {
  font-weight: 100; }

.ttl {
  text-transform: none; }

.ls1 {
  letter-spacing: .01em; }

.ts {
  text-shadow: 0 1px 0 #fff; }

.list-alpha {
  list-style-type: upper-alpha; }

/*

        Structure


*/
.m0 {
  margin: 0; }

.mt0 {
  margin-top: 0; }

.mr0 {
  margin-right: 0; }

.mb0 {
  margin-bottom: 0; }

.ml0 {
  margin-left: 0; }

.m1 {
  margin: 1rem; }

.mt1 {
  margin-top: 1rem; }

.mr1 {
  margin-right: 1rem; }

.mb1 {
  margin-bottom: 1rem; }

.ml1 {
  margin-left: 1rem; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  .m1-res {
    margin: 2rem; }

  .mt1-res {
    margin-top: 2rem; }

  .mr1-res {
    margin-right: 2rem; }

  .mb1-res {
    margin-bottom: 2rem; }

  .ml1-res {
    margin-left: 2rem; } }
.m2 {
  margin: 2rem; }

.mt2 {
  margin-top: 2rem; }

.mr2 {
  margin-right: 2rem; }

.mb2 {
  margin-bottom: 2rem; }

.ml2 {
  margin-left: 2rem; }

.m4 {
  margin: 4rem; }

.mt4 {
  margin-top: 4rem; }

.mr4 {
  margin-right: 4rem; }

.mb4 {
  margin-bottom: 4rem; }

.ml4 {
  margin-left: 4rem; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  .m2-res {
    margin: 4rem; }

  .mt2-res {
    margin-top: 4rem; }

  .mr2-res {
    margin-right: 4rem; }

  .mb2-res {
    margin-bottom: 4rem; }

  .ml2-res {
    margin-left: 4rem; } }
/* Padding
*/
.p0 {
  padding: 0; }

.pt0 {
  padding-top: 0; }

.pr0 {
  padding-right: 0; }

.pb0 {
  padding-bottom: 0; }

.pl0 {
  padding-left: 0; }

.p1 {
  padding: 1rem; }

.pt1 {
  padding-top: 1rem; }

.pr1 {
  padding-right: 1rem; }

.pb1 {
  padding-bottom: 1rem; }

.pl1 {
  padding-left: 1rem; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  .p1-res {
    padding: 2rem; }

  .pt1-res {
    padding-top: 2rem; }

  .pr1-res {
    padding-right: 2rem; }

  .pb1-res {
    padding-bottom: 2rem; }

  .pl1-res {
    padding-left: 2rem; } }
.p2 {
  padding: 2rem; }

.pt2 {
  padding-top: 2rem; }

.pr2 {
  padding-right: 2rem; }

.pb2 {
  padding-bottom: 2rem; }

.pl2 {
  padding-left: 2rem; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  .p2-res {
    padding: 4rem; }

  .pt2-res {
    padding-top: 4rem; }

  .pr2-res {
    padding-right: 4rem; }

  .pb2-res {
    padding-bottom: 4rem; }

  .pl2-res {
    padding-left: 4rem; } }
.tappad {
  line-height: 3rem; }

.tappad-s {
  display: block;
  padding: 0 1rem;
  line-height: 3rem; }

.borbox {
  box-sizing: border-box; }

.db {
  display: block; }

.dib {
  display: inline-block; }

.fl {
  float: left; }

.fr {
  float: right; }

.wrap {
  margin-right: auto;
  margin-left: auto; }

.posrel {
  position: relative; }

.posabs {
  position: absolute; }

.top0 {
  top: 0; }

.right0 {
  right: 0; }

.bottom0 {
  bottom: 0; }

.left0 {
  left: 0; }

.top1 {
  top: 1rem; }

.right1 {
  right: 1rem; }

.bottom1 {
  bottom: 1rem; }

.left1 {
  left: 1rem; }

.top2 {
  top: 2rem; }

.right2 {
  right: 2rem; }

.bottom2 {
  bottom: 2rem; }

.left2 {
  left: 2rem; }

.fill {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto; }

.z1 {
  z-index: 100; }

.z2 {
  z-index: 200; }

.z3 {
  z-index: 300; }

.z4 {
  z-index: 400; }

.z5 {
  z-index: 500; }

.overhide {
  overflow: hidden; }

.scroll-y {
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch; }

.sq1 {
  width: 1rem;
  height: 1rem; }

.sq2 {
  width: 2rem;
  height: 2rem; }

.sq3 {
  width: 3rem;
  height: 3rem; }

.sq4 {
  width: 4rem;
  height: 4rem; }

.sq5 {
  width: 6rem;
  height: 6rem; }

.sq6 {
  width: 8rem;
  height: 8rem; }

.sq7 {
  width: 16rem;
  height: 16rem; }

.minhi1 {
  min-height: 1rem; }

.minhi2 {
  min-height: 2rem; }

.minhi3 {
  min-height: 3rem; }

.minhi4 {
  min-height: 4rem; }

.minhi5 {
  min-height: 6rem; }

.minhi6 {
  min-height: 8rem; }

.minhi7 {
  min-height: 16rem; }

.maxhi1 {
  max-height: 1rem; }

.maxhi2 {
  max-height: 2rem; }

.maxhi3 {
  max-height: 3rem; }

.maxhi4 {
  max-height: 4rem; }

.maxhi5 {
  max-height: 6rem; }

.maxhi6 {
  max-height: 8rem; }

.maxhi7 {
  max-height: 16rem; }

.lh1 {
  line-height: 1rem; }

.lh2 {
  line-height: 2rem; }

.lh3 {
  line-height: 3rem; }

.lh4 {
  line-height: 4rem; }

.lh5 {
  line-height: 6rem; }

.lh6 {
  line-height: 8rem; }

.lh7 {
  line-height: 16rem; }

.mw1 {
  max-width: 12rem; }

.mw2 {
  max-width: 96px; }

.maxwi1 {
  max-width: 24rem; }

.maxwi2 {
  max-width: 32rem; }

.maxwi3 {
  max-width: 40rem; }

.maxwi4 {
  max-width: 48rem; }

.maxwi5 {
  max-width: 60rem; }

.asp-sq {
  width: 100%;
  height: 0;
  padding-bottom: 100%; }

.asp-4o3 {
  width: 100%;
  height: 0;
  padding-bottom: 75%; }

.asp-16o9 {
  width: 100%;
  height: 0;
  padding-bottom: 56.25%; }

.wi100 {
  width: 100%; }

.wi87p5 {
  width: 87.5%; }

.wi75 {
  width: 75%; }

.wi62p5 {
  width: 62.5%; }

.wi50 {
  width: 50%; }

.wi37p5 {
  width: 37.5%; }

.wi25 {
  width: 25%; }

.wi10 {
  width: 10%; }

.wi66 {
  width: 66.66667%; }

.wi33 {
  width: 33.33333%; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  .wi100-m {
    width: 100%; }

  .wi87p5-m {
    width: 87.5%; }

  .wi75-m {
    width: 75%; }

  .wi62p5-m {
    width: 62.5%; }

  .wi50-m {
    width: 50%; }

  .wi37p5-m {
    width: 37.5%; }

  .wi25-m {
    width: 25%; } }
.center {
  margin: 0 auto; }

/*

        Modules


*/
.btn {
  display: inline-block;
  overflow: hidden; }

.btn-med {
  line-height: 48px;
  padding: 0 16px; }

.btn-big {
  line-height: 64px;
  padding: 0 16px; }

.media {
  overflow: hidden; }
  .media .img {
    float: left;
    margin-right: 1rem; }
  .media .bd {
    overflow: hidden; }

.modal {
  display: none; }

/* ==========================================================================
   grid
   ========================================================================== */
/**
 * Core grid component
 * Make use of dimension utilities, or components that extend 'grid' in order
 * to apply particular widths to cells.
 *
 * Example uses:
 *
 * <div class="grid">
 *     <div class="grid-cell u-size1of2"></div>
 *     <div class="grid-cell u-size1of2"></div>
 *     <div class="grid-cell u-size1of3"></div>
 *     <div class="grid-cell u-size1of3"></div>
 * </div>
 *
 * <div class="grid grid--center">
 *     <div class="grid-cell u-size1of3"></div>
 *     <div class="grid-cell u-size1of3"></div>
 * </div>
 */
/* grid container
   ========================================================================== */
/**
 * All content must be contained within descendent `grid-cell` elements.
 *
 * 1. Ensure consistent default alignment.
 * 2. Remove inter-unit whitespace that appears between `inline-block` child
 *    elements. Works for non-monospace font-families. If you're using a
 *    monospace base font, you will need to set the `grid` font-family to
 *    `sans-serif` and then redeclare the monospace font on the `grid-cell`
 *    objects.
 * 3. Protect against WebKit bug with optimizelegibility.
 */
.grid {
  display: block;
  padding: 0;
  margin: 0;
  text-align: left;
  /* 1 */
  letter-spacing: -0.31em;
  /* 2 */
  text-rendering: optimizespeed;
  /* 3 */ }

/* Opera hack */
.opera:-o-prefocus,
.grid {
  word-spacing: -0.43em;
  /* 2 */ }

/**
 * Modifier: horizontally center all grid units
 * Allows for automatic unit centering irrespective of the number of
 * units in the grid.
 */
.grid--center {
  text-align: center; }

/* grid cell
   ========================================================================== */
/**
 * No explicit width by default. Rely on combining `grid-cell` with a dimension
 * utility or component that extends 'grid'.
 *
 * 1. Fundamentals of the non-float grid layout mechanism.
 * 2. Controls vertical positioning of units.
 * 3. Keeps content correctly aligned with the grid direction.
 * 4. Reset text defaults.
 */
.grid-cell {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  display: inline-block;
  /* 1 */
  margin: 0;
  padding: 0;
  vertical-align: top;
  /* 2 */
  text-align: left;
  /* 3 */
  letter-spacing: normal;
  /* 4 */
  word-spacing: normal;
  /* 4 */
  text-rendering: auto;
  /* 4 */ }

/**
 * Modifier: horizontally center one unit
 * Set a specific unit to be horizontally centered. Doesn't affect
 * any other units. Can still contain a child `grid` object.
 */
.grid-cell--center {
  display: block;
  margin: 0 auto; }

@media screen and (min-width: 640px) and (max-width: 1023px) {
  /* grid version 2 (at first breakpoint)
  ========================================================================== */
  .v2-grid--1col > .grid-cell,
  .v2-grid--3on1 > .grid-cell--4 {
    width: 100%; }

  .v2-grid--1to3 > .grid-cell--2,
  .v2-grid--3to1 > .grid-cell--1 {
    width: 75%; }

  .v2-grid--1to2 > .grid-cell--2,
  .v2-grid--2to1 > .grid-cell--1 {
    width: 66.666%; }

  .v2-grid--2col > .grid-cell {
    width: 50%; }

  .v2-grid--1to2 > .grid-cell--1,
  .v2-grid--2to1 > .grid-cell--2,
  .v2-grid--3col > .grid-cell,
  .v2-grid--3on1 > .grid-cell--1,
  .v2-grid--3on1 > .grid-cell--2,
  .v2-grid--3on1 > .grid-cell--3 {
    width: 33.333%; }

  .v2-grid--1to3 > .grid-cell--1,
  .v2-grid--3to1 > .grid-cell--2,
  .v2-grid--4col > .grid-cell {
    width: 25%; }

  /**
   * Fit and Fill
   */
  .v2-grid--fitToFill > .grid-cell--1 {
    display: block;
    float: left;
    width: auto; }

  .v2-grid--fitToFill > .grid-cell--2 {
    display: block;
    overflow: hidden;
    width: auto; }

  /* Contain floats */
  .v2-grid--fitToFill:after {
    display: table;
    content: " ";
    clear: both; } }
@media screen and (min-width: 1024px) {
  /* grid version 3 (at second breakpoint)
  ========================================================================== */
  .v3-grid--1col > .grid-cell {
    width: 100%; }

  .v3-grid--1to2 > .grid-cell--2,
  .v3-grid--2to1 > .grid-cell--1 {
    width: 66.666%; }

  .v3-grid--2to3 > .grid-cell--2,
  .v3-grid--3to2 > .grid-cell--1 {
    width: 60%; }

  .v3-grid--2col > .grid-cell {
    width: 50%; }

  .v3-grid--2to3 > .grid-cell--1,
  .v3-grid--3to2 > .grid-cell--2 {
    width: 40%; }

  .v3-grid--1to2 > .grid-cell--1,
  .v3-grid--2to1 > .grid-cell--2,
  .v3-grid--3col > .grid-cell {
    width: 33.333%; }

  .v3-grid--4col > .grid-cell {
    width: 25%; } }

