@page{
    margin: 120px 75px 100px;
    font-family: 'Hind', sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    line-height: 10px;
    letter-spacing: 0.15px;
}

/* The whole page is 825px width (625px for the content left)  */

* {
    box-sizing: border-box;
}

/*noinspection CssNoGenericFontName*/
.fa {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}

/* Fix the bullet point alignment */
ul > li:before {
    content: '';
    display: inline-block;
    float: left;
    line-height: 1.2em;
}

ul > li {
    margin-bottom: 2px;
}

ul > li:last-child {
    margin-bottom: 0;
}

/********************************* HEADER *********************************/
header {
    position: fixed;
    left: 0; top: -80px; right: 0;

    box-sizing: border-box;
    border-bottom: 1px solid #b3b3b3;
    padding-bottom: 10px;
}

header #logo,
header #created-at {
    display: inline-block;
    font-size: 12px;
}

header #logo a img {
    width: 136px;
    height: 40px;
}

header #created-at {
    float: right;
    width: 200px;
    text-align: right;
}

header #logo a {
    position: relative;
}

header #logo a img {
    position: relative;
}

/********************************* MAIN *********************************/

div#image-info-row {
    padding-bottom: 20px;
    border-bottom: 1px solid #b3b3b3;
    margin-bottom: 20px;

    /*background-color: green;*/
}

#product-image-wrapper {
    width: 250px;
}

div#product-image-wrapper,
div.product-info-main {
    display: inline-block;
}

img.fotorama__img {
    width: 250px;
    height: 250px;
    float: left;
}

div.product-info-main {
    text-align: right;
    padding-left: 20px;
    position: relative;
    left: -177px;
    min-height: 250px;

    /*background-color: deeppink;*/
}

/*div.product-info-main > * {*/
/*    background-color: lightblue;*/
/*}*/

.page-title-wrapper h1 a {
    /*background-color: blue;*/
}

/*.page-title-wrapper h1 a span {*/
/*    background-color: red;*/
/*}*/

div.product-info-main > * {
    position: relative;
    /*left: -64px;*/
    right: 16px;

    /*background-color: orange;*/
}

div.product-info-main .page-title {
    font-size: 24px;
    line-height: 16px;
}

div.product-info-main .page-title a {
    color: #003366;
    text-decoration: none;
}

div.product-info-main .page-title a:hover {
    color: #337AB7;
}

div.product-info-main .page-title,
div.product-info-main .bundle-delta-model-number-container #delta-model-number-wrapper label {
    color: #003366;
}

div.product-info-main .product-info-stock-sku {
    display: none;
}

div.product-info-main .box-tocart {
    display: none;
}

div.product-info-main .product-info-price .price-final_price {
    /* hack:
     * The width of this element affects the width of the product-info-main element.
     * All the positions are balanced to perfectly fit into the layout. If one elements width changed, the layout
     * of the product-info-main content is disrupted. Thus, we need to set the explicit width of this element.
     */
    width: 566.5px;
}

div.product-info-main .product-info-price .price-final_price > .price-final_price.tax.weee {
    font-size: 18pt;
}

div.product-info-main .product-info-price .price-final_price > .price-final_price.tax.weee:after {
    content: "(zzgl. MwSt.)";
    font-size: 8pt;
}

div#pdf-note {
    /* hack:
     * The width of this element affects the width of the product-info-main element.
     * All the positions are balanced to perfectly fit into the layout. If one elements width changed, the layout
     * of the product-info-main content is disrupted. Thus, we need to set the explicit width of this element.
     */
    width: 318px;
    padding-left: 248.5px;
}

div#pdf-note label {
    color: #003366;
    font-weight: bold;
}

div#pdf-note span {
    text-align: left;
}

div.product-info-main .product-label.new {
    background-color: #a53748; /* @micro-red */

    text-align: left;
    padding-left: 2px;

    width: 28px;
    height: 30px;

    clear: both;
    display: inline-block;

    z-index: 999;

    position: absolute;
    top: 0;
    left: 180px;
}

div.product-info-main .product-label.new .product-label-text {
    color: white;
    font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
    font-weight: bold;
    font-style: italic;
    transform: rotate(-10deg);

    font-size: 10px;
    line-height: 25px;
}

div#bundleSummary {
    padding: 0;
}

