﻿@charset "UTF-8";

/* ================
      共通
=================*/
.pc-only{display: none;}

#ginellia_monitor{
  background: #FFF1E9;
  padding: 91px 0 0 0;
  color: #6D2B22;
}

#ginellia_monitor img{vertical-align: bottom;}

.text-marker {
  background-image: linear-gradient(transparent 0%, #FFFBD0 0%, #FFFBD0 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  font-weight: 600;
}

.em{
  color: #D10049;
  font-weight: 600;
  font-size: 19px;
}
.gm-btn{margin-top: 20px;}

/* -------ボタン-------- */
.gm-qsa-btn a,
.gm-btn a{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  background: #D10049;
  border-radius: 100px;
  font-weight: 600;
  width: 100%;
  height: 48px;
  font-size: 16px;
}

.gm-qsa-btn-area .gm-qsa-btn-ttl{
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  margin-top: 10px;
  margin-bottom: 8px;
}

.gm-qsa-btn-area .gm-qsa-btn-ttl span{
  position: relative;
  display: inline-block;
  padding: 10px 40px;
  color: #D10049;
}  

.gm-qsa-btn-area .gm-qsa-btn-ttl span:after,
.gm-qsa-btn-area .gm-qsa-btn-ttl span::before{
  position: absolute;
  content: "";
  top: 50%;
  width: 24px;
  height: 34px;
  transform: translate(0, -50%);  
}

.gm-qsa-btn-area .gm-qsa-btn-ttl span:after{
  left: 0;
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_lt.png) no-repeat;
  background-size: auto;
  background-size: 24px auto;
}

.gm-qsa-btn-area .gm-qsa-btn-ttl span:before{
  right: 0;
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_rt.png) no-repeat;
  background-size: auto;
  background-size: 24px auto;
}

/* -------タイトル-------- */
h2{
  text-align: center;
  font-size: 24px;
}
h2 span{
  position: relative;
  display: inline-block;
  padding: 10px 40px;
  color: #D10049;
}

h2 span:after,
h2 span:before{
  position: absolute;
  content: "";
  top: 50%;
  width: 24px;
  height: 34px;
  transform: translate(0, -50%);
}

h2 span:after{
  left: 0;
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_lt.png) no-repeat;
  background-size: 24px auto;
}

h2 span:before{
  right: 0;
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_rt.png) no-repeat;
  background-size: 24px auto;
}

.sec02 h2 span:after{
  top: 60%;
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_lt_w.png) no-repeat;
  background-size: 24px auto;
}

.sec02 h2 span:before{
  top: 60%;  
  background: url(../../../../img/usr/freepage/ginellia_monitor/title_deco_rt_w.png) no-repeat;
  background-size: 24px auto;
}

.sec02 h2 span{color: #fff;}

h3 {
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  color: #D10049;
}

h3 p {
  position: relative;
  display: inline-block;
  padding: 10px 40px;
}

h3 p::before,
h3 p::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 35px;
  height: 1px;
  border-radius: 50%;
  background-image: radial-gradient(circle, #D10049 1px, transparent 1px);
  background-size: 6px 1px;
  background-repeat: repeat-x;
}

h3 p::before {
  left: 0;
}

h3 p::after {
  right: 0;
}

/* -------font-------- */
.gm-text-b{font-size: 24px;}
.gm-text-l{font-size: 20px;}
.gm-text-m{font-size: 16px;}  
.gm-text-n{font-size: 14px;}
.gm-text-s{font-size: 12px;}

/* -------リスト-------- */
.gm-list li {
  position: relative;
  padding-left: 15px;
  margin-bottom: 4px;
}

.gm-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: calc(2em / 2 - 4px);
  width: 4px;
  height: 4px;
  background-color: #333;
  border-radius: 50%;
}

/* -------矢印-------- */
.gm-step-arrow{width: 100%;}
.gm-step-arrow .gm-step-arrow{
  position: relative;
  text-align: center;
  text-indent: -9999px;
  width: 100px;
  height: 32px;
  margin: 0 auto;
} 

.gm-step-arrow .gm-step-arrow:after{
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25px 40px 0 40px;
  border-color: #6D2B22 transparent transparent transparent;  
}

