@charset "UTF-8";

/* ------------------
   reset
------------------ */
*, ::before, ::after { box-sizing: border-box; border-style: solid; border-width: 0; }
html { line-height: 1.15; -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent; }
body { margin: 0; padding: 0; }
main { display: block; }
blockquote, q { quotes: none; }
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0; word-break: break-all; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
dd { margin-left: 0; }
hr { box-sizing: content-box; height: 0; overflow: visible; border-top-width: 1px; margin: 0; clear: both; color: inherit; }
pre { font-family: monospace, monospace; font-size: inherit; white-space: pre-wrap; }
address { font-style: inherit; }
a { background-color: transparent; text-decoration: none; color: inherit; }
abbr[title] { text-decoration: underline dotted; }
b, strong { font-weight: bolder; }
code, kbd, samp { font-family: monospace, monospace; font-size: inherit; }
small { font-size: 80%; }
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sub { bottom: -0.25em; }
sup { top: -0.5em; }
svg, img, embed, object, iframe { vertical-align: bottom; }
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer; }
button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default; }
button:focus-visible { outline: none; }
:-moz-focusring { outline: auto; }
select:disabled { opacity: inherit; }
option { padding: 0; }
fieldset { margin: 0; padding: 0; min-width: 0; }
legend { padding: 0; }
progress { vertical-align: baseline; }
textarea { overflow: auto; }
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }
[type="search"] { outline-offset: -2px; }
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }
::-webkit-file-upload-button { -webkit-appearance: button; font: inherit; }
[type="number"] { -moz-appearance: textfield; }
label[for] { cursor: pointer; }
details { display: block; }
summary { display: list-item; }
[contenteditable]:focus { outline: auto; }
table { border-color: inherit; border-collapse: collapse; border-spacing: 0; }
caption { text-align: left; }
td, th { vertical-align: top; padding: 0; }
th { font-weight: bold; vertical-align: middle; text-align: left; }

/* ------------------
   style
------------------ */
:root {
  --color-black: #000000;
  --color-black05: rgba(0, 0, 0, 0.05);
  --color-black10: rgba(0, 0, 0, 0.1);
  --color-black25: rgba(0, 0, 0, 0.25);

  --color-white: #ffffff;
  --color-text: #333333;
  --color-gray: #C8C8C8;
  --color-mgray: #E0E0E0;
  --color-pgray: #F6F6F6;
  --color-border: #DFDFDF;
  --color-option: #D0D0D0;
  --color-placeholder: #666666;

  --color-Main: #0079C5;
  --color-Main90: rgba(0, 121, 197, 0.9);
  --color-Sub: #E7F4FD;
  --color-Accent: #FB7D00;
  --color-Dot: #C7C7C7;
  --color-red: #D40202;
  --color-scroll-BG: #DBDBDB;
  --color-scroll-drag: #BBBBBB;
 
  /* sp font */
  --font-60: min(6.0rem, 16vmin);
  --font-55: min(5.5rem, 14.666666666666666vmin);
  --font-50: min(5.0rem, 13.333333333333334vmin);
  --font-48: min(4.8rem, 12.8vmin);
  --font-45: min(4.5rem, 12vmin);
  --font-42: min(4.2rem, 11.200000000000001vmin);
  --font-40: min(4.0rem, 10.666666666666668vmin);
  --font-38: min(3.8rem, 10.133333333333333vmin);
  --font-36: min(3.6rem, 9.6vmin);
  --font-35: min(3.5rem, 9.333333333333334vmin);
  --font-34: min(3.4rem, 9.066666666666666vmin);
  --font-33: min(3.3rem, 8.799999999999999vmin);
  --font-32: min(3.2rem, 8.533333333333333vmin);
  --font-30: min(3.0rem, 8vmin);
  --font-28: min(2.8rem, 7.466666666666668vmin);
  --font-27: min(2.7rem, 7.199999999999999vmin);
  --font-25: min(2.5rem, 6.666666666666667vmin);
  --font-24: min(2.4rem, 6.4vmin);
  --font-23: min(2.3rem, 6.133333333333333vmin);
  --font-22: min(2.2rem, 5.866666666666666vmin);
  --font-21: min(2.1rem, 5.6000000000000005vmin);
  --font-20: min(2.0rem, 5.333333333333334vmin);
  --font-19: min(1.9rem, 5.066666666666666vmin);
  --font-18: min(1.8rem, 4.8vmin);
  --font-17: min(1.7rem, 4.533333333333333vmin);
  --font-16: min(1.6rem, 4.266666666666667vmin);
  --font-15: min(1.5rem, 4vmin);
  --font-14: min(1.4rem, 3.733333333333334vmin);
  --font-13: min(1.3rem, 3.4666666666666663vmin);
  --font-12: min(1.2rem, 3.2vmin);
  --font-11: min(1.1rem, 2.933333333333333vmin);
  --font-10: min(1.0rem, 2.666666666666667vmin);
  --font-9: min(0.9rem, 2.4vmin);
  --font-8: min(0.8rem, 2.1333333333333333vmin);
  --font-7: min(0.7rem, 1.866666666666667vmin);
  --font-6: min(0.6rem, 1.6vmin);
  --font-5: min(0.5rem, 1.3333333333333335vmin);
  --font-4: min(0.4rem, 1.0666666666666667vmin);
  --font-3: min(0.3rem, 0.8vmin);
  --font-2: min(0.2rem, 0.5333333333333333vmin);
  --font-1: min(0.1rem, 0.26666666666666666vmin);

  --font-NotoSansJP: "Noto Sans JP", sans-serif;
  --font-Roboto: "Roboto", sans-serif;

  /* border-radius */
  --img-radius-pc: 2.0rem;
  --img-radius-sp: min(1.0rem, 2.666666666666667vmin);
  --btn-radius: 100vh;
  --circle-radius: 50%;
}

html {
  scroll-behavior: smooth;
  font-size: 62.5%;
}

