@CHARSET "UTF-8";

:root {
  --pri-color: white;
  --pri-color-text: black;
  --pri-color-highlight: cornflowerblue;
  --pri-color-text-highlight: white;

  --sec-color: var(--pri-color-highlight);
  --sec-color-text: var(--pri-color-text-highlight);

  --neutral-color: lightslategrey;
  --neutral-color-text: whitesmoke;

  --btn-color-positive: var(--pri-color);
  --btn-color-negative: orangered;

  --input-color: var(--pri-color);
  --input-color-text: var(--pri-color-text);

  --default-spacing: 12px;
  --default-rounding: 4px;

  --max-width: 960px;

  --font-size-xxl: 24px;
  --font-size-xl: 20px;
  --font-size-l: 16px;
  --font-size-m: 14px;
  --font-size-s: 12px;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  outline: none;

  font-size: var(--font-size-m);
  font-weight: normal;
  line-height: 1.5;
  font-family: -apple-system,BlinkMacSystemFont,system-ui,ui-sans-serif,sans-serif,Helvetica,Arial;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--neutral-color);
  color: var(--neutral-color-text);
  text-align: left;
}

h1 {
  font-size: var(--font-size-xxl);
}

h2 {
  font-size: var(--font-size-xl);
}

span {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}

a {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  text-decoration: underline;
  line-height: inherit;
}

a:hover {
  text-decoration: none;
}

strong {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  font-weight: bold;
  line-height: inherit;
}

li {
  list-style-position: inside;
}

input[type="text"], input[type="password"], input[type="email"], input[type="number"], input[type="tel"], textarea, .input {
  display: block;
  width: 100%;

  margin: 0px;
  padding: var(--default-spacing);
  border: 1px solid var(--input-color-text);
  border-radius: 0px;

  background: var(--input-color);
  color: var(--input-color-text);

  text-align: left;
}

select {
  display: block;
  width: 100%;
  max-width: 500px;

  margin: 0px;
  padding: var(--default-spacing);
  border: 1px solid var(--input-color-text);
  border-radius: 0px;

  background: var(--input-color);
  color: var(--input-color-text);

  text-align: left;
}

select[multiple="multiple"] {
  display: block;
  width: 100%;
  max-width: 500px;

  margin: 0px;
  padding: 0px;
  border: 1px solid var(--input-color-text);
  border-radius: 0px;

  background: var(--input-color);
  color: var(--input-color-text);

  text-align: left;
}

select option {
  display: block;
  width: 100%;

  margin: 0px;
  padding: var(--default-spacing);
  border: 0px;
  border-radius: 0px;

  background: var(--input-color);
  color: var(--input-color-text);

  text-align: left;
}

select option[selected="selected"] {
  background: gray;
  color: white;
}

label {
  display: block;
  width: 100%;

  margin: 0px;
  padding: var(--default-spacing);
  border: 0px;
  border-radius: 0px;

  background: var(--pri-color);
  color: var(--pri-color-text);

  text-align: left;
}

/*
 * General elements.
 */
.root-flow {
  display: block;
  width: 100%;
  overflow: auto;
  max-width: 100%;

  border: 0px;
  margin: 0px;
  padding: 0px;

  text-align: center;
}

.page-flow {
  display: block;
  width: auto;
  overflow: auto;
  max-width: var(--max-width);

  border: 0px;
  margin: 0px auto;
  padding: 0px;

  text-align: left;
}

/*
 * Header elements.
 */
.menu {
  display: none;
  box-sizing: border-box;

  margin: 0px;
  border: 0px;
  border-bottom: 1px solid white;
  padding: 0px;
}

.menu-item {
  display: block;
  box-sizing: border-box;

  margin: 0px;
}

.menu-item a {
  display: block;
  box-sizing: border-box;

  margin: 0px;
  padding: var(--default-spacing);

  background: var(--sec-color);
  color: var(--sec-color-text);
  text-decoration: none;
  text-align: left;
}

.menu-item a:hover {
  background: var(--pri-color);
  color: var(--pri-color-text);
}

.message-error {
  display: block;
  width: 100%;

  margin: var(--default-spacing) 0px 0px 0px;
  padding: var(--default-spacing);
  border: 0px;
  border-radius: var(--default-rounding);

  background: var(--btn-color-negative);
  color: white;
  font-family: sans-serif;
  text-decoration: none;
  text-align: left;
}

