/*
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: 10%;
}

.product-details {
    float: left;
    width: 45%;
    padding-right:50px;
}

.product-price {
    float: left;
    width: 12%;
    padding-right:20px;
}

.product-price-v {
    float: left;
    width: 14%;
}

.product-quantity {
    float: left;
    width: 10%;
}
.product-quantity-v {
    float: left;
    width: 5%;
}

.product-removal {
    float: left;
    width: 9%;
}

.product-status-v {
    float: left;
    padding-left:20px;
    width: 10%;
}

.product-line-price {
    float: left;
    width: 12%;
    text-align: right;
}

.product-line-price-v {
    float: left;
    width: 12%;
    text-align: right;
}

.order-reason {
    padding-left:20px;
    padding-top:20px;
    float: left;
    clear: both;
}
.order-reason-dd {
    padding-left:10px;
    padding-top:20px;
    float: left;
}
.order-reason-ta {
    padding-left:10px;
    padding-top:20px;
    width:500px;
    float: left;
}
.order-reason-bt {
    padding-left:10px;
    padding-top:20px;
    width:500px;
    float: left;
}

/* 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:before, .product .product-line-price:before, .totals-value:before {
    content: '';
}

/* Body/Header stuff */
body {
    /* 2/2/19 */
    /*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: #aaa;*/
    color:#000
}

.shopping-cart {
    margin-top: -45px;
}

/* Column headers */
.column-labels label {
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px solid #eee;
}
.column-labels .product-image, .column-labels .product-details, .column-labels .product-removal {
    text-indent: -9999px;
}

/*
.actions {
    padding-bottom:10px;
    border-bottom: 1px solid #eee;
}
*/

/* 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";
}
.product .product-details .product-description {
    margin: 5px 20px 5px 0;
    line-height: 1.4em;
}
.product .product-quantity input {
    width: 40px;
}
.product .remove-product {
    border: 0;
    padding: 4px 8px;
    background-color: #c66;
    color: #fff;
    font-family: "HelveticaNeue-Medium", "Helvetica Neue Medium";
    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 {
    float: right;
    width: 21%;
    text-align: right;
}
.totals .totals-item-total {
    font-family: "HelveticaNeue-Medium", "Helvetica Neue Medium";
}

.checkout {
    float: right;
    border: 0;
    margin-top: 20px;
    padding: 6px 25px;
    background-color: #6b6;
    color: #fff;
    font-size: 25px;
    border-radius: 3px;
}

.checkout:hover {
    background-color: #494;
}

textarea.form-control {
    height: 35px;
}

/* Make adjustments for tablet */
@media screen and (max-width: 650px) {
    textarea.form-control {
        height: auto;
    }

    .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-price-v {
        margin-left:10px;
        clear: both;
        width: 70px;
    }

    .product-quantity {
        width: 100px;
    }
    .product-quantity-v {
        width: 100px;
    }

    .product-quantity input {
        margin-left: 20px;
    }

    .product-quantity:before {
        content: 'x';
    }

    .product-quantity-v:before {
        content: 'x';
    }

    .product-status-v:before {
        float:left;
        content:"\000AStatus: ";
        padding-right:10px;
    }
    .product-status-v {
        float: right;
        padding-left:20px;
        width: 100%;
    }

    .product-removal {
        width: auto;
    }

    .product-line-price {
        float: right;
        width: 70px;
    }

    .product-line-price-v {
        float: right;
        width: 150px;
        padding-right:10px;
    }
    .product .product-line-price-v:before {
        content: 'Item Total: ';
    }
    .order-reason-ta {
        padding-left:10px;
        padding-top:20px;
        width:300px;
        float: left;
    }
    .order-reason-bt {
        padding-left:10px;
        padding-top:20px;
        width:300px;
        float: left;
    }


}
/* Make more adjustments for phone */
@media screen and (max-width: 350px) {
    textarea.form-control {
        height: auto;
    }
    .product-removal {
        float: right;
    }

    .product-line-price {
        float: right;
        clear: left;
        width: auto;
        margin-top: 10px;
    }

    .product .product-line-price:before {
        content: 'Item Total: ';
    }

    .product-line-price-v {
        float: right;
        clear: left;
        width: auto;
        margin-top: 10px;
    }

    .product .product-line-price-v:before {
        content: 'Item Total: ';
    }

    .totals .totals-item label {
        width: 60%;
    }
    .totals .totals-item .totals-value {
        width: 40%;
    }

}