body {
  background-color: var(--color-BG);
  color: var(--color-text);
  font-family:"Noto Sans JP", メイリオ, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "Lucida Sans Unicode", "Lucida Grande", Arial, Helvetica, "ＭＳ Ｐゴシック", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  html {
    scroll-padding-top: max(25.333333333333336vw, 9.5rem);
  }

  .pc-only {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  :root {
    --pc-page-padding-inline: 20px;
    --pc-page-width: calc(1200px + var(--pc-page-padding-inline) * 2);
  }

  html {
    scroll-padding-top: 19.5rem;
  }

  .sp-only {
    display: none !important;
  }
}

/* リンク */
:root {
  --link-hover-opacity: .7;
  --link-hover-transition: opacity .3s ease-in-out;
  --link-btn-transition: all .3s;
}

a {
  color: var(--color-text);
  text-decoration: none;
  transition: var(--link-hover-transition);
}

a:hover, a:active {
  opacity: var(--link-hover-opacity);
}

input[type="text"],
select, textarea {
  box-sizing: border-box;
  font-size: 1.6rem;
}

input::placeholder {
  color: var(--color-placeholder);
  font-size: 1.4rem;
}

img {
  max-width: 100%;
  height: auto;
}

.img-wrap {
  display: grid;
  place-items: center;
}

.img-wrap img {
  grid-column: 1;
  grid-row: 1;
}

.accordion-img {
  display: grid;
  place-items: center;
  background-color: var(--color-white);
  border-radius: var(--circle-radius);
}

.accordion-img .--line {
  grid-column: 1;
  grid-row: 1;
  display: block;
  background-color: var(--color-Main);
  border-radius: var(--btn-radius);
}

.accordion-img .--line:last-child {
  transform: rotate(90deg);
  transition: var(--link-btn-transition);
}

*:is(.open) > .accordion-img .--line:last-child {
  transform: rotate(0deg);
}

@media screen and (max-width: 768px) {
  input[type="text"],
  select, textarea {
    border: var(--font-1) solid var(--color-option);
    padding-block: var(--font-7);
    padding-inline: var(--font-8);
  }

  .accordion-img {
    width: var(--font-20);
    height: var(--font-20);
  }

  .accordion-img .--line {
    width: var(--font-10);
    height: var(--font-2);
  }
}

@media screen and (min-width: 769px) {
  input[type="text"],
  select, textarea {
    border: 0.1rem solid var(--color-option);
    padding-block: 0.75rem;
    padding-inline: 1.6rem;
  }

  .img-wrap > img {
    grid-column: 1;
    grid-row: 1;
    transition: var(--link-btn-transition);
  }

  .img-wrap .on-img {
    opacity: 0;
    pointer-events: none;
  }

  *:hover > .img-wrap .out-img {
    opacity: 0;
    pointer-events: none;
  }

  *:hover > .img-wrap .on-img {
    opacity: 1;
    pointer-events: inherit;
  }

  .accordion-img {
    width: 3rem;
    height: 3rem;
  }

  .accordion-img .--line {
    width: 1.2rem;
    height: 0.2rem;
  }
}

/* -----------------------------------------------------------------
   header
----------------------------------------------------------------- */
.header {
  position: fixed;
  top: 0;
  left: 0;
  display: grid;
  align-items: center;
  width: 100%;
  background-color: var(--color-white);
  z-index: 1000;
}

.obi-wrap {
  background-color: var(--color-pgray);
  overflow: hidden;
  transition: var(--link-btn-transition);
}

.obi-text {
  font-weight: 500;
}

.header-wrap {
  background: var(--color-white);
  transition: var(--link-btn-transition);
}

.header-wrap .container {
  display: grid;
  align-items: center;
  height: inherit;
}

.header-wrap .logo {
  transition: var(--link-btn-transition);
}

.header-wrap .logo-link {
  display: block;
  width: max-content;
}

.header-guide {
  display: flex;
  align-items: center;
}

.header-guide-link {
  position: relative;
}

.header-nav-cart {
  position: relative;
}

.cart-badge {
  position: absolute;
  display: grid;
  place-content: center;
  background-color: var(--color-red);
  border-radius: var(--circle-radius);
  color: var(--color-white);
  font-weight: 700;
  line-height: 1;
}

.cart-badge:is(.no-badge) {
  display: none;
}

.header-search-wrap {
  display: block;
}

.search-content-area {
  position: relative;
}

.header-search-wrap .search-content-area .header-search-input {
  border: none;
}

.header-search-wrap .search-content-area .header-search-input:focus {
  outline: none;
}

.header-search-btn {
  position: absolute;
  top: 0;
  right: 0;
}

.header-guide-search-wrap .close-img {
  display: block;
}

.menu-close-wrap .close-btn {}

.menu-close-wrap .close-img {
  display: block;
}

.menu-content {
  transition: var(--link-btn-transition);
  overscroll-behavior: contain;
}

.menu-guide-wrap {
  display: grid;
}

.menu-category-list {
  display: grid;
}

a:is(.menu-category-name){
  position: relative;
  background-color: var(--color-Sub);
}

.menu-category-list .menu-category-three-wrap {
  max-height: 0;
  overflow: hidden;
  transition: var(--link-btn-transition);
}

.menu-category-list .menu-category-child-content .list-item:is(.open) .menu-category-three-wrap {
}

.menu-information-content {
  display: grid;
}

.menu-information-content .menu-information-link {
  display: grid;
  background-color: var(--color-Main);
  color: var(--color-white);
}

.menu-guide-text {
  font-weight: 500;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .header {
    position: fixed;
    top: 0;
    width: 100vw;
    border-block-start: var(--font-4) solid var(--color-Main);
  }

  .obi-wrap {
    padding-block: var(--font-5);
  }

  .obi-wrap .container {
  }

  .obi-text {
    display: block;
    font-size: var(--font-12);
    overflow-x: auto;
    padding-inline: var(--font-15);
    text-align: center;
    white-space: nowrap;
  }

  .header-wrap {
    height: max(15.466666666666667vmin, 5.8rem);
    box-shadow: 0 var(--font-2) var(--font-2) 0 var(--color-black05);
  }

  .header-wrap > .container {
    grid-template-columns: minmax(0, 1fr) max-content;
    align-items: center;
    column-gap: var(--font-15);
    width: 100vw;
    height: 100%;
  }

  .header-wrap .logo {
    margin-inline-start: var(--font-15);
  }

  .logo-img {
    width: max(66.66666666666666vmin, 25rem);
  }

  .menu-btn {
    display: grid;
    row-gap: var(--font-1);
    width: var(--font-40);
    margin-inline-end: var(--font-6);
  }

  .menu-btn .img-wrap {
    width: var(--font-30);
    margin: auto;
  }

  .menu-btn .menu-img {
    width: var(--font-20);
  }

  .menu-btn .close-img {
    opacity: 0;
    pointer-events: none;
    display: block;
  }

  .menu-btn:is(.open) .menu-img {
    opacity: 0;
    pointer-events: none;
  }

  .menu-btn:is(.open) .close-img {
    opacity: 1;
    pointer-events: inherit;
  }

  .menu-btn .header-guide-text {
    grid-row: 2;
    grid-column: 1;
    font-size: var(--font-10);
    font-weight: 500;
    text-align: center;
    transition: var(--link-btn-transition);
  }

  .menu-btn .header-guide-close {
    opacity: 0;
    pointer-events: none;
  }

  .menu-btn:is(.open) .header-guide-menu {
    opacity: 0;
    pointer-events: none;
  }

  .menu-btn:is(.open) .header-guide-close {
    opacity: 1;
    pointer-events: inherit;
  }

  .menu-wrap {
    position: fixed;
    top: 6rem;
    left: 0;
    width: 100vw;
    height: 100vh;
    max-height: calc(100% - max(12vmin, 6rem));
    background-color: var(--color-white);
    opacity: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    pointer-events: none;
    transition: var(--link-btn-transition);
    z-index: -1;
  }

  .menu-wrap:is(.open) {
    opacity: 1;
    pointer-events: inherit;
  }

  .header-search {
    width: 100vw;
    background-color: var(--color-Sub);
    padding-block: var(--font-30);
    padding-inline: var(--font-15);
  }

  .header-search-wrap {
    display: grid;
    row-gap: var(--font-15);
    place-items: center;
  }

  .header-search-wrap .search-content-area .header-search-input {
    width: 100%;
    height: var(--font-50);
    background-color: var(--color-white);
    border: var(--font-1) solid var(--color-border);
    border-radius: var(--btn-radius);
    font-size: 1.6rem;
    padding-block: 0;
    padding-inline-start: var(--font-32);
    padding-inline-end: max(22.666666666666664vmin, 8.5rem);
  }

  .header-search-btn {
    display: grid;
    place-items: start;
    align-items: center;
    width: max(20vmin, 7.5rem);
    height: var(--font-50);
    border: var(--font-1) solid var(--color-Main);
    background-color: var(--color-Main);
    border-start-end-radius: var(--btn-radius);
    border-end-end-radius: var(--btn-radius);
    padding-inline-start: var(--font-15);
  }

  .header-search-btn .search-img {
    width: min(9.866666666666667vmin, 3.7rem);
  }

  .menu-member-wrap {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .menu-guide-link {
    display: grid;
    align-items: center;
    height: var(--font-55);
    background-color: var(--color-Main);
    padding-inline: var(--font-20);
  }

  .menu-guide-link:is(.menu-guide-mypage, .menu-guide-member) {
    grid-template-columns: var(--font-30) minmax(0, 1fr);
  }

  .menu-guide-link:is(.menu-guide-logout, .menu-guide-login) {
    grid-template-columns: var(--font-34) minmax(0, 1fr);
    border-inline-start: var(--font-1) solid var(--color-white);
  }

  .menu-guide-link img {
    margin: auto;
  }

  .menu-guide-text {
    color: var(--color-white);
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
  }

  .menu-category-page {
    margin-block: var(--font-20);
  }

  .menu-page-name {
    color: var(--color-Main);
    font-size: 1.9rem;
    font-weight: 700;
    margin-block-end: var(--font-10);
    letter-spacing: 0.03em;
    text-align: center;
  }

  .menu-category-name {
    display: grid;
    align-items: center;
    grid-template-columns: minmax(0, 1fr) var(--font-25);
    column-gap: var(--font-10);
    font-size: 1.4rem;
    padding-block: var(--font-12);
    padding-inline: var(--font-15);
  }

  a:is(.menu-category-name) img {
    width: var(--font-25);
  }

  div:is(.menu-category-name) .--name {
    margin-inline-start: 1em;
  }

  .menu-category-list .menu-category-child-content .list-item:is(.open) div:is(.menu-category-name) .accordion-img .--line:last-child {
    transform: rotate(0deg);
  }

  .menu-category-child-content .list-item:not(:first-child) {
    border-block-start: var(--font-1) solid var(--color-mgray);
  }

  .menu-category-link:not(.menu-category-name) {
    display: grid;
    align-items: center;
    grid-template-columns: minmax(0, 1fr) var(--font-25);
    column-gap: var(--font-10);
    padding-block: var(--font-12);
    padding-inline: var(--font-15);
  }

  .menu-category-link:not(.menu-category-name) .--name {
    font-size: 1.4rem;
  }

  .menu-category-link:not(.menu-category-name) .link-img {
    width: var(--font-6);
  }

  .menu-category-three-content .list-item:is(:first-child) {
    border-block-start: var(--font-1) solid var(--color-mgray);
  }

  .menu-category-three-content .list-item .menu-category-link .--name {
    margin-inline-start: 2em;
  }

  .menu-information-content .list-item {
    border-block-end: var(--font-1) solid var(--color-white);
  }

  .menu-information-content .menu-information-link {
    grid-template-columns: minmax(0, 1fr) var(--font-25);
    column-gap: var(--font-10);
    padding-block: var(--font-12);
    padding-inline: var(--font-15);
  }

  .menu-information-content .menu-information-link .--name {
    font-size: 1.4rem;
  }

  .menu-information-content .menu-information-link .link-img {
    width: var(--font-25);
  }
}

@media screen and (min-width: 769px) {
  .header {
    border-block-start: 0.5rem solid var(--color-Main);
  }

  .obi-wrap {
    height: 5rem;
  }

  .obi-wrap > .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    column-gap: 2.0rem;
  }

  .obi-text {
    font-size: 1.4rem;
    line-height: 5rem;
  }

  .obi-member-wrap {
    display: flex;
    align-items: center;
    column-gap: 1.2rem;
  }

  .obi-member-wrap .obi-guide-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 15rem;
    height: 3.4rem;
    background-color: var(--color-Main);
    border-radius: var(--btn-radius);
  }

  .obi-member-wrap .obi-guide-link:is(.obi-guide-member, .obi-guide-mypage) {
    column-gap: 0.8rem;
  }

  .obi-member-wrap .obi-guide-link:is(.obi-guide-login) {
    column-gap: 0.8rem;
  }

  .obi-member-wrap .obi-guide-link:is(.obi-guide-logout) {
    column-gap: 0.6rem;
  }

  .obi-member-wrap .obi-guide-link img {
    width: 2rem;
  }

  .obi-member-wrap .obi-guide-link .obi-guide-text {
    color: var(--color-white);
    font-size: 1.2rem;
    font-weight: 500;
  }

  .header-wrap {
    height: 8rem;
  }

  .header-wrap > .container {
    grid-template-columns: 35rem minmax(0, 1fr) max-content;
    column-gap: 3.8rem;
  }

  .logo-img {
    width: 35rem;
  }

  .menu-wrap {
    display: grid;
    align-items: center;
    justify-content: end;
    height: 100%;
  }

  .header-page-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 9rem;
    height: 100%;
  }

  .header-category-page {
    display: grid;
    align-items: center;
    height: 100%;
  }

  .header-navi-category .header-navi-name {
    display: flex;
    align-items: center;
    column-gap: 0.8rem;
    cursor: pointer;
  }

  .header-navi-category-wrap {
    position: fixed;
    top: 14rem;
    left: 50%;
    width: 120rem;
    max-height: calc(100vh - 19rem);
    background-color: var(--color-white);
    border: 0.1rem solid var(--color-mgray);
    border-end-start-radius: var(--img-radius-pc);
    border-end-end-radius: var(--img-radius-pc);
    box-shadow: 0 0.2rem 0.2rem  0 var(--color-black10);
    opacity: 0;
    padding-block: 4.0rem;
    padding-inline: 3.8rem;
    pointer-events: none;
    transform: translateX(-50%);
    transition: var(--link-btn-transition);
    z-index: -1;
  }

  .header-navi-category:is(.open) .header-navi-category-wrap {
    opacity: 1;
    pointer-events: inherit;
  }

  .header-navi-category-content {
    max-height: calc(100vh - 27rem);
    overflow-y: auto;
  }

  .header-navi-category-content::-webkit-scrollbar {
    width: 1.0rem;
    background-color: var(--color-scroll-BG);
    border-radius: 0.5rem;
  }

  .header-navi-category-content::-webkit-scrollbar-thumb {
    width: 1.0rem;
    background: var(--color-scroll-drag);
    border-radius: 0.5rem;
  }

  .header-navi-category-list {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 2.4rem;
  }

  .header-navi-category-first-link {
    display: grid;
    grid-template-columns: 0.7rem minmax(0, 1fr);
    column-gap: 0.8rem;
    align-items: center;
  }

  .header-navi-category-first-link .link-img {
    width: 0.7rem;
  }

  .header-navi-category-first-link .--name {
    font-size: 1.4rem;
    font-weight: 500;
  }

  .header-navi-category-child-wrap {
    margin-block-start: 1.8rem;
    margin-inline-start: 1.5rem;
  }

  .header-navi-category-child-content {
    display: grid;
    row-gap: 2rem;
  }

  .header-navi-category-link {
    font-size: 1.4rem;
  }

  .header-navi-link {
    font-size: 1.5rem;
    font-weight: 600;
  }

  .search-content-area {
    width: 32rem;
  }

  .header-search-wrap .search-content-area .header-search-input {
    width: 32rem;
    height: 4.6rem;
    background-color: var(--color-Sub);
    border-radius: var(--btn-radius);
    font-size: 1.4rem;
    padding-inline-start: 2rem;
    padding-inline-end: 8rem;
  }

  .header-search-btn {
    display: grid;
    align-items: center;
    justify-content: center;
    width: 7rem;
    height: 4.6rem;
    border-end-start-radius: var(--btn-radius);
    border-end-end-radius: var(--btn-radius);
  }

  .header-search-btn .search-img {
    width: 2.3rem;
  }

  .header-guide-wrap {
    display: flex;
    align-items: center;
  }

  .header-estimate-link {
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 0.6rem;
    width: 16rem;
    height: 4.6rem;
    background-color: var(--color-Accent);
    border-radius: var(--btn-radius);
    margin-inline-end: 1.6rem;
    padding-inline: 1.0rem;
  }

  .header-estimate-link .estimate-img {
    width: 2.4rem;
  }

  .header-estimate-link .header-estimate-text {
    color: var(--color-white);
    font-size: 1.4rem;
    font-weight: 700;
  }

  .header-guide-link {
    position: relative;
    display: grid;
    grid-template-rows: 3.0rem max-content;
    row-gap: 0.5rem;
    cursor: pointer;
  }

  .header-guide-contact {
    margin-inline-end: 2.5rem;
  }

  .header-guide-link .img-wrap img {
    width: 3rem;
  }

  .header-guide-text {
    font-size: 1.3rem;
    font-weight: 500;
    white-space: nowrap;
  }

  .header-navi-wrap {
    height: 5.5rem;
    box-shadow: 0 0.4rem 0.4rem 0 var(--color-black05);
  }

  .header-navi-wrap > .container {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
  }

  .header-navi-category .header-navi-name {
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 1.5rem;
    border-inline-start: 0.1rem solid var(--color-Main);
    border-inline-end: 0.1rem solid var(--color-Main);
    line-height: 1.8rem;
    padding-inline-start: 3.8rem;
    padding-inline-end: 3.5rem;
  }

  .header-navi-category .header-navi-name .img-wrap img {
    width: 1.2rem;
  }

  .header-navi-category:is(.open) .header-navi-name .img-wrap .menu-img {
    opacity: 0;
    pointer-events: none;
  }

  .header-navi-category:is(.open) .header-navi-name .img-wrap .close-img {
    opacity: 1;
    pointer-events: inherit;
  }

  .header-navi-category .header-navi-name .--name {
    font-size: 1.5rem;
    font-weight: 600;
    transition: var(--link-btn-transition);
  }

  .header-navi-category:is(.open) .header-navi-name .--name {
    color: var(--color-Main);
  }

  .header-navi-link {
    border-inline-end: 0.1rem solid var(--color-Main);
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.8rem;
    padding-inline: 4.9rem;
  }
}

