@charset "UTF-8";
/*===================================
  
  共通CSS

===================================*/
@media screen and (min-width: 992px) {
  html {
    overflow-y: scroll;
    overflow-x: hidden;
  }
}
body {
  position: relative;
  height: 100%;
  background: url("../img/img-common/bg_02.png") repeat-y center top;
}
body.no_rightContent {
  background: none;
}
body.is_hidden {
  /*  overflow: hidden;*/
}
body.media {
  background: none;
}
.wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
/*===================================
  
  ヘッダー

===================================*/
#header {
  width: 100%;
  height: 66px;
  background: #fff;
  border-bottom: 4px solid #2793ff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
}
#header .inner {
  position: relative;
  height: 100%;
  padding: 0 2%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__logo a {
  position: relative;
  display: block;
  height: 48px;
}
.header__logo img {
  height: 48px;
}
.header__logo__text {
  width: 100%;
  padding-left: 23%;
  white-space: nowrap;
  font-size: 0.8rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0;
  color: #16c2d1;
  position: absolute;
  bottom: 0;
  left: 0;
}
.header__linkArea_02 {
  margin-right: 13%;
}
.header__linkArea_02__list {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0 10px;
}
.header__linkArea_02__list li {
  border-radius: 4px;
}
.header__linkArea_02__list li a div {
  position: relative;
  width: 40px;
  height: 40px;
}
.header__linkArea_02__list li a div p {
  display: none;
}
#header_shohin_num {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15px;
  height: 15px;
  border-radius: 100px;
  background: #fff;
  position: absolute;
  top: 5px;
  right: 3px;
  font-size: 0.9rem;
  font-weight: bold;
  letter-spacing: -0.05em;
  color: #fa336b;
  z-index: 1;
}
.header__linkArea_02__list__cart {
  background: #fa336b;
}
.header__linkArea_02__list__cart a img {
  height: 23px;
  position: absolute;
  top: 55%;
  left: 46%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.header__linkArea_02__list__form {
  background: #30c6d4;
}
.header__linkArea_02__list__form a img {
  height: 15px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.header__linkArea_02__list_mypage a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 40px;
}
.header__linkArea_02__list_mypage a img{
	margin-top: 3px;
	height: 34px;
}
.header__hamburger {
  position: absolute;
  top: 10px;
  right: 2%;
  z-index: 5000;
  width: 40px;
  height: 40px;
}
.header__hamburger span {
  display: inline-block;
  transition: all 0.4s;
  position: absolute;
  left: 8px;
  height: 2px;
  background: #2793ff;
}
.header__hamburger span:nth-of-type(1) {
  top: 12px;
  width: 60%;
}
.header__hamburger span:nth-of-type(2) {
  top: 20px;
  width: 60%;
}
.header__hamburger span:nth-of-type(3) {
  top: 28px;
  width: 60%;
}
.header__hamburger.active span:nth-of-type(1) {
  top: 13px;
  left: 7.5px;
  transform: translateY(6px) rotate(-135deg);
  width: 75%;
}
.header__hamburger.active span:nth-of-type(2) {
  opacity: 0;
}
.header__hamburger.active span:nth-of-type(3) {
  top: 24px;
  left: 7.5px;
  transform: translateY(-6px) rotate(135deg);
  width: 75%;
}
@media screen and (min-width: 992px) {
  #header {
    width: 100%;
    height: 78px;
    background: #fff;
    border-bottom: none;
    position: fixed;
    top: 0;
    left: 0;
  }
  #header .inner {
    max-width: 1180px;
    width: 100%;
    height: 100%;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
  .header__logo {
    margin-right: 50px;
  }
  .header__logo a {
    height: 57px;
  }
  .header__logo img {
    height: 56px;
  }
  .header__logo__text {
    font-size: 1.1rem;
  }
  .header__linkArea_01 {
    margin: 7px 20px 0 0;
  }
  .media .header__linkArea_01 {
    margin: 7px 167px 0 0;
  }
  .header__linkArea_01__list {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 10px;
  }
  .header__linkArea_01__list li a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px 0;
  }
  .header__linkArea_01__list li a img {
    height: 27px;
  }
  .header__linkArea_01__list li a span {
    font-size: 0.9rem;
    font-weight: bold;
    letter-spacing: -0.03em;
  }
  .header__linkArea_02 {
    margin-right: 12px;
  }
  .header__linkArea_02__list li {
    border-radius: 4px;
  }
  .header__linkArea_02__list li a div {
    width: 72px;
    height: 60px;
  }
  .header__linkArea_02__list li a div p {
    display: block;
    font-size: 1.1rem;
    color: #fff;
    letter-spacing: 0;
    white-space: nowrap;
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
  #header_shohin_num {
    width: 18px;
    height: 18px;
    position: absolute;
    top: 6px;
    right: 14px;
    font-size: 1.2rem;
  }
  .header__linkArea_02__list__cart a img {
    height: 26px;
    position: absolute;
    top: 40%;
    left: 46%;
  }
  .header__linkArea_02__list__form a img {
    height: 18px;
    position: absolute;
    top: 40%;
    left: 50%;
  }
  .header__telArea {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-right: 10px;
  }
  .header__telArea__tel {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .header__telArea__tel dt a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 6px;
  }
  .header__telArea__tel dt a img {
    height: 27px;
    margin-top: 6px;
  }
  .header__telArea__tel dt a span {
    font-size: 2.8rem;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.0;
    color: #0564ec;
  }
  .header__telArea__tel dd {
    font-size: 1.1rem;
    font-weight: bold;
    letter-spacing: 0;
    text-indent: 8px;
    padding-top: 2px;
  }
  .header__telArea__explain {
    position: relative;
    border: 2px solid #16c2d1;
    border-radius: 6px;
    background: #fff;
    padding: 2px 4px 0;
    margin-left: 5px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
  .header__telArea__explain::before {
    content: "";
    background: url("../img/img-common/bg_arrow_04.png") no-repeat left top/contain;
    width: 12px;
    height: 10px;
    position: absolute;
    top: 50%;
    left: -12px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }
  .header__telArea__explain p {
    letter-spacing: 0;
    line-height: 1.2;
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
  }
  .header__telArea__explain p strong {
    display: block;
    color: #0564ec;
    font-size: 1.7rem;
    background: linear-gradient(transparent 60%, #fffc00 40%);
    padding: 0 0.2em 0.1em;
  }
  .header__telArea__explain p strong span {
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 1200px) {
  .header__linkArea_01__list {
    gap: 0 12px;
  }
.header__linkArea_01__list li a span {
    font-size: 1.1rem;
  }
}

/*===================================
  
  ハンバーガーメニュー

===================================*/
.header__spMenu{
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background: #d8edff;
    overflow-y: scroll;
    z-index: 3000;
    clip-path: inset(0 0 0 100%);
    transition: 0.4s cubic-bezier(.86,.35,.41,.8);
	visibility: hidden;
}
.header__spMenu.active{
  clip-path: inset(0);
  opacity: 1;
  visibility: visible;
}

#header .header__spMenu .inner {
  height: auto;
  padding: 0 8%;
  display: block;
}
.header__spMenu__logo {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 0;
}
.header__spMenu__logo a {
    position: relative;
    display: inline-block;
    margin-left: -3%;
}
.header__spMenu__logo__image{
    height: 56px;
    
}
.header__spMenu__logo__text{
    font-size: 0.9rem;
    font-weight: bold;
    color: #16c2d1;
    position: absolute;
    bottom: 3px;
    left: 32%;
}
.header__spMenu__content{
    background: #fff;
    border-radius: 12px;
    padding: 5px 4% 30px;
}
.header__spMenu__content__linkArea_01{
    margin-bottom: 35px;
}
.header__spMenu__content__linkArea_01__title {
  font-size: 1.3rem;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0;
  line-height: 1.0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 30px;
  background: #57b8ff;
}
.header__spMenu__content__linkArea_01__title.-campaign {
  margin-bottom: 15px;
}
.header__spMenu__content__linkArea_01__list{
	margin-bottom: 35px;
}
.header__spMenu__content__linkArea_01__list li a{
    position: relative;
    height: 57px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 13px;
    border-bottom: 1px solid #a7d1f6;
    padding-left: 4%;
}
.header__spMenu__content__linkArea_01__list li a::before{
  content: "";
  width: 9px;
  height: 9px;
  border-top: 1px solid #4FA6FD;
  border-right: 1px solid #4FA6FD;
  transform: rotate(45deg);
  position: absolute;
  top: 42%;
  right: 6%;
}
.header__spMenu__content__linkArea_01__list li a span{
    font-size: 1.2rem;
    font-weight: bold;
}
.header__spMenu__content__linkArea_01__list li a img{
    height: 35px;
}
.header__spMenu__content__linkArea_01__list li.wakeari a span + img {
  height: 27px;
}
.header__spMenu__content__linkArea_01__btn {
  width: 94%;
  margin: 0 auto 35px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 15px 0;
}
.header__spMenu__content__linkArea_02{
    width: 94%;
    margin: 0 auto 15px;
}
.header__spMenu__content__linkArea_02__list{
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0 2%;
}
.header__spMenu__content__linkArea_02__list li {
    width: 49%;
    height: 40px;
}
.header__spMenu__content__linkArea_02__list li a{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 7px;
}
.header__spMenu__content__linkArea_02__list__image {
    width: 30px;
    text-align: center;
}
.header__spMenu__content__linkArea_02__list__image img{
    height: 25px;
}
.header__spMenu__content__linkArea_02__list li a span{
    font-size: 1.1rem;
    font-weight: bold;
    letter-spacing: -0.03em;
    white-space: nowrap;
}
.header__spMenu__content__linkArea_03{
    width: 82%;
    margin: 0 auto 12px;
}
.header__spMenu__content__linkArea_03__list{
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 12px 0;
}
.header__spMenu__content__linkArea_03__list li {
    width: 100%;
}
.header__spMenu__content__linkArea_03__list li a{
    position: relative;
    width: 100%;
    height: 50px;
    background: #fa336b;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 12%;
    border-radius: 8px;
}
.header__spMenu__content__linkArea_03__list li a::after{
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 42%;
  right: 6%;
}
.header__spMenu__content__linkArea_03__list li a span{
    font-size: 1.2rem;
    font-weight: bold;
    color: #fff;
    letter-spacing: 0.05em;
}

.header__spMenu__content__linkArea_03__list__cart__image,
.header__spMenu__content__linkArea_03__list__form__image{
    width: 36px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 3px 0 0 8%;
}
.header__spMenu__content__linkArea_03__list__cart__image img{
    height: 26px;
}
.header__spMenu__content__linkArea_03__list__form__image img{
    height: 17px;
}
.header__spMenu__content__linkArea_03__list .header__spMenu__content__linkArea_03__list__form a{
    background: #30c6d4;
}

.header__spMenu__content__telArea{
    margin-bottom: 30px;
}
.header__spMenu__content__telArea a{
    width: 82%;
    margin: 0 auto;
    position: relative;
    border: 2px solid #16c2d1;
    border-radius: 6px;
    background: #fff;
    padding: 5px 3%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}
.header__spMenu__content__telArea p{
    font-size: 1.0rem;
    font-weight: bold;
    width: 100%;
    text-align: center;
}
.header__spMenu__content__telArea p strong{
    font-size: 1.3rem;
    color: #0564ec;
    background: linear-gradient(transparent 63%, #fffc00 37%);
    padding: 0 0.2em 0;
}
.header__spMenu__content__telArea__tel dt {
    font-size: 1.6rem;
    font-weight: bold;
    color: #0564ec;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 5px;
}
.header__spMenu__content__telArea__tel dt img{
    height: 24px;
    margin-top: 3px;
}
.header__spMenu__content__telArea__tel dd{
    font-size: 0.8rem;
    margin-top: -5px;
}
.header__spMenu__content__telArea__image{
    position: absolute;
    bottom: 13px;
    right: 1%;
}
.header__spMenu__content__snsArea{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 15px;
}
.header__spMenu__content__snsArea ul{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 5px 0;
  border-bottom: 1px dotted #333;
  padding-bottom: 15px;
}
.header__spMenu__content__snsArea ul li a{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 10px;
    text-decoration: underline;
}
.header__spMenu__content__snsArea ul li a img{
    height: 38px;
}

.header__spMenu__content__snsArea ul li a span{
    font-size: 1.0rem;
    line-height: 1.3;
}
.header__spMenu__content__linkArea04 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.header__spMenu__content__linkArea04 a {
  position: relative;
  width: 86%;
  padding: 0 0 0 2%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0 10px;
}
.header__spMenu__content__linkArea04 a::before {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
  transform: rotate(45deg);
  position: absolute;
  top: 42%;
  right: 6%;
}
.header__spMenu__content__linkArea04 a img {
  height: 30px;
}
.header__spMenu__content__linkArea04 a dl {
  position: relative;
  font-size: 1.0rem;
}
.header__spMenu__content__linkArea04 a dl dt {
  position: relative;
  font-weight: bold;
  padding-right: 17px;
}
.header__spMenu__content__linkArea04 a dl dt::before {
  content: "";
  background: url("../img/img-common/ico_hambargur_blank.png") no-repeat left top/contain;
  width: 12px;
  height: 12px;
  position: absolute;
  top: 5px;
  right: 0%;
}

.header__spMenu__closeBtn{
    width: 40%;
    height: 30px;
    border: 1px solid #1d86e9;
    background: #fff;
    border-radius: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #1d86e9;
    font-size: 1.1rem;
    font-weight: bold;
    margin: 30px auto 50px;
}
.header__spMenu__closeBtn span{
    position: relative;
    padding-left: 16px;
}
.header__spMenu__closeBtn span::after{
    content: "";
    background: #1d86e9;
    width: 13px;
    height: 1px;
    position: absolute;
    top: 10px;
    left: 0%;
    transform:rotate(-135deg);
}
.header__spMenu__closeBtn span::before{
    content: "";
    background: #1d86e9;
    width: 13px;
    height: 1px;
    position: absolute;
    top: 10px;
    left: 0%;
    transform: rotate(135deg);
}

/*===================================
  
  メイン

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

@media screen and (min-width: 992px) {
  .main {
    position: relative;
    width: 1180px;
    margin: auto;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0 0;
  }
  .main::after {
    content: "";
    background: #fff;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: -980px;
  }
}

/*===================================
  
   左カラム

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

@media screen and (min-width: 992px) {
  #leftContent {
    position: sticky;
    top: 78px;
    width: 200px;
    max-height: 100vh;
    padding-bottom: 100px;
    background: #fff;
    overflow: scroll;
    scrollbar-width: none;
	z-index: 10;
  }
  .leftContent__list {
    border-top: 1px solid #30c6d4;
	margin-bottom: 20px;
  }
  .leftContent__list li a {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 7px;
    width: 200px;
    height: 53px;
    border-bottom: 1px solid #e5e5e5;
  }
  .leftContent__list li a::after {
    content: "";
    width: 7px;
    height: 7px;
    border-top: 1px solid #8e8e8e;
    border-right: 1px solid #8e8e8e;
    transform: rotate(45deg);
    position: absolute;
    top: 25px;
    right: 10px;
  }
  .leftContent__list li a img {
    height: 34px;
  }
  .leftContent__list li.sample a img {
    height: 26px;
    margin: 0 4px;
  }
  .leftContent__list li a span {
    font-size: 1.2rem;
  }
.leftContent__btnList{
	display: flex;
	flex-direction: column;
	gap: 15px 0;
}
	
    }


  /*===================================
  
  右カラム（計算機）

===================================*/
#rightContent {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  z-index: 9999;
  width: 90%;
  top: 120px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transition: 0.8s;
}
#rightContent.active{
  opacity: 1;
  visibility: visible;
  position: fixed;
  z-index: 9999;
  width: 90%;
  top: 75px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}    