/* Header: Search Bar */
.search-form {
  display: block;
  margin: var(--default-spacing);
  padding: 0;
}

.search-input {
  display: block;
  width: 100%;
  margin: 0;
  padding: 6px var(--default-spacing);
  border: 0px;
  border-radius: 16px;
}

/**
 * Buy now styles.
 */
.cart-heading {
  display: block;
  width: auto;

  margin: var(--default-spacing);
  padding: 0px;
  border: 0px;

  text-align: left;
}

.cart-items {
  display: block;
  width: auto;

  margin: var(--default-spacing);
  padding: 0px;
  border: 0px;

  text-align: left;
}

.cart-items table {
  width: 100%;

  border-collapse: collapse;
}

.cart-items thead tr {
  background: var(--sec-color);
  color: var(--sec-color-text);
}

.cart-items thead th {
  color: White;
  font-weight: bold;
}

.cart-items tr {
  border: 1px solid var(--pri-color-text);
}

.cart-items .add {
  display: inline-block;
  border-radius: var(--default-rounding);
  padding: 0px 8px;

  background: white;
  color: green;
  text-decoration: none;
}

.cart-items .add:hover {
  background: green;
  color: white;
  text-decoration: none;
}

.cart-items .remove {
  display: inline-block;
  border-radius: var(--default-rounding);
  padding: 0px 8px;

  background: white;
  color: red;
  text-decoration: none;
}

.cart-items .remove:hover {
  background: red;
  color: white;
  text-decoration: none;
}

.cart-form {
  display: block;
  width: auto;

  margin: var(--default-spacing);
  padding: 0px;
  border: 1px solid var(--pri-color-text);
  border-radius: var(--default-rounding);

  text-align: left;
  background: var(--pri-color);
  color: var(--pri-color-text);
}

@media screen and (max-width: 550px) {
  .cart-form {
    margin: 0px var(--default-spacing);
    border: 0px;
  }
}

.cart-form h2 {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 500px;

  margin: var(--default-spacing) auto;
  padding: var(--default-spacing) 0px;
  border: 0px;

  font-family: sans-serif;
  text-transform: uppercase;
  text-align: left;
}

.cart-form p {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 500px;

  margin: var(--default-spacing) auto;
  padding: 0px;
}

.cart-form label {
  display: block;

  margin: 0px;
  padding: var(--default-spacing) 0px;
  border: 0px;
  border-radius: 0px;

  background: var(--pri-color);
  color: var(--pri-color-text);

  font-size: 16px;
  text-align: left;
}

.cart-form button {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 500px;

  margin: var(--default-spacing) auto var(--default-spacing) auto;
  border: 1px solid var(--sec-color);
  padding: var(--default-spacing);
  box-shadow: 0 4px 2px rgba(0, 0, 0, 0.2);
  border-radius: 24px;

  background: var(--sec-color);
  color: var(--sec-color-text);
  text-decoration: none;
  text-align: center;
  letter-spacing: 1px;
  font-weight: bold;
}

.cart-form button:hover {
  box-shadow: none;
  border: 1px solid var(--sec-color-text);
}

.required {
  color: red;
  text-decoration: none;
}

/* Footer items. */
.footer-blocks {
  display: block;
  list-style: none;
}

.footer-blocks > li {
  display: inline-block;
  vertical-align: top;
  margin: var(--default-spacing);
}

.footer-blocks h4 {
  font-weight: bold;
}

.footer-blocks table {
  border-collapse: collapse;
}

.footer-blocks ul {
  list-style: none;
}

/* Content blocks. */
.content {
  display: block;
  margin: var(--default-spacing);
}

.content h2 {
  font-weight: bold;
  margin-bottom: var(--default-spacing);
}

/* PDP */
.pdp {
  background: white;
  color: black;
}

.pdp h1 {
  margin: var(--default-spacing);
  text-transform: uppercase;
}

.pdp h2 {
  margin: var(--default-spacing);
  text-transform: uppercase;
}

.pdp .brand {
  margin: var(--default-spacing);
  color: dimgray;
}

.pdp .available {
  margin: var(--default-spacing);
  color: green;
}

.pdp .price {
  margin: var(--default-spacing);
  font-size: var(--font-size-l);
  font-weight: bold;
}