@media screen and (min-width: 769px) and (max-width: 1240px) {
  .header {
    width: var(--pc-page-width);
  }

  .menu-wrap {
    right: 1.0rem;
  }
}

/* -----------------------------------------------------------------
   footer
----------------------------------------------------------------- */
.footer {
}

#page-scroll {
  position: fixed;
  opacity: 0;
  pointer-events: none;
  transition: var(--link-btn-transition);
  z-index: +1;
}

body:is(.__scroll) #page-scroll {
  opacity: 1;
  pointer-events: inherit;
}

.page-scroll-link {
  border-radius: var(--circle-radius);
}

.footer-guide-wrap {
  background-color: var(--color-pgray);
}

.footer-guide-wrap .container {
  display: grid;
  place-content: center;
}

.footer-guide-wrap .logo-link {
  display: inline-block;
  margin-inline: auto;
}

.footer-guide-list .--title .footer-guide-link {
  display: flex;
  align-items: center;
}

.footer-guide-list .--title .--text {
  font-weight: 500;
}

.footer-search-btn {
  display: grid;
  align-items: center;
  justify-content: center;
  background-color: var(--color-Main);
  border-radius: var(--btn-radius);
}

.footer-search-btn .--text {
    color: var(--color-white);
    font-weight: 700;
}

.footer-estimate-link {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-Accent);
  border-radius: var(--btn-radius);
}

.footer-estimate-link .footer-estimate-text {
  color: var(--color-white);
  font-weight: 700;
}

.footer-contact-wrap {
  display: grid;
}

.footer-contact-wrap .--item {
  background-color: var(--color-white);
}

.footer-contact-wrap .--item .--name {
  display: grid;
  place-items: center;
  background-color: var(--color-Main);
  color: var(--color-white);
  font-weight: 700;
}

.footer-contact-wrap .--item .--content {
  display: grid;
  place-items: center;
}

