/*  ==============================

    Service Styles

    ==============================  */
.wrapper h1 {
    margin: 0 0 15px 0;
}
.wrapper {
    margin: 2px auto 75px;
}
.enterprise-service h1 {
    margin: 0 0 40px 0;
}
.wrapper h1 + h2 {
    font-size: 35px;
    color: #dd1100;
    margin: 40px 0 30px;
    font-weight: 300;
}
.service-table h2 + p {
    font-size: 15px;
}
.third .description {
    height: 70px;
}
.third a.button {
    width: 130px;
}
.description {
    text-align: left;
    font-size: 15px;
}
.description h3 {
    font-size: 20px;
    margin: 0;
}
.description ul {
    margin: 20px 0 40px;
}
.description li {
    margin: 0 0 10px 10px;
    font-size: 16px;
}
.subheading {
    width: 800px;
}
.service-table {
    border-collapse: collapse;
    table-layout: fixed;
}
.service-table h2 {
    color: #dd1100;
    font-size: 35px;
    margin: 0 0 25px;
    white-space: nowrap;
}
.service-table h3 {
    color: #535353;
    font-size: 19px;
    margin: 0 0 5px 0;
}
.service-table h3 + ul {
    margin: 30px 0 0 0;
}
.service-table p.description-heading {
    font-size: 19px;
    margin: 0 0 10px;
}
.service-table p {
    margin: 0 0 15px;
    line-height: 1.5;
}
.enterprise-service .service-table p {
    font-size: 21px;
    font-weight: 300;
    margin: 10px 0 40px;
    line-height: 1.6;
}
.enterprise-service .service-table td {
    padding: 30px;
}
.enterprise-service .service-table p + .button {
    margin: 0 0 20px 0;
}
.service-table td {
    padding: 25px 40px;
    border: 1px solid #d6d6d6;
    vertical-align: top;
    width: 519px;
    background: #fff;
}
.service-table td:nth-child(2n) {
    background: #f8f8f8;
}
a.button {
    display: inline-block;
    vertical-align: middle;
}
a.button.medium.width-250{
    min-width: 250px;
}
a.button.medium.width-260{
    min-width: 260px;
}
p.upgrade {
    vertical-align: middle;
    font-size: 13px;
    line-height: 1.3;
    white-space: nowrap;
    margin: 10px 0 0 0;
    display: block;
}

p.upgrade a {
    font-weight: 600;
}
.chart th:before {
    margin: 0 0 0 52px;
}
.service-table li {
    font-size: 18px;
    margin: 0 0 20px 30px;
    text-indent: 0px;
    padding: 0 0 0 10px;
    position: relative;
}
.service-table li:last-child {
    margin: 0 0 0 30px;
}
.service-table li:before {
    content: '';
    width: 26px;
    height: 21px;
    background: url('/mathematica/pricing/img/check-bigger.png') no-repeat left center;
    position: absolute;
    top: -5px;
    left: -25px;
    display: inline-block;
}
.service-table li.gray {
    color: #cfcfcf;
}
.service-table li.gray:before {
    content: '\00d7';
    color: #cfcfcf;
    width: 0;
    height: 0;
    border: 0;
    font-weight: 600;
    font-size: 50px;
    transform: none;
    top: 4px;
    left: -30px;
}

/* Tabs and charts
--------------------------------------------*/
#tabs {
    position: relative;
    margin: 35px 0 0 0;
}
#tabs a.tab.selected {
    background: #dd1100;
    color: #fff;
}
#tabs .tab {
    border: 1px solid #dd1100;
    border-right: 0;
    border-bottom: 0;
    font-size: 15px;
    height: 60px;
    display: table-cell;
    vertical-align: middle;
    padding: 0 45px;
    background: #fff;
    background: linear-gradient(to bottom,  #ffffff 30%,#eaeaea 100%);
    font-weight: 600;
    text-align: center;
}
#tabs .tab.last {
    border-right: 1px solid #dd1100;
}
.tab.selected {
    background: #dd1100;
    color: #fff;
}
#tabs .service-table {
    border: 1px solid #dd1100;
    height: 164px;
    position: absolute;
    z-index: 10;
}
#tabs .service-table td {
    border: 0;
    text-align: center;
    font-size: 18px;
    color: #dd1100;
    padding: 25px 30px;
}
#tabs .service-table td + td {
    border-left: 1px solid #d6d6d6;
}
#tabs .service-table .button {
    margin: 10px auto 0;
    display: block;
    width: 180px;
}
#tabs .service-table .price-tag.premier {
    display: inline-block;
    vertical-align: text-bottom;
}

/* Show Hide */
#tabs .show-hide:before {
    content: '+';
    display: inline-block;
    font-size: 40px;
    vertical-align: middle;
    font-weight: 600;
}
#tabs .show .show-hide:before {
    content: '';
    width: 18px;
    height: 3px;
    background: #dd1100;
    margin: 1px 1px 0 1px;
}
#tabs .show-hide:after {
    content: 'Show Full List of Benefits';
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 0 10px;
    font-size: 17px;
}
#tabs .show .show-hide:after {
    content: 'Hide Full List of Benefits';
}
#tabs .show-hide {
    border: 1px solid #d6d6d6;
    background: #f8f8f8;
    color: #dd1100;
    padding: 10px 30px;
    display: block;
    cursor: pointer;
    height: 44px;
}
#tabs .show-hide:hover {
    background: #f8f8f8;
    border: 1px solid #f77700;
}
#tabs .show-hide:hover:after {
    color: #f77700;
}
#tabs .show-hide:hover:before {
    color: #f77700;
}
#tabs .show .show-hide:hover:before {
    background: #f77700;
}
.chart {
    width: 100%;
}
#tabs .red-td-heading {
    background: #dd1100;
    color: #fff;
    font-size: 16px;
}
#tabs .red-td-heading td {
    border: 1px solid #d6d6d6;
    border-top: 0;
    padding: 3px;
}
#tabs .red-td-heading td:after {
    display: none;
}
#tabs .chart th:before {
    display: none;
}
#tabs .show .chart th:before {
    display: block;
}
.chart td:nth-child(2n):after {
    content: '';
    width: 0;
    height: 25px;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;
}

.chart-wrapper {
    max-height: 44px;
    overflow: hidden;
}
.show.chart-wrapper {
    max-height: 2500px;
    transition-property: all;
    transition-duration: .8s;
    overflow: visible;
}
.single-column {
    width: 828px;
}
.single-column#tabs {
    margin: 0;
}
.single-column .service-table td {
    width: 828px;
    height: 164px;
}
.filler {
    height: 164px;
    position: relative;
}
#tabs .service-table.collapsed {
    position: fixed;
}
/* Footer */
p.table-footer-text {
    padding: 15px 0 0 12px;
}