#robot_wrap {
  background: #fff;
  letter-spacing: 0;
  border-radius: 10px;
  padding: 15px;
}
.robot_wrap_title {
  font-size: 130%;
  font-weight: bold;
  text-align: center;
  margin-bottom: 5px;
}
#item_field:focus-within, #option_field:focus-within, #grass_r_field:focus-within, #eddge_field:focus-within, #tate_size:focus-within, #yoko_size:focus-within, #thickness_field:focus-within, #maisu_field:focus-within {
  background: #dfefff;
}
.item_field_inner, .option_field_inner, .grass_r_field_inner, .eddge_field_inner, .tate_size_inner, .yoko_size_inner, .thickness_field_inner, .maisu_field_inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 5px 7px;
  border-bottom: 1px solid #ccc;
}
.tate_size_item, .yoko_size_item {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0 5px;
}
#tate_field_mmconvert, #yoko_field_mmconvert {
  font-size: 1.1rem;
}
.maisu_field_item {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0 5px;
}
.text_discount {
  font-size: 13px;
  padding-left: 17px;
}
.text_discount strong {
  color: #ff0000;
}
/* ------------------------
選択項目タイトル
---------------------------*/
  .item_field_title{
    font-size: 105%;
    letter-spacing: -0.02em;
    font-weight: bold;
    text-align: left;
    width: 85px;
  }
  .item_field_title span{
    letter-spacing: -0.05em;
  }