.footer-contact-wrap .--item .--area {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.footer-contact-wrap .--item .--area .--list:last-child {
  grid-column: 1 / 3;
}

.footer-contact-wrap .--item .--area .--prefecture {
  font-weight: 500;
}

.footer-contact-wrap .--item .--area .--district {
  word-break: break-all;
}

.footer-contact-wrap .--item .--telephonenumber {
  display: flex;
  align-items: center;
}

.footer-contact-wrap .--item .--telephonenumber .--num {
  color: var(--color-Main);
  font-weight: 700;
}

.footer-contact-wrap .--item .--businesshours {
  display: grid;
}

.footer-contact-wrap .--item .--businesshours .--day {
  display: grid;
  place-items: center;
  height: max-content;
  color: #E83E0B;
  font-weight: 700;
}

.footer-nav-wrap {
  background-color: var(--color-Main);
}

.footer-nav-wrap .container {
  display: flex;
}

.footer-nav-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.footer-nav-link {
  color: var(--color-white);
}

.copyright {
  display: inline-block;
  color: var(--color-white);
  font-weight: 500;
  letter-spacing: 0.05em;
}

@media screen and (max-width: 768px) {
  .footer {
  }

  #page-scroll {
    bottom: var(--font-5);
    right: var(--font-5);
  }

  .page-scroll-link {
    width: var(--font-40);
    height: var(--font-40);
  }

  .page-scroll-link .scroll-img {
    width: var(--font-40);
    height: var(--font-40);
  }

  .footer-guide-wrap .logo-link .logo-img {
    width: max(69.33333333333334vmin, 26rem);
  }

  .footer-guide-wrap {
    padding-block-start: var(--font-30);
    padding-block-end: var(--font-25);
    padding-inline: var(--font-15);
  }

  .footer-guide-list {
    display: grid;
    row-gap: var(--font-25);
    margin-block-start: var(--font-30);
  }

  .footer-guide-list .--item:not(:has(.footer-estimate-link)) {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-guide-list .--item:has(.--content) {
    row-gap: var(--font-8);
  }

  .footer-guide-list .--item:not(:has(.--content, .footer-estimate-link)) {
    row-gap: var(--font-15);
  }

  .footer-guide-list .--item:has(.--content) .--title {
    grid-column: 1 / 3;
  }

  .footer-guide-list .--item .--content:nth-of-type(2) {
    margin-inline-start: max(8.266666666666666vmin, 3.1rem);
  }

  .footer-guide-list .--title .footer-guide-link {
    column-gap: var(--font-10);
  }

  .footer-guide-list .--title .--text {
    font-size: 1.3rem;
  }

  .footer-guide-list .--content {
    display: grid;
    row-gap: var(--font-10);
  }

  .footer-guide-list .--content .footer-guide-link {
    font-size: 1.3rem;
  }

  .footer-estimate-title {
    width: max(80vmin, 30rem);
    font-size: 1.4rem;
    font-weight: 500;
    margin-block-end: var(--font-10);
    margin-inline: auto;
  }

  .footer-search-btn {
    grid-template-columns: max(6.4vmin, 2.4rem) max-content;
    column-gap: var(--font-5);
    width: max(80vmin, 30rem);
    height: var(--font-45);
    background-position: center right var(--font-11);
    background-size: var(--font-25) auto;
    font-size: 1.5rem;
    margin-block-end: var(--font-10);
    margin-inline: auto;
  }

  .footer-search-btn img {
    width: max(6.4vmin, 2.4rem);
  }

  .footer-search-btn .--text {
    font-size: 1.3rem;
  }

  .footer-estimate-link {
    justify-content: center;
    width: max(80vmin, 30rem);
    height: var(--font-45);
    margin-inline: auto;
    padding-inline-start: var(--font-35);
    padding-inline-end: var(--font-11);
  }

  .footer-estimate-link .estimate-img {
    width: var(--font-28);
  }

  .footer-estimate-link .footer-estimate-text {
    font-size: 1.5rem;
    margin-inline-start: var(--font-10);
    margin-inline-end: var(--font-14);
  }

  .footer-estimate-link .link-img {
    width: var(--font-25);
  }

  .footer-contact-wrap {
    row-gap: var(--font-15);
    margin-block-start: var(--font-25);
  }

  .footer-contact-wrap .--item {
    width: calc(100vw - var(--font-30));
    border-radius: var(--img-radius-sp);
    box-shadow: 0 var(--font-2) var(--font-2) 0 var(--color-black05);
  }

  .footer-contact-wrap .--item .--name {
    border-start-start-radius: var(--img-radius-sp);
    border-start-end-radius: var(--img-radius-sp);
    font-size: 1.4rem;
    padding-block: var(--font-11);
  }

  .footer-contact-wrap .--item .--content {
    row-gap: var(--font-10);
    padding-block: var(--font-15);
    padding-inline: var(--font-28);
  }

  .footer-contact-wrap .--item .--area {
    grid-template-columns: max-content max-content;
    column-gap: var(--font-33);
    row-gap: var(--font-12);
    width: 100%;
  }

  .footer-contact-wrap .--item .--area .--list {
    display: flex;
    flex-flow: column;
    row-gap: var(--font-3);
  }

  .footer-contact-wrap .--item .--area .--prefecture {
    font-size: 1.2rem;
  }

  .footer-contact-wrap .--item .--area .--district {
    font-size: 1.1rem;
  }

  .footer-contact-wrap .--item .--telephonenumber {
    column-gap: var(--font-8);
  }

  .footer-contact-wrap .--item .--telephonenumber .tell-img {
    width: var(--font-20);
  }

  .footer-contact-wrap .--item .--telephonenumber .--num {
    font-size: 2rem;
  }

  .footer-contact-wrap .--item .--businesshours {
    grid-template-columns: max-content minmax(0, 1fr);
    column-gap: var(--font-8);
  }

  .footer-contact-wrap .--item .--businesshours .--day {
    width: max(15.466666666666667vmin, 5.8rem);
    border: var(--font-1) solid #E83E0B;
    font-size: 1.2rem;
    line-height: 1.75;
  }

  .footer-contact-wrap .--item .--businesshours .--hours .--text {
    font-size: 1.1rem;
    line-height: 2;
  }

  .footer-contact-wrap .--item .--businesshours .--hours .--note {
    font-size: 1.0rem;
    line-height: 2;
  }

  .footer-nav-wrap {
    padding-block-start: var(--font-15);
    padding-block-end: var(--font-11);
  }

  .footer-nav-wrap .container {
    flex-flow: column;
    row-gap: var(--font-11);
    width: calc(100vw - var(--font-30));
    margin-inline: auto;
  }

  .footer-nav-list {
    justify-content: center;
    gap: var(--font-25);
  }

  .footer-nav-link {
    font-size: 1.0rem;
  }

  .copyright {
    font-size: 1.0rem;
    font-weight: 500;
    text-align: center;
  }
}

@media screen and (min-width: 769px) {
  .footer {
  }

  #page-scroll {
    bottom: 1rem;
    right: 1rem;
  }

  .page-scroll-link {
    width: 4rem;
    height: 4rem;
  }

  .footer .footer-guide-wrap .container {
    row-gap: 5rem;
    padding-block: 4rem;
  }

  .footer-guide-list {
    display: flex;
    margin-inline: auto;
  }

  .footer-guide-list .--item {
    display: flex;
    flex-flow: column;
    row-gap: 1.3rem;
  }

  .footer-guide-list .--item:first-child {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    justify-content: space-between;
    column-gap: 7rem;
    row-gap: 1.3rem;
    margin-inline-end: 8rem;
  }

  .footer-guide-list .--item:first-child .--title {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .footer-guide-list .--item:first-child .--content {
    grid-row: 2;
  }

  .footer-guide-list .--item:first-child .--content:first-child {
    grid-column: 1;
  }

  .footer-guide-list .--item:first-child .--content:last-child {
    grid-column: 2;
    margin-inline-start: 0;
  }

  .footer-guide-list .--item:not(:first-child, :has(.footer-estimate-link)) {
    margin-inline-end: 9rem;
  }

  .footer-guide-list .--item:not(:has(.--content)) {
    row-gap: 1.5rem;
  }

  .footer-guide-list .--title .footer-guide-link {
    column-gap: 0.5rem;
  }

  .footer-guide-list .--title .footer-guide-link img {
    width: 2rem;
  }

  .footer-guide-list .--title .--text {
    font-size: 1.4rem;
  }

  .footer-guide-list .--content {
    display: flex;
    flex-direction: column;
    row-gap: 2.4rem;
    margin-inline-start: 2.7rem;
  }

  .footer-guide-list .--content .footer-guide-link {
    font-size: 1.4rem;
  }

  .footer-estimate-title {
    font-size: 1.4rem;
    font-weight: 500;
  }

  .footer-search-btn {
    grid-template-columns: 2.4rem max-content;
    column-gap: 0.5rem;
    width: 100%;
    height: 4.6rem;
  }

  .footer-search-btn img {
    width: 2.4rem;
  }

  .footer-search-btn .--text {
    font-size: 1.4rem;
  }

  .footer-estimate-link {
    width: 25rem;
    height: 4.6rem;
    column-gap: 0.5rem;
  }

  .footer-estimate-link .estimate-img {
    width: 2.4rem;
  }

  .footer-estimate-link .footer-estimate-text {
    font-size: 1.4rem;
  }

  .footer-contact-wrap {
    grid-template-columns: repeat(2, 52rem);
    column-gap: 8rem;
  }

  .footer-contact-wrap .--item {
    border-radius: var(--img-radius-pc);
    box-shadow: 0 0.4rem 0.4rem 0 var(--color-black05);
  }

  .footer-contact-wrap .--item .--name {
    border-start-start-radius: var(--img-radius-pc);
    border-start-end-radius: var(--img-radius-pc);
    font-size: 1.8rem;
    padding-block: 1.3rem;
  }

  .footer-contact-wrap .--item .--content {
    padding-block-start: 1.1rem;
    padding-block-end: 2.3rem;
  }

  .footer-contact-wrap .--item .--area {
    column-gap: 3.3rem;
    row-gap: 1.0rem;
  }

  .footer-contact-wrap .--item .--area .--prefecture {
    font-size: 1.4rem;
    line-height: 3.4rem;
  }

  .footer-contact-wrap .--item .--area .--district {
    font-size: 1.2rem;
  }

  .footer-contact-wrap .--item .--tell {
    margin-block-start: 1.0rem;
  }

  .footer-contact-wrap .--item .--telephonenumber {
    column-gap: 0.7rem;
    pointer-events: none;
  }

  .footer-contact-wrap .--item .--telephonenumber .tell-img {
    width: 3rem;
  }

  .footer-contact-wrap .--item .--telephonenumber .--num {
    font-size: 2.8rem;
  }

  .footer-contact-wrap .--item .--businesshours {
    grid-template-columns: 6.8rem minmax(0, 1fr);
    column-gap: 1.3rem;
    margin-block-start: 1.1rem;
  }

  .footer-contact-wrap .--item .--businesshours .--day {
    border: 0.1rem solid #E83E0B;
    font-size: 1.2rem;
    line-height: 2;
  }
  .footer-contact-wrap .--item .--businesshours .--hours {}

  .footer-contact-wrap .--item .--businesshours .--hours .--text {
    font-size: 1.4rem;
    line-height: 1.75;
  }

  .footer-contact-wrap .--item .--businesshours .--hours .--note {
    font-size: 1.2rem;
    line-height: 2;
  }

  .footer-nav-wrap {
    padding-block-start: 2.6rem;
    padding-block-end: 2.7rem;
  }

  .footer-nav-wrap .container {
    align-items: center;
    justify-content: center;
    column-gap: 5rem;
  }

  .footer-nav-list {
    column-gap: 5rem;
  }

  .footer-nav-link {
    font-size: 1.4rem;
  }

  .copyright {
    font-size: 1.4rem;
  }
}

@media screen and (min-width: 769px) and (max-width: 1240px) {
  .footer {
    width: var(--pc-page-width);
  }
}

/* -----------------------------------------------------------------
   contents area
----------------------------------------------------------------- */
.contents {
  display: block;
}

.breadcrumb {
  margin-inline: auto;
  white-space: normal;
  word-break: break-all;
}

.breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  content: ">";
}

.breadcrumb .breadcrumb-item:is(.current) a {
  pointer-events: none;
}

.breadcrumb a, .breadcrumb-item.current {
}

.container {
  margin-inline: auto;
}

.contents .heading {
  color: var(--color-Main);
  font-weight: 800;
  text-align: center;
  white-space: normal;
  word-break: break-all;
}

