@charset "utf-8";

/* =====================================================
/* root
===================================================== */
:root {
  --color-black: #333333;
  --color-white: #ffffff;
  --color-gray: #f3f3f3;
  --color-dark-gray: #888888;
  --color-blue: #0070c0;
  --color-light-blue: #daf9ff;
  --color-red: #ab0000;
  --color-yellow: #f9d005;
  --color-theme-color: #00a9c9;
  --color-focus-bg: #e1f0f8;
  --color-focus-outline: #83c0de;
  --color-navy: #003a57;
}

/* =====================================================
/* flex
===================================================== */
.flex {
  display: flex;
  align-items: center;
  gap: 30px;

  &:first-of-type {
    margin-block-start: 0 !important;
  }

  &:nth-of-type(n + 1) {
    margin-block-start: 15px;
  }
}

@media screen and (width <=768px) {
  .flex {
    gap: 20px;
    flex-direction: column;
  }
}

/* =====================================================
/* flex_box
===================================================== */
.flex_box {
  display: flex;
  flex-wrap: wrap;
  inline-size: calc(100% / 2 - 15px);

  & input {
    inline-size: 100%;
  }
}

@media screen and (width <=768px) {
  .flex_box {
    inline-size: 100%;

    & input {
      inline-size: 100%;
    }
  }
}

/* =====================================================
/* flex-row
===================================================== */
.flex-row {
  flex-direction: row;
}

/* =====================================================
/* placeholder
===================================================== */
::placeholder {
  color: var(--color-dark-gray);
  font-size: 13px;
}

/* =====================================================
/* small
===================================================== */
small {
  font-size: 12px;
  margin-block-start: 10px;
}

/* =====================================================
/* borderNone
===================================================== */
.borderNone {
  border: none !important;
}

/* =====================================================
/* input
===================================================== */
input {
  inline-size: 100%;
  block-size: 50px;
  padding: 5px 10px;
  border: solid 1px var(--color-dark-gray);
  border-radius: 5px;

  &:focus-visible {
    caret-color: var(--color-black);
    background-color: var(--color-focus-bg);
    outline: 2px solid var(--color-focus-outline);
  }
}

@media screen and (width <=768px) {
  input {
    inline-size: 100%;
  }
}

/* =====================================================
/* customCheckBox
===================================================== */
.customCheckBox {
  border: none;
  inline-size: 100%;

  & label {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0 0.5em;
    max-inline-size: 100%;
    block-size: 50px;
    padding: 0.5em 0.7em;
    border: 1px solid var(--color-dark-gray);
    border-radius: 3px;
    cursor: pointer;

    &:has(:checked) {
      color: var(--color-black);
      border: 2px solid var(--color-focus-outline);
      background-color: var(--color-focus-bg);

      &::after {
        position: absolute;
        top: 17px;
        left: 16px;
        transform: rotate(45deg);
        inline-size: 6px;
        block-size: 10px;
        border: solid var(--color-theme-color);
        border-width: 0 2px 2px 0;
        content: "";
      }
    }

    &::before {
      content: "";
      inline-size: 15px;
      block-size: 15px;
      border-radius: 1px;
      background-color: var(--color-white);
      border: 1px solid var(--color-theme-color);
    }
  }

  & input {
    display: none;
  }
}

@media screen and (width <=768px) {
  .customCheckBox {
    & label {
      &:has(:checked) {
        &::after {
          left: 13.5px;
        }
      }
    }
  }
}

/* =====================================================
/* materialsCheckBox
===================================================== */
.materialsCheckBox {
  border: none;
  inline-size: 100%;
  margin: 20px auto 0;

  & label {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0 0.5em;
    max-inline-size: 100%;
    block-size: 50px;
    padding: 0.5em 0.7em;
    border: 1px solid var(--color-dark-gray);
    border-radius: 3px;
    cursor: pointer;
    background-color: var(--color-white);

    &:has(:checked) {
      color: var(--color-black);
      border: 2px solid var(--color-focus-outline);
      background-color: var(--color-focus-bg);

      &::after {
        position: absolute;
        top: 36%;
        left: 36%;
        transform: translate(-36%, -36%);
        transform: rotate(45deg);
        inline-size: 6px;
        block-size: 10px;
        border: solid var(--color-theme-color);
        border-width: 0 2px 2px 0;
        content: "";
      }
    }

    &::before {
      content: "";
      inline-size: 15px;
      block-size: 15px;
      border-radius: 1px;
      background-color: var(--color-white);
      border: 1px solid var(--color-theme-color);
    }
  }

  & input {
    display: none;
  }
}

@media screen and (width <=768px) {
  .materialsCheckBox {
    inline-size: 100%;

    & label {
      &:has(:checked) {
        &::after {
          left: 55px;
        }
      }
    }
  }
}

/* =====================================================
/* selectBox
===================================================== */
.selectBox {
  position: relative;
  inline-size: 100%;

  &::before,
  &::after {
    position: absolute;
    content: "";
    pointer-events: none;
  }

  &::before {
    display: inline-block;
    right: 0;
    inline-size: 50px;
    block-size: 50px;
    border-radius: 0 3px 3px 0;
    background-color: var(--color-theme-color);
  }

  &::after {
    position: absolute;
    top: 50%;
    right: 1.5em;
    transform: translate(50%, -50%) rotate(45deg);
    inline-size: 15px;
    block-size: 15px;
    border-block-end: 3px solid var(--color-white);
    border-inline-end: 3px solid var(--color-white);
  }

  & select {
    appearance: none;
    inline-size: 100%;
    block-size: 50px;
    padding: 5px;
    border: solid 1px var(--color-dark-gray);
    border-radius: 5px;
    cursor: pointer;
    overflow: hidden;

    &:focus {
      background: var(--color-focus-bg);
      outline: 2px solid var(--color-theme-color);
    }
  }
}