.option_field_title, .grass_r_field_title, .eddge_field_title, .tate_size_title, .yoko_size_title, .thickness_field_title, .maisu_field_title {
  font-size: 110%;
  font-weight: bold;
  text-align: left;
  width: 85px;
}
/* ------------------------
select 幅・枠線・フォントサイズ  
---------------------------*/
#robot_wrap select {
  color: #333;
  background: #fff;
  padding: 3px 6px;
  border: 1px solid #9ad5ff;
  border-radius: 4px;
  -webkit-appearance: none;
  appearance: none;
}
#robot_wrap select:focus {
  outline: none;
}
.item_field_item select, .option_field_item select, .grass_r_field_item select, .eddge_field_item select {
  width: 220px;
  font-size: 1.2rem;
}
#tate_field select, #yoko_field select {
  width: 75px;
  font-size: 1.2rem;
}
#tate_field_mm select, #yoko_field_mm select {
  width: 75px;
  font-size: 1.2rem;
}
.thickness_field_item select, .maisu_field_item select {
  width: 75px;
  font-size: 1.2rem;
}
/* ------------------------
select 矢印  
---------------------------*/
.item_field_item, .option_field_item, .grass_r_field_item, .eddge_field_item, #tate_field, #tate_field_mm, #yoko_field, #yoko_field_mm, .thickness_field_item, .maisu_field_item {
  position: relative;
}
.item_field_item::before, .option_field_item::before, .grass_r_field_item::before, .eddge_field_item::before, #tate_field::before, #tate_field_mm::before, #yoko_field::before, #yoko_field_mm::before, .thickness_field_item::before, .maisu_field_item::before {
  content: "";
  width: 7px;
  height: 7px;
  margin: 0 10px;
  border-bottom: 1px solid #284b8a;
  border-right: 1px solid #284b8a;
  pointer-events: none;
  transform: rotate(45deg);
  position: absolute;
  top: 7px;
  right: 0;
}
#tate_field::before, #tate_field_mm::before, #yoko_field::before, #yoko_field_mm::before, .thickness_field_item::before, .maisu_field_item::before {
  top: 8px;
  right: -2px;
}
/* ------------------------
金額
---------------------------*/
.money_block {
  background: #333;
  border-radius: 10px;
  margin: 5px 0;
  padding: 0 8px;
  height: 44px;
}
.money_block_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
}
.money_block_title {
  color: #fff;
  padding-top: 7px;
  font-size: 100%;
}
#money {
  color: #FFFF00;
  font-size: 2.5rem;
  line-height: 1.4;
  position: relative;
  padding-right: 35px;
}
#money span {
  font-size: 1.0rem;
  position: absolute;
  bottom: 7px;
  right: 0;
}
/* ------------------------
カート部分
---------------------------*/
#cart_link img {
  width: auto;
}
.cart_link_item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.cart_link_item_left {
  width: 49%;
  background: #333;
  padding: 5px 10px;
  border-radius: 10px;
}
.cart_link_item_left_title {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0 2px;
}
.cart_link_item_left_title::after {
  content: "";
  background: url("../img/img-common/cart_line_sp.png") no-repeat left top/contain;
  width: 8px;
  height: 65px;
  position: absolute;
  top: 50px;
  left: 7px;
}
.cart_link_item_left_title p {
  color: #fff;
  font-size: 1.0rem;
  text-align: left;
  padding-bottom: 3px;
}
 #robot_wrap .cart_link_item_left_select {
    position: relative;
    margin-bottom: 10px;
  }
  #robot_wrap .cart_link_item_left_select::after {
    content: "";
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #333;
    border-right: 2px solid #333;
    position: absolute;
    top: 50%;
    right: 7px;
    transform: translateY(-50%) rotate(45deg);
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    pointer-events: none;
  }
  #robot_wrap .cart_link_item_left_select select {
    width: 100%;
    font-size: 1.1rem;
    padding: 2px 10px;
    border: 1px solid #ccc;
    border-radius: 0;
    background: #fff;
  }
.cart_link_item_left dl {
  padding-left: 18px;
}
.cart_link_item_left dl:first-of-type {
  margin-bottom: 6px;
}
.cart_link_item_left dl dt {
  color: #fff;
  font-size: 1.0rem;
  text-align: left;
  line-height: 1.1;
  padding-left: 3px;
}
.cart_link_item_left dl dd {
  color: #FFFF00;
  font-size: 1.8rem;
  line-height: 1.3;
  text-align: left;
}
.cart_link_item_left dl dd span {
  font-size: 1.0rem;
  font-weight: normal;
  padding-left: 2px;
}
.cart_link_item_right {
  width: 48%;
}
.cart_link_item_right_yoteibi {
  background: #333;
  padding: 5px 6px 3px 8px;
  border-radius: 10px;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
}
.cart_link_item_right_yoteibi p {
  color: #fff;
  font-size: 1.0rem;
  text-align: left;
}
#yoteibi {
  width: 100%;
  font-size: 1.6rem;
  text-align: right;
  line-height: 1.0;
  margin-bottom: 5px;
}
#yoteibi em {
  font-style: normal;
}
#cart_link_btn {
  margin-top: 10px;
}
#toCart {
  margin-top: 8px;
}
/* ##### 有方追加 2024.03.05 ##### */
#sendprice_kojin, #sendprice_jigyo {
  font-size: 1.8rem;
  font-style: normal;
}
#sendprice_kojin.sendprice_none, #sendprice_jigyo.sendprice_none {
  padding-left: 4px;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
}
/*#sendprice_kojin.sendprice_none + span, #sendprice_jigyo.sendprice_none + span {
  display: none;
}*/
/* ##### 有方追加 2024.03.05 ##### */
#cart_link_btn span, #toCart span {
  width: 100%;
  height: 36px;
  border-radius: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.2;
  background: #ff6d12;
  transition: ease 0.5s;
}
#toCart span {
  background: #284b8a;
}
/* エラーメッセージ
------------------------------*/
#err_mes {
  background: #cc0000;
  display: block;
  padding: 5%;
  border-radius: 10px;
  border: 3px solid #fff;
  width: 92%;
  position: fixed;
  top: 345px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index:9999; 
}
#err_mes h3 {
  background: #fff;
  border-radius: 100px;
  font-size: 1.3rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 10px;
}
#err_mes h3 em {
  color: #CC0000;
  font-style: normal;
}
#err_mes ul {
  overflow: scroll;
}
#err_mes ul li {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.4;
}
#err_mes ul li:not(:last-of-type) {
  margin-bottom: 10px;
}

@media screen and (max-width: 991px) {
  /* ------------------------
テキスト入力 幅・枠線・フォントサイズ  
---------------------------*/
  #item_field_item_input, #option_field_item_input, #grass_r_field_item_input, #eddge_field_item_input {
    width: 214px;
    padding: 3px 6px;
    font-size: 1.2rem;
    color: #333;
    text-align: left;
    border: 1px solid #9ad5ff;
    border-radius: 4px;
  }
  #thickness_field_item_input {
    width: 75px;
    padding: 3px 6px;
    font-size: 1.2rem;
    color: #333;
    text-align: left;
    border: 1px solid #9ad5ff;
    border-radius: 4px;
  }
  #item_field_item_input:hover, #option_field_item_input:hover, #grass_r_field_item_input:hover, #eddge_field_item_input:hover, #thickness_field_item_input:hover {
    cursor: default;
  }
  #item_field_item_input::placeholder, #option_field_item_input::placeholder, #grass_r_field_item_input::placeholder, #eddge_field_item_input::placeholder, #thickness_field_item_input::placeholder {
    color: #333;
  }
  #item_field_item_input:focus, #option_field_item_input:focus, #grass_r_field_item_input:focus, #eddge_field_item_input:focus, #thickness_field_item_input:focus {
    outline: none;
  }
  body.is_hidden {
    /*  overflow: hidden;*/
  }
  #item_cover {
    opacity: 0;
    visibility: hidden;
    width: 100%;
    height: 100%;
    background: transparent;
    overflow-y: scroll;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 12000;
    transition: 1.4s;
  }
  #item_cover.active {
    opacity: 1;
    visibility: visible;
  }