.more-btn {
  display: grid;
  place-items: center;
  background: var(--color-Main) url(https://gigaplus.makeshop.jp/tgsec/img/common/circle_link_wt.svg) no-repeat;
  border-radius: var(--btn-radius);
  color: var(--color-white);
  font-weight: 700;
  margin-inline: auto;
  text-align: center;
}

.item-quantity {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.item-quantity .item-qty__label {
  font-weight: 500;
}

.item-quantity .quantity {
  display: grid;
  background-color: var(--color-white);
  border-radius: var(--btn-radius);
}

.item-quantity .quantity .quantity__button {
  display: grid;
  place-items: center;
}

.item-quantity .quantity .quantity__input {
  border: none;
  font-weight: 700;
  text-align: center;
}
.title {
	text-align: center;
	background-color: var(--color-Main);
	color: white;
	margin: 15px 0 7px 0;
	border-radius: 12px;
	font-size: 16px;
	padding: 8px;
}

@media screen and (max-width: 768px) {
  .contents {
    padding-block-start: max(24vmin, 9rem);
  }

  .breadcrumb {
    width: calc(100vw - var(--font-30));
    font-size: 1.2rem;
    padding-block-start: var(--font-10);
    margin-block-end: var(--font-25);
  }

  .breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    margin-inline: min(0.5rem, 1.3333333333333335vmin);
  }

  .contents .heading {
    max-width: calc(100vw - var(--font-30));
    font-size: 2.1rem;
    margin-block-end: var(--font-35);
    margin-inline: auto;
  }

  .contents .heading:has(.heading-img) {
    margin-block-end: var(--font-30);
  }

  .heading-img {
    width: min(7.6rem, 20.266666666666666vmin);
  }

  .more-btn {
    width: max(80vmin, 30rem);
    height: var(--font-45);
    background-position: center right var(--font-11);
    background-size: var(--font-25) auto;
    font-size: 1.5rem;
  }

  .item-quantity {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }

  .item-quantity:has(.item-qty__label) {
    column-gap: var(--font-20);
  }

  .item-quantity .item-qty__label {
    font-size: 1.4rem;
  }
  
  .item-quantity .quantity {
    grid-template-columns: min(3.4rem, 9.066666666666666vmin) minmax(0, 1fr) min(3.4rem, 9.066666666666666vmin);
    width: min(10rem, 26.666666666666668vmin);
    height: var(--font-40);
    border: var(--font-1) solid var(--color-Sub);
  }
    
  .item-quantity .quantity .quantity__button {
    width: min(3.4rem, 9.066666666666666vmin);
    height: 100%;
  }

  .item-quantity .quantity .quantity__button:is(.down) {
    border-start-start-radius: var(--font-40);
    border-start-end-radius: var(--font-40);
  }

  .item-quantity .quantity .quantity__button:is(.up) {
    border-end-start-radius: var(--font-40);
    border-end-end-radius: var(--font-40);
  }

  .item-quantity .quantity .quantity__button img {
    width: var(--font-10);
  }

  .item-quantity .quantity .quantity__input {
    width: 100%;
    padding: var(--font-5);
  }
}

@media screen and (min-width: 769px) {
  div[class*="-wrap"] .container {
    max-width: 120rem;
    overflow: hidden;
  }

  .contents {
    margin-block-start: 19.0rem;
  }

  .main {
  }

  .breadcrumb {
    font-size: 1.4rem;
    padding-block-start: 2.0rem;
    margin-block-end: 5.0rem;
  }

  .breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    margin-inline: 0.5rem;
  }

  .contents .heading {
    font-size: 3rem;
    margin-block-end: 6.0rem;
  }

  .contents .heading:has(.heading-img) {
    margin-block-end: 4.0rem;
  }

  .heading-img {
    width: 8rem;
  }

  .more-btn {
    width: 40rem;
    height: 7rem;
    background-position: center right 2rem;
    background-size: 3rem auto;
    font-size: 1.8rem;
  }

  .item-quantity {
    column-gap: 2.0rem;
  }
  
  .item-quantity .item-qty__label {
    font-size: 1.6rem;
  }
  
  .item-quantity .quantity {
    grid-template-columns: 3.4rem minmax(0, 1fr) 3.4rem;
    width: 11rem;
    height: 4rem;
    border: 0.1rem solid var(--color-Sub);
    border-radius: 10.0rem;
  }
  
  .item-quantity .quantity .quantity__button {
    width: 3.4rem;
    height: 100%;
  }

  .item-quantity .quantity .quantity__button:is(.down) {
    border-start-start-radius: 2rem;
    border-start-end-radius: 2rem;
  }

  .item-quantity .quantity .quantity__button:is(.up) {
    border-end-start-radius: 2rem;
    border-end-end-radius: 2rem;
  }

  .item-quantity .quantity .quantity__button img {
    width: 1rem;
  }
  
  .item-quantity .quantity .quantity__input {
    width: 100%;
    padding: 0.5rem;
  }
  
}

@media screen and (min-width: 769px) and (max-width: 1240px) {
  .contents {
    width: var(--pc-page-width);
  }

  div[class*="-wrap"] .container {
    max-width: calc(100% - 2rem);
  }
}

/* -----------------------------------------------------------------
   list
----------------------------------------------------------------- */
.slider {
  opacity: 0;
  transition: var(--link-btn-transition);
}

.slider:is(.slick-initialized) {
  opacity: 1;
}

.item-list .list-item {
  position: relative;
  display: flex;
  flex-flow: column;
  height: auto;
  background-color: var(--color-white);
}

.item-list .list-item .item-num {
  position: absolute;
  display: grid;
  align-items: center;
  justify-content: center;
  background-color: var(--color-Main);
  border-radius: var(--circle-radius);
  z-index: +1;
}

.item-list .list-item .item-num:is(.rank1) {
  background-color: #D7B119;
}

.item-list .list-item .item-num:is(.rank2) {
  background-color: #959595;
}

.item-list .list-item .item-num:is(.rank3) {
  background-color: #B7752F;
}

.item-list .list-item .item-num .--num {
  color: var(--color-white);
  font-family: var(--font-Roboto);
  font-weight: 500;
}

.item-list-image {
  aspect-ratio: 1;
  overflow: hidden;
}

.item-list-image img {
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: contain;
}

.item-list .list-item .item-icon {
  display: flex;
  flex-wrap: wrap;
}

.item-list .list-item .soldout {
  font-weight: 700;
}

.item-list .list-item .item-name {
  font-weight: 400;
}

.item-list .list-item .item-original_code {}

.sale-price-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.item-list .list-item .price-wrap:is(.sale-price-wrap) {
  color: var(--color-red);
}

.item-list .list-item .sale-off {
  display: inline-block;
  font-weight: 700;
}

.item-list .list-item .price {
  color: var(--color-red);
  font-weight: 700;
  text-align: right;
}

.original_price {
  font-weight: 700;
  text-align: right;
}

.strikethrough {
  position: relative;
}

.strikethrough::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: block;
  width: 100%;
  background-color: var(--color-text);
}

.item-list:is(.swiper-initialized) {
}

.swiper:is(.swiper-initialized) div:is(.swiper-button-prev, .swiper-button-next) {
  display: block;
}

.swiper:has(.swiper-scrollbar-lock) div:is(.swiper-button-prev, .swiper-button-next) {
  display: none;
}

.swiper:is(.swiper-initialized) .swiper-button-prev {
  left: 0;
}

.swiper:is(.swiper-initialized) .swiper-button-next {
  right: 0;
}

.blog-list-item {
  height: auto;
  background-color: var(--color-white);
}

.blog-list-item .item-date {
  font-weight: 600;
}

.blog-list-item .item-tag {
  display: flex;
  flex-wrap: wrap;
}

.blog-list-item .item-tag .list-tag-link {
  display: grid;
  place-items: center;
  border-radius: var(--btn-radius);
  color: var(--color-Main);
  font-weight: 700;
}

div[class*="item-list"] .swiper-button-next:after, div[class*="item-list"]  .swiper-button-prev:after {
  content: none;
}