@media screen and (width <=768px) {
  .selectBox {
    position: relative;

    &::before {
      inline-size: 40px;
    }

    & select {
      padding: 5px;
    }
  }
}

/* =====================================================
/* textarea
===================================================== */
textarea {
  inline-size: 100%;
  block-size: 80px;
  border: solid 1px var(--color-dark-gray);
  border-radius: 5px;
  padding: 5px;

  &:focus-visible {
    caret-color: var(--color-black);
    background-color: var(--color-focus-bg);
    outline: 2px solid var(--color-focus-outline);
  }
}

@media screen and (width <=768px) {
  textarea {
    inline-size: 100%;
  }
}

/* =================================================
/* materialsTab
================================================= */
.materialsTab {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  cursor: pointer;

  & .tab {
    color: var(--color-white);
    background-color: var(--color-black);
    border-right: none;
    padding: 10px;
    text-align: center;
    font-weight: bold;

    &.is-active {
      color: var(--color-white);
      background: var(--color-theme-color);
      transition: all ease-out 0.2s 0.1s;
    }
  }
}

@media screen and (width <=768px) {
  .materialsTab {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;

    & .tab {
      display: grid;
      place-items: center;
      grid-template-rows: 50px;
      padding: 0 10px;
      font-size: 12px;
    }
  }
}

/* =================================================
/* content
================================================= */
.content {
  display: none;

  &.is-show {
    display: block;
    transition: all ease-out 0.2s 0.1s;
  }
}

/* =================================================
/* materials
================================================= */
.materials {
  inline-size: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 30px;
  margin-block: 30px 0;

  & .materialsBox {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background: var(--color-gray);
    border-radius: 5px;
    inline-size: calc(100% / 3 - 20px);

    & .title {
      font-size: 18px;
      font-weight: bold;
    }

    & .text {
      min-block-size: 57px;
    }

    & .materialsList {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 15px;
      margin-block: 10px 0;

      & .item {
        inline-size: 100%;

        & img {
          inline-size: auto;
          max-block-size: 200px;
          background: var(--color-white);
        }
      }
    }
  }
}

@media screen and (width <=768px) {
  .materials {
    flex-wrap: nowrap;
    flex-direction: row;
    overflow-x: scroll;

    & .materialsBox {
      flex-shrink: 0;
      inline-size: 80%;

      & .materialsList {
        justify-content: center;
      }
    }
  }
}

/* =====================================================
/* conversion
===================================================== */
.conversion {
  inline-size: 100%;
  display: grid;
  place-items: center;
  padding-block-start: 30px;

  & button[type="submit"] {
    inline-size: 500px;
    padding: 10px;
    border-radius: 5px;
    background-color: var(--color-yellow);
    color: var(--color-black);
    font-weight: bold;
    border: none;
    cursor: pointer;

    &:hover {
      opacity: 0.8;
      transition: 0.3s;
    }
  }

  & button[name="back"] {
    inline-size: 500px;
    padding: 10px;
    border-radius: 5px;
    color: var(--color-white);
    background-color: var(--color-dark-gray);
    font-weight: bold;
    border: none;
    cursor: pointer;
    margin-block-start: 25px;

    &:hover {
      opacity: 0.8;
      transition: 0.3s;
    }
  }
}

@media screen and (width <=768px) {
  .conversion {
    padding-block: 0 140px;

    & button[type="submit"] {
      inline-size: 100%;
      font-size: 16px;
    }

    & button[name="back"] {
      inline-size: 100%;
      font-size: 16px;
    }
  }
}

/* =====================================================
/* stickyCart
===================================================== */
.stickyCart {
  display: none;
  position: fixed;
  bottom: 0;
  right: 0;
  inline-size: 400px;
  block-size: auto;
  background: var(--color-focus-bg);
  box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  transition: transform 0.3s ease-in-out;

  &.is-visible {
    display: block;
  }

  & .inner {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    max-inline-size: 100%;
    margin: 0 auto;
    padding: 15px;

    & .selectedItem:last-child {
      display: flex;
      flex-wrap: nowrap;
      justify-content: space-between;
      gap: 20px;
      overflow-x: auto;
      margin-block-start: 20px;
    }
  }

  .cartItem {
    position: relative;
    inline-size: 100px;
    block-size: auto;
    border-radius: 5px;
    flex-shrink: 0;

    & img {
      inline-size: 100%;
      block-size: 100%;
      object-fit: cover;
      border-radius: 5px;
    }

    & .removeBtn {
      position: absolute;
      top: 5px;
      right: 5px;
      inline-size: 25px;
      block-size: 25px;
      background-color: var(--color-white);
      color: var(--color-black);
      border: none;
      border-radius: 50%;
      font-size: 14px;
      font-weight: bold;
      line-height: 25px;
      text-align: center;
      cursor: pointer;
      padding: 0;
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
      transition: background-color 0.2s;
    }
  }

  .contactLink a {
    position: relative;
    inline-size: 100%;
    color: var(--color-white);
    background: var(--color-navy);
    display: grid;
    place-items: center;
    padding: 10px;

    &::after {
      content: "";
      position: absolute;
      top: 50%;
      right: 30%;
      transform: translate(-30%, -50%);
      inline-size: 20px;
      block-size: 20px;
      background: url(../img/common/arrow_cool_down.svg) center / cover no-repeat;
    }
  }
}

@media screen and (width <=768px) {
  .stickyCart {
    inline-size: 100%;

    & .cartItem {
      inline-size: auto;
      block-size: 80px;

      & .removeBtn {
        inline-size: 25px;
        block-size: 25px;
        font-size: 16px;
        line-height: 25px;
      }
    }
  }
}