#item_cover__closeArea{
	opacity: 0;
    visibility: hidden;
	width: 100%;
	height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 12001;
	background: transparent;
	}
  #item_cover.active #item_cover__closeArea{
    opacity: 1;
    visibility: visible;
  }
  #item_field_item_content, #option_field_item_content, #grass_r_field_item_content, #eddge_field_item_content, #thickness_field_item_content {
    position: relative;
    width: 90%;
    padding: 30px 0;
    background: #fff;
    border-radius: 18px;
    margin: 76px auto;
    opacity: 0;
    visibility: hidden;
    display: none;
    z-index: 13000;
  }
  #item_field_item_content.active, #option_field_item_content.active, #grass_r_field_item_content.active, #eddge_field_item_content.active, #thickness_field_item_content.active {
    opacity: 1;
    visibility: visible;
    display: block;
  }
  #item_field_item_content .inner, #option_field_item_content .inner, #grass_r_field_item_content .inner, #eddge_field_item_content .inner, #thickness_field_item_content .inner {
    width: 90%;
    margin: auto;
    padding: 0;
  }
  /* タイトル */
  .item_field_item_content_title, .option_field_item_content_title, .grass_r_field_item_content_title, .eddge_field_item_content_title, .thickness_field_item_content_title {
    text-align: center;
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 15px;
  }
  .item_field_item_content_title span, .option_field_item_content_title span, .grass_r_field_item_content_title span, .eddge_field_item_content_title span, .thickness_field_item_content_title span {
    color: #00b2c1;
  }
  /* 厚さタイトル下テキスト */
  .thickness_field_item_content_text {
    text-align: center;
    margin: -10px 0 10px;
  }
  .thickness_field_item_content_text span {
    position: relative;
    font-size: 1.1rem;
    font-weight: bold;
    color: #00b2c1;
    padding-left: 1em;
    line-height: 1.4;
    display: inline-block;
    text-align: left;
  }
  .thickness_field_item_content_text span::before {
    content: "※";
    position: absolute;
    top: 0%;
    left: 0%;
  }
  /* 閉じるボタン */
  .item_modal_close.-button {
    width: 32px;
    height: 32px;
    border-radius: 100px;
    background: #16c2d1;
    position: absolute;
    top: 8px;
    right: 8px;
    cursor: pointer;
    transition: all .3s;
  }
  .item_modal_close.-button:hover {
    opacity: 0.8;
  }
  .item_modal_close.-button::before {
    content: "";
    background: #fff;
    width: 2px;
    height: 19px;
    position: absolute;
    top: 7px;
    left: 15px;
    transform: rotate(135deg);
  }
  .item_modal_close.-button::after {
    content: "";
    background: #fff;
    width: 2px;
    height: 19px;
    position: absolute;
    top: 7px;
    left: 15px;
    transform: rotate(-135deg);
  }
  /* 閉じるボタン（テキスト） */
  .item_modal_close.-text {
    padding: 30px 0 0;
    text-align: center;
  }
  .item_modal_close.-text span {
    font-size: 1.3rem;
    color: #16c2d1;
    position: relative;
    padding-left: 28px;
    cursor: pointer;
    transition: all .3s;
  }
  .item_modal_close.-text span:hover {
    opacity: 0.8;
  }
  .item_modal_close.-text span::before {
    content: "";
    background: #16c2d1;
    width: 2px;
    height: 19px;
    position: absolute;
    top: -1px;
    left: 14px;
    transform: rotate(135deg);
  }
  .item_modal_close.-text span::after {
    content: "";
    background: #16c2d1;
    width: 2px;
    height: 19px;
    position: absolute;
    top: -1px;
    left: 14px;
    transform: rotate(-135deg);
  }
  /* 選択項目ボタン */
  .item_button {
    position: relative;
    /*    width: 92%;*/
    padding: 13px 2vw 10px 5%;
    background: #EEFFFF;
    border: 2px solid #ccc;
    border-radius: 10px;
    box-shadow: 2px 5px 10px -4px #212121;
    transition: all .3s;
  }
  .item_button:hover {
    border: 2px solid #16c2d1;
  }
  .item_button:not(:last-of-type) {
    margin-bottom: 25px;
  }
  .item_button:has(input:checked) {
    border: 2px solid #16c2d1;
  }
  .item_button input {
    position: absolute;
    top: 0;
    left: 0;
    -webkit-appearance: none;
    appearance: none;
  }
  .item_button_inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 8px 15px;
    text-align: left;
  }
  .item_button_inner_subtitle span {
    font-size: 1.1rem;
	line-height: 1.0;
    font-weight: bold;
    color: #fff;
    background: #284b8a;
    padding: 4px 10px 3px;
    border-radius: 5px;
  }
  .item_button_inner_title {
    font-size: 1.3rem;
    font-weight: bold;
    color: #00b2c1;
    white-space: nowrap;
    letter-spacing: 0em;
    line-height: 1.4;
    width: 100%;
  }
  .item_button_inner_title span {
    font-size: 1.0rem;
    padding-left: 1.5%;
  }
  .item_button_inner_image img {
    width: 100px;
    height: auto;
  }
  .item_button_inner_textarea {
    position: relative;
    width: 57%;
    flex-grow: 1;
  }
  .item_button_inner_textarea_text {
    font-size: 1.0rem;
    line-height: 1.4;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
  }
  .item_button_inner_textarea_list {
    font-size: 1.0rem;
    line-height: 1.4;
    letter-spacing: 0.05em;
    margin-bottom: 5px;
  }
  .item_button_inner_textarea_button {
    font-size: 1.2rem;
    font-weight: bold;
    color: #fff;
    line-height: 1.0;
    letter-spacing: 0.05em;
    background: #16c2d1;
    width: 90px;
    height: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100px;
    margin-left: auto;
  }
    /* オプション オプション組み合わせ
	強化ガラス ＋ 飛散防止フィルム
	高透過ガラス ＋ 飛散防止フィルム
	透明ガラス(フロートガラス)＋飛散防止フィルム
	スリガラス＋飛散防止フィルム
	フロストガラス＋飛散防止フィルム
	スモークガラス(グレー)＋飛散防止フィルム
	スモークガラス(ブロンズ)＋飛散防止フィルム
	スモークガラス(グリーン)＋飛散防止フィルム
	*/
	
	.item_button:has(#option_field_item_transparent_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_transparent_hightrancesplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_transsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_surisplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_frostsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smokegraysplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_smokebronzesplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smokegreensplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_suri_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_flost_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smoke_temperedsplash) .item_button_inner_image img{
    width: 213px;
  }
	.item_button:has(#option_field_item_transparent_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_transparent_hightrancesplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_transsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_surisplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_frostsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smokegraysplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_smokebronzesplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smokegreensplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_suri_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_flost_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smoke_temperedsplash) .item_button_inner_textarea{
    width: 310px;
  }	
  /* 鏡の形 選択ボタン */
  #grass_r_field_item_content .item_button {
    position: relative;
    z-index: 100;
  }
  #grass_r_field_item_content .item_button_inner_image img {
    margin-top: 15px;
  }
  #grass_r_field_item_content .item_button_list .item_button {
    width: 80%;
  }
  #grass_r_field_item_content .item_button_list::before {
    content: "";
    background: url("../img/img-common/grass_r_field_item_bg_sp.png") no-repeat left top/contain;
    width: 54px;
    height: 1633px;
    position: absolute;
    top: -19px;
    left: 12%;
  }
  #grass_r_field_item_content .item_button_list .item_button:first-of-type .item_button_inner_textarea_mm{
    width: 120px;
  }	
  #grass_r_field_item_content .item_button_list .item_button:first-of-type .item_button_inner_textarea_mm strong{
    font-size: 1.2rem;
	line-height: 1.0;
  }
	
	
	
	
	
	
	
	
	
	
	
  /* エッジ加工 選択ボタン */
  #eddge_field_item_content .item_button_inner_textarea_button {
    margin-top: 0px;
    width: 90px;
  }
  .item_button_inner_textarea_eddge {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0 10px;
  }
  .item_button_inner_textarea_eddge .item_button_inner_textarea_button {
    margin-left: 0;
  }
  .item_button_inner_textarea_mm {
    font-size: 1.1rem;
    color: #00b2c1;
    line-height: 1.0;
    background: #fff;
    border: 1px solid #16c2d1;
    width: 90px;
    height: 23px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .item_button_inner_textarea_mm strong {
    font-weight: normal;
    font-size: 1.3rem;
    letter-spacing: 0;
  }
  #eddge_field_item_content .item_button {
    position: relative;
    z-index: 100;
  }
  .item_button_list {
    position: relative;
    margin-top: -5px;
  }
  .item_button_list::before {
    content: "";
    background: url("../img/img-common/eddge_field_item_bg_sp.png") no-repeat left top/contain;
    width: 54px;
    height: 624px;
    position: absolute;
    top: -19px;
    left: 12%;
  }
  .item_button_list .item_button {
    width: 71%;
    padding: 12px 2vw 12px 2%;
    margin-left: auto;
  }
  .item_button_list .item_button:has(input:checked) {
    border: 3px solid #0080FF;
  }
  .item_button_list .item_button:not(:last-of-type) {
    margin-bottom: 19px;
  }
  .item_button_list .item_button_inner {
    justify-content: flex-end;
  }
  .item_button_list .item_button_inner_textarea {
    width: auto;
  }
}
@media screen and (min-width: 992px) {
  #rightContent {
    position: sticky;
    top: 78px;
    width: 270px;
    max-height: 100vh;
    overflow: scroll;
    scrollbar-width: none;
    padding-bottom: 100px;
    opacity: 1;
    visibility: visible;
    left: 0;
    transform: translateX(0%);
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
  }
  #nekorobo {
    width: 260px;
    margin-left: 10px;
  }
  #robot_wrap {
    font-family: Arial, "Noto Sans JP", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    letter-spacing: 0;
    background: #fff;
    border-radius: 10px;
    padding: 15px 6px;
    margin-top: 10px;
    transition: 0.2s;
  }
  #robot_wrap.active {
    margin-top: 120px;
  }
  .robot_wrap_title {
    font-size: 15px;
    font-weight: bold;
    text-align: center;
  }
  #item_field:focus-within, #option_field:focus-within, #grass_r_field:focus-within, #eddge_field:focus-within, #tate_size:focus-within, #yoko_size:focus-within, #thickness_field:focus-within, #maisu_field:focus-within {
    background: #dfefff;
  }
  .item_field_inner, .option_field_inner, .grass_r_field_inner, .eddge_field_inner, .tate_size_inner, .yoko_size_inner, .thickness_field_inner, .maisu_field_inner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 6px 5px;
    border-bottom: 1px solid #ccc;
  }
  .tate_size_item, .yoko_size_item {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 5px;
  }
  #tate_field_mmconvert, #yoko_field_mmconvert {
    font-size: 13px;
  }
  .maisu_field_item {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0 5px;
  }
  .text_discount {
    font-size: 13px;
    padding-left: 17px;
  }
  .text_discount strong {
    color: #ff0000;
  }
  /* ------------------------
選択項目タイトル
---------------------------*/
  .item_field_title{
    font-size: 12px;
    letter-spacing: -0.02em;
    font-weight: bold;
    text-align: left;
  }
  .item_field_title span{
    letter-spacing: -0.05em;
  }
  .option_field_title, .grass_r_field_title, .eddge_field_title, .tate_size_title, .yoko_size_title, .thickness_field_title, .maisu_field_title {
    font-size: 13px;
    letter-spacing: 0;
    font-weight: bold;
    text-align: left;
  }
  .item_field_title, .option_field_title, .grass_r_field_title, .eddge_field_title {
    width: 74px;
  }
  .tate_size_title, .yoko_size_title, .thickness_field_title, .maisu_field_title {
    width: 35px;
  }
  /* ------------------------
select 幅・枠線・フォントサイズ  
---------------------------*/
  #robot_wrap select {
    padding: 4px;
    color: #333;
    border: 1px solid #9ad5ff;
    border-radius: 4px;
    -webkit-appearance: none;
    appearance: none;
  }
  #robot_wrap select:focus {
    outline: none;
  }
  .item_field_item select, .option_field_item select, .grass_r_field_item select, .eddge_field_item select {
    width: 166px;
  }
  #tate_field select, #yoko_field select {
    width: 70px;
    font-size: 14px;
  }
  #tate_field_mm select, #yoko_field_mm select {
    width: 60px;
    font-size: 14px;
  }
  .thickness_field_item select, .maisu_field_item select {
    width: 70px;
    font-size: 14px;
  }
  /* ------------------------
select 矢印  
---------------------------*/
  .item_field_item, .option_field_item, .grass_r_field_item, .eddge_field_item, #tate_field, #tate_field_mm, #yoko_field, #yoko_field_mm, .thickness_field_item, .maisu_field_item {
    position: relative;
  }
  .item_field_item::before, .option_field_item::before, .grass_r_field_item::before, .eddge_field_item::before, #tate_field::before, #tate_field_mm::before, #yoko_field::before, #yoko_field_mm::before, .thickness_field_item::before, .maisu_field_item::before {
    content: "";
    width: 7px;
    height: 7px;
    margin: 0 10px;
    border-bottom: 1px solid #284b8a;
    border-right: 1px solid #284b8a;
    pointer-events: none;
    transform: rotate(45deg);
    position: absolute;
    top: 5px;
    right: 0;
  }
  #tate_field::before, #tate_field_mm::before, #yoko_field::before, #yoko_field_mm::before, .thickness_field_item::before, .maisu_field_item::before {
    top: 8px;
    right: -2px;
  }
  /* ------------------------
金額
---------------------------*/
  .money_block {
    background: #333;
    border-radius: 10px;
    margin: 8px 0 3px;
    padding: 2px 8px 0;
    height: 40px;
  }
  .money_block_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 100%;
  }
  .money_block_title {
    color: #fff;
    padding-top: 7px;
  }
  #money {
    color: #FFFF00;
    font-size: 28px;
    position: relative;
    padding-right: 30px;
  }
  #money span {
    font-size: 10px;
    position: absolute;
    bottom: 10px;
    right: 0;
  }
  /* ------------------------
カート部分
---------------------------*/
  #cart_link img {
    width: auto;
  }
  .btn_estimate {
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    padding-right: 4px;
    margin-bottom: 2px;
  }
  .btn_estimate p {
    text-align: left;
    font-weight: bold;
    font-size: 13px;
  }
  .btn_estimate_question {
    position: relative;
  }
  .btn_estimate_question img {
    height: 15px;
    padding: 2px 0 0 3px;
  }
  .cart_link_item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .cart_link_item_left {
    width: 120px;
    background: #333;
    margin-top: -26px;
    padding: 5px 8px 6px 8px;
    border-radius: 10px;
  }
  .cart_link_item_left_title {
    height: 20px;
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0 2px;
  }
  .cart_link_item_left_title::after {
    content: "";
    background: url("../img/img-common/cart_line.png") no-repeat left top/contain;
    width: 7px;
    height: 56px;
    position: absolute;
    top: 46px;
    left: 5px;
  }
  .cart_link_item_left_title p {
    color: #fff;
    font-size: 13px;
    text-align: left;
  }
  .cart_link_item_left_title_question {
    position: relative;
  }
  .cart_link_item_left_title_question img {
    height: 15px;
    padding: 1px 0 0 0;
  }
  #robot_wrap .cart_link_item_left_select {
    position: relative;
    margin-bottom: 10px;
  }
  #robot_wrap .cart_link_item_left_select::after {
    content: "";
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #333;
    border-right: 2px solid #333;
    position: absolute;
    top: 50%;
    right: 7px;
    transform: translateY(-50%) rotate(45deg);
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    pointer-events: none;
  }
  #robot_wrap .cart_link_item_left_select select {
    width: 100%;
    font-size: 1.1rem;
    padding: 2px 4px;
    border: 1px solid #ccc;
    border-radius: 0;
    background: #fff;
  }

  .cart_link_item_left dl {
    padding-left: 15px;
  }
  .cart_link_item_left dl:first-of-type {
    margin-bottom: 7px;
  }
  .cart_link_item_left dl dt {
    color: #fff;
    font-size: 12px;
    text-align: left;
    line-height: 1.2;
    padding-left: 3px;
  }
  .cart_link_item_left dl dd {
    color: #FFFF00;
    font-size: 17px;
    line-height: 1.3;
    text-align: left;
  }
  .cart_link_item_left dl dd span {
    font-size: 10px;
    font-weight: normal;
    padding-left: 2px;
  }
  .cart_link_item_right {
    width: 122px;
  }
  .cart_link_item_right_yoteibi {
    background: #333;
    padding: 5px 5px 2px 5px;
    border-radius: 10px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .cart_link_item_right_yoteibi p {
    color: #fff;
    font-size: 13px;
    text-align: left;
  }
  .cart_link_item_right_yoteibi_question {
    position: relative;
  }
  .cart_link_item_right_yoteibi_question img {
    height: 15px;
    padding: 1px 0 0 1px;
  }
  #yoteibi {
    width: 100%;
    font-size: 17px;
    text-align: right;
  }
  /* ##### 有方追加 2024.03.05 ##### */
  #sendprice_kojin, #sendprice_jigyo {
    font-size: 17px;
  }
  #sendprice_kojin.sendprice_none, #sendprice_jigyo.sendprice_none {
    padding-left: 4px;
    font-size: 14px;
	letter-spacing: 0.08em;
  }