div[class$="sort-wrap"] {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.sort-wrap {
  justify-content: space-between;
}

.list-total {
}

div[class$="sort-wrap"] .list-total .--num {
  font-weight: 500;
}

div[class$="sort-wrap"] p[class$="sort-text"] {
  font-weight: 500;
}

.sort-list {
  display: flex;
  flex-wrap: wrap;
}

.sort-link {
  font-weight: 400;
}

.sort-link:is(a) {
  text-decoration: underline;
}

.pager {
  display: flex;
  align-items: center;
  justify-content: center;
}

.pager-item .pager-link {
  display: grid;
  place-items: center;
  color: var(--color-Main);
  border-radius: var(--circle-radius);
}

.pager-item .pager-link img {
  grid-column: 1;
  grid-row: 1;
  transition: var(--link-btn-transition);
}

.pager-item .pager-link .on-img {
  opacity: 0;
}

.pager-item:not(.pager-prev, .pager-next) .pager-link {
  border-radius: 50%;
  font-family: var(--font-Roboto);
  font-weight: 500;
  transition: var(--link-btn-transition);
}

.pager-item:has(.current) .pager-btn {
  display: grid;
  place-items: center;
  border-radius: 50%;
  background-color: var(--color-Main);
  color: var(--color-white);
  font-family: var(--font-Roboto);
  font-weight: 500;
}

.empty {
  text-align: center;
}

.empty-link {
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .item-list:is(.swiper-initialized) {
    padding-inline: var(--font-15);
  }

  .item-list:is(.category-item-list, .search-item-list) {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: var(--font-12);
    row-gap: var(--font-24);
    width: calc(100vw - var(--font-30));
    margin-inline: auto;
  }

  .item-list:is(.swiper-initialized) .swiper-wrapper {
  }

  .item-list .list-item {
    border: var(--font-1) solid var(--color-mgray);
    border-radius: var(--img-radius-sp);
    box-shadow: 0 var(--font-2) var(--font-2) 0 var(--color-black05);
    margin-block-end: var(--font-2);
    padding-block: var(--font-20);
    padding-inline: var(--font-12);
  }

  .item-list:has(.swiper-scrollbar) .list-item {
  }

  .item-list:has(.swiper-scrollbar) .list-item:not(:last-child) {
    margin-inline-end: var(--font-12);
  }

  .item-list:has(.swiper-scrollbar) .list-item:last-child {
  }

  .item-list .list-item:has(.item-num) {
    margin-block-start: var(--font-13);
  }

  .item-list .list-item .item-num {
    top: max(-3.4666666666666663vmin, -1.3rem);
    left: var(--font-13);
    width: var(--font-30);
    height: var(--font-30);
    border: var(--font-1) solid var(--color-white);
  }

  .item-list .list-item .item-num .--num {
    font-size: var(--font-14);
  }

  .item-list .list-item .item-icon {
    gap: var(--font-4);
    margin-block-start: var(--font-7);
  }

  .item-list .list-item .item-icon img {
    width: auto;
    height: var(--font-19);
  }

  .item-list .list-item .item-name {
    font-size: 1.4rem;
    margin-block-start: var(--font-8);
  }

  .item-list .list-item .item-original_code {
    font-size: 1.1rem;
    margin-block-start: var(--font-8);
  }

  .item-list .list-item .price-wrap {
    margin-block-start: var(--font-8);
  }

  .item-list .list-item .price-wrap:is(.sale-price-wrap) {
    gap: var(--font-4);
  }

  .item-list .list-item .price {
    font-size: 1.6rem;
  }

  .item-list .list-item .price .--yen {
    font-size: 1.1rem;
  }

  .item-list .list-item .price .--tax {
    font-size: 1.0rem;
  }
 
  .item-list .list-item .sale-off {
    border: var(--font-1) solid var(--color-red);
    font-size: 1.0rem;
    padding-inline: var(--font-6);
  }

  .item-list .list-item .sale-off .--num {
    font-size: 1.4rem;
  }

  .original_price {
    font-size: 1.1rem;
    margin-block-start: var(--font-8);
  }

  .original_price .--yen {
    font-size: 1.0rem;
  }

  .original_price .--tax {
    font-size: 1.0rem;
  }

  .strikethrough::after {
    height: var(--font-1);
  }

  .item-list:is(.swiper-initialized) .swiper-button-prev, .item-list:is(.swiper-initialized) .swiper-button-next {
    width: var(--font-30);
    height: var(--font-30);
  }

  .item-list .list-item .soldout {
    font-size: 1.3rem;
    margin-block-start: var(--font-7);
  }

  .swiper-initialized:is(.ranking-item-list, .group-item-list, .checked-item-list) .swiper-button-prev, .swiper-initialized:is(.ranking-item-list, .group-item-list, .checked-item-list) .swiper-button-next {
    display: none !important;
  }

  .item-list:is(.swiper-horizontal)>.swiper-scrollbar {
    position: relative;
    left: 0;
    bottom: 0;
    width: calc(100vw - var(--font-30));
    height: var(--font-10);
    background-color: var(--color-scroll-BG);
    border-radius: 0;
    margin-block-start: var(--font-30);
  }

  .item-list:is(.swiper-horizontal)>.swiper-scrollbar .swiper-scrollbar-drag {
    background-color: var(--color-scroll-drag);
    border-radius: var(--font-30);
  }

  .blog-list-item {
    border: var(--font-1) solid var(--color-mgray);
    border-radius: var(--img-radius-pc);
    box-shadow: 0 var(--font-2) var(--font-2) var(--color-black05);
    margin-block-end: var(--font-2);
    padding-block: var(--font-15);
    padding-inline: var(--font-12);
  }

  .blog-list-item .item-date {
    font-size: 1.4rem;
    margin-block-start: var(--font-8);
  }

  .blog-list-item .item-name {
    font-size: 1.2rem;
    margin-block-start: var(--font-8);
  }

  .blog-list-item .item-tag {
    gap: var(--font-5);
    margin-block-start: var(--font-8);
  }
  
  .blog-list-item .item-tag .list-tag-link {
    border: var(--font-1) solid var(--color-Main);
    font-size: 1.0rem;
    padding-block: var(--font-3);
    padding-inline: var(--font-7);
  }

  .sort-wrap {
    column-gap: var(--font-10);
    row-gap: var(--font-10);
    width: calc(100vw - var(--font-30));
    border-block-end: var(--font-1) solid var(--color-Main);
    margin-block-start: var(--font-40);
    margin-block-end: var(--font-15);
    margin-inline: auto;
    padding-block-end: var(--font-8);
  }

  .list-total {
    font-size: 1.3rem;
  }

  .sort-select select {
    width: min(12rem, 32vmin);
    background-position: center right var(--font-4);
    background-size: var(--font-10) auto;
    padding-inline-end: var(--font-30);
  }

  div[class$="sort-wrap"] {
    column-gap: var(--font-10);
  }

  div[class$="sort-wrap"] p[class$="sort-text"] {
    font-size: 1.2rem;
  }

  div[class$="sort-wrap"] .list-total .--num {
    font-size: 1.6rem;
    margin-inline: var(--font-2);
  }

  .sort-list {
    column-gap: var(--font-10);
    row-gap: var(--font-10);
  }

  .sort-link {
    font-size: 1.2rem;
  }

  .sort-select {}

  .pager-wrap {
    margin-block-start: var(--font-30);
    padding-block-end: var(--font-50);
  }

  .pager {
    column-gap: var(--font-15);
  }

  .pager-link {
    display: grid;
    place-items: center;
  }

  .pager-item .pager-link {
    display: grid;
    place-items: center;
    width: 8vw;
    aspect-ratio: 1;
    border: var(--font-1) solid var(--color-Main);
    font-size: var(--font-12);
  }
  
  .pager-item:is(.pager-prev, .pager-next) .pager-link {
  }

  .pager-item:is(.pager-prev, .pager-next) .pager-link img {
    width: var(--font-6);
  }

  .pager-item:has(.current) .pager-btn {
    display: grid;
    place-items: center;
    width: 8vw;
    aspect-ratio: 1;
    font-size: var(--font-12);
  }

  .empty_wrap {
    display: grid;
    place-items: center;
    row-gap: var(--font-20);
    width: calc(100vw - var(--font-30));
    margin-block-start: var(--font-32);
    margin-inline: auto;
    padding-block: var(--font-50);
  }

  .empty, .empty-link {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 769px) {
    .item-list:is(.category-item-list, .search-item-list) {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      column-gap: 2.6rem;
      row-gap: 4rem;
      margin-inline: auto;
    }

    .item-list .list-item {
      border: 0.1rem solid var(--color-mgray);
      border-radius: var(--img-radius-pc);
      box-shadow: 0 0.4rem 0.4rem 0 var(--color-black05);
      margin-block-end: 0.4rem;
      padding-block: 4rem;
      padding-inline: 2.5rem;
    }

    .item-list .list-item:has(.item-num) {
      margin-block-start: 2.7rem;
    }

    .item-list .list-item .item-num {
      top: -2.7rem;
      left: 2.4rem;
      width: 5rem;
      height: 5rem;
      border: 0.1rem solid var(--color-white);
    }

    .item-list .list-item .item-num .--num {
      font-size: 2.4rem;
    }
   
    .item-list .list-item .soldout {
      font-size: 1.4rem;
      margin-block-start: 1.2rem;
    }

    .item-list .list-item .item-icon {
      gap: 0.8rem;
      margin-block-start: 1.5rem;
    }

    .item-list .list-item .item-icon img {
      width: auto;
      height: 2.6rem;
    }
  
    .item-list .list-item .item-name {
      font-size: 1.6rem;
      margin-block-start: 1.5rem;
    }

    .item-list .list-item .item-original_code {
      font-size: 1.6rem;
      margin-block-start: 1.5rem;
    }

    .item-list .list-item .price-wrap {
      margin-block-start: 1.5rem;
    }

    .item-list .list-item .price-wrap:is(.sale-price-wrap) {
      gap: 0.8rem;
    }

    .item-list .list-item .sale-off {
      border: 0.1rem solid var(--color-red);
      font-size: 1.2rem;
      padding-inline: 1.1rem;
    }

    .item-list .list-item .sale-off .--num {
      font-size: 1.8rem;
    }

    .item-list .list-item .price {
      font-size: 2.2rem;
    }

    .item-list .list-item .price .--yen {
      font-size: 1.6rem;
    }

    .item-list .list-item .price .--tax {
      font-size: 1.2rem;
    }
 
    .original_price {
      font-size: 1.8rem;
      margin-block-start: 1.5rem;
    }
 
    .original_price .--yen {
      font-size: 1.4rem;
    }
 
    .original_price .--tax {
      font-size: 1.0rem;
    }

    .strikethrough::after {
      height: 0.1rem;
    }

    .swiper:is(.swiper-initialized) {
      padding-inline: 1.9rem;
    }

    .swiper:is(.swiper-initialized) .swiper-button-prev, .swiper:is(.swiper-initialized) .swiper-button-next {
      top: 50%;
      transform: translateY(-50%);
      width: 4rem;
      height: 4rem;
      margin: 0;
    }
  
    .swiper-scrollbar {
    }

    .swiper-horizontal>.swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
      display: none;
    }

    .swiper:is(.bk-sub, .bk-white)::before, .swiper:is(.bk-sub, .bk-white)::after {
      content: "";
      position: absolute;
      top: 0;
      display: block;
      width: 1.9rem;
      height: 100%;
      z-index: 2;
    }

    .swiper:is(.bk-sub)::before, .swiper:is(.bk-sub)::after {
      background-color: var(--color-Sub);
    }

    .swiper:is(.bk-white)::before, .swiper:is(.bk-white)::after {
      background-color: var(--color-white);
    }

    .swiper:is(.bk-sub, .bk-white)::before {
      left: 0;
    }

    .swiper:is(.bk-sub, .bk-white)::after {
      right: 0;
    }

    .blog-list-item {
      border: 0.1rem solid var(--color-mgray);
      border-radius: var(--img-radius-pc);
      box-shadow: 0 0.4rem 0.4rem var(--color-black05);
      margin-block-end: 0.4rem;
      padding-block: 2rem;
      padding-inline: 2rem;
    }

    .blog-list-item .item-date {
      font-size: 1.8rem;
      margin-block-start: 2rem;
    }

    .blog-list-item .item-name {
      font-size: 1.6rem;
      margin-block-start: 2rem;
      line-height: 2;
    }
  
    .blog-list-item .item-tag {
      gap: 0.5rem;
      margin-block-start: 2rem;
    }
    
    .blog-list-item .item-tag .list-tag-link {
      border: 0.1rem solid var(--color-Main);
      font-size: 1.4rem;
      padding-block: 0.5rem;
      padding-inline: 1.5rem;
    }
    
    .sort-wrap {
      border-block-end: 0.1rem solid var(--color-Main);
      margin-block-start: 8.0rem;
      margin-block-end: 3rem;
      padding-block-end: 1.4rem;
    }

  .list-total {
    font-size: 1.4rem;
  }

  .sort-select select {
    width: 20rem;
    background-position: center right 1rem;
    background-size: 1.2rem auto;
    font-size: 1.4rem;
    padding-block: 1rem;
    padding-inline-end: 3rem;
  }

  .sort-wrap div[class$="sort-wrap"] {
    column-gap: 4.0rem;
  }

  div[class$="sort-wrap"] p[class$="sort-text"] {
    font-size: 1.4rem;
  }

  div[class$="sort-wrap"] .list-total .--num {
    font-size: 1.8rem;
    margin-inline: 0.2rem;
  }

  .sort-list {
    column-gap: 4.0rem;
  }

  .sort-link {
    font-size: 1.4rem;
  }

  .pager-wrap {
    margin-block-start: 8.0rem;
    padding-block-end: 10.0rem;
  }

  .pager {
    column-gap: 2.5rem;
  }

  .pager-btn {
  }

  .pager-link {
    transition: var(--link-btn-transition);
  }

  .pager-item .pager-link {
    width: 3.5rem;
    height: 3.5rem;
    border: 0.1rem solid var(--color-Main);
    font-size: 1.6rem;
  }

  .pager-item:has(.current) .pager-btn {
    width: 3.5rem;
    height: 3.5rem;
    border: 0.1rem solid var(--color-Main);
    font-size: 1.6rem;
  }

  .pager-item:is(.pager-prev, .pager-next) .pager-link {
  }

  .pager-item:is(.pager-prev, .pager-next) .pager-link:hover {
  }

  .pager-item:is(.pager-prev, .pager-next) .pager-link img {
    width: 0.8rem;
  }

  .empty_wrap {
    display: grid;
    place-items: center;
    row-gap: 2rem;
    margin-block-start: 4rem;
    padding-block: 8.0rem;
  }

  .empty, .empty-link {
    font-size: 1.6rem;
  }
}


/* -----------------------------------------------------------------
   news
----------------------------------------------------------------- */
.news-list {
  display: grid;
}

.news-item:not(:last-child) {
}

.news-item {
  display: grid;
}

.news-link {
  display: grid;
  color: var(--color-text);
}

.news-date {
  font-weight: 600;
}

.news-title {
  font-weight: 400;
}

@media screen and (max-width: 768px) {
  .news-list {
    row-gap: var(--font-10);
    max-width: calc(100vw - var(--font-30));
    border: var(--font-1) solid var(--color-mgray);
    border-radius: var(--font-8);
    box-shadow: 0 var(--font-2) var(--font-2) var(--color-black05);
    margin-inline: auto;
    padding-block-start: var(--font-25);
    padding-block-end: var(--font-35);
    padding-inline: var(--font-22);
  }

  .news-item {
    border-block-end: var(--font-1) solid var(--color-mgray);
  }

  .news-item .news-link {
    row-gap: var(--font-10);
    padding-block-end: var(--font-10);
    font-size: 1.3rem;
  }
}

@media screen and (min-width: 769px) {
  .news-list {
    row-gap: 1rem;
    border: 0.2rem solid var(--color-mgray);
    border-radius: 1.5rem;
    box-shadow: 0 0.4rem 0.4rem var(--color-black05);
    padding-block: 5rem;
    padding-inline: 7.8rem;
  }

  .news-item {
    border-block-end: 0.1rem solid var(--color-mgray);
  }

  .news-item .news-link {
    grid-template-columns: 8em minmax(0, 1fr);
    column-gap: 5.0rem;
    padding-block-start: 1.0rem;
    padding-block-end: 2.0rem;
    font-size: 1.8rem;
  }
}


/* -----------------------------------------------------------------
  XXX
----------------------------------------------------------------- */
div[class$="-concept"] {
  margin-inline: auto;
}

div[class$="-concept"] dl[class$="-section"] {
  display: grid;
  margin-inline: auto;
}

div[class$="-concept"] dl[class$="-section"] dd pre {
  font-family: inherit;
}

@media screen and (max-width: 768px) {
  div[class$="-concept"] {
    row-gap: var(--font-10);
    max-width: calc(100vw - var(--font-30));
    border: var(--font-1) solid var(--color-mgray);
    border-radius: var(--font-8);
    box-shadow: 0 var(--font-2) var(--font-2) var(--color-black05);
    margin-inline: auto;
    padding-block-start: var(--font-25);
    padding-block-end: var(--font-35);
    padding-inline: var(--font-22);
  }

  div[class$="-concept"] dl[class$="-section"] {
    row-gap: var(--font-10);
    padding-block: var(--font-10);
    border-block-end: var(--font-1) solid var(--color-mgray);
  }

  div[class$="-concept"] dl[class$="-section"] dt {
    font-size: 1.4rem;
  }

  div[class$="-concept"] dl[class$="-section"] dd {
    font-size: 1.4rem;
  }
}

@media screen and (min-width: 769px) {
  div[class$="-concept"] {
    row-gap: 1rem;
    border: 0.2rem solid var(--color-mgray);
    border-radius: 1.5rem;
    box-shadow: 0 0.4rem 0.4rem var(--color-black05);
    padding-block: 5rem;
    padding-inline: 7.8rem;
  }

  div[class$="-concept"] dl[class$="-section"] {
    grid-template-columns: 20.0rem 1fr;
    column-gap: 5.0rem;
    border-block-end: 0.1rem solid var(--color-mgray);
    padding-block-start: 1.0rem;
    padding-block-end: 1.0rem;
  }

  div[class$="-concept"] dl[class$="-section"] dt {
    font-size: 1.6rem;
  }

  div[class$="-concept"] dl[class$="-section"] dd {
    font-size: 1.6rem;
  }
}

/* スクロールコンテンツエリア */
.scroll-wrap {
  position: fixed;
  display: grid;
  background-color: var(--color-white);
  opacity: 0;
  pointer-events: none;
  transition: var(--link-btn-transition);
  z-index: 10;
}

body:is(.__scroll) .scroll-wrap {
  opacity: 1;
  pointer-events: inherit;
}

body:is(.__scroll) .scroll-wrap:is(.close) {
  opacity: 0;
  pointer-events: none;
}

.scroll-title {
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
}

.scroll-wrap .search-btn {
  display: grid;
  align-items: center;
  justify-content: center;
  background-color: var(--color-Main);
  border-radius: var(--btn-radius);
}

.scroll-wrap .search-btn .--text {
  color: var(--color-white);
  font-weight: 700;
}

.scroll-wrap .estimate-btn {
  display: grid;
  align-items: center;
  justify-content: center;
  background-color: var(--color-Accent);
  border-radius: var(--btn-radius);
}

.scroll-wrap .estimate-btn .--text {
  color: var(--color-white);
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .scroll-wrap {
    bottom: 0;
    right: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: var(--font-5);
    row-gap: var(--font-10);
    width: 100vw;
    border: var(--font-1) solid var(--color-gray);
    border-start-start-radius: var(--font-8);
    border-start-end-radius: var(--font-8);
    box-shadow: 0 var(--font-2) var(--font-2) 0 var(--color-black05);
    padding-block: var(--font-15);
    padding-inline: var(--font-5);
  }

  body:is(.__scroll) .scroll-wrap:is(.close) {
    opacity: 0;
    pointer-events: none;
  }

  .scroll-title {
    grid-column: 1 / 3;
  }

  .scroll-wrap .search-btn {
    grid-template-columns: max(6.4vmin, 2.4rem) max-content;
    column-gap: var(--font-3);
    width: 100%;
    height: var(--font-40);
  }

  .scroll-wrap .search-btn .search-img {
    width: max(6.4vmin, 2.4rem);
  }

  .scroll-wrap .search-btn .--text {
    font-size: 1.3rem;
  }

  .scroll-wrap .estimate-btn {
    grid-template-columns: max(5.6000000000000005vmin, 2.1rem) max-content;
    column-gap: var(--font-3);
    width: 100%;
    height: var(--font-40);
  }

  .scroll-wrap .estimate-btn .estimate-img {
    width: max(5.6000000000000005vmin, 2.1rem);
  }

  .scroll-wrap .estimate-btn .--text {
    font-size: 1.2rem;
  }
}

@media screen and (min-width: 769px) {
  .scroll-wrap {
    bottom: 8.5rem;
    right: 1rem;
    row-gap: 1.2rem;
    width: 35rem;
    border: 0.1rem solid var(--color-gray);
    border-radius: 1.5rem;
    box-shadow: 0 0.4rem 0.4rem 0 var(--color-black05);
    padding-block: 3.5rem;
    padding-inline: 2rem;
  }

  .scroll-wrap .search-btn {
    grid-template-columns: 2.4rem max-content;
    column-gap: 0.5rem;
    width: 100%;
    height: 4.6rem;
  }

  .scroll-wrap .search-btn .search-img {
    width: 2.4rem;
  }

  .scroll-wrap .search-btn .--text {
    font-size: 1.4rem;
  }

  .scroll-wrap .estimate-btn {
    grid-template-columns: 2.4rem max-content;
    column-gap: 0.5rem;
    width: 100%;
    height: 4.6rem;
  }

  .scroll-wrap .estimate-btn .estimate-img {
    width: 2.4rem;
  }

  .scroll-wrap .estimate-btn .--text {
    font-size: 1.4rem;
  }
}

/* ogm */
.closeBtn {
	text-align: right;
	margin-top: 20px;
}
.content {
	width: 1060px;
	margin: 0 auto;
	margin-block-start: 19.0rem;
	font-size: 17px;
}

.alert {
  padding: 15px;
  margin-bottom: 15px;
  border: 1px solid transparent;
  border-radius: 4px;
}
.alert-danger {
  background-color: #f2dede;
  border-color: #ebccd1;
  color: #a94442;
}
table {
    border-collapse: collapse;
    width: 100%;
}
table tr th {
    border:1px solid #ddd;
}
td {
    border:1px solid #ddd;
}

.merchandise {
    margin: 16px auto 0;
}
.required {
    display: inline-block;
    background: #cc0000;
    font-weight: normal;
    color: #fff;
    padding: 3px 5px;
    font-size: 11px;
    float: right;
    margin-right: 7px
}
.requiredNotRight {
    display: inline-block;
    background: #cc0000;
    font-weight: normal;
    color: #fff;
    padding: 3px 5px;
    font-size: 11px;
    margin-left: 8px;
}
.notes {
    font-size: 13px;
    color: #777;
    display: block;
    margin-top: 8px;
    margin-bottom: 8px;
    margin-left: 8px;
}
.quoterequestNotes {
	font-size: 13px;
	color: #777;
	margin-left: 15px;
}
.quoterequestNote {
	font-size: 13px;
	color: #777;
}
.section-title {
    font-size: 1.2em;
    font-weight: bold;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #ddd;
}
.form-group {
    text-align: left;
    margin: 30px 12px 40px 12px
}
.file-upload {
    display: flex;
    align-items: center;
    justify-content: left;
    padding-top: 5px;
}
.file-label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    background-color: var(--color-Main);
    border: 1px solid var(--color-Main);
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    margin-right: 10px;
    border-radius: 12px;
    color: white;
}
.file-input {
    display: none;
}
.file-name {
    margin-right: 10px;
}
.file-preview {
    margin-right: 10px;
    width: 100px;   /* 幅を100pxに設定 */
    height: 100px;  /* 高さを100pxに設定 */
    object-fit: cover; /* 画像が指定サイズに収まるようにトリミング */
    cursor: pointer; /* カーソルをポインターに変更 */
}
.remove-button {
    background-color: #f44336;
    color: white;
    border: none;
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    margin-left:10px;
}
.remove-button:hover {
    background-color: #d32f2f;
}
.example-link {
    color: #007bff;
    text-decoration: none;
    margin-left: 20px;
    margin-right: 20px;
    text-decoration: underline;
}
.example-link:hover {
    text-decoration: underline;
}
.other_request_form {
    field-sizing: content;
    width: 500px;
    height: 250px;
    min-height: min-content;
}
.customer_information {
    margin-top: 100px;
}
.hidden-div {
  display: none;
}
.btnWrap {
    margin-top: 24px;
    text-align:center;
}

