/*
I wanted to go with a mobile first approach, but it actually lead to more verbose CSS in this case, so I've gone web first. Can't always force things...

Side note: I know that this style of nesting in SASS doesn't result in the most performance efficient CSS code... but on the OCD/organizational side, I like it. So for CodePen purposes, CSS selector performance be damned.
*/
/* Global settings */
/* Global "table" column settings */
.product-image {
    float: left;
    width: 20%;
}

.product-details {
    float: left;
    width: 37%;
}

    /* lorsque le lien supprimé est retiré */
    .product-details.product-no-removal {
        width: 46%;
    }

.product-price {
    float: left;
    width: 12%;
}

.product-quantity {
    float: left;
    width: 10%;
}

.product-removal {
    float: left;
    width: 9%;
}

.product-line-price {
    float: left;
    width: 12%;
    text-align: right;
}

/* This is used as the traditional .clearfix class */
.group:before, .shopping-cart:before, .column-labels:before, .product:before, .totals-item:before,
.group:after,
.shopping-cart:after,
.column-labels:after,
.product:after,
.totals-item:after {
    content: '';
    display: table;
}

.group:after, .shopping-cart:after, .column-labels:after, .product:after, .totals-item:after {
    clear: both;
}

.group, .shopping-cart, .column-labels, .product, .totals-item {
    zoom: 1;
}

/* Apply clearfix in a few places */
/* Apply dollar signs */
.product .product-price:after, .product .product-line-price:after, .totals-value:after {
    content: '\20AC';
}

/* Body/Header stuff */
/*
body {
    padding: 0px 30px 30px 20px;
    font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 100;
}

h1 {
    font-weight: 100;
}
*/
label {
    color: #000;
}

.shopping-cart {}

/* Column headers */
.column-labels label {
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px solid #eee;
}

/*.column-labels .product-details,*/
.column-labels .product-image,
.column-labels .product-removal {
    text-indent: -9999px;
}

/* Product entries */
.product {
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}
.product .product-image {
    text-align: center;
}
.product .product-image img {
    width: 100px;
}
.product .product-details .product-title {
    margin-right: 20px;
    /*font-family: "HelveticaNeue-Medium", "Helvetica Neue Medium";*/
    font-family: "Roboto";
}
.product .product-details .product-description {
    margin: 5px 20px 5px 0;
    line-height: 1.4em;
    font-size: 80%;
}
.product .product-quantity input {
    width: 80%;
    min-width: 60px;
    padding: 10px 20px;
    letter-spacing: 1px;
    font-size: 0.8em;
    border: none;
    line-height: 17px;
}
.product .remove-product {
    border: 0;
    /*padding: 4px 8px;*/
    background-color: #ab1a1d;
    color: #fff;
    /*font-family: "HelveticaNeue-Medium", "Helvetica Neue Medium";*/
    font-family: "Roboto";
    /*font-size: 12px;*/
    /*border-radius: 3px;*/
}
.product .remove-product:hover {
    background-color: #a44;
}

/* Totals section */
.totals .totals-item {
    float: right;
    clear: both;
    width: 100%;
    margin-bottom: 10px;
}
.totals .totals-item label {
    float: left;
    clear: both;
    width: 79%;
    text-align: right;
}
.totals .totals-item .totals-value,
.totals .totals-item .totals-info {
    float: right;
    width: 21%;
    text-align: right;
}
.totals .totals-item-total {
    /*font-family: "HelveticaNeue-Medium", "Helvetica Neue Medium";*/
    font-family: "Roboto";
}
.totals .totals-item .totals-info {font-size: 85%}

button.checkout {
    float: right;
    /*border: 0;*/
    margin-top: 1em;
    /*padding: 6px 25px;*/
    /*background-color: #6b6;*/
    color: #fff;
    /*font-size: 25px;*/
    /*border-radius: 3px;*/
}

    button.checkout:focus,
    button.checkout:hover {
        /*background-color: #494;*/
    }

.checkout_back {
    float: left;
    margin-top: 1em;
    padding: 6px 25px;
    background: #EEE;
    color: #A9989E;
    font-size: 25px;
    /*border-radius: 3px;*/
    line-height: 1.1;
    text-transform: lowercase;
}

    .checkout_back:focus,
    .checkout_back:hover {
        color: black!important;
    }

.shopping-cart .checkout:hover {
    background-color: #494;
}

/* Make adjustments for tablet */
@media screen and (max-width: 800px) {
    .shopping-cart {
        margin: 0;
        padding-top: 20px;
        border-top: 1px solid #eee;
    }

    .column-labels {
        display: none;
    }

    .product-image {
        float: right;
        width: auto;
    }
    .product-image img {
        margin: 0 0 10px 10px;
    }

    .product-details {
        float: none;
        margin-bottom: 10px;
        width: auto;
    }

    .product-price {
        clear: both;
        width: 70px;
    }

    .product-quantity {
        width: 100px;
    }
    .product-quantity input {
        margin-left: 20px;
    }

    .product-quantity:before {
        content: 'x';
    }

    .product-removal {
        width: auto;
    }

    .product-line-price {
        float: right;
        width: 70px;
    }
}
/* Make more adjustments for phone */
@media screen and (max-width: 500px) {
    .product-removal {
        float: right;
    }

    .product-line-price {
        float: right;
        clear: left;
        width: auto;
        margin-top: 10px;
    }

    .product .product-line-price:before {
        content: 'Item Total: ';
    }

    .totals .totals-item label {
        width: 60%;
    }
    .totals .totals-item .totals-value {
        width: 40%;
    }
}

.link-underline a {text-decoration: underline}
.erreur {color : #a94442;}