div#bundleSummary .title,
div.product.attribute.description .title {
}

div#bundleSummary .title {
    padding-left: 27.5px;
}

div#bundleSummary .items strong,
div.product.attribute.description strong{
    color: #337ab7;
}

div#bundleSummary .title strong,
div.product.attribute.description .title strong {
    font-size: 18px;
    font-weight: 400;
    color: #003366;
}

table.data.table.additional-attributes {
    float: left;
    width: 53.5%;
}

table.data.table.additional-attributes caption {
    display: none;
}

div.product.attribute.description a {
    text-decoration: none;
}

table.data.table.additional-attributes tr th {
    text-align: left;
}

table.data.table.additional-attributes tr td {
    text-align: right;
}

div.product.attribute.description,
div#bundleSummary {
    float: left;
}

div.product.attribute.description {
    width: 300px;
    page-break-inside: auto;
}

div.product.attribute.description table tbody td {
    width: 50% !important;
    line-height: 12px;
    vertical-align: top;
    padding: 0 5px;
}

div.product.attribute.description table tbody td p {
    margin: 0;
    padding: 0;
}

div.product.attribute.description table tbody tr:nth-child(odd) {
    background: #e5eaf3;
}

div.product.attribute.description table tbody tr:nth-child(even) {
    background: #f8f8f8;
}

div.product.attribute.description > .value {
    page-break-inside: auto;
}

div#bundleSummary {
    width: 325px;
    margin-left: 15px;
}

div#bundleSummary div#bundle-summary-inner-wrapper {
    max-width: 325px;
}

div#bundleSummary ul.bundle.items {
    width: 285px;
}

div#bundleSummary .summary-selection-qtytitle {
    display: inline-block;
    width: 200px;
}

div#bundleSummary div[data-container="options"] > .selection {
    margin-top: 5px;
}

div#bundleSummary div[data-container="options"] > .selection:first-child {
    margin-top: 0;
}

div#bundleSummary .summary-selection-price {
    display: inline-block;
    text-align: right;
    width: 80px;
}

div#bundleSummary .summary-selection-attributes {
    display: block;
    padding-left: 15px;
    margin-top: -5px;
}

div.bundle-info {
}

div.bundle-info .price-container {
    display: none;
}

div.product-info-main .price-from {
    margin-top: 50px;
}

div.product-info-main .price-from .price-container:after,
#bundle-info-configured-price .price-container:after{
    content: "(zzgl. MwSt.)";
    font-size: 8pt;
}

div.bundle-info .price-container:after {
    content: "(zzgl. MwSt.)";
    font-size: 8pt;
}

#bundle-info-configured-price {
    color: #003366;
    font-size: 12pt;
    font-weight: bold;

    margin-top: -5px;
}

/**
* Bundle Options
*/

div.bundle-options-wrapper {
    page-break-before: always;
    width: 100%;
    margin-bottom: 20px;
}

div.bundle-options-wrapper fieldset {
    border: none;
    padding: 0;
}

div.bundle-options-wrapper .field.option.required .bundle-option-top label > span:after {
    content: '*';
    font-size: 12px;
    color: #6d5184;
    margin: 0 0 0 3.75px;
}

div.bundle-options-wrapper fieldset legend.title {
    padding: 0;
    left: 0;
    font-weight: 400;
    font-size: 18px;
    color: #003366;
}

div.bundle-options-wrapper fieldset .used-slots-bar {
    display: inline-block;
    font-weight: 400;
    float: right;
    font-size: 10px;
}

div.bundle-options-wrapper fieldset legend.title span {
}

div.bundle-options-wrapper .field.option .notifications-hints {
    display: none;
}

div.control > .notifications {
    margin-top: 10px;
    margin-bottom: 3px;
    font-size: 12px;
}

div.control > .notifications > .notification {
    padding: 5px;
    border: 1px solid #B3B3B3;
    border-radius: 2px;
    margin-bottom: 2px;
}

div.control > .notifications > .notification.warn {
    color: #6d5184;
    border-color: #6d5184;
}

div.control > .notifications > .notification.info {
    color: #337ab7;
    border-color: #337ab7;
}

div.control > .notifications > .notification:not(:first-child) {
     margin-top: 2px;
}

div.control > .notifications > .notification .fa {
    margin-right: 5px;
    float: left;
    padding-top: 2px;
}