/*  #sendprice_kojin.sendprice_none + span, #sendprice_jigyo.sendprice_none + span {
    display: none;
  }*/
  /* ##### 有方追加 2024.03.05 ##### */
  #cart_link_btn, #toCart {
    margin-top: 5px;
  }
  #cart_link_btn span, #toCart span {
    width: 100%;
    height: 28px;
    border-radius: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.2;
    background: #ff6d12;
    transition: ease 0.5s;
  }
  #toCart span {
    background: #284b8a;
  }
  #cart_link_btn span:hover, #toCart span:hover {
    cursor: pointer;
    opacity: 0.7;
  }
  /* ------------------------
矢印
---------------------------*/
  #nekorobo .arrow {
    position: absolute;
    top: 34%;
    left: -17%;
  }
  /* エラーメッセージ
------------------------------*/
  #err_mes {
    background: #cc0000;
    display: block;
    padding: 20px 30px;
    border-radius: 10px;
    border: 3px solid #fff;
    opacity: 1;
    position: fixed;
    top: 20vh;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    width: 560px;
  }
  #err_mes h3 {
    color: #CC0000;
    background: #fff;
    border-radius: 100px;
    font-size: 1.6rem;
    text-align: center;
    font-weight: bold;
    line-height: 1.2;
    padding: 5px 0;
    margin: 0 0 15px 0;
  }
  #err_mes ul {
    color: #fff;
    padding: 0 15px;
    overflow: visible;
  }
  #err_mes ul li {
    font-size: 1.4rem;
    font-weight: bold;
    color: #fff;
    text-align: left;
  }
  #err_mes ul li:not(:last-of-type) {
    margin-bottom: 5px;
  }
  /* ------------------------
テキスト入力 幅・枠線・フォントサイズ  
---------------------------*/
  #item_field_item_input, #option_field_item_input, #grass_r_field_item_input, #eddge_field_item_input {
    width: 162px;
    padding: 5px;
    color: #333;
    font-size: 1.2rem;
    text-align: left;
    border: 1px solid #9ad5ff;
    border-radius: 4px;
  }
  #thickness_field_item_input {
    width: 68px;
    padding: 5px;
    color: #333;
    text-align: left;
    border: 1px solid #9ad5ff;
    border-radius: 4px;
    font-size: 14px;
  }
  #item_field_item_input:hover, #option_field_item_input:hover, #grass_r_field_item_input:hover, #eddge_field_item_input:hover, #thickness_field_item_input:hover {
    cursor: default;
  }
  #item_field_item_input::placeholder, #option_field_item_input::placeholder, #grass_r_field_item_input::placeholder, #eddge_field_item_input::placeholder, #thickness_field_item_input::placeholder {
    color: #333;
  }
  #item_field_item_input:focus, #option_field_item_input:focus, #grass_r_field_item_input:focus, #eddge_field_item_input:focus, #thickness_field_item_input:focus {
    outline: none;
  }
  body.is_hidden {
    /*  overflow: hidden;*/
  }
  #item_cover {
    opacity: 0;
    visibility: hidden;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.40);
    overflow-y: scroll;
    scrollbar-width: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10000;
    transition: 0.8s;
  }
  #item_cover.active {
    opacity: 1;
    visibility: visible;
  }