.gm-step-arrow .gm-step-arrow.gm-step-arrow-p1:after{border-color: #FFEAEC transparent transparent transparent;}
.gm-step-arrow .gm-step-arrow.gm-step-arrow-p2:after{border-color: #FFDDE0 transparent transparent transparent;}

/* -------mv-------- */
.gm-mv-inner{padding: 10px 0 40px;}
.gm-mv-ttl{
  margin-bottom: 40px;
  padding: 0 5px;
}

.gm-mv-main{
  background: #fff;
  border-radius: 40px;
  text-align: center;
  padding: 0 0 23px;
  margin: 0 15px;
}

.gm-mv-main .gm-mv-img img{
  margin-top: -50px;
  width: 65vw;
}

.gm-mv-text img{width: 45vw;}

/* -------モニター期間-------- */
.gm-period{
  text-align: center;
  padding: 10px 10px;
}

.gm-mv-inner .gm-period{
  background: #D10049;
  color: #fff;
  margin: 20px 15px 0;  
  border-radius: 100px;  
}

.gm-period .gm-period-ttl{
  display: inline-block;
  background: #FEE9DC;
  color: #D10049;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  padding: 3px 8px;
}

.gm-period .gm-period-day{
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gm-period .gm-period-day .ymd{
    font-size: 17px;
    font-weight: 500;
}

.gm-period .gm-period-day .gm-week{
    font-size: 14px;
    font-weight: 500;
}

.gm-period .gm-period-day .gm-time{
  font-size: 17px;
  font-weight: 500;
  margin-left: 4px;
}

.gm-period .gm-period-desc{
    font-size: 12px;
    font-weight: 500;
}

.gm-lead{
  text-align: center;
  margin-top: 0;
}

.gm-lead .gm-text-l{
  font-weight: 600;
  color: #D10049;
}

.gm-lead .gm-text-b{
  font-weight: 600;
  color: #D10049;
  margin-top: 8px;
}

.gm-lead .gm-nomal-text{
  margin-top: 12px;
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  color: #6D2B22;
}

.gm-lead .gm-nomal-text span{
  color: #D10049;
  font-weight: 600;  
}

.gm-qsa-list-inner{
  display: flex;
  justify-content: center;
}

.gm-qsa-list{
  position: relative;
  padding: 30px 0 30px;
  color: #6D2B22;
  display: inline-grid;  
  gap: 10px;
  text-align: left;
  margin: 20px 0 0 0;
}

.gm-qsa-list p{
  font-size: 20px;
  font-weight: 600;
  text-align: left;
}

.gm-qsa-list:before{top: 0;}
.gm-qsa-list:after{bottom: 0;}

.gm-qsa-list:after,
.gm-qsa-list:before{
  position: absolute;
  left: 50%;
  content:"・・・・・・・";
  font-size: 14px;
  color: #6D2B22;
  transform: translate(-50%, 0);
  font-weight: 600;
}

.gm-info{
  margin: 22px 15px 0;
  background: #fff;
  border-radius: 12px;
  border: solid 1px #C8887D;
  padding: 20px 15px;
  color: #333;
  font-size: 16px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.gm-info .gm-info-ttl{
  font-size: 26px;
  font-weight: 600;
  color: #6D2B22;
}

.gm-info .gm-info-desc{
  margin-top: 20px;
  font-size: 12px;
  color: #707070;
}

.gm-info ul{
  margin-top: 20px;
}

.gm-info li{
  position: relative;
  padding-left: 30px;
  margin-bottom: 16px;
  font-size: 16px;
  font-weight: 500;
}

.gm-info li:last-child{margin-bottom: 0;}
.gm-info li:after{
  content: '';
  position: absolute;
  left: 0;
  top: 2px;
  width: 22px;
  height: 22px;
  background: url(../../../../img/usr/freepage/ginellia_monitor/check.png) no-repeat;
  background-size: 22px auto;
}

.gm-info li span.text-marker{color: #D10049;}

.gm-msg{
  text-align: center;
  margin-top: 20px;
}

.gm-msg .gm-text-m{
  font-weight: 500;
}

.gm-msg .gm-text-l{
  font-weight: 600;
  margin-top: 8px;
}

/* -------sec02-------- */
.sec02 .gm-cont-inner{
  padding: 30px 15px 38px;
  margin-top: 30px;
  background: linear-gradient(to top, #FEF4CD 0%, #DB3465 70%, #D10049 100%);
}

.sec02 .gm-ttl-sub{
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
}

.sec02 h2{color: #fff;}
.sec02 .gm-period{
  color: #6D2B22;
  font-weight: 500;
}

.sec02 .gm-period .gm-period-desc{
  font-size: 12px;
  font-weight: 500;  
}


.sec02 .gm-limited{
  text-align: center;
  padding: 4px 0;
}

.sec02 .gm-limited p{
  padding: 3px 15px 4px;
  display: inline-block;
  background: #D10049;
  border-radius: 8px;
  color: #fff;
}

.sec02 .gm-limited p span:nth-child(1){
  font-size: 16px;
  font-weight: 600;
}

.sec02 .gm-limited p span:nth-child(2){
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
}

.sec02 .gm-limited p span:nth-child(3){
  font-size: 14px;
  font-weight: 600;
}

.sec02 .gm-limited p span:nth-child(4){
  font-size: 16px;
  font-weight: 600;
}

.sec02 .gm-text-nomal-m{
  text-align: center;
  font-size: 16px;
  font-weight: 500;
  margin-top: 8px;
  line-height: 1.6;
}

.sec02 .gm-text-nomal-s{
  font-size: 14px;
  margin-top: 8px;
  line-height: 1.8;
  color: #6D2B22;
}

.sec02 .gm-wrap{
  padding: 20px 0;
  background: #FFF8F4;
  border-radius: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

.sec02 .gm-box{
  padding: 0 20px;
  width: 100%;
}
.sec02 .gm-box.gm-box-s{padding: 0 10px;}

.sec02 .gm-box-img{
  margin-top: 10px;
}

.sec02 .fukidashi-ttl {
  width: 100%;
  position: relative;
  background: #6D2B22;
  color: #fff;
  padding: 8px 10px 10px;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
}

.sec02 .fukidashi-ttl + .gm-box-step-line{margin-top: 16px;}
.sec02 .fukidashi-ttl::after {
  content: '';
  position: absolute;
  top: 98%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 25px 0 25px;
  border-color: #6D2B22 transparent transparent transparent;
}

.sec02 .gm-text-body{
  margin-top: 28px;
  border-radius: 10px;
  background: #fff;
}

.sec02 .gm-list{
  margin-top: 10px;
  padding: 0 5px;
  color: #6D2B22;
}

/* step */
.sec02 .gm-step-sub-ttl{text-align: center;}
.sec02 .gm-step-sub-ttl span{
  position: relative;
  display: inline-block;
  position: relative;
  border-bottom: 1px solid #D10049;
  padding: 0 0 5px;
  font-size: 14px;
  font-weight: 600;
  color: #D10049;
}

.sec02 .gm-step-sub-ttl span:after{
content: '';
  position: absolute;
  top: 96%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 10px 0 10px;
  border-color: #fff transparent transparent transparent;
}

.sec02 .gm-step-sub-ttl span::before{
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 10px 0 10px;
  border-color: #D10049 transparent transparent transparent;
}

.sec02 .gm-step-ttl{
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  color: #6D2B22;
}

.sec02 .gm-step-ttl span{color: #D10049;}
.sec02 .gm-step-sub-ttl + .gm-step-ttl{margin-top: 15px;}
.sec02 .gm-box-step-inner{
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  padding: 0 20px;
}

.sec02 .gm-box-step-line > p{
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  margin-top: 16px;
  color: #6D2B22;  
}

.sec02 .gm-box-step-line{
  position: relative;
  padding: 45px 15px 20px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 2px 1px 7px rgba(0, 0, 0, .08);
  width: 100%;
}

.sec02 .gm-box-step-line.gm-box-step-line-scroll{padding: 40px 0 20px;}
.sec02 .gm-box-step-line.gm-box-step-line-4,
.sec02 .gm-box-step-line.gm-box-step-line-5{margin-top: 30px;}

.sec02 .gm-box-step-line .gm-step-num{
  position: absolute;
  left: 0;
  top: 0;
  width: 80px;
  height: 42px;
  background: #FEE9DC;
  border-radius: 10px 0 10px;
}

.sec02 .gm-box-step-line .gm-step-num p {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 78px;
  height: 40px;
  border-radius: 10px 0 10px;
  border-right: solid 1px #CC0047;
  border-bottom: solid 1px #CC0047;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: #D10049;
}

.sec02 .gm-box-step-line .gm-step-num p span{
  font-size: 16px;
  font-weight: 600;
  display: inline-block;
  margin-left: 4px;
}

.sec02 .gm-step-desc{
  color: #707070;
  font-size: 10px;
  font-weight: 400;
  text-align: center;
  margin-top: 12px;
}
.sec02 .gm-box-step-scroll{
  margin-top: 16px;
  padding: 0 0 0 15px;
}
.sec02 .gm-box-step-scroll ul {
    display: flex;
    list-style: none;
}

.sec02 .gm-box-step-scroll li {
    position: relative;
    flex: 0 0 240px;
    margin: 0 18px 0 0;    
  }

.sec02 .gm-box-step-scroll li:after{
    position: absolute;
    content: '';
    top: 50%;
    right: -14px;
    transform: translateY(-50%); 
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 18px 0 18px 12px;
    border-color: transparent transparent transparent #FFDDE0;
  } 
  
.sec02 .gm-box-step-scroll li:last-child:after{display: none;}

.sec02 .qsa-info{
  margin-top: 12px;
  font-size: 10px;
  font-weight: 500;
  padding: 0 20px;
  color: #707070;
}

.sec02 .qsa-info li{
  position: relative;
  padding-left: 15px;
  margin-bottom: 4px;
}

.sec02 .qsa-info li:before{
  content: '※';
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 4px;
  border-radius: 50%;
}

/* -------さらに-------- */
.sec-more .gm-cont-inner{
  background: #EFE9E5;
  padding: 35px 15px 40px 15px;
}

.sec-more .gm-cont-inner .gm-more-box{
  background: #fff;
  border-radius: 20px;
  padding: 30px 20px;
}

/* -------商品情報-------- */
.sec-goods .gm-cont-inner{
  padding: 35px 15px 0 15px;
}

.gm-kodawari-list{
  background: #fff;
  border-radius: 20px;
  padding: 35px 20px 15px;
}

.gm-kodawari-list li{
  margin-top: 20px;
  position: relative;
  padding: 70px 15px 20px;
  background: #FFFDEF;
  border-radius: 20px;
  box-shadow: 2px 1px 7px rgba(0, 0, 0, .08);
}

.gm-kodawari-goods dt figure,
.gm-kodawari-goods dd figure{
  text-align: center;
}

.gm-kodawari-goods dd{
  padding: 20px 0 0 0;
}

.gm-kodawari-goods .gm-kodawari-goods-desc p{
  margin-top: 10px;
  text-align: center;
  color: #6D2B22;
}

.gm-kodawari-goods dt img{
  width: 70vw;

}

.gm-kodawari-goods dd img{
  width: 50vw;
}

.gm-kodawari-list li .gm-kodawari-num{
  position: absolute;
  left: 0;
  top: 0;
  width: 80px;
  height: 58px;
  background: #fff;
  border-radius: 20px 0 20px;
}

.gm-kodawari-list li .gm-kodawari-num p{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 78px;
  height: 56px;  
  border-radius: 20px 0 20px;
  border-right: solid 1px #FEE9DC;
  border-bottom: solid 1px #FEE9DC; 
  text-align: center;
  font-size: 10px;
  padding: 8px 0;
}
.gm-kodawari-list li .gm-kodawari-num p span{
  width: 100%;
  color: #D10049;
}
.gm-kodawari-list li .gm-kodawari-num p span:nth-child(1){font-size: 10px;}
.gm-kodawari-list li .gm-kodawari-num p span:nth-child(2){
  font-size: 24px;
  line-height: 1;
}

.gm-kodawari-list h4{
  font-size: 18px;
  font-weight: 500;
  color: #6D2B22;
}  

.gm-kodawari-list h4 span{color: #C80033;}

.gm-kodawari-list dl{margin-top: 10px;}
.sec-goods .gm-qsa-btn{
  margin-top: 20px;
  margin-bottom: 30px;
}
.sec-goods h3{font-size: 20px;}

/* -------アンケートボタン-------- */
.gm-qsa-btn-area-bottom{
  padding: 20px 0 30px;
}

.sec-more .gm-cont-inner .gm-more-box dd p{color: #6D2B22;}
.gm-kodawari-point-list dl dt{
  color: #6D2B22;
}

/* --------------SP--------------- */
@media only screen and (max-width: 768px) {
  /* ------共通------- */
  #ginellia_monitor img{
    max-width: 100%;
    height: auto;
  }

  .gm-mv-inner{
    background: url(../../../../img/usr/freepage/ginellia_monitor/sp/mv_bg.png) no-repeat;
    background-size: cover;
  }

  .gm-qsa-btn a{
    width: 279px;
    height: 48px;
    margin: 0 auto;
  }

  .gm-box-step-scroll {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .gm-box-step-scroll {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .gm-box-step-scroll::-webkit-scrollbar {display: none;} 
  .gm-box-step-scroll img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
  }

  .gm-box-step-line-4:after{
    position: absolute;
    content: "";    
    top: -30px;
    right: -10px;
    content: "";
    width: 129.5px;
    height: 84.5px;
    background: url(../../../../img/usr/freepage/ginellia_monitor/step4_icon.png) no-repeat;
    background-size: 129.5px auto;
  }

  .gm-box-step-line-5:after{
    position: absolute;
    content: "";
    top: -30px;
    right: -10px;
    content: "";
    width: 77px;
    height: 84.5px;
    background: url(../../../../img/usr/freepage/ginellia_monitor/step5_icon.png) no-repeat;
    background-size: 77px auto;
  }
  
  .sec-more .gm-cont-inner .gm-more-box dl{
    display: flex;
    flex-wrap: wrap;
  }

  .sec-more .gm-cont-inner .gm-more-box dt{
    width: 100%;
    order: 2;
    padding: 20px 0 0;
  }
  .sec-more .gm-cont-inner .gm-more-box dd{
    order: 1;
    text-align: center;
    width: 100%;
    line-height: 1.8;    
  }
  .sec-more .gm-cont-inner .gm-more-box dd p{margin-bottom: 8px;}
   .sec02 .gm-box-step-scroll{display: grid;}
   .sec02 .gm-wrap{display: block;}
  /* .sec02 .gm-box-step-scroll ul{width: max-content;} */
  .sec02 .gm-box-step{margin-top: 28px;}
  .sec02 .gm-text-nomal-s{margin-bottom: 25px;}
  .gm-lead .gm-nomal-text{padding: 0 15px;}

}

@media only screen and (min-width: 767px) {
  .pc-only{display: block;}
  #ginellia_monitor{padding: 152px 0 0 0;}
  .gm-mv-inner{
    background: url(../../../../img/usr/freepage/ginellia_monitor/mv_bg.png) no-repeat no-repeat center bottom / cover;
    padding: 30px 0 0;
  }
  
  .gm-mv-main .gm-mv-img{order: 2;}
  .gm-mv-main .gm-mv-text{order: 1;}
  .gm-mv-main .gm-mv-img img{
    margin-top: -70px;
    max-width: 490px;
  }
  .gm-mv-text img{max-width: 309px;}
  .gm-mv-main .gm-mv-img img,
  .gm-mv-text img{
    width: auto;
    height: auto;
  }

  /* mv */
  .gm-mv-ttl{
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 6% 50px;
  }

  .gm-mv-inner .gm-mv-main{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-around;    
    max-width: 1200px;
    height: 370px;
    margin: 0 auto;
    padding: 40px 80px 40px 80px;
    box-sizing: border-box;
  }

  .sec02 .gm-wrap{
    max-width: 1600px;
    margin: 0 auto;
    padding: 80px 20px;
  }

  /* 期間 */
  .gm-mv-inner .gm-period{
    max-width: 1600px;
    margin: 45px auto 0 auto;    
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    padding: 12px 10px;
  }

  .gm-period .gm-period-ttl{
    font-size: 20px;
    font-weight: 500;
  }

  .gm-period .gm-period-day{
    margin-left: 36px;
  }
  .gm-lead{padding-top: 60px;}
  .gm-lead .gm-text-l{
    font-size: 32px;
  }
  .gm-lead .gm-text-b{
    font-size: 44px;
    margin-top: 20px;
  }

  .gm-lead .gm-nomal-text{
    font-size: 20px;
    margin-top: 40px;  
  }
  .gm-msg{margin-top: 40px;}
  .gm-msg .gm-text-m{font-size: 24px;}
  .gm-msg .gm-text-l{
    font-size: 28px;
    margin-top: 20px;
  }

  .gm-period .gm-period-day{
    font-size: 38px;
    margin: 0 0 0 34px;
  }
  .gm-period .gm-period-day .ymd{font-size: 30px;}
  .gm-period .gm-period-day .gm-week{font-size: 26px;}
  .gm-period .gm-period-day .gm-time{font-size: 30px;}
  .gm-period .gm-period-desc{
    font-size: 22px;
    margin-left: 8px;
  }

  .gm-info{
    max-width: 940px;
    margin: 30px auto 0;
    padding: 40px 15px;
    border: none;
    box-shadow: 2px 1px 7px rgba(0, 0, 0, .08);
    display: flex;
    justify-content: center;    
  }

  .gm-info li{
    font-size: 22px;
    padding-left: 60px;
    margin-bottom: 20px;
  }

  .gm-info li:after{
    width: 32px;
    height: 32px;
    background-size: 32px auto;
  }

  .sec-goods .gm-kodawari-list{
    max-width: 1600px;
    margin: 50px auto 0 auto;      
  }

  .sec-more .gm-more-box{
    max-width: 1600px;
    margin: 0 auto;    
  }

  /* sec02 */
  .sec02 .gm-box{
    max-width: 1210px;
    margin: 0 auto;
    width: 1210px;
  }

  .sec02 .gm-cont-inner{
    padding: 120px 15px 120px;
    margin-top: 120px;
  }

  .sec02 .gm-ttl-sub{
    font-size: 36px;
  }

  h2 {font-size: 52px;}
  h2 span{padding: 10px 80px;}
  h2 span::after,
  h2 span::before{
    width: 48px;
    height: 68px;
    top: 50%;
    background-size: 48px auto;
  }
  
  .sec02 h2{margin-bottom: 50px;}
  .sec02 h2 span{padding: 10px 80px;}
  .sec02 h2 span::after,
  .sec02 h2 span::before{
    width: 48px;
    height: 68px;
    top: 50%;
    background-size: 48px auto;
  }

  h3 {
    font-size: 40px;
    display: flex;
    align-items: center;
    width: 100%;
    margin-top: 48px;
    padding: 0 10px;
  }

  h3::before,
  h3::after {
    content: '';
    flex-grow: 1;
    background-image: radial-gradient(circle, #D10049 2px, transparent 2px);
    background-size: 10px 4px;
    background-repeat: repeat-x;
    height: 4px;
    background-position: center;
  }

  h3 p {padding: 0 30px;} 
  h3 p::before,
  h3 p::after{display: none;}
  .sec02 .gm-box,
  .sec02 .gm-box.gm-box-s{padding: 0;}  
  .sec02 .gm-list{
    width: 830px;
    margin: 0 auto;
    padding: 40px 0 0;
  }

  .gm-list li{
    margin-bottom: 8px;
    font-size: 20px;
  }

  .sec02 .gm-box-step{
    max-width: 1200px;
    margin: 0 auto;
  }

  .sec02 .gm-period{
    padding: 50px 0 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .sec02 .gm-period .gm-period-day{
    font-size: 33px;
    margin: 0;
  }
  .sec02 .gm-period .gm-period-day .ymd{font-size: 25px;}
  .sec02 .gm-period .gm-period-day .gm-week{font-size: 21px;}
  .sec02 .gm-period .gm-period-day .gm-time{font-size: 25px;}
  .sec02 .gm-period .gm-period-desc{
    font-size: 19px;
    margin-left: 16px;
  }
  
  .sec02 .gm-limited{
    margin-top: 48px;
  }

  .sec02 .gm-limited p span:nth-child(1){font-size: 24px;}
  .sec02 .gm-limited p span:nth-child(2){font-size: 36px;}
  .sec02 .gm-limited p span:nth-child(3){font-size: 20px;}
  .sec02 .gm-limited p span:nth-child(4){font-size: 24px;}
  .sec02 .gm-text-nomal-m{
    font-size: 24px;
    margin-top: 16px;
  }

  .sec02 .gm-text-nomal-s{
    text-align: center;
    font-size: 20px;
    margin-top: 52px;
    padding: 0 0 25px;    
  }
  .sec02 .gm-box-img{margin-top: 30px;}
  .sec02 .gm-box-img img{height: auto;}
  .sec02 .gm-box-step-inner{
    padding: 0;
    gap: 40px;
  }

  .sec02 .fukidashi-ttl{
    font-size: 36px;
  }

  .em{font-size: 28px;}

  .gm-qsa-btn a,
  .gm-btn a{
    width: 700px;
    margin: 0 auto;
    font-size: 32px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .sec02 .gm-box-step-line{
    padding: 45px 15px 40px;
    margin: 20px 40px 0;
  }

  .sec02 .gm-box-step-line .gm-step-num{
    width: 144px;
    height: 64px;    
  }

  .sec02 .gm-box-step-line .gm-step-num p{
    font-size: 22px;
    width: 142px;
    height: 62px;
  }

  .sec02 .gm-box-step-line .gm-step-num p span{
    font-size: 30px;
    margin-top: -4px;
  }

  .sec02 .gm-step-sub-ttl span{
    font-size: 24px;
  }

  .sec02 .gm-step-ttl{
    font-size: 32px;
  }

  .sec02 .gm-box-step-line > p{
    font-size: 20px;
    line-height: 1.8;
  }

  #ginellia_monitor .sec02 .gm-box-step-line > p img{
    vertical-align: middle;
    margin: 0 4px;
    width: 60px;
  }

  .sec02 .gm-step-desc{
    font-size: 16px;
  }

  .sec02 .gm-box-step-scroll ul{justify-content: center;}
  .sec02 .gm-box-step-scroll li{flex: 0 0 318px;}
  .sec02 .gm-box-step-scroll li::after{
    right: -17px;
    border-width: 20px 0 20px 15px;
  }

  .sec02 .fukidashi-ttl::after{
    border-width: 20px 30px 0 30px;
  }

  .gm-step-img{text-align: center;}
  .gm-step-arrow .gm-step-arrow{height: 55px;}
  .gm-step-arrow .gm-step-arrow::after{
    border-width: 48px 80px 0 80px;
  }

  .sec02 .gm-box-step-line.gm-box-step-line-4,
  .sec02 .gm-box-step-line.gm-box-step-line-5{margin-top: 0;}
  .sec02 .gm-step-sub-ttl span::after{top: 97%;}

  .gm-box-step-line-4:after{
    position: absolute;
    content: "";    
    top: 10px;
    right: 20px;
    content: "";
    width: 259px;
    height: 169px;
    background: url(../../../../img/usr/freepage/ginellia_monitor/step4_icon.png) no-repeat;
  }

  .gm-box-step-line-5:after{
    position: absolute;
    content: "";
    top: 20px;
    right: 30px;
    content: "";
    width: 163px;
    height: 179px;
    background: url(../../../../img/usr/freepage/ginellia_monitor/step5_icon.png) no-repeat;
  }
  .gm-qsa-btn-area{margin-top: 60px;}
  .gm-qsa-btn-area .gm-qsa-btn-ttl{font-size: 28px;}
  .sec02 .qsa-info{
    font-size: 16px;
    margin-top: 40px;
    padding: 0;
    line-height: 1.8;
  }
  .sec-more .gm-cont-inner .gm-more-box{
    margin-top: 39px;
    
  }
  .sec-more .gm-cont-inner .gm-more-box dl{
    display: flex;
  }

  .sec-more .gm-cont-inner .gm-more-box dt{
    min-width: 490px;
    flex: 1;
    padding: 0;
  }

  .sec-more .gm-cont-inner .gm-more-box dd{
    text-align: left;
    flex: 1;
    padding: 0 0 0 40px;
  }

  .sec-more .gm-cont-inner .gm-more-box dd p{
    margin-bottom: 40px;
    font-size: 22px;
    line-height: 1.8;
  }
  .sec-more .gm-cont-inner{padding: 70px 15px 120px 15px;}
  .sec-more .gm-cont-inner .gm-more-box{
    padding: 75px 15px;
  }

  .sec-more .gm-cont-inner .gm-more-box dl{
    max-width: 1200px;
    margin: 0 auto;
  }

  /* こだわり */
  .gm-kodawari-list-inner{
    max-width: 1200px;
    margin: 0 auto;
  }

  .gm-kodawari-point-list{
    max-width: 1200px;
    margin: 60px auto 0 auto;
  }
  .gm-kodawari-list{padding: 80px 15px 70px;}
  .gm-kodawari-goods .gm-kodawari-goods-desc p{
    font-size: 20px;
    line-height: 1.8;
    margin-top: 20px;
  }

  .gm-kodawari-goods{margin-bottom: 50px;}
  .gm-kodawari-goods dl{
    display: flex;
  }

  .gm-kodawari-goods dl dt{
    max-width: 520px;
    min-width: 300px;
    flex: 1;
    padding: 0;

  }

  .gm-kodawari-goods dl dt img{
    width: auto;
    height: auto;
  }

  .gm-kodawari-list dl{
    display: flex;
  }

  .gm-kodawari-point-list dl dt{
    font-size: 20px;
    line-height: 2;
    padding-top: 30px;
    flex: 1;
  }

  .gm-kodawari-point-list ul li dd{
    width: 30%;
  }

  .gm-kodawari-goods dl dd{
    padding: 0 0 0 48px;
    text-align: center;
  }

  .gm-kodawari-goods dl dd .gm-qsa-btn{width: auto;}

  .gm-kodawari-goods dl dd .gm-qsa-btn a{
    height: 80px;
    font-size: 28px;
    width: auto;
  }

  .gm-kodawari-goods dl dd img{
    max-width: 290px;
  }

  .sec-goods h3{font-size: 40px;}
  .gm-kodawari-list h4{
    text-align: left;
    padding: 0 0 0 130px;
    font-size: 34px;
  }

  .gm-kodawari-list li{
    padding: 70px 50px 20px;
    margin-top: 30px;
  }
  .gm-kodawari-list li .gm-kodawari-num{
    width: 154px;
    height: 113px;
  }

  .gm-kodawari-list li .gm-kodawari-num p{
    width: 152px;
    height: 111px;
    padding: 20px 0;    
  } 
  
  .gm-kodawari-list li .gm-kodawari-num p span:nth-child(1){
    font-size: 16px;
    font-weight: 500;
  }
  .gm-kodawari-list li .gm-kodawari-num p span:nth-child(2){
    font-size: 50px;
    font-weight: 400;  
  }
  .gm-qsa-btn-area-bottom{padding: 0 0 120px;}
  .sec-goods .gm-cont-inner{padding: 100px 15px 0 15px;}
  .sec-more img{height: auto;}

  .gm-qsa-btn a,
  .gm-btn a{
    border: 2px solid #D10049;
    transition: all .3s;
  }

  .gm-qsa-btn a:hover,
  .gm-btn a:hover{
    background: #fff;
    color: #D10049;  
  }

  .gm-qsa-list:after,
  .gm-qsa-list:before{
    font-size: 14px;
  }
  .gm-qsa-list{
    margin: 30px 0 0 0;
    padding: 40px 0 40px;
  }
  .gm-qsa-list p{font-size: 26px;}
  .gm-info .gm-info-desc{
    font-size: 16px;
    margin-top: 30px;
  }

}