.btn.disabled, .returnbtn.disabled {
	background: #ddd;
	pointer-events: none;
}
.loginBtn {
	justify-content: center;
	align-items: center;
	justify-content: center;
	column-gap: 0.6rem;
	width: 10rem;
	height: 2.9rem;
	background-color: #0079C5;
	border-radius: var(--btn-radius);
	margin-inline-end: 1.6rem;
	padding-inline: 1.0rem;
	margin: 10px;
	color: white;
}
.loginBtn.disabled {
	background: #ddd;
	pointer-events: none;
}
.forget-password {
	margin-bottom: 10px;
	text-decoration: underline;
}
.forgetPass {
	color: #0000EE;
}
.search-modelNumber {
	color: #0000EE;
	font-size: 11px;
	margin-top: 5px;
	text-decoration: underline;
}
.consultation-form {
	color: #0000EE;
	margin-top: 5px;
	text-decoration: underline;
}

.btn {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	justify-content: center;
	column-gap: 0.6rem;
	width: 16rem;
	height: 4.6rem;
	background-color: #0079C5;
	border-radius: var(--btn-radius);
	margin-inline-end: 1.6rem;
	padding-inline: 1.0rem;
	margin: 10px;
}
.returnbtn {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	justify-content: center;
	column-gap: 0.6rem;
	width: 16rem;
	height: 4.6rem;
	background-color: #ddd;
	border-radius: var(--btn-radius);
	margin-inline-end: 1.6rem;
	padding-inline: 1.0rem;
	margin: 10px;
	border: 0.1rem solid rgb(0, 54, 94);
}
.shop_btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	column-gap: 0.6rem;
	width: 16rem;
	height: 4.6rem;
	background-color: var(--color-Main);
	border-radius: var(--btn-radius);
	margin-bottom: 10px;
}
.btn_character {
	color: white;
	font-size: 14px;
}
.retrunbtn_character {
	color: rgb(0, 54, 94);
	font-size: 14px;
}