#item_cover__closeArea{
	opacity: 0;
    visibility: hidden;
	width: 100%;
	height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10001;
	background: transparent;
	}
  #item_cover.active #item_cover__closeArea{
    opacity: 1;
    visibility: visible;
  }
  #item_field_item_content, #option_field_item_content, #grass_r_field_item_content, #eddge_field_item_content, #thickness_field_item_content {
    position: relative;
    font-family: "Noto Sans JP", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    width: 670px;
    padding: 30px 0;
    background: #fff;
    border-radius: 18px;
    margin-top: 100px;
    margin-left: calc((100% - 960px) / 2);
    margin-bottom: 100px;
    opacity: 0;
    visibility: hidden;
    display: none;
    z-index: 11000;
    transition: 0.8s;
  }
  #item_field_item_content.active, #option_field_item_content.active, #grass_r_field_item_content.active, #eddge_field_item_content.active, #thickness_field_item_content.active {
    opacity: 1;
    visibility: visible;
    display: block;
  }
  #item_field_item_content .inner, #option_field_item_content .inner, #grass_r_field_item_content .inner, #eddge_field_item_content .inner, #thickness_field_item_content .inner {
    width: 604px;
    margin: auto;
  }
  /* タイトル */
  .item_field_item_content_title, .option_field_item_content_title, .grass_r_field_item_content_title, .eddge_field_item_content_title, .thickness_field_item_content_title {
    text-align: center;
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 25px;
  }
  .item_field_item_content_title span, .option_field_item_content_title span, .grass_r_field_item_content_title span, .eddge_field_item_content_title span, .thickness_field_item_content_title span {
    color: #00b2c1;
  }
  /* 厚さタイトル下テキスト */
  .thickness_field_item_content_text {
    text-align: center;
    margin-bottom: 20px;
  }
  .thickness_field_item_content_text span {
    position: relative;
    font-size: 14px;
    font-weight: bold;
    color: #16c2d1;
    padding-left: 1em;
  }
  .thickness_field_item_content_text span::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
  }
  /* 閉じるボタン */
  .item_modal_close.-button {
    width: 30px;
    height: 30px;
    border-radius: 100px;
    background: #16c2d1;
    position: absolute;
    top: 16px;
    right: 20px;
    cursor: pointer;
    transition: all .3s;
  }
  .item_modal_close.-button:hover {
    opacity: 0.8;
  }
  .item_modal_close.-button::before {
    content: "";
    background: #fff;
    width: 2px;
    height: 17px;
    position: absolute;
    top: 7px;
    left: 14px;
    transform: rotate(135deg);
  }
  .item_modal_close.-button::after {
    content: "";
    background: #fff;
    width: 2px;
    height: 17px;
    position: absolute;
    top: 7px;
    left: 14px;
    transform: rotate(-135deg);
  }
  /* 閉じるボタン（テキスト） */
  .item_modal_close.-text {
    text-align: center;
    padding: 50px 0 0;
  }
  .item_modal_close.-text span {
    font-size: 2.2rem;
    color: #00b2c1;
    position: relative;
    padding-left: 34px;
    cursor: pointer;
    transition: all .3s;
  }
  .item_modal_close.-text span:hover {
    opacity: 0.8;
  }
  .item_modal_close.-text span::before {
    content: "";
    background: #00b2c1;
    width: 3px;
    height: 24px;
    position: absolute;
    top: 7px;
    left: 14px;
    transform: rotate(135deg);
  }
  .item_modal_close.-text span::after {
    content: "";
    background: #00b2c1;
    width: 3px;
    height: 24px;
    position: absolute;
    top: 7px;
    left: 14px;
    transform: rotate(-135deg);
  }
  /* 選択項目ボタン */
  .item_button {
    position: relative;
    width: 600px;
    background: #eeffff;
    border: 2px solid #ccc;
    border-radius: 10px;
    box-shadow: 2px 5px 10px -4px #212121;
    transition: all .3s;
    cursor: pointer;
  }
  .item_button:hover {
    border: 2px solid #16c2d1;
  }
  .item_button:not(:last-of-type) {
    margin-bottom: 25px;
  }
  .item_button:has(input:checked) {
    width: 563px;
    border: 3px solid #16c2d1;
  }
  .item_button label {
    cursor: pointer;
  }
  .item_button input {
    position: absolute;
    top: 0;
    left: 0;
    -webkit-appearance: none;
    appearance: none;
  }
  .item_button_inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 8px 15px;
    text-align: left;
    padding: 13px 10px 20px 25px;
  }
  .item_button_inner_subtitle span {
    font-size: 15px;
    font-weight: bold;
    color: #fff;
    background: #284b8a;
    padding: 2px 10px 4px;
    border-radius: 5px;
  }
  .item_button_inner_title {
    font-size: 20px;
    font-weight: bold;
    color: #00b2c1;
    letter-spacing: 0.05em;
    line-height: 1.0;
    width: 100%;
  }
  .item_button_inner_title span {
    font-size: 16px;
    padding-left: 10px;
  }
  .item_button_inner_image img {
    width: 100px;
    height: auto;
    margin-left: 20px;
  }
  .item_button_inner_textarea {
    position: relative;
    width: 420px;
  }
  .item_button_inner_textarea_text {
    font-size: 14px;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
  }
  .item_button_inner_textarea_list {
    font-size: 14px;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
  }
  .item_button_inner_textarea_button {
    font-size: 16px;
    font-weight: bold;
    color: #fff;
    line-height: 1.0;
    letter-spacing: 0.05em;
    background: #16c2d1;
    width: 100px;
    height: 25px;
    padding-bottom: 2px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100px;
    margin-left: auto;
  }
  /* オプション オプション組み合わせ
	強化ガラス ＋ 飛散防止フィルム
	高透過ガラス ＋ 飛散防止フィルム
	透明ガラス(フロートガラス)＋飛散防止フィルム
	スリガラス＋飛散防止フィルム
	フロストガラス＋飛散防止フィルム
	スモークガラス(グレー)＋飛散防止フィルム
	スモークガラス(ブロンズ)＋飛散防止フィルム
	スモークガラス(グリーン)＋飛散防止フィルム
	*/
	.item_button:has(#option_field_item_transparent_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_transparent_hightrancesplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_transsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_surisplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_frostsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smokegraysplash) .item_button_inner_image img,
	.item_button:has(#option_field_item_smokebronzesplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smokegreensplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_suri_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_flost_temperedsplash) .item_button_inner_image img, 
	.item_button:has(#option_field_item_smoke_temperedsplash) .item_button_inner_image img{
    width: 213px;
  }
	.item_button:has(#option_field_item_transparent_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_transparent_hightrancesplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_transsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_surisplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_frostsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smokegraysplash) .item_button_inner_textarea,
	.item_button:has(#option_field_item_smokebronzesplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smokegreensplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_suri_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_flost_temperedsplash) .item_button_inner_textarea, 
	.item_button:has(#option_field_item_smoke_temperedsplash) .item_button_inner_textarea{
    width: 310px;
  }
  /* 鏡の形 選択ボタン */
  #grass_r_field_item_content .item_button_inner_textarea_button {
    margin-top: -36px;
  }
  #grass_r_field_item_content .item_button {
    position: relative;
    z-index: 100;
  }
  #grass_r_field_item_content .item_button_list {
    position: relative;
    margin-top: -5px;
  }
  #grass_r_field_item_content .item_button_list::before {
    content: "";
    background: url("../img/img-common/grass_r_field_item_bg_pc.png") no-repeat left top/contain;
    width: 61px;
    height: 1742px;
    position: absolute;
    top: -19px;
    left: 94px;
  }
  #grass_r_field_item_content .item_button_list .item_button:first-of-type .item_button_inner_textarea_mm{
    width: 160px;
  }	
  #grass_r_field_item_content .item_button_list .item_button:first-of-type .item_button_inner_textarea_mm strong{
    font-size: 16px;
	line-height: 1.0;
  }
  #grass_r_field_item_content .item_button_list .item_button_inner_textarea_button {
    margin-top: 0px;
  }
	
	
	
	
	
	
	
  /* エッジ加工 選択ボタン */
  #eddge_field_item_content .item_button_inner_textarea_button {
    margin-top: -36px;
  }
  .item_button_inner_textarea_eddge {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0 25px;
    margin-top: -40px;
  }
  .item_button_inner_textarea_mm {
    font-size: 16px;
    color: #00b2c1;
    line-height: 1.0;
    background: #fff;
    border: 1px solid #16c2d1;
    width: 110px;
    height: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .item_button_inner_textarea_mm strong {
    font-size: 20px;
  }
  #eddge_field_item_content .item_button_inner_textarea_eddge .item_button_inner_textarea_button {
    margin: 0px;
  }
  #eddge_field_item_content .item_button {
    position: relative;
    z-index: 100;
  }
  .item_button_list {
    position: relative;
    margin-top: -5px;
  }
  .item_button_list::before {
    content: "";
    background: url("../img/img-common/eddge_field_item_bg_pc.png") no-repeat left top/contain;
    width: 61px;
    height: 665px;
    position: absolute;
    top: -19px;
    left: 94px;
  }
  .item_button_list .item_button {
    width: 450px;
    margin-left: auto;
  }
  .item_button_list .item_button:has(input:checked) {
    width: 428px;
    border: 3px solid #0080FF;
  }
  .item_button_list .item_button:not(:last-of-type) {
    margin-bottom: 19px;
  }
  .item_button_list .item_button_inner {
    padding: 12px 20px 12px 0;
    justify-content: flex-end;
  }
  .item_button_list .item_button .item_button_inner_textarea_eddge {
    margin: 0px;
  }
  /* 厚さ 選択ボタン */
  #thickness_field_item_content .item_button_inner_textarea_button {
    margin-top: -36px;
  }
}

  /*===================================
  
  スマホ用定点ボタン

===================================*/
#close_btn {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  bottom: -40px;
  right: -15px;
  z-index: 9999;
  transition: 0.8s;
}
#close_btn.active {
  visibility: visible;
  opacity: 1;
  bottom: -25px;
}
#close_btn img{
    height: 38px;
}
#open_btn {
  position: fixed;
  bottom:80px;
  right: -18px;
  display: none;
    z-index: 9999;
}
#open_btn.active {
  display:block;
}
#open_btn img{
    height: 136px;
}
.no_rightContent #open_btn{
    display: none;
}
@media screen and (min-width: 992px) {    
	#close_btn, #open_btn {
		display: none;
	}
}