div.control > .notifications > .notification span {
    margin-left: 20px;
    line-height: 9px;
}

div.bundle-options-wrapper .field.option {
    margin-top: 5px;
    margin-bottom: 10px;
    /*border-bottom: 2px solid #337ab7;*/
}

div.bundle-options-wrapper .fieldset-bundle-options > .field.option.CPU {
    margin-top: 20px;
}

div.bundle-options-wrapper .fieldset-bundle-options {
    margin-bottom: 0;
}

div.bundle-options-wrapper p.required {
    margin-left: 3px;
}

div.bundle-options-wrapper .bundle-option-top {
    font-size: 10pt;
    font-weight: bold;
    border-bottom: 2px solid #337ab7;
    padding-bottom: 4px;
    color: #337ab7;
    /*margin-bottom: 5px;*/
}

div.bundle-options-wrapper table {
    margin-bottom: 10px;
    border-collapse: collapse;
    width: 100%;
}

div.bundle-options-wrapper table.select-type-radio th:first-child,
div.bundle-options-wrapper table.select-type-radio td:first-child {
    display: none;
}

div.bundle-options-wrapper table th {
    border-bottom: 2px solid #b3b3b3;
}

div.bundle-options-wrapper table tr td {
    border-bottom: 1px solid #b3b3b3;
}

div.bundle-options-wrapper table tr:last-child td {
    border-bottom: 0;
}

div.bundle-options-wrapper table th,
div.bundle-options-wrapper table td {
    font-size: 10px;
    padding: 2px 5px;
    text-align: left;
}

div.bundle-options-wrapper table th:last-child,
div.bundle-options-wrapper table td:last-child {
    text-align: right;
}

div.bundle-options-wrapper table td input[type="checkbox"] {
    display: none;
}

div.bundle-options-wrapper table td .selection-special-price-label {
    color: #6D5184;
}

div.bundle-options-wrapper table td .selection-special-price-label .fa-percent {
    margin: 0 5px;
}

div.bundle-options-wrapper table td .selection-special-price-label .selection-on-sale {
    font-weight: bold;
}

div.bundle-options-wrapper table td .selection-old-price {
    margin-left: 5px;
    text-decoration: line-through;
}

div.bundle-options-wrapper table td .selection-special-price .price-container .price {
    font-weight: bold;
    color: #6D5184;
}

div.bundle-options-wrapper table td .selection-poor-availability {
    display: inline-block;
    margin-left: 5px;
}

div.bundle-options-wrapper table td .selection-poor-availability.yellow {
    color: #ded7e3;
}

div.bundle-options-wrapper table td .selection-poor-availability.orange {
    color: #9986a9;
}

div.bundle-options-wrapper table td .selection-poor-availability.red {
    color: #6d5184;
}

div.bundle-options-wrapper #availability-status-legend span:not(:first-child) {
    margin-left: 5px;
}

div.bundle-options-wrapper #availability-status-legend {
    font-size: 10px;
}

div.bundle-options-wrapper table td .selection-poor-availability,
div.bundle-options-wrapper #availability-status-legend i {
    vertical-align: bottom;
    padding-bottom: 3px;
}

div.bundle-options-wrapper #availability-status-legend .yellow {
    color: #ded7e3;
}

div.bundle-options-wrapper #availability-status-legend .orange {
    color: #9986a9;
}

div.bundle-options-wrapper #availability-status-legend .red {
    color: #6d5184;
}

    /* Input Fields */

div.bundle-options-wrapper input[type="number"] {
    display: inline;
    white-space: nowrap;
    border: 1px solid #b3b3b3;
}

div.bundle-options-wrapper input[type="number"]:before {
    content: attr(value);
}

/*noinspection CssUnusedSymbol*/
div.bundle-options-wrapper .field.qty-holder {
    font-size: 10px;
    margin-left: 5px;
}

/**
* CPU Price Scale Table
*/

/*noinspection CssUnusedSymbol*/
div.bundle-cpu-table-container #bundle-cpu-price-scale-table {
    page-break-before: avoid;
}

div.bundle-cpu-table-container legend.title {
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: 400;
    color: #003366;
}

div.bundle-cpu-table-container table {
    border-collapse: collapse;
    width: 100%;
    font-size: 10px;
}

div.bundle-cpu-table-container table thead {
    font-weight: bold;
}