.pdp .addtocart {
  display: block;
  margin: var(--default-spacing);
  padding: var(--default-spacing);
  border-radius: var(--default-rounding);

  text-align: center;
  background: var(--sec-color);
  color: var(--sec-color-text);
  font-size: var(--font-size-l);
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: 1px;
}

.pdp .addtocart:hover {
  background: royalblue;
  color: white;
}

.pdp .characteristics {
  margin: var(--default-spacing);
}

.pdp .characteristics table {
  width: 100%; border-collapse: collapse;
}

.pdp .characteristics tr {
  border-top: 1px solid lightgray;
  border-bottom: 1px solid lightgray;
}

.pdp .characteristics th {
  width: 50%;
  padding: 4px 0px;

  vertical-align: top;
  font-weight: bold;
  color: dimgray;
}

.pdp .characteristics td {
  padding: 4px 0px;

  vertical-align: top;
}

.pdp .description {
  margin: var(--default-spacing);
}

/* PLP */
.product-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
  align-items: stretch;
  gap: var(--default-spacing);
  margin: var(--default-spacing);
}

.product-list > li {
  display: flex;
  flex-direction: column;
  justify-content: space-between;

  list-style-type: none;
  width: calc(50% - 0.5 * var(--default-spacing));
  margin: 0;
  border: 1px solid silver;
  box-shadow: 0px 4px 4px 2px rgba(0, 0, 0, 0.1);
}

@media screen and (min-width: 640px) {
  .product-list > li {
    width: calc(33% - 0.66 * var(--default-spacing));
  }
}

.product-list-media {
  padding: 0;
  overflow: hidden;
  text-align: center;
  border-bottom: 1px solid silver;
}

.product-list-media > a {
  display: block;
  width: 100%;
  margin: auto;
  border: 0px;
}

.product-list-media > a > img{
  display: block;
  width: auto;
  max-width: 100%;
  margin: auto;
  border: 0px;
}

.product-list-detail {
  padding: var(--default-spacing);
  display: block;
  overflow: hidden;
}

.product-list-detail > .name {
  margin-bottom: var(--default-spacing);
  display: block;
}

.product-list-detail > .code {
  margin-bottom: var(--default-spacing);
  display: block;
  color: dimgray;
}

.product-list-detail > .instock {
  margin-bottom: var(--default-spacing);
  display: block;
  color: seagreen;
}

.product-list-detail > .price {
  margin-bottom: var(--default-spacing);
  display: block;
  font-size: var(--font-size-l);
}

.product-list-button {
  display: block;
  box-sizing: border-box;
  width: auto;
  margin: 0px;
  border: 0px;
  padding: 8px var(--default-spacing);
  border-radius: var(--default-rounding);

  background: var(--sec-color);
  color: white;

  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 1px;
}

.product-list-button:hover {
  background: royalblue;
  color: white;
}

.pager {
  display: block;
  box-sizing: border-box;
  width: auto;
  margin: var(--default-spacing);
  border: none;
  padding: 0px;
}

.pager-flat {
  display: inline-block;
  box-sizing: border-box;
  width: auto;
  min-width: 48px;
  margin: 0px;
  border: 1px solid cornflowerblue;
  padding: var(--default-spacing);
  border-radius: var(--default-rounding);

  background: white;
  color: cornflowerblue;

  text-decoration: none;
  text-align: center;
  letter-spacing: 1px;
}

.pager-dots {
  display: inline-block;
  box-sizing: border-box;
  width: auto;
  min-width: 48px;
  margin: 0px;
  border: 1px solid white;
  padding: var(--default-spacing);
  border-radius: var(--default-rounding);

  background: white;
  color: cornflowerblue;

  text-decoration: none;
  text-align: center;
  letter-spacing: 1px;
}

.pager a {
  display: inline-block;
  box-sizing: border-box;
  width: auto;
  min-width: 48px;
  margin: 0px;
  border: 1px solid cornflowerblue;
  padding: var(--default-spacing);
  border-radius: var(--default-rounding);

  background: cornflowerblue;
  color: white;

  text-decoration: none;
  text-align: center;
  letter-spacing: 1px;
}

.pager a:hover {
  border: 1px solid royalblue;
  background: royalblue;
  color: white;
}