/*------------------------------------
cover
------------------------------------*/
#cover {
  opacity: 0;
  visibility: hidden;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.40);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3000;
  transition: 0.8s;
}
#cover.active{
  opacity: 1;
  visibility: visible;
}
  /*===================================
  
  中央カラム

===================================*/
  #centerContent {
    margin-top: 84px;
  }
.media #centerContent {
  margin: 90px 0 !important;
}
@media screen and (min-width: 992px) {
  #centerContent {
    width: 710px;
    padding: 0;
    margin-top: 78px;
  }
  .no_rightContent #centerContent {
    width: 980px;
    padding: 0;
    margin-top: 78px;
  }
  .media #centerContent {
    width: 980px;
    padding: 0 10px;
    margin: 110px 0 140px !important;
  }
  }
@media screen and (max-width: 1180px) {
  .media #centerContent {
	overflow-x: hidden;
  }
}
/*===================================
  
  フッター

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

/* ------------------------
3つの特長
---------------------------*/
.footer__feature {
  background: #77c2fe;
  padding: 30px 0 30px;
}
.footer__feature__ttl {
  font-size: 1.8rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  line-height: 1.1;
  margin-bottom: 15px;
  letter-spacing: 0.05em;
  position: relative;
}
.footer__feature__ttl::before {
  content: "";
  background: url("../img/img-common/ico_23.png") no-repeat left top/contain;
  width: 129px;
  height: 128px;
  position: absolute;
  top: -80px;
  right: 5px;
}
.footer__feature__ttl span {
  font-size: 1.6rem;
  display: block;
}
.footer__feature__ttl strong {
  letter-spacing: 0.2em;
}
.footer__feature__ttl strong i {
  font-size: 3.0rem;
  font-style: normal;
}
.footer__feature ul {
  width: 100%;
  margin: auto;
}
.footer__feature ul li:not(:last-of-type) {
  margin-bottom: 25px;
}
@media screen and (min-width: 992px) {
  .footer__feature {
    padding: 50px 0 30px;
  }
  .footer__feature__ttl {
    font-size: 2.8rem;
    margin-bottom: 30px;
  }
  .footer__feature__ttl::before {
    width: 240px;
    height: 238px;
    top: -30px;
    right: -20px
  }
  .footer__feature__ttl span {
    font-size: 2.0rem;
  }
  .footer__feature__ttl strong i {
    font-size: 4.8rem;
  }
  .footer__feature ul {
    width: 100%;
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 0 20px;
  }
  .footer__feature ul li:not(:last-of-type) {
    margin-bottom: 25px;
  }
}
/* ------------------------
お問い合わせ
---------------------------*/
.footer__contact {
  background: #a5d9fe;
  padding: 30px 0;
}
.footer__contact__content {
  background: #fff;
  border-radius: 14px;
  padding: 20px 5% 25px;
  box-shadow: 3px 3px 15px -5px #76b6e2
}
.footer__contact__content__title {
  font-size: 1.6rem;
  font-weight: bold;
  color: #26a1fb;
  text-align: center;
  line-height: 1.3;
  margin-bottom: 10px;
}
.footer__contact__content__title span {
  position: relative;
  display: inline-block;
}
.footer__contact__content__title span::before {
  content: "";
  background: url("../img/img-common/ico_deco_left.png") no-repeat left top/contain;
  width: 30px;
  height: 29px;
  position: absolute;
  bottom: 5px;
  left: -50px;
}
.footer__contact__content__title span::after {
  content: "";
  background: url("../img/img-common/ico_deco_right.png") no-repeat left top/contain;
  width: 30px;
  height: 29px;
  position: absolute;
  bottom: 5px;
  right: -50px;
}
.footer__contact__content__text {
  font-size: 1.1rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 6px;
}
.footer__contact__content__tel {
  position: relative;
  padding-left: 23%;
  margin-bottom: 15px;
}
.footer__contact__content__tel::before {
  content: "";
  background: url("../img/img-common/ico_nekorobo_inquiry.png") no-repeat left top/contain;
  width: 56px;
  height: 71px;
  position: absolute;
  top: 6px;
  left: 0;
}
.footer__contact__content__tel dt a {
  font-size: 2.0rem;
  font-weight: bold;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0 7px;
}
.footer__contact__content__tel dt a img {
  height: 28px;
  margin-top: 2px;
}
.footer__contact__content__tel dd {
  font-size: 0.9rem;
  line-height: 1.4;
  margin-top: -3px;
}
.footer__contact__content__list {
  width: 87%;
  margin: 0 auto;
}
.footer__contact__content__list li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 43px;
  background: #559ee7;
  border-radius: 8px;
}
.footer__contact__content__list li a::before {
  content: "";
  background: url("../img/img-common/ico_mail.png") no-repeat left top/contain;
  width: 22px;
  height: 16px;
  position: absolute;
  top: 55%;
  left: 8%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
.footer__contact__content__list li a::after {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 45%;
  right: 6%;
}
.footer__contact__content__list li a span {
  font-size: 1.2rem;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.1em;
}
.footer__contact__content__list__form {
  margin-bottom: 10px;
}
li.footer__contact__content__list__line a {
  background: #01b902;
}
li.footer__contact__content__list__line a::before {
  content: "";
  background: url("../img/img-common/ico_line.png") no-repeat left top/contain;
  width: 28px;
  height: 28px;
  position: absolute;
  top: 50%;
  left: 7%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
@media screen and (min-width: 992px) {
  .footer__contact {
    padding: 50px 0;
  }
  .footer__contact__content {
    width: 940px;
    margin: auto;
    padding: 40px 0;
  }
  .footer__contact__content__title {
    font-size: 2.6rem;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
  }
  .footer__contact__content__text {
    font-size: 1.6rem;
    margin-bottom: 10px;
  }
  .footer__contact__content__tel {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 25px;
    padding-left: 50px;
    margin-bottom: 15px;
  }
  .footer__contact__content__tel::before {
    width: 84px;
    height: 106px;
    top: -47px;
    left: 65px;
  }
  .footer__contact__content__tel dt a {
    font-size: 4.2rem;
    gap: 0 10px;
  }
  .footer__contact__content__tel dt a img {
    height: 43px;
    margin-top: 6px;
  }
  .footer__contact__content__tel dd {
    font-size: 1.5rem;
    margin-top: 0;
  }
  .footer__contact__content__list {
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 0 50px;
  }
  .footer__contact__content__list li a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 350px;
    height: 70px;
    background: #559ee7;
    border-radius: 8px;
  }
  .footer__contact__content__list li a::before {
    width: 29px;
    height: 20px;
    top: 53%;
    left: 8%;
  }
  .footer__contact__content__list li a::after {
    width: 13px;
    height: 13px;
  }
  .footer__contact__content__list li a span {
    font-size: 2.0rem;
    letter-spacing: 0em;
  }
  .footer__contact__content__list__form {
    margin-bottom: 10px;
  }
  li.footer__contact__content__list__line a {
    background: #01b902;
  }
  li.footer__contact__content__list__line a::before {
    background: url("../img/img-common/ico_line.png") no-repeat left top/contain;
    width: 40px;
    height: 40px;
  }
}
/* ------------------------
バナーエリア 1
---------------------------*/
.footer__linkArea_01 {
  background: #D7E9FB;
  padding: 20px 0;
}
.footer__linkArea_01 ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px 0;
  width: 85%;
  margin: auto;
}
.footer__linkArea_01 ul li {
  width: 47%;
  text-align: center;
}
.footer__linkArea_01 ul li a {
  text-decoration: underline;
}
.footer__linkArea_01 ul li a span {
  font-size: 0.9rem;
  letter-spacing: 0;
}
@media screen and (min-width: 992px) {
  .footer__linkArea_01 {
    padding: 30px 0;
  }
  .footer__linkArea_01 ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 15px 0;
    width: 85%;
    margin: auto;
  }
  .footer__linkArea_01 ul li {
    width: 180px;
  }
  .footer__linkArea_01 ul li a img {
    max-width: 100%;
  }
  .footer__linkArea_01 ul li a span {
    font-size: 1.3rem;
	letter-spacing: 0.05em;
  }
  .footer__linkArea_01 ul li a:hover {
    text-decoration: none;
  }
}
/* ------------------------
バナーエリア 2
---------------------------*/
.footer__linkArea_02 {
  padding: 30px 0;
}
.footer__linkArea_02 .inner {
  padding: 0 4%;
}
.footer__linkArea_02__title {
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 15px;
}
.footer__linkArea_02 ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px 0;
}
.footer__linkArea_02 ul li {
  width: 47%;
}
.footer__linkArea_02 ul li:last-of-type {
  width: 100%;
}
@media screen and (min-width: 992px) {
  .footer__linkArea_02 {
    background: #fff;
    padding: 30px 0 50px;
  }
  .footer__linkArea_02 .inner {
    padding: 0;
  }
  .footer__linkArea_02__title {
    font-size: 2.0rem;
    margin-bottom: 15px;
  }
  .footer__linkArea_02 ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 0 15px;
  }
  .footer__linkArea_02 ul li {
    width: auto;
  }
  .footer__linkArea_02 ul li:last-of-type {
    width: auto;
  }
}
/* ------------------------
SNSエリア
---------------------------*/
.footer__snsArea {
  padding: 30px 0;
  background: #F7F7F7;
}
.footer__snsArea .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
}
.footer__snsArea__title {
  width: 100%;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 15px;
}
.footer__snsArea ul {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 10px 0;
}
.footer__snsArea ul li a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0 10px;
}
.footer__snsArea ul li a img {
  height: 50px;
}
@media screen and (min-width: 992px) {
  .footer__snsArea {
    padding: 30px 0 50px;
  }
  .footer__snsArea .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
  }
  .footer__snsArea__title {
    font-size: 2.0rem;
    margin-bottom: 15px;
  }
  .footer__snsArea ul {
    width: 730px;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 10px 0;
  }
  .footer__snsArea ul li {
    width: 50%;
  }
  .footer__snsArea ul li a {
    font-size: 1.3rem;
    letter-spacing: 0;
  }
  .footer__snsArea ul li a:hover {
    text-decoration: underline;
  }
}
/* ------------------------
スマホ用フッターリンク
---------------------------*/
.footer__spLink {
  background: #E7F6FF;
  border-top: 4px solid #4FA6FD;
  border-bottom: 4px solid #4FA6FD;
}
.footer__spLink nav ul li:not(:last-of-type) {
  border-bottom: 1px dotted #ccc;
}
.footer__spLink nav ul li a {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  height: 48px;
  padding: 0 0 0 6%;
  font-size: 1.2rem;
}
.footer__spLink nav ul li a::after {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #4FA6FD;
  border-right: 2px solid #4FA6FD;
  transform: rotate(45deg);
  position: absolute;
  top: 42%;
  right: 6%;
}
/* ------------------------
テキストエリア
---------------------------*/
.footer__content {
  padding: 25px 0 0;
}
.footer__content__textArea__payment {
  font-size: 1.0rem;
  text-align: center;
  margin-bottom: 30px;
}
.footer__content__textArea__logo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 25px;
}
.footer__content__textArea__logo a {
  position: relative;
}
.footer__content__textArea__logo a img{
    height: 62px;
}
.footer__content__textArea__logo__text {
  font-size: 1.0rem;
  font-weight: bold;
  color: #16c2d1;
  position: absolute;
  bottom: 0;
  left: 32%;
}
.footer__content__textArea__company {
  font-size: 1.2rem;
  margin-bottom: 20px;
}
.footer__content__textArea__company__tel a {
  font-size: 1.3rem;
  text-decoration: underline;
}
.footer__content__textArea__company__tel a img {
  height: 20px;
  margin: 2px 5px 0 0;
}
.footer__content__textArea__company__tel span {
  font-size: 0.9rem;
  letter-spacing: -0.01em;
  padding-left: 8px;
}
@media screen and (min-width: 992px) {
  .footer__content {
    background: #E7F6FF;
    border-top: 4px solid #4FA6FD;
    padding: 25px 0 0;
  }
  .footer__content .inner {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0 210px;
  }
  .footer__content__linkArea nav {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0 40px;
  }
  .footer__content__linkArea nav ul {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 6px 0;
  }
  .footer__content__linkArea nav ul li a {
    position: relative;
    font-size: 1.3rem;
    padding-left: 0.8em;
    text-decoration: underline;
  }
  .footer__content__linkArea nav ul li a::before {
    content: "";
    border-style: solid;
    border-width: 4px 0 4px 5px;
    border-color: transparent transparent transparent #0157AD;
    position: absolute;
    top: 55%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }
  .footer__content__linkArea nav ul li a:hover {
    text-decoration: none;
  }
  .footer__content__textArea__payment {
    font-size: 1.2rem;
    text-align: left;
    margin-bottom: 70px;
  }
  .footer__content__textArea__payment p {
    margin-bottom: 5px;
  }
  .footer__content__textArea__logo {
    justify-content: flex-start;
    margin-bottom: 15px;
  }
  .footer__content__textArea__logo a {
    padding-bottom: 0px;
  }
  .footer__content__textArea__logo__text {
    font-size: 1.1rem;
  }
  .footer__content__textArea__company {
    font-size: 1.3rem;
    margin-bottom: 40px;
  }
  .footer__content__textArea__company__tel a {
    font-size: 1.8rem;
    font-weight: bold;
    text-decoration: none;
  }
  .footer__content__textArea__company__tel a img {
    height: 22px;
    margin: 3px 5px 0 0;
  }
  .footer__content__textArea__company__tel span {
    font-size: 1.1rem;
	letter-spacing: 0;
    padding-left: 8px;
  }
}
/* ------------------------
コピーライト
---------------------------*/
.copyright {
  background: #0157AD;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.copyright small {
  color: #fff;
  line-height: 1.0;
}
.copyright small a {
  color: #fff;
  text-decoration: none;
}
/*===================================
  
  ページトップ

===================================*/
.pagetop {
  width: 46px;
  height: 46px;
  position: fixed;
  bottom: 50px;
  right: 20px;
  transition: opacity 1s;
  opacity: 0;
  cursor: pointer;
  z-index: 10000;
}
.pagetop.is_active {
  opacity: 1;
}
@media screen and (max-width: 991px) {
  .pagetop {
    width: 35px;
    height: 35px;
    bottom: 30px;
    right: 10px;
    z-index: 99;
  }
}
/*===================================
  
  計算機ツールチップ

===================================*/
@media screen and (max-width: 991px) {
  .tooltip_cart_link {
    display: none;
  }
}
@media screen and (min-width: 992px) {
  .tooltip_cart_link {
    visibility: hidden;
    opacity: 0;
    border: 4px solid #0080ff;
    background: #fff;
    color: #000;
    border-radius: 15px;
    padding: 15px;
    position: fixed;
    top: 340px;
    right: calc((100vw - 1180px) / 2);
    width: 275px;
    z-index: 9999;
    transition: 0.3s;
  }
  .tooltip_cart_link.long {
    width: 430px;
  }
  .tooltip_cart_link::after {
    content: "";
    background: url("../img/img-common/bg_arrow_03.png") no-repeat left top/contain;
    width: 23px;
    height: 36px;
    position: absolute;
    bottom: -36px;
    right: 11px;
    transform: translateX(0%);
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
  }
  .tooltip_cart_link h3 {
    font-size: 1.4rem;
    font-weight: bold;
  }
  .tooltip_cart_link .blue {
    color: #0377ea;
  }
  .tooltip_cart_link p {
    font-size: 1.3rem;
  }
  .tooltip_cart_link h3 + p {}
  .tooltip_cart_link ul {
    margin-bottom: 10px;
  }
  .tooltip_cart_link ul li {
    position: relative;
    padding-left: 12px;
    font-size: 1.3rem;
    line-height: 1.5;
    text-align: left;
  }
  .tooltip_cart_link ul li::before {
    content: "";
    width: 6px;
    height: 6px;
    background: #0080ff;
    border-radius: 100px;
    position: absolute;
    left: 0;
    top: 0.5em;
  }
  .tooltip_cart_link ul li:not(:last-of-type) {
    margin-bottom: 8px;
  }
  .tooltip_cart_link .txt_attention {
    padding-left: 26px;
    font-size: 1.3rem;
    text-align: left;
    margin: 0 0 10px 0;
  }
  .tooltip_cart_link .txt_attention strong {
    position: relative;
    color: #ff0000;
    padding: 0 5px 4px;
    background-image: linear-gradient(#ffff15, #ffff15);
    background-size: 98% 60%;
    background-position: 0 110%;
    background-repeat: no-repeat;
  }
  .tooltip_cart_link .txt_attention strong::before {
    content: "";
    width: 22px;
    height: 22px;
    background: url("../img/img-common/ico_exclamation.png") no-repeat left top/contain;
    position: absolute;
    left: -24px;
    top: 2px;
  }
  .tooltip_cart_link .txt_attention + p {
    color: #ff0000;
    font-size: 1.3rem;
    font-weight: bold;
    margin: 0 0 10px 0;
    text-align: left;
    padding: 0 0 0 28px;
  }
  #tooltip_estimate {
    right: calc((100vw - 1180px) / 2 - 18px);
  }
  #tooltip_estimate.active {
    top: 350px;
    visibility: visible;
    opacity: 1;
  }
  #tooltip_postage {
    top: 110px;
    right: calc((100vw - 1180px) / 2 - 18px);
  }
  #tooltip_postage.active {
    top: 122px;
    visibility: visible;
    opacity: 1;
  }
  #tooltip_postage.tooltip_cart_link {
    width: 385px;
  }
  #tooltip_postage.tooltip_cart_link::after {
    right: 179px;
  }
  #tooltip_postage.tooltip_cart_link h3, #tooltip_postage.tooltip_cart_link p {
    text-align: center;
    margin-bottom: 10px;
  }
  #tooltip_shippingDate {
    top: 206px;
    right: calc((100vw - 1180px) / 2 - 18px);
  }
  #tooltip_shippingDate.active {
    top: 216px;
    visibility: visible;
    opacity: 1;
  }
  #tooltip_shippingDate.tooltip_cart_link {
    width: 370px;
  }
  #tooltip_shippingDate.tooltip_cart_link::after {
    right: 19px;
  }
  #tooltip_shippingDate.tooltip_cart_link h3, #tooltip_shippingDate.tooltip_cart_link p {
    margin-bottom: 10px;
  }
}