#send_btn, #return_btn{
	cursor: pointer;
}
#outArea {
	text-align: center;
	margin-top: 30px;
}
.agreeBox {
	text-align: center;
}
.policyTitle {
	text-align: center;
	margin-top: 20px;
}


/* モーダル ここから */
.modal {
    display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 1; /* Sit on top */
    padding-top: 50px; /* Location of the box */
    left: 0;
    top: 0;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0, 0, 0); /* Fallback color */
    background-color: rgba(0, 0, 0, 0.6); /* Black w/ opacity */
}

/* Modal Content (image) */
.modal-content {
    margin: auto;
    display: block;
    max-width: 90%;
    max-height: 90%;
    margin-block-start: 19.0rem;
}

/* The Close Button */
.close, .closeExampleButton {
    position: absolute;
    top: 15px;
    right: 35px;
    color: #f1f1f1;
    font-size: 40px;
    font-weight: bold;
    transition: 0.3s;
    margin-block-start: 19.0rem;
}

.close:hover,
.close:focus,
.closeExampleButton:hover,
.closeExampleButton:focus {
    color: #bbb;
    text-decoration: none;
    cursor: pointer;
}
.modal-trigger {
    cursor: pointer;
    color: blue;
    text-decoration: underline;
    margin-left: 10px;
    margin-right: 10px;
}
/* モーダル ここまで */

/* 点滅用 */
@keyframes blinking {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

.validateMessage {
	display: inline-block;
	width: 100%;
	color: red;
	font-size: 13px;
	margin: 8px;
}
.label-like input {
  border: none;
  background-color: transparent;
  font-size: 16px;
  color: #333;
  padding: 0;
  pointer-events: none; /* クリックイベントを無効化 */
  margin-left: 10px;
}
.label-like input:focus {
  outline: none;
}
iframe.privacyPolicy {
    width: 100%;
    border: 1px solid #ccc;
    margin-bottom: 8px;
    height: 140px;
    overflow: auto;
    text-align: center;
}
.input_form {
	border: 1px solid #ddd;
	height: 28px;
	margin: 10px;
}
textarea::placeholder {
	color: #999;
	font-size: 11px;
}
#harea, #modelNumber {
	margin: 8px;
}
.other_request {
	text-align: center;
	vertical-align: middle;
}
.product-name, .product-price {
	text-align: center;
}
.consumer {
	text-align: center;
	margin: 10px
}
input[type="radio"]:disabled + label {
	cursor: default;
	color: #6c757d;
}
.radio-container {
	display: -webkit-inline-box;
	flex-wrap: wrap;
	gap: 10px;
	width: calc(50% - 5px);
	margin-top: 10px;
}
.table-th-adjustment {
	margin-left: 10px;
	margin-top: 10px;
}
.confirm-th-adjustment {
	margin: 10px;
}
.formTable td, .quote_request_table td {
	vertical-align: middle;
}
.input-member-information {
	margin: 10px;
}
.width-adjustment {
	width: 85%;
}
#otherRequestForm {
	margin: 8px;
	width: 575px;
	min-height: 200px;
	resize:none;
	overflow-y: hidden;
	overflow-x: hidden;
	white-space: pre-wrap;
	word-wrap: break-word;
	box-sizing: border-box;
}
.outAreaHr {
	border: 0;
	height: 4px;
	background-image: linear-gradient(to right, #0079C5 50%, #FB7D00 50%);
	width: 3%;
	margin: 6px auto;
}
.product_img {
	width: 400px;
	height: auto;
}

.adjust-required {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 2px;
}

.quote_request_table th {
	position: relative;
}

@media only screen and (max-width: 640px) {
	body {
		font-size: 13px;
	}
	.content {
		min-width: 350px;
		width: 80%;
		font-size: 13px;
		margin-block-start: 7.5rem;
	}
	.btn, .shop_btn, .returnbtn {
		width: 100px;
		height: 40px;
	}
	.btn_character {
		font-size: 11px;
	}
	.retrunbtn_character {
		font-size: 11px;
	}
	.quote_request_table, .login, .formTable, .merchandise_table {
		width: 100%;
		table-layout: fixed;
	}
	.quote_request_table th, .quote_request_table td, .formTable th, .formTable td 
	, .login td, .login th {
		display: block;
		width: 100%;
		word-break: break-all;
	}
	.quote_request_table th, .formTable th, .login th {
		text-align: left;
		padding-left: 10px;
	}
	.other_request_form {
		width:100%;
		height: 150px;
		margin-top: 8px;
	}
	.product_img {
		width: 100px;
		height: auto;
	}
	.form-group {
		font-size: 10px;
	}
	.file-upload {
		display: block;
	}
	.file-label {
		display: inline-block;
		margin: 0px 0px 10px 0px;
	}
	.remove-button {
		margin: 10px 0px 0px 0px;
	}
	.title {
		font-size: 13px;
	}
	.responsive-br {
		display: none;
	}
	.quoterequestNotes {
		margin-top: 8px;
		font-size: 11px;
	}
	#otherRequestForm {
		width: 95%;
	}
	.adjustmentSp {
		margin: 10px;
	}
	.constructionSiteCheck {
		margin-top: 15px;
		margin-bottom: 15px;
	}
	.noneValueAdjust {
		height: 41px;
	}
	.responsiveInputPhoneForm20 {
		width: 20%
	}
	.responsiveInputPhoneForm25 {
		width: 25%;
	}
	.table-th-adjustment {
		margin-left: 0px;
		margin-bottom: 10px;
	}
	.outAreaHr {
		width: 7%;
	}
	body.no-scroll {
		overflow: hidden;
	}
	.adjust-required {
		right: 10px;
	}
	.consumer {
		text-align: left;
		margin: 10px 0px 10px 0px;
	}
}