div.bundle-cpu-table-container table tr.selected {
    background-color: #e5eaf3;
}

div.bundle-cpu-table-container table tr th {
    border-bottom: 2px solid #B3B3B3;
}

div.bundle-cpu-table-container table td {
    border-bottom: 1px solid #B3B3B3;
}

div.bundle-cpu-table-container table th,
div.bundle-cpu-table-container table td {
    padding: 5px;
    text-align: left;
}

div.bundle-cpu-table-container table td .selection-special-price-label {
    color: #6D5184;
}

div.bundle-cpu-table-container table td .selection-special-price-label .fa-percent {
    margin: 0 5px;
}

div.bundle-cpu-table-container table td .selection-special-price-label .selection-on-sale {
    font-weight: bold;
}

div.bundle-cpu-table-container table td .selection-poor-availability.yellow {
    color: #ded7e3
}

div.bundle-cpu-table-container table td .selection-poor-availability.orange {
    color: #9986a9
}

div.bundle-cpu-table-container table td .selection-poor-availability.red {
    color: #6d5184
}

div.bundle-cpu-table-container table th:last-child,
div.bundle-cpu-table-container table td:last-child {
    text-align: right;
}

/********************************* FOOTER *********************************/
footer {
    position: fixed;
    left: 0; bottom: -80px; right: 0;

    font-size: 9pt;

    box-sizing: border-box;
    border-top: 1px solid #b3b3b3;
    padding-top: 10px;
}

footer #address {
}

footer #address,
footer #page-count {
    display: inline-block;
}

footer #page-count {
    float: right;
    width: 200px;
    text-align: right;
}

footer #page-count span:before {
    content: counter(page);
}

footer .secret-link {
    color: black;
    text-decoration: none;
}

/********************************* SHOPPING CART *********************************/
h1.cart.title {
    font-weight: 400;
    font-size: 24px;
}

#shopping-cart-table {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
}

#shopping-cart-table tbody tr:first-child td {
    padding-top: 15px;
}

#shopping-cart-table tbody tr td {
    vertical-align: top;
}

#shopping-cart-table thead tr th {
    border-bottom: 2px solid #b3b3b3;
}

#shopping-cart-table tbody {
    border-bottom: 1px solid #b3b3b3;
}

#shopping-cart-table thead tr th.item {
    text-align: left;
}

#shopping-cart-table tbody tr td.item dl.item-options dt {
    font-weight: 700;
}

#shopping-cart-table tbody tr td.item dl.item-options dd:nth-child(1) {
    margin-bottom: 15px;
}

#shopping-cart-table tbody tr td.item dl.item-options dt {
}

#shopping-cart-table tbody tr td.item dl.item-options dd {
}

#shopping-cart-table thead tr th.price,
#shopping-cart-table tbody tr td.price,
#shopping-cart-table thead tr th.subtotal,
#shopping-cart-table tbody tr td.subtotal {
    text-align: right;
}

#shopping-cart-table thead tr th.qty,
#shopping-cart-table tbody tr td.qty {
    text-align: center;
}

#shopping-cart-table tbody tr td.price .price:after,
#shopping-cart-table tbody tr td.subtotal .price:after {
    content: "(zzgl. MwSt.)";
    font-size: 8px;
    display: block;
    margin-top: -6px;
}

#shopping-cart-table tbody.cart.grand-totals {
    font-size: 14px;
    padding-bottom: 0;
    margin-bottom: 0;
    border-top: 2px solid #b3b3b3;
    border-bottom: 2px solid #b3b3b3;
}

#shopping-cart-table tbody.cart.grand-totals th.mark,
#shopping-cart-table tbody.cart.grand-totals td.amount {
    text-align: right;
    padding: 15px 0;
}

#shopping-cart-table tbody.cart.grand-totals td.amount {
    column-span: all;
}

#shopping-cart-table tbody.cart.grand-totals td.amount .price:after {
    content: "(zzgl. MwSt.)";
    font-size: 10px;
    display: block;
    margin-top: -5px;
}

#shopping-cart-table tbody.cart.item td.item .product-item-name {
    line-height: 20px;
    font-size: 16px;
    font-weight: 400;
}

#shopping-cart-table tbody.cart.item td.item .product-item-name a {
    text-decoration: none;
    color: #337ab7